slopless 0.2.7 → 0.2.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +19 -3
- package/dist/adapters/textlint/rule.js +21 -0
- package/dist/adapters/textlint/rule.js.map +1 -0
- package/dist/adapters/textlint/units.js +133 -1
- package/dist/adapters/textlint/units.js.map +1 -1
- package/dist/cli.js +1 -1
- package/dist/presets/everything.js +2 -0
- package/dist/presets/everything.js.map +1 -1
- package/dist/registries/orthography.js +4 -0
- package/dist/registries/orthography.js.map +1 -1
- package/dist/reporting/reports.js +50 -0
- package/dist/reporting/reports.js.map +1 -1
- package/dist/rules/academic-slop/tortured-phrases.js +13 -23
- package/dist/rules/academic-slop/tortured-phrases.js.map +1 -1
- package/dist/rules/metrics/avg-sentence-length.js +23 -21
- package/dist/rules/metrics/avg-sentence-length.js.map +1 -1
- package/dist/rules/metrics/coleman-liau.js +23 -23
- package/dist/rules/metrics/coleman-liau.js.map +1 -1
- package/dist/rules/metrics/flesch-kincaid.js +23 -23
- package/dist/rules/metrics/flesch-kincaid.js.map +1 -1
- package/dist/rules/metrics/gunning-fog.js +23 -23
- package/dist/rules/metrics/gunning-fog.js.map +1 -1
- package/dist/rules/metrics/paragraph-length.js +19 -20
- package/dist/rules/metrics/paragraph-length.js.map +1 -1
- package/dist/rules/metrics/word-repetition.js +20 -21
- package/dist/rules/metrics/word-repetition.js.map +1 -1
- package/dist/rules/narrative-slop/body-action-density.js +60 -23
- package/dist/rules/narrative-slop/body-action-density.js.map +1 -1
- package/dist/rules/narrative-slop/data/narrative-cliches.json +27 -0
- package/dist/rules/narrative-slop/flat-action-cadence.js +23 -26
- package/dist/rules/narrative-slop/flat-action-cadence.js.map +1 -1
- package/dist/rules/narrative-slop/narrative-cliches.js +35 -33
- package/dist/rules/narrative-slop/narrative-cliches.js.map +1 -1
- package/dist/rules/narrative-slop/perception-verb-density.js +22 -23
- package/dist/rules/narrative-slop/perception-verb-density.js.map +1 -1
- package/dist/rules/orthography/artifact-placeholders.js +110 -0
- package/dist/rules/orthography/artifact-placeholders.js.map +1 -0
- package/dist/rules/orthography/colon-dramatic.js +24 -32
- package/dist/rules/orthography/colon-dramatic.js.map +1 -1
- package/dist/rules/orthography/em-dashes.js +19 -33
- package/dist/rules/orthography/em-dashes.js.map +1 -1
- package/dist/rules/orthography/exclamation-density.js +20 -34
- package/dist/rules/orthography/exclamation-density.js.map +1 -1
- package/dist/rules/orthography/fake-timestamps.js +12 -32
- package/dist/rules/orthography/fake-timestamps.js.map +1 -1
- package/dist/rules/orthography/hidden-unicode-controls.js +51 -0
- package/dist/rules/orthography/hidden-unicode-controls.js.map +1 -0
- package/dist/rules/orthography/sentence-case.js +24 -32
- package/dist/rules/orthography/sentence-case.js.map +1 -1
- package/dist/rules/orthography/smart-quotes.js +12 -32
- package/dist/rules/orthography/smart-quotes.js.map +1 -1
- package/dist/rules/phrases/cliches.js +16 -27
- package/dist/rules/phrases/cliches.js.map +1 -1
- package/dist/rules/phrases/corporate-speak.js +16 -27
- package/dist/rules/phrases/corporate-speak.js.map +1 -1
- package/dist/rules/phrases/data/llm-disclaimer-expansions.json +9 -2
- package/dist/rules/phrases/data/redundancy-patterns.json +7 -0
- package/dist/rules/phrases/data/wordiness-patterns.json +2 -0
- package/dist/rules/phrases/humble-bragger.js +12 -22
- package/dist/rules/phrases/humble-bragger.js.map +1 -1
- package/dist/rules/phrases/jargon-faker.js +14 -25
- package/dist/rules/phrases/jargon-faker.js.map +1 -1
- package/dist/rules/phrases/llm-disclaimer.js +19 -23
- package/dist/rules/phrases/llm-disclaimer.js.map +1 -1
- package/dist/rules/phrases/prohibited-phrases.js +13 -23
- package/dist/rules/phrases/prohibited-phrases.js.map +1 -1
- package/dist/rules/phrases/redundancy.js +13 -23
- package/dist/rules/phrases/redundancy.js.map +1 -1
- package/dist/rules/phrases/skunked-terms.js +13 -23
- package/dist/rules/phrases/skunked-terms.js.map +1 -1
- package/dist/rules/phrases/uncomparables.js +15 -26
- package/dist/rules/phrases/uncomparables.js.map +1 -1
- package/dist/rules/phrases/wordiness.js +13 -23
- package/dist/rules/phrases/wordiness.js.map +1 -1
- package/dist/rules/private/textlint-rule-builders.js +46 -0
- package/dist/rules/private/textlint-rule-builders.js.map +1 -0
- package/dist/rules/semantic-thinness/patterns/puffery-evaluative-claim.json +56 -0
- package/dist/rules/semantic-thinness/private/pattern-data-d.js +2 -0
- package/dist/rules/semantic-thinness/private/pattern-data-d.js.map +1 -1
- package/dist/rules/semantic-thinness/semantic-thinness.js +27 -23
- package/dist/rules/semantic-thinness/semantic-thinness.js.map +1 -1
- package/dist/rules/syntactic-patterns/authority/authority-padding.js +19 -23
- package/dist/rules/syntactic-patterns/authority/authority-padding.js.map +1 -1
- package/dist/rules/syntactic-patterns/closers/affirmation-closers.js +45 -43
- package/dist/rules/syntactic-patterns/closers/affirmation-closers.js.map +1 -1
- package/dist/rules/syntactic-patterns/closers/boilerplate-conclusion.js +25 -22
- package/dist/rules/syntactic-patterns/closers/boilerplate-conclusion.js.map +1 -1
- package/dist/rules/syntactic-patterns/closers/false-question.js +20 -24
- package/dist/rules/syntactic-patterns/closers/false-question.js.map +1 -1
- package/dist/rules/syntactic-patterns/closers/summative-closer.js +20 -24
- package/dist/rules/syntactic-patterns/closers/summative-closer.js.map +1 -1
- package/dist/rules/syntactic-patterns/contrast/blame-reframe.js +19 -23
- package/dist/rules/syntactic-patterns/contrast/blame-reframe.js.map +1 -1
- package/dist/rules/syntactic-patterns/contrast/contrastive-aphorism.js +39 -31
- package/dist/rules/syntactic-patterns/contrast/contrastive-aphorism.js.map +1 -1
- package/dist/rules/syntactic-patterns/contrast/negation-reframe.js +12 -21
- package/dist/rules/syntactic-patterns/contrast/negation-reframe.js.map +1 -1
- package/dist/rules/syntactic-patterns/contrast/private/negation-reframe-parts.js +4 -2
- package/dist/rules/syntactic-patterns/contrast/private/negation-reframe-parts.js.map +1 -1
- package/dist/rules/syntactic-patterns/contrast/private/negative-slop-frames.js +33 -2
- package/dist/rules/syntactic-patterns/contrast/private/negative-slop-frames.js.map +1 -1
- package/dist/rules/syntactic-patterns/generalization/softening-language.js +19 -23
- package/dist/rules/syntactic-patterns/generalization/softening-language.js.map +1 -1
- package/dist/rules/syntactic-patterns/generalization/universalizing-claims.js +19 -23
- package/dist/rules/syntactic-patterns/generalization/universalizing-claims.js.map +1 -1
- package/dist/rules/syntactic-patterns/lead-ins/boilerplate-framing.js +12 -22
- package/dist/rules/syntactic-patterns/lead-ins/boilerplate-framing.js.map +1 -1
- package/dist/rules/syntactic-patterns/lead-ins/generic-signposting.js +19 -23
- package/dist/rules/syntactic-patterns/lead-ins/generic-signposting.js.map +1 -1
- package/dist/rules/syntactic-patterns/lead-ins/lesson-framing.js +19 -23
- package/dist/rules/syntactic-patterns/lead-ins/lesson-framing.js.map +1 -1
- package/dist/rules/syntactic-patterns/lead-ins/llm-openers.js +28 -25
- package/dist/rules/syntactic-patterns/lead-ins/llm-openers.js.map +1 -1
- package/dist/rules/syntactic-patterns/lead-ins/observer-guidance.js +19 -23
- package/dist/rules/syntactic-patterns/lead-ins/observer-guidance.js.map +1 -1
- package/dist/rules/syntactic-patterns/llm-artifacts/data/response-wrapper-patterns.json +6 -0
- package/dist/rules/syntactic-patterns/llm-artifacts/response-wrapper.js +21 -26
- package/dist/rules/syntactic-patterns/llm-artifacts/response-wrapper.js.map +1 -1
- package/dist/rules/syntactic-patterns/repetition/demonstrative-emphasis.js +28 -51
- package/dist/rules/syntactic-patterns/repetition/demonstrative-emphasis.js.map +1 -1
- package/dist/rules/syntactic-patterns/repetition/empty-emphasis.js +19 -23
- package/dist/rules/syntactic-patterns/repetition/empty-emphasis.js.map +1 -1
- package/dist/rules/syntactic-patterns/repetition/fragment-stacking.js +12 -32
- package/dist/rules/syntactic-patterns/repetition/fragment-stacking.js.map +1 -1
- package/dist/rules/syntactic-patterns/repetition/triple-repeat.js +15 -38
- package/dist/rules/syntactic-patterns/repetition/triple-repeat.js.map +1 -1
- package/dist/rules/term-policy/recommended-terms.js +24 -22
- package/dist/rules/term-policy/recommended-terms.js.map +1 -1
- package/dist/rules/term-policy/required-terms.js +20 -24
- package/dist/rules/term-policy/required-terms.js.map +1 -1
- package/dist/rules/words/hedge-stacking.js +19 -23
- package/dist/rules/words/hedge-stacking.js.map +1 -1
- package/dist/rules/words/llm-vocabulary.js +14 -20
- package/dist/rules/words/llm-vocabulary.js.map +1 -1
- package/dist/rules/words/prohibited-words.js +12 -17
- package/dist/rules/words/prohibited-words.js.map +1 -1
- package/dist/rules/words/simplicity.js +20 -25
- package/dist/rules/words/simplicity.js.map +1 -1
- package/package.json +3 -1
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { allParagraphSentences } from "../../shared/text/sections.js";
|
|
2
1
|
import { wordTokens } from "../../shared/text/tokens.js";
|
|
3
|
-
import {
|
|
2
|
+
import { oneToOneRule } from "../private/textlint-rule-builders.js";
|
|
4
3
|
const HEDGE_THRESHOLD = 2;
|
|
5
4
|
const HEDGE_WORDS = new Set([
|
|
6
5
|
"might",
|
|
@@ -21,27 +20,24 @@ function hedgeCount(text) {
|
|
|
21
20
|
}
|
|
22
21
|
return count;
|
|
23
22
|
}
|
|
24
|
-
const rule = (
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
const count = hedgeCount(item.sentence.text);
|
|
30
|
-
if (count < HEDGE_THRESHOLD) {
|
|
31
|
-
continue;
|
|
32
|
-
}
|
|
33
|
-
emitTextlintFinding(context, {
|
|
34
|
-
node: item.paragraph,
|
|
35
|
-
ruleId: "words:hedge-stacking",
|
|
36
|
-
message: `Hedge stacking found: ${count} hedge words in one sentence. Keep fewer than ${HEDGE_THRESHOLD}.`,
|
|
37
|
-
range: {
|
|
38
|
-
start: item.source.originalStartFor(item.sentence.start),
|
|
39
|
-
end: item.source.originalEndFor(item.sentence.end)
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
}
|
|
23
|
+
const rule = oneToOneRule({
|
|
24
|
+
detect: (unit) => {
|
|
25
|
+
const count = hedgeCount(unit.text);
|
|
26
|
+
if (count < HEDGE_THRESHOLD) {
|
|
27
|
+
return [];
|
|
43
28
|
}
|
|
44
|
-
|
|
45
|
-
|
|
29
|
+
return [
|
|
30
|
+
{
|
|
31
|
+
evidence: String(count),
|
|
32
|
+
label: "hedge stacking",
|
|
33
|
+
range: { start: 0, end: unit.text.length }
|
|
34
|
+
}
|
|
35
|
+
];
|
|
36
|
+
},
|
|
37
|
+
family: "words",
|
|
38
|
+
formatMessage: (report) => `Hedge stacking found: ${report.evidence} hedge words in one sentence. Keep fewer than ${HEDGE_THRESHOLD}.`,
|
|
39
|
+
ruleId: "words:hedge-stacking",
|
|
40
|
+
unitKind: "sentence"
|
|
41
|
+
});
|
|
46
42
|
export default rule;
|
|
47
43
|
//# sourceMappingURL=hedge-stacking.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hedge-stacking.js","sourceRoot":"","sources":["../../../src/rules/words/hedge-stacking.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"hedge-stacking.js","sourceRoot":"","sources":["../../../src/rules/words/hedge-stacking.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAEpE,MAAM,eAAe,GAAG,CAAC,CAAC;AAE1B,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC;IAC1B,OAAO;IACP,OAAO;IACP,SAAS;IACT,UAAU;IACV,QAAQ;IACR,UAAU;IACV,OAAO;IACP,YAAY;CACb,CAAC,CAAC;AAEH,SAAS,UAAU,CAAC,IAAY;IAC9B,IAAI,KAAK,GAAG,CAAC,CAAC;IAEd,KAAK,MAAM,KAAK,IAAI,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QACrC,IAAI,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;YACtC,KAAK,IAAI,CAAC,CAAC;QACb,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,IAAI,GAAG,YAAY,CAAC;IACxB,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;QACf,MAAM,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,KAAK,GAAG,eAAe,EAAE,CAAC;YAC5B,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,OAAO;YACL;gBACE,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC;gBACvB,KAAK,EAAE,gBAAgB;gBACvB,KAAK,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;aAC3C;SACF,CAAC;IACJ,CAAC;IACD,MAAM,EAAE,OAAO;IACf,aAAa,EAAE,CAAC,MAAM,EAAE,EAAE,CACxB,yBAAyB,MAAM,CAAC,QAAQ,iDAAiD,eAAe,GAAG;IAC7G,MAAM,EAAE,sBAAsB;IAC9B,QAAQ,EAAE,UAAU;CACrB,CAAC,CAAC;AAEH,eAAe,IAAI,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { wordTokens } from "../../shared/text/tokens.js";
|
|
2
|
-
import {
|
|
2
|
+
import { oneToOneRule } from "../private/textlint-rule-builders.js";
|
|
3
3
|
const LLM_VOCABULARY = new Set([
|
|
4
4
|
"delve",
|
|
5
5
|
"vibrant",
|
|
@@ -14,24 +14,18 @@ const LLM_VOCABULARY = new Set([
|
|
|
14
14
|
"moreover",
|
|
15
15
|
"tapestry"
|
|
16
16
|
]);
|
|
17
|
-
const rule = (
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
range: { start: token.start, end: token.end }
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
};
|
|
35
|
-
};
|
|
17
|
+
const rule = oneToOneRule({
|
|
18
|
+
detect: (unit) => wordTokens(unit.text)
|
|
19
|
+
.filter((token) => LLM_VOCABULARY.has(token.normalized))
|
|
20
|
+
.map((token) => ({
|
|
21
|
+
evidence: token.text,
|
|
22
|
+
label: token.text,
|
|
23
|
+
range: { start: token.start, end: token.end }
|
|
24
|
+
})),
|
|
25
|
+
family: "words",
|
|
26
|
+
formatMessage: (report) => `LLM vocabulary found: "${report.evidence}". Replace the stock diction with a concrete word.`,
|
|
27
|
+
ruleId: "words:llm-vocabulary",
|
|
28
|
+
unitKind: "str"
|
|
29
|
+
});
|
|
36
30
|
export default rule;
|
|
37
31
|
//# sourceMappingURL=llm-vocabulary.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"llm-vocabulary.js","sourceRoot":"","sources":["../../../src/rules/words/llm-vocabulary.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"llm-vocabulary.js","sourceRoot":"","sources":["../../../src/rules/words/llm-vocabulary.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAEpE,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC;IAC7B,OAAO;IACP,SAAS;IACT,WAAW;IACX,OAAO;IACP,QAAQ;IACR,QAAQ;IACR,OAAO;IACP,eAAe;IACf,WAAW;IACX,SAAS;IACT,UAAU;IACV,UAAU;CACX,CAAC,CAAC;AAEH,MAAM,IAAI,GAAG,YAAY,CAAC;IACxB,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CACf,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC;SAClB,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;SACvD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACf,QAAQ,EAAE,KAAK,CAAC,IAAI;QACpB,KAAK,EAAE,KAAK,CAAC,IAAI;QACjB,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE;KAC9C,CAAC,CAAC;IACP,MAAM,EAAE,OAAO;IACf,aAAa,EAAE,CAAC,MAAM,EAAE,EAAE,CACxB,0BAA0B,MAAM,CAAC,QAAQ,oDAAoD;IAC/F,MAAM,EAAE,sBAAsB;IAC9B,QAAQ,EAAE,KAAK;CAChB,CAAC,CAAC;AAEH,eAAe,IAAI,CAAC"}
|
|
@@ -1,21 +1,16 @@
|
|
|
1
1
|
import prohibitedWords from "./data/prohibited-words.json" with { type: "json" };
|
|
2
2
|
import { findPhraseMatches } from "../../shared/matchers/phrases.js";
|
|
3
|
-
import {
|
|
4
|
-
const rule = (
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
};
|
|
3
|
+
import { oneToOneRule } from "../private/textlint-rule-builders.js";
|
|
4
|
+
const rule = oneToOneRule({
|
|
5
|
+
detect: (unit) => findPhraseMatches(unit.text, prohibitedWords).map((match) => ({
|
|
6
|
+
evidence: match.text,
|
|
7
|
+
label: match.text,
|
|
8
|
+
range: { start: match.start, end: match.end }
|
|
9
|
+
})),
|
|
10
|
+
family: "words",
|
|
11
|
+
formatMessage: (report) => `Prohibited word found: "${report.evidence}". Rewrite without this term.`,
|
|
12
|
+
ruleId: "words:prohibited-words",
|
|
13
|
+
unitKind: "str"
|
|
14
|
+
});
|
|
20
15
|
export default rule;
|
|
21
16
|
//# sourceMappingURL=prohibited-words.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prohibited-words.js","sourceRoot":"","sources":["../../../src/rules/words/prohibited-words.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prohibited-words.js","sourceRoot":"","sources":["../../../src/rules/words/prohibited-words.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,8BAA8B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACjF,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAEpE,MAAM,IAAI,GAAG,YAAY,CAAC;IACxB,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CACf,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAC5D,QAAQ,EAAE,KAAK,CAAC,IAAI;QACpB,KAAK,EAAE,KAAK,CAAC,IAAI;QACjB,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE;KAC9C,CAAC,CAAC;IACL,MAAM,EAAE,OAAO;IACf,aAAa,EAAE,CAAC,MAAM,EAAE,EAAE,CACxB,2BAA2B,MAAM,CAAC,QAAQ,+BAA+B;IAC3E,MAAM,EAAE,wBAAwB;IAChC,QAAQ,EAAE,KAAK;CAChB,CAAC,CAAC;AAEH,eAAe,IAAI,CAAC"}
|
|
@@ -1,31 +1,26 @@
|
|
|
1
1
|
import simplicityPairs from "./data/simplicity-pairs.json" with { type: "json" };
|
|
2
|
-
import { allParagraphSentences } from "../../shared/text/sections.js";
|
|
3
2
|
import { wordTokens } from "../../shared/text/tokens.js";
|
|
4
|
-
import {
|
|
3
|
+
import { oneToOneRule } from "../private/textlint-rule-builders.js";
|
|
5
4
|
const SIMPLE_BY_COMPLEX = new Map(simplicityPairs.map(([complex, simple]) => [complex, simple]));
|
|
6
|
-
const rule = (
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
for (const token of wordTokens(item.sentence.text)) {
|
|
12
|
-
const simple = SIMPLE_BY_COMPLEX.get(token.normalized);
|
|
13
|
-
if (simple === undefined) {
|
|
14
|
-
continue;
|
|
15
|
-
}
|
|
16
|
-
emitTextlintFinding(context, {
|
|
17
|
-
node: item.paragraph,
|
|
18
|
-
ruleId: "words:simplicity",
|
|
19
|
-
message: `Complex word found: "${token.text}". Use "${simple}" instead.`,
|
|
20
|
-
range: {
|
|
21
|
-
start: item.source.originalStartFor(item.sentence.start + token.start),
|
|
22
|
-
end: item.source.originalEndFor(item.sentence.start + token.end)
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
}
|
|
5
|
+
const rule = oneToOneRule({
|
|
6
|
+
detect: (unit) => wordTokens(unit.text).flatMap((token) => {
|
|
7
|
+
const simple = SIMPLE_BY_COMPLEX.get(token.normalized);
|
|
8
|
+
if (simple === undefined) {
|
|
9
|
+
return [];
|
|
27
10
|
}
|
|
28
|
-
|
|
29
|
-
|
|
11
|
+
return [
|
|
12
|
+
{
|
|
13
|
+
data: { simple },
|
|
14
|
+
evidence: token.text,
|
|
15
|
+
label: token.text,
|
|
16
|
+
range: { start: token.start, end: token.end }
|
|
17
|
+
}
|
|
18
|
+
];
|
|
19
|
+
}),
|
|
20
|
+
family: "words",
|
|
21
|
+
formatMessage: (report) => `Complex word found: "${report.evidence}". Use "${report.detections[0]?.data?.["simple"]}" instead.`,
|
|
22
|
+
ruleId: "words:simplicity",
|
|
23
|
+
unitKind: "sentence"
|
|
24
|
+
});
|
|
30
25
|
export default rule;
|
|
31
26
|
//# sourceMappingURL=simplicity.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simplicity.js","sourceRoot":"","sources":["../../../src/rules/words/simplicity.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"simplicity.js","sourceRoot":"","sources":["../../../src/rules/words/simplicity.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,8BAA8B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACjF,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAEpE,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAC/B,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAC9D,CAAC;AAEF,MAAM,IAAI,GAAG,YAAY,CAAC;IACxB,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CACf,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;QACtC,MAAM,MAAM,GAAG,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACvD,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;YACzB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,OAAO;YACL;gBACE,IAAI,EAAE,EAAE,MAAM,EAAE;gBAChB,QAAQ,EAAE,KAAK,CAAC,IAAI;gBACpB,KAAK,EAAE,KAAK,CAAC,IAAI;gBACjB,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE;aAC9C;SACF,CAAC;IACJ,CAAC,CAAC;IACJ,MAAM,EAAE,OAAO;IACf,aAAa,EAAE,CAAC,MAAM,EAAE,EAAE,CACxB,wBAAwB,MAAM,CAAC,QAAQ,WAAW,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,QAAQ,CAAC,YAAY;IACtG,MAAM,EAAE,kBAAkB;IAC1B,QAAQ,EAAE,UAAU;CACrB,CAAC,CAAC;AAEH,eAAe,IAAI,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "slopless",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.8",
|
|
4
4
|
"description": "Deterministic textlint rules for detecting slop in prose.",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -48,10 +48,12 @@
|
|
|
48
48
|
"./rules/narrative-slop/flat-action-cadence": "./dist/rules/narrative-slop/flat-action-cadence.js",
|
|
49
49
|
"./rules/narrative-slop/narrative-cliches": "./dist/rules/narrative-slop/narrative-cliches.js",
|
|
50
50
|
"./rules/narrative-slop/perception-verb-density": "./dist/rules/narrative-slop/perception-verb-density.js",
|
|
51
|
+
"./rules/orthography/artifact-placeholders": "./dist/rules/orthography/artifact-placeholders.js",
|
|
51
52
|
"./rules/orthography/colon-dramatic": "./dist/rules/orthography/colon-dramatic.js",
|
|
52
53
|
"./rules/orthography/em-dashes": "./dist/rules/orthography/em-dashes.js",
|
|
53
54
|
"./rules/orthography/exclamation-density": "./dist/rules/orthography/exclamation-density.js",
|
|
54
55
|
"./rules/orthography/fake-timestamps": "./dist/rules/orthography/fake-timestamps.js",
|
|
56
|
+
"./rules/orthography/hidden-unicode-controls": "./dist/rules/orthography/hidden-unicode-controls.js",
|
|
55
57
|
"./rules/orthography/sentence-case": "./dist/rules/orthography/sentence-case.js",
|
|
56
58
|
"./rules/orthography/smart-quotes": "./dist/rules/orthography/smart-quotes.js",
|
|
57
59
|
"./rules/phrases/cliches": "./dist/rules/phrases/cliches.js",
|