dotMorten.OmdGenerator
1.0.0
See the version list below for details.
dotnet tool install --global dotMorten.OmdGenerator --version 1.0.0
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local dotMorten.OmdGenerator --version 1.0.0
#tool dotnet:?package=dotMorten.OmdGenerator&version=1.0.0
nuke :add-package dotMorten.OmdGenerator --version 1.0.0
.NET Object Model Diagram Generator
A cross-platform Roslyn-based tool that generates an object model diagram of a set of C# source files
Install
Run the following command from commandline (requires .NET Core 2.1 installed):
dotnet tool install --global dotMorten.OmdGenerator
Usage:
generateomd /source=[source folder] /compareSource=[oldSourceFolder] /preprocessors=[defines] /format=[html|image] /showPrivate /showInternal
Required parameters:
source Specifies the folder of source files to include for the object model.
Separate with ; for multiple folders
or
assemblies Specifies a set of assemblies to include for the object model.
Separate with ; for multiple assemblies, or use wildcards
Optional parameters:
compareSource Specifies a folder of old source to compare and generate a diff model
This can be useful for finding API changes or compare branches
compareAssemblies Specifies a set of old assemblies to compare and generate a adiff model.
Separate with; for multiple assemblies, or use wildcards
format Format to generate:
'html' a single html output (html is default)
'md' for markdown you can copy-paste to for instance GitHub
preprocessors Define a set of preprocessors values. Use ; to separate multiple
exclude Defines one or more strings that can't be part of the path Ie '*/Samples/*;*/UnitTests/*'
(use forward slash for folder separators)
regexfilter Defines a regular expression for filtering on full file names in the source
showPrivate Show private members (default is false)
showInternal Show internal members (default is false)
NuGet
As an alternative you can also reference a NuGet package to your class library, and set up a post-build script to generate an Object Model Diagram HTML file:
Install-Package dotMorten.OmdGenerator
Add the following to your project:
<Target Name="GenerateObjectModel">
<Exec Command="dotnet "$(DotNetOMDGeneratorToolPath)" /source="@(Compile)" /preprocessors="$(DefineConstants)" /output="$(OutputPath)$(TargetName).html"" WorkingDirectory="$(ProjectDir)" />
</Target>
An example of a generated output for all of .NET Core can be found here.
It can also be used to compare two folders (for instance two separate branches) and only show changes to the API. Here's an example of .NET CoreFX v2.0 vs Master.
Examples
Generate OMD for .NET Core FX source code, and ignore ref and test folders:
generateomd /source=c:\github\dotnet\corefx\src /exclude="*/ref/*;*/tests/*;*/perftests/*"
Compare .NET CoreFX Master with v2.0.0 repo branches directly from their Github zipped downloads:
generateomd /source=https://github.com/dotnet/corefx/archive/master.zip /compareSource=https://github.com/dotnet/corefx/archive/release/2.0.0.zip /exclude="*/ref/*;*/tests/*;*/perftests/*"
What's new in Xamarin.Forms? Compare assemblies from the nuget cache:
generateomd /assemblies=%USERPROFILE%\.nuget\packages\xamarin.forms\3.3.0.912540\lib\netstandard2.0\*.dll /compareAsssemblies=%USERPROFILE%\.nuget\packages\xamarin.forms\3.2.0.871581\lib\netstandard2.0\*.dll
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. |
.NET Core | netcoreapp2.1 is compatible. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
This package has no dependencies.