2017 © Pedro Peláez
 

library cli-md-renderer

A CLI Markdown Render for league/commonmark compatibile AST

image

aydin-hassan/cli-md-renderer

A CLI Markdown Render for league/commonmark compatibile AST

  • Wednesday, February 28, 2018
  • by AydinHassan
  • Repository
  • 1 Watchers
  • 3 Stars
  • 4,816 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 7 Versions
  • 1 % Grown

The README.md

CLI Markdown Renderer

<img src="https://github.com/AydinHassan/cli-md-renderer/workflows/CliMdRenderer/badge.svg">

Build Status Windows Build Status Coverage Status, (*1)

Usage

<?php
require_once 'vendor/autoload.php';

use AydinHassan\CliMdRenderer\CliRendererFactory;
use League\CommonMark\Environment\Environment;
use League\CommonMark\Parser\MarkdownParser;

$parser       = new MarkdownParser((new Environment())->addExtension(new CommonMarkCoreExtension()));
$parser       = new DocParser(Environment::createCommonMarkEnvironment());
$cliRenderer  = (new CliRendererFactory)->__invoke();
$ast          = $parser->parse(file_get_contents('path/to/file.md'));

echo $cliRenderer->renderBlock($ast);

Syntax Highlighting

FencedCode can be syntax highlighted. By default only PHP source code is Syntax Highlighted using: kadet/keylighter If you want to add syntax highlighting for other languages you should create a class which implements \AydinHassan\CliMdRenderer\SyntaxHighlighterInterface, (*2)

It accepts code as a string and should return highlighted code as a string. You register your highlighter like so, (*3)

<?php

use AydinHassan\CliMdRenderer\Renderer\FencedCodeRenderer;

$codeRenderer = new FencedCodeRenderer;
$codeRenderer->addSyntaxHighlighter('js', new JsSyntaxHighlighter);

If you need to do this you cannot use the factory so construction will look something like:, (*4)

<?php 
require_once 'vendor/autoload.php';

use AydinHassan\CliMdRenderer\Highlighter\PhpHighlighter;
use AydinHassan\CliMdRenderer\InlineRenderer\LinkRenderer;
use AydinHassan\CliMdRenderer\Renderer\DocumentRenderer;
use AydinHassan\CliMdRenderer\Renderer\FencedCodeRenderer;
use AydinHassan\CliMdRenderer\Renderer\HeaderRenderer;
use AydinHassan\CliMdRenderer\Renderer\HorizontalRuleRenderer;
use AydinHassan\CliMdRenderer\Renderer\ParagraphRenderer;
use Colors\Color;
use Kadet\Highlighter\KeyLighter;
use League\CommonMark\Block\Element\Document;
use League\CommonMark\Block\Element\Header;
use League\CommonMark\Block\Element\HorizontalRule;
use League\CommonMark\Block\Element\Paragraph;
use League\CommonMark\Block\Element\FencedCode;
use AydinHassan\CliMdRenderer\InlineRenderer\TextRenderer;
use AydinHassan\CliMdRenderer\InlineRenderer\CodeRenderer;
use AydinHassan\CliMdRenderer\InlineRenderer\EmphasisRenderer;
use AydinHassan\CliMdRenderer\InlineRenderer\StrongRenderer;
use AydinHassan\CliMdRenderer\InlineRenderer\NewlineRenderer;
use League\CommonMark\Inline\Element\Link;
use League\CommonMark\Inline\Element\Text;
use League\CommonMark\Inline\Element\Code;
use League\CommonMark\Inline\Element\Emphasis;
use League\CommonMark\Inline\Element\Strong;
use League\CommonMark\Inline\Element\Newline;

$codeRender = new FencedCodeRenderer();
$keyLighter = new KeyLighter;
$keyLighter->init();
$codeRender->addSyntaxHighlighter('php', new PhpHighlighter($keyLighter));
$codeRender->addSyntaxHighlighter('js', new JsSyntaxHighlighter);

$blockRenderers = [
    Document::class         => new DocumentRenderer,
    Header::class           => new HeaderRenderer,
    HorizontalRule::class   => new HorizontalRuleRenderer,
    Paragraph::class        => new ParagraphRenderer,
    FencedCode::class       => $codeRender,
];

$inlineBlockRenderers = [
    Text::class             => new TextRenderer,
    Code::class             => new CodeRenderer,
    Emphasis::class         => new EmphasisRenderer,
    Strong::class           => new StrongRenderer,
    Newline::class          => new NewlineRenderer,
    Link::class             => new LinkRenderer,
];

$colors = new Color;
$colors->setForceStyle(true);

return new CliRenderer($blockRenderers, $inlineBlockRenderers, $colors);

To Do

  • [ ] Make configurable (Line Endings, colors, styles)
  • [x] Image Renderer
  • [x] List Renderer
  • [x] Code Syntax Highlighting
  • [x] Documentation

The Versions

28/02 2018

dev-master

9999999-dev

A CLI Markdown Render for league/commonmark compatibile AST

  Sources   Download

MIT

The Requires

 

The Development Requires

28/02 2018

2.3.0

2.3.0.0

A CLI Markdown Render for league/commonmark compatibile AST

  Sources   Download

MIT

The Requires

 

The Development Requires

05/03 2017

2.2.0

2.2.0.0

A CLI Markdown Render for league/commonmark compatibile AST

  Sources   Download

MIT

The Requires

 

The Development Requires

27/10 2016

2.1.0

2.1.0.0

A CLI Markdown Render for league/commonmark compatibile AST

  Sources   Download

MIT

The Requires

 

The Development Requires

27/06 2016

2.0.0

2.0.0.0

A CLI Markdown Render for league/commonmark compatibile AST

  Sources   Download

MIT

The Requires

 

The Development Requires

04/12 2015

1.0.1

1.0.1.0

A CLI Markdown Render for league/commonmark compatibile AST

  Sources   Download

MIT

The Requires

 

The Development Requires

18/10 2015