在64位版本的Windows中,32位软件安装在"c:\ program files(x86)"中.这意味着你不能使用$(programfiles)来获取(32位)软件的路径.所以我需要一个$(ProgramFiles32)来克服我的MSBuild项目.我不想根据运行的操作系统更改项目.
我有一个解决方案,我会发布,但也许有一个更容易/更好的方式.
在MSBuild 4.0+中,有一个$(MSBuildProgramFiles32)
属性,你可以自信地直接使用它(特别是如果你准备把一个ToolsVersion="4.0"
放在文件的顶部以保证它可用,如果不是则快速失败).
如果您不是并且需要能够做到正确的事情即使在MSBuild 2.0或更高版本的环境中执行(即回到VS 2005环境),完整的解决方案是:
$(MSBuildProgramFiles32) $(ProgramFiles%28x86%29) $(ProgramFiles) (x86) $(ProgramFiles)
不幸的是渐进增强/填充工具的压倒一切的MSBuild保留属性名称MSBuildProgramFiles32
通过无论是
或者
被拒绝的MSBuild 4.0+,因此不能作出更为简洁并且还支持.NET 2.0.
我的解决方案是查看"c:\ program files(x86)"是否存在,如果存在,则认为这是64位操作系统.否则使用正常的程序文件目录:
$(PROGRAMFILES) (x86) $(PROGRAMFILES)
我可以像这样使用它
在MSBuild 4.0中,$(MSBuildProgramFiles32)
将为您提供32位Program Files目录.
尝试 "$(MSBuildExtensionsPath32)\.."