У меня есть следующий сценарий. Мы используем хранимые процедуры для доступа к базе данных и используем 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» должен быть
указано (но не оба).
Что мне нужно сделать, чтобы сделать эту работу?