Is there a command line utility for rendering GitHub flavored Markdown?
Asked Answered
M

24

462

I'm wondering if there is a command line utility for taking a GitHub flavored Markdown file and rendering it to HTML.

I'm using a GitHub wiki to create website content. I've cloned the repository on my server and would then like to process it into regular HTML. It's important to me that what appears on GitHub is exactly how it should look for my website. I'd also really like to use the fenced blocks with ~~~, so I'd rather not use standard Markdown syntax only.

I've looked a bit into the JavaScript live preview thinking I could hook it into Node.js, but they say it is deprecated. I've looked at the redcarpet repository, but it doesn't look like it has a command line interface.

I rolled my own solution, however, since no solution here is clearly better than the others, I'll leave the question without a selected answer.

Molybdic answered 8/10, 2011 at 4:48 Comment(12)
RE: UPDATE: If I added an --out argument to grip to render to an HTML file instead of the browser, would that be acceptable?Chianti
@Chianti please do add that option!Choose
@Molybdic @Choose just deployed the --export option, which renders GFM and its styles to a single file. Does this answer the question?Chianti
@Chianti sweet, shall check it out!Choose
@McLeopold, Joe kind of knocked this out of the park by creating a simple reusable solution, might want to give him the answer.Derte
I don't know if this is still relevant, but as @gringo-suave pointed out in his answer, there is the Markdown Python module that allows the use of extensions. Check out their page for more information. There is even an extension for fenced code blocks and code highlight!Chagres
Check out this gist for an example on how to do it.Chagres
pandoc -s -f markdown -t man "my documentation file.markdown" | man -l - (from https://mcmap.net/q/81386/-less-style-markdown-viewer-for-unix-systems)Wasteland
Github itself uses Sundown. See https://mcmap.net/q/80174/-is-there-a-command-line-utility-for-rendering-github-flavored-markdownCommunard
It is github.com/github/markupCree
Since @Molybdic need to HTML, for generic Markdown should be: pandoc input.md -f markdown -t html -s -o output.html. -s, --standalone: Produce output with an appropriate header and footerAlston
It's amazing that no one's pointed out that yes, of course there is, because github released one as part of their commonmark forking, and it's been available for almost a decade now over on github.com/github/cmark-gfmDincolo
C
495

I wrote a small CLI in Python and added GFM support. It's called Grip (Github Readme Instant Preview).

Install it with:

$ pip install grip

And to use it, simply:

$ grip

Then visit localhost:5000 to view the readme.md file at that location.

You can also specify your own file:

$ grip CHANGES.md

And change port:

$ grip 8080

And of course, specifically render GitHub-Flavored Markdown, optionally with repository context:

$ grip --gfm --context=username/repo issue.md

Notable features:

  • Renders pages to appear exactly like on GitHub
  • Fenced blocks
  • Python API
  • Navigate between linked files (thanks, vladwing!) added in 2.0
  • Export to a single file (thanks, iliggio!) added in 2.0
  • New: Read from stdin and export to stdout added in 3.0

Check it out.

Chianti answered 8/12, 2012 at 20:3 Comment(22)
Works really well and you can't beat ease of install for Pythonistas!Ejectment
This should be a first hit for "github markdown preview." Everything else is complicated, doesn't work, or doesn't do all the GitHub features. grip works right out of the box.Transpadane
Thanks for the hint, a real great package. Is there a reason why there is no HTML (css-inclusive) export?Beanfeast
Does this work with Python3.x? Because I tried installing, and it seems like it may have a dependency on flask, which does not appear to be supported with Python3.x. See github.com/mitsuhiko/flask/issues/339Afebrile
@Afebrile That issue is out of date. Flask does support 3.3, see flask.pocoo.org/docs/python3. Here's a more recent Github thread on the topic github.com/mitsuhiko/flask/issues/587. If there's another dependency that needs updated, feel free to open an issue or a pull request.Chianti
It should be noted that this package requires an active internet connection and your github authentication credentials (provided at command line) if you do more than 60 refreshes per hour.Extinction
@Extinction You can use a personal auth token instead of your credentials. That's actually recommended instead of exposing your password. github.com/joeyespo/grip#accessChianti
This is great for creating local mirrors of Github wikis. First clone your wiki by running this command like this (replace .git with .wiki) git clone https://github.com/user/project.wiki. Then you can host it locally with grip for a killer combo :)Ambros
@Ambros Thanks for sharing! Just added a 'Tips' section to the Readme with this github.com/joeyespo/grip#tips :-)Chianti
As mentioned earlier, I don't think this is a particularly great solution because all it does it goes off to Github and gets Github to render your Markdown. It requires a working internet connection with access to Github, and if Github dies then this tool stops working. I'd rather have a completely offline solution.Dufrene
For debian users, you can run grip via python -m grip [options], since there is no executable placed in the PATH directories.Mabellemable
I got grip 4.2.0 from a pip install and it works as a server but the --export function doesn't work. It just hangs. Anyone else have this problem? Of course if you want an HTML file you can always save-as from the browser.Interstratify
@Interstratify There's an issue that was recently opened that I think is related. (github.com/joeyespo/grip/issues/180) I'll take a look at it next week! Feel free to comment there or open a new issue anyway to make sure the specific issue you're seeing is addressed.Chianti
Latest 4.3.2 for me (on Windows) only supports page links with an explicit .md suffix (rather than the normal syntax of just the page name). Am I missing something here?Showoff
Hmm this says the [link text](link URL) format I was using should always be the full URL (i.e. with the suffix). Yet GitHub allows it not to have the .md suffix and work.Showoff
...and including the suffix on GitHub gives me a link to the raw source of the page, not it rendered (i.e., I have to use the suffix-less links). Huh?Showoff
@StuartRossiter Want to open an issue? I'd be happy to look into it. It might be easier to drill down into the details there instead of in comments here github.com/joeyespo/grip/issuesChianti
Unfortunately, it doesn't seem to support GFM tables which is what I need.Kilmarnock
nice tool! I was expecting something that would render it in the cli though.Accelerometer
@AlexanderOh You can output to file with grip file.md --export file.htmlPiperine
Pretty cool tool since it uses Github API, so it's an exact rendering. One inherent downside is that it adds a ton of css and header code.Piperine
doesn't seem to render the mermaid js stuff that is now supported in github flavored markdown :(Doubleheader
C
122

I've not found a quick and easy method for GitHub-flavoured Markdown, but I have found a slightly more generic version - Pandoc. It converts from/to a number of formats, including Markdown, Rest, HTML and others.

I've also developed a Makefile to convert all .md files to .html (in large part to the example at Writing, Markdown and Pandoc):

# 'Makefile'
MARKDOWN = pandoc --from gfm --to html --standalone
all: $(patsubst %.md,%.html,$(wildcard *.md)) Makefile

clean:
    rm -f $(patsubst %.md,%.html,$(wildcard *.md))
    rm -f *.bak *~

%.html: %.md
    $(MARKDOWN) $< --output $@
Cinemascope answered 8/11, 2011 at 12:19 Comment(7)
i've been using "watch pandoc ..." to continuously convert a markdown file to html, and the chrome "live reload" extension to get real time "stay where i'm scrolled too" functionality with this, and it works great. chrome.google.com/webstore/detail/livereload/…Moxley
Pandoc reads GFM fine but it doesn't generate the same HTML GitHub does -- for instance, if you have a multi-line <pre/> tag in your GFM source, Pandoc will put <br/> tags in for the line breaks in it, while GitHub's renderer, though it strips leading whitespace, seems to otherwise leave the content alone.Lajuanalake
How does one go about getting nice styling on the resulting HTML? My output is still rendered with Times New Roman, for example.Intyre
Pandoc install instructions are here. On macOS: brew install pandocRoice
neither the gfm nor the markdown_github input formats correctly render things like code blocks.Slipsheet
it also does not correctly interpret the YAML or pandoc header metadata blocksSlipsheet
pandoc's output downloads a file from Cloudflare for IE 9 compatibilityHerbherbaceous
D
32
pip3 install --user markdown
python3 -m markdown readme.md > readme.html

It doesn't handle GitHub extensions, but it is better than nothing. I believe you can extend the module to handle the GitHub additions.

Decurrent answered 20/8, 2012 at 21:7 Comment(3)
/usr/bin/python: markdown is a package and cannot be directly executedOsteal
Simple HTML output with no fancy tags.Scarf
Strictly speaking, this is "John Gruber's Markdown", not GitHub flavored Markdown.Herbherbaceous
O
29

Maybe this might help:

gem install github-markdown

No documentation exists, but I got it from the gollum documentation. Looking at rubydoc.info, it looks like you can use:

require 'github/markdown'  
puts GitHub::Markdown.render_gfm('your markdown string')

in your Ruby code. You can wrap that easily in a script to turn it into a command line utility:

#!/usr/bin/env ruby

# render.rb
require 'github/markdown'

puts GitHub::Markdown.render_gfm File.read(ARGV[0])

Execute it with ./render.rb path/to/my/markdown/file.md. Note that this is not safe for use in production without sanitization.

Ondometer answered 14/11, 2012 at 13:40 Comment(3)
Thanks Jim, due to virtually non-existent examples, I was stuck at the require step (replacing dash with slash made it).. ;)Eras
This is great if you're already using NPM. I had to use it, on account of DOxygen causing me constant problems with specifically github-flavored markdown + exporting to HTML.Haldis
is this running locally or is it sending data out to GitHub API?Slipsheet
A
27

To read a README.md file in the terminal I use:

pandoc README.md | lynx -stdin

Pandoc outputs it in HTML format, which Lynx renders in your terminal.

It works great: It fills my terminal, shortcuts are shown below, I can scroll through, and the links work! There is only one font size though, but the colors + indentation + alignment make up for that.

Installation:

  • apt: sudo apt-get install pandoc lynx
  • nix: nix-shell -p pandoc lynx
Albright answered 16/12, 2014 at 11:29 Comment(5)
The question is specifically about command-line usage. Before writing your own ruby script (or egad node server), give this a shot.Scooter
Exactly this works inside your terminal. Or if your favorite (desktop?) browser can access that folder use pandoc readme.md -o readme.md.html and open the resulting file.Albright
@baerry-staes Yes, sorry, I hope it was clear that yours was my favored answer.Scooter
@JustinMiddleton yes i got that, thank you. My comment was just to add some extra info for desktop users.. i figured someone someday reading this might find it useful.Albright
I've tried about 5-6 other console md readers and this has by far been the best solution. I just added the most basic function to my config to make it a little quicker to use. function md { pandoc $@ | lynx -stdin }Todtoday
H
24

Probably not what you want, but since you mentioned Node.js: I could not find a good tool to preview GitHub Flavored Markdown documentation on my local drive before committing them to GitHub, so today I created one, based on Node.js: https://github.com/ypocat/gfms

So perhaps you can reuse the showdown.js from it for your Wiki, if your question is still actual. If not, maybe other people facing the same problem as I did will find (just as I did) this question and this answer to it.

Harlamert answered 29/1, 2012 at 8:31 Comment(1)
Well done, man. Saves me from having to resort to Ruby or Python when I'm writing a node application, which is great.Administer
P
20

GitHub has a Markdown API you can use.

Passivism answered 23/6, 2014 at 2:21 Comment(3)
jq --slurp --raw-input '{"text": "\(.)", "mode": "markdown"}' < README.md | curl --data @- https://api.github.com/markdown > README.htmlHitlerism
@VebjornLjosa * that * or grip... You chose. :PPar
grip is amazing. But, unfortunately, due to its name it is not possible to find it easily if you forget how it is named. (not available via MacPorts either).Hinch
V
14

Use marked. It supports GitHub Flavored Markdown, can be used as a Node.js module and from the command line.

An example would be:

$ marked -o hello.html
hello world
^D
$ cat hello.html
<p>hello world</p>
Verney answered 25/10, 2012 at 12:59 Comment(4)
I've noticed that this doesn't support features like syntax highlighting for code blocks and newer features like checklists. But hey it gets most of the way!Choose
Very nice, the only thing I'm missing is some borders for the tables. Well, at least I can render them at all, this is pretty much exactly what I need. Pipe in the GFM, pipe out HTML :)Derain
I'm confused about this example, what is ^D?Emersed
Use it like marked -o out.html -i in.md --gfmSwagman
S
13

I created a tool similar to Atom's Preview functionality, but as a standalone application. Not sure if this is what you're looking for, but it might be helpful. -- https://github.com/yoshuawuyts/vmd

vmd

Subzero answered 24/2, 2015 at 10:56 Comment(2)
You guys still supporting this? I tried to install with NPM today, but no dice. >downloading electron-v0.36.9-win32-x64.zip >Error: self signed certificateHaldis
Yeah, we are! What version of npm / node did you run this on? - feel free to open up an issue on GH and we'll take a look at this. Thanks!Subzero
S
11

This is mostly a follow-on to @barry-staes's answer for using Pandoc. Homebrew has it as well, if you're on a Mac:

brew install pandoc

Pandoc supports GFM as an input format via the markdown_github name.

Output to file

cat foo.md | pandoc -f markdown_github > foo.html

Open in Lynx

cat foo.md | pandoc -f markdown_github | lynx -stdin # To open in Lynx

Open in the default browser on OS X

cat foo.md | pandoc -f markdown_github > foo.html && open foo.html # To open in the default browser on OS X`

TextMate Integration

You can always pipe the current selection or current document to one of the above, as most editors allow you to do. You can also easily configure the environment so that pandoc replaces the default Markdown processor used by the Markdown bundle.

First, create a shell script with the following contents (I'll call it ghmarkdown):

#!/bin/bash
# Note included, optional --email-obfuscation arg
pandoc -f markdown_github --email-obfuscation=references

You can then set the TM_MARKDOWN variable (in Preferences→Variables) to /path/to/ghmarkdown, and it will replace the default Markdown processor.

Scooter answered 12/1, 2015 at 18:48 Comment(0)
L
10

pandoc with browser works well for me.

Usage: cat README.md | pandoc -f markdown_github | browser

Installation (Assuming you are using Mac OSX):

  • $ brew install pandoc

  • $ brew install browser

Or on Debian/Ubuntu: apt-get install pandoc browser

Lundin answered 23/8, 2016 at 19:6 Comment(4)
apt-get isntall pandoc will do, no need to use insecure, local stuff like brew.Disclaim
@DominikGeorge there is a typo, it is install, not isntallComplice
@DominikGeorge there's no apt-get on macOS.Segalman
I was wondering what this browser is - it is just a shell script to create a temporary html file, and then call the system browser to open this file; formulae.brew.sh/formula/browser points to gist.github.com/defunkt/318247 which contains the scriptPoisson
L
9

I use Pandoc with the option --from=gfm for GitHub Flavored Markdown like this:

$ pandoc my_file.md   --from=gfm -t html -o my_file.html
Lanceted answered 13/4, 2018 at 21:12 Comment(4)
With pandoc 1.16.0.2 on linux mint 18 I get an error: pandoc: Unknown reader: gfm. Going to 2.2.1 fixes this.Catlin
I tested it with Pandoc 2.1.2.Lanceted
how to install 2.2.1 on ubuntu?Boxer
@AlexanderMills Did you try sudo apt install pandoc ?Lanceted
P
9

Building on this comment I wrote a one-liner to hit the Github Markdown API using curl and jq.

Paste this bash function onto the command line or into your ~/.bash_profile:

mdsee(){ 
    HTMLFILE="$(mktemp -u).html"
    cat "$1" | \
      jq --slurp --raw-input '{"text": "\(.)", "mode": "markdown"}' | \
      curl -s --data @- https://api.github.com/markdown > "$HTMLFILE"
    echo $HTMLFILE
    open "$HTMLFILE"
}

And then to see the rendered HTML in-browser run:

mdsee readme.md

Replace open "$HTMLFILE" with lynx "$HTMLFILE" if you need a pure terminal solution.

Palua answered 2/1, 2019 at 21:38 Comment(0)
E
6

Also see https://softwareengineering.stackexchange.com/a/128721/24257.


If you're interested in how we [Github] render Markdown files, you might want to check out Redcarpet, our Ruby interface to the Sundown library.

Ruby-script, which use Redcarpet, will be "command line utility", if you'll have local Ruby

Elastomer answered 8/10, 2011 at 5:4 Comment(3)
Haven't ideas - I don't write Ruby and I didn't read Redcarpet sourcesElastomer
@LazyBadger, Sundown is the actual parser (written in C). Redcarpet is not needed.Communard
This is arguably the best solution, but you don't give actual instructions on what to do. So after installing the gem gem install redcarpet, suppose we're in a directory containing README.md what next?Conducive
M
4

My final solution was to use Python Markdown. I rolled my own extension that fixed the fence blocks.

Molybdic answered 30/1, 2012 at 18:44 Comment(0)
H
4

There is a really nice and simple tool for browsing GFM Markdown documents:

GFMS - Github Flavored Markdown Server

It's simple and lightweight (no configuration needed) HTTP server you can start in any directory containing markdown files to browse them.

Features:

  • Full GFM Markdown support
  • Source code syntax highlighting
  • Browsing files and directories
  • Nice looking output (and configurable CSS stylesheets)
  • Export to PDF
Hsu answered 20/6, 2014 at 14:38 Comment(0)
A
4

GitHub has (since) developed a nice modular text editor called Atom (based on Chromium and uses Node.js modules for packages).

A default preinstalled package Markdown Preview lets you display your preview in a separate tab using Ctrl + Shift + M.

I haven't tested its full syntax, but since it's coming from GitHub, I'd be highly surprised if the preview's syntax was different from theirs (fenced blocks using ~~~ work).

Now, while it's not technically command-line based, it uses Node.js and outputs to a DOM-based renderer, which might help anyone trying to render GitHub syntax-based HTML on a Node.js-based webserver, or just edit her/his README.md offline.

Abba answered 31/7, 2014 at 2:9 Comment(1)
In Atom you can install a package called gfm-pdf (atom.io/packages/gfm-pdf), which exports your markdown document to a HTML and/or PDF document. The library wkhtmltopdf is required.Selimah
M
3

I managed to use a one-line Ruby script for that purpose (although it had to go in a separate file). First, run these commands once on each client machine you'll be pushing docs from:

gem install github-markup
gem install commonmarker

Next, install this script in your client image, and call it render-readme-for-javadoc.rb:

require 'github/markup'

puts GitHub::Markup.render_s(GitHub::Markups::MARKUP_MARKDOWN, File.read('README.md'))

Finally, invoke it like this:

ruby ./render-readme-for-javadoc.rb >> project/src/main/javadoc/overview.html

ETA: This won't help you with StackOverflow-flavor Markdown, which seems to be failing on this answer.

Msg answered 16/9, 2017 at 5:2 Comment(1)
I think this is the "closest to source" answer from all of them since these tools are the ones used by github.Tonl
D
2

Improving upon @barry-stae's solution. Stick this snippet in ~/.bashrc

function mdviewer(){
  pandoc $* | lynx -stdin
}

Then we can quickly view the file from the command-line. Also works nicely over SSH/Telnet sessions.

mdviewer README.md
Diesis answered 4/12, 2015 at 17:45 Comment(0)
P
1

A 'quick-and-dirty' approach is to download the wiki HTML pages using the wget utility, instead of cloning it. For example, this is how I downloaded the Hystrix wiki from GitHub (I'm using Ubuntu Linux):

 $ wget -e robots=off -nH -E -H -k -K -p https://github.com/Netflix/Hystrix/wiki
 $ wget -e robots=off -nH -E -H -k -K -I "Netflix/Hystrix/wiki" -r -l 1 https://github.com/Netflix/Hystrix/wiki

The first call will download the wiki entry page and all its dependencies. The second one will call all sub-pages on it. You can browse now the wiki by opening Netflix/Hystrix/wiki.1.html.

Note that both calls to wget are necessary. If you just run the second one then you will miss some dependencies required to show the pages properly.

Plutonium answered 22/5, 2015 at 11:58 Comment(0)
C
0

Based on Jim Lim's answer, I installed the GitHub Markdown gem. That included a script called gfm that takes a filename on the command line and writes the equivalent HTML to standard output. I modified that slightly to save the file to disk and then to open the standard browser with launchy:

#!/usr/bin/env ruby

HELP = <<-help
  Usage: gfm [--readme | --plaintext] [<file>]
  Convert a GitHub-Flavored Markdown file to HTML and write to standard output.
  With no <file> or when <file> is '-', read Markdown source text from standard input.
  With `--readme`, the files are parsed like README.md files in GitHub.com. By default,
  the files are parsed with all the GFM extensions.
help

if ARGV.include?('--help')
  puts HELP
  exit 0
end

root = File.expand_path('../../', __FILE__)
$:.unshift File.expand_path('lib', root)

require 'github/markdown'
require 'tempfile'
require 'launchy'

mode = :gfm
mode = :markdown if ARGV.delete('--readme')
mode = :plaintext if ARGV.delete('--plaintext')

outputFilePath = File.join(Dir.tmpdir, File.basename(ARGF.path))  + ".html"

File.open(outputFilePath, "w") do |outputFile |
    outputFile.write(GitHub::Markdown.to_html(ARGF.read, mode))
end

outputFileUri = 'file:///' + outputFilePath

Launchy.open(outputFileUri)
Cardiology answered 15/10, 2013 at 16:3 Comment(1)
I tried this with fenced blocks for Ruby and Cucumber. While the fences (ruby, cucumber, etc.) appear to be recognized as fences (because they're rendered in fixed width text), there is no syntax highlighting. Any idea why?Rois
A
0

Improving upon @barry-stae and @Sandeep answers for regular users of elinks you would add the following to .bashrc:

function mdviewer() {
  pandoc $* | elinks --force-html
}

Don't forget to install pandoc (and elinks).

Auteur answered 22/3, 2016 at 12:11 Comment(0)
A
0

Another option is AllMark - the markdown server.
Docker images available for ready-to-go setup.

$ allmark serve .

Note: It recursively scans directories to serve website from markdown files. So for faster processing of single file, move it to a separate directory.

Aldus answered 27/1, 2021 at 23:18 Comment(0)
S
0

There is: when GitHub forked the commonmark specification, they also forked the compiler tool (with updates specific to GFM syntax). Just hit up https://github.com/github/cmark-gfm and follow the build instructions.

Though, if you're a Windows user, the instructions forget to mention that you want to first install the Community Edition of Visual Studio, with the "Desktop development with C++" workload installed, after which you can compile the cli tool using the MSVS terminal (start an untemplated project, then "view" -> "terminal", which will start a copy of PowerShell with all the PATH etc values bootstrapped correctly), in which you need to run nmake /f Makefile.nmake rather than just the nmake that the README.md tells you to run.

Scenario answered 19/1, 2024 at 18:27 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.