Update MD026/no-trailing-punctuation to handle empty punctuation paramater, escape for RegExp (fixes #205).

This commit is contained in:
David Anson 2019-07-26 23:03:56 -07:00
parent d336a11665
commit 91b4fcd55f
6 changed files with 39 additions and 13 deletions

View file

@ -792,23 +792,24 @@ Aliases: no-trailing-punctuation
Parameters: punctuation (string; default ".,;:!?。,;:!?")
This rule is triggered on any heading that has a normal or full-width punctuation
character as the last character in the line:
This rule is triggered on any heading that has one of the specified normal or
full-width punctuation characters as the last character in the line:
```markdown
# This is a heading.
```
To fix this, remove any trailing punctuation:
To fix this, remove the trailing punctuation:
```markdown
# This is a heading
```
Note: The punctuation parameter can be used to specify what characters class
as punctuation at the end of the heading. For example, you can set it to
`".,;:!"` to allow headings with question marks in them, such as might be used
in an FAQ.
Note: The `punctuation` parameter can be used to specify what characters count
as punctuation at the end of a heading. For example, you can change it to
`".,;:!"` to allow headings that end with a question mark, such as in an FAQ.
Setting the `punctuation` parameter to `""` allows all characters - and is
equivalent to disabling the rule.
<a name="md027"></a>

View file

@ -2,17 +2,21 @@
"use strict";
const { addError, allPunctuation, forEachHeading, rangeFromRegExp } =
require("../helpers");
const { addError, allPunctuation, escapeForRegExp, forEachHeading,
rangeFromRegExp } = require("../helpers");
module.exports = {
"names": [ "MD026", "no-trailing-punctuation" ],
"description": "Trailing punctuation in heading",
"tags": [ "headings", "headers" ],
"function": function MD026(params, onError) {
const punctuation = params.config.punctuation || allPunctuation;
const trailingPunctuationRe = new RegExp("[" + punctuation + "]$");
forEachHeading(params, function forHeading(heading, content) {
let punctuation = params.config.punctuation;
if (punctuation === undefined) {
punctuation = allPunctuation;
}
const trailingPunctuationRe =
new RegExp("[" + escapeForRegExp(punctuation) + "]$");
forEachHeading(params, (heading, content) => {
const match = trailingPunctuationRe.exec(content);
if (match) {
addError(onError, heading.lineNumber,

View file

@ -1,6 +1,6 @@
{
"default": true,
"MD026": {
"punctuation": ".,;:!"
"punctuation": ".,;:!]"
}
}

View file

@ -10,5 +10,7 @@
## Heading 6?
## Heading 7 {MD026}]
The rule has been customized to allow question marks while disallowing
everything else.

View file

@ -0,0 +1,6 @@
{
"default": true,
"MD026": {
"punctuation": ""
}
}

View file

@ -0,0 +1,13 @@
# Heading Trailing Punctuation
## Heading .
## Heading ,
## Heading ;
## Heading :
## Heading !
## Heading ?