pickier 0.1.28 → 0.1.30

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 (263) hide show
  1. package/dist/ast.d.ts +13 -0
  2. package/dist/bin/cli.js +554 -436
  3. package/dist/plugins/eslint.d.ts +2 -0
  4. package/dist/plugins/general.d.ts +2 -0
  5. package/dist/plugins/index.d.ts +2 -0
  6. package/dist/plugins/lockfile.d.ts +22 -0
  7. package/dist/plugins/markdown.d.ts +2 -0
  8. package/dist/plugins/node.d.ts +2 -0
  9. package/dist/plugins/perfectionist.d.ts +6 -0
  10. package/dist/plugins/pickier.d.ts +2 -0
  11. package/dist/plugins/publint.d.ts +10 -0
  12. package/dist/plugins/quality.d.ts +2 -0
  13. package/dist/plugins/regexp.d.ts +2 -0
  14. package/dist/plugins/shell.d.ts +2 -0
  15. package/dist/plugins/spell.d.ts +3 -0
  16. package/dist/plugins/style.d.ts +2 -0
  17. package/dist/plugins/ts.d.ts +2 -0
  18. package/dist/plugins/unused-imports.d.ts +6 -0
  19. package/dist/plugins/utils.d.ts +4 -0
  20. package/dist/rules/general/_template-tracking.d.ts +31 -0
  21. package/dist/rules/general/array-callback-return.d.ts +2 -0
  22. package/dist/rules/general/constructor-super.d.ts +2 -0
  23. package/dist/rules/general/for-direction.d.ts +2 -0
  24. package/dist/rules/general/getter-return.d.ts +2 -0
  25. package/dist/rules/general/no-async-promise-executor.d.ts +2 -0
  26. package/dist/rules/general/no-compare-neg-zero.d.ts +2 -0
  27. package/dist/rules/general/no-cond-assign.d.ts +2 -0
  28. package/dist/rules/general/no-const-assign.d.ts +2 -0
  29. package/dist/rules/general/no-constant-condition.d.ts +2 -0
  30. package/dist/rules/general/no-constructor-return.d.ts +2 -0
  31. package/dist/rules/general/no-dupe-class-members.d.ts +2 -0
  32. package/dist/rules/general/no-dupe-keys.d.ts +2 -0
  33. package/dist/rules/general/no-duplicate-case.d.ts +2 -0
  34. package/dist/rules/general/no-empty-pattern.d.ts +2 -0
  35. package/dist/rules/general/no-fallthrough.d.ts +2 -0
  36. package/dist/rules/general/no-irregular-whitespace.d.ts +2 -0
  37. package/dist/rules/general/no-loss-of-precision.d.ts +2 -0
  38. package/dist/rules/general/no-new.d.ts +13 -0
  39. package/dist/rules/general/no-promise-executor-return.d.ts +2 -0
  40. package/dist/rules/general/no-redeclare.d.ts +2 -0
  41. package/dist/rules/general/no-regex-spaces.d.ts +10 -0
  42. package/dist/rules/general/no-self-assign.d.ts +2 -0
  43. package/dist/rules/general/no-self-compare.d.ts +2 -0
  44. package/dist/rules/general/no-sparse-arrays.d.ts +2 -0
  45. package/dist/rules/general/no-undef.d.ts +2 -0
  46. package/dist/rules/general/no-unreachable.d.ts +2 -0
  47. package/dist/rules/general/no-unsafe-negation.d.ts +2 -0
  48. package/dist/rules/general/no-unused-vars.d.ts +2 -0
  49. package/dist/rules/general/no-useless-catch.d.ts +2 -0
  50. package/dist/rules/general/prefer-const.d.ts +2 -0
  51. package/dist/rules/general/prefer-object-spread.d.ts +2 -0
  52. package/dist/rules/general/prefer-template.d.ts +2 -0
  53. package/dist/rules/general/use-isnan.d.ts +2 -0
  54. package/dist/rules/general/valid-typeof.d.ts +2 -0
  55. package/dist/rules/imports/first.d.ts +2 -0
  56. package/dist/rules/imports/import-dedupe.d.ts +2 -0
  57. package/dist/rules/imports/named.d.ts +2 -0
  58. package/dist/rules/imports/no-cycle.d.ts +2 -0
  59. package/dist/rules/imports/no-duplicate-imports.d.ts +2 -0
  60. package/dist/rules/imports/no-import-dist.d.ts +2 -0
  61. package/dist/rules/imports/no-import-node-modules-by-path.d.ts +2 -0
  62. package/dist/rules/imports/no-unresolved.d.ts +2 -0
  63. package/dist/rules/lockfile/parser.d.ts +79 -0
  64. package/dist/rules/lockfile/validate-host.d.ts +18 -0
  65. package/dist/rules/lockfile/validate-https.d.ts +14 -0
  66. package/dist/rules/lockfile/validate-integrity.d.ts +19 -0
  67. package/dist/rules/lockfile/validate-package-names.d.ts +23 -0
  68. package/dist/rules/lockfile/validate-scheme.d.ts +17 -0
  69. package/dist/rules/markdown/_fence-tracking.d.ts +32 -0
  70. package/dist/rules/markdown/_shared.d.ts +9 -0
  71. package/dist/rules/markdown/blanks-around-fences.d.ts +5 -0
  72. package/dist/rules/markdown/blanks-around-headings.d.ts +5 -0
  73. package/dist/rules/markdown/blanks-around-lists.d.ts +5 -0
  74. package/dist/rules/markdown/blanks-around-tables.d.ts +5 -0
  75. package/dist/rules/markdown/code-block-style.d.ts +5 -0
  76. package/dist/rules/markdown/code-fence-style.d.ts +5 -0
  77. package/dist/rules/markdown/commands-show-output.d.ts +5 -0
  78. package/dist/rules/markdown/descriptive-link-text.d.ts +5 -0
  79. package/dist/rules/markdown/emphasis-style.d.ts +5 -0
  80. package/dist/rules/markdown/fenced-code-language.d.ts +5 -0
  81. package/dist/rules/markdown/first-line-heading.d.ts +5 -0
  82. package/dist/rules/markdown/heading-increment.d.ts +5 -0
  83. package/dist/rules/markdown/heading-start-left.d.ts +5 -0
  84. package/dist/rules/markdown/heading-style.d.ts +5 -0
  85. package/dist/rules/markdown/hr-style.d.ts +5 -0
  86. package/dist/rules/markdown/line-length.d.ts +5 -0
  87. package/dist/rules/markdown/link-fragments.d.ts +5 -0
  88. package/dist/rules/markdown/link-image-reference-definitions.d.ts +5 -0
  89. package/dist/rules/markdown/link-image-style.d.ts +5 -0
  90. package/dist/rules/markdown/list-indent.d.ts +5 -0
  91. package/dist/rules/markdown/list-marker-space.d.ts +5 -0
  92. package/dist/rules/markdown/no-alt-text.d.ts +5 -0
  93. package/dist/rules/markdown/no-bare-urls.d.ts +5 -0
  94. package/dist/rules/markdown/no-blanks-blockquote.d.ts +5 -0
  95. package/dist/rules/markdown/no-duplicate-heading.d.ts +10 -0
  96. package/dist/rules/markdown/no-emphasis-as-heading.d.ts +9 -0
  97. package/dist/rules/markdown/no-empty-links.d.ts +5 -0
  98. package/dist/rules/markdown/no-hard-tabs.d.ts +5 -0
  99. package/dist/rules/markdown/no-inline-html.d.ts +5 -0
  100. package/dist/rules/markdown/no-missing-space-atx.d.ts +5 -0
  101. package/dist/rules/markdown/no-missing-space-closed-atx.d.ts +5 -0
  102. package/dist/rules/markdown/no-multiple-blanks.d.ts +5 -0
  103. package/dist/rules/markdown/no-multiple-space-atx.d.ts +5 -0
  104. package/dist/rules/markdown/no-multiple-space-blockquote.d.ts +5 -0
  105. package/dist/rules/markdown/no-multiple-space-closed-atx.d.ts +5 -0
  106. package/dist/rules/markdown/no-reversed-links.d.ts +5 -0
  107. package/dist/rules/markdown/no-space-in-code.d.ts +5 -0
  108. package/dist/rules/markdown/no-space-in-emphasis.d.ts +5 -0
  109. package/dist/rules/markdown/no-space-in-links.d.ts +5 -0
  110. package/dist/rules/markdown/no-trailing-punctuation.d.ts +5 -0
  111. package/dist/rules/markdown/no-trailing-spaces.d.ts +5 -0
  112. package/dist/rules/markdown/ol-prefix.d.ts +5 -0
  113. package/dist/rules/markdown/proper-names.d.ts +5 -0
  114. package/dist/rules/markdown/reference-links-images.d.ts +14 -0
  115. package/dist/rules/markdown/required-headings.d.ts +5 -0
  116. package/dist/rules/markdown/single-title.d.ts +5 -0
  117. package/dist/rules/markdown/single-trailing-newline.d.ts +5 -0
  118. package/dist/rules/markdown/strong-style.d.ts +5 -0
  119. package/dist/rules/markdown/table-column-count.d.ts +5 -0
  120. package/dist/rules/markdown/table-column-style.d.ts +5 -0
  121. package/dist/rules/markdown/table-pipe-style.d.ts +5 -0
  122. package/dist/rules/markdown/ul-indent.d.ts +14 -0
  123. package/dist/rules/markdown/ul-style.d.ts +5 -0
  124. package/dist/rules/node/prefer-global-buffer.d.ts +9 -0
  125. package/dist/rules/node/prefer-global-process.d.ts +9 -0
  126. package/dist/rules/quality/complexity.d.ts +2 -0
  127. package/dist/rules/quality/default-case.d.ts +2 -0
  128. package/dist/rules/quality/eqeqeq.d.ts +2 -0
  129. package/dist/rules/quality/max-depth.d.ts +2 -0
  130. package/dist/rules/quality/max-lines-per-function.d.ts +2 -0
  131. package/dist/rules/quality/no-alert.d.ts +2 -0
  132. package/dist/rules/quality/no-await-in-loop.d.ts +2 -0
  133. package/dist/rules/quality/no-caller.d.ts +2 -0
  134. package/dist/rules/quality/no-case-declarations.d.ts +2 -0
  135. package/dist/rules/quality/no-else-return.d.ts +2 -0
  136. package/dist/rules/quality/no-empty-function.d.ts +2 -0
  137. package/dist/rules/quality/no-empty.d.ts +2 -0
  138. package/dist/rules/quality/no-eval.d.ts +2 -0
  139. package/dist/rules/quality/no-extend-native.d.ts +2 -0
  140. package/dist/rules/quality/no-extra-boolean-cast.d.ts +2 -0
  141. package/dist/rules/quality/no-global-assign.d.ts +2 -0
  142. package/dist/rules/quality/no-implied-eval.d.ts +2 -0
  143. package/dist/rules/quality/no-iterator.d.ts +2 -0
  144. package/dist/rules/quality/no-lonely-if.d.ts +2 -0
  145. package/dist/rules/quality/no-new-func.d.ts +2 -0
  146. package/dist/rules/quality/no-new-wrappers.d.ts +2 -0
  147. package/dist/rules/quality/no-new.d.ts +2 -0
  148. package/dist/rules/quality/no-octal.d.ts +2 -0
  149. package/dist/rules/quality/no-param-reassign.d.ts +2 -0
  150. package/dist/rules/quality/no-proto.d.ts +2 -0
  151. package/dist/rules/quality/no-return-assign.d.ts +2 -0
  152. package/dist/rules/quality/no-sequences.d.ts +2 -0
  153. package/dist/rules/quality/no-shadow.d.ts +2 -0
  154. package/dist/rules/quality/no-throw-literal.d.ts +2 -0
  155. package/dist/rules/quality/no-use-before-define.d.ts +2 -0
  156. package/dist/rules/quality/no-useless-call.d.ts +2 -0
  157. package/dist/rules/quality/no-useless-concat.d.ts +2 -0
  158. package/dist/rules/quality/no-useless-escape.d.ts +2 -0
  159. package/dist/rules/quality/no-useless-rename.d.ts +2 -0
  160. package/dist/rules/quality/no-useless-return.d.ts +2 -0
  161. package/dist/rules/quality/no-var.d.ts +2 -0
  162. package/dist/rules/quality/no-with.d.ts +2 -0
  163. package/dist/rules/quality/prefer-arrow-callback.d.ts +2 -0
  164. package/dist/rules/quality/require-await.d.ts +2 -0
  165. package/dist/rules/regexp/no-super-linear-backtracking.d.ts +2 -0
  166. package/dist/rules/regexp/no-unused-capturing-group.d.ts +2 -0
  167. package/dist/rules/regexp/no-useless-lazy.d.ts +9 -0
  168. package/dist/rules/shell/_shared.d.ts +24 -0
  169. package/dist/rules/shell/command-substitution.d.ts +6 -0
  170. package/dist/rules/shell/consistent-case-terminators.d.ts +9 -0
  171. package/dist/rules/shell/function-style.d.ts +6 -0
  172. package/dist/rules/shell/heredoc-indent.d.ts +7 -0
  173. package/dist/rules/shell/indent.d.ts +2 -0
  174. package/dist/rules/shell/keyword-spacing.d.ts +10 -0
  175. package/dist/rules/shell/no-broken-redirect.d.ts +7 -0
  176. package/dist/rules/shell/no-cd-without-check.d.ts +6 -0
  177. package/dist/rules/shell/no-eval.d.ts +6 -0
  178. package/dist/rules/shell/no-exit-in-subshell.d.ts +7 -0
  179. package/dist/rules/shell/no-ls-parsing.d.ts +7 -0
  180. package/dist/rules/shell/no-trailing-semicolons.d.ts +6 -0
  181. package/dist/rules/shell/no-trailing-whitespace.d.ts +5 -0
  182. package/dist/rules/shell/no-useless-cat.d.ts +6 -0
  183. package/dist/rules/shell/no-variable-in-single-quotes.d.ts +7 -0
  184. package/dist/rules/shell/operator-spacing.d.ts +11 -0
  185. package/dist/rules/shell/prefer-double-brackets.d.ts +6 -0
  186. package/dist/rules/shell/prefer-printf.d.ts +6 -0
  187. package/dist/rules/shell/quote-variables.d.ts +2 -0
  188. package/dist/rules/shell/set-options.d.ts +8 -0
  189. package/dist/rules/shell/shebang.d.ts +2 -0
  190. package/dist/rules/sort/exports.d.ts +2 -0
  191. package/dist/rules/sort/heritage-clauses.d.ts +2 -0
  192. package/dist/rules/sort/imports.d.ts +2 -0
  193. package/dist/rules/sort/keys.d.ts +2 -0
  194. package/dist/rules/sort/named-imports.d.ts +2 -0
  195. package/dist/rules/sort/objects.d.ts +2 -0
  196. package/dist/rules/sort/tailwind-classes.d.ts +5 -0
  197. package/dist/rules/style/array-bracket-spacing.d.ts +2 -0
  198. package/dist/rules/style/arrow-parens.d.ts +2 -0
  199. package/dist/rules/style/arrow-spacing.d.ts +2 -0
  200. package/dist/rules/style/block-spacing.d.ts +2 -0
  201. package/dist/rules/style/brace-style.d.ts +10 -0
  202. package/dist/rules/style/comma-dangle.d.ts +2 -0
  203. package/dist/rules/style/comma-spacing.d.ts +2 -0
  204. package/dist/rules/style/comma-style.d.ts +2 -0
  205. package/dist/rules/style/computed-property-spacing.d.ts +2 -0
  206. package/dist/rules/style/consistent-chaining.d.ts +2 -0
  207. package/dist/rules/style/consistent-list-newline.d.ts +2 -0
  208. package/dist/rules/style/curly.d.ts +5 -0
  209. package/dist/rules/style/dot-location.d.ts +2 -0
  210. package/dist/rules/style/function-call-spacing.d.ts +2 -0
  211. package/dist/rules/style/generator-star-spacing.d.ts +2 -0
  212. package/dist/rules/style/if-newline.d.ts +2 -0
  213. package/dist/rules/style/indent-binary-ops.d.ts +2 -0
  214. package/dist/rules/style/indent-unindent.d.ts +2 -0
  215. package/dist/rules/style/key-spacing.d.ts +2 -0
  216. package/dist/rules/style/keyword-spacing.d.ts +2 -0
  217. package/dist/rules/style/lines-between-class-members.d.ts +2 -0
  218. package/dist/rules/style/max-statements-per-line.d.ts +2 -0
  219. package/dist/rules/style/multiline-ternary.d.ts +2 -0
  220. package/dist/rules/style/new-parens.d.ts +2 -0
  221. package/dist/rules/style/no-extra-parens.d.ts +2 -0
  222. package/dist/rules/style/no-floating-decimal.d.ts +2 -0
  223. package/dist/rules/style/no-mixed-operators.d.ts +2 -0
  224. package/dist/rules/style/no-mixed-spaces-and-tabs.d.ts +2 -0
  225. package/dist/rules/style/no-multi-spaces.d.ts +10 -0
  226. package/dist/rules/style/no-multiple-empty-lines.d.ts +9 -0
  227. package/dist/rules/style/no-tabs.d.ts +2 -0
  228. package/dist/rules/style/no-trailing-spaces.d.ts +9 -0
  229. package/dist/rules/style/no-whitespace-before-property.d.ts +2 -0
  230. package/dist/rules/style/object-curly-spacing.d.ts +2 -0
  231. package/dist/rules/style/operator-linebreak.d.ts +2 -0
  232. package/dist/rules/style/padded-blocks.d.ts +2 -0
  233. package/dist/rules/style/quote-props.d.ts +2 -0
  234. package/dist/rules/style/rest-spread-spacing.d.ts +2 -0
  235. package/dist/rules/style/semi-spacing.d.ts +2 -0
  236. package/dist/rules/style/space-before-blocks.d.ts +2 -0
  237. package/dist/rules/style/space-before-function-paren.d.ts +2 -0
  238. package/dist/rules/style/space-in-parens.d.ts +2 -0
  239. package/dist/rules/style/space-infix-ops.d.ts +2 -0
  240. package/dist/rules/style/space-unary-ops.d.ts +2 -0
  241. package/dist/rules/style/spaced-comment.d.ts +2 -0
  242. package/dist/rules/style/switch-colon-spacing.d.ts +2 -0
  243. package/dist/rules/style/template-curly-spacing.d.ts +2 -0
  244. package/dist/rules/style/template-tag-spacing.d.ts +2 -0
  245. package/dist/rules/style/top-level-function.d.ts +6 -0
  246. package/dist/rules/style/wrap-iife.d.ts +2 -0
  247. package/dist/rules/style/yield-star-spacing.d.ts +2 -0
  248. package/dist/rules/ts/member-delimiter-style.d.ts +4 -0
  249. package/dist/rules/ts/no-explicit-any.d.ts +2 -0
  250. package/dist/rules/ts/no-floating-promises.d.ts +2 -0
  251. package/dist/rules/ts/no-misused-promises.d.ts +2 -0
  252. package/dist/rules/ts/no-require-imports.d.ts +2 -0
  253. package/dist/rules/ts/no-top-level-await.d.ts +4 -0
  254. package/dist/rules/ts/no-ts-export-equal.d.ts +2 -0
  255. package/dist/rules/ts/no-unsafe-assignment.d.ts +2 -0
  256. package/dist/rules/ts/prefer-nullish-coalescing.d.ts +2 -0
  257. package/dist/rules/ts/prefer-optional-chain.d.ts +2 -0
  258. package/dist/rules/ts/type-annotation-spacing.d.ts +2 -0
  259. package/dist/rules/ts/type-generic-spacing.d.ts +2 -0
  260. package/dist/rules/ts/type-named-tuple-spacing.d.ts +2 -0
  261. package/dist/src/index.js +527 -423
  262. package/dist/utils.d.ts +12 -3
  263. package/package.json +3 -2
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const eslintPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const generalPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare function getAllPlugins(): PickierPlugin[];
@@ -0,0 +1,22 @@
1
+ import type { PickierPlugin } from '../types';
2
+ /**
3
+ * Lockfile security plugin for pickier.
4
+ *
5
+ * Validates lockfiles (package-lock.json, yarn.lock, bun.lock) for security issues
6
+ * that could indicate supply chain attacks.
7
+ *
8
+ * Rules:
9
+ * - validate-host: Ensure packages are from allowed registry hosts
10
+ * - validate-https: Ensure packages use HTTPS protocol
11
+ * - validate-integrity: Ensure packages use strong integrity hashes (SHA512)
12
+ * - validate-package-names: Ensure package names match their resolved URLs
13
+ * - validate-scheme: Ensure packages use allowed URL schemes
14
+ *
15
+ * Attack vectors protected against:
16
+ * 1. Malicious Host Injection - Attacker modifies lockfile to point to malicious registries
17
+ * 2. Package Name Substitution - Lockfile references wrong package name in URL
18
+ * 3. Unencrypted Protocol Usage - Using HTTP instead of HTTPS (MITM attacks)
19
+ * 4. Weak Integrity Hashes - Using SHA1/SHA256 instead of SHA512 (collision attacks)
20
+ * 5. Unauthorized URL Schemes - Using file://, data://, git+http://, etc.
21
+ */
22
+ export declare const lockfilePlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const markdownPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const nodePlugin: PickierPlugin;
@@ -0,0 +1,6 @@
1
+ import type { PickierPlugin } from '../types';
2
+ /**
3
+ * Perfectionist plugin - provides compatibility with perfectionist ESLint plugin
4
+ * These rules are aliases to existing Pickier rules under different namespaces
5
+ */
6
+ export declare const perfectionistPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const pickierPlugin: PickierPlugin;
@@ -0,0 +1,10 @@
1
+ import type { PickierPlugin } from '../types';
2
+ /**
3
+ * publint plugin for pickier.
4
+ *
5
+ * Validates package.json files for correct npm publishing configuration.
6
+ * Checks exports/imports ordering, field types, file format, module system, etc.
7
+ *
8
+ * Ported from publint (https://publint.dev).
9
+ */
10
+ export declare const publintPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const qualityPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const regexpPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const shellPlugin: PickierPlugin;
@@ -0,0 +1,3 @@
1
+ import type { PickierPlugin } from '../types';
2
+ // ── Plugin export ───────────────────────────────────────────────
3
+ export declare const spellPlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const stylePlugin: PickierPlugin;
@@ -0,0 +1,2 @@
1
+ import type { PickierPlugin } from '../types';
2
+ export declare const tsPlugin: PickierPlugin;
@@ -0,0 +1,6 @@
1
+ import type { PickierPlugin } from '../types';
2
+ /**
3
+ * unused-imports plugin - provides compatibility with unused-imports ESLint plugin
4
+ * These rules are aliases to existing Pickier rules under different namespaces
5
+ */
6
+ export declare const unusedImportsPlugin: PickierPlugin;
@@ -0,0 +1,4 @@
1
+ import type { RuleModule } from '../types';
2
+ export declare function codeOnly(rule: RuleModule): RuleModule;
3
+ export declare function shellOnly(rule: RuleModule): RuleModule;
4
+ export declare function packageJsonOnly(rule: RuleModule): RuleModule;
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Compute, for each line of a TS/JS source, whether the line begins inside
3
+ * a template-literal body (i.e. between an unclosed backtick and its
4
+ * matching close).
5
+ *
6
+ * Used by rules like `prefer-const` and `pickier/no-unused-vars` to skip
7
+ * generated code embedded in template strings — declarations and function
8
+ * bodies inside a `\`<script>...\`` blob aren't real top-level code, and
9
+ * applying lint rules to them produces false positives that fixers will
10
+ * happily turn into broken runtime code.
11
+ *
12
+ * Tracks: single-quoted strings, double-quoted strings, template-literal
13
+ * bodies + their `${}` expressions (with brace depth), regex literals
14
+ * (with character-class awareness), line and block comments.
15
+ *
16
+ * Regex-vs-division disambiguation uses the previous "significant"
17
+ * character on the logical statement: `/` after operators / punctuation
18
+ * starts a regex; `/` after an identifier or closing bracket is division.
19
+ */
20
+ export declare function computeLineStartsInTemplate(text: string): boolean[];
21
+ /**
22
+ * On a single line, return [start, end] ranges of characters that fall
23
+ * inside a backtick-bounded template literal. If a backtick opens but
24
+ * doesn't close on this line, the range extends to the line's end (it's
25
+ * the first line of a multi-line template).
26
+ *
27
+ * Used by per-line fixers to refuse to rewrite identifiers that fall
28
+ * inside an embedded code blob whose other usages live in the same
29
+ * template string and aren't visible to the syntactic rename.
30
+ */
31
+ export declare function backtickRangesOnLine(line: string): Array<[number, number]>;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const arrayCallbackReturnRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const constructorSuperRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const forDirectionRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const getterReturnRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noAsyncPromiseExecutorRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noCompareNegZeroRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noCondAssignRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noConstAssignRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noConstantConditionRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noConstructorReturnRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noDupeClassMembersRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noDupeKeysRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noDuplicateCaseRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noEmptyPatternRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noFallthroughRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noIrregularWhitespaceRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noLossOfPrecisionRule: RuleModule;
@@ -0,0 +1,13 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * Disallow `new` operators outside of assignments or comparisons.
4
+ * Prevents using `new` for side effects without storing the result.
5
+ *
6
+ * Violations:
7
+ * - `new MyClass()` (result not used)
8
+ *
9
+ * Valid:
10
+ * - `const instance = new MyClass()`
11
+ * - `return new MyClass()`
12
+ */
13
+ export declare const noNew: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noPromiseExecutorReturnRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noRedeclareRule: RuleModule;
@@ -0,0 +1,10 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * Disallow multiple spaces in regular expressions.
4
+ * Use quantifiers like {2} instead for clarity.
5
+ *
6
+ * Violations:
7
+ * - `/foo bar/` (use /foo {2}bar/ instead)
8
+ * - `/ +/` (multiple spaces)
9
+ */
10
+ export declare const noRegexSpaces: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noSelfAssignRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noSelfCompareRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noSparseArraysRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noUndefRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noUnreachableRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noUnsafeNegationRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noUnusedVarsRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noUselessCatchRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const preferConstRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const preferObjectSpreadRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const preferTemplate: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const useIsNaNRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const validTypeofRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const firstRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const importDedupeRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const namedRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noCycleRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noDuplicateImportsRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noImportDistRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noImportNodeModulesByPathRule: RuleModule;
@@ -0,0 +1,2 @@
1
+ import type { RuleModule } from '../../types';
2
+ export declare const noUnresolvedRule: RuleModule;
@@ -0,0 +1,79 @@
1
+ /**
2
+ * Detect lockfile type from filename
3
+ */
4
+ export declare function detectLockfileType(filePath: string): 'npm' | 'yarn' | 'bun' | null;
5
+ /**
6
+ * Check if content is a lockfile based on structure
7
+ */
8
+ export declare function isLockfileContent(content: string, filePath: string): boolean;
9
+ /**
10
+ * Parse npm package-lock.json (supports v1, v2, v3)
11
+ */
12
+ export declare function parseNpmLockfile(content: string): ParsedLockfile;
13
+ /**
14
+ * Parse yarn.lock (supports classic v1 and berry/v2+)
15
+ */
16
+ export declare function parseYarnLockfile(content: string): ParsedLockfile;
17
+ /**
18
+ * Parse bun.lock (JSON format)
19
+ *
20
+ * Bun lockfile format (v1):
21
+ * {
22
+ * "lockfileVersion": 1,
23
+ * "packages": {
24
+ * "pkg-name": ["pkg-name@version", "resolved-url", { deps }, "integrity-hash"],
25
+ * "@scope/pkg": ["@scope/pkg@version", "", { deps }, "sha512-..."],
26
+ * }
27
+ * }
28
+ *
29
+ * Array format: [name@version, resolved_url, meta_object, integrity_hash]
30
+ * Note: resolved_url is often empty string for packages from default registry
31
+ */
32
+ export declare function parseBunLockfile(content: string): ParsedLockfile;
33
+ /**
34
+ * Parse a lockfile based on its type
35
+ */
36
+ export declare function parseLockfile(content: string, filePath: string): ParsedLockfile | null;
37
+ /**
38
+ * Extract host from a resolved URL
39
+ */
40
+ export declare function extractHost(resolvedUrl: string): string | null;
41
+ /**
42
+ * Extract protocol/scheme from a resolved URL
43
+ */
44
+ export declare function extractScheme(resolvedUrl: string): string | null;
45
+ /**
46
+ * Extract package name from a resolved URL
47
+ * Works for npm/yarn registry URLs like:
48
+ * - https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz
49
+ * - https://registry.npmjs.org/@babel/core/-/core-7.0.0.tgz
50
+ */
51
+ export declare function extractPackageNameFromUrl(resolvedUrl: string): string | null;
52
+ /**
53
+ * Extract integrity hash type (sha1, sha256, sha512, etc.)
54
+ */
55
+ export declare function extractIntegrityType(integrity: string): string | null;
56
+ /**
57
+ * Expand host aliases to actual hostnames
58
+ */
59
+ export declare function expandHostAliases(hosts: string[]): string[];
60
+ // Registry aliases for convenience
61
+ export declare const REGISTRY_ALIASES: {
62
+ npm: 'registry.npmjs.org';
63
+ yarn: 'registry.yarnpkg.com';
64
+ verdaccio: 'registry.verdaccio.org'
65
+ };
66
+ /**
67
+ * Lockfile parser for npm, yarn, and bun lockfiles.
68
+ * Normalizes different formats into a unified structure for validation.
69
+ */
70
+ export declare interface ParsedPackage {
71
+ name: string
72
+ version: string
73
+ resolved?: string
74
+ integrity?: string
75
+ }
76
+ export declare interface ParsedLockfile {
77
+ type: 'npm' | 'yarn' | 'yarn-berry' | 'bun'
78
+ packages: Map<string, ParsedPackage>
79
+ }
@@ -0,0 +1,18 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * Validate that all packages in a lockfile are from allowed hosts.
4
+ * Prevents supply chain attacks where an attacker modifies the lockfile
5
+ * to point packages to malicious registries.
6
+ *
7
+ * Options:
8
+ * - allowedHosts: Array of allowed hostnames or aliases ('npm', 'yarn', 'verdaccio')
9
+ * - emptyHostname: Whether to allow packages with empty/missing resolved URLs (default: true)
10
+ *
11
+ * Example config:
12
+ * ```ts
13
+ * pluginRules: {
14
+ * 'lockfile/validate-host': ['error', { allowedHosts: ['npm', 'yarn'] }]
15
+ * }
16
+ * ```
17
+ */
18
+ export declare const validateHost: RuleModule;
@@ -0,0 +1,14 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * Validate that all packages use HTTPS protocol.
4
+ * Prevents man-in-the-middle attacks where packages could be intercepted
5
+ * and replaced when downloaded over unencrypted HTTP.
6
+ *
7
+ * Example config:
8
+ * ```ts
9
+ * pluginRules: {
10
+ * 'lockfile/validate-https': 'error'
11
+ * }
12
+ * ```
13
+ */
14
+ export declare const validateHttps: RuleModule;
@@ -0,0 +1,19 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * Validate that all packages use strong integrity hashes (SHA512).
4
+ * Weak hash algorithms like SHA1 and SHA256 are more susceptible to
5
+ * collision attacks, potentially allowing attackers to substitute
6
+ * malicious packages that match the same hash.
7
+ *
8
+ * Options:
9
+ * - requiredAlgorithm: The minimum required hash algorithm (default: 'sha512')
10
+ * - exclude: Array of package names to exclude from validation
11
+ *
12
+ * Example config:
13
+ * ```ts
14
+ * pluginRules: {
15
+ * 'lockfile/validate-integrity': ['error', { requiredAlgorithm: 'sha512', exclude: [] }]
16
+ * }
17
+ * ```
18
+ */
19
+ export declare const validateIntegrity: RuleModule;
@@ -0,0 +1,23 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * Validate that package names in lockfile match the resolved URL.
4
+ * Detects package substitution attacks where an attacker replaces a legitimate
5
+ * package with a malicious one by pointing to a different package in the URL.
6
+ *
7
+ * Example attack:
8
+ * Package key: meow@1.0.0
9
+ * Resolved URL: https://registry.npmjs.org/meowlicious/-/meow-4.0.1.tgz
10
+ * The URL points to a different package (meowlicious) than expected (meow).
11
+ *
12
+ * Options:
13
+ * - aliases: Object mapping package names to allowed URL names
14
+ * Example: { 'foo': 'foo-package' } allows 'foo' to resolve to 'foo-package'
15
+ *
16
+ * Example config:
17
+ * ```ts
18
+ * pluginRules: {
19
+ * 'lockfile/validate-package-names': ['error', { aliases: {} }]
20
+ * }
21
+ * ```
22
+ */
23
+ export declare const validatePackageNames: RuleModule;
@@ -0,0 +1,17 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * Validate that all packages use allowed URL schemes/protocols.
4
+ * Prevents attacks using unexpected schemes like file://, data://,
5
+ * git+http://, or other protocols that might bypass security policies.
6
+ *
7
+ * Options:
8
+ * - allowedSchemes: Array of allowed URL schemes (default: ['https:', 'git+https:', 'git+ssh:'])
9
+ *
10
+ * Example config:
11
+ * ```ts
12
+ * pluginRules: {
13
+ * 'lockfile/validate-scheme': ['error', { allowedSchemes: ['https:', 'git+ssh:'] }]
14
+ * }
15
+ * ```
16
+ */
17
+ export declare const validateScheme: RuleModule;
@@ -0,0 +1,32 @@
1
+ /**
2
+ * CommonMark-compliant code-block detection for markdown.
3
+ *
4
+ * Returns a Set of 0-indexed line numbers that are inside any code block —
5
+ * fenced (` ``` ... ``` ` / `~~~ ... ~~~`) or indented (4-space prefix). The
6
+ * fence boundary lines themselves are also included.
7
+ *
8
+ * Per the CommonMark spec, a fenced code block:
9
+ * - Opens with at least 3 backticks or tildes, optionally followed by an
10
+ * "info string" (e.g. ` ```js `).
11
+ * - Closes only with the SAME fence character, AT LEAST as many of them
12
+ * as the opener, and an EMPTY info string (just the run of backticks
13
+ * or tildes plus optional trailing whitespace).
14
+ * - Anything else inside the block — including ` ```js ` lines — is
15
+ * content, not a fence boundary.
16
+ *
17
+ * The naive tracker that toggles on every `^`{3,}|~{3,}` confuses
18
+ * `` ```js `` with a close and corrupts state for the rest of the file.
19
+ * Use this helper instead.
20
+ *
21
+ * Indented code blocks: a line is treated as inside an indented code block
22
+ * when it has 4+ leading spaces and the previous non-blank line is also
23
+ * indented (or blank with another indented line above it). Lines inside a
24
+ * fenced block don't double-count as indented.
25
+ */
26
+ export declare function getCodeBlockLines(lines: string[]): Set<number>;
27
+ /**
28
+ * Like `getCodeBlockLines` but returns whether a single line index is
29
+ * inside ANY kind of code block — handy for one-shot checks where you
30
+ * don't already have the set computed.
31
+ */
32
+ export declare function isInsideCodeBlock(lines: string[], targetIdx: number): boolean;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Identify genuine GFM table rows in a markdown document. A row counts as
3
+ * a table row when it is part of a block that includes a separator row of
4
+ * the form `|---|---|` (pipes + dashes, optional colons for alignment).
5
+ * Stray `|` characters inside paragraphs are ignored. Lines inside fenced
6
+ * or indented code blocks are ignored — `| Foo | Bar |` lines inside a
7
+ * `` ```markdown `` example are content, not real tables.
8
+ */
9
+ export declare function findTableRows(lines: string[]): Set<number>;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD031 - Fenced code blocks should be surrounded by blank lines
4
+ */
5
+ export declare const blanksAroundFencesRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD022 - Headings should be surrounded by blank lines
4
+ */
5
+ export declare const blanksAroundHeadingsRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD032 - Lists should be surrounded by blank lines
4
+ */
5
+ export declare const blanksAroundListsRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD058 - Tables should be surrounded by blank lines
4
+ */
5
+ export declare const blanksAroundTablesRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD046 - Code block style
4
+ */
5
+ export declare const codeBlockStyleRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD048 - Code fence style
4
+ */
5
+ export declare const codeFenceStyleRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD014 - Dollar signs used before commands without showing output
4
+ */
5
+ export declare const commandsShowOutputRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD059 - Link text should be descriptive
4
+ */
5
+ export declare const descriptiveLinkTextRule: RuleModule;
@@ -0,0 +1,5 @@
1
+ import type { RuleModule } from '../../types';
2
+ /**
3
+ * MD049 - Emphasis style
4
+ */
5
+ export declare const emphasisStyleRule: RuleModule;