Skip to content

Wrapper-script for running markdown linters in Foliant projects

License

Notifications You must be signed in to change notification settings

holamgadol/foliant-md-linter

Repository files navigation

Foliant markdown linter

Wrapper-script for running markdown linters in Foliant projects.

This script uses:

Installation

Locate your foliant project:

cd my-awesome-foliant-project/

Install foliant-md-linter via npm. Locally or globally, as you wish.

npm i foliant-md-linter

Include foliant-md-linter into Foliant build

You can invoke foliant-md-linter in a Foliant building process.

Prerequisites

  • Install foliant-md-linter into your Docker-image if you're using a building within Docker:

    RUN npm i foliant-md-linter -g
  • Install runcommands preprocessor if you haven't installed it yet:

    • native install

      pip install foliantcontrib.runcommands
    • docker install

      RUN pip3 install foliantcontrib.runcommands
  1. Add runcommands to the preprocessors part of the foliant.yml:
preprocessors:
    - runcommands:
        commands:
            - cd ${PROJECT_DIR}
            # use thr project title for the p argument
            # use the l flag if using foliant-md-linter within docker
            - foliant-md-linter styleguide -v -p my-awesome-foliant-project -s src -l
  1. Build you project as usual and check the output for foliant-md-linter messages.
$ foliant make site --with mkdocs
Parsing config... Done
Applying preprocessor runcommands... markdownlint-cli2 v0.4.0 (markdownlint v0.25.1)

Finding: src/**/*.md
...
Found 5 styleguide and formatting errors
Full markdownlint log see in /usr/src/app/.markdownlint_full.log

removing /usr/src/app/.markdownlint-cli2.jsonc ...

Done
Applying preprocessor mkdocs... Done
...

Usage

Run foliant-md-linter from the project root with following commands and options:

  • full-check – check md files with markdownlint and markdown-link-check

    • -v, --verbose – print full linting results (default: false)

    • -s, --source <path-to-sources> – specify source directory (default: src)

    • -c, --config <path-to-sources> – path to custom config

    • -p, --project <project-name> – specify project name

    • -d, --debug – print executing command (default: false)

    • -a, --allowfailure – allow exit with failure if errors (default: false)

    • --node-modules <node-modules-path> – custom path to node modules (the command to get the path to the node modules npm list -g | head -1)

    • -w --working-dir <working-dir> – the working directory should be set if the project folder differs from the CWD. For example, when using the linter in vs code (the command to get the path to the working dir pwd in the foliant project folder)

      helpful in CI/CD, as you can cause pipelines to fail in case of linting errors

    • -l, --clearconfig – remove markdownlint config after execution (default: false)

      helpful within docker, otherwise annoying bugs are occurred with the markdownlint extension for VSCode

    • -f, --fix – fix formatting errors with markdownlint (default: false)

    • -m, --markdownlintmode – set mode for markdownlint. Possible values:

      • full – check md files with markdownlint and markdown-link-check
      • slim (default value) – check for critical errors with markdownlint
      • typograph – fix typograph errors with markdownlint
      • mdlint-default – check md files for critical formatting errors with markdownlint and validate external links with markdown-link-check
    • --foliant-config – set the configuration file is a foliant from which chapters (default: ./foliant.yml)

    • --format – set the format of the markdownlint-cli2 config file (default: jsonc, incompatible with --project, --node-modules, --working-dir)

  • markdown – check md files for errors with markdownlint

    • -v, -s, -c, -d, -a, -l, -f, -m, --foliant-config
  • urls validate external links with markdown-link-check

    • -v, -s, -d, -a, -l
  • print print linting results

    • -v
  • create-config create markdownlint config for styleguide adherence

    • -v, -s, -p, -d, -m

.markdownlintignore – an exception file, each line of which can contain a glob.

Format cjs

Using the --format argument on the CLI, you can set the configuration file format for markdownlint-cli2. If you select the cjs format, you will get a more automated version of the configuration file. You will not need to manually specify the parameters working_dir, node_modules and project. These arguments will be make automatically using the path and git-repo-name extensions.

The configuration file will list all the files specified in the chapters and includes_map sections for use as "globs".

To use the lint all markdown files function with the markdownlint extension for VS Code, a file will be added to the project folder .vscode/settings.json. Checking of all files will be disabled in this file, but the list of files that need to be checked will remain in the cjs file. So you can use the lint all markdown files function in VS Code, but it will check only those files that will be contained in chapters, and in includes_map.json

Examples

The simplest case

$ npx foliant-md-linter full-check

Checked 2 files
Found 8 critical formatting errors
Full markdownlint log see in /Users/user/github/foliant-md-linter/.markdownlint_slim.log

Found 9 styleguide and formatting errors
Full markdownlint log see in /Users/user/github/foliant-md-linter/.markdownlint_full.log

Found 2 broken external links
Full markdown-link-check log see in /Users/user/github/foliant-md-linter/.markdownlinkcheck.log

If you want more detailed output

$ npx foliant-md-linter full-check -v

Checked 2 files
Found 8 critical formatting errors

--------------------------------------------------------------------------------

FILE: src/linter-test-A.md

src/linter-test-A.md:3 MD001/heading-increment/header-increment Heading levels should only increment by one level at a time [Expected: h2; Actual: h3]
src/linter-test-A.md:7 indented-fence Fenced code shouldn't be indented by 1 to 3 spaces [Context: "   ```bash"]
src/linter-test-A.md:11 non-literal-fence-label Invalid language label in fenced code block
src/linter-test-A.md:18 fenced-code-in-quote Fenced code shouldn't be in quote
src/linter-test-A.md:26 validate-internal-links Broken link [image does not exist] [Context: "/red-circle.png"]
src/linter-test-A.md:30 validate-internal-links Broken link [file does not exist] [Context: "/another-project/subproject/article"]
src/linter-test-A.md:32 validate-internal-links Broken link [file does not exist] [Context: "/another-project/subproject/article#anchor"]

--------------------------------------------------------------------------------

FILE: src/subproject/article.md

src/subproject/article.md:3 validate-internal-links Broken link [invalid local anchor] [Context: "#anchor"]

Full markdownlint log see in /Users/user/github/foliant-md-linter/.markdownlint_slim.log

Found 9 styleguide and formatting errors
Full markdownlint log see in /Users/user/github/foliant-md-linter/.markdownlint_full.log

Found 2 broken external links

--------------------------------------------------------------------------------

FILE: src//linter-test-A.md

  [✖] https://github.com/holamgadol/foliant-md-lint → Status: 404

--------------------------------------------------------------------------------

FILE: src//subproject/article.md

  [✖] https://github.com/holamgadol/foliant-md-linte → Status: 404

Full markdown-link-check log see in /Users/user/github/foliant-md-linter/.markdownlinkcheck.log

If project sources are located in a folder other than src, then you may specify them via -s option

$ npx foliant-md-linter full-check -s another-sources

Sometimes, the project directory and the project name could be different, especially inside docker containers. You have an option to specify the project name to validate absolute links properly

$ npx foliant-md-linter full-check -p project-name

You can edit a generated .markdownlint-cli2.jsonc config file for your needs and use it for the next markdownlint runs by -c option

$ npx foliant-md-linter full-check -c