(some of the following information may be subject to change)

Aldoc

aldoc is a markup language, which takes heavy inspiration from Markdown. Its main goal is to provide the beauty and control of LaTeX documents with Markdown's pretty syntax.

Another one of its goals is to remove the quirks that Markdown brings with its original design, such as:

Syntax

The syntax of aldoc is still WIP: what syntax will be the most beneficious has not yet been decided, but still, the one used for testing temporarily is the following:

  • Enumerated lists can be written in many ways. Aldoc's design allow you to use any combination of enumerator (1, a, III) and symbol (., ), -).
  • Bold text is written with asterisks around it. Normal text is written *until the asterisks come around*.

    Tool

  • As a tool, library and Cargo package, it provides an abstraction for the language and also a way to compile the documents to PDF. To do that the following processes takes place:

    1. The aldoc source is parsed into a Rust abstraction.
    2. The abstraction is compiled to LaTeX.
    3. The LaTeX code is compiled to PDF via LatexMk (this step is planned to change)

    Usage

    To actually compile the document, you only need to provide it with the input file path (.ald) and the output pdf path, like this:

    shell $ aldoc doc.ald compile out.pdf

    You may even omit the output file, in which case, aldoc will output a pdf with the same basename as the document.

    shell $ aldoc doc.ald compile # outputs pdf as "doc.pdf"

    Features

    Thanks

    Thanks to Markdown, and the Nom parser library for providing the necessary tools, as it was fundamental to making the Aldoc parser more extensible. Links for reference:

    (ironically this README is written in Markdown)