我有以下情况。我们使用存储过程来访问数据库,我们使用 LiNQ 2 SQL 来生成类,或者我们为此使用 Unplugged LINQ to SQL Generator。它已作为自定义工具运行,但区分生成的类是一件很头疼的事。我们想自动生成这些类,但将其从版本控制中排除,所以我设置了创建 msbuild 任务的任务。找到了这篇文章和这篇文章,但我自己无法解决这个问题。我添加了一些代码,任务如下所示:
public class GenerateDesignerDC : Task
{
public ITaskItem[] InputFiles { get; set; }
public ITaskItem[] OutputFiles { get; set; }
public override bool Execute()
{
var generatedFileNames = new List<string>();
foreach (var task in InputFiles)
{
string inputFileName = task.ItemSpec;
string outputFileName = Path.ChangeExtension(inputFileName, ".Designer.cs");
string result;
// Build code string
var generator = new ULinqCodeGenerator("CSharp");
string fileContent;
using (FileStream fs = File.OpenRead(inputFileName))
using (StreamReader rd = new StreamReader(fs))
{
fileContent = rd.ReadToEnd();
}
using (var destination = new FileStream(outputFileName, FileMode.Create))
{
byte[] bytes = Encoding.UTF8.GetBytes(generator.BuildCode(inputFileName, fileContent));
destination.Write(bytes, 0, bytes.Length);
}
generatedFileNames.Add(outputFileName);
}
OutputFiles = generatedFileNames.Select(name => new TaskItem(name)).ToArray();
return true;
}
}
现在我尝试为此添加一个名为 custom.target 的自定义目标
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<CoreCompileDependsOn>$(CoreCompileDependsOn);GenerateToolOutput</CoreCompileDependsOn>
</PropertyGroup>
<UsingTask TaskName="BuildTasks.GenerateDesignerDC" AssemblyFile="BuildTasks.dll" />
<Target Name="GenerateToolOutput" Inputs="@(dbml)" Outputs="@(dbml->'$(IntermediateOutputPath)%(FileName).designer.cs')">
<GenerateDesignerDC InputFiles="@(dbml)" OutputFiles="@(dbml->'$(IntermediateOutputPath)%(FileName).designer.cs')">
<Output ItemGroup="Compile" TaskParameter="OutputFiles" />
</GenerateDesignerDC>
</Target>
</Project>
我还将必要的 ItemGroups 添加到项目文件中,如下所示:
<ItemGroup>
<AvailableItemName Include="dbml" />
</ItemGroup>
<ItemGroup>
<Compile Include="@(dbml)" />
</ItemGroup>
最后,我使用以下内容将文件添加到项目中:
<dbml Include="DAL\SettingsDC.dbml">
<SubType>Designer</SubType>
<Generator>ULinqToSQLGenerator</Generator>
<LastGenOutput>SettingsDC.designer.cs</LastGenOutput>
</dbml>
这会导致错误消息说
“GenerateDesignerDC”任务的输出规范无效。“TaskParameter”属性是必需的,并且必须指定“ItemName”或“PropertyName”属性(但不能同时指定)。
我需要做什么才能完成这项工作?