eslint-plugin-tsdoc-require-2 1.0.6 → 1.0.8

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 (346) hide show
  1. package/README.md +111 -36
  2. package/dist/internal/require-tag-factory.cjs +58 -9
  3. package/dist/internal/require-tag-factory.d.ts +5 -2
  4. package/dist/internal/require-tag-factory.d.ts.map +1 -1
  5. package/dist/internal/require-tag-factory.js +58 -9
  6. package/dist/internal/require-tag-factory.js.map +1 -1
  7. package/dist/plugin.cjs +146 -17
  8. package/dist/plugin.d.ts +2 -0
  9. package/dist/plugin.d.ts.map +1 -1
  10. package/dist/plugin.js +142 -16
  11. package/dist/plugin.js.map +1 -1
  12. package/dist/rules/require-tag-rules.cjs +121 -25
  13. package/dist/rules/require-tag-rules.d.ts +5 -30
  14. package/dist/rules/require-tag-rules.d.ts.map +1 -1
  15. package/dist/rules/require-tag-rules.js +93 -0
  16. package/dist/rules/require-tag-rules.js.map +1 -1
  17. package/dist/rules/require.cjs +59 -16
  18. package/dist/rules/require.d.ts +3 -1
  19. package/dist/rules/require.d.ts.map +1 -1
  20. package/dist/rules/require.js +59 -16
  21. package/dist/rules/require.js.map +1 -1
  22. package/dist/rules/required-tags/require-abstract.cjs +32 -0
  23. package/dist/rules/required-tags/require-abstract.d.ts +5 -0
  24. package/dist/rules/required-tags/require-abstract.d.ts.map +1 -0
  25. package/dist/rules/required-tags/require-abstract.js +30 -0
  26. package/dist/rules/required-tags/require-abstract.js.map +1 -0
  27. package/dist/rules/required-tags/require-alpha.cjs +0 -1
  28. package/dist/rules/required-tags/require-alpha.d.ts.map +1 -1
  29. package/dist/rules/required-tags/require-alpha.js +1 -2
  30. package/dist/rules/required-tags/require-alpha.js.map +1 -1
  31. package/dist/rules/required-tags/require-author.cjs +32 -0
  32. package/dist/rules/required-tags/require-author.d.ts +5 -0
  33. package/dist/rules/required-tags/require-author.d.ts.map +1 -0
  34. package/dist/rules/required-tags/require-author.js +30 -0
  35. package/dist/rules/required-tags/require-author.js.map +1 -0
  36. package/dist/rules/required-tags/require-beta.cjs +0 -1
  37. package/dist/rules/required-tags/require-beta.d.ts.map +1 -1
  38. package/dist/rules/required-tags/require-beta.js +1 -2
  39. package/dist/rules/required-tags/require-beta.js.map +1 -1
  40. package/dist/rules/required-tags/require-category.cjs +32 -0
  41. package/dist/rules/required-tags/require-category.d.ts +5 -0
  42. package/dist/rules/required-tags/require-category.d.ts.map +1 -0
  43. package/dist/rules/required-tags/require-category.js +30 -0
  44. package/dist/rules/required-tags/require-category.js.map +1 -0
  45. package/dist/rules/required-tags/require-class.cjs +32 -0
  46. package/dist/rules/required-tags/require-class.d.ts +5 -0
  47. package/dist/rules/required-tags/require-class.d.ts.map +1 -0
  48. package/dist/rules/required-tags/require-class.js +30 -0
  49. package/dist/rules/required-tags/require-class.js.map +1 -0
  50. package/dist/rules/required-tags/require-decorator.cjs +0 -1
  51. package/dist/rules/required-tags/require-decorator.d.ts.map +1 -1
  52. package/dist/rules/required-tags/require-decorator.js +1 -2
  53. package/dist/rules/required-tags/require-decorator.js.map +1 -1
  54. package/dist/rules/required-tags/require-default-value.cjs +0 -1
  55. package/dist/rules/required-tags/require-default-value.d.ts.map +1 -1
  56. package/dist/rules/required-tags/require-default-value.js +1 -2
  57. package/dist/rules/required-tags/require-default-value.js.map +1 -1
  58. package/dist/rules/required-tags/require-deprecated.cjs +0 -1
  59. package/dist/rules/required-tags/require-deprecated.d.ts.map +1 -1
  60. package/dist/rules/required-tags/require-deprecated.js +1 -2
  61. package/dist/rules/required-tags/require-deprecated.js.map +1 -1
  62. package/dist/rules/required-tags/require-document.cjs +32 -0
  63. package/dist/rules/required-tags/require-document.d.ts +5 -0
  64. package/dist/rules/required-tags/require-document.d.ts.map +1 -0
  65. package/dist/rules/required-tags/require-document.js +30 -0
  66. package/dist/rules/required-tags/require-document.js.map +1 -0
  67. package/dist/rules/required-tags/require-enum.cjs +32 -0
  68. package/dist/rules/required-tags/require-enum.d.ts +5 -0
  69. package/dist/rules/required-tags/require-enum.d.ts.map +1 -0
  70. package/dist/rules/required-tags/require-enum.js +30 -0
  71. package/dist/rules/required-tags/require-enum.js.map +1 -0
  72. package/dist/rules/required-tags/require-event-property.cjs +0 -1
  73. package/dist/rules/required-tags/require-event-property.d.ts.map +1 -1
  74. package/dist/rules/required-tags/require-event-property.js +1 -2
  75. package/dist/rules/required-tags/require-event-property.js.map +1 -1
  76. package/dist/rules/required-tags/require-event.cjs +32 -0
  77. package/dist/rules/required-tags/require-event.d.ts +5 -0
  78. package/dist/rules/required-tags/require-event.d.ts.map +1 -0
  79. package/dist/rules/required-tags/require-event.js +30 -0
  80. package/dist/rules/required-tags/require-event.js.map +1 -0
  81. package/dist/rules/required-tags/require-example.cjs +0 -1
  82. package/dist/rules/required-tags/require-example.d.ts.map +1 -1
  83. package/dist/rules/required-tags/require-example.js +1 -2
  84. package/dist/rules/required-tags/require-example.js.map +1 -1
  85. package/dist/rules/required-tags/require-expand.cjs +32 -0
  86. package/dist/rules/required-tags/require-expand.d.ts +5 -0
  87. package/dist/rules/required-tags/require-expand.d.ts.map +1 -0
  88. package/dist/rules/required-tags/require-expand.js +30 -0
  89. package/dist/rules/required-tags/require-expand.js.map +1 -0
  90. package/dist/rules/required-tags/require-experimental.cjs +0 -1
  91. package/dist/rules/required-tags/require-experimental.d.ts.map +1 -1
  92. package/dist/rules/required-tags/require-experimental.js +1 -2
  93. package/dist/rules/required-tags/require-experimental.js.map +1 -1
  94. package/dist/rules/required-tags/require-function.cjs +32 -0
  95. package/dist/rules/required-tags/require-function.d.ts +5 -0
  96. package/dist/rules/required-tags/require-function.d.ts.map +1 -0
  97. package/dist/rules/required-tags/require-function.js +30 -0
  98. package/dist/rules/required-tags/require-function.js.map +1 -0
  99. package/dist/rules/required-tags/require-group.cjs +32 -0
  100. package/dist/rules/required-tags/require-group.d.ts +5 -0
  101. package/dist/rules/required-tags/require-group.d.ts.map +1 -0
  102. package/dist/rules/required-tags/require-group.js +30 -0
  103. package/dist/rules/required-tags/require-group.js.map +1 -0
  104. package/dist/rules/required-tags/require-hidden.cjs +32 -0
  105. package/dist/rules/required-tags/require-hidden.d.ts +5 -0
  106. package/dist/rules/required-tags/require-hidden.d.ts.map +1 -0
  107. package/dist/rules/required-tags/require-hidden.js +30 -0
  108. package/dist/rules/required-tags/require-hidden.js.map +1 -0
  109. package/dist/rules/required-tags/require-hideconstructor.cjs +32 -0
  110. package/dist/rules/required-tags/require-hideconstructor.d.ts +5 -0
  111. package/dist/rules/required-tags/require-hideconstructor.d.ts.map +1 -0
  112. package/dist/rules/required-tags/require-hideconstructor.js +30 -0
  113. package/dist/rules/required-tags/require-hideconstructor.js.map +1 -0
  114. package/dist/rules/required-tags/require-ignore.cjs +32 -0
  115. package/dist/rules/required-tags/require-ignore.d.ts +5 -0
  116. package/dist/rules/required-tags/require-ignore.d.ts.map +1 -0
  117. package/dist/rules/required-tags/require-ignore.js +30 -0
  118. package/dist/rules/required-tags/require-ignore.js.map +1 -0
  119. package/dist/rules/required-tags/require-import.cjs +32 -0
  120. package/dist/rules/required-tags/require-import.d.ts +5 -0
  121. package/dist/rules/required-tags/require-import.d.ts.map +1 -0
  122. package/dist/rules/required-tags/require-import.js +30 -0
  123. package/dist/rules/required-tags/require-import.js.map +1 -0
  124. package/dist/rules/required-tags/require-include.cjs +32 -0
  125. package/dist/rules/required-tags/require-include.d.ts +5 -0
  126. package/dist/rules/required-tags/require-include.d.ts.map +1 -0
  127. package/dist/rules/required-tags/require-include.js +30 -0
  128. package/dist/rules/required-tags/require-include.js.map +1 -0
  129. package/dist/rules/required-tags/require-inherit-doc.cjs +0 -1
  130. package/dist/rules/required-tags/require-inherit-doc.d.ts.map +1 -1
  131. package/dist/rules/required-tags/require-inherit-doc.js +1 -2
  132. package/dist/rules/required-tags/require-inherit-doc.js.map +1 -1
  133. package/dist/rules/required-tags/require-inline.cjs +32 -0
  134. package/dist/rules/required-tags/require-inline.d.ts +5 -0
  135. package/dist/rules/required-tags/require-inline.d.ts.map +1 -0
  136. package/dist/rules/required-tags/require-inline.js +30 -0
  137. package/dist/rules/required-tags/require-inline.js.map +1 -0
  138. package/dist/rules/required-tags/require-interface.cjs +32 -0
  139. package/dist/rules/required-tags/require-interface.d.ts +5 -0
  140. package/dist/rules/required-tags/require-interface.d.ts.map +1 -0
  141. package/dist/rules/required-tags/require-interface.js +30 -0
  142. package/dist/rules/required-tags/require-interface.js.map +1 -0
  143. package/dist/rules/required-tags/require-internal.cjs +0 -1
  144. package/dist/rules/required-tags/require-internal.d.ts.map +1 -1
  145. package/dist/rules/required-tags/require-internal.js +1 -2
  146. package/dist/rules/required-tags/require-internal.js.map +1 -1
  147. package/dist/rules/required-tags/require-label.cjs +0 -1
  148. package/dist/rules/required-tags/require-label.d.ts.map +1 -1
  149. package/dist/rules/required-tags/require-label.js +1 -2
  150. package/dist/rules/required-tags/require-label.js.map +1 -1
  151. package/dist/rules/required-tags/require-license.cjs +32 -0
  152. package/dist/rules/required-tags/require-license.d.ts +5 -0
  153. package/dist/rules/required-tags/require-license.d.ts.map +1 -0
  154. package/dist/rules/required-tags/require-license.js +30 -0
  155. package/dist/rules/required-tags/require-license.js.map +1 -0
  156. package/dist/rules/required-tags/require-link.cjs +0 -1
  157. package/dist/rules/required-tags/require-link.d.ts.map +1 -1
  158. package/dist/rules/required-tags/require-link.js +1 -2
  159. package/dist/rules/required-tags/require-link.js.map +1 -1
  160. package/dist/rules/required-tags/require-merge-module-with.cjs +32 -0
  161. package/dist/rules/required-tags/require-merge-module-with.d.ts +5 -0
  162. package/dist/rules/required-tags/require-merge-module-with.d.ts.map +1 -0
  163. package/dist/rules/required-tags/require-merge-module-with.js +30 -0
  164. package/dist/rules/required-tags/require-merge-module-with.js.map +1 -0
  165. package/dist/rules/required-tags/require-module.cjs +32 -0
  166. package/dist/rules/required-tags/require-module.d.ts +5 -0
  167. package/dist/rules/required-tags/require-module.d.ts.map +1 -0
  168. package/dist/rules/required-tags/require-module.js +30 -0
  169. package/dist/rules/required-tags/require-module.js.map +1 -0
  170. package/dist/rules/required-tags/require-namespace.cjs +32 -0
  171. package/dist/rules/required-tags/require-namespace.d.ts +5 -0
  172. package/dist/rules/required-tags/require-namespace.d.ts.map +1 -0
  173. package/dist/rules/required-tags/require-namespace.js +30 -0
  174. package/dist/rules/required-tags/require-namespace.js.map +1 -0
  175. package/dist/rules/required-tags/require-overload.cjs +32 -0
  176. package/dist/rules/required-tags/require-overload.d.ts +5 -0
  177. package/dist/rules/required-tags/require-overload.d.ts.map +1 -0
  178. package/dist/rules/required-tags/require-overload.js +30 -0
  179. package/dist/rules/required-tags/require-overload.js.map +1 -0
  180. package/dist/rules/required-tags/require-override.cjs +0 -1
  181. package/dist/rules/required-tags/require-override.d.ts.map +1 -1
  182. package/dist/rules/required-tags/require-override.js +1 -2
  183. package/dist/rules/required-tags/require-override.js.map +1 -1
  184. package/dist/rules/required-tags/require-package-documentation.cjs +0 -1
  185. package/dist/rules/required-tags/require-package-documentation.d.ts.map +1 -1
  186. package/dist/rules/required-tags/require-package-documentation.js +1 -2
  187. package/dist/rules/required-tags/require-package-documentation.js.map +1 -1
  188. package/dist/rules/required-tags/require-param.cjs +0 -1
  189. package/dist/rules/required-tags/require-param.d.ts.map +1 -1
  190. package/dist/rules/required-tags/require-param.js +1 -2
  191. package/dist/rules/required-tags/require-param.js.map +1 -1
  192. package/dist/rules/required-tags/require-primary-export.cjs +32 -0
  193. package/dist/rules/required-tags/require-primary-export.d.ts +5 -0
  194. package/dist/rules/required-tags/require-primary-export.d.ts.map +1 -0
  195. package/dist/rules/required-tags/require-primary-export.js +30 -0
  196. package/dist/rules/required-tags/require-primary-export.js.map +1 -0
  197. package/dist/rules/required-tags/require-private-remarks.cjs +0 -1
  198. package/dist/rules/required-tags/require-private-remarks.d.ts.map +1 -1
  199. package/dist/rules/required-tags/require-private-remarks.js +1 -2
  200. package/dist/rules/required-tags/require-private-remarks.js.map +1 -1
  201. package/dist/rules/required-tags/require-private.cjs +32 -0
  202. package/dist/rules/required-tags/require-private.d.ts +5 -0
  203. package/dist/rules/required-tags/require-private.d.ts.map +1 -0
  204. package/dist/rules/required-tags/require-private.js +30 -0
  205. package/dist/rules/required-tags/require-private.js.map +1 -0
  206. package/dist/rules/required-tags/require-property.cjs +32 -0
  207. package/dist/rules/required-tags/require-property.d.ts +5 -0
  208. package/dist/rules/required-tags/require-property.d.ts.map +1 -0
  209. package/dist/rules/required-tags/require-property.js +30 -0
  210. package/dist/rules/required-tags/require-property.js.map +1 -0
  211. package/dist/rules/required-tags/require-protected.cjs +32 -0
  212. package/dist/rules/required-tags/require-protected.d.ts +5 -0
  213. package/dist/rules/required-tags/require-protected.d.ts.map +1 -0
  214. package/dist/rules/required-tags/require-protected.js +30 -0
  215. package/dist/rules/required-tags/require-protected.js.map +1 -0
  216. package/dist/rules/required-tags/require-public.cjs +0 -1
  217. package/dist/rules/required-tags/require-public.d.ts.map +1 -1
  218. package/dist/rules/required-tags/require-public.js +1 -2
  219. package/dist/rules/required-tags/require-public.js.map +1 -1
  220. package/dist/rules/required-tags/require-readonly.cjs +0 -1
  221. package/dist/rules/required-tags/require-readonly.d.ts.map +1 -1
  222. package/dist/rules/required-tags/require-readonly.js +1 -2
  223. package/dist/rules/required-tags/require-readonly.js.map +1 -1
  224. package/dist/rules/required-tags/require-remarks.cjs +0 -1
  225. package/dist/rules/required-tags/require-remarks.d.ts.map +1 -1
  226. package/dist/rules/required-tags/require-remarks.js +1 -2
  227. package/dist/rules/required-tags/require-remarks.js.map +1 -1
  228. package/dist/rules/required-tags/require-returns.cjs +0 -1
  229. package/dist/rules/required-tags/require-returns.d.ts.map +1 -1
  230. package/dist/rules/required-tags/require-returns.js +1 -2
  231. package/dist/rules/required-tags/require-returns.js.map +1 -1
  232. package/dist/rules/required-tags/require-sealed.cjs +0 -1
  233. package/dist/rules/required-tags/require-sealed.d.ts.map +1 -1
  234. package/dist/rules/required-tags/require-sealed.js +1 -2
  235. package/dist/rules/required-tags/require-sealed.js.map +1 -1
  236. package/dist/rules/required-tags/require-see.cjs +0 -1
  237. package/dist/rules/required-tags/require-see.d.ts.map +1 -1
  238. package/dist/rules/required-tags/require-see.js +1 -2
  239. package/dist/rules/required-tags/require-see.js.map +1 -1
  240. package/dist/rules/required-tags/require-since.cjs +32 -0
  241. package/dist/rules/required-tags/require-since.d.ts +5 -0
  242. package/dist/rules/required-tags/require-since.d.ts.map +1 -0
  243. package/dist/rules/required-tags/require-since.js +30 -0
  244. package/dist/rules/required-tags/require-since.js.map +1 -0
  245. package/dist/rules/required-tags/require-sort-strategy.cjs +32 -0
  246. package/dist/rules/required-tags/require-sort-strategy.d.ts +5 -0
  247. package/dist/rules/required-tags/require-sort-strategy.d.ts.map +1 -0
  248. package/dist/rules/required-tags/require-sort-strategy.js +30 -0
  249. package/dist/rules/required-tags/require-sort-strategy.js.map +1 -0
  250. package/dist/rules/required-tags/require-summary.cjs +32 -0
  251. package/dist/rules/required-tags/require-summary.d.ts +5 -0
  252. package/dist/rules/required-tags/require-summary.d.ts.map +1 -0
  253. package/dist/rules/required-tags/require-summary.js +30 -0
  254. package/dist/rules/required-tags/require-summary.js.map +1 -0
  255. package/dist/rules/required-tags/require-template.cjs +32 -0
  256. package/dist/rules/required-tags/require-template.d.ts +5 -0
  257. package/dist/rules/required-tags/require-template.d.ts.map +1 -0
  258. package/dist/rules/required-tags/require-template.js +30 -0
  259. package/dist/rules/required-tags/require-template.js.map +1 -0
  260. package/dist/rules/required-tags/require-throws.cjs +0 -1
  261. package/dist/rules/required-tags/require-throws.d.ts.map +1 -1
  262. package/dist/rules/required-tags/require-throws.js +1 -2
  263. package/dist/rules/required-tags/require-throws.js.map +1 -1
  264. package/dist/rules/required-tags/require-type-param.cjs +0 -1
  265. package/dist/rules/required-tags/require-type-param.d.ts.map +1 -1
  266. package/dist/rules/required-tags/require-type-param.js +1 -2
  267. package/dist/rules/required-tags/require-type-param.js.map +1 -1
  268. package/dist/rules/required-tags/require-use-declared-type.cjs +32 -0
  269. package/dist/rules/required-tags/require-use-declared-type.d.ts +5 -0
  270. package/dist/rules/required-tags/require-use-declared-type.d.ts.map +1 -0
  271. package/dist/rules/required-tags/require-use-declared-type.js +30 -0
  272. package/dist/rules/required-tags/require-use-declared-type.js.map +1 -0
  273. package/dist/rules/required-tags/require-virtual.cjs +0 -1
  274. package/dist/rules/required-tags/require-virtual.d.ts.map +1 -1
  275. package/dist/rules/required-tags/require-virtual.js +1 -2
  276. package/dist/rules/required-tags/require-virtual.js.map +1 -1
  277. package/dist/rules/restrict-tags.cjs +416 -0
  278. package/dist/rules/restrict-tags.d.ts +17 -0
  279. package/dist/rules/restrict-tags.d.ts.map +1 -0
  280. package/dist/rules/restrict-tags.js +414 -0
  281. package/dist/rules/restrict-tags.js.map +1 -0
  282. package/docs/rules/getting-started.md +97 -0
  283. package/docs/rules/index.md +61 -0
  284. package/docs/rules/presets/all.md +100 -0
  285. package/docs/rules/presets/detailed.md +41 -0
  286. package/docs/rules/presets/index.md +156 -0
  287. package/docs/rules/presets/jsdoc.md +43 -0
  288. package/docs/rules/presets/packages.md +41 -0
  289. package/docs/rules/presets/recommended.md +37 -0
  290. package/docs/rules/presets/tsdoc.md +45 -0
  291. package/docs/rules/presets/typedoc-strict.md +50 -0
  292. package/docs/rules/presets/typedoc.md +44 -0
  293. package/docs/rules/require.md +92 -56
  294. package/docs/rules/required-tags/require-abstract.md +87 -0
  295. package/docs/rules/required-tags/require-alpha.md +1 -1
  296. package/docs/rules/required-tags/require-author.md +87 -0
  297. package/docs/rules/required-tags/require-beta.md +1 -1
  298. package/docs/rules/required-tags/require-category.md +87 -0
  299. package/docs/rules/required-tags/require-class.md +71 -0
  300. package/docs/rules/required-tags/require-decorator.md +1 -1
  301. package/docs/rules/required-tags/require-default-value.md +1 -1
  302. package/docs/rules/required-tags/require-deprecated.md +1 -1
  303. package/docs/rules/required-tags/require-document.md +87 -0
  304. package/docs/rules/required-tags/require-enum.md +73 -0
  305. package/docs/rules/required-tags/require-event-property.md +1 -1
  306. package/docs/rules/required-tags/require-event.md +87 -0
  307. package/docs/rules/required-tags/require-example.md +1 -1
  308. package/docs/rules/required-tags/require-expand.md +87 -0
  309. package/docs/rules/required-tags/require-experimental.md +1 -1
  310. package/docs/rules/required-tags/require-function.md +74 -0
  311. package/docs/rules/required-tags/require-group.md +87 -0
  312. package/docs/rules/required-tags/require-hidden.md +87 -0
  313. package/docs/rules/required-tags/require-hideconstructor.md +87 -0
  314. package/docs/rules/required-tags/require-ignore.md +87 -0
  315. package/docs/rules/required-tags/require-import.md +87 -0
  316. package/docs/rules/required-tags/require-include.md +87 -0
  317. package/docs/rules/required-tags/require-inherit-doc.md +1 -1
  318. package/docs/rules/required-tags/require-inline.md +87 -0
  319. package/docs/rules/required-tags/require-interface.md +74 -0
  320. package/docs/rules/required-tags/require-internal.md +1 -1
  321. package/docs/rules/required-tags/require-label.md +1 -1
  322. package/docs/rules/required-tags/require-license.md +87 -0
  323. package/docs/rules/required-tags/require-link.md +1 -1
  324. package/docs/rules/required-tags/require-merge-module-with.md +87 -0
  325. package/docs/rules/required-tags/require-module.md +78 -0
  326. package/docs/rules/required-tags/require-namespace.md +87 -0
  327. package/docs/rules/required-tags/require-overload.md +87 -0
  328. package/docs/rules/required-tags/require-override.md +1 -1
  329. package/docs/rules/required-tags/require-package-documentation.md +44 -24
  330. package/docs/rules/required-tags/require-param.md +45 -25
  331. package/docs/rules/required-tags/require-primary-export.md +87 -0
  332. package/docs/rules/required-tags/require-private.md +87 -0
  333. package/docs/rules/required-tags/require-property.md +87 -0
  334. package/docs/rules/required-tags/require-protected.md +87 -0
  335. package/docs/rules/required-tags/require-remarks.md +40 -25
  336. package/docs/rules/required-tags/require-returns.md +45 -25
  337. package/docs/rules/required-tags/require-since.md +87 -0
  338. package/docs/rules/required-tags/require-sort-strategy.md +87 -0
  339. package/docs/rules/required-tags/require-summary.md +87 -0
  340. package/docs/rules/required-tags/require-template.md +87 -0
  341. package/docs/rules/required-tags/require-throws.md +53 -25
  342. package/docs/rules/required-tags/require-type-param.md +45 -25
  343. package/docs/rules/required-tags/require-use-declared-type.md +87 -0
  344. package/docs/rules/required-tags.md +171 -39
  345. package/docs/rules/restrict-tags.md +203 -0
  346. package/package.json +394 -45
@@ -0,0 +1,414 @@
1
+ import { AST_NODE_TYPES, AST_TOKEN_TYPES, ESLintUtils, } from "@typescript-eslint/utils";
2
+ const enforceableEntityKinds = [
3
+ "class",
4
+ "enum",
5
+ "function",
6
+ "interface",
7
+ "namespace",
8
+ "object",
9
+ "type",
10
+ "variable",
11
+ ];
12
+ const defaultRestrictedTags = [
13
+ "@augments",
14
+ "@callback",
15
+ "@extends",
16
+ "@jsx",
17
+ "@satisfies",
18
+ "@type",
19
+ "@typedef",
20
+ "@yields",
21
+ ];
22
+ const defaultEnforceFor = [...enforceableEntityKinds];
23
+ const optionSchema = {
24
+ additionalProperties: false,
25
+ properties: {
26
+ enforceFor: {
27
+ items: {
28
+ enum: [...enforceableEntityKinds],
29
+ type: "string",
30
+ },
31
+ type: "array",
32
+ uniqueItems: true,
33
+ },
34
+ exportMode: {
35
+ description: "Choose whether to check exported declarations, non-exported top-level declarations, or both.",
36
+ enum: [
37
+ "all",
38
+ "exported",
39
+ "non-exported",
40
+ ],
41
+ type: "string",
42
+ },
43
+ includeNonExported: {
44
+ default: false,
45
+ description: 'Legacy alias for exportMode: "all". Also enforce on non-exported declarations when true.',
46
+ type: "boolean",
47
+ },
48
+ mode: {
49
+ default: "deny",
50
+ description: "Tag restriction mode. deny = listed tags are disallowed. allow = only listed tags are permitted.",
51
+ enum: ["allow", "deny"],
52
+ type: "string",
53
+ },
54
+ tags: {
55
+ description: "Tag names used by the selected restriction mode.",
56
+ items: {
57
+ pattern: "^@[A-Za-z][A-Za-z0-9-]*$",
58
+ type: "string",
59
+ },
60
+ type: "array",
61
+ uniqueItems: true,
62
+ },
63
+ },
64
+ type: "object",
65
+ };
66
+ const resolveExportMode = (ruleOption) => {
67
+ if (ruleOption?.includeNonExported === true) {
68
+ return "all";
69
+ }
70
+ return ruleOption?.exportMode ?? "exported";
71
+ };
72
+ const shouldCheckExportedDeclarations = (exportMode) => exportMode === "all" || exportMode === "exported";
73
+ const shouldCheckNonExportedDeclarations = (exportMode) => exportMode === "all" || exportMode === "non-exported";
74
+ const assertUnreachable = (value) => {
75
+ throw new Error(`Unexpected node type: ${String(value)}`);
76
+ };
77
+ const createRule = ESLintUtils.RuleCreator((ruleName) => `https://github.com/Nick2bad4u/eslint-plugin-tsdoc-require-2/blob/main/docs/rules/${ruleName}.md`);
78
+ const isSupportedDeclaration = (node) => node.type === AST_NODE_TYPES.ClassDeclaration ||
79
+ node.type === AST_NODE_TYPES.FunctionDeclaration ||
80
+ node.type === AST_NODE_TYPES.TSDeclareFunction ||
81
+ node.type === AST_NODE_TYPES.TSEnumDeclaration ||
82
+ node.type === AST_NODE_TYPES.TSInterfaceDeclaration ||
83
+ node.type === AST_NODE_TYPES.TSModuleDeclaration ||
84
+ node.type === AST_NODE_TYPES.TSTypeAliasDeclaration ||
85
+ node.type === AST_NODE_TYPES.VariableDeclaration;
86
+ const isSupportedDefaultExportExpression = (node) => node.type === AST_NODE_TYPES.ArrowFunctionExpression ||
87
+ node.type === AST_NODE_TYPES.ClassExpression ||
88
+ node.type === AST_NODE_TYPES.FunctionExpression ||
89
+ node.type === AST_NODE_TYPES.ObjectExpression;
90
+ const getExpressionKind = (node) => {
91
+ if (node.type === AST_NODE_TYPES.ArrowFunctionExpression ||
92
+ node.type === AST_NODE_TYPES.FunctionExpression) {
93
+ return "function";
94
+ }
95
+ if (node.type === AST_NODE_TYPES.ClassExpression) {
96
+ return "class";
97
+ }
98
+ if (node.type === AST_NODE_TYPES.ObjectExpression) {
99
+ return "object";
100
+ }
101
+ return assertUnreachable(node);
102
+ };
103
+ const getEntityDisplayName = (name) => name ?? "<default export>";
104
+ const isTopLevelNode = (node) => node.parent?.type === AST_NODE_TYPES.Program;
105
+ const getModuleDeclarationName = (declaration) => {
106
+ if (declaration.id.type === AST_NODE_TYPES.Identifier) {
107
+ return declaration.id.name;
108
+ }
109
+ if (declaration.id.type === AST_NODE_TYPES.Literal &&
110
+ typeof declaration.id.value === "string") {
111
+ return declaration.id.value;
112
+ }
113
+ return undefined;
114
+ };
115
+ const getTSDocCommentNode = (sourceCode, node) => {
116
+ const comments = sourceCode.getCommentsBefore(node);
117
+ const nearestComment = comments.at(-1);
118
+ if (nearestComment === undefined) {
119
+ return null;
120
+ }
121
+ if (nearestComment.type !== AST_TOKEN_TYPES.Block) {
122
+ return null;
123
+ }
124
+ if (!nearestComment.value.startsWith("*")) {
125
+ return null;
126
+ }
127
+ const nearestCommentLoc = nearestComment.loc;
128
+ const nodeLoc = node.loc;
129
+ if (nearestCommentLoc === null || nodeLoc === null) {
130
+ return null;
131
+ }
132
+ const lineGap = nodeLoc.start.line - nearestCommentLoc.end.line;
133
+ if (lineGap < 0 || lineGap > 1) {
134
+ return null;
135
+ }
136
+ return nearestComment;
137
+ };
138
+ const createTargetKey = (target) => {
139
+ const [start, end] = target.reportNode.range;
140
+ return `${start}:${end}:${target.kind}:${target.name ?? ""}`;
141
+ };
142
+ const declarationTargets = (declaration) => {
143
+ if (declaration.type === AST_NODE_TYPES.ClassDeclaration) {
144
+ return [
145
+ {
146
+ commentNode: declaration,
147
+ kind: "class",
148
+ name: declaration.id?.name,
149
+ reportNode: declaration,
150
+ },
151
+ ];
152
+ }
153
+ if (declaration.type === AST_NODE_TYPES.FunctionDeclaration ||
154
+ declaration.type === AST_NODE_TYPES.TSDeclareFunction) {
155
+ return [
156
+ {
157
+ commentNode: declaration,
158
+ kind: "function",
159
+ name: declaration.id?.name,
160
+ reportNode: declaration,
161
+ },
162
+ ];
163
+ }
164
+ if (declaration.type === AST_NODE_TYPES.TSEnumDeclaration) {
165
+ return [
166
+ {
167
+ commentNode: declaration,
168
+ kind: "enum",
169
+ name: declaration.id.name,
170
+ reportNode: declaration,
171
+ },
172
+ ];
173
+ }
174
+ if (declaration.type === AST_NODE_TYPES.TSInterfaceDeclaration) {
175
+ return [
176
+ {
177
+ commentNode: declaration,
178
+ kind: "interface",
179
+ name: declaration.id.name,
180
+ reportNode: declaration,
181
+ },
182
+ ];
183
+ }
184
+ if (declaration.type === AST_NODE_TYPES.TSModuleDeclaration) {
185
+ return [
186
+ {
187
+ commentNode: declaration,
188
+ kind: "namespace",
189
+ name: getModuleDeclarationName(declaration),
190
+ reportNode: declaration,
191
+ },
192
+ ];
193
+ }
194
+ if (declaration.type === AST_NODE_TYPES.TSTypeAliasDeclaration) {
195
+ return [
196
+ {
197
+ commentNode: declaration,
198
+ kind: "type",
199
+ name: declaration.id.name,
200
+ reportNode: declaration,
201
+ },
202
+ ];
203
+ }
204
+ if (declaration.type === AST_NODE_TYPES.VariableDeclaration) {
205
+ return declaration.declarations.flatMap((declarator) => {
206
+ if (declarator.id.type !== AST_NODE_TYPES.Identifier) {
207
+ return [];
208
+ }
209
+ return [
210
+ {
211
+ commentNode: declaration,
212
+ kind: "variable",
213
+ name: declarator.id.name,
214
+ reportNode: declarator,
215
+ },
216
+ ];
217
+ });
218
+ }
219
+ return assertUnreachable(declaration);
220
+ };
221
+ const declarationTargetsWithCommentNode = (declaration, commentNode) => declarationTargets(declaration).map((target) => ({
222
+ ...target,
223
+ commentNode,
224
+ }));
225
+ const extractTagNames = (commentText) => {
226
+ const tagPattern = /(?:^|\W)@(?<tagName>[A-Za-z][-0-9A-Za-z]*)/gu;
227
+ const extractedTagNames = new Set();
228
+ for (const match of commentText.matchAll(tagPattern)) {
229
+ const rawTagName = match.groups?.["tagName"];
230
+ if (rawTagName === undefined) {
231
+ continue;
232
+ }
233
+ extractedTagNames.add(`@${rawTagName}`);
234
+ }
235
+ return extractedTagNames;
236
+ };
237
+ const getConfiguredTagSet = (ruleOption) => {
238
+ const configuredTags = ruleOption?.tags ?? defaultRestrictedTags;
239
+ return new Set(configuredTags);
240
+ };
241
+ /** ESLint rule module implementing tsdoc-require-2/restrict-tags. */
242
+ const restrictTagsRule = createRule({
243
+ create(context) {
244
+ const declarationsByName = new Map();
245
+ const checkedTargets = new Set();
246
+ const sourceCode = context.sourceCode;
247
+ const ruleOption = context.options.at(0);
248
+ const enabledKinds = new Set(ruleOption?.enforceFor ?? defaultEnforceFor);
249
+ const exportMode = resolveExportMode(ruleOption);
250
+ const restrictMode = ruleOption?.mode ?? "deny";
251
+ const configuredTagSet = getConfiguredTagSet(ruleOption);
252
+ const allowedTags = [...configuredTagSet];
253
+ const checkTarget = (target) => {
254
+ if (!enabledKinds.has(target.kind)) {
255
+ return;
256
+ }
257
+ const targetKey = createTargetKey(target);
258
+ if (checkedTargets.has(targetKey)) {
259
+ return;
260
+ }
261
+ checkedTargets.add(targetKey);
262
+ const commentNode = getTSDocCommentNode(sourceCode, target.commentNode);
263
+ if (commentNode === null) {
264
+ return;
265
+ }
266
+ if (configuredTagSet.size === 0) {
267
+ return;
268
+ }
269
+ const foundTags = extractTagNames(commentNode.value);
270
+ for (const tagName of foundTags) {
271
+ const isConfiguredTag = configuredTagSet.has(tagName);
272
+ if (restrictMode === "deny" && isConfiguredTag) {
273
+ context.report({
274
+ data: {
275
+ entityKind: target.kind,
276
+ entityName: getEntityDisplayName(target.name),
277
+ tagName,
278
+ },
279
+ messageId: "disallowedTag",
280
+ node: target.reportNode,
281
+ });
282
+ continue;
283
+ }
284
+ if (restrictMode === "allow" && !isConfiguredTag) {
285
+ context.report({
286
+ data: {
287
+ allowedTags: allowedTags.length === 0
288
+ ? "<none>"
289
+ : allowedTags.join(", "),
290
+ entityKind: target.kind,
291
+ entityName: getEntityDisplayName(target.name),
292
+ tagName,
293
+ },
294
+ messageId: "tagNotAllowed",
295
+ node: target.reportNode,
296
+ });
297
+ }
298
+ }
299
+ };
300
+ const checkDeclarationWithExportComment = (declaration, exportNode) => {
301
+ for (const target of declarationTargetsWithCommentNode(declaration, exportNode)) {
302
+ checkTarget(target);
303
+ }
304
+ };
305
+ const trackDeclarationTargets = (declaration) => {
306
+ for (const target of declarationTargets(declaration)) {
307
+ if (target.name === undefined) {
308
+ continue;
309
+ }
310
+ declarationsByName.set(target.name, target);
311
+ }
312
+ };
313
+ const checkIdentifierExport = (identifier) => {
314
+ const target = declarationsByName.get(identifier.name);
315
+ if (target !== undefined) {
316
+ checkTarget(target);
317
+ }
318
+ };
319
+ return {
320
+ ExportDefaultDeclaration(exportNode) {
321
+ if (!shouldCheckExportedDeclarations(exportMode) ||
322
+ !isTopLevelNode(exportNode)) {
323
+ return;
324
+ }
325
+ const { declaration } = exportNode;
326
+ if (declaration.type === AST_NODE_TYPES.Identifier) {
327
+ checkIdentifierExport(declaration);
328
+ return;
329
+ }
330
+ if (isSupportedDeclaration(declaration)) {
331
+ checkDeclarationWithExportComment(declaration, exportNode);
332
+ return;
333
+ }
334
+ if (isSupportedDefaultExportExpression(declaration)) {
335
+ checkTarget({
336
+ commentNode: exportNode,
337
+ kind: getExpressionKind(declaration),
338
+ name: undefined,
339
+ reportNode: declaration,
340
+ });
341
+ }
342
+ },
343
+ ExportNamedDeclaration(exportNode) {
344
+ if (!shouldCheckExportedDeclarations(exportMode) ||
345
+ !isTopLevelNode(exportNode)) {
346
+ return;
347
+ }
348
+ if (exportNode.declaration !== null &&
349
+ isSupportedDeclaration(exportNode.declaration)) {
350
+ checkDeclarationWithExportComment(exportNode.declaration, exportNode);
351
+ }
352
+ if (exportNode.source !== null) {
353
+ return;
354
+ }
355
+ for (const specifier of exportNode.specifiers) {
356
+ if (specifier.type !== AST_NODE_TYPES.ExportSpecifier) {
357
+ continue;
358
+ }
359
+ checkIdentifierExport(specifier.local);
360
+ }
361
+ },
362
+ Program(programNode) {
363
+ declarationsByName.clear();
364
+ checkedTargets.clear();
365
+ for (const statement of programNode.body) {
366
+ if (isSupportedDeclaration(statement)) {
367
+ if (shouldCheckNonExportedDeclarations(exportMode)) {
368
+ for (const target of declarationTargetsWithCommentNode(statement, statement)) {
369
+ checkTarget(target);
370
+ }
371
+ }
372
+ if (shouldCheckExportedDeclarations(exportMode)) {
373
+ trackDeclarationTargets(statement);
374
+ }
375
+ continue;
376
+ }
377
+ if (shouldCheckExportedDeclarations(exportMode) &&
378
+ statement.type ===
379
+ AST_NODE_TYPES.ExportNamedDeclaration &&
380
+ statement.declaration !== null &&
381
+ isSupportedDeclaration(statement.declaration)) {
382
+ trackDeclarationTargets(statement.declaration);
383
+ }
384
+ }
385
+ },
386
+ };
387
+ },
388
+ meta: {
389
+ defaultOptions: [
390
+ {
391
+ enforceFor: [...enforceableEntityKinds],
392
+ exportMode: "exported",
393
+ mode: "deny",
394
+ tags: [...defaultRestrictedTags],
395
+ },
396
+ ],
397
+ deprecated: false,
398
+ docs: {
399
+ description: "disallow or allow only specific TSDoc/JSDoc tags in TSDoc blocks using configurable declaration scope.",
400
+ frozen: false,
401
+ recommended: false,
402
+ url: "https://github.com/Nick2bad4u/eslint-plugin-tsdoc-require-2/blob/main/docs/rules/restrict-tags.md",
403
+ },
404
+ messages: {
405
+ disallowedTag: "TSDoc for {{entityKind}} {{entityName}} contains disallowed tag {{tagName}}.",
406
+ tagNotAllowed: "TSDoc for {{entityKind}} {{entityName}} contains tag {{tagName}}, which is not in the allowed set: {{allowedTags}}.",
407
+ },
408
+ schema: [optionSchema],
409
+ type: "problem",
410
+ },
411
+ name: "restrict-tags",
412
+ });
413
+ export default restrictTagsRule;
414
+ //# sourceMappingURL=restrict-tags.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"restrict-tags.js","sourceRoot":"","sources":["../../src/rules/restrict-tags.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,97 @@
1
+ # Getting Started
2
+
3
+ `eslint-plugin-tsdoc-require-2` is easiest to adopt in layers:
4
+
5
+ 1. **Require docs to exist** with [`tsdoc-require-2/require`](./require.md).
6
+ 2. **Require specific tags** with one or more [`require-*` rules](./required-tags.md).
7
+ 3. **Restrict allowed tag vocabulary** with [`tsdoc-require-2/restrict-tags`](./restrict-tags.md).
8
+
9
+ Starting from a preset gives you a stable baseline before you tune rule options.
10
+
11
+ ## 1) Install
12
+
13
+ ```bash
14
+ npm install --save-dev eslint-plugin-tsdoc-require-2
15
+ ```
16
+
17
+ ## 2) Choose one preset baseline
18
+
19
+ Pick **one** preset as your starting point:
20
+
21
+ | Preset | Best for |
22
+ | --- | --- |
23
+ | [`recommended`](./presets/recommended.md) | Minimal rollout: require TSDoc comments only. |
24
+ | [`detailed`](./presets/detailed.md) | Require comments + `@remarks` for richer docs. |
25
+ | [`packages`](./presets/packages.md) | Package/library docs including `@packageDocumentation`. |
26
+ | [`jsdoc`](./presets/jsdoc.md) | Function-tag baseline (`@param`, `@returns`, `@throws`) with JSDoc-friendly behavior. |
27
+ | [`tsdoc`](./presets/tsdoc.md) | Strong TSDoc baseline with tag requirements + compatibility-tag restrictions. |
28
+ | [`typedoc`](./presets/typedoc.md) | TypeDoc-oriented declaration-kind tag enforcement. |
29
+ | [`typedoc-strict`](./presets/typedoc-strict.md) | Stricter TypeDoc baseline with module remarks and restricted tags. |
30
+ | [`all`](./presets/all.md) | Every rule. Useful for audits, usually too strict for day-one adoption. |
31
+
32
+ ## 3) Enable a preset in Flat Config
33
+
34
+ ```ts
35
+ import tsdocRequire from "eslint-plugin-tsdoc-require-2";
36
+
37
+ export default [tsdocRequire.configs.recommended];
38
+ ```
39
+
40
+ ## 4) Add targeted overrides (recommended)
41
+
42
+ After selecting a preset, add a second config block to tune scope/options.
43
+
44
+ ```ts
45
+ import tsdocRequire from "eslint-plugin-tsdoc-require-2";
46
+
47
+ export default [
48
+ tsdocRequire.configs.tsdoc,
49
+ {
50
+ rules: {
51
+ "tsdoc-require-2/require": [
52
+ "error",
53
+ {
54
+ exportMode: "all",
55
+ },
56
+ ],
57
+ "tsdoc-require-2/restrict-tags": [
58
+ "error",
59
+ {
60
+ exportMode: "all",
61
+ mode: "deny",
62
+ tags: ["@typedef", "@callback"],
63
+ },
64
+ ],
65
+ },
66
+ },
67
+ ];
68
+ ```
69
+
70
+ ## How to use the rules together
71
+
72
+ Treat the rules as a pipeline:
73
+
74
+ 1. **Presence layer:** `require` ensures there is a TSDoc block.
75
+ 2. **Content layer:** `require-*` tag rules enforce required fields (for example `@param`).
76
+ 3. **Vocabulary layer:** `restrict-tags` blocks unsupported tags.
77
+
78
+ ### Important composition tip
79
+
80
+ Keep `exportMode` and `enforceFor` aligned across rules. If one rule checks only exported declarations but another checks all declarations, your policy can feel inconsistent.
81
+
82
+ ### Important allow-mode tip
83
+
84
+ When using `restrict-tags` with `mode: "allow"`, include every tag required by enabled `require-*` rules, or the rules will conflict.
85
+
86
+ ## Suggested rollout strategy
87
+
88
+ 1. Start with `recommended`.
89
+ 2. Add only the tag rules your team can consistently maintain (`@param`, `@returns`, `@throws`, `@remarks` are common first picks).
90
+ 3. Add `restrict-tags` only after your required-tag policy is stable.
91
+ 4. Expand from `exportMode: "exported"` to `"all"` when internal documentation quality is a goal.
92
+
93
+ ## Next steps
94
+
95
+ - Compare presets in [Presets Overview](./presets/index.md).
96
+ - Review [Rules Overview](./index.md).
97
+ - Learn the foundational rule in [`tsdoc-require-2/require`](./require.md).
@@ -0,0 +1,61 @@
1
+ ---
2
+ slug: /
3
+ title: Rules
4
+ description: Explore the comprehensive set of rules provided by eslint-plugin-tsdoc-require-2 to enforce TSDoc/JSDoc documentation standards in your TypeScript codebase.
5
+ ---
6
+
7
+ # Rules
8
+
9
+ `eslint-plugin-tsdoc-require-2` enforces API documentation with three complementary rule families.
10
+
11
+ ## Rule family overview
12
+
13
+ | Family | Purpose | Start here when |
14
+ | --- | --- | --- |
15
+ | [`require`](./require.md) | Require a TSDoc block (`/** ... */`) on selected declarations. | You need a documentation baseline first. |
16
+ | [`required-tags`](./required-tags.md) | Require specific tags (for example `@param`, `@returns`, `@remarks`) through individual `require-*` rules. | You want documentation completeness and consistency. |
17
+ | [`restrict-tags`](./restrict-tags.md) | Allow-list or deny-list tags to control vocabulary and compatibility. | You need a strict tag policy (for example strict TSDoc vs loose JSDoc/TypeDoc tags). |
18
+
19
+ ## How the families work together
20
+
21
+ Use them in this order:
22
+
23
+ 1. **Presence**: `require` ensures docs exist.
24
+ 2. **Completeness**: `require-*` rules ensure required tags exist.
25
+ 3. **Vocabulary**: `restrict-tags` ensures only approved tags are used.
26
+
27
+ This sequencing reduces confusion because tag rules only matter once comments exist.
28
+
29
+ ## Practical configuration pattern
30
+
31
+ Use a preset for the baseline, then add focused overrides.
32
+
33
+ ```ts
34
+ import tsdocRequire from "eslint-plugin-tsdoc-require-2";
35
+
36
+ export default [
37
+ tsdocRequire.configs.recommended,
38
+ {
39
+ rules: {
40
+ "tsdoc-require-2/require-param": ["error", { enforceFor: ["function"] }],
41
+ "tsdoc-require-2/require-returns": ["error", { enforceFor: ["function"] }],
42
+ "tsdoc-require-2/restrict-tags": [
43
+ "error",
44
+ {
45
+ mode: "deny",
46
+ tags: ["@typedef", "@callback"],
47
+ },
48
+ ],
49
+ },
50
+ },
51
+ ];
52
+ ```
53
+
54
+ ## Where to start
55
+
56
+ - New adoption: [Getting Started](./getting-started.md)
57
+ - Preset selection: [Presets Overview](./presets/index.md)
58
+ - Rule family details:
59
+ - [`tsdoc-require-2/require`](./require.md)
60
+ - [`tsdoc-require-2/required-tags` family](./required-tags.md)
61
+ - [`tsdoc-require-2/restrict-tags`](./restrict-tags.md)