What library does Github use for parsing markdown?
Asked Answered
D

3

20

Github "uses" github flavored markdown but I haven't been able to find what that means exactly. What parsing library do they use on the client to render the preview(s)?

Is the same lib used for *.md files, issues, and wiki pages?

Bonus points if you can point me to a resource that shows how github flavored markdown and commonmark overlap and how they are different.

Drabble answered 18/9, 2016 at 17:32 Comment(0)
A
12

point me to a resource that shows how github flavored markdown and commonmark overlap and how they are different.

This is now (March 2017) officially documented: see "A formal spec for GitHub Flavored Markdown"

Starting today, all Markdown user content hosted in our website, including user comments, wikis, and .md files in repositories will be parsed and rendered following a formal specification for GitHub Flavored Markdown.

This is detailed in "A formal spec for GitHub Flavored Markdown"

This formal specification is based on CommonMark, an ambitious project to formally specify the Markdown syntax used by many websites on the internet in a way that reflects its real world usage.
CommonMark allows people to continue using Markdown the same way they always have, while offering developers a comprehensive specification and reference implementations to interoperate and display Markdown in a consistent way between platforms.

The idea is:

Taking the CommonMark spec and re-engineering our current user content stack around it is not a trivial endeavour.
The main issue we struggled with is that the spec (and hence its reference implementations) focuses strictly on the common subset of Markdown that is supported by the original Perl implementation.
This does not include some of the extended features that have been always available on GitHub. Most notably, support for tables, strikethrough, autolinks and task lists are missing.

In order to fully specify the version of Markdown we use at GitHub (known as GFM), we had to formally define the syntax and semantics of these features, something which we had never done before. We did this on top of the existing CommonMark spec, taking special care to ensure that our extensions are a strict and optional superset of the original specification.

Aphorize answered 14/3, 2017 at 22:39 Comment(0)
D
10

Markup is "The code we [Github] use to render README.your_favorite_markup". They list Redcarpet as their library for Markdown. This, in turn, uses Sundown. Whether this is used for all of the site I'm not sure.

It also claims to have "massive extension support".

Sundown has optional support for several (unofficial) Markdown extensions, such as non-strict emphasis, fenced code blocks, tables, autolinks, strikethrough and more.

For full detail you'll probably have to dig into those libraries.

Bonus points if you can point me to a resource that shows how github flavored markdown and commonmark overlap and how they are different.

Sundown claims to be "fully standards compliant" with Markdown v1.0.0 and v1.0.3, but for the life of me I cannot find those versions. Only v1.0.1 and CommonMark which is at 0.26.

Sundown passes out of the box the official Markdown v1.0.0 and v1.0.3 test suites, and has been extensively tested with additional corner cases to make sure its output is as sane as possible at all times.

The Github Markdown extensions are documented in their Mastering Markdown guide.

Depalma answered 28/9, 2016 at 20:54 Comment(0)
F
0

Parsing library

The cmark-gfm library and tool, which is GitHub's fork of cmark, appears to be actively maintained and match the behavior of GitHub.com, so I assume that's what they're using as of 2023.

You may need to activate extensions using the -e option to get all GitHub features. To get a list of extensions, run make && ./build/src/cmark-gfm --list-extensions.

Documentation

There is a specification for GitHub Flavored Markdown, though it appears to be out of date – for example, it doesn't specify the syntax for footnotes (added in 2021, #64).

Therefore, I would suggest that GitHub's documentation is the best up-to-date source. Also take note of the many sections under "Work with advanced formatting" in the left sidebar.

Fleam answered 5/12, 2023 at 18:14 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.