eslint-plugin-jsdoc 56.0.0 → 56.0.2
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/dist/cjs/getJsdocProcessorPlugin.d.cts +5 -1
- package/dist/cjs/iterateJsdoc.d.cts +6 -2
- package/dist/getJsdocProcessorPlugin.cts +3 -1
- package/dist/iterateJsdoc.cts +9 -4
- package/package.json +4 -4
- package/src/getJsdocProcessorPlugin.cts +3 -1
- package/src/iterateJsdoc.cts +9 -4
- package/dist/cjs/WarnSettings.js +0 -30
- package/dist/cjs/alignTransform.js +0 -285
- package/dist/cjs/defaultTagOrder.js +0 -152
- package/dist/cjs/exportParser.js +0 -754
- package/dist/cjs/getDefaultTagStructureForMode.js +0 -840
- package/dist/cjs/getJsdocProcessorPlugin.cjs +0 -4
- package/dist/cjs/getJsdocProcessorPlugin.js +0 -553
- package/dist/cjs/index-cjs.js +0 -492
- package/dist/cjs/index.cjs.cjs +0 -6
- package/dist/cjs/iterateJsdoc.cjs +0 -38
- package/dist/cjs/iterateJsdoc.js +0 -1981
- package/dist/cjs/jsdocUtils.js +0 -1470
- package/dist/cjs/rules/checkAccess.js +0 -35
- package/dist/cjs/rules/checkAlignment.js +0 -63
- package/dist/cjs/rules/checkExamples.js +0 -486
- package/dist/cjs/rules/checkIndentation.js +0 -66
- package/dist/cjs/rules/checkLineAlignment.js +0 -297
- package/dist/cjs/rules/checkParamNames.js +0 -320
- package/dist/cjs/rules/checkPropertyNames.js +0 -105
- package/dist/cjs/rules/checkSyntax.js +0 -27
- package/dist/cjs/rules/checkTagNames.js +0 -252
- package/dist/cjs/rules/checkTemplateNames.js +0 -189
- package/dist/cjs/rules/checkTypes.js +0 -421
- package/dist/cjs/rules/checkValues.js +0 -163
- package/dist/cjs/rules/convertToJsdocComments.js +0 -313
- package/dist/cjs/rules/emptyTags.js +0 -79
- package/dist/cjs/rules/implementsOnClasses.js +0 -63
- package/dist/cjs/rules/importsAsDependencies.js +0 -105
- package/dist/cjs/rules/informativeDocs.js +0 -153
- package/dist/cjs/rules/linesBeforeBlock.js +0 -106
- package/dist/cjs/rules/matchDescription.js +0 -240
- package/dist/cjs/rules/matchName.js +0 -122
- package/dist/cjs/rules/multilineBlocks.js +0 -339
- package/dist/cjs/rules/noBadBlocks.js +0 -88
- package/dist/cjs/rules/noBlankBlockDescriptions.js +0 -56
- package/dist/cjs/rules/noBlankBlocks.js +0 -41
- package/dist/cjs/rules/noDefaults.js +0 -84
- package/dist/cjs/rules/noMissingSyntax.js +0 -164
- package/dist/cjs/rules/noMultiAsterisks.js +0 -83
- package/dist/cjs/rules/noRestrictedSyntax.js +0 -75
- package/dist/cjs/rules/noTypes.js +0 -88
- package/dist/cjs/rules/noUndefinedTypes.js +0 -451
- package/dist/cjs/rules/requireAsteriskPrefix.js +0 -144
- package/dist/cjs/rules/requireDescription.js +0 -136
- package/dist/cjs/rules/requireDescriptionCompleteSentence.js +0 -258
- package/dist/cjs/rules/requireExample.js +0 -103
- package/dist/cjs/rules/requireFileOverview.js +0 -117
- package/dist/cjs/rules/requireHyphenBeforeParamDescription.js +0 -144
- package/dist/cjs/rules/requireJsdoc.js +0 -629
- package/dist/cjs/rules/requireParam.js +0 -480
- package/dist/cjs/rules/requireParamDescription.js +0 -77
- package/dist/cjs/rules/requireParamName.js +0 -52
- package/dist/cjs/rules/requireParamType.js +0 -77
- package/dist/cjs/rules/requireProperty.js +0 -44
- package/dist/cjs/rules/requirePropertyDescription.js +0 -22
- package/dist/cjs/rules/requirePropertyName.js +0 -22
- package/dist/cjs/rules/requirePropertyType.js +0 -22
- package/dist/cjs/rules/requireReturns.js +0 -197
- package/dist/cjs/rules/requireReturnsCheck.js +0 -108
- package/dist/cjs/rules/requireReturnsDescription.js +0 -58
- package/dist/cjs/rules/requireReturnsType.js +0 -52
- package/dist/cjs/rules/requireTemplate.js +0 -173
- package/dist/cjs/rules/requireThrows.js +0 -101
- package/dist/cjs/rules/requireYields.js +0 -172
- package/dist/cjs/rules/requireYieldsCheck.js +0 -164
- package/dist/cjs/rules/sortTags.js +0 -392
- package/dist/cjs/rules/tagLines.js +0 -259
- package/dist/cjs/rules/textEscaping.js +0 -125
- package/dist/cjs/rules/typeFormatting.js +0 -328
- package/dist/cjs/rules/validTypes.js +0 -333
- package/dist/cjs/tagNames.js +0 -209
- package/dist/cjs/utils/hasReturnValue.js +0 -469
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const iterateJsdoc_js_1 = __importDefault(require("../iterateJsdoc.js"));
|
|
7
|
-
/**
|
|
8
|
-
* @param {string} targetTagName
|
|
9
|
-
* @param {boolean} enableFixer
|
|
10
|
-
* @param {import('comment-parser').Block} jsdoc
|
|
11
|
-
* @param {import('../iterateJsdoc.js').Utils} utils
|
|
12
|
-
* @returns {boolean}
|
|
13
|
-
*/
|
|
14
|
-
const validatePropertyNames = (targetTagName, enableFixer, jsdoc, utils) => {
|
|
15
|
-
const propertyTags = Object.entries(jsdoc.tags).filter(([, tag,]) => {
|
|
16
|
-
return tag.tag === targetTagName;
|
|
17
|
-
});
|
|
18
|
-
return propertyTags.some(([, tag,], index) => {
|
|
19
|
-
/** @type {import('../iterateJsdoc.js').Integer} */
|
|
20
|
-
let tagsIndex;
|
|
21
|
-
const dupeTagInfo = propertyTags.find(([tgsIndex, tg,], idx) => {
|
|
22
|
-
tagsIndex = Number(tgsIndex);
|
|
23
|
-
return tg.name === tag.name && idx !== index;
|
|
24
|
-
});
|
|
25
|
-
if (dupeTagInfo) {
|
|
26
|
-
utils.reportJSDoc(`Duplicate @${targetTagName} "${tag.name}"`, dupeTagInfo[1], enableFixer ? () => {
|
|
27
|
-
utils.removeTag(tagsIndex);
|
|
28
|
-
} : null);
|
|
29
|
-
return true;
|
|
30
|
-
}
|
|
31
|
-
return false;
|
|
32
|
-
});
|
|
33
|
-
};
|
|
34
|
-
/**
|
|
35
|
-
* @param {string} targetTagName
|
|
36
|
-
* @param {{
|
|
37
|
-
* idx: number;
|
|
38
|
-
* name: string;
|
|
39
|
-
* type: string;
|
|
40
|
-
* }[]} jsdocPropertyNames
|
|
41
|
-
* @param {import('comment-parser').Block} jsdoc
|
|
42
|
-
* @param {Function} report
|
|
43
|
-
*/
|
|
44
|
-
const validatePropertyNamesDeep = (targetTagName, jsdocPropertyNames, jsdoc, report) => {
|
|
45
|
-
/** @type {string} */
|
|
46
|
-
let lastRealProperty;
|
|
47
|
-
return jsdocPropertyNames.some(({ idx, name: jsdocPropertyName, }) => {
|
|
48
|
-
const isPropertyPath = jsdocPropertyName.includes('.');
|
|
49
|
-
if (isPropertyPath) {
|
|
50
|
-
if (!lastRealProperty) {
|
|
51
|
-
report(`@${targetTagName} path declaration ("${jsdocPropertyName}") appears before any real property.`, null, jsdoc.tags[idx]);
|
|
52
|
-
return true;
|
|
53
|
-
}
|
|
54
|
-
let pathRootNodeName = jsdocPropertyName.slice(0, jsdocPropertyName.indexOf('.'));
|
|
55
|
-
if (pathRootNodeName.endsWith('[]')) {
|
|
56
|
-
pathRootNodeName = pathRootNodeName.slice(0, -2);
|
|
57
|
-
}
|
|
58
|
-
if (pathRootNodeName !== lastRealProperty) {
|
|
59
|
-
report(`@${targetTagName} path declaration ("${jsdocPropertyName}") root node name ("${pathRootNodeName}") ` +
|
|
60
|
-
`does not match previous real property name ("${lastRealProperty}").`, null, jsdoc.tags[idx]);
|
|
61
|
-
return true;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
else {
|
|
65
|
-
lastRealProperty = jsdocPropertyName;
|
|
66
|
-
}
|
|
67
|
-
return false;
|
|
68
|
-
});
|
|
69
|
-
};
|
|
70
|
-
exports.default = (0, iterateJsdoc_js_1.default)(({ context, jsdoc, report, utils, }) => {
|
|
71
|
-
const { enableFixer = false, } = context.options[0] || {};
|
|
72
|
-
const jsdocPropertyNamesDeep = utils.getJsdocTagsDeep('property');
|
|
73
|
-
if (!jsdocPropertyNamesDeep || !jsdocPropertyNamesDeep.length) {
|
|
74
|
-
return;
|
|
75
|
-
}
|
|
76
|
-
const targetTagName = /** @type {string} */ (utils.getPreferredTagName({
|
|
77
|
-
tagName: 'property',
|
|
78
|
-
}));
|
|
79
|
-
const isError = validatePropertyNames(targetTagName, enableFixer, jsdoc, utils);
|
|
80
|
-
if (isError) {
|
|
81
|
-
return;
|
|
82
|
-
}
|
|
83
|
-
validatePropertyNamesDeep(targetTagName, jsdocPropertyNamesDeep, jsdoc, report);
|
|
84
|
-
}, {
|
|
85
|
-
iterateAllJsdocs: true,
|
|
86
|
-
meta: {
|
|
87
|
-
docs: {
|
|
88
|
-
description: 'Ensures that property names in JSDoc are not duplicated on the same block and that nested properties have defined roots.',
|
|
89
|
-
url: 'https://github.com/gajus/eslint-plugin-jsdoc/blob/main/docs/rules/check-property-names.md#repos-sticky-header',
|
|
90
|
-
},
|
|
91
|
-
fixable: 'code',
|
|
92
|
-
schema: [
|
|
93
|
-
{
|
|
94
|
-
additionalProperties: false,
|
|
95
|
-
properties: {
|
|
96
|
-
enableFixer: {
|
|
97
|
-
type: 'boolean',
|
|
98
|
-
},
|
|
99
|
-
},
|
|
100
|
-
type: 'object',
|
|
101
|
-
},
|
|
102
|
-
],
|
|
103
|
-
type: 'suggestion',
|
|
104
|
-
},
|
|
105
|
-
});
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const iterateJsdoc_js_1 = __importDefault(require("../iterateJsdoc.js"));
|
|
7
|
-
exports.default = (0, iterateJsdoc_js_1.default)(({ jsdoc, report, settings, }) => {
|
|
8
|
-
const { mode, } = settings;
|
|
9
|
-
// Don't check for "permissive" and "closure"
|
|
10
|
-
if (mode === 'jsdoc' || mode === 'typescript') {
|
|
11
|
-
for (const tag of jsdoc.tags) {
|
|
12
|
-
if (tag.type.slice(-1) === '=') {
|
|
13
|
-
report('Syntax should not be Google Closure Compiler style.', null, tag);
|
|
14
|
-
break;
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
}, {
|
|
19
|
-
iterateAllJsdocs: true,
|
|
20
|
-
meta: {
|
|
21
|
-
docs: {
|
|
22
|
-
description: 'Reports against syntax not valid for the mode (e.g., Google Closure Compiler in non-Closure mode).',
|
|
23
|
-
url: 'https://github.com/gajus/eslint-plugin-jsdoc/blob/main/docs/rules/check-syntax.md#repos-sticky-header',
|
|
24
|
-
},
|
|
25
|
-
type: 'suggestion',
|
|
26
|
-
},
|
|
27
|
-
});
|
|
@@ -1,252 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const iterateJsdoc_js_1 = __importDefault(require("../iterateJsdoc.js"));
|
|
7
|
-
const escape_string_regexp_1 = __importDefault(require("escape-string-regexp"));
|
|
8
|
-
// https://babeljs.io/docs/en/babel-plugin-transform-react-jsx/
|
|
9
|
-
const jsxTagNames = new Set([
|
|
10
|
-
'jsx',
|
|
11
|
-
'jsxFrag',
|
|
12
|
-
'jsxImportSource',
|
|
13
|
-
'jsxRuntime',
|
|
14
|
-
]);
|
|
15
|
-
const typedTagsAlwaysUnnecessary = new Set([
|
|
16
|
-
'augments',
|
|
17
|
-
'callback',
|
|
18
|
-
'class',
|
|
19
|
-
'enum',
|
|
20
|
-
'implements',
|
|
21
|
-
'private',
|
|
22
|
-
'property',
|
|
23
|
-
'protected',
|
|
24
|
-
'public',
|
|
25
|
-
'readonly',
|
|
26
|
-
'this',
|
|
27
|
-
'type',
|
|
28
|
-
'typedef',
|
|
29
|
-
]);
|
|
30
|
-
const typedTagsNeedingName = new Set([
|
|
31
|
-
'template',
|
|
32
|
-
]);
|
|
33
|
-
const typedTagsUnnecessaryOutsideDeclare = new Set([
|
|
34
|
-
'abstract',
|
|
35
|
-
'access',
|
|
36
|
-
'class',
|
|
37
|
-
'constant',
|
|
38
|
-
'constructs',
|
|
39
|
-
'default',
|
|
40
|
-
'enum',
|
|
41
|
-
'export',
|
|
42
|
-
'exports',
|
|
43
|
-
'function',
|
|
44
|
-
'global',
|
|
45
|
-
'inherits',
|
|
46
|
-
'instance',
|
|
47
|
-
'interface',
|
|
48
|
-
'member',
|
|
49
|
-
'memberof',
|
|
50
|
-
'memberOf',
|
|
51
|
-
'method',
|
|
52
|
-
'mixes',
|
|
53
|
-
'mixin',
|
|
54
|
-
'module',
|
|
55
|
-
'name',
|
|
56
|
-
'namespace',
|
|
57
|
-
'override',
|
|
58
|
-
'property',
|
|
59
|
-
'requires',
|
|
60
|
-
'static',
|
|
61
|
-
'this',
|
|
62
|
-
]);
|
|
63
|
-
exports.default = (0, iterateJsdoc_js_1.default)(({ context, jsdoc, jsdocNode, node, report, settings, sourceCode, utils, }) => {
|
|
64
|
-
const
|
|
65
|
-
/**
|
|
66
|
-
* @type {{
|
|
67
|
-
* definedTags: string[],
|
|
68
|
-
* enableFixer: boolean,
|
|
69
|
-
* jsxTags: boolean,
|
|
70
|
-
* typed: boolean
|
|
71
|
-
}} */ { definedTags = [], enableFixer = true, jsxTags, typed, } = context.options[0] || {};
|
|
72
|
-
/** @type {(string|undefined)[]} */
|
|
73
|
-
let definedPreferredTags = [];
|
|
74
|
-
const { structuredTags, tagNamePreference, } = settings;
|
|
75
|
-
const definedStructuredTags = Object.keys(structuredTags);
|
|
76
|
-
const definedNonPreferredTags = Object.keys(tagNamePreference);
|
|
77
|
-
if (definedNonPreferredTags.length) {
|
|
78
|
-
definedPreferredTags = Object.values(tagNamePreference).map((preferredTag) => {
|
|
79
|
-
if (typeof preferredTag === 'string') {
|
|
80
|
-
// May become an empty string but will be filtered out below
|
|
81
|
-
return preferredTag;
|
|
82
|
-
}
|
|
83
|
-
if (!preferredTag) {
|
|
84
|
-
return undefined;
|
|
85
|
-
}
|
|
86
|
-
if (typeof preferredTag !== 'object') {
|
|
87
|
-
utils.reportSettings('Invalid `settings.jsdoc.tagNamePreference`. Values must be falsy, a string, or an object.');
|
|
88
|
-
}
|
|
89
|
-
return preferredTag.replacement;
|
|
90
|
-
})
|
|
91
|
-
.filter(Boolean);
|
|
92
|
-
}
|
|
93
|
-
/**
|
|
94
|
-
* @param {import('eslint').Rule.Node} subNode
|
|
95
|
-
* @returns {boolean}
|
|
96
|
-
*/
|
|
97
|
-
const isInAmbientContext = (subNode) => {
|
|
98
|
-
return subNode.type === 'Program' ?
|
|
99
|
-
context.getFilename().endsWith('.d.ts') :
|
|
100
|
-
Boolean(
|
|
101
|
-
/** @type {import('@typescript-eslint/types').TSESTree.VariableDeclaration} */ (subNode).declare) || isInAmbientContext(subNode.parent);
|
|
102
|
-
};
|
|
103
|
-
/**
|
|
104
|
-
* @param {import('comment-parser').Spec} jsdocTag
|
|
105
|
-
* @returns {boolean}
|
|
106
|
-
*/
|
|
107
|
-
const tagIsRedundantWhenTyped = (jsdocTag) => {
|
|
108
|
-
if (!typedTagsUnnecessaryOutsideDeclare.has(jsdocTag.tag)) {
|
|
109
|
-
return false;
|
|
110
|
-
}
|
|
111
|
-
if (jsdocTag.tag === 'default') {
|
|
112
|
-
return false;
|
|
113
|
-
}
|
|
114
|
-
if (node === null) {
|
|
115
|
-
return false;
|
|
116
|
-
}
|
|
117
|
-
if (context.getFilename().endsWith('.d.ts') && [
|
|
118
|
-
null, 'Program', undefined,
|
|
119
|
-
].includes(node?.parent?.type)) {
|
|
120
|
-
return false;
|
|
121
|
-
}
|
|
122
|
-
if (isInAmbientContext(/** @type {import('eslint').Rule.Node} */ (node))) {
|
|
123
|
-
return false;
|
|
124
|
-
}
|
|
125
|
-
return true;
|
|
126
|
-
};
|
|
127
|
-
/**
|
|
128
|
-
* @param {string} message
|
|
129
|
-
* @param {import('comment-parser').Spec} jsdocTag
|
|
130
|
-
* @param {import('../iterateJsdoc.js').Integer} tagIndex
|
|
131
|
-
* @param {Partial<import('comment-parser').Tokens>} [additionalTagChanges]
|
|
132
|
-
* @returns {void}
|
|
133
|
-
*/
|
|
134
|
-
const reportWithTagRemovalFixer = (message, jsdocTag, tagIndex, additionalTagChanges) => {
|
|
135
|
-
utils.reportJSDoc(message, jsdocTag, enableFixer ? () => {
|
|
136
|
-
if (jsdocTag.description.trim()) {
|
|
137
|
-
utils.changeTag(jsdocTag, {
|
|
138
|
-
postType: '',
|
|
139
|
-
type: '',
|
|
140
|
-
...additionalTagChanges,
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
utils.removeTag(tagIndex, {
|
|
145
|
-
removeEmptyBlock: true,
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
} : null, true);
|
|
149
|
-
};
|
|
150
|
-
/**
|
|
151
|
-
* @param {import('comment-parser').Spec} jsdocTag
|
|
152
|
-
* @param {import('../iterateJsdoc.js').Integer} tagIndex
|
|
153
|
-
* @returns {boolean}
|
|
154
|
-
*/
|
|
155
|
-
const checkTagForTypedValidity = (jsdocTag, tagIndex) => {
|
|
156
|
-
if (typedTagsAlwaysUnnecessary.has(jsdocTag.tag)) {
|
|
157
|
-
reportWithTagRemovalFixer(`'@${jsdocTag.tag}' is redundant when using a type system.`, jsdocTag, tagIndex, {
|
|
158
|
-
postTag: '',
|
|
159
|
-
tag: '',
|
|
160
|
-
});
|
|
161
|
-
return true;
|
|
162
|
-
}
|
|
163
|
-
if (tagIsRedundantWhenTyped(jsdocTag)) {
|
|
164
|
-
reportWithTagRemovalFixer(`'@${jsdocTag.tag}' is redundant outside of ambient (\`declare\`/\`.d.ts\`) contexts when using a type system.`, jsdocTag, tagIndex);
|
|
165
|
-
return true;
|
|
166
|
-
}
|
|
167
|
-
if (typedTagsNeedingName.has(jsdocTag.tag) && !jsdocTag.name) {
|
|
168
|
-
reportWithTagRemovalFixer(`'@${jsdocTag.tag}' without a name is redundant when using a type system.`, jsdocTag, tagIndex);
|
|
169
|
-
return true;
|
|
170
|
-
}
|
|
171
|
-
return false;
|
|
172
|
-
};
|
|
173
|
-
for (let tagIndex = 0; tagIndex < jsdoc.tags.length; tagIndex += 1) {
|
|
174
|
-
const jsdocTag = jsdoc.tags[tagIndex];
|
|
175
|
-
const tagName = jsdocTag.tag;
|
|
176
|
-
if (jsxTags && jsxTagNames.has(tagName)) {
|
|
177
|
-
continue;
|
|
178
|
-
}
|
|
179
|
-
if (typed && checkTagForTypedValidity(jsdocTag, tagIndex)) {
|
|
180
|
-
continue;
|
|
181
|
-
}
|
|
182
|
-
const validTags = [
|
|
183
|
-
...definedTags,
|
|
184
|
-
...( /** @type {string[]} */(definedPreferredTags)),
|
|
185
|
-
...definedNonPreferredTags,
|
|
186
|
-
...definedStructuredTags,
|
|
187
|
-
...typed ? typedTagsNeedingName : [],
|
|
188
|
-
];
|
|
189
|
-
if (utils.isValidTag(tagName, validTags)) {
|
|
190
|
-
let preferredTagName = utils.getPreferredTagName({
|
|
191
|
-
allowObjectReturn: true,
|
|
192
|
-
defaultMessage: `Blacklisted tag found (\`@${tagName}\`)`,
|
|
193
|
-
tagName,
|
|
194
|
-
});
|
|
195
|
-
if (!preferredTagName) {
|
|
196
|
-
continue;
|
|
197
|
-
}
|
|
198
|
-
let message;
|
|
199
|
-
if (typeof preferredTagName === 'object') {
|
|
200
|
-
({
|
|
201
|
-
message,
|
|
202
|
-
replacement: preferredTagName,
|
|
203
|
-
} = /** @type {{message: string; replacement?: string | undefined;}} */ (preferredTagName));
|
|
204
|
-
}
|
|
205
|
-
if (!message) {
|
|
206
|
-
message = `Invalid JSDoc tag (preference). Replace "${tagName}" JSDoc tag with "${preferredTagName}".`;
|
|
207
|
-
}
|
|
208
|
-
if (preferredTagName !== tagName) {
|
|
209
|
-
report(message, (fixer) => {
|
|
210
|
-
const replacement = sourceCode.getText(jsdocNode).replace(new RegExp(`@${(0, escape_string_regexp_1.default)(tagName)}\\b`, 'v'), `@${preferredTagName}`);
|
|
211
|
-
return fixer.replaceText(jsdocNode, replacement);
|
|
212
|
-
}, jsdocTag);
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
else {
|
|
216
|
-
report(`Invalid JSDoc tag name "${tagName}".`, null, jsdocTag);
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
}, {
|
|
220
|
-
iterateAllJsdocs: true,
|
|
221
|
-
meta: {
|
|
222
|
-
docs: {
|
|
223
|
-
description: 'Reports invalid block tag names.',
|
|
224
|
-
url: 'https://github.com/gajus/eslint-plugin-jsdoc/blob/main/docs/rules/check-tag-names.md#repos-sticky-header',
|
|
225
|
-
},
|
|
226
|
-
fixable: 'code',
|
|
227
|
-
schema: [
|
|
228
|
-
{
|
|
229
|
-
additionalProperties: false,
|
|
230
|
-
properties: {
|
|
231
|
-
definedTags: {
|
|
232
|
-
items: {
|
|
233
|
-
type: 'string',
|
|
234
|
-
},
|
|
235
|
-
type: 'array',
|
|
236
|
-
},
|
|
237
|
-
enableFixer: {
|
|
238
|
-
type: 'boolean',
|
|
239
|
-
},
|
|
240
|
-
jsxTags: {
|
|
241
|
-
type: 'boolean',
|
|
242
|
-
},
|
|
243
|
-
typed: {
|
|
244
|
-
type: 'boolean',
|
|
245
|
-
},
|
|
246
|
-
},
|
|
247
|
-
type: 'object',
|
|
248
|
-
},
|
|
249
|
-
],
|
|
250
|
-
type: 'suggestion',
|
|
251
|
-
},
|
|
252
|
-
});
|
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
const iterateJsdoc_js_1 = __importStar(require("../iterateJsdoc.js"));
|
|
37
|
-
const jsdocUtils_js_1 = require("../jsdocUtils.js");
|
|
38
|
-
const jsdoccomment_1 = require("@es-joy/jsdoccomment");
|
|
39
|
-
exports.default = (0, iterateJsdoc_js_1.default)(({ jsdoc, node, report, settings, sourceCode, utils, }) => {
|
|
40
|
-
const { mode, } = settings;
|
|
41
|
-
const templateTags = utils.getTags('template');
|
|
42
|
-
const usedNames = new Set();
|
|
43
|
-
/**
|
|
44
|
-
* @param {string} potentialType
|
|
45
|
-
*/
|
|
46
|
-
const checkForUsedTypes = (potentialType) => {
|
|
47
|
-
let parsedType;
|
|
48
|
-
try {
|
|
49
|
-
parsedType = mode === 'permissive' ?
|
|
50
|
-
(0, jsdoccomment_1.tryParse)(/** @type {string} */ (potentialType)) :
|
|
51
|
-
(0, jsdoccomment_1.parse)(/** @type {string} */ (potentialType), mode);
|
|
52
|
-
}
|
|
53
|
-
catch {
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
(0, jsdoccomment_1.traverse)(parsedType, (nde) => {
|
|
57
|
-
const { type, value, } = /** @type {import('jsdoc-type-pratt-parser').NameResult} */ (nde);
|
|
58
|
-
if (type === 'JsdocTypeName') {
|
|
59
|
-
usedNames.add(value);
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
};
|
|
63
|
-
const checkParamsAndReturnsTags = (jsdc = jsdoc) => {
|
|
64
|
-
const paramName = /** @type {string} */ (utils.getPreferredTagName({
|
|
65
|
-
tagName: 'param',
|
|
66
|
-
}));
|
|
67
|
-
const paramTags = (0, jsdocUtils_js_1.getTags)(jsdc, paramName);
|
|
68
|
-
for (const paramTag of paramTags) {
|
|
69
|
-
checkForUsedTypes(paramTag.type);
|
|
70
|
-
}
|
|
71
|
-
const returnsName = /** @type {string} */ (utils.getPreferredTagName({
|
|
72
|
-
tagName: 'returns',
|
|
73
|
-
}));
|
|
74
|
-
const returnsTags = (0, jsdocUtils_js_1.getTags)(jsdc, returnsName);
|
|
75
|
-
for (const returnsTag of returnsTags) {
|
|
76
|
-
checkForUsedTypes(returnsTag.type);
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
const checkTemplateTags = () => {
|
|
80
|
-
for (const tag of templateTags) {
|
|
81
|
-
const names = utils.parseClosureTemplateTag(tag);
|
|
82
|
-
for (const nme of names) {
|
|
83
|
-
if (!usedNames.has(nme)) {
|
|
84
|
-
report(`@template ${nme} not in use`, null, tag);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
};
|
|
89
|
-
/**
|
|
90
|
-
* @param {import('@typescript-eslint/types').TSESTree.FunctionDeclaration|
|
|
91
|
-
* import('@typescript-eslint/types').TSESTree.ClassDeclaration|
|
|
92
|
-
* import('@typescript-eslint/types').TSESTree.TSInterfaceDeclaration|
|
|
93
|
-
* import('@typescript-eslint/types').TSESTree.TSTypeAliasDeclaration} aliasDeclaration
|
|
94
|
-
* @param {boolean} [checkParamsAndReturns]
|
|
95
|
-
*/
|
|
96
|
-
const checkParameters = (aliasDeclaration, checkParamsAndReturns) => {
|
|
97
|
-
/* c8 ignore next -- Guard */
|
|
98
|
-
const { params, } = aliasDeclaration.typeParameters ?? {
|
|
99
|
-
params: [],
|
|
100
|
-
};
|
|
101
|
-
for (const { name: { name, }, } of params) {
|
|
102
|
-
usedNames.add(name);
|
|
103
|
-
}
|
|
104
|
-
if (checkParamsAndReturns) {
|
|
105
|
-
checkParamsAndReturnsTags();
|
|
106
|
-
}
|
|
107
|
-
else if (aliasDeclaration.type === 'ClassDeclaration') {
|
|
108
|
-
/* c8 ignore next -- TS */
|
|
109
|
-
for (const nde of aliasDeclaration?.body?.body ?? []) {
|
|
110
|
-
// @ts-expect-error Should be ok
|
|
111
|
-
const commentNode = (0, jsdoccomment_1.getJSDocComment)(sourceCode, nde, settings);
|
|
112
|
-
if (!commentNode) {
|
|
113
|
-
continue;
|
|
114
|
-
}
|
|
115
|
-
const innerJsdoc = (0, iterateJsdoc_js_1.parseComment)(commentNode, '');
|
|
116
|
-
checkParamsAndReturnsTags(innerJsdoc);
|
|
117
|
-
const typeName = /** @type {string} */ (utils.getPreferredTagName({
|
|
118
|
-
tagName: 'type',
|
|
119
|
-
}));
|
|
120
|
-
const typeTags = (0, jsdocUtils_js_1.getTags)(innerJsdoc, typeName);
|
|
121
|
-
for (const typeTag of typeTags) {
|
|
122
|
-
checkForUsedTypes(typeTag.type);
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
checkTemplateTags();
|
|
127
|
-
};
|
|
128
|
-
const handleTypeAliases = () => {
|
|
129
|
-
const nde = /** @type {import('@typescript-eslint/types').TSESTree.Node} */ (node);
|
|
130
|
-
if (!nde) {
|
|
131
|
-
return;
|
|
132
|
-
}
|
|
133
|
-
switch (nde.type) {
|
|
134
|
-
case 'ClassDeclaration':
|
|
135
|
-
case 'TSInterfaceDeclaration':
|
|
136
|
-
case 'TSTypeAliasDeclaration':
|
|
137
|
-
checkParameters(nde);
|
|
138
|
-
break;
|
|
139
|
-
case 'ExportDefaultDeclaration':
|
|
140
|
-
case 'ExportNamedDeclaration':
|
|
141
|
-
switch (nde.declaration?.type) {
|
|
142
|
-
case 'ClassDeclaration':
|
|
143
|
-
case 'TSInterfaceDeclaration':
|
|
144
|
-
case 'TSTypeAliasDeclaration':
|
|
145
|
-
checkParameters(nde.declaration);
|
|
146
|
-
break;
|
|
147
|
-
case 'FunctionDeclaration':
|
|
148
|
-
checkParameters(nde.declaration, true);
|
|
149
|
-
break;
|
|
150
|
-
}
|
|
151
|
-
break;
|
|
152
|
-
case 'FunctionDeclaration':
|
|
153
|
-
checkParameters(nde, true);
|
|
154
|
-
break;
|
|
155
|
-
}
|
|
156
|
-
};
|
|
157
|
-
const callbackTags = utils.getTags('callback');
|
|
158
|
-
const functionTags = utils.getTags('function');
|
|
159
|
-
if (callbackTags.length || functionTags.length) {
|
|
160
|
-
checkParamsAndReturnsTags();
|
|
161
|
-
checkTemplateTags();
|
|
162
|
-
return;
|
|
163
|
-
}
|
|
164
|
-
const typedefTags = utils.getTags('typedef');
|
|
165
|
-
if (!typedefTags.length || typedefTags.length >= 2) {
|
|
166
|
-
handleTypeAliases();
|
|
167
|
-
return;
|
|
168
|
-
}
|
|
169
|
-
const potentialTypedefType = typedefTags[0].type;
|
|
170
|
-
checkForUsedTypes(potentialTypedefType);
|
|
171
|
-
const propertyName = /** @type {string} */ (utils.getPreferredTagName({
|
|
172
|
-
tagName: 'property',
|
|
173
|
-
}));
|
|
174
|
-
const propertyTags = utils.getTags(propertyName);
|
|
175
|
-
for (const propertyTag of propertyTags) {
|
|
176
|
-
checkForUsedTypes(propertyTag.type);
|
|
177
|
-
}
|
|
178
|
-
checkTemplateTags();
|
|
179
|
-
}, {
|
|
180
|
-
iterateAllJsdocs: true,
|
|
181
|
-
meta: {
|
|
182
|
-
docs: {
|
|
183
|
-
description: 'Checks that any `@template` names are actually used in the connected `@typedef` or type alias.',
|
|
184
|
-
url: 'https://github.com/gajus/eslint-plugin-jsdoc/blob/main/docs/rules/check-template-names.md#repos-sticky-header',
|
|
185
|
-
},
|
|
186
|
-
schema: [],
|
|
187
|
-
type: 'suggestion',
|
|
188
|
-
},
|
|
189
|
-
});
|