dotnet-cstomd 2.0.1

dotnet tool install --global dotnet-cstomd --version 2.0.1                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local dotnet-cstomd --version 2.0.1                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=dotnet-cstomd&version=2.0.1                
nuke :add-package dotnet-cstomd --version 2.0.1                

CsToMd

Idea and Overview

NuGet Badge

The dotnet CLI tool to generate the Markdown documentation file from the C# file.

The idea is to have a normal C# .cs file with the special comments /*md, md*/, and //md which will be stripped when converting the file into the respective Markdown .md file. There are couple of additional features but this is basically it.

Now you have the documentation always up-to-date with the runnable samples in the normal .NET Test library project with NUnit, XUnit, etc.

You may check the DryIoc documentation project for the real-world case example.

The additional features since v1.2.0:

  • Converting the section outlined with //md{ and //md} comments int the collapsed markdown details.
  • The optional cstomd.config file in the folder with the lines starters to be removed completely from the generated documentation file.

Dotnet CLI tool

The dotnet-cstomd is a dotnet CLI tool. It may be called from the command line and from the MSBuild scripts (enabling the document generation in the build pipeline).

I addition the dotnet tool enables the documentation development in the Visual Studio Code.

VSCode usage

How to use

  • Install the dotnet-cstomd globally from the nuget, e.g. in the shell of your choice dotnet tool install --global dotnet-cstomd --version 2.0.1. Now you can invoke cstomd MyClass.cs directly and get the MyClass.md output.

Build integration

  • Switch to your project: cd path\to\MyProject

  • Add the tool manifest file: dotnet new tool-manifest

  • Install the tool: dotnet tool install --global dotnet-cstomd --version 1.2.1 (the manifest file will be updated and later used for restore)

  • Add the section to you project:

    <ItemGroup>
        <DocFile Include="**\*.cs" />
    </ItemGroup>
    
    <Target Name="MdGenerate" BeforeTargets="BeforeBuild">
        <Exec WorkingDirectory="$(ProjectDir)" Command="dotnet cstomd %(DocFile.Identity)" />
    </Target>
    

    You may check the DryIoc documentation project file for the real-world case example.

  • You may run the document generation target without the rest the build:

 dotnet msbuild -target:MdGenerate path\to\MyProject\MyProject.csproj

You may create a helper build_the_docs file and store the command there.

Here is the MS tutorial for installing and using the local tools.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
2.0.1 244 9/14/2024
1.2.1 1,668 8/31/2020
1.2.0 426 8/28/2020
1.0.0-preview-04 316 8/24/2020
1.0.0-preview-03 304 8/21/2020
1.0.0-preview-02 318 8/21/2020
1.0.0-preview-01 285 8/21/2020

## v2.0.0 - Major release

- breaking: Updated to run in .NET 6.0 instead of .NET Core 3.1
- adding: readme.md file to the package


## v1.2.1 - Bug-fix release

- added: Adding the new line after the collapsible section otherwise it breaks the markdown


## v1.2.0 - Feature release

- added: #3 Make it to dotnet CLI tool (dotnet-cstomd)
- added: #4 Ability to remove specific lines from the md output (cstomd.config)
- added: #6 Add the special comments to wrap the section into collapsible details enhancement
- added: #7 Strip the comment from the line with `//md` enhancement