我正在创建一个 t4 模板并尝试在模板中初始化 nhibernate。在 t4 运行时,我收到一个错误:
无法加载文件或程序集“Network.Framework.Entities”或其依赖项之一。该系统找不到指定的文件。
我了解错误的含义,但我不知道如何将此文件提供给 t4 运行时以便它可以找到它。我已将此文件添加为程序集和导入。我已将 dll 文件放在 VS 公共程序集目录、t4 临时目录以及与模板相同的目录中。没有任何效果。
和融合日志:
从以下位置加载的程序集管理器:C:\WINNT\Microsoft.NET\Framework\v4.0.30319\clr.dll 在可执行文件 C:\program files\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe 下运行
--- 详细的错误日志如下。
=== 预绑定状态信息 ===
日志:用户 = 我自己
日志:DisplayName = Network.Framework.Entities(部分)
警告:为程序集提供了部分绑定信息:
警告:程序集名称:Network.Framework.Entities | 域 ID:77
警告:仅提供部分程序集显示名称时会发生部分绑定。
警告:这可能会导致活页夹加载不正确的程序集。
警告:建议为程序集提供完全指定的文本标识,
WRN:由简单的名称、版本、文化和公钥标记组成。
警告:有关此问题的详细信息和常见解决方案,请参阅白皮书http://go.microsoft.com/fwlink/?LinkId=109270。
日志:Appbase = file:///C:/program files/Microsoft Visual Studio 10.0/Common7/IDE/
日志:初始 PrivatePath = NULL
调用程序集:NHibernate,版本=3.3.0.4000,文化=中性,PublicKeyToken=aa95f207798dfdb4。
===
LOG:此绑定在 LoadFrom 加载上下文中开始。警告:将不会在 LoadFrom 上下文中探测本机图像。本机映像只会在默认加载上下文中进行探测,例如使用 Assembly.Load()。
LOG:使用应用程序配置文件:C:\program files\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe.Config
LOG:使用主机配置文件:
LOG:使用 C:\WINNT\Microsoft.NET\Framework\v4.0.30319\config\machine.config 中的机器配置文件。
LOG:此时未将策略应用于引用(私有、自定义、部分或基于位置的程序集绑定)。
LOG:之前看到过相同的绑定,但由于 hr = 0x80070002 失败。
这是我的模板:
<#@ template language="C#v4.0" hostspecific="True" debug="True" #>
<#@ output extension=".cs" #>
<#@ assembly name="mscorlib.dll" #>
<#@ assembly name="System.Xml.dll" #>
<#@ assembly name="System.Configuration.dll" #>
<#@ assembly name="EnvDTE.dll" #>
<#@ assembly name="$(SolutionDir)SharedDLLs\NHibernate.dll" #>
<#@ assembly name="$(SolutionDir)SharedDLLs\nunit.core.dll" #>
<#@ assembly name="$(SolutionDir)SharedDLLs\nunit.framework.dll" #>
<#@ assembly name="$(SolutionDir)SharedDLLs\NHibernate.Mapping.Attributes.dll" #>
<#@ assembly name="$(SolutionDir)SharedDLLs\Iesi.Collections.dll" #>
<#@ assembly name="$(SolutionDir)Network.Framework.Entities.Data\bin\Debug\Network.Framework.Entities.Data.dll" #>
<#@ assembly name="$(SolutionDir)Network.Framework.Entities\bin\Debug\Network.Framework.Entities.dll" #>
<#@ import namespace="System.Diagnostics" #>
<#@ import namespace="System.Configuration" #>
<#@ import namespace="System.Reflection" #>
<#@ import namespace="System.Collections.Generic" #>
<#@ import namespace="Network.Framework.Entities.Data.BL" #>
<#@ import namespace="Network.Framework.Entities" #>
<#@ import namespace="NHibernate" #>
<#@ import namespace="NHibernate.Cfg" #>
<#@ import namespace="NHibernate.Mapping.Attributes" #>
<#@ import namespace="EnvDTE" #>
<#@ import namespace="Network.Framework.Entities.DAL" #>
<#@ import namespace="System.Xml" #>
<#
System.Diagnostics.Debugger.Launch();
string path = Host.ResolvePath(@"..\Network.Framework.Entities\NHibernate.MSSQL.Config.xml");
T4DataAccess<ReferenceValue> dal = CreateDataAccess<ReferenceValue>(path);
ReferenceValueBL bl = new ReferenceValueBL(dal);
#>
using System;
namespace Network.Framework.Entities
{
public class ReferenceValueKey
{
<#
List<ReferenceValue> refVals = bl.Select();
foreach(ReferenceValue rv in refVals)
{
Write("Public ");
Write(rv.ReferenceValueCode.GetType().Name);
Write(" ");
Write(rv.ReferenceValueCode);
Write(" = ");
Write(rv.ReferenceValueCode);
}
#>
}
}
<#+
public ISessionFactory GetDBSession(string nHibernateConfigPath)
{
NHibernate.Cfg.Configuration cfg = new NHibernate.Cfg.Configuration().Configure(nHibernateConfigPath);
var assembly = System.Reflection.Assembly.GetAssembly(typeof(Network.Framework.Entities.PlanCode));
var serializedAssembly = HbmSerializer.Default.Serialize(assembly);
cfg.AddInputStream(serializedAssembly);
return cfg.BuildSessionFactory();
}
public T4DataAccess<T> CreateDataAccess<T>(string nHibernateConfigPath) where T : class
{
ISessionFactory db = GetDBSession(nHibernateConfigPath);
return new T4DataAccess<T>(db);
}
#>