eslint-plugin-jsdoc 48.0.0 → 48.0.1

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