2018-01-21 21:44:25 -08:00
|
|
|
// @ts-check
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
2019-04-13 11:18:57 -07:00
|
|
|
const { addErrorDetailIf, filterTokens } = require("../helpers");
|
2018-01-21 21:44:25 -08:00
|
|
|
|
2024-02-27 20:42:09 -08:00
|
|
|
// eslint-disable-next-line jsdoc/valid-types
|
|
|
|
/** @type import("./markdownlint").Rule */
|
2018-01-21 21:44:25 -08:00
|
|
|
module.exports = {
|
2023-11-09 20:05:30 -08:00
|
|
|
"names": [ "MD001", "heading-increment" ],
|
2018-03-19 23:39:42 +01:00
|
|
|
"description": "Heading levels should only increment by one level at a time",
|
2023-11-09 20:05:30 -08:00
|
|
|
"tags": [ "headings" ],
|
2024-03-09 16:17:50 -08:00
|
|
|
"parser": "markdownit",
|
2018-01-21 21:44:25 -08:00
|
|
|
"function": function MD001(params, onError) {
|
2018-04-27 22:05:34 -07:00
|
|
|
let prevLevel = 0;
|
2019-04-13 11:18:57 -07:00
|
|
|
filterTokens(params, "heading_open", function forToken(token) {
|
2020-09-06 20:34:10 -07:00
|
|
|
const level = Number.parseInt(token.tag.slice(1), 10);
|
2018-01-21 21:44:25 -08:00
|
|
|
if (prevLevel && (level > prevLevel)) {
|
2019-04-13 11:18:57 -07:00
|
|
|
addErrorDetailIf(onError, token.lineNumber,
|
2018-01-21 21:44:25 -08:00
|
|
|
"h" + (prevLevel + 1), "h" + level);
|
|
|
|
}
|
|
|
|
prevLevel = level;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|