Skip to content

A tool to generate markdown document tables of contents for a single file as well as a directory of file.

License

Notifications You must be signed in to change notification settings

Root-App/2doc2toc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

2Doc2Toc

Generates table of contents for markdown files inside local git repository. Links are compatible with anchors generated by github or other sites via a command line flag.

This project was original forked from https://github.com/thlorenz/doctoc.

Table of Contents generated with DocToc

Installation

Note this package has yet to be publish but you'll be able to eventually install it with

npm install -g 2doc2toc

Usage

In its simplest usage, you can pass one or more files or folders to the 2doc2toc command. This will update the TOCs of each file specified as well as of each markdown file found by recursively searching each folder. Below are some examples.

Adding toc to all files in a directory and sub directories

Go into the directory that contains you local git project and type:

2doc2toc .

This will update all markdown files in the current directory and all its subdirectories with a table of content that will point at the anchors generated by the markdown parser. 2Doc2Toc defaults to using the GitHub parser, but other modes can be specified.

Update existing doctoc TOCs effortlessly

If you already have a TOC inserted by doctoc, it will automatically be updated by running the command (rather than inserting a duplicate toc). Doctoc locates the TOC by the <!-- START doctoc --> and <!-- END doctoc --> comments, so you can also move a generated TOC to any other portion of your document and it will be updated there.

Adding toc to individual files

If you want to convert only specific files, do:

2doc2toc /path/to/file [...]

Examples

2doc2toc README.md

2doc2toc CONTRIBUTING.md LICENSE.md

You can use this feature to do more sophisticated things. For example, if you have ack installed, you could add <!-- DOCTOC SKIP --> to specific files and then use

ack -L 'DOCTOC SKIP' | xargs 2doc2toc

to recompile only those files which don't have the DOCTOC SKIP comment.

Using 2doc2toc to generate links compatible with other sites

In order to add a table of contents whose links are compatible other sites add the appropriate mode flag:

Available modes are:

--bitbucket bitbucket.org
--nodejs    nodejs.org
--github    github.com
--gitlab    gitlab.com
--ghost     ghost.org

Example

2doc2toc README.md --bitbucket

Specifying location of toc

By default, 2doc2toc places the toc at the top of the file. You can indicate to have it placed elsewhere with the following format:

<!-- START doctoc -->
<!-- END doctoc -->

You place this code directly in your .md file. For example:

// my_new_post.md
Here we are, introducing the post. It's going to be great!
But first: a TOC for easy reference.

<!-- START doctoc -->
<!-- END doctoc -->

# Section One

Here we'll discuss...

Running 2doc2toc will insert the toc at that location.

Specifying a custom TOC title

Use the --title option to specify a (Markdown-formatted) custom TOC title; e.g., 2doc2toc --title '**Contents**' . From then on, you can simply run 2doc2toc <file> and doctoc will will keep the title you specified.

Alternatively, to blank out the title, use the --notitle option. This will simply remove the title from the TOC.

Specifying a maximum heading level for TOC entries

Use the --maxlevel option to limit TOC entries to headings only up to the specified level; e.g., 2doc2toc --maxlevel 3 .

By default,

  • no limit is placed on Markdown-formatted headings,
  • whereas headings from embedded HTML are limited to 4 levels.

Printing to stdout

You can print to stdout by using the -s or --stdout option.

Only update existing ToC

Use --update-only or -u to only update the existing ToC. That is, the Markdown files without ToC will be left untouched. It is good if you want to use 2doc2toc with lint-staged.

Usage as a git hook

2Doc2Toc can be used as a pre-commit hook by using the following configuration:

repos:
-   repo: https://github.com/Root-App/2doc2toc
    rev: ...  # substitute a tagged version
    hooks:
    -   id: 2doc2toc

This will run 2doc2toc against markdown files when committing to ensure the TOC stays up-to-date.

About

A tool to generate markdown document tables of contents for a single file as well as a directory of file.

Resources

License

Stars

Watchers

Forks

Packages

No packages published