This repository provides GitHub's recommended markdownlint configurations, and additional rules for use on GitHub open source and internal projects.
In addition to defaults defined by markdownlint, we use this repository to enforce rules not defined by default, including our own custom rules.
See opinions codified in index.js.
The following are custom rules defined in this plugin.
See markdownlint rules for documentation on rules pulled in from markdownlint.
Important: We support the use of markdownlint through markdownlint-cli2 instead of markdownlint-cli for compatibility with the vscode-markdownlint plugin.
- 
Create a .markdownlint-cli2.mjsfile in the root of your repository.touch .markdownlint-cli2.mjs 
- 
Install packages. npm install -D markdownlint-cli2 # if updating existing package, check for updates npm install -D @github/markdownlint-github [--@github:registry=https://registry.npmjs.org] npm install -D markdownlint-cli2-formatter-pretty 
- 
Add/modify your linting script in package.json."scripts": { "lint:markdown": "markdownlint-cli2 \"**/*.{md,mdx}\" \"!node_modules\"" } 
- 
Edit .markdownlint-cli2.mjsfile to suit your needs. Start withimport markdownIt from "markdown-it" import configOptions, {init} from "@github/markdownlint-github" const markdownItFactory = () => markdownIt({ html: true }) const options = { config: init(), customRules: ["@github/markdownlint-github"], markdownItFactory, outputFormatters: [ [ "markdownlint-cli2-formatter-pretty", { "appendLink": true } ] // ensures the error message includes a link to the rule documentation ] } export default options Or, you can also pass in configuration options that you wish to override the default. Read more at Customizing configurations. This looks like: import markdownIt from "markdown-it" import configOptions, {init} from "@github/markdownlint-github" const overriddenOptions = init({ 'fenced-code-language': false, // Custom overrides }) const markdownItFactory = () => markdownIt({ html: true }) const options = { config: overriddenOptions, customRules: ["@github/markdownlint-github"], markdownItFactory, outputFormatters: [ [ "markdownlint-cli2-formatter-pretty", { "appendLink": true } ] ] } export default options 
- 
Install the vscode-markdownlintplugin to ensuremarkdownlintviolations are surfaced in the file. This plugin should flag rules based off your.markdownlint-cli2.mjsconfiguration. When you make edits to your configuration, you will need to reload the VSCode window (Ctrl+Shift+P->Reload Window) to ensure the extension syncs. If your project runs on Codespaces, consider adding this extension to your.devcontainer/devcontainer.jsonso that this extension is installed to new Codespaces by default.
You may determine that the defaults set by this plugin are not suitable for your project.
This plugin will pull in the the defaults defined by markdownlint, several of which pertain to stylistic practices. You may choose to disable these rules if you determine it doesn't provide value for your project.
However, others of these rules should NOT be disabled because they encourage best accessibility practices. Disabling these rules will negatively impact accessibility. These rules are defined in accessibility.json.
To review configurations supported by markdownlint, see markdownlint-cli2 configuration.
You may write custom rules within your repository. Follow the custom rules guide in markdownlint to write your rule.
The rule will need to be enabled in the configuration. For instance, if you introduce some-rule.js with the name "some-rule", you must set the path of the custom rule in the .markdownlint-cli2.mjs file:
import configOptions, {init} from "@github/markdownlint-github"
import markdownIt from "markdown-it"
const markdownItFactory = () => markdownIt({ html: true })
const options = init({
    "some-rule": true,
    customRules: ["@github/markdownlint-github", "some-rule.js"],
    markdownItFactory
})
export default optionsSee markdownlint-cli2 configuration.
Consider upstreaming any rules you find useful as proposals to this repository.
This project is licensed under the terms of the MIT open source license. Please refer to the MIT license for the full terms.
See CODEOWNERS.
Please read Contributing Guide for more information.