#markup-language #html #markup #language #text #command-line #command-line-interface

bin+lib doccy

Doccy is a simple brace based markup language

7 releases

Uses old Rust 2015

0.3.2 Dec 19, 2019
0.3.1 Dec 19, 2019
0.3.0 Sep 22, 2018
0.2.3 Dec 19, 2019
0.1.1 Sep 21, 2018

#52 in #markup-language

MIT license

33KB
894 lines

Doccy

Doccy is a simple brace based markup language, an alternative to writing HTML for people who enjoy the power and flexibility but do not enjoy writing it.

Features:

See the latest documentation for more information about Doccy syntax and provided APIs.

  • Implied paragraphs and line breaks
  • Simple curley brace based element syntax
  • Support for all body HTML elements
  • Command line interface

Examples

Rust

extern crate doccy;

use doccy::doccy_to_html;

fn main() {
    match doccy_to_html("your document {em: here}") {
        // <p>your document <em>here</em></p>
        Ok(html) => println!("{}", html),
        Err(error) => {}
    };
}

Command line

# <p>your document <em>here</em></p>
echo "your document {em: here}" | doccy to-html

lib.rs:

Doccy is a simple brace based markup language, an alternative to writing HTML for people who enjoy the power and flexibility but do not enjoy writing it.

Syntax

Elements

Anything between two curley-braces is considered an element.

Regular Elements

Writing an element is easy:

{h1: Top-level heading}

Renders as:

<h1>Top-level heading</h1>

Self closing Elements

Some elements do not support children, and are self closing in which case the colon can be skipped entirely. For example line breaks (<br>) can be written as:

{br}

Renders as:

<br>

If you use this syntax for elements that do not support being self closing in HTML, then a closing tag will be rendered:

{div}

Renders as:

<div></div>

Preformatted Elements

Sometimes it is necessary to ignore Doccy syntax, you can do this with a Preformatted Element:

{pre:#
You can use all of the {brackets} in here and they {em: won't be parsed!}
#}

Renders as:

<pre>You can use all of the {brackets} in here and they {em: won't be parsed!}</pre>

This isn't just limited to the HTML pre element either, you can use it on any element.

Attributes

Anything between the name of an element and colon is expected to be an attribute.

Named Attributes

A named attribute with a value looks like:

{h1 @class main header: Header}

Renders as:

<h1 class="main header">Header</h1>

Without a value:

{input @required}

Renders as:

<input required>

Values containing special characters must be escaped:

{h1 @test Bad characters\: \@\#\%\.\{\}: ...}

Renders as:

<h1 test="Bad characters: @#%.{}">...</h1>

Unless they are part of a URL:

{a @href https://www.example.com: Example}

Renders as:

<a href="https://www.example.com">Example</h1>

Data Attributes

A shorthand for data- attributes:

{pre %lang html: ...}
{pre %html: ...}

Renders as:

<pre data-lang="html">...</pre>
<pre data-html>...</pre>

As with named attributes, special characters must be escaped.

Class Attributes

A shorthand for class="..." attributes:

{h1.main.header: Header}

Renders as:

<h1 class="main header">Header</h1>

Id Attributes

A shorthand for id="..." attributes:

{h1#main: Header}

Renders as:

<h1 id="main">Header</h1>

Paragraphs

Any text contained within specific contexts will be treated as one or more paragraphs if separated by two or more line breaks and it contains only inline elements.

In the document body

This is a paragraph.

{h1: This is a header.}

And this is another.

Renders as:

<p>This is a paragraph.</p>
<h1>This is a header.</h1>
<p>And this is another.</p>

In content elements

The following elements also automatically wrap paragraphs: article, aside, blockquote, div, fieldset, footer, form, header, hgroup, main and section.

{blockquote: This is a paragraph.

And this is another.}

Renders as:

<blockquote>
    <p>This is a paragraph.</p>
    <p>And this is another.</p>
</blockquote>

Examples

Parsing and rendering documents:

use doccy::doccy_to_html;

match doccy_to_html("your document {em: here}") {
    // <p>your document <em>here</em></p>
    Ok(html) => println!("{}", html),
    Err(error) => {}
};

Using grammar and Renderer directly:

use doccy::grammar;
use doccy::render::Renderer;

let mut renderer = Renderer::new();

if let Ok(ast) = grammar::attributes("@href https\\://example\\.com") {
    renderer.attributes(&ast);
}

println!("{}", renderer.output); // href="https://example.com"

Dependencies

~2MB
~25K SLoC