A fast, powerful, CommonMark compliant, extensible Markdown processor for .NET
Markdig is a fast, powerful, CommonMark compliant, extensible Markdown processor for .NET.
NOTE: The repository is under construction. There will be a dedicated website and proper documentation at some point!
You can try Markdig online and compare it to other implementations on babelmark3
#
of a headers with @
)~~
,~
^
++
==
http://
or https://
or ftp://
or mailto:
or www.xxx.yyy
a.
b.
and roman bullet (i
, ii
…etc.)""...""
(inspired by this CommonMark discussion ):::
for generating a proper <div>...</div>
instead (inspired by this CommonMark discussion )$$
for block and $
for inline math (inspired from this CommonMark discussion)mermaid
and nomnoml
diagrams)0.20.0+
, Markdig is compatible only with NETStandard 2.0
, NETStandard 2.1
, NETCoreApp 2.1
and NETCoreApp 3.1
.If you are looking for support for an old .NET Framework 3.5 or 4.0, you can download Markdig 0.18.3
.
markdig.wpf
Neo.Markdig.Xaml
Markdig.SyntaxHighlighting
Markdown.ColorCode
WebStoating.Markdig.Prism
Markdig.Extensions.ScriptCs
The repository is under construction. There will be a dedicated website and proper documentation at some point!
While there is not yet a dedicated documentation, you can find from the specs documentation how to use these extensions.
In the meantime, you can have a “behind the scene” article about Markdig in my blog post “Implementing a Markdown Engine for .NET”
Markdig is available as a NuGet package:
Also Markdig.Signed NuGet package provides signed assemblies.
The main entry point for the API is the Markdig.Markdown
class:
By default, without any options, Markdig is using the plain CommonMark parser:
var result = Markdown.ToHtml("This is a text with some *emphasis*");
Console.WriteLine(result); // prints: <p>This is a text with some <em>emphasis</em></p>
In order to activate most of all advanced extensions (except Emoji, SoftLine as HardLine, Bootstrap, YAML Front Matter, JiraLinks and SmartyPants)
// Configure the pipeline with all advanced extensions active
var pipeline = new MarkdownPipelineBuilder().UseAdvancedExtensions().Build();
var result = Markdown.ToHtml("This is a text with some *emphasis*", pipeline);
You can have a look at the MarkdownExtensions that describes all actionable extensions (by modifying the MarkdownPipeline)
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated. For detailed contributing guidelines, please see contributing.md.
In order to build Markdig, you need to install .NET 6.0
This software is released under the BSD-Clause 2 license.
The latest benchmark was collected on April 23 2022, against the following implementations:
// * Summary *
BenchmarkDotNet=v0.13.1, OS=Windows 10.0.22000
AMD Ryzen 9 5950X, 1 CPU, 32 logical and 16 physical cores
.NET SDK=6.0.202
[Host] : .NET 6.0.4 (6.0.422.16404), X64 RyuJIT
DefaultJob : .NET 6.0.4 (6.0.422.16404), X64 RyuJIT
| Method | Mean | Error | StdDev |
|------------------ |-----------:|----------:|----------:|
| markdig | 1.979 ms | 0.0221 ms | 0.0185 ms |
| cmark | 2.571 ms | 0.0081 ms | 0.0076 ms |
| CommonMark.NET | 2.016 ms | 0.0169 ms | 0.0158 ms |
| MarkdownSharp | 221.455 ms | 1.4442 ms | 1.3509 ms |
Supports this project with a monthly donation and help me continue improving it. [Become a sponsor]
Lilith River, author of Imageflow Server, an easy on-demand
image editing, optimization, and delivery server
Thanks to the fantastic work done by John Mac Farlane for the CommonMark specs and all the people involved in making Markdown a better standard!
This project would not have been possible without this huge foundation.
Thanks also to the project BenchmarkDotNet that makes benchmarking so easy to setup!
Some decoding part (e.g HTML EntityHelper.cs) have been re-used from CommonMark.NET
Thanks to the work done by @clarkd on the JIRA Link extension (https://github.com/clarkd/MarkdigJiraLinker), now included with this project!
Alexandre MUTEL aka xoofx