前端之家收集整理的这篇文章主要介绍了
xml – .csproj中的文件排序顺序,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在Visual Stu
dio csproj中,要编译的
文件被引用为:
<ItemGroup>
<Compile Include="C\Something.cs">
<Compile Include="B\SomethingElse.cs">
<Compile Include="A\YetSomethingElse.cs">
<\ItemGroup>
在我看来,订单是随机的(至少我看不到订购原则)。
在修复合并冲突时发生了几次,我错误地添加了一个文件两次(因为有很多文件,合并冲突行中的文件已经在列表中的另一个位置)。如果有一种方法来按字母顺序对Compile Included文件进行排序,这将很容易避免。
这是否可能已经(或者我必须自己写一个脚本)?我有什么副作用吗?
@H_
403_10@
我刚刚遇到这个问题,因为我们团队的更多成员没有他们的
解决方案
文件提交,我们将
文件独立
添加到
解决方案,他们迟来提交他们的
解决方案
文件,Team Foundation Server / Visual Stu
dio Online完全无法获得合并权限。
有些文件被添加了两次,有的没有添加,所有的人都有不同的顺序的文件 – 合并地狱。
我有一种工作方式,无法使用以下C#在解决方案中排序内容文件,我在令人敬畏的LinqPad中执行。
var documentsLocation = System.Environment.GetFolderPath(System.Environment.SpecialFolder.MyDocuments);
var unsortedFilePath = Path.Combine(documentsLocation.ToString(),"UnsortedConfigItems.xml");
var unsortedFile = new FileInfo(unsortedFilePath);
if (!unsortedFile.Exists) {
throw new FileNotFoundException(string.Format("The unsorted file could not be found at path {0}",unsortedFilePath));
}
var sortedFilePath = Path.Combine(documentsLocation,"SortedConfigItems.xml");
const string RootNodeName = "ItemGroup";
const string IncludeAttributeName = "Include";
var contentElementNames = new [] { "Compile","Content","None" };
var xmlFile = XDocument.Load(unsortedFile.FullName);
if (xmlFile == null || xmlFile.Root == null || xmlFile.Root.Name != RootNodeName)
{
Console.WriteLine("Invalid file or unexpected file schema");
return;
}
var allElements = xmlFile.Root.Elements();
var contentElements = new List<XElement>();
foreach(var elementName in contentElementNames) {
contentElements.AddRange(xmlFile.Root.Elements(elementName));
}
var elementsWithInclude = contentElements.Where(ce => ce.Attribute(IncludeAttributeName) != null && !string.IsNullOrWhiteSpace(ce.Attribute(IncludeAttributeName).Value));
if (!elementsWithInclude.Any())
{
Console.WriteLine("No content elements to sort");
return;
}
contentElements = null; // Make candidate for garbage collection
var uniqueElements = new List<XElement>(elementsWithInclude.Count());
foreach (var element in elementsWithInclude)
{
if (!uniqueElements.Any(e => e.Attribute(IncludeAttributeName).Value == element.Attribute(IncludeAttributeName).Value))
{
uniqueElements.Add(element);
}
}
var sortedUniqueElements = uniqueElements.OrderBy(ue => ue.Name.LocalName).ThenBy(ue => ue.Attribute(IncludeAttributeName).Value).ToList();
var remainingElements = new List<XElement>();
foreach (var element in allElements.Where(ae => !elementsWithInclude.Contains(ae))) { // This uses elements with include and not sorted unique to avoid re-adding filtered files
remainingElements.Add(element);
}
var sortedFile = new XDocument();
sortedFile.AddFirst(new XElement(RootNodeName));
sortedUniqueElements.ForEach(sue => sortedFile.Root.Add(sue));
remainingElements.ForEach(re => sortedFile.Root.Add(re));
sortedFile.Save(sortedFilePath);
我确定它可以被稍微压缩,变得更加优雅,但它为我们做了工作。
步骤完整性 –
>确保您的项目文件在源代码管理或本地备份。>右键单击解决方案资源管理器中的项目,然后选择“卸载项目”(如果项目文件未显示,并且解决方案中只有一个项目,则在Visual Studio选项中选择“始终显示解决方案”)。>项目图标应该已更改,并将列为“(不可用)”。再次右键单击并选择“编辑ProjectName.csproj”找到包含内容引用的ItemGroup节点,并剪切或复制并粘贴到一个新文件中(NotePad是理想的,但使用您选择的编辑器)并保存在XmlPathName的位置。确保“ItemGroup”节点是新XML文档的根节点。>如果需要,更改SortedPathName中的路径,并确保您的Windows用户帐户对该位置具有写入权限。>在LinqPad中运行上面的C#(或分支,并创建自己的控制台应用程序/ Powershell脚本)。>检查输出文件的内容,以确保它看起来正确(一致的行数和格式),如果可能,验证为有效的XML(记事本中的XML工具是理想的)。>将输出文件的内容复制回您的解决方案文件,替换原始的ItemGroup节点。>关闭csproj文件,右键单击解决方案资源管理器中的项目,然后选择“重新加载项目”。>如果项目是您的启动项目,则可能需要再次右键单击并选择“设为启动项目”>尝试构建