使用装配属性的最佳做法是什么?

时间:2008-09-15 12:31:11

标签: .net assemblies attributes assemblyinfo

我有一个多项目的解决方案。我试图通过链接一个解决方案范围的程序集信息文件来优化AssemblyInfo.cs文件。这样做的最佳做法是什么?哪些属性应该在解决方案范围的文件中,哪些属于项目/程序集特定?


编辑:如果您有兴趣,可以跟进问题What are differences between AssemblyVersion, AssemblyFileVersion and AssemblyInformationalVersion?

8 个答案:

答案 0 :(得分:204)

我们使用名为GlobalAssemblyInfo.cs的全局文件和名为AssemblyInfo.cs的本地文件。全局文件包含以下属性:

 [assembly: AssemblyProduct("Your Product Name")]

 [assembly: AssemblyCompany("Your Company")]
 [assembly: AssemblyCopyright("Copyright © 2008 ...")]
 [assembly: AssemblyTrademark("Your Trademark - if applicable")]

 #if DEBUG
 [assembly: AssemblyConfiguration("Debug")]
 #else
 [assembly: AssemblyConfiguration("Release")]
 #endif

 [assembly: AssemblyVersion("This is set by build process")]
 [assembly: AssemblyFileVersion("This is set by build process")]

本地AssemblyInfo.cs包含以下属性:

 [assembly: AssemblyTitle("Your assembly title")]
 [assembly: AssemblyDescription("Your assembly description")]
 [assembly: AssemblyCulture("The culture - if not neutral")]

 [assembly: ComVisible(true/false)]

 // unique id per assembly
 [assembly: Guid("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx")]

您可以使用以下过程添加GlobalAssemblyInfo.cs:

  • 在项目的上下文菜单中选择添加/现有项目
  • 选择GlobalAssemblyInfo.cs
  • 点击右侧的小向下箭头
  • 展开添加按钮
  • 在按钮下拉列表中选择“添加为链接”

答案 1 :(得分:19)

就我而言,我们正在构建一个产品,我们有一个Visual Studio解决方案,在他们自己的项目中有各种组件。共同的属性去了。在该解决方案中,大约有35个项目和一个通用程序集信息(CommonAssemblyInfo.cs),它具有以下属性:

[assembly: AssemblyCompany("Company")]
[assembly: AssemblyProduct("Product Name")]
[assembly: AssemblyCopyright("Copyright © 2007 Company")]
[assembly: AssemblyTrademark("Company")]

//This shows up as Product Version in Windows Explorer
//We make this the same for all files in a particular product version. And increment it globally for all projects.
//We then use this as the Product Version in installers as well (for example built using Wix).
[assembly: AssemblyInformationalVersion("0.9.2.0")]

我们在每个程序集的基础上提供其他属性,例如AssemblyTitle,AssemblyVersion等。构建程序集时,AssemblyInfo.cs和CommonAssemblyInfo.cs都内置于每个程序集中。这为我们提供了两个世界中最好的东西,你可能想要为所有项目提供一些共同的属性,为其他项目提供特定的值。

希望有所帮助。

答案 2 :(得分:13)

@JRoppert提出的解决方案与我的解决方案几乎相同。唯一的区别是我将以下行放在本地AssemblyInfo.cs文件中,因为它们可能因每个程序集而异:

#if DEBUG
[assembly: AssemblyConfiguration("Debug")]
#else
[assembly: AssemblyConfiguration("Release")]
#endif
[assembly: AssemblyVersion("This is set by build process")]
[assembly: AssemblyFileVersion("This is set by build process")]
[assembly: CLSCompliant(true)]

我也(通常)每个解决方案使用一个通用的装配信息,假设一个解决方案是单个产品系列/可释放产品。通用程序集信息文件还包含:

[assembly: AssemblyInformationalVersion("0.9.2.0")]

这将设置Windows资源管理器显示的“ProductVersion”值。

答案 3 :(得分:8)

MSBuild Community Tasks包含一个名为AssemblyInfo的自定义任务,您可以使用它来生成assemblyinfo.cs。它需要对您的csproj文件进行一些手动编辑才能使用,但这是值得的。

答案 4 :(得分:5)

在我看来,使用GlobalAssemblyInfo.cs比它值得更麻烦,因为你需要修改每个项目文件并记住修改每个新项目,而默认情况下你得到一个AssemblyInfo.cs。 p>

对于全球价值观的变化(即公司,产品等),这些变化通常很少且易于管理我不认为DRY应该是一个考虑因素。如果要手动将所有项目中的值更改为一次性,只需运行以下MSBuild脚本(取决于MSBuild Extension Pack):

<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" DefaultTargets="UpdateAssemblyInfo" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">

    <ItemGroup>
        <AllAssemblyInfoFiles Include="..\**\AssemblyInfo.cs" />
    </ItemGroup>

    <Import Project="MSBuild.ExtensionPack.tasks" />

  <Target Name="UpdateAssemblyInfo">
    <Message Text="%(AllAssemblyInfoFiles.FullPath)" />
    <MSBuild.ExtensionPack.Framework.AssemblyInfo 
        AssemblyInfoFiles="@(AllAssemblyInfoFiles)"
        AssemblyCompany="Company"
        AssemblyProduct="Product"
        AssemblyCopyright="Copyright"
        ... etc ...
        />
  </Target>

</Project>

答案 5 :(得分:3)

要在多个项目之间共享文件,您可以将现有文件添加为链接。

为此,请添加现有文件,然后在文件选择器中点击“添加为链接”。Add As Link
(来源:free.fr

至于要放在共享文件中的内容,我建议放置将在程序集之间共享的内容。像版权,公司,也许是版本。

答案 6 :(得分:1)

不建议对多个项目使用单个AseemblyInfo.cs文件。 AssemblyInfo文件包含可能仅与该特定程序集相关的信息。最明显的两条信息是AssemblyTitleAssemblyVersion

更好的解决方案可能是使用由MSBuild处理的targets文件,以便将程序集属性“注入”多个项目。

答案 7 :(得分:1)

我发现有用的一件事是通过在预构建阶段应用令牌替换来生成AssemblyVersion元素(等)。

我使用TortoiseSvn,并且很容易使用其SubWCRev.exe将模板AssemblyInfo.wcrev转换为AssemblyInfo.cs。模板中的相关行可能如下所示:

[assembly: AssemblyVersion("2.3.$WCREV$.$WCMODS?1:0$$WCUNVER?1:0$")]

第三个元素是修订号。我使用第四个元素来检查我没有忘记提交任何新的或更改的文件(如果一切正常,第四个元素是00)。

顺便提一下,如果您使用此版本控件,请添加AssemblyInfo.wcrev忽略 AssemblyInfo.cs