如何在 Visual Studio 中抑制程序集引用警告?
How to suppress assembly reference warnings in Visual Studio?
在 Visual Studio 2015 年,我想取消此类警告:
但是,它们似乎没有警告标识符,所以我无法应用 this.
等解决方案
我理解这些警告,但它们不能以友好的方式解决,所以我想隐藏它们,我的项目已经正确处理这些程序集,但我将解释为什么警告不能解决:
我的解决方案有两种解决方案配置,一种用于在 .NetFx4 下编译解决方案,另一种用于 .NetFx45,为此我使用条件编译常量和手动步骤,因为我需要手动更改目标框架更改解决方案配置后的解决方案,因此当解决方案配置为以 .NetFx4 而不是 .NetFx45 为目标时,程序集会发出警告,但是,在解决方案资源管理器中,程序集设置为从不将它们复制到 deplyment 文件夹,并且 类 导入那些程序集在条件编译常量内,所以确实存在出错的风险。
这些是 MSBuild 警告,不是编译器或代码分析警告。您应该能够在 Visual Studio 输出 window 中看到错误代码(例如:MSB3268
),即使它们没有出现在错误列表中也是如此。
也就是说,隐藏这些并不是微不足道的,因为 pragmas 和 SuppressMessage
attributes 都不适用于这些。 MSBuild ResolveAssemblyReference
任务会生成这些警告,虽然它确实具有似乎旨在帮助防止生成警告的属性,但它们在针对 v4.0 框架时无法完全发挥作用。 (即使它们确实有效,使用它们也需要覆盖通过 Microsoft.CSharp.targets
导入的 ResolveAssemblyReferences
目标以将值推送到任务属性,这会增加长期维护的麻烦)。
有一件事实际上对这里有帮助:指出在针对 4.0 框架时不应包含引用。例如(在您的 .csproj
文件中):
<ItemGroup>
<Reference Include="System" />
<Reference Include="System.Core" />
...
</ItemGroup>
<ItemGroup Condition="'$(TargetFrameworkVersion)' != 'v4.0'">
<Reference Include="Microsoft.Experimental.IdentityModel.Clients.ActiveDirectory, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
<HintPath>..\packages\Microsoft.Experimental.IdentityModel.Clients.ActiveDirectory.4.0.209160138-alpha\lib\net45\Microsoft.Experimental.IdentityModel.Clients.ActiveDirectory.dll</HintPath>
<Private>True</Private>
</Reference>
...
</ItemGroup>
重要的一点是第二个 ItemGroup
的条件,它指示 MSBuild 只有在目标框架不是 4.0 时才将引用包含在组中。
由于这种方法非常符合您的意图,因此似乎比抑制警告更可取(即使这是可能的)。但是,有一个小问题:IDE 仍会为每个直接引用的程序集生成一个 "the referenced component could not be found" 警告,而且似乎没有任何办法可以防止这种情况发生。另一方面,每个直接引用的排除程序集的一个警告已经比每个直接引用的程序集引用的每个框架程序集的一个警告要好得多...
在 Visual Studio 2015 年,我想取消此类警告:
但是,它们似乎没有警告标识符,所以我无法应用 this.
等解决方案我理解这些警告,但它们不能以友好的方式解决,所以我想隐藏它们,我的项目已经正确处理这些程序集,但我将解释为什么警告不能解决:
我的解决方案有两种解决方案配置,一种用于在 .NetFx4 下编译解决方案,另一种用于 .NetFx45,为此我使用条件编译常量和手动步骤,因为我需要手动更改目标框架更改解决方案配置后的解决方案,因此当解决方案配置为以 .NetFx4 而不是 .NetFx45 为目标时,程序集会发出警告,但是,在解决方案资源管理器中,程序集设置为从不将它们复制到 deplyment 文件夹,并且 类 导入那些程序集在条件编译常量内,所以确实存在出错的风险。
这些是 MSBuild 警告,不是编译器或代码分析警告。您应该能够在 Visual Studio 输出 window 中看到错误代码(例如:MSB3268
),即使它们没有出现在错误列表中也是如此。
也就是说,隐藏这些并不是微不足道的,因为 pragmas 和 SuppressMessage
attributes 都不适用于这些。 MSBuild ResolveAssemblyReference
任务会生成这些警告,虽然它确实具有似乎旨在帮助防止生成警告的属性,但它们在针对 v4.0 框架时无法完全发挥作用。 (即使它们确实有效,使用它们也需要覆盖通过 Microsoft.CSharp.targets
导入的 ResolveAssemblyReferences
目标以将值推送到任务属性,这会增加长期维护的麻烦)。
有一件事实际上对这里有帮助:指出在针对 4.0 框架时不应包含引用。例如(在您的 .csproj
文件中):
<ItemGroup>
<Reference Include="System" />
<Reference Include="System.Core" />
...
</ItemGroup>
<ItemGroup Condition="'$(TargetFrameworkVersion)' != 'v4.0'">
<Reference Include="Microsoft.Experimental.IdentityModel.Clients.ActiveDirectory, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
<HintPath>..\packages\Microsoft.Experimental.IdentityModel.Clients.ActiveDirectory.4.0.209160138-alpha\lib\net45\Microsoft.Experimental.IdentityModel.Clients.ActiveDirectory.dll</HintPath>
<Private>True</Private>
</Reference>
...
</ItemGroup>
重要的一点是第二个 ItemGroup
的条件,它指示 MSBuild 只有在目标框架不是 4.0 时才将引用包含在组中。
由于这种方法非常符合您的意图,因此似乎比抑制警告更可取(即使这是可能的)。但是,有一个小问题:IDE 仍会为每个直接引用的程序集生成一个 "the referenced component could not be found" 警告,而且似乎没有任何办法可以防止这种情况发生。另一方面,每个直接引用的排除程序集的一个警告已经比每个直接引用的程序集引用的每个框架程序集的一个警告要好得多...