CommonMark

CommonMark is a Markdown dialect, an attempt to unify all the different, divergent dialects of Markdown by providing an unambiguous syntax specification for Markdown, together with a suite of comprehensive tests to validate implementation.

Time will show, if this attempt is successful.

However, CommonMark is a well specified Markdown dialect, in contrast to most (if not all) other dialects. Other software adopts CommonMark somehow, notably GitHub Flavored Markdown (GFM). But they provide proprietary extensions, which makes it harder to change to another CommonMark implementation if needed. Plus, they sometimes build on an older specification of CommonMark.

Zettelstore supports the latest CommonMark specification version 0.30 (2021-06-19). If possible, Zettelstore will adapt to newer versions when they are available.

To provide CommonMark support, Zettelstore uses currently the Goldmark implementation, which passes all validation tests of CommonMark. Internally, CommonMark is translated into some kind of super-set of Zettelmarkup, which additionally allows to use HTML code.1 This Zettelmarkup super-set is later encoded, often into HTML. Because Zettelstore HTML encoding philosophy differs a little bit to that of CommonMark, Zettelstore itself will not pass the CommonMark test suite fully. However, no CommonMark language element will fail to be encoded as HTML. In most cases, the differences are not visible for an user, but only by comparing the generated HTML code.

Be aware, depending on the value of the startup configuration key insecure-html, HTML code found within a CommonMark document or within the mentioned kind of super-set of Zettelmarkup will typically be ignored for security-related reasons.

  1. Effectively, Markdown and CommonMark are itself super-sets of HTML. ↩︎