在编译期间使用 Roslyn/MSBuild 自带的方法/函数判断、计算和修改属性

2023-10-22 10:03:39 浏览数 (2)

充分利用 MSBuild 自带的方法,可以在编译期间完成大多数常见的属性转换,而不再需要自己专门写库来完成。

本文介绍如何使用 MSBuild 自带的方法,并列举 MSBuild 中各种自带的方法。


如何在编译期间使用 MSBuild 自带的方法

当然,在修改编译期间的代码的时候,你可能需要提前了解项目文件相关的知识:

  • 理解 C# 项目 csproj 文件格式的本质和编译流程

以下是使用 MSBuild 自带方法的最简单的一个例子,执行 5-1 的数学运算。

1

<Walterlv>$(MSBuild::Subtract(5, 1))</Walterlv>

更复杂的,可能是 MSBuild 方法调用的嵌套了:

1

<WalterlvPath Condition="HasTrailingSlash('$(WalterlvPath)')">$(WalterlvPath.Substring(0, $(MSBuild::Add($(WalterlvPath.Length), -1))))</WalterlvPath>

以上两段示例分别来自我的另外两篇博客,如果不明白,可以参考这两篇博客的内容:

  • 在 Roslyn/MSBuild 中进行基本的数学运算
  • Roslyn/MSBuild 在编译期间处理路径中的斜杠与反斜杠

MSBuild 自带的方法

数学运算

MSBuild 中数学运算的部分可以参考我的另一篇博客:

  • 在 Roslyn/MSBuild 中进行基本的数学运算

EnsureTrailingSlash

确保路径结尾有斜杠。

可参考我的另一篇博客:

  • Roslyn/MSBuild 在编译期间处理路径中的斜杠与反斜杠

GetDirectoryNameOfFileAbove & GetPathOfFileAbove

这两个是非常有用却又非常容易被忽视的 API,非常有必要介绍一下。

可以阅读我的另一篇博客了解其用途和用法:

  • Roslyn/MSBuild 在编译期间从当前文件开始查找父级文件夹,直到找到包含特定文件的文件夹

MakeRelative

计算两个路径之间的相对路径表示。

1 2 3 4 5 6

<PropertyGroup> <Path1>C:Walterlv</Path1> <Path2>C:WalterlvDemo</Path2> <WalterlvPath1>$(MSBuild::MakeRelative($(Path1), $(Path2)))</WalterlvPath1> <WalterlvPath2>$(MSBuild::MakeRelative($(Path2), $(Path1)))</WalterlvPath2> </PropertyGroup>

WalterlvPath1 的值会计算为 Demo,而 WalterlvPath2 的值会计算为 ..

ValueOrDefault

如果赋值了,就使用所赋的值;否则使用参数指定的值:

1 2 3 4

<PropertyGroup> <WalterlvValue1>$(MSBuild::ValueOrDefault('$(FooBar)', 'walterlv'))</WalterlvValue1> <WalterlvValue2>$(MSBuild::ValueOrDefault('$(WalterlvValue1)', 'lindexi'))</WalterlvValue2> </PropertyGroup>

第一行,因为我们没有定义任何一个名为 FooBar 的属性,所以 WalterlvValue1 属性会计算得到 walterlv 值。第二行,因为 WalterlvValue1 已经得到了一个值,所以 WalterlvValue2 也会得到 WalterlvValue1 的值,也就是 walterlv,不会得到 lindexi

其他

MSBuild 剩下的一些方法使用场景非常有限(不懂就别瞎装懂了),这里做一些简单的介绍。

  • $([MSBuild]::DoesTaskHostExist(string theRuntime, string theArchitecture))
    • 可参见:msbuild/Microsoft.Common.overridetasks at master · microsoft/msbuild
  • GetRegistryValue
  • GetRegistryValueFromView

参考资料

  • Property Functions - Visual Studio - Microsoft Docs

本文会经常更新,请阅读原文: https://blog.walterlv.com/post/msbuild-property-functions.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系 ([email protected]) 。

0 人点赞