2013-11-16 09:51:01 +02:00
## Parsedown
2013-07-23 23:32:45 +03:00
2013-12-15 03:32:34 +02:00
Better [Markdown ](http://en.wikipedia.org/wiki/Markdown ) parser for PHP.
2013-07-10 23:22:16 +03:00
2014-05-16 03:34:43 +03:00
* [Demo ](http://parsedown.org/demo )
2014-09-11 15:47:59 +03:00
* [Video Tutorial ](http://youtu.be/wYZBY8DEikI )
2013-11-23 15:58:58 +02:00
2013-12-03 22:49:50 +02:00
### Features
2013-11-23 15:58:58 +02:00
2014-04-17 11:22:49 +03:00
* [Fast ](http://parsedown.org/speed )
* [Consistent ](http://parsedown.org/consistency )
2013-12-03 23:19:50 +02:00
* [GitHub Flavored ](https://help.github.com/articles/github-flavored-markdown )
2014-04-17 11:22:49 +03:00
* [Tested ](https://travis-ci.org/erusev/parsedown ) in PHP 5.2, 5.3, 5.4, 5.5, 5.6 and [hhvm ](http://www.hhvm.com/ )
* Extensible
2014-05-14 20:07:52 +03:00
* [Markdown Extra extension ](https://github.com/erusev/parsedown-extra ) < sup > new</ sup >
2014-06-18 12:27:25 +03:00
* [JavaScript port ](https://github.com/hkdobrev/parsedown.js ) under development < sup > new</ sup >
2013-07-23 10:36:28 +03:00
2013-07-23 23:32:45 +03:00
### Installation
Include `Parsedown.php` or install [the composer package ](https://packagist.org/packages/erusev/parsedown ).
2013-07-23 23:54:32 +03:00
### Example
2013-07-23 23:32:45 +03:00
2014-02-21 02:49:59 +02:00
``` php
2014-05-17 17:13:00 +03:00
$Parsedown = new Parsedown();
2013-07-23 23:32:45 +03:00
2014-05-17 17:13:00 +03:00
echo $Parsedown->text('Hello _Parsedown_ !'); # prints: < p > Hello < em > Parsedown</ em > !</ p >
2013-11-13 01:38:29 +02:00
```
2014-05-16 01:15:21 +03:00
2014-05-17 17:13:00 +03:00
More examples in [the wiki ](https://github.com/erusev/parsedown/wiki/Usage ).
2014-05-16 01:15:21 +03:00
### Questions
2014-05-16 01:27:54 +03:00
**How does Parsedown work?**< br / >
Parsedown recognises that the Markdown syntax is optimised for humans so it tries to read like one. It goes through text line by line. It looks at how lines start to identify blocks. It looks for special characters to identify inline elements.
2014-05-16 01:15:21 +03:00
2014-05-16 01:27:54 +03:00
**Why doesn’ t Parsedown use namespaces?**< br / >
Using namespaces would mean dropping support for PHP 5.2. Since Parsedown is a single class with an uncommon name, making this trade wouldn't make much sense.
2014-05-16 01:15:21 +03:00
2014-09-09 14:30:17 +03:00
**Is Parsedown compliant with CommonMark?**< br / >
We are [working on it ](https://github.com/erusev/parsedown/tree/commonmark ).
2014-05-16 01:27:54 +03:00
**Who uses Parsedown?**< br / >
[phpDocumentor ](http://www.phpdoc.org/ ), [Bolt CMS ](http://bolt.cm/ ), [RaspberryPi.org ](http://www.raspberrypi.org/ ) and [more ](https://www.versioneye.com/php/erusev:parsedown/references ).