Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Mdformat plugin to generate a table of contents
Table of Contents generated with mdformat-toc
Mdformat-toc is an mdformat plugin that adds mdformat the capability to auto-generate a table of contents (ToC). The ToC is generated in a user-specified location in the Markdown file.
Mdformat-toc, by default, creates an HTML anchor for each heading listed in the ToC. ToC links should therefore be compatible with any well-behaved Markdown renderer (including GitLab's renderer).
HTML anchor generation can be disabled, in which case a user should configure a slug function that is compatible with the Markdown renderer used (GitHub and GitLab slug functions are currently supported).
pip install mdformat-toc
Add the following line to your Markdown file. A ToC will be generated in the location indicated by it.
<!-- mdformat-toc start -->
After adding the indicator line, simply run
mdformat <filename>
and mdformat will generate a ToC.
Arguments can be added to the indicator line to alter how the ToC is generated. An indicator line with the default options would look like:
<!-- mdformat-toc start --slug=github --maxlevel=6 --minlevel=1 -->
Placing more than one indicator lines in a document is currently not supported.
A user can configure a range of heading levels to be included in the ToC (and to be "anchored"). For instance, the following configuration will only list 2nd, 3rd and 4th level headings in the ToC:
<!-- mdformat-toc start --minlevel=2 --maxlevel=4 -->
By default, an HTML anchor is appended to each heading. For instance, the following heading
# Some title
might be formatted as
# Some title<a name="some-title"></a>
This ensures that ToC links do not rely on a Markdown renderer to create HTML anchors, and makes the links universally compatible.
ToC links are by default compatible with the anchors generated by GitHub's Markdown renderer. If your Markdown is only hosted on GitHub, you can disable mdformat-toc's HTML anchor generation:
<!-- mdformat-toc start --no-anchors -->
Mdformat-toc defaults to using GitHub's slug function.
If your Markdown is not hosted on GitHub you may want to use GitLab's slug function instead:
<!-- mdformat-toc start --slug=gitlab --no-anchors -->
NOTE: Unlike GitLab, GitHub requires using its own slug function in order for ToC links to work expectedly. Creating HTML anchors and using a non-GitHub slug function is not GitHub compatible because GitHub's Markdown renderer modifies the HTML anchors mdformat-toc creates. The default configuration (GitHub slug function and anchor generation) is the only configuration cross-compatible with GitHub and GitLab.
FAQs
Mdformat plugin to generate table of contents
We found that mdformat-toc demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.