cmark-gfm/README.md

172 строки
5.7 KiB
Markdown
Исходник Обычный вид История

2015-04-16 22:55:05 +03:00
cmark
=====
2014-07-22 09:29:16 +04:00
[![Build Status]](https://travis-ci.org/jgm/cmark)
[![Windows Build Status]](https://ci.appveyor.com/project/jgm/cmark)
2015-04-16 22:55:05 +03:00
`cmark` is the C reference implementation of [CommonMark], a
rationalized version of Markdown syntax with a [spec][the spec].
(For the JavaScript reference implementation, see
[commonmark.js].)
2014-08-14 09:28:18 +04:00
2015-01-25 08:47:46 +03:00
It provides a shared library (`libcmark`) with functions for parsing
CommonMark documents to an abstract syntax tree (AST), manipulating
2015-03-22 03:36:02 +03:00
the AST, and rendering the document to HTML, groff man,
CommonMark, or an XML representation of the AST. It also provides a
command-line program (`cmark`) for parsing and rendering CommonMark
documents.
2015-01-25 08:47:46 +03:00
2015-04-16 22:55:05 +03:00
Advantages of this library:
- **Portable.** The library and program are written in standard
C99 and have no external dependencies. It has been tested with
MSVC, gcc, tcc, and clang.
- **Fast.** Performance is very good, on par with the fastest
Markdown processors: see the [benchmarks].
2015-04-16 22:55:05 +03:00
- **Accurate.** The library passes all CommonMark conformance tests.
2015-04-16 23:57:29 +03:00
- **Standardized.** The library can be expected to parse CommonMark
the same way as any other conforming parser. So, for example,
you can use `commonmark.js` on the client to preview content that
will be rendered on the server using `cmark`.
2015-04-16 22:55:05 +03:00
- **Robust.** The library has been extensively fuzz-tested using
american fuzzy lop. The test suite includes pathological cases
that bring many other Markdown parsers to a crawl (for example,
thousands-deep nested bracketed text or block quotes).
- **Flexible.** CommonMark input is parsed to an AST which can be
manipulated programatically prior to rendering.
- **Multiple renderers.** Output in HTML, groff man, CommonMark,
and a custom XML format is supported. And it is easy to write new
renderers to support other formats.
- **Free.** BSD2-licensed.
2015-01-25 08:47:46 +03:00
It is easy to use `libcmark` in python, lua, ruby, and other dynamic
languages: see the `wrappers/` subdirectory for some simple examples.
There are also libraries that wrap `libcmark` for
[go](https://github.com/rhinoman/go-commonmark),
[Haskell](http://hackage.haskell.org/package/cmark),
[ruby](https://github.com/gjtorikian/commonmarker),
2015-05-28 18:21:52 +03:00
[Perl](https://metacpan.org/release/CommonMark), and
[R](http://cran.r-project.org/package=commonmark).
Installing
----------
2014-11-12 07:45:30 +03:00
Building the C program (`cmark`) and shared library (`libcmark`)
requires [cmake]. If you modify `scanners.re`, then you will also
need [re2c], which is used to generate `scanners.c` from
`scanners.re`. We have included a pre-generated `scanners.c` in
the repository to reduce build dependencies.
2014-11-12 07:45:30 +03:00
2014-11-13 00:17:06 +03:00
If you have GNU make, you can simply `make`, `make test`, and `make
install`. This calls [cmake] to create a `Makefile` in the `build`
directory, then uses that `Makefile` to create the executable and
library. The binaries can be found in `build/src`. The default
installation prefix is `/usr/local`. To change the installation
prefix, pass the `INSTALL_PREFIX` variable if you run `make` for the
first time: `make INSTALL_PREFIX=path`.
2014-11-12 07:45:30 +03:00
2014-11-13 00:17:06 +03:00
For a more portable method, you can use [cmake] manually. [cmake] knows
how to create build environments for many build systems. For example,
on FreeBSD:
mkdir build
cd build
2014-11-13 00:17:06 +03:00
cmake .. # optionally: -DCMAKE_INSTALL_PREFIX=path
2015-01-07 09:23:31 +03:00
make # executable will be created as build/src/cmark
2014-11-13 00:17:06 +03:00
make test
make install
2014-11-13 00:17:06 +03:00
Or, to create Xcode project files on OSX:
2014-11-13 00:17:06 +03:00
mkdir build
cd build
cmake -G Xcode ..
open cmark.xcodeproj
2014-11-12 07:45:30 +03:00
2014-11-13 00:17:06 +03:00
The GNU Makefile also provides a few other targets for developers.
2015-01-13 08:09:17 +03:00
To run a benchmark:
make bench
2014-11-12 18:51:06 +03:00
To run a "fuzz test" against ten long randomly generated inputs:
make fuzztest
2015-01-13 08:09:17 +03:00
To run a test for memory leaks using `valgrind`:
2014-11-12 18:51:06 +03:00
make leakcheck
2015-01-13 08:09:17 +03:00
To reformat source code using `astyle`:
make astyle
To make a release tarball and zip archive:
2014-11-12 18:51:06 +03:00
make archive
2014-11-12 18:43:17 +03:00
Installing (Windows)
--------------------
2014-11-25 00:01:45 +03:00
To compile with MSVC and NMAKE:
nmake
You can cross-compile a Windows binary and dll on linux if you have the
`mingw32` compiler:
make mingw
The binaries will be in `build-mingw/windows/bin`.
Usage
-----
Instructions for the use of the command line program and library can
be found in the man pages in the `man` subdirectory.
**A note on security:**
This library does not attempt to sanitize link attributes or
raw HTML. If you use it in applications that accept
untrusted user input, you must run the output through an HTML
sanitizer to protect against
[XSS attacks](http://en.wikipedia.org/wiki/Cross-site_scripting).
Contributing
------------
There is a [forum for discussing
CommonMark](http://talk.commonmark.org); you should use it instead of
github issues for questions and possibly open-ended discussions.
Use the [github issue tracker](http://github.com/jgm/CommonMark/issues)
only for simple, clear, actionable issues.
2014-11-23 04:20:41 +03:00
Authors
-------
John MacFarlane wrote the original library and program.
The block parsing algorithm was worked out together with David
Greenspan. Vicent Marti optimized the C implementation for
performance, increasing its speed tenfold. Kārlis Gaņģis helped
work out a better parsing algorithm for links and emphasis,
eliminating several worst-case performance issues.
Nick Wellnhofer contributed many improvements, including
most of the C library's API and its test harness.
2014-11-13 00:17:06 +03:00
2015-04-16 22:55:05 +03:00
[sundown]: https://github.com/vmg/sundown
[benchmarks]: benchmarks.md
[the spec]: http://spec.commonmark.org
[CommonMark]: http://commonmark.org
[cmake]: http://www.cmake.org/download/
2014-11-12 07:48:09 +03:00
[re2c]: http://re2c.org
2015-04-16 22:55:05 +03:00
[commonmark.js]: https://github.com/jgm/commonmark.js
[Build Status]: https://img.shields.io/travis/jgm/cmark/master.svg?style=flat
[Windows Build Status]: https://ci.appveyor.com/api/projects/status/32r7s2skrgm9ubva?svg=true