eslint-plugin-jsdoc 52.0.3 → 52.0.4

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 (357) hide show
  1. package/dist/WarnSettings.cjs +35 -18
  2. package/dist/WarnSettings.cjs.map +1 -1
  3. package/dist/alignTransform.cjs +305 -224
  4. package/dist/alignTransform.cjs.map +1 -1
  5. package/dist/defaultTagOrder.cjs +43 -132
  6. package/dist/defaultTagOrder.cjs.map +1 -1
  7. package/dist/exportParser.cjs +696 -478
  8. package/dist/exportParser.cjs.map +1 -1
  9. package/dist/generateRule.cjs +242 -0
  10. package/dist/generateRule.cjs.map +1 -0
  11. package/dist/getDefaultTagStructureForMode.cjs +288 -184
  12. package/dist/getDefaultTagStructureForMode.cjs.map +1 -1
  13. package/dist/getJsdocProcessorPlugin.cjs +550 -364
  14. package/dist/getJsdocProcessorPlugin.cjs.map +1 -1
  15. package/dist/getJsdocProcessorPlugin.d.ts +65 -68
  16. package/dist/getJsdocProcessorPlugin.d.ts.map +1 -1
  17. package/dist/index.cjs +383 -398
  18. package/dist/index.cjs.map +1 -1
  19. package/dist/index.d.ts +6 -11
  20. package/dist/index.d.ts.map +1 -1
  21. package/dist/iterateJsdoc.cjs +1988 -1528
  22. package/dist/iterateJsdoc.cjs.map +1 -1
  23. package/dist/iterateJsdoc.d.ts +349 -358
  24. package/dist/iterateJsdoc.d.ts.map +1 -1
  25. package/dist/jsdocUtils.cjs +1376 -1009
  26. package/dist/jsdocUtils.cjs.map +1 -1
  27. package/dist/rules/checkAccess.cjs +36 -29
  28. package/dist/rules/checkAccess.cjs.map +1 -1
  29. package/dist/rules/checkAlignment.cjs +54 -41
  30. package/dist/rules/checkAlignment.cjs.map +1 -1
  31. package/dist/rules/checkExamples.cjs +484 -327
  32. package/dist/rules/checkExamples.cjs.map +1 -1
  33. package/dist/rules/checkIndentation.cjs +65 -50
  34. package/dist/rules/checkIndentation.cjs.map +1 -1
  35. package/dist/rules/checkLineAlignment.cjs +311 -220
  36. package/dist/rules/checkLineAlignment.cjs.map +1 -1
  37. package/dist/rules/checkParamNames.cjs +335 -227
  38. package/dist/rules/checkParamNames.cjs.map +1 -1
  39. package/dist/rules/checkPropertyNames.cjs +106 -78
  40. package/dist/rules/checkPropertyNames.cjs.map +1 -1
  41. package/dist/rules/checkSyntax.cjs +34 -21
  42. package/dist/rules/checkSyntax.cjs.map +1 -1
  43. package/dist/rules/checkTagNames.cjs +210 -188
  44. package/dist/rules/checkTagNames.cjs.map +1 -1
  45. package/dist/rules/checkTemplateNames.cjs +178 -121
  46. package/dist/rules/checkTemplateNames.cjs.map +1 -1
  47. package/dist/rules/checkTypes.cjs +385 -291
  48. package/dist/rules/checkTypes.cjs.map +1 -1
  49. package/dist/rules/checkValues.cjs +146 -100
  50. package/dist/rules/checkValues.cjs.map +1 -1
  51. package/dist/rules/convertToJsdocComments.cjs +306 -228
  52. package/dist/rules/convertToJsdocComments.cjs.map +1 -1
  53. package/dist/rules/emptyTags.cjs +72 -62
  54. package/dist/rules/emptyTags.cjs.map +1 -1
  55. package/dist/rules/implementsOnClasses.cjs +56 -36
  56. package/dist/rules/implementsOnClasses.cjs.map +1 -1
  57. package/dist/rules/importsAsDependencies.cjs +99 -62
  58. package/dist/rules/importsAsDependencies.cjs.map +1 -1
  59. package/dist/rules/informativeDocs.cjs +142 -105
  60. package/dist/rules/informativeDocs.cjs.map +1 -1
  61. package/dist/rules/linesBeforeBlock.cjs +105 -70
  62. package/dist/rules/linesBeforeBlock.cjs.map +1 -1
  63. package/dist/rules/matchDescription.cjs +222 -160
  64. package/dist/rules/matchDescription.cjs.map +1 -1
  65. package/dist/rules/matchName.cjs +128 -73
  66. package/dist/rules/matchName.cjs.map +1 -1
  67. package/dist/rules/multilineBlocks.cjs +352 -235
  68. package/dist/rules/multilineBlocks.cjs.map +1 -1
  69. package/dist/rules/noBadBlocks.cjs +86 -63
  70. package/dist/rules/noBadBlocks.cjs.map +1 -1
  71. package/dist/rules/noBlankBlockDescriptions.cjs +57 -35
  72. package/dist/rules/noBlankBlockDescriptions.cjs.map +1 -1
  73. package/dist/rules/noBlankBlocks.cjs +48 -26
  74. package/dist/rules/noBlankBlocks.cjs.map +1 -1
  75. package/dist/rules/noDefaults.cjs +79 -52
  76. package/dist/rules/noDefaults.cjs.map +1 -1
  77. package/dist/rules/noMissingSyntax.cjs +165 -115
  78. package/dist/rules/noMissingSyntax.cjs.map +1 -1
  79. package/dist/rules/noMultiAsterisks.cjs +89 -48
  80. package/dist/rules/noMultiAsterisks.cjs.map +1 -1
  81. package/dist/rules/noRestrictedSyntax.cjs +79 -45
  82. package/dist/rules/noRestrictedSyntax.cjs.map +1 -1
  83. package/dist/rules/noTypes.cjs +80 -59
  84. package/dist/rules/noTypes.cjs.map +1 -1
  85. package/dist/rules/noUndefinedTypes.cjs +388 -297
  86. package/dist/rules/noUndefinedTypes.cjs.map +1 -1
  87. package/dist/rules/requireAsteriskPrefix.cjs +159 -108
  88. package/dist/rules/requireAsteriskPrefix.cjs.map +1 -1
  89. package/dist/rules/requireDescription.cjs +129 -89
  90. package/dist/rules/requireDescription.cjs.map +1 -1
  91. package/dist/rules/requireDescriptionCompleteSentence.cjs +262 -201
  92. package/dist/rules/requireDescriptionCompleteSentence.cjs.map +1 -1
  93. package/dist/rules/requireExample.cjs +104 -73
  94. package/dist/rules/requireExample.cjs.map +1 -1
  95. package/dist/rules/requireFileOverview.cjs +129 -75
  96. package/dist/rules/requireFileOverview.cjs.map +1 -1
  97. package/dist/rules/requireHyphenBeforeParamDescription.cjs +133 -85
  98. package/dist/rules/requireHyphenBeforeParamDescription.cjs.map +1 -1
  99. package/dist/rules/requireJsdoc.cjs +557 -384
  100. package/dist/rules/requireJsdoc.cjs.map +1 -1
  101. package/dist/rules/requireParam.cjs +526 -336
  102. package/dist/rules/requireParam.cjs.map +1 -1
  103. package/dist/rules/requireParamDescription.cjs +80 -55
  104. package/dist/rules/requireParamDescription.cjs.map +1 -1
  105. package/dist/rules/requireParamName.cjs +50 -32
  106. package/dist/rules/requireParamName.cjs.map +1 -1
  107. package/dist/rules/requireParamType.cjs +80 -55
  108. package/dist/rules/requireParamType.cjs.map +1 -1
  109. package/dist/rules/requireProperty.cjs +42 -31
  110. package/dist/rules/requireProperty.cjs.map +1 -1
  111. package/dist/rules/requirePropertyDescription.cjs +25 -17
  112. package/dist/rules/requirePropertyDescription.cjs.map +1 -1
  113. package/dist/rules/requirePropertyName.cjs +25 -17
  114. package/dist/rules/requirePropertyName.cjs.map +1 -1
  115. package/dist/rules/requirePropertyType.cjs +25 -17
  116. package/dist/rules/requirePropertyType.cjs.map +1 -1
  117. package/dist/rules/requireReturns.cjs +203 -125
  118. package/dist/rules/requireReturns.cjs.map +1 -1
  119. package/dist/rules/requireReturnsCheck.cjs +103 -60
  120. package/dist/rules/requireReturnsCheck.cjs.map +1 -1
  121. package/dist/rules/requireReturnsDescription.cjs +54 -39
  122. package/dist/rules/requireReturnsDescription.cjs.map +1 -1
  123. package/dist/rules/requireReturnsType.cjs +50 -32
  124. package/dist/rules/requireReturnsType.cjs.map +1 -1
  125. package/dist/rules/requireTemplate.cjs +178 -119
  126. package/dist/rules/requireTemplate.cjs.map +1 -1
  127. package/dist/rules/requireThrows.cjs +95 -61
  128. package/dist/rules/requireThrows.cjs.map +1 -1
  129. package/dist/rules/requireYields.cjs +166 -106
  130. package/dist/rules/requireYields.cjs.map +1 -1
  131. package/dist/rules/requireYieldsCheck.cjs +152 -96
  132. package/dist/rules/requireYieldsCheck.cjs.map +1 -1
  133. package/dist/rules/sortTags.cjs +444 -258
  134. package/dist/rules/sortTags.cjs.map +1 -1
  135. package/dist/rules/tagLines.cjs +266 -179
  136. package/dist/rules/tagLines.cjs.map +1 -1
  137. package/dist/rules/textEscaping.cjs +127 -92
  138. package/dist/rules/textEscaping.cjs.map +1 -1
  139. package/dist/rules/validTypes.cjs +265 -252
  140. package/dist/rules/validTypes.cjs.map +1 -1
  141. package/dist/tagNames.cjs +170 -134
  142. package/dist/tagNames.cjs.map +1 -1
  143. package/dist/utils/hasReturnValue.cjs +474 -246
  144. package/dist/utils/hasReturnValue.cjs.map +1 -1
  145. package/package.json +24 -40
  146. package/src/WarnSettings.js +34 -0
  147. package/src/alignTransform.js +358 -0
  148. package/src/defaultTagOrder.js +169 -0
  149. package/src/exportParser.js +978 -0
  150. package/src/getDefaultTagStructureForMode.js +969 -0
  151. package/src/getJsdocProcessorPlugin.js +672 -0
  152. package/src/index.js +530 -0
  153. package/src/iterateJsdoc.js +2518 -0
  154. package/src/jsdocUtils.js +1896 -0
  155. package/src/rules/checkAccess.js +45 -0
  156. package/src/rules/checkAlignment.js +63 -0
  157. package/src/rules/checkExamples.js +589 -0
  158. package/src/rules/checkIndentation.js +75 -0
  159. package/src/rules/checkLineAlignment.js +372 -0
  160. package/src/rules/checkParamNames.js +474 -0
  161. package/src/rules/checkPropertyNames.js +152 -0
  162. package/src/rules/checkSyntax.js +30 -0
  163. package/src/rules/checkTagNames.js +314 -0
  164. package/src/rules/checkTemplateNames.js +204 -0
  165. package/src/rules/checkTypes.js +535 -0
  166. package/src/rules/checkValues.js +248 -0
  167. package/src/rules/convertToJsdocComments.js +398 -0
  168. package/src/rules/emptyTags.js +98 -0
  169. package/src/rules/implementsOnClasses.js +64 -0
  170. package/src/rules/importsAsDependencies.js +133 -0
  171. package/src/rules/informativeDocs.js +189 -0
  172. package/src/rules/linesBeforeBlock.js +134 -0
  173. package/src/rules/matchDescription.js +286 -0
  174. package/src/rules/matchName.js +151 -0
  175. package/src/rules/multilineBlocks.js +493 -0
  176. package/src/rules/noBadBlocks.js +119 -0
  177. package/src/rules/noBlankBlockDescriptions.js +69 -0
  178. package/src/rules/noBlankBlocks.js +53 -0
  179. package/src/rules/noDefaults.js +85 -0
  180. package/src/rules/noMissingSyntax.js +195 -0
  181. package/src/rules/noMultiAsterisks.js +134 -0
  182. package/src/rules/noRestrictedSyntax.js +91 -0
  183. package/src/rules/noTypes.js +93 -0
  184. package/src/rules/noUndefinedTypes.js +543 -0
  185. package/src/rules/requireAsteriskPrefix.js +190 -0
  186. package/src/rules/requireDescription.js +161 -0
  187. package/src/rules/requireDescriptionCompleteSentence.js +335 -0
  188. package/src/rules/requireExample.js +118 -0
  189. package/src/rules/requireFileOverview.js +154 -0
  190. package/src/rules/requireHyphenBeforeParamDescription.js +176 -0
  191. package/src/rules/requireJsdoc.js +743 -0
  192. package/src/rules/requireParam.js +602 -0
  193. package/src/rules/requireParamDescription.js +89 -0
  194. package/src/rules/requireParamName.js +55 -0
  195. package/src/rules/requireParamType.js +89 -0
  196. package/src/rules/requireProperty.js +48 -0
  197. package/src/rules/requirePropertyDescription.js +25 -0
  198. package/src/rules/requirePropertyName.js +25 -0
  199. package/src/rules/requirePropertyType.js +25 -0
  200. package/src/rules/requireReturns.js +238 -0
  201. package/src/rules/requireReturnsCheck.js +145 -0
  202. package/src/rules/requireReturnsDescription.js +59 -0
  203. package/src/rules/requireReturnsType.js +51 -0
  204. package/src/rules/requireTemplate.js +201 -0
  205. package/src/rules/requireThrows.js +111 -0
  206. package/src/rules/requireYields.js +216 -0
  207. package/src/rules/requireYieldsCheck.js +208 -0
  208. package/src/rules/sortTags.js +558 -0
  209. package/src/rules/tagLines.js +359 -0
  210. package/src/rules/textEscaping.js +154 -0
  211. package/src/rules/validTypes.js +401 -0
  212. package/src/tagNames.js +238 -0
  213. package/src/utils/hasReturnValue.js +572 -0
  214. package/dist/WarnSettings.js +0 -20
  215. package/dist/WarnSettings.js.map +0 -1
  216. package/dist/_virtual/rolldown_runtime.cjs +0 -32
  217. package/dist/_virtual/rolldown_runtime.js +0 -11
  218. package/dist/alignTransform.js +0 -241
  219. package/dist/alignTransform.js.map +0 -1
  220. package/dist/defaultTagOrder.js +0 -134
  221. package/dist/defaultTagOrder.js.map +0 -1
  222. package/dist/exportParser.js +0 -518
  223. package/dist/exportParser.js.map +0 -1
  224. package/dist/getDefaultTagStructureForMode.js +0 -188
  225. package/dist/getDefaultTagStructureForMode.js.map +0 -1
  226. package/dist/getJsdocProcessorPlugin.d.cts +0 -70
  227. package/dist/getJsdocProcessorPlugin.d.cts.map +0 -1
  228. package/dist/getJsdocProcessorPlugin.js +0 -383
  229. package/dist/getJsdocProcessorPlugin.js.map +0 -1
  230. package/dist/index.d.cts +0 -22
  231. package/dist/index.d.cts.map +0 -1
  232. package/dist/index.js +0 -425
  233. package/dist/index.js.map +0 -1
  234. package/dist/iterateJsdoc.d.cts +0 -471
  235. package/dist/iterateJsdoc.d.cts.map +0 -1
  236. package/dist/iterateJsdoc.js +0 -1617
  237. package/dist/iterateJsdoc.js.map +0 -1
  238. package/dist/jsdocUtils.js +0 -1123
  239. package/dist/jsdocUtils.js.map +0 -1
  240. package/dist/rules/checkAccess.js +0 -33
  241. package/dist/rules/checkAccess.js.map +0 -1
  242. package/dist/rules/checkAlignment.js +0 -47
  243. package/dist/rules/checkAlignment.js.map +0 -1
  244. package/dist/rules/checkExamples.js +0 -348
  245. package/dist/rules/checkExamples.js.map +0 -1
  246. package/dist/rules/checkIndentation.js +0 -59
  247. package/dist/rules/checkIndentation.js.map +0 -1
  248. package/dist/rules/checkLineAlignment.js +0 -229
  249. package/dist/rules/checkLineAlignment.js.map +0 -1
  250. package/dist/rules/checkParamNames.js +0 -237
  251. package/dist/rules/checkParamNames.js.map +0 -1
  252. package/dist/rules/checkPropertyNames.js +0 -88
  253. package/dist/rules/checkPropertyNames.js.map +0 -1
  254. package/dist/rules/checkSyntax.js +0 -25
  255. package/dist/rules/checkSyntax.js.map +0 -1
  256. package/dist/rules/checkTagNames.js +0 -191
  257. package/dist/rules/checkTagNames.js.map +0 -1
  258. package/dist/rules/checkTemplateNames.js +0 -124
  259. package/dist/rules/checkTemplateNames.js.map +0 -1
  260. package/dist/rules/checkTypes.js +0 -299
  261. package/dist/rules/checkTypes.js.map +0 -1
  262. package/dist/rules/checkValues.js +0 -103
  263. package/dist/rules/checkValues.js.map +0 -1
  264. package/dist/rules/convertToJsdocComments.js +0 -231
  265. package/dist/rules/convertToJsdocComments.js.map +0 -1
  266. package/dist/rules/emptyTags.js +0 -67
  267. package/dist/rules/emptyTags.js.map +0 -1
  268. package/dist/rules/implementsOnClasses.js +0 -40
  269. package/dist/rules/implementsOnClasses.js.map +0 -1
  270. package/dist/rules/importsAsDependencies.js +0 -68
  271. package/dist/rules/importsAsDependencies.js.map +0 -1
  272. package/dist/rules/informativeDocs.js +0 -110
  273. package/dist/rules/informativeDocs.js.map +0 -1
  274. package/dist/rules/linesBeforeBlock.js +0 -75
  275. package/dist/rules/linesBeforeBlock.js.map +0 -1
  276. package/dist/rules/matchDescription.js +0 -167
  277. package/dist/rules/matchDescription.js.map +0 -1
  278. package/dist/rules/matchName.js +0 -77
  279. package/dist/rules/matchName.js.map +0 -1
  280. package/dist/rules/multilineBlocks.js +0 -245
  281. package/dist/rules/multilineBlocks.js.map +0 -1
  282. package/dist/rules/noBadBlocks.js +0 -68
  283. package/dist/rules/noBadBlocks.js.map +0 -1
  284. package/dist/rules/noBlankBlockDescriptions.js +0 -41
  285. package/dist/rules/noBlankBlockDescriptions.js.map +0 -1
  286. package/dist/rules/noBlankBlocks.js +0 -30
  287. package/dist/rules/noBlankBlocks.js.map +0 -1
  288. package/dist/rules/noDefaults.js +0 -56
  289. package/dist/rules/noDefaults.js.map +0 -1
  290. package/dist/rules/noMissingSyntax.js +0 -126
  291. package/dist/rules/noMissingSyntax.js.map +0 -1
  292. package/dist/rules/noMultiAsterisks.js +0 -58
  293. package/dist/rules/noMultiAsterisks.js.map +0 -1
  294. package/dist/rules/noRestrictedSyntax.js +0 -49
  295. package/dist/rules/noRestrictedSyntax.js.map +0 -1
  296. package/dist/rules/noTypes.js +0 -65
  297. package/dist/rules/noTypes.js.map +0 -1
  298. package/dist/rules/noUndefinedTypes.js +0 -303
  299. package/dist/rules/noUndefinedTypes.js.map +0 -1
  300. package/dist/rules/requireAsteriskPrefix.js +0 -112
  301. package/dist/rules/requireAsteriskPrefix.js.map +0 -1
  302. package/dist/rules/requireDescription.js +0 -95
  303. package/dist/rules/requireDescription.js.map +0 -1
  304. package/dist/rules/requireDescriptionCompleteSentence.js +0 -220
  305. package/dist/rules/requireDescriptionCompleteSentence.js.map +0 -1
  306. package/dist/rules/requireExample.js +0 -77
  307. package/dist/rules/requireExample.js.map +0 -1
  308. package/dist/rules/requireFileOverview.js +0 -81
  309. package/dist/rules/requireFileOverview.js.map +0 -1
  310. package/dist/rules/requireHyphenBeforeParamDescription.js +0 -89
  311. package/dist/rules/requireHyphenBeforeParamDescription.js.map +0 -1
  312. package/dist/rules/requireJsdoc.js +0 -404
  313. package/dist/rules/requireJsdoc.js.map +0 -1
  314. package/dist/rules/requireParam.js +0 -344
  315. package/dist/rules/requireParam.js.map +0 -1
  316. package/dist/rules/requireParamDescription.js +0 -59
  317. package/dist/rules/requireParamDescription.js.map +0 -1
  318. package/dist/rules/requireParamName.js +0 -36
  319. package/dist/rules/requireParamName.js.map +0 -1
  320. package/dist/rules/requireParamType.js +0 -59
  321. package/dist/rules/requireParamType.js.map +0 -1
  322. package/dist/rules/requireProperty.js +0 -35
  323. package/dist/rules/requireProperty.js.map +0 -1
  324. package/dist/rules/requirePropertyDescription.js +0 -21
  325. package/dist/rules/requirePropertyDescription.js.map +0 -1
  326. package/dist/rules/requirePropertyName.js +0 -21
  327. package/dist/rules/requirePropertyName.js.map +0 -1
  328. package/dist/rules/requirePropertyType.js +0 -21
  329. package/dist/rules/requirePropertyType.js.map +0 -1
  330. package/dist/rules/requireReturns.js +0 -131
  331. package/dist/rules/requireReturns.js.map +0 -1
  332. package/dist/rules/requireReturnsCheck.js +0 -66
  333. package/dist/rules/requireReturnsCheck.js.map +0 -1
  334. package/dist/rules/requireReturnsDescription.js +0 -43
  335. package/dist/rules/requireReturnsDescription.js.map +0 -1
  336. package/dist/rules/requireReturnsType.js +0 -36
  337. package/dist/rules/requireReturnsType.js.map +0 -1
  338. package/dist/rules/requireTemplate.js +0 -122
  339. package/dist/rules/requireTemplate.js.map +0 -1
  340. package/dist/rules/requireThrows.js +0 -67
  341. package/dist/rules/requireThrows.js.map +0 -1
  342. package/dist/rules/requireYields.js +0 -115
  343. package/dist/rules/requireYields.js.map +0 -1
  344. package/dist/rules/requireYieldsCheck.js +0 -105
  345. package/dist/rules/requireYieldsCheck.js.map +0 -1
  346. package/dist/rules/sortTags.js +0 -262
  347. package/dist/rules/sortTags.js.map +0 -1
  348. package/dist/rules/tagLines.js +0 -183
  349. package/dist/rules/tagLines.js.map +0 -1
  350. package/dist/rules/textEscaping.js +0 -102
  351. package/dist/rules/textEscaping.js.map +0 -1
  352. package/dist/rules/validTypes.js +0 -259
  353. package/dist/rules/validTypes.js.map +0 -1
  354. package/dist/tagNames.js +0 -144
  355. package/dist/tagNames.js.map +0 -1
  356. package/dist/utils/hasReturnValue.js +0 -265
  357. package/dist/utils/hasReturnValue.js.map +0 -1
@@ -0,0 +1,572 @@
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
+ };
@@ -1,20 +0,0 @@
1
- //#region src/WarnSettings.js
2
- const WarnSettings = function() {
3
- /** @type {WeakMap<object, Set<string>>} */
4
- const warnedSettings = /* @__PURE__ */ new WeakMap();
5
- return {
6
- hasBeenWarned(context, setting) {
7
- return warnedSettings.has(context) && warnedSettings.get(context).has(setting);
8
- },
9
- markSettingAsWarned(context, setting) {
10
- // c8 ignore else
11
- if (!warnedSettings.has(context)) warnedSettings.set(context, /* @__PURE__ */ new Set());
12
- /** @type {Set<string>} */ warnedSettings.get(context).add(setting);
13
- }
14
- };
15
- };
16
- var WarnSettings_default = WarnSettings;
17
-
18
- //#endregion
19
- export { WarnSettings_default as default };
20
- //# sourceMappingURL=WarnSettings.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"WarnSettings.js","names":[],"sources":["../src/WarnSettings.js"],"sourcesContent":["const WarnSettings = function () {\n /** @type {WeakMap<object, Set<string>>} */\n const warnedSettings = new WeakMap();\n\n return {\n /**\n * Warn only once for each context and setting\n * @param {{}} context\n * @param {string} setting\n * @returns {boolean}\n */\n hasBeenWarned (context, setting) {\n return warnedSettings.has(context) && /** @type {Set<string>} */ (\n warnedSettings.get(context)\n ).has(setting);\n },\n\n /**\n * @param {{}} context\n * @param {string} setting\n * @returns {void}\n */\n markSettingAsWarned (context, setting) {\n // c8 ignore else\n if (!warnedSettings.has(context)) {\n warnedSettings.set(context, new Set());\n }\n\n /** @type {Set<string>} */ (warnedSettings.get(context)).add(setting);\n },\n };\n};\n\nexport default WarnSettings;\n"],"mappings":";AAAA,MAAM,eAAe,WAAY;;CAE/B,MAAM,iCAAiB,IAAI;AAE3B,QAAO;EAOL,cAAe,SAAS,SAAS;AAC/B,UAAO,eAAe,IAAI,QAAQ,IAChC,eAAe,IAAI,QAAQ,CAC3B,IAAI,QAAQ;EACf;EAOD,oBAAqB,SAAS,SAAS;;AAErC,OAAI,CAAC,eAAe,IAAI,QAAQ,EAC9B,eAAe,IAAI,yBAAS,IAAI,MAAM;8BAGZ,eAAe,IAAI,QAAQ,CAAE,IAAI,QAAQ;EACtE;CACF;AACF;AAED,2BAAe"}
@@ -1,32 +0,0 @@
1
- //#region rolldown:runtime
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all) __defProp(target, name, {
10
- get: all[name],
11
- enumerable: true
12
- });
13
- };
14
- var __copyProps = (to, from, except, desc) => {
15
- if (from && typeof from === "object" || typeof from === "function") for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
16
- key = keys[i];
17
- if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
18
- get: ((k) => from[k]).bind(null, key),
19
- enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
20
- });
21
- }
22
- return to;
23
- };
24
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
25
- value: mod,
26
- enumerable: true
27
- }) : target, mod));
28
-
29
- //#endregion
30
-
31
- exports.__export = __export;
32
- exports.__toESM = __toESM;
@@ -1,11 +0,0 @@
1
- //#region rolldown:runtime
2
- var __defProp = Object.defineProperty;
3
- var __export = (target, all) => {
4
- for (var name in all) __defProp(target, name, {
5
- get: all[name],
6
- enumerable: true
7
- });
8
- };
9
-
10
- //#endregion
11
- export { __export };