RhoMicro.Staple.Analyzers 1.0.2

Prefix Reserved
dotnet add package RhoMicro.Staple.Analyzers --version 1.0.2
                    
NuGet\Install-Package RhoMicro.Staple.Analyzers -Version 1.0.2
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="RhoMicro.Staple.Analyzers" Version="1.0.2" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="RhoMicro.Staple.Analyzers" Version="1.0.2" />
                    
Directory.Packages.props
<PackageReference Include="RhoMicro.Staple.Analyzers" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add RhoMicro.Staple.Analyzers --version 1.0.2
                    
#r "nuget: RhoMicro.Staple.Analyzers, 1.0.2"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package RhoMicro.Staple.Analyzers@1.0.2
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=RhoMicro.Staple.Analyzers&version=1.0.2
                    
Install as a Cake Addin
#tool nuget:?package=RhoMicro.Staple.Analyzers&version=1.0.2
                    
Install as a Cake Tool

RhoMicro.Staple

This is a library for accessing documentation comments at runtime.

Licensing

This work is licensed to you under the MPL-2.0 license.

Features

  • Parses XML documentation into typed content objects.
  • Reads documentation from XML sources, parsed Documentation objects, or assemblies, loading the associated XML documentation file automatically when present.
  • Exposes Documentation lookup as extension members on Assembly, Type, and MemberInfo.
  • Preserves common XML documentation elements such as summary, remarks, example, typeparam, param, and inline formatting nodes.
  • Caches discovered documentation for repeated lookups.

Installation

Library:

dotnet add package RhoMicro.Staple

Generator:

dotnet add package RhoMicro.Staple.Analyzers

How To Use

Annotate your types with docs comments:

namespace Foo
{
    /// <summary>This is the <c>Bar</c> class.</summary>
    public static class Bar
    {
        /// <summary>This is the <see cref = "Baz"/> method.</summary>
        /// <returns>This method always returns <c>0</c> (<see langword="default"/>).</returns>
        public static int Baz() => 0;
    }
}

Retrieve them using reflection:

var barSummary = typeof(Bar).Documentation?.Summary?.InnerXml;
var baz = typeof(Bar).GetMethod("Baz");
var bazSummary = baz?.Documentation?.Summary?.InnerXml;
var bazReturns = baz?.Documentation?.Returns?.InnerXml;
Assert.Equal("This is the <c>Bar</c> class.", barSummary);
Assert.Equal("This is the <see cref=\"M:Foo.Bar.Baz\"/> method.", bazSummary);
Assert.Equal("This method always returns <c>0</c> (<see langword=\"default\"/>).", bazReturns);

Create Documentation Manually

Create a DocumentationContext instance. Assemblies passed to DocumentationContext.Create(...) automatically load their associated XML documentation file when one is available:

var context = DocumentationContext.Create("""
                <members>
                <member name="T:Foo.Bar">
                <summary>This is an artificial summary.</summary>
                </member>
                </members>
                """);
var barSummary = context.GetContent(typeof(Bar).DocumentationId)?.Summary?.InnerXml;
Assert.Equal("This is an artificial summary.", barSummary);

Create Artificial Documentation

You can add the XmlDocumentationAttribute to your assembly manually and access those docs through the same API. The source generator can automate that when you do not want to emit a docs XML file.

The analyzer package provides a generator for attaching documentation in metadata via assembly attributes as opposed to an XML file (GenerateDocumentationFile).

There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.0.2 40 6/16/2026
1.0.1 39 6/16/2026
1.0.0 44 6/16/2026
0.0.0-prerelease5 45 6/15/2026
0.0.0-prerelease4 51 6/15/2026
0.0.0-prerelease3 52 6/15/2026