Download the PHP package cebe/markdown without Composer

On this page you can find all versions of the php package cebe/markdown. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package markdown

A super fast, highly extensible markdown parser for PHP

Latest Stable Version Total Downloads Build Status Code Coverage Scrutinizer Quality Score

What is this?

A set of PHP classes, each representing a Markdown flavor, and a command line tool for converting markdown files to HTML files.

The implementation focus is to be fast (see benchmark) and extensible. Parsing Markdown to HTML is as simple as calling a single method (see Usage) providing a solid implementation that gives most expected results even in non-trivial edge cases.

Extending the Markdown language with new elements is as simple as adding a new method to the class that converts the markdown text to the expected output in HTML. This is possible without dealing with complex and error prone regular expressions. It is also possible to hook into the markdown structure and add elements or read meta information using the internal representation of the Markdown text as an abstract syntax tree (see Extending the language).

Currently the following markdown flavors are supported:

Future plans are to support:

Who is using it?

Installation

PHP 5.4 or higher is required to use it. It will also run on facebook's hhvm.

The library uses PHPDoc annotations to determine the markdown elements that should be parsed. So in case you are using PHP opcache, make sure it does not strip comments.

Installation is recommended to be done via composer by running:

composer require cebe/markdown "~1.2.0"

Alternatively you can add the following to the require section in your composer.json manually:

Run composer update cebe/markdown afterwards.

Note: If you have configured PHP with opcache you need to enable the opcache.save_comments option because inline element parsing relies on PHPdoc annotations to find declared elements.

Usage

In your PHP project

To parse your markdown you need only two lines of code. The first one is to choose the markdown flavor as one of the following:

The next step is to call the parse()-method for parsing the text using the full markdown language or calling the parseParagraph()-method to parse only inline elements.

Here are some examples:

You may optionally set one of the following options on the parser object:

For all Markdown Flavors:

For GithubMarkdown:

It is recommended to use UTF-8 encoding for the input strings. Other encodings may work, but are currently untested.

The command line script

You can use it to render this readme:

bin/markdown README.md > README.html

Using github flavored markdown:

bin/markdown --flavor=gfm README.md > README.html

or convert the original markdown description to html using the unix pipe:

curl http://daringfireball.net/projects/markdown/syntax.text | bin/markdown > md.html

Here is the full Help output you will see when running bin/markdown --help:

PHP Markdown to HTML converter
------------------------------

by Carsten Brandt <mail@cebe.cc>

Usage:
    bin/markdown [--flavor=<flavor>] [--full] [file.md]

    --flavor  specifies the markdown flavor to use. If omitted the original markdown by John Gruber [1] will be used.
              Available flavors:

              gfm   - Github flavored markdown [2]
              extra - Markdown Extra [3]

    --full    ouput a full HTML page with head and body. If not given, only the parsed markdown will be output.

    --help    shows this usage information.

    If no file is specified input will be read from STDIN.

Examples:

    Render a file with original markdown:

        bin/markdown README.md > README.html

    Render a file using gihtub flavored markdown:

        bin/markdown --flavor=gfm README.md > README.html

    Convert the original markdown description to html using STDIN:

        curl http://daringfireball.net/projects/markdown/syntax.text | bin/markdown > md.html

[1] http://daringfireball.net/projects/markdown/syntax
[2] https://help.github.com/articles/github-flavored-markdown
[3] http://michelf.ca/projects/php-markdown/extra/

Security Considerations

By design markdown allows HTML to be included within the markdown text. This also means that it may contain Javascript and CSS styles. This allows to be very flexible for creating output that is not limited by the markdown syntax, but it comes with a security risk if you are parsing user input as markdown (see XSS).

In that case you should process the result of the markdown conversion with tools like HTML Purifier that filter out all elements which are not allowed for users to be added.

The list of allowed elements for markdown could be configured as:

The list of allowed attributes would be:

The above configuration is a general recommendation and may need to be adjusted dependent on your needs.

Extensions

Here are some extensions to this library:

Extending the language

Markdown consists of two types of language elements, I'll call them block and inline elements simlar to what you have in HTML with <div> and <span>. Block elements are normally spreads over several lines and are separated by blank lines. The most basic block element is a paragraph (<p>). Inline elements are elements that are added inside of block elements i.e. inside of text.

This markdown parser allows you to extend the markdown language by changing existing elements behavior and also adding new block and inline elements. You do this by extending from the parser class and adding/overriding class methods and properties. For the different element types there are different ways to extend them as you will see in the following sections.

Adding block elements

The markdown is parsed line by line to identify each non-empty line as one of the block element types. To identify a line as the beginning of a block element it calls all protected class methods who's name begins with identify. An identify function returns true if it has identified the block element it is responsible for or false if not. In the following example we will implement support for fenced code blocks which are part of the github flavored markdown.

                  "Fenced code block feature of github flavored markdown"

', 3) === 0) { return true; } return false; }

// ...

}

  1. Rendering the element. After all blocks have been consumed, they are being rendered using the render{elementName}()-method where elementName refers to the name of the element in the abstract syntax tree:

    You may also add code highlighting here. In general it would also be possible to render ouput in a different language than HTML for example LaTeX.

Adding inline elements

Adding inline elements is different from block elements as they are parsed using markers in the text. An inline element is identified by a marker that marks the beginning of an inline element (e.g. [ will mark a possible beginning of a link or ` will mark inline code).

Parsing methods for inline elements are also protected and identified by the prefix parse. Additionally a @marker annotation in PHPDoc is needed to register the parse function for one or multiple markers. The method will then be called when a marker is found in the text. As an argument it takes the text starting at the position of the marker. The parser method will return an array containing the element of the abstract sytnax tree and an offset of text it has parsed from the input markdown. All text up to this offset will be removed from the markdown before the next marker will be searched.

As an example, we will add support for the strikethrough feature of github flavored markdown:

Composing your own Markdown flavor

This markdown library is composed of traits so it is very easy to create your own markdown flavor by adding and/or removing the single feature traits.

Designing your Markdown flavor consists of four steps:

  1. Select a base class
  2. Select language feature traits
  3. Define escapeable characters
  4. Optionally add custom rendering behavior

Select a base class

If you want to extend from a flavor and only add features you can use one of the existing classes (Markdown, GithubMarkdown or MarkdownExtra) as your flavors base class.

If you want to define a subset of the markdown language, i.e. remove some of the features, you have to extend your class from Parser.

Select language feature traits

The following shows the trait selection for traditional Markdown.

In general, just adding the trait with use is enough, however in some cases some fine tuning is desired to get most expected parsing results. Elements are detected in alphabetical order of their identification function. This means that if a line starting with - could be a list or a horizontal rule, the preference has to be set by renaming the identification function. This is what is done with renaming identifyHr to identifyAHr and identifyBUl to identifyBUl. The consume function always has to have the same name as the identification function so this has to be renamed too.

There is also a conflict for parsing of the < character. This could either be a link/email enclosed in < and > or an inline HTML tag. In order to resolve this conflict when adding the LinkTrait, we need to hide the parseInlineHtml method of the HtmlTrait.

If you use any trait that uses the $html5 property to adjust its output you also need to define this property.

If you use the link trait it may be useful to implement prepare() as shown above to reset references before parsing to ensure you get a reusable object.

Define escapeable characters

Depending on the language features you have chosen there is a different set of characters that can be escaped using \. The following is the set of escapeable characters for traditional markdown, you can copy it to your class as is.

Add custom rendering behavior

Optionally you may also want to adjust rendering behavior by overriding some methods. You may refer to the consumeParagraph() method of the Markdown and GithubMarkdown classes for some inspiration which define different rules for which elements are allowed to interrupt a paragraph.

Acknowledgements

I'd like to thank @erusev for creating Parsedown which heavily influenced this work and provided the idea of the line based parsing approach.

FAQ

Why another markdown parser?

While reviewing PHP markdown parsers for choosing one to use bundled with the Yii framework 2.0 I found that most of the implementations use regex to replace patterns instead of doing real parsing. This way extending them with new language elements is quite hard as you have to come up with a complex regex, that matches your addition but does not mess with other elements. Such additions are very common as you see on github which supports referencing issues, users and commits in the comments. A real parser should use context aware methods that walk trough the text and parse the tokens as they find them. The only implentation that I have found that uses this approach is Parsedown which also shows that this implementation is much faster than the regex way. Parsedown however is an implementation that focuses on speed and implements its own flavor (mainly github flavored markdown) in one class and at the time of this writing was not easily extensible.

Given the situation above I decided to start my own implementation using the parsing approach from Parsedown and making it extensible creating a class for each markdown flavor that extend each other in the way that also the markdown languages extend each other. This allows you to choose between markdown language flavors and also provides a way to compose your own flavor picking the best things from all. I chose this approach as it is easier to implement and also more intuitive approach compared to using callbacks to inject functionallity into the parser.

Where do I report bugs or rendering issues?

Just open an issue on github, post your markdown code and describe the problem. You may also attach screenshots of the rendered HTML result to describe your problem.

How can I contribute to this library?

Check the CONTRIBUTING.md file for more info.

Am I free to use this?

This library is open source and licensed under the MIT License. This means that you can do whatever you want with it as long as you mention my name and include the license file. Check the license for details.

Contact

Feel free to contact me using twitter.


All versions of markdown with dependencies

PHP Build Version
Package Version
Requires php Version >=5.4.0
lib-pcre Version *
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package cebe/markdown contains the following files

Collapse All

inline

  CodeTrait.php
  EmphStrongTrait.php
  LinkTrait.php
  StrikeoutTrait.php
  UrlLinkTrait.php

block

  CodeTrait.php
  FencedCodeTrait.php
  HeadlineTrait.php
  HtmlTrait.php
  ListTrait.php
  QuoteTrait.php
  RuleTrait.php
  TableTrait.php

bin

  markdown

tests

   extra-data

    code_in_lists.html
    code_in_lists.md
    fenced-code.html
    fenced-code.md
    non-tables.html
    non-tables.md
    special-attributes.html
    special-attributes.md
    tables.html
    tables.md
    test_precedence.html
    test_precedence.md

   github-data

    url.html
    test_precedence.md
    test_precedence.html
    tables.md
    tables.html
    non-tables.md
    non-tables.html
    lists.md
    lists.html
    issue-50.md
    issue-50.html
    issue-38.md
    issue-38.html
    issue-33.md
    issue-33.html
    github-sample.md
    github-sample.html
    github-code-in-numbered-list.md
    github-code-in-numbered-list.html
    github-basics.md
    github-basics.html
    dense-block-markers2.md
    dense-block-markers2.html
    dense-block-markers.md
    dense-block-markers.html
    del.md
    del.html
    code_in_lists.md
    code_in_lists.html
    url.md

   markdown-data

    md1_nested_blockquotes.html
    md1_markdown_documentation_basics.md
    md1_markdown_documentation_basics.html
    md1_literal_quotes_in_titles.md
    md1_literal_quotes_in_titles.html
    md1_links_reference_style.md
    md1_links_reference_style.html
    md1_links_inline_style.md
    md1_links_inline_style.html
    md1_inline_html_simple.md
    md1_inline_html_simple.html
    md1_inline_html_comments.md
    md1_inline_html_comments.html
    md1_inline_html_avanced.md
    md1_inline_html_avanced.html
    md1_horizontal_rules.md
    md1_horizontal_rules.html
    md1_blockquotes_with_code_blocks.md
    md1_blockquotes_with_code_blocks.html
    md1_backslash_escapes.md
    md1_backslash_escapes.html
    md1_nested_blockquotes.md
    md1_ordered_and_unordered_lists.html
    md1_ordered_and_unordered_lists.md
    paragraph.md
    utf8-do-not-kill-characters.html
    unicode.md
    unicode.html
    test_precedence.md
    test_precedence.html
    specs.md
    specs.html
    references.md
    references.html
    paragraph.html
    md1_strong_and_em_together.html
    newline.md
    newline.html
    nested-lists.md
    nested-lists.html
    md1_tidyness.md
    md1_tidyness.html
    md1_tabs.md
    md1_tabs.html
    md1_strong_and_em_together.md
    md1_auto_links.md
    md1_amps_and_angle_encoding.md
    md1_auto_links.html
    dos.md
    escape-in-link.html
    endless_loop_bug.md
    endless_loop_bug.html
    empty-line.md
    empty-line.html
    emphasis.md
    emphasis.html
    dos2.md
    dos2.html
    dos.html
    headline.html
    dense-block-markers.md
    dense-block-markers.html
    code.md
    code.html
    blockquote.md
    blockquote.html
    blockquote-nested.md
    blockquote-nested.html
    README
    escape-in-link.md
    headline.md
    md1_amps_and_angle_encoding.html
    list-marker-in-paragraph.html
    list_items_with_undefined_ref.md
    list_items_with_undefined_ref.html
    list_and_reference.md
    list_and_reference.html
    list.md
    list.html
    list-separated-by-hr.md
    list-separated-by-hr.html
    list-marker-in-paragraph.md
    links.md
    hr.html
    links.html
    lazy-list.md
    lazy-list.html
    inline-html.md
    inline-html.html
    images.md
    images.html
    html-block.md
    html-block.html
    hr.md
    utf8-do-not-kill-characters.md

   markdown-ol-start-num-data

    list.html
    list.md
    md1_ordered_and_unordered_lists.html
    md1_ordered_and_unordered_lists.md
  BaseMarkdownTest.php
  GithubMarkdownTest.php
  MarkdownExtraTest.php
  MarkdownOLStartNumTest.php
  MarkdownTest.php
  ParserTest.php
  bootstrap.php
  profile.php
CHANGELOG.md
CONTRIBUTING.md
GithubMarkdown.php
LICENSE
.travis.yml
MarkdownExtra.php
Parser.php
README.md
.scrutinizer.yml
.gitignore
composer.json
.gitattributes
phpunit.xml.dist
Markdown.php