mirror of
https://github.com/DavidAnson/markdownlint.git
synced 2025-12-16 22:10:13 +01:00
Update MD043/required-headings to standardize early-return flow.
This commit is contained in:
parent
b13d6a49ee
commit
acd8c6ff28
2 changed files with 84 additions and 80 deletions
|
|
@ -5635,52 +5635,54 @@ module.exports = {
|
|||
"tags": ["headings", "headers"],
|
||||
"function": function MD043(params, onError) {
|
||||
var requiredHeadings = params.config.headings || params.config.headers;
|
||||
if (!Array.isArray(requiredHeadings)) {
|
||||
// Nothing to check; avoid doing any work
|
||||
return;
|
||||
}
|
||||
var matchCase = params.config.match_case || false;
|
||||
if (Array.isArray(requiredHeadings)) {
|
||||
var levels = {};
|
||||
for (var _i = 0, _arr = [1, 2, 3, 4, 5, 6]; _i < _arr.length; _i++) {
|
||||
var level = _arr[_i];
|
||||
levels["h" + level] = "######".substr(-level);
|
||||
}
|
||||
var i = 0;
|
||||
var matchAny = false;
|
||||
var hasError = false;
|
||||
var anyHeadings = false;
|
||||
var getExpected = function getExpected() {
|
||||
return requiredHeadings[i++] || "[None]";
|
||||
};
|
||||
var handleCase = function handleCase(str) {
|
||||
return matchCase ? str : str.toLowerCase();
|
||||
};
|
||||
forEachHeading(params, function (heading, content) {
|
||||
if (!hasError) {
|
||||
anyHeadings = true;
|
||||
var actual = levels[heading.tag] + " " + content;
|
||||
var expected = getExpected();
|
||||
if (expected === "*") {
|
||||
var nextExpected = getExpected();
|
||||
if (handleCase(nextExpected) !== handleCase(actual)) {
|
||||
matchAny = true;
|
||||
i--;
|
||||
}
|
||||
} else if (expected === "+") {
|
||||
var levels = {};
|
||||
for (var _i = 0, _arr = [1, 2, 3, 4, 5, 6]; _i < _arr.length; _i++) {
|
||||
var level = _arr[_i];
|
||||
levels["h" + level] = "######".substr(-level);
|
||||
}
|
||||
var i = 0;
|
||||
var matchAny = false;
|
||||
var hasError = false;
|
||||
var anyHeadings = false;
|
||||
var getExpected = function getExpected() {
|
||||
return requiredHeadings[i++] || "[None]";
|
||||
};
|
||||
var handleCase = function handleCase(str) {
|
||||
return matchCase ? str : str.toLowerCase();
|
||||
};
|
||||
forEachHeading(params, function (heading, content) {
|
||||
if (!hasError) {
|
||||
anyHeadings = true;
|
||||
var actual = levels[heading.tag] + " " + content;
|
||||
var expected = getExpected();
|
||||
if (expected === "*") {
|
||||
var nextExpected = getExpected();
|
||||
if (handleCase(nextExpected) !== handleCase(actual)) {
|
||||
matchAny = true;
|
||||
} else if (handleCase(expected) === handleCase(actual)) {
|
||||
matchAny = false;
|
||||
} else if (matchAny) {
|
||||
i--;
|
||||
} else {
|
||||
addErrorDetailIf(onError, heading.lineNumber, expected, actual);
|
||||
hasError = true;
|
||||
}
|
||||
} else if (expected === "+") {
|
||||
matchAny = true;
|
||||
} else if (handleCase(expected) === handleCase(actual)) {
|
||||
matchAny = false;
|
||||
} else if (matchAny) {
|
||||
i--;
|
||||
} else {
|
||||
addErrorDetailIf(onError, heading.lineNumber, expected, actual);
|
||||
hasError = true;
|
||||
}
|
||||
});
|
||||
var extraHeadings = requiredHeadings.length - i;
|
||||
if (!hasError && (extraHeadings > 1 || extraHeadings === 1 && requiredHeadings[i] !== "*") && (anyHeadings || !requiredHeadings.every(function (heading) {
|
||||
return heading === "*";
|
||||
}))) {
|
||||
addErrorContext(onError, params.lines.length, requiredHeadings[i]);
|
||||
}
|
||||
});
|
||||
var extraHeadings = requiredHeadings.length - i;
|
||||
if (!hasError && (extraHeadings > 1 || extraHeadings === 1 && requiredHeadings[i] !== "*") && (anyHeadings || !requiredHeadings.every(function (heading) {
|
||||
return heading === "*";
|
||||
}))) {
|
||||
addErrorContext(onError, params.lines.length, requiredHeadings[i]);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
|
|
|||
82
lib/md043.js
82
lib/md043.js
|
|
@ -11,52 +11,54 @@ module.exports = {
|
|||
"tags": [ "headings", "headers" ],
|
||||
"function": function MD043(params, onError) {
|
||||
const requiredHeadings = params.config.headings || params.config.headers;
|
||||
if (!Array.isArray(requiredHeadings)) {
|
||||
// Nothing to check; avoid doing any work
|
||||
return;
|
||||
}
|
||||
const matchCase = params.config.match_case || false;
|
||||
if (Array.isArray(requiredHeadings)) {
|
||||
const levels = {};
|
||||
for (const level of [ 1, 2, 3, 4, 5, 6 ]) {
|
||||
levels["h" + level] = "######".substr(-level);
|
||||
}
|
||||
let i = 0;
|
||||
let matchAny = false;
|
||||
let hasError = false;
|
||||
let anyHeadings = false;
|
||||
const getExpected = () => requiredHeadings[i++] || "[None]";
|
||||
const handleCase = (str) => (matchCase ? str : str.toLowerCase());
|
||||
forEachHeading(params, (heading, content) => {
|
||||
if (!hasError) {
|
||||
anyHeadings = true;
|
||||
const actual = levels[heading.tag] + " " + content;
|
||||
const expected = getExpected();
|
||||
if (expected === "*") {
|
||||
const nextExpected = getExpected();
|
||||
if (handleCase(nextExpected) !== handleCase(actual)) {
|
||||
matchAny = true;
|
||||
i--;
|
||||
}
|
||||
} else if (expected === "+") {
|
||||
const levels = {};
|
||||
for (const level of [ 1, 2, 3, 4, 5, 6 ]) {
|
||||
levels["h" + level] = "######".substr(-level);
|
||||
}
|
||||
let i = 0;
|
||||
let matchAny = false;
|
||||
let hasError = false;
|
||||
let anyHeadings = false;
|
||||
const getExpected = () => requiredHeadings[i++] || "[None]";
|
||||
const handleCase = (str) => (matchCase ? str : str.toLowerCase());
|
||||
forEachHeading(params, (heading, content) => {
|
||||
if (!hasError) {
|
||||
anyHeadings = true;
|
||||
const actual = levels[heading.tag] + " " + content;
|
||||
const expected = getExpected();
|
||||
if (expected === "*") {
|
||||
const nextExpected = getExpected();
|
||||
if (handleCase(nextExpected) !== handleCase(actual)) {
|
||||
matchAny = true;
|
||||
} else if (handleCase(expected) === handleCase(actual)) {
|
||||
matchAny = false;
|
||||
} else if (matchAny) {
|
||||
i--;
|
||||
} else {
|
||||
addErrorDetailIf(onError, heading.lineNumber,
|
||||
expected, actual);
|
||||
hasError = true;
|
||||
}
|
||||
} else if (expected === "+") {
|
||||
matchAny = true;
|
||||
} else if (handleCase(expected) === handleCase(actual)) {
|
||||
matchAny = false;
|
||||
} else if (matchAny) {
|
||||
i--;
|
||||
} else {
|
||||
addErrorDetailIf(onError, heading.lineNumber,
|
||||
expected, actual);
|
||||
hasError = true;
|
||||
}
|
||||
});
|
||||
const extraHeadings = requiredHeadings.length - i;
|
||||
if (
|
||||
!hasError &&
|
||||
((extraHeadings > 1) ||
|
||||
((extraHeadings === 1) && (requiredHeadings[i] !== "*"))) &&
|
||||
(anyHeadings || !requiredHeadings.every((heading) => heading === "*"))
|
||||
) {
|
||||
addErrorContext(onError, params.lines.length,
|
||||
requiredHeadings[i]);
|
||||
}
|
||||
});
|
||||
const extraHeadings = requiredHeadings.length - i;
|
||||
if (
|
||||
!hasError &&
|
||||
((extraHeadings > 1) ||
|
||||
((extraHeadings === 1) && (requiredHeadings[i] !== "*"))) &&
|
||||
(anyHeadings || !requiredHeadings.every((heading) => heading === "*"))
|
||||
) {
|
||||
addErrorContext(onError, params.lines.length,
|
||||
requiredHeadings[i]);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue