我进行了以下设置(为简便起见,删除了无趣的XML):
MyProject.fsproj
<Project ...>
<Import Project="MyTask.props" />
...
<ItemGroup>
<Compile Include="Program.fs" />
</ItemGroup>
</Project>
MyTask.props
<Project ...>
<UsingTask XXX.UpdateAssemblyInfo />
<Target Name="UpdateAssemblyInfo"
BeforeTargets="CoreCompile">
<UpdateAssemblyInfo ...>
<Output
TaskParameter="AssemblyInfoTempFilePath"
PropertyName="AssemblyInfoTempFilePath" />
</UpdateAssemblyInfo>
<ItemGroup>
<Compile Include="$(AssemblyInfoTempFilePath)" />
</ItemGroup>
</Target>
</Project>
问题是,尽管是在项目开始时就导入的,但MyTask.props添加的ItemGroup是在的最后一个的基础上添加的。我认为这是因为当时未实际导入ItemGroup-在运行任务时将其添加。
这在F#中不是一件好事,因为文件顺序很重要-在生成列表的末尾包含文件意味着无法生成EXE(例如,入口点必须在最后一个文件中)。
因此,我的问题是-我是否有办法将ItemGroup作为Target的一部分输出,并将生成的ItemGroup首先放置?
最佳答案
有点晚了,但是这可能对将来的人有所帮助,我不在此样本上使用import标记,但是它将以相同的方式工作,重要的部分是“UpdateAssemblyInfo”目标,主要思想是清除并使用适当的排序顺序重新生成Compile ItemGroup。
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Compile Include="Program.cs" />
<Compile Include="Properties\AssemblyInfo.cs" />
</ItemGroup>
<Target Name="Build" DependsOnTargets="UpdateAssemblyInfo">
</Target>
<Target Name="UpdateAssemblyInfo">
<!-- Generate your property -->
<PropertyGroup>
<AssemblyInfoTempFilePath>ABC.xyz</AssemblyInfoTempFilePath>
</PropertyGroup>
<!-- Copy current Compile ItemGroup to TempCompile -->
<ItemGroup>
<TempCompile Include="@(Compile)"></TempCompile>
</ItemGroup>
<!-- Clear the Compile ItemGroup-->
<ItemGroup>
<Compile Remove="@(Compile)"/>
</ItemGroup>
<!-- Create the new Compile ItemGroup using the required order -->
<ItemGroup>
<Compile Include="$(AssemblyInfoTempFilePath)"/>
<Compile Include="@(TempCompile)"/>
</ItemGroup>
<!-- Display the Compile ItemGroup ordered -->
<Message Text="Compile %(Compile.Identity)"/>
</Target>
</Project>
关于f# - 选择通过任务在目标中生成的ItemGroup文件的位置,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/32701909/