mirror of
https://github.com/DavidAnson/markdownlint.git
synced 2025-09-22 05:40:48 +02:00
Stop sharing params object across rules because doing so is unstable for asynchronous rules (fixes #510).
This commit is contained in:
parent
4affefc68d
commit
62f5c85238
3 changed files with 87 additions and 20 deletions
|
@ -1498,22 +1498,22 @@ function lintContent(ruleList, name, content, md, config, frontMatter, handleRul
|
|||
var aliasToRuleNames = mapAliasToRuleNames(ruleList);
|
||||
var _a = getEnabledRulesPerLineNumber(ruleList, lines, frontMatterLines, noInlineConfig, config, aliasToRuleNames), effectiveConfig = _a.effectiveConfig, enabledRulesPerLineNumber = _a.enabledRulesPerLineNumber;
|
||||
// Create parameters for rules
|
||||
var params = {
|
||||
"name": helpers.deepFreeze(name),
|
||||
"tokens": helpers.deepFreeze(tokens),
|
||||
"lines": helpers.deepFreeze(lines),
|
||||
"frontMatterLines": helpers.deepFreeze(frontMatterLines)
|
||||
};
|
||||
cache.lineMetadata(helpers.getLineMetadata(params));
|
||||
cache.flattenedLists(helpers.flattenLists(params.tokens));
|
||||
cache.codeBlockAndSpanRanges(helpers.codeBlockAndSpanRanges(params, cache.lineMetadata()));
|
||||
var paramsBase = helpers.deepFreeze({
|
||||
name: name,
|
||||
tokens: tokens,
|
||||
lines: lines,
|
||||
frontMatterLines: frontMatterLines
|
||||
});
|
||||
cache.lineMetadata(helpers.getLineMetadata(paramsBase));
|
||||
cache.flattenedLists(helpers.flattenLists(paramsBase.tokens));
|
||||
cache.codeBlockAndSpanRanges(helpers.codeBlockAndSpanRanges(paramsBase, cache.lineMetadata()));
|
||||
// Function to run for each rule
|
||||
var results = [];
|
||||
// eslint-disable-next-line jsdoc/require-jsdoc
|
||||
function forRule(rule) {
|
||||
// Configure rule
|
||||
var ruleName = rule.names[0].toUpperCase();
|
||||
params.config = effectiveConfig[ruleName];
|
||||
var params = __assign(__assign({}, paramsBase), { "config": effectiveConfig[ruleName] });
|
||||
// eslint-disable-next-line jsdoc/require-jsdoc
|
||||
function throwError(property) {
|
||||
throw new Error("Property '" + property + "' of onError parameter is incorrect.");
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue