jbroadway / slimdown
A simple regex-based Markdown parser.
Installs: 4 284
Dependents: 0
Suggesters: 0
Security: 0
Stars: 32
Watchers: 3
Forks: 8
Open Issues: 1
Requires
- php: >=7.2
Requires (Dev)
- phpunit/phpunit: ^8.5
This package is auto-updated.
Last update: 2025-01-12 03:04:42 UTC
README
A simple regex-based Markdown parser in PHP. Supports the
following elements (and can be extended via Slimdown::add_rule()
):
- Headers
- Links
- Bold
- Emphasis
- Deletions
- Quotes
- Code blocks
- Inline code
- Blockquotes
- Ordered/unordered lists
- Checklists
- Images
Originally hosted as a gist here.
Usage
Here is the general use case:
<?php require_once ('Slimdown.php'); echo Slimdown::render ( "# Page title\n\nAnd **now** for something _completely_ different." );
Or via composer:
composer require jbroadway/slimdown
Then:
<?php require __DIR__ . '/vendor/autoload.php'; echo Slimdown::render ( "# Page title\n\nAnd **now** for something _completely_ different." );
Adding rules
A simple rule to convert :)
to an image:
<?php Slimdown::add_rule ('/(\W)\:\)(\W)/', '\1<img src="smiley.png" />\2'); echo Slimdown::render ('Know what I\'m sayin? :)');
In this example, we add GitHub-style internal linking
(e.g., [[Another Page]]
).
<?php function mywiki_internal_link ($title) { return sprintf ( '<a href="%s">%s</a>', preg_replace ('/[^a-zA-Z0-9_-]+/', '-', $title), $title ); } Slimdown::add_rule ('/\[\[(.*?)\]\]/e', 'mywiki_internal_link (\'\\1\')'); echo Slimdown::render ('Check [[This Page]] out!');
A longer example
<?php echo Slimdown::render ("# Title And *now* [a link](http://www.google.com) to **follow** and [another](http://yahoo.com/). * One * Two * Three ## Subhead One **two** three **four** five. One __two__ three _four_ five __six__ seven _eight_. 1. One 2. Two 3. Three More text with `inline($code)` sample. > A block quote > across two lines. - [ ] One - [x] Two - [ ] Three More text...");