120

我正在为 C# 类库创建一个 NuGet 包,并且我想将生成的 Xml 文档包含在该库中。这是我的 nuspec 文件:

<?xml version="1.0" encoding="utf-8"?>
<package>
  <metadata>
    <id>MyLibrary</id>
    <version>1.0.0.0</version>
    <authors>John Nelson</authors>
    <language>en-US</language>
    <description>A C# class library</description>
  </metadata>
  <files>
    <file src="..\..\build\MyLibrary.dll" target="lib\Net40" />
    <file src="..\..\build\MyLibrary.xml" target="lib\Net40" />
  </files>
</package>

当我使用此命令构建包时

nuget pack MyLibrary.nuspec

它会产生错误。如果我删除该行:

<file src="..\..\build\MyLibrary.xml" target="lib\Net40" />

NuGet.exe 成功创建 nupkg。我什至可以解压缩包,并验证内容是否正确。我究竟做错了什么?xml 文件是否应该进入不同的目标目录?

4

2 回答 2

109

问题是我没有检查我正在使用的构建配置的“生成 Xml 文档”。那个 nuspec 是正确的。

在此处输入图像描述

于 2011-03-07T01:07:33.717 回答
26

在 .NET Core/Standard 中,您可以通过编辑项目 XML 文件来执行此操作,例如:

<PropertyGroup>
    <TargetFramework>netstandard2.0</TargetFramework>
    <GenerateDocumentationFile>true</GenerateDocumentationFile>
</PropertyGroup>

<PropertyGroup>
    <DocumentationFile>bin\$(Configuration)\$(TargetFramework)\$(AssemblyName).xml</DocumentationFile>
</PropertyGroup>

这会将文档作为 XML 文件输出到您的输出程序集旁边。

编辑: 作为附带说明,一旦启用GenerateDocumentationFile,您可能会在公共方法上收到很多警告,因为您没有添加完整的文档标签。如果您想禁用这些警告,只需添加PropertyGroup

<NoWarn>$(NoWarn);1591</NoWarn>
于 2019-09-30T10:13:21.983 回答