gpt4 book ai didi

.net - 使构建过程独立于 GAC

转载 作者:行者123 更新时间:2023-12-03 23:45:56 32 4
gpt4 key购买 nike

我们如何才能使 .NET 项目的构建过程 (Dev Studio 2005) 完全独立于运行它的特定机器上的 GAC 上安装的内容。

这是我们要解决的问题:根据碰巧安装到 GAC 中的程序集,我们的构建过程会在输出目录中生成不同的 .NET 程序集,然后我们使用这些程序集来构建 .MSI

这大概是因为开发工作室假设,因为它安装在 GAC 中,所以它不应该作为我们产品的一部分安装。

我们希望禁用此行为,以便将项目直接或间接引用的所有 .NET 程序集复制到项目的输出目录中(.NET 2.0 运行时标准程序集除外)。

对于直接程序集引用,我知道设置“Copy Local=True”可以做到这一点。

但是,这不适用于间接程序集引用。

即我们的一个项目引用了一个名为“A.dll”的程序集,它依赖于另一个名为“B.dll”的程序集,该程序集与“A.dll”位于同一目录中。在 GAC 中未安装“B.dll”的机器上,A.dll 和 B.dll 都将复制到 Dev studio 构建过程中的输出目录。这就是我们想要的。

但是在将 B.dll 安装到 GAC 的机器上,即使 A.dll 的“Copy Local = True”,B.dll 也不会被复制到输出目录中。

最佳答案

就像 Marc 建议的那样,唯一的方法是添加依赖引用并设置 CopyLocal=True。

但我开始同意 Danny 的回答 - 不要使用 Dev Studio 进行部署,因为您无法充分控制构建过程。

为什么? Dev Studio 有一些“默认”逻辑,如果它已经计算了一个属性的值,那么它不会将它保存到 .CSPROJ 文件中,而将 Dev Studio 实例留在另一台机器上的任务是“默认” “把属性(property)换成别的东西了!

唯一没有错误的方法是直接显式编辑 .csproj xml 文件并确保您已将 True 添加到 Reference 元素:

<ItemGroup>
<Reference Include="ConfigManagerClient, Version=1.0.0.0, Culture=neutral, PublicKeyToken=20fc1ffb797ec904, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>..\..\thirdparty\CM\ConfigManagerClient.dll</HintPath>
<!-- If DevStudio inferred this to be true, then it won't explicitly save it.
When the project is loaded on another machine on which the assembly is
installed in the GAC,
Dev Studio on _that_ machine will infer that CopyLocal should be False!!
-->
<Private>True</Private>
</Reference>

这种行为似乎使得几乎不可能知道您的 .CSPROJ 文件在另一台机器上运行时会做什么。

从长远来看,最好不要将构建和打包过程委托(delegate)给 Dev Studio,而只是使用 Nant 和显式命令行。

关于.net - 使构建过程独立于 GAC,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/516217/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com