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

标签 .net visual-studio-2005 gac

我们如何才能使 .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/

相关文章:

c++ - 无论如何我可以在 visual studio 2005 上使用 visual studio 2015 运行一个已经编码的项目

c++ - 有符号和无符号的位移位操作

php - Visual Studio PHP

c# - GAC 与 JIT

javascript - 从全日历的月 View 中鼠标悬停时未显示工具提示?

.net - "ApplicationServices"是横切关注点 "stuff"的正确名称吗?

.net - 逗号分隔数的正则表达式

c# - .Net/C# - 使用 GAC 的优缺点

.net - 去GAC,还是不去GAC?

.net - Gacutil.exe 成功添加程序集,但程序集在资源管理器中不可见。为什么?