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.
Files changed (79) hide show
  1. package/dist/cjs/getJsdocProcessorPlugin.d.cts +5 -1
  2. package/dist/cjs/iterateJsdoc.d.cts +6 -2
  3. package/dist/getJsdocProcessorPlugin.cts +3 -1
  4. package/dist/iterateJsdoc.cts +9 -4
  5. package/package.json +4 -4
  6. package/src/getJsdocProcessorPlugin.cts +3 -1
  7. package/src/iterateJsdoc.cts +9 -4
  8. package/dist/cjs/WarnSettings.js +0 -30
  9. package/dist/cjs/alignTransform.js +0 -285
  10. package/dist/cjs/defaultTagOrder.js +0 -152
  11. package/dist/cjs/exportParser.js +0 -754
  12. package/dist/cjs/getDefaultTagStructureForMode.js +0 -840
  13. package/dist/cjs/getJsdocProcessorPlugin.cjs +0 -4
  14. package/dist/cjs/getJsdocProcessorPlugin.js +0 -553
  15. package/dist/cjs/index-cjs.js +0 -492
  16. package/dist/cjs/index.cjs.cjs +0 -6
  17. package/dist/cjs/iterateJsdoc.cjs +0 -38
  18. package/dist/cjs/iterateJsdoc.js +0 -1981
  19. package/dist/cjs/jsdocUtils.js +0 -1470
  20. package/dist/cjs/rules/checkAccess.js +0 -35
  21. package/dist/cjs/rules/checkAlignment.js +0 -63
  22. package/dist/cjs/rules/checkExamples.js +0 -486
  23. package/dist/cjs/rules/checkIndentation.js +0 -66
  24. package/dist/cjs/rules/checkLineAlignment.js +0 -297
  25. package/dist/cjs/rules/checkParamNames.js +0 -320
  26. package/dist/cjs/rules/checkPropertyNames.js +0 -105
  27. package/dist/cjs/rules/checkSyntax.js +0 -27
  28. package/dist/cjs/rules/checkTagNames.js +0 -252
  29. package/dist/cjs/rules/checkTemplateNames.js +0 -189
  30. package/dist/cjs/rules/checkTypes.js +0 -421
  31. package/dist/cjs/rules/checkValues.js +0 -163
  32. package/dist/cjs/rules/convertToJsdocComments.js +0 -313
  33. package/dist/cjs/rules/emptyTags.js +0 -79
  34. package/dist/cjs/rules/implementsOnClasses.js +0 -63
  35. package/dist/cjs/rules/importsAsDependencies.js +0 -105
  36. package/dist/cjs/rules/informativeDocs.js +0 -153
  37. package/dist/cjs/rules/linesBeforeBlock.js +0 -106
  38. package/dist/cjs/rules/matchDescription.js +0 -240
  39. package/dist/cjs/rules/matchName.js +0 -122
  40. package/dist/cjs/rules/multilineBlocks.js +0 -339
  41. package/dist/cjs/rules/noBadBlocks.js +0 -88
  42. package/dist/cjs/rules/noBlankBlockDescriptions.js +0 -56
  43. package/dist/cjs/rules/noBlankBlocks.js +0 -41
  44. package/dist/cjs/rules/noDefaults.js +0 -84
  45. package/dist/cjs/rules/noMissingSyntax.js +0 -164
  46. package/dist/cjs/rules/noMultiAsterisks.js +0 -83
  47. package/dist/cjs/rules/noRestrictedSyntax.js +0 -75
  48. package/dist/cjs/rules/noTypes.js +0 -88
  49. package/dist/cjs/rules/noUndefinedTypes.js +0 -451
  50. package/dist/cjs/rules/requireAsteriskPrefix.js +0 -144
  51. package/dist/cjs/rules/requireDescription.js +0 -136
  52. package/dist/cjs/rules/requireDescriptionCompleteSentence.js +0 -258
  53. package/dist/cjs/rules/requireExample.js +0 -103
  54. package/dist/cjs/rules/requireFileOverview.js +0 -117
  55. package/dist/cjs/rules/requireHyphenBeforeParamDescription.js +0 -144
  56. package/dist/cjs/rules/requireJsdoc.js +0 -629
  57. package/dist/cjs/rules/requireParam.js +0 -480
  58. package/dist/cjs/rules/requireParamDescription.js +0 -77
  59. package/dist/cjs/rules/requireParamName.js +0 -52
  60. package/dist/cjs/rules/requireParamType.js +0 -77
  61. package/dist/cjs/rules/requireProperty.js +0 -44
  62. package/dist/cjs/rules/requirePropertyDescription.js +0 -22
  63. package/dist/cjs/rules/requirePropertyName.js +0 -22
  64. package/dist/cjs/rules/requirePropertyType.js +0 -22
  65. package/dist/cjs/rules/requireReturns.js +0 -197
  66. package/dist/cjs/rules/requireReturnsCheck.js +0 -108
  67. package/dist/cjs/rules/requireReturnsDescription.js +0 -58
  68. package/dist/cjs/rules/requireReturnsType.js +0 -52
  69. package/dist/cjs/rules/requireTemplate.js +0 -173
  70. package/dist/cjs/rules/requireThrows.js +0 -101
  71. package/dist/cjs/rules/requireYields.js +0 -172
  72. package/dist/cjs/rules/requireYieldsCheck.js +0 -164
  73. package/dist/cjs/rules/sortTags.js +0 -392
  74. package/dist/cjs/rules/tagLines.js +0 -259
  75. package/dist/cjs/rules/textEscaping.js +0 -125
  76. package/dist/cjs/rules/typeFormatting.js +0 -328
  77. package/dist/cjs/rules/validTypes.js +0 -333
  78. package/dist/cjs/tagNames.js +0 -209
  79. package/dist/cjs/utils/hasReturnValue.js +0 -469
@@ -1,469 +0,0 @@
1
- "use strict";
2
- /**
3
- * @typedef {import('estree').Node|
4
- * import('@typescript-eslint/types').TSESTree.Node} ESTreeOrTypeScriptNode
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.hasValueOrExecutorHasNonEmptyResolveValue = exports.hasReturnValue = void 0;
8
- /**
9
- * Checks if a node is a promise but has no resolve value or an empty value.
10
- * An `undefined` resolve does not count.
11
- * @param {ESTreeOrTypeScriptNode|undefined|null} node
12
- * @returns {boolean|undefined|null}
13
- */
14
- const isNewPromiseExpression = (node) => {
15
- return node && node.type === 'NewExpression' && node.callee.type === 'Identifier' &&
16
- node.callee.name === 'Promise';
17
- };
18
- /**
19
- * @param {ESTreeOrTypeScriptNode|null|undefined} node
20
- * @returns {boolean}
21
- */
22
- const isVoidPromise = (node) => {
23
- return /** @type {import('@typescript-eslint/types').TSESTree.TSTypeReference} */ (node)?.typeArguments?.params?.[0]?.type === 'TSVoidKeyword'
24
- /* c8 ignore next 5 */
25
- // eslint-disable-next-line @stylistic/operator-linebreak -- c8
26
- || /** @type {import('@typescript-eslint/types').TSESTree.TSTypeReference} */ (node
27
- // @ts-expect-error Ok
28
- )?.typeParameters?.params?.[0]?.type === 'TSVoidKeyword';
29
- };
30
- const undefinedKeywords = new Set([
31
- 'TSNeverKeyword', 'TSUndefinedKeyword', 'TSVoidKeyword',
32
- ]);
33
- /**
34
- * Checks if a node has a return statement. Void return does not count.
35
- * @param {ESTreeOrTypeScriptNode|undefined|null} node
36
- * @param {boolean} [throwOnNullReturn]
37
- * @param {PromiseFilter} [promFilter]
38
- * @returns {boolean|undefined}
39
- */
40
- // eslint-disable-next-line complexity
41
- const hasReturnValue = (node, throwOnNullReturn, promFilter) => {
42
- if (!node) {
43
- return false;
44
- }
45
- switch (node.type) {
46
- case 'ArrowFunctionExpression':
47
- case 'FunctionDeclaration':
48
- case 'FunctionExpression': {
49
- return 'expression' in node && node.expression && (!isNewPromiseExpression(node.body) || !isVoidPromise(node.body)) ||
50
- hasReturnValue(node.body, throwOnNullReturn, promFilter);
51
- }
52
- case 'BlockStatement': {
53
- return node.body.some((bodyNode) => {
54
- return bodyNode.type !== 'FunctionDeclaration' && hasReturnValue(bodyNode, throwOnNullReturn, promFilter);
55
- });
56
- }
57
- case 'DoWhileStatement':
58
- case 'ForInStatement':
59
- case 'ForOfStatement':
60
- case 'ForStatement':
61
- case 'LabeledStatement':
62
- case 'WhileStatement':
63
- case 'WithStatement': {
64
- return hasReturnValue(node.body, throwOnNullReturn, promFilter);
65
- }
66
- case 'IfStatement': {
67
- return hasReturnValue(node.consequent, throwOnNullReturn, promFilter) ||
68
- hasReturnValue(node.alternate, throwOnNullReturn, promFilter);
69
- }
70
- case 'MethodDefinition':
71
- return hasReturnValue(node.value, throwOnNullReturn, promFilter);
72
- case 'ReturnStatement': {
73
- // void return does not count.
74
- if (node.argument === null) {
75
- if (throwOnNullReturn) {
76
- throw new Error('Null return');
77
- }
78
- return false;
79
- }
80
- if (promFilter && isNewPromiseExpression(node.argument)) {
81
- // Let caller decide how to filter, but this is, at the least,
82
- // a return of sorts and truthy
83
- return promFilter(node.argument);
84
- }
85
- return true;
86
- }
87
- case 'SwitchStatement': {
88
- return node.cases.some((someCase) => {
89
- return someCase.consequent.some((nde) => {
90
- return hasReturnValue(nde, throwOnNullReturn, promFilter);
91
- });
92
- });
93
- }
94
- case 'TryStatement': {
95
- return hasReturnValue(node.block, throwOnNullReturn, promFilter) ||
96
- hasReturnValue(node.handler && node.handler.body, throwOnNullReturn, promFilter) ||
97
- hasReturnValue(node.finalizer, throwOnNullReturn, promFilter);
98
- }
99
- case 'TSDeclareFunction':
100
- case 'TSFunctionType':
101
- case 'TSMethodSignature': {
102
- const type = node?.returnType?.typeAnnotation?.type;
103
- return type && !undefinedKeywords.has(type);
104
- }
105
- default: {
106
- return false;
107
- }
108
- }
109
- };
110
- exports.hasReturnValue = hasReturnValue;
111
- /**
112
- * Checks if a node has a return statement. Void return does not count.
113
- * @param {ESTreeOrTypeScriptNode|null|undefined} node
114
- * @param {PromiseFilter} promFilter
115
- * @returns {undefined|boolean|ESTreeOrTypeScriptNode}
116
- */
117
- // eslint-disable-next-line complexity
118
- const allBrancheshaveReturnValues = (node, promFilter) => {
119
- if (!node) {
120
- return false;
121
- }
122
- switch (node.type) {
123
- // case 'MethodDefinition':
124
- // return allBrancheshaveReturnValues(node.value, promFilter);
125
- case 'ArrowFunctionExpression':
126
- case 'FunctionDeclaration':
127
- case 'FunctionExpression': {
128
- return 'expression' in node && node.expression && (!isNewPromiseExpression(node.body) || !isVoidPromise(node.body)) ||
129
- allBrancheshaveReturnValues(node.body, promFilter) ||
130
- /** @type {import('@typescript-eslint/types').TSESTree.BlockStatement} */
131
- (node.body).body.some((nde) => {
132
- return nde.type === 'ReturnStatement';
133
- });
134
- }
135
- case 'BlockStatement': {
136
- const lastBodyNode = node.body.slice(-1)[0];
137
- return allBrancheshaveReturnValues(lastBodyNode, promFilter);
138
- }
139
- case 'DoWhileStatement':
140
- case 'WhileStatement':
141
- if (
142
- /**
143
- * @type {import('@typescript-eslint/types').TSESTree.Literal}
144
- */
145
- (node.test).value === true) {
146
- // If this is an infinite loop, we assume only one branch
147
- // is needed to provide a return
148
- return hasReturnValue(node.body, false, promFilter);
149
- }
150
- // Fallthrough
151
- case 'ForStatement':
152
- if (node.test === null) {
153
- // If this is an infinite loop, we assume only one branch
154
- // is needed to provide a return
155
- return hasReturnValue(node.body, false, promFilter);
156
- }
157
- case 'ForInStatement':
158
- case 'ForOfStatement':
159
- case 'LabeledStatement':
160
- case 'WithStatement': {
161
- return allBrancheshaveReturnValues(node.body, promFilter);
162
- }
163
- case 'IfStatement': {
164
- return allBrancheshaveReturnValues(node.consequent, promFilter) &&
165
- allBrancheshaveReturnValues(node.alternate, promFilter);
166
- }
167
- case 'ReturnStatement': {
168
- // void return does not count.
169
- if (node.argument === null) {
170
- return false;
171
- }
172
- if (promFilter && isNewPromiseExpression(node.argument)) {
173
- // Let caller decide how to filter, but this is, at the least,
174
- // a return of sorts and truthy
175
- return promFilter(node.argument);
176
- }
177
- return true;
178
- }
179
- case 'SwitchStatement': {
180
- return /** @type {import('@typescript-eslint/types').TSESTree.SwitchStatement} */ (node).cases.every((someCase) => {
181
- return !someCase.consequent.some((consNode) => {
182
- return consNode.type === 'BreakStatement' ||
183
- consNode.type === 'ReturnStatement' && consNode.argument === null;
184
- });
185
- });
186
- }
187
- case 'ThrowStatement': {
188
- return true;
189
- }
190
- case 'TryStatement': {
191
- // If `finally` returns, all return
192
- return node.finalizer && allBrancheshaveReturnValues(node.finalizer, promFilter) ||
193
- // Return in `try`/`catch` may still occur despite `finally`
194
- allBrancheshaveReturnValues(node.block, promFilter) &&
195
- (!node.handler ||
196
- allBrancheshaveReturnValues(node.handler && node.handler.body, promFilter)) &&
197
- (!node.finalizer || (() => {
198
- try {
199
- hasReturnValue(node.finalizer, true, promFilter);
200
- }
201
- catch (error) {
202
- if ( /** @type {Error} */(error).message === 'Null return') {
203
- return false;
204
- }
205
- /* c8 ignore next 3 */
206
- // eslint-disable-next-line @stylistic/padding-line-between-statements -- c8
207
- throw error;
208
- }
209
- // As long as not an explicit empty return, then return true
210
- return true;
211
- })());
212
- }
213
- case 'TSDeclareFunction':
214
- case 'TSFunctionType':
215
- case 'TSMethodSignature': {
216
- const type = node?.returnType?.typeAnnotation?.type;
217
- return type && !undefinedKeywords.has(type);
218
- }
219
- default: {
220
- return false;
221
- }
222
- }
223
- };
224
- /**
225
- * @callback PromiseFilter
226
- * @param {ESTreeOrTypeScriptNode|undefined} node
227
- * @returns {boolean}
228
- */
229
- /**
230
- * Avoids further checking child nodes if a nested function shadows the
231
- * resolver, but otherwise, if name is used (by call or passed in as an
232
- * argument to another function), will be considered as non-empty.
233
- *
234
- * This could check for redeclaration of the resolver, but as such is
235
- * unlikely, we avoid the performance cost of checking everywhere for
236
- * (re)declarations or assignments.
237
- * @param {import('@typescript-eslint/types').TSESTree.Node|null|undefined} node
238
- * @param {string} resolverName
239
- * @returns {boolean}
240
- */
241
- // eslint-disable-next-line complexity
242
- const hasNonEmptyResolverCall = (node, resolverName) => {
243
- if (!node) {
244
- return false;
245
- }
246
- // Arrow function without block
247
- switch (node.type) {
248
- case 'ArrayExpression':
249
- case 'ArrayPattern':
250
- return node.elements.some((element) => {
251
- return hasNonEmptyResolverCall(element, resolverName);
252
- });
253
- case 'ArrowFunctionExpression':
254
- case 'FunctionDeclaration':
255
- case 'FunctionExpression': {
256
- // Shadowing
257
- if ( /** @type {import('@typescript-eslint/types').TSESTree.Identifier} */(node.params[0])?.name === resolverName) {
258
- return false;
259
- }
260
- return hasNonEmptyResolverCall(node.body, resolverName);
261
- }
262
- case 'AssignmentExpression':
263
- case 'BinaryExpression':
264
- case 'LogicalExpression': {
265
- return hasNonEmptyResolverCall(node.left, resolverName) ||
266
- hasNonEmptyResolverCall(node.right, resolverName);
267
- }
268
- case 'AssignmentPattern':
269
- return hasNonEmptyResolverCall(node.right, resolverName);
270
- case 'AwaitExpression':
271
- case 'SpreadElement':
272
- case 'UnaryExpression':
273
- case 'YieldExpression':
274
- return hasNonEmptyResolverCall(node.argument, resolverName);
275
- case 'BlockStatement':
276
- case 'ClassBody':
277
- return node.body.some((bodyNode) => {
278
- return hasNonEmptyResolverCall(bodyNode, resolverName);
279
- });
280
- /* c8 ignore next 2 -- In Babel? */
281
- case 'CallExpression':
282
- // @ts-expect-error Babel?
283
- case 'OptionalCallExpression':
284
- return /** @type {import('@typescript-eslint/types').TSESTree.Identifier} */ (node.callee).name === resolverName && (
285
- // Implicit or explicit undefined
286
- node.arguments.length > 1 || node.arguments[0] !== undefined) ||
287
- node.arguments.some((nde) => {
288
- // Being passed in to another function (which might invoke it)
289
- return nde.type === 'Identifier' && nde.name === resolverName ||
290
- // Handle nested items
291
- hasNonEmptyResolverCall(nde, resolverName);
292
- });
293
- case 'ChainExpression':
294
- case 'Decorator':
295
- case 'ExpressionStatement':
296
- return hasNonEmptyResolverCall(node.expression, resolverName);
297
- case 'ClassDeclaration':
298
- case 'ClassExpression':
299
- return hasNonEmptyResolverCall(node.body, resolverName);
300
- /* c8 ignore next 2 -- In Babel? */
301
- // @ts-expect-error Babel?
302
- case 'ClassMethod':
303
- case 'MethodDefinition':
304
- return node.decorators && node.decorators.some((decorator) => {
305
- return hasNonEmptyResolverCall(decorator, resolverName);
306
- }) ||
307
- node.computed && hasNonEmptyResolverCall(node.key, resolverName) ||
308
- hasNonEmptyResolverCall(node.value, resolverName);
309
- /* c8 ignore next 2 -- In Babel? */
310
- // @ts-expect-error Babel?
311
- case 'ClassProperty':
312
- /* c8 ignore next 2 -- In Babel? */
313
- // @ts-expect-error Babel?
314
- case 'ObjectProperty':
315
- case 'Property':
316
- case 'PropertyDefinition':
317
- return node.computed && hasNonEmptyResolverCall(node.key, resolverName) ||
318
- hasNonEmptyResolverCall(node.value, resolverName);
319
- case 'ConditionalExpression':
320
- case 'IfStatement': {
321
- return hasNonEmptyResolverCall(node.test, resolverName) ||
322
- hasNonEmptyResolverCall(node.consequent, resolverName) ||
323
- hasNonEmptyResolverCall(node.alternate, resolverName);
324
- }
325
- case 'DoWhileStatement':
326
- case 'ForInStatement':
327
- case 'ForOfStatement':
328
- case 'ForStatement':
329
- case 'LabeledStatement':
330
- case 'WhileStatement':
331
- case 'WithStatement': {
332
- return hasNonEmptyResolverCall(node.body, resolverName);
333
- }
334
- /* c8 ignore next 2 -- In Babel? */
335
- // @ts-expect-error Babel?
336
- case 'Import':
337
- case 'ImportExpression':
338
- return hasNonEmptyResolverCall(node.source, resolverName);
339
- // ?.
340
- /* c8 ignore next 2 -- In Babel? */
341
- case 'MemberExpression':
342
- // @ts-expect-error Babel?
343
- case 'OptionalMemberExpression':
344
- return hasNonEmptyResolverCall(node.object, resolverName) ||
345
- hasNonEmptyResolverCall(node.property, resolverName);
346
- case 'ObjectExpression':
347
- case 'ObjectPattern':
348
- return node.properties.some((property) => {
349
- return hasNonEmptyResolverCall(property, resolverName);
350
- });
351
- /* c8 ignore next 2 -- In Babel? */
352
- // @ts-expect-error Babel?
353
- case 'ObjectMethod':
354
- /* c8 ignore next 6 -- In Babel? */
355
- // @ts-expect-error
356
- return node.computed && hasNonEmptyResolverCall(node.key, resolverName) ||
357
- // @ts-expect-error
358
- node.arguments.some((nde) => {
359
- return hasNonEmptyResolverCall(nde, resolverName);
360
- });
361
- case 'ReturnStatement': {
362
- if (node.argument === null) {
363
- return false;
364
- }
365
- return hasNonEmptyResolverCall(node.argument, resolverName);
366
- }
367
- // Comma
368
- case 'SequenceExpression':
369
- case 'TemplateLiteral':
370
- return node.expressions.some((subExpression) => {
371
- return hasNonEmptyResolverCall(subExpression, resolverName);
372
- });
373
- case 'SwitchStatement': {
374
- return node.cases.some((someCase) => {
375
- return someCase.consequent.some((nde) => {
376
- return hasNonEmptyResolverCall(nde, resolverName);
377
- });
378
- });
379
- }
380
- case 'TaggedTemplateExpression':
381
- return hasNonEmptyResolverCall(node.quasi, resolverName);
382
- case 'TryStatement': {
383
- return hasNonEmptyResolverCall(node.block, resolverName) ||
384
- hasNonEmptyResolverCall(node.handler && node.handler.body, resolverName) ||
385
- hasNonEmptyResolverCall(node.finalizer, resolverName);
386
- }
387
- case 'VariableDeclaration': {
388
- return node.declarations.some((nde) => {
389
- return hasNonEmptyResolverCall(nde, resolverName);
390
- });
391
- }
392
- case 'VariableDeclarator': {
393
- return hasNonEmptyResolverCall(node.id, resolverName) ||
394
- hasNonEmptyResolverCall(node.init, resolverName);
395
- }
396
- /*
397
- // Shouldn't need to parse literals/literal components, etc.
398
-
399
- case 'Identifier':
400
- case 'TemplateElement':
401
- case 'Super':
402
- // Exports not relevant in this context
403
- */
404
- default:
405
- return false;
406
- }
407
- };
408
- /**
409
- * Checks if a Promise executor has no resolve value or an empty value.
410
- * An `undefined` resolve does not count.
411
- * @param {ESTreeOrTypeScriptNode} node
412
- * @param {boolean} anyPromiseAsReturn
413
- * @param {boolean} [allBranches]
414
- * @returns {boolean}
415
- */
416
- const hasValueOrExecutorHasNonEmptyResolveValue = (node, anyPromiseAsReturn, allBranches) => {
417
- const hasReturnMethod = allBranches ?
418
- /**
419
- * @param {ESTreeOrTypeScriptNode} nde
420
- * @param {PromiseFilter} promiseFilter
421
- * @returns {boolean}
422
- */
423
- (nde, promiseFilter) => {
424
- let hasReturn;
425
- try {
426
- hasReturn = hasReturnValue(nde, true, promiseFilter);
427
- }
428
- catch (error) {
429
- // c8 ignore else
430
- if ( /** @type {Error} */(error).message === 'Null return') {
431
- return false;
432
- }
433
- /* c8 ignore next 3 */
434
- // eslint-disable-next-line @stylistic/padding-line-between-statements -- c8
435
- throw error;
436
- }
437
- // `hasReturn` check needed since `throw` treated as valid return by
438
- // `allBrancheshaveReturnValues`
439
- return Boolean(hasReturn && allBrancheshaveReturnValues(nde, promiseFilter));
440
- } :
441
- /**
442
- * @param {ESTreeOrTypeScriptNode} nde
443
- * @param {PromiseFilter} promiseFilter
444
- * @returns {boolean}
445
- */
446
- (nde, promiseFilter) => {
447
- return Boolean(hasReturnValue(nde, false, promiseFilter));
448
- };
449
- return hasReturnMethod(node, (prom) => {
450
- if (anyPromiseAsReturn) {
451
- return true;
452
- }
453
- if (isVoidPromise(prom)) {
454
- return false;
455
- }
456
- const { body, params, } =
457
- /**
458
- * @type {import('@typescript-eslint/types').TSESTree.FunctionExpression|
459
- * import('@typescript-eslint/types').TSESTree.ArrowFunctionExpression}
460
- */ (
461
- /** @type {import('@typescript-eslint/types').TSESTree.NewExpression} */ (prom).arguments[0]) || {};
462
- if (!params?.length) {
463
- return false;
464
- }
465
- const { name: resolverName, } = /** @type {import('@typescript-eslint/types').TSESTree.Identifier} */ (params[0]);
466
- return hasNonEmptyResolverCall(body, resolverName);
467
- });
468
- };
469
- exports.hasValueOrExecutorHasNonEmptyResolveValue = hasValueOrExecutorHasNonEmptyResolveValue;