eslint-plugin-jsdoc
Version:
JSDoc linting rules for ESLint.
110 lines (107 loc) • 3.85 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _iterateJsdoc = _interopRequireDefault(require("../iterateJsdoc.cjs"));
var _jsdocUtils = require("../jsdocUtils.cjs");
var _jsdoccomment = require("@es-joy/jsdoccomment");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
var _default = exports.default = (0, _iterateJsdoc.default)(({
context,
indent,
jsdoc,
utils
}) => {
const {
enableFixer = true
} = context.options[0] || {};
/**
* @param {import('@es-joy/jsdoccomment').JsdocTagWithInline} tag
*/
const checkType = tag => {
const potentialType = tag.type;
/** @type {import('jsdoc-type-pratt-parser').RootResult} */
let parsedType;
try {
parsedType = (0, _jsdoccomment.parse)(/** @type {string} */potentialType, 'typescript');
} catch {
return;
}
(0, _jsdoccomment.traverse)(parsedType, (nde, parentNode) => {
// @ts-expect-error Adding our own property for use below
nde.parentNode = parentNode;
});
(0, _jsdoccomment.traverse)(parsedType, (nde, parentNode, property, index) => {
switch (nde.type) {
case 'JsdocTypeCallSignature':
{
const object = /** @type {import('jsdoc-type-pratt-parser').ObjectResult} */
parentNode;
if (typeof index === 'number' && object.elements.length === 1) {
utils.reportJSDoc('Call signature found; function type preferred.', tag, enableFixer ? () => {
const func = /** @type {import('jsdoc-type-pratt-parser').FunctionResult} */{
arrow: true,
constructor: false,
meta: (/** @type {Required<import('jsdoc-type-pratt-parser').MethodSignatureResult['meta']>} */
nde.meta),
parameters: nde.parameters,
parenthesis: true,
returnType: nde.returnType,
type: 'JsdocTypeFunction',
typeParameters: nde.typeParameters
};
if (property && 'parentNode' in object && object.parentNode) {
if (typeof object.parentNode === 'object' && 'elements' in object.parentNode && Array.isArray(object.parentNode.elements)) {
const idx = object.parentNode.elements.indexOf(object);
object.parentNode.elements[idx] = func;
/* c8 ignore next 6 -- Guard */
} else {
throw new Error(
// @ts-expect-error Ok
`Rule currently unable to handle type ${object.parentNode.type}`);
}
} else {
parsedType = func;
}
(0, _jsdocUtils.rewireByParsedType)(jsdoc, tag, parsedType, indent);
} : null);
}
break;
}
}
});
};
const tags = utils.filterTags(({
tag
}) => {
return Boolean(tag !== 'import' && utils.tagMightHaveTypePosition(tag));
});
for (const tag of tags) {
if (tag.type) {
checkType(tag);
}
}
}, {
iterateAllJsdocs: true,
meta: {
docs: {
description: 'Prefers function types over call signatures when there are no other properties.',
url: 'https://github.com/gajus/eslint-plugin-jsdoc/blob/main/docs/rules/ts-prefer-function-type.md#repos-sticky-header'
},
fixable: 'code',
schema: [{
additionalProperties: false,
properties: {
enableFixer: {
description: 'Whether to enable the fixer or not',
type: 'boolean'
}
},
type: 'object'
}],
type: 'suggestion'
}
});
module.exports = exports.default;
//# sourceMappingURL=tsPreferFunctionType.cjs.map