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