为 Roslyn 分析器提供依赖项的正确方法是什么?

Sam*_*der 7 .net nuget roslyn roslyn-code-analysis

我们已经开始将 Roslyn 分析器包含在我们的一些库中,以使我们的开发人员更容易发现这些库的功能。

为了促进这一点,我们有一个分析器使用的共享库。因此,我们有共享组件, Company.Roslyn.dll并且Company.Collections.VisualStudio.dll包含分析器并且依赖于该共享组件。当我们创建 nuget 时,Company.Collections我们包含如下依赖项:

<file src="Build\Company.Collections.VisualStudio.dll" target="analyzers\dotnet\cs" />
<file src="Build\Company.Roslyn.dll" target="analyzers\dotnet\cs" />
Run Code Online (Sandbox Code Playgroud)

当安装程序运行时,它会将两个 dll 作为分析器添加到项目文件中。

现在我们已经创建了第二个分析器 dll,它依赖于它,Company.Roslyn.dll我们最终在项目的分析器列表中得到了 2 个实例。

我的第一个问题是,这是正确的吗?实际上并不Company.Roslyn.dll包含任何分析器,那么是否应该将其添加为分析器?如果我不这样做,那么在某些情况下我会收到一条警告,提示应将依赖项添加为分析器......

我的第二个更普遍的问题是我们应该如何管理分析器的依赖关系,我的感觉是它们应该只部署在文件夹中,而不是分析器,所以它只是install.ps1存在问题的默认脚本吗?这应该只添加实际的分析器dll?

Tam*_*mas 3

在 VS 2015 中,仅添加analyzer.dll 是不够的。所有参考文献也必须添加。我不确定VS2017中是否对此进行了改进。

两个单独的分析器具有相同的依赖性通常不是问题。尽管依赖项在解决方案资源管理器树中出现了两次,但 VS 只会将 DLL 加载到内存中一次。(除非 DLL 是强类型的,并且您部署了两个不同的版本)请注意,依赖项也在 nuget 分析器包和分析器 VSIX 扩展之间共享。