Python parser for the CommonMark Markdown spec
Project description
Pure Python port of jgm’s commonmark.js, a Markdown parser and renderer for the CommonMark specification, using only native modules. Once both this project and the CommonMark specification are stable we will release the first 1.0 version and attempt to keep up to date with changes in commonmark.js.
We are currently at the same development stage (actually a bit ahead because we have implemented HTML entity conversion and href URL escaping) as commonmark.js. Since Python versions pre-3.4 use outdated (i.e. not HTML5 spec) entity conversion, I’ve converted the 3.4 implementation into a single file, entitytrans.py which so far seems to work (all tests pass on 2.6, 2.7, 3.3, 3.4, and 3.5).
Current version: 0.6.4
Installation
rolands@kamaji:~$ pip install commonmark
Usage
import CommonMark CommonMark.commonmark('*hello!*') # '<p><em>hello!</em></p>\n' # Or, without the syntactic sugar: parser = CommonMark.Parser() renderer = CommonMark.HtmlRenderer() ast = parser.parse("Hello *World*") html = renderer.render(ast) json = CommonMark.ASTtoJSON(ast) CommonMark.dumpAST(ast) # pretty print generated AST structure print(html) # <p>Hello <em>World</em><p/> ----- or ----- rolands@kamaji:~$ cmark.py README.md -o README.html rolands@kamaji:~$ cmark.py README.md -o README.json -aj # output AST as JSON rolands@kamaji:~$ cmark.py README.md -a # pretty print generated AST structure rolands@kamaji:~$ cmark.py -h usage: cmark.py [-h] [-o [O]] [-a] [-aj] [infile] Process Markdown according to the CommonMark specification. positional arguments: infile Input Markdown file to parse, defaults to stdin optional arguments: -h, --help show this help message and exit -o [O] Output HTML/JSON file, defaults to stdout -a Print formatted AST -aj Output JSON AST
Contributing
If you would like to offer suggestions/optimizations/bugfixes through pull requests please do! Also if you find an error in the parser/renderer that isn’t caught by the current test suite please open a new issue and I would also suggest you send the commonmark.js project a pull request adding your test to the existing test suite.
Tests
To work on CommonMark-py, you will need to be able to run the test suite to make sure your changes don’t break anything. To run the tests, you can do something like this:
$ pyvenv venv $ ./venv/bin/python setup.py develop test
The tests script, run_spec_tests.py, is pretty much a devtool. As well as running all the tests embedded in spec.txt it also allows you to run specific tests using the -t argument, provide information about passed tests with -p, percentage passed by category of test with -s, and enter markdown interactively with -i (In interactive mode end a block by inputting a line with just end, to quit do the same but with quit). -d can be used to print call tracing.
rolands@kamaji:~/utils/CommonMark-py$ python run_spec_tests.py -h usage: run_spec_tests.py [-h] [-t T] [-p] [-f] [-i] [-d] [-np] [-s] script to run the CommonMark specification tests against the CommonMark.py parser optional arguments: -h, --help show this help message and exit -t T Single test to run or comma separated list of tests (-t 10 or -t 10,11,12,13) -p Print passed test information -f Print failed tests (during -np...) -i Interactive Markdown input mode -d Debug, trace calls -np Only print section header, tick, or cross -s Print percent of tests passed by category
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file CommonMark-0.6.4.tar.gz
.
File metadata
- Download URL: CommonMark-0.6.4.tar.gz
- Upload date:
- Size: 83.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0a881b7526ab4c841498f71cb591d499f79fcaedb692e78e334bb3921d27d171 |
|
MD5 | 5d6b44a0a8e5d6cb66dbe6cad72e99ae |
|
BLAKE2b-256 | dc059f2361017999720f8fbbae8955bf2976f8fc2fc0e0f682019420e675bdd0 |
File details
Details for the file CommonMark-0.6.4-py2.py3-none-any.whl
.
File metadata
- Download URL: CommonMark-0.6.4-py2.py3-none-any.whl
- Upload date:
- Size: 45.4 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | da79b830e6874da896b880804cb7f99f4fc4020e1c63977783f552ab18579acb |
|
MD5 | 22fecad48091e26fe5883a41c7d0e18a |
|
BLAKE2b-256 | 898d465d2316172c43771b2680638f13d23280aaea0688b9578047cc0afdaca1 |