Project

markly

0.02
A long-lived project that still receives updates
CommonMark parser and renderer. Written in C, wrapped in Ruby.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
 Dependencies
 Project Readme

Markly

A parser and abstract syntax tree for Markdown documents (CommonMark compatible) in Ruby. Originally forked from CommonMarker. It also includes extensions to the CommonMark spec as documented in the GitHub Flavored Markdown spec, such as support for tables, strikethroughs, and autolinking.

Development Status

Motivation

This code base was originally forked from Commonmarker before theyswitched from cmark-gfm (C) to comrak (Rust). The original implementation provided access to the abstract syntaxtree (AST), which is useful for building tools on top of Markdown. The Rust implementation did not provide thisfunctionality, and so this fork was created to continue to provide these (and more) features.

It should be noted that commonmarker re-introduced AST access, but the original C implementation in this fork is 3-4x faster at processing Markdown into HTML and has a more advanced HTML generation and AST processing features.

Usage

Please see the project documentation for more details.

  • Getting Started - This guide explains now to install and use Markly.

  • Abstract Syntax Tree - This guide explains how to use Markly's abstract syntax tree (AST) to parse and manipulate Markdown documents.

  • Headings - This guide explains how to work with headings in Markly, including extracting them for navigation and handling duplicate heading text.

Releases

Please see the project releases for all releases.

v0.15.1

  • Add agent context.

v0.15.0

  • Introduced Markly::Renderer::Headings class for extracting headings from markdown documents with automatic duplicate ID resolution. When rendering HTML with ids: true, duplicate heading text now automatically gets unique IDs (deployment, deployment-2, deployment-3). The Headings class can also be used to extract headings for building navigation or table of contents.

v0.14.0

  • Expose Markly::Renderer::HTML.anchor_for method to generate URL-safe anchors from headers.

Contributing

We welcome contributions to this project.

  1. Fork it.
  2. Create your feature branch (git checkout -b my-new-feature).
  3. Commit your changes (git commit -am 'Add some feature').
  4. Push to the branch (git push origin my-new-feature).
  5. Create new Pull Request.

Developer Certificate of Origin

In order to protect users of this project, we require all contributors to comply with the Developer Certificate of Origin. This ensures that all contributions are properly licensed and attributed.

Community Guidelines

This project is best served by a collaborative and respectful environment. Treat each other professionally, respect differing viewpoints, and engage constructively. Harassment, discrimination, or harmful behavior is not tolerated. Communicate clearly, listen actively, and support one another. If any issues arise, please inform the project maintainers.