UNPKG

eslint-plugin-jsdoc

Version:
122 lines (119 loc) 4.08 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _iterateJsdoc = _interopRequireDefault(require("../iterateJsdoc.cjs")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } /** * @param {string} targetTagName * @param {boolean} enableFixer * @param {import('comment-parser').Block} jsdoc * @param {import('../iterateJsdoc.js').Utils} utils * @returns {boolean} */ const validatePropertyNames = (targetTagName, enableFixer, jsdoc, utils) => { const propertyTags = Object.entries(jsdoc.tags).filter(([, tag]) => { return tag.tag === targetTagName; }); return propertyTags.some(([, tag], index) => { /** @type {import('../iterateJsdoc.js').Integer} */ let tagsIndex; const dupeTagInfo = propertyTags.find(([tgsIndex, tg], idx) => { tagsIndex = Number(tgsIndex); return tg.name === tag.name && idx !== index; }); if (dupeTagInfo) { utils.reportJSDoc(`Duplicate @${targetTagName} "${tag.name}"`, dupeTagInfo[1], enableFixer ? () => { utils.removeTag(tagsIndex); } : null); return true; } return false; }); }; /** * @param {string} targetTagName * @param {{ * idx: number; * name: string; * type: string; * }[]} jsdocPropertyNames * @param {import('comment-parser').Block} jsdoc * @param {import('../iterateJsdoc.js').Report} report */ const validatePropertyNamesDeep = (targetTagName, jsdocPropertyNames, jsdoc, report) => { /** @type {string} */ let lastRealProperty; return jsdocPropertyNames.some(({ idx, name: jsdocPropertyName }) => { const isPropertyPath = jsdocPropertyName.includes('.'); if (isPropertyPath) { if (!lastRealProperty) { report(`@${targetTagName} path declaration ("${jsdocPropertyName}") appears before any real property.`, null, jsdoc.tags[idx]); return true; } let pathRootNodeName = jsdocPropertyName.slice(0, jsdocPropertyName.indexOf('.')); if (pathRootNodeName.endsWith('[]')) { pathRootNodeName = pathRootNodeName.slice(0, -2); } if (pathRootNodeName !== lastRealProperty) { report(`@${targetTagName} path declaration ("${jsdocPropertyName}") root node name ("${pathRootNodeName}") ` + `does not match previous real property name ("${lastRealProperty}").`, null, jsdoc.tags[idx]); return true; } } else { lastRealProperty = jsdocPropertyName; } return false; }); }; var _default = exports.default = (0, _iterateJsdoc.default)(({ context, jsdoc, report, utils }) => { const { enableFixer = false } = context.options[0] || {}; const jsdocPropertyNamesDeep = utils.getJsdocTagsDeep('property'); if (!jsdocPropertyNamesDeep || !jsdocPropertyNamesDeep.length) { return; } const targetTagName = /** @type {string} */utils.getPreferredTagName({ tagName: 'property' }); const isError = validatePropertyNames(targetTagName, enableFixer, jsdoc, utils); if (isError) { return; } validatePropertyNamesDeep(targetTagName, jsdocPropertyNamesDeep, jsdoc, report); }, { iterateAllJsdocs: true, meta: { docs: { description: 'Ensures that property names in JSDoc are not duplicated on the same block and that nested properties have defined roots.', url: 'https://github.com/gajus/eslint-plugin-jsdoc/blob/main/docs/rules/check-property-names.md#repos-sticky-header' }, fixable: 'code', schema: [{ additionalProperties: false, properties: { enableFixer: { description: `Set to \`true\` to auto-remove \`@property\` duplicates (based on identical names). Note that this option will remove duplicates of the same name even if the definitions do not match in other ways (e.g., the second property will be removed even if it has a different type or description).`, type: 'boolean' } }, type: 'object' }], type: 'suggestion' } }); module.exports = exports.default; //# sourceMappingURL=checkPropertyNames.cjs.map