1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- "use strict";
-
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
-
- var _iterateJsdoc = _interopRequireDefault(require("../iterateJsdoc"));
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- var _default = (0, _iterateJsdoc.default)(({
- utils
- }) => {
- const propertyAssociatedTags = utils.filterTags(({
- tag
- }) => {
- return ['typedef', 'namespace'].includes(tag);
- });
-
- if (!propertyAssociatedTags.length) {
- return;
- }
-
- const targetTagName = utils.getPreferredTagName({
- tagName: 'property'
- });
-
- if (utils.hasATag([targetTagName])) {
- return;
- }
-
- propertyAssociatedTags.forEach(propertyAssociatedTag => {
- if (!['object', 'Object', 'PlainObject'].includes(propertyAssociatedTag.type)) {
- return;
- }
-
- utils.reportJSDoc(`Missing JSDoc @${targetTagName}.`, null, () => {
- utils.addTag(targetTagName);
- });
- });
- }, {
- iterateAllJsdocs: true,
- meta: {
- docs: {
- description: 'Requires that all `@typedef` and `@namespace` tags have `@property` when their type is a plain `object`, `Object`, or `PlainObject`.',
- url: 'https://github.com/gajus/eslint-plugin-jsdoc#eslint-plugin-jsdoc-rules-require-property'
- },
- fixable: 'code',
- type: 'suggestion'
- }
- });
-
- exports.default = _default;
- module.exports = exports.default;
- //# sourceMappingURL=requireProperty.js.map
|