eslint 9.22.0 → 9.24.0
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.
- package/README.md +48 -46
- package/bin/eslint.js +92 -90
- package/conf/default-cli-options.js +22 -22
- package/conf/ecma-version.js +1 -1
- package/conf/globals.js +97 -98
- package/conf/replacements.json +24 -20
- package/conf/rule-type-list.json +88 -92
- package/lib/api.js +12 -12
- package/lib/cli-engine/cli-engine.js +830 -810
- package/lib/cli-engine/file-enumerator.js +381 -387
- package/lib/cli-engine/formatters/formatters-meta.json +16 -16
- package/lib/cli-engine/formatters/html.js +107 -99
- package/lib/cli-engine/formatters/json-with-metadata.js +5 -5
- package/lib/cli-engine/formatters/json.js +2 -2
- package/lib/cli-engine/formatters/stylish.js +96 -75
- package/lib/cli-engine/hash.js +1 -1
- package/lib/cli-engine/index.js +1 -1
- package/lib/cli-engine/lint-result-cache.js +144 -145
- package/lib/cli-engine/load-rules.js +16 -16
- package/lib/cli.js +638 -457
- package/lib/config/config-loader.js +726 -622
- package/lib/config/config.js +247 -221
- package/lib/config/default-config.js +54 -45
- package/lib/config/flat-config-array.js +167 -172
- package/lib/config/flat-config-helpers.js +72 -72
- package/lib/config/flat-config-schema.js +375 -368
- package/lib/config/rule-validator.js +139 -144
- package/lib/config-api.js +2 -2
- package/lib/eslint/eslint-helpers.js +756 -681
- package/lib/eslint/eslint.js +934 -912
- package/lib/eslint/index.js +2 -2
- package/lib/eslint/legacy-eslint.js +577 -533
- package/lib/languages/js/index.js +263 -264
- package/lib/languages/js/source-code/index.js +1 -1
- package/lib/languages/js/source-code/source-code.js +1128 -1057
- package/lib/languages/js/source-code/token-store/backward-token-comment-cursor.js +39 -35
- package/lib/languages/js/source-code/token-store/backward-token-cursor.js +35 -36
- package/lib/languages/js/source-code/token-store/cursor.js +36 -36
- package/lib/languages/js/source-code/token-store/cursors.js +80 -52
- package/lib/languages/js/source-code/token-store/decorative-cursor.js +17 -18
- package/lib/languages/js/source-code/token-store/filter-cursor.js +19 -20
- package/lib/languages/js/source-code/token-store/forward-token-comment-cursor.js +40 -32
- package/lib/languages/js/source-code/token-store/forward-token-cursor.js +40 -41
- package/lib/languages/js/source-code/token-store/index.js +592 -498
- package/lib/languages/js/source-code/token-store/limit-cursor.js +17 -18
- package/lib/languages/js/source-code/token-store/padded-token-cursor.js +23 -16
- package/lib/languages/js/source-code/token-store/skip-cursor.js +19 -20
- package/lib/languages/js/source-code/token-store/utils.js +63 -60
- package/lib/languages/js/validate-language-options.js +104 -89
- package/lib/linter/apply-disable-directives.js +467 -383
- package/lib/linter/code-path-analysis/code-path-analyzer.js +650 -672
- package/lib/linter/code-path-analysis/code-path-segment.js +215 -216
- package/lib/linter/code-path-analysis/code-path-state.js +2118 -2096
- package/lib/linter/code-path-analysis/code-path.js +307 -319
- package/lib/linter/code-path-analysis/debug-helpers.js +183 -163
- package/lib/linter/code-path-analysis/fork-context.js +296 -271
- package/lib/linter/code-path-analysis/id-generator.js +22 -23
- package/lib/linter/file-context.js +119 -120
- package/lib/linter/index.js +3 -3
- package/lib/linter/interpolate.js +16 -16
- package/lib/linter/linter.js +2403 -2045
- package/lib/linter/node-event-generator.js +284 -225
- package/lib/linter/report-translator.js +256 -219
- package/lib/linter/rule-fixer.js +122 -124
- package/lib/linter/rules.js +36 -36
- package/lib/linter/safe-emitter.js +18 -18
- package/lib/linter/source-code-fixer.js +94 -92
- package/lib/linter/timing.js +104 -101
- package/lib/linter/vfile.js +70 -73
- package/lib/options.js +404 -361
- package/lib/rule-tester/index.js +1 -1
- package/lib/rule-tester/rule-tester.js +1308 -1046
- package/lib/rules/accessor-pairs.js +298 -263
- package/lib/rules/array-bracket-newline.js +250 -238
- package/lib/rules/array-bracket-spacing.js +263 -224
- package/lib/rules/array-callback-return.js +402 -356
- package/lib/rules/array-element-newline.js +358 -313
- package/lib/rules/arrow-body-style.js +400 -281
- package/lib/rules/arrow-parens.js +206 -173
- package/lib/rules/arrow-spacing.js +169 -163
- package/lib/rules/block-scoped-var.js +125 -123
- package/lib/rules/block-spacing.js +186 -176
- package/lib/rules/brace-style.js +262 -199
- package/lib/rules/callback-return.js +203 -190
- package/lib/rules/camelcase.js +403 -392
- package/lib/rules/capitalized-comments.js +253 -232
- package/lib/rules/class-methods-use-this.js +224 -172
- package/lib/rules/comma-dangle.js +379 -346
- package/lib/rules/comma-spacing.js +193 -195
- package/lib/rules/comma-style.js +375 -316
- package/lib/rules/complexity.js +173 -169
- package/lib/rules/computed-property-spacing.js +236 -211
- package/lib/rules/consistent-return.js +181 -170
- package/lib/rules/consistent-this.js +167 -147
- package/lib/rules/constructor-super.js +412 -404
- package/lib/rules/curly.js +407 -332
- package/lib/rules/default-case-last.js +38 -31
- package/lib/rules/default-case.js +89 -85
- package/lib/rules/default-param-last.js +69 -54
- package/lib/rules/dot-location.js +122 -110
- package/lib/rules/dot-notation.js +192 -156
- package/lib/rules/eol-last.js +122 -120
- package/lib/rules/eqeqeq.js +168 -155
- package/lib/rules/for-direction.js +146 -121
- package/lib/rules/func-call-spacing.js +261 -231
- package/lib/rules/func-name-matching.js +293 -209
- package/lib/rules/func-names.js +165 -164
- package/lib/rules/func-style.js +159 -127
- package/lib/rules/function-call-argument-newline.js +152 -129
- package/lib/rules/function-paren-newline.js +349 -291
- package/lib/rules/generator-star-spacing.js +229 -210
- package/lib/rules/getter-return.js +208 -172
- package/lib/rules/global-require.js +85 -74
- package/lib/rules/grouped-accessor-pairs.js +170 -150
- package/lib/rules/guard-for-in.js +72 -63
- package/lib/rules/handle-callback-err.js +108 -103
- package/lib/rules/id-blacklist.js +182 -199
- package/lib/rules/id-denylist.js +168 -187
- package/lib/rules/id-length.js +197 -171
- package/lib/rules/id-match.js +344 -289
- package/lib/rules/implicit-arrow-linebreak.js +102 -79
- package/lib/rules/indent-legacy.js +1344 -1118
- package/lib/rules/indent.js +2272 -1759
- package/lib/rules/index.js +317 -292
- package/lib/rules/init-declarations.js +137 -107
- package/lib/rules/jsx-quotes.js +94 -82
- package/lib/rules/key-spacing.js +750 -633
- package/lib/rules/keyword-spacing.js +648 -605
- package/lib/rules/line-comment-position.js +142 -128
- package/lib/rules/linebreak-style.js +107 -106
- package/lib/rules/lines-around-comment.js +540 -448
- package/lib/rules/lines-around-directive.js +233 -203
- package/lib/rules/lines-between-class-members.js +305 -234
- package/lib/rules/logical-assignment-operators.js +582 -399
- package/lib/rules/max-classes-per-file.js +69 -68
- package/lib/rules/max-depth.js +146 -143
- package/lib/rules/max-len.js +473 -434
- package/lib/rules/max-lines-per-function.js +201 -176
- package/lib/rules/max-lines.js +158 -162
- package/lib/rules/max-nested-callbacks.js +102 -104
- package/lib/rules/max-params.js +78 -76
- package/lib/rules/max-statements-per-line.js +205 -198
- package/lib/rules/max-statements.js +168 -164
- package/lib/rules/multiline-comment-style.js +637 -479
- package/lib/rules/multiline-ternary.js +241 -176
- package/lib/rules/new-cap.js +233 -213
- package/lib/rules/new-parens.js +88 -79
- package/lib/rules/newline-after-var.js +287 -250
- package/lib/rules/newline-before-return.js +229 -222
- package/lib/rules/newline-per-chained-call.js +142 -127
- package/lib/rules/no-alert.js +90 -79
- package/lib/rules/no-array-constructor.js +125 -113
- package/lib/rules/no-async-promise-executor.js +30 -24
- package/lib/rules/no-await-in-loop.js +69 -71
- package/lib/rules/no-bitwise.js +124 -100
- package/lib/rules/no-buffer-constructor.js +55 -47
- package/lib/rules/no-caller.js +39 -33
- package/lib/rules/no-case-declarations.js +61 -57
- package/lib/rules/no-catch-shadow.js +76 -73
- package/lib/rules/no-class-assign.js +51 -48
- package/lib/rules/no-compare-neg-zero.js +62 -48
- package/lib/rules/no-cond-assign.js +148 -132
- package/lib/rules/no-confusing-arrow.js +98 -81
- package/lib/rules/no-console.js +202 -199
- package/lib/rules/no-const-assign.js +47 -41
- package/lib/rules/no-constant-binary-expression.js +500 -405
- package/lib/rules/no-constant-condition.js +158 -143
- package/lib/rules/no-constructor-return.js +49 -49
- package/lib/rules/no-continue.js +25 -27
- package/lib/rules/no-control-regex.js +125 -121
- package/lib/rules/no-debugger.js +28 -30
- package/lib/rules/no-delete-var.js +29 -29
- package/lib/rules/no-div-regex.js +47 -41
- package/lib/rules/no-dupe-args.js +68 -69
- package/lib/rules/no-dupe-class-members.js +102 -89
- package/lib/rules/no-dupe-else-if.js +100 -77
- package/lib/rules/no-dupe-keys.js +133 -110
- package/lib/rules/no-duplicate-case.js +50 -43
- package/lib/rules/no-duplicate-imports.js +179 -176
- package/lib/rules/no-else-return.js +430 -385
- package/lib/rules/no-empty-character-class.js +57 -50
- package/lib/rules/no-empty-function.js +127 -128
- package/lib/rules/no-empty-pattern.js +63 -58
- package/lib/rules/no-empty-static-block.js +37 -35
- package/lib/rules/no-empty.js +98 -86
- package/lib/rules/no-eq-null.js +37 -32
- package/lib/rules/no-eval.js +256 -250
- package/lib/rules/no-ex-assign.js +42 -39
- package/lib/rules/no-extend-native.js +161 -159
- package/lib/rules/no-extra-bind.js +201 -190
- package/lib/rules/no-extra-boolean-cast.js +398 -348
- package/lib/rules/no-extra-label.js +150 -131
- package/lib/rules/no-extra-parens.js +1654 -1325
- package/lib/rules/no-extra-semi.js +146 -144
- package/lib/rules/no-fallthrough.js +199 -157
- package/lib/rules/no-floating-decimal.js +74 -66
- package/lib/rules/no-func-assign.js +54 -55
- package/lib/rules/no-global-assign.js +78 -73
- package/lib/rules/no-implicit-coercion.js +349 -293
- package/lib/rules/no-implicit-globals.js +158 -135
- package/lib/rules/no-implied-eval.js +140 -112
- package/lib/rules/no-import-assign.js +145 -159
- package/lib/rules/no-inline-comments.js +101 -95
- package/lib/rules/no-inner-declarations.js +115 -101
- package/lib/rules/no-invalid-regexp.js +222 -190
- package/lib/rules/no-invalid-this.js +123 -117
- package/lib/rules/no-irregular-whitespace.js +266 -252
- package/lib/rules/no-iterator.js +29 -33
- package/lib/rules/no-label-var.js +59 -62
- package/lib/rules/no-labels.js +138 -133
- package/lib/rules/no-lone-blocks.js +127 -123
- package/lib/rules/no-lonely-if.js +108 -77
- package/lib/rules/no-loop-func.js +238 -213
- package/lib/rules/no-loss-of-precision.js +218 -201
- package/lib/rules/no-magic-numbers.js +246 -218
- package/lib/rules/no-misleading-character-class.js +499 -446
- package/lib/rules/no-mixed-operators.js +188 -182
- package/lib/rules/no-mixed-requires.js +253 -240
- package/lib/rules/no-mixed-spaces-and-tabs.js +134 -121
- package/lib/rules/no-multi-assign.js +46 -44
- package/lib/rules/no-multi-spaces.js +163 -143
- package/lib/rules/no-multi-str.js +42 -41
- package/lib/rules/no-multiple-empty-lines.js +196 -158
- package/lib/rules/no-native-reassign.js +90 -85
- package/lib/rules/no-negated-condition.js +79 -75
- package/lib/rules/no-negated-in-lhs.js +45 -43
- package/lib/rules/no-nested-ternary.js +33 -32
- package/lib/rules/no-new-func.js +71 -62
- package/lib/rules/no-new-native-nonconstructor.js +43 -39
- package/lib/rules/no-new-object.js +48 -48
- package/lib/rules/no-new-require.js +48 -47
- package/lib/rules/no-new-symbol.js +52 -50
- package/lib/rules/no-new-wrappers.js +43 -41
- package/lib/rules/no-new.js +28 -29
- package/lib/rules/no-nonoctal-decimal-escape.js +141 -121
- package/lib/rules/no-obj-calls.js +66 -53
- package/lib/rules/no-object-constructor.js +104 -97
- package/lib/rules/no-octal-escape.js +40 -43
- package/lib/rules/no-octal.js +32 -32
- package/lib/rules/no-param-reassign.js +235 -217
- package/lib/rules/no-path-concat.js +66 -67
- package/lib/rules/no-plusplus.js +60 -61
- package/lib/rules/no-process-env.js +49 -48
- package/lib/rules/no-process-exit.js +54 -50
- package/lib/rules/no-promise-executor-return.js +214 -182
- package/lib/rules/no-proto.js +26 -29
- package/lib/rules/no-prototype-builtins.js +146 -124
- package/lib/rules/no-redeclare.js +154 -152
- package/lib/rules/no-regex-spaces.js +183 -161
- package/lib/rules/no-restricted-exports.js +208 -185
- package/lib/rules/no-restricted-globals.js +111 -112
- package/lib/rules/no-restricted-imports.js +657 -537
- package/lib/rules/no-restricted-modules.js +222 -202
- package/lib/rules/no-restricted-properties.js +181 -153
- package/lib/rules/no-restricted-syntax.js +56 -52
- package/lib/rules/no-return-assign.js +55 -50
- package/lib/rules/no-return-await.js +148 -124
- package/lib/rules/no-script-url.js +52 -45
- package/lib/rules/no-self-assign.js +148 -146
- package/lib/rules/no-self-compare.js +63 -46
- package/lib/rules/no-sequences.js +135 -116
- package/lib/rules/no-setter-return.js +185 -152
- package/lib/rules/no-shadow-restricted-names.js +61 -46
- package/lib/rules/no-shadow.js +342 -316
- package/lib/rules/no-spaced-func.js +82 -77
- package/lib/rules/no-sparse-arrays.js +54 -59
- package/lib/rules/no-sync.js +61 -60
- package/lib/rules/no-tabs.js +83 -72
- package/lib/rules/no-template-curly-in-string.js +33 -32
- package/lib/rules/no-ternary.js +25 -29
- package/lib/rules/no-this-before-super.js +321 -319
- package/lib/rules/no-throw-literal.js +31 -36
- package/lib/rules/no-trailing-spaces.js +199 -191
- package/lib/rules/no-undef-init.js +76 -61
- package/lib/rules/no-undef.js +51 -48
- package/lib/rules/no-undefined.js +73 -75
- package/lib/rules/no-underscore-dangle.js +370 -327
- package/lib/rules/no-unexpected-multiline.js +112 -102
- package/lib/rules/no-unmodified-loop-condition.js +254 -254
- package/lib/rules/no-unneeded-ternary.js +212 -147
- package/lib/rules/no-unreachable-loop.js +145 -142
- package/lib/rules/no-unreachable.js +255 -248
- package/lib/rules/no-unsafe-finally.js +93 -85
- package/lib/rules/no-unsafe-negation.js +105 -83
- package/lib/rules/no-unsafe-optional-chaining.js +192 -178
- package/lib/rules/no-unused-expressions.js +178 -162
- package/lib/rules/no-unused-labels.js +139 -124
- package/lib/rules/no-unused-private-class-members.js +206 -182
- package/lib/rules/no-unused-vars.js +1669 -1449
- package/lib/rules/no-use-before-define.js +229 -231
- package/lib/rules/no-useless-assignment.js +590 -511
- package/lib/rules/no-useless-backreference.js +212 -193
- package/lib/rules/no-useless-call.js +58 -53
- package/lib/rules/no-useless-catch.js +40 -40
- package/lib/rules/no-useless-computed-key.js +144 -115
- package/lib/rules/no-useless-concat.js +65 -60
- package/lib/rules/no-useless-constructor.js +158 -111
- package/lib/rules/no-useless-escape.js +342 -291
- package/lib/rules/no-useless-rename.js +183 -156
- package/lib/rules/no-useless-return.js +344 -312
- package/lib/rules/no-var.js +233 -212
- package/lib/rules/no-void.js +50 -48
- package/lib/rules/no-warning-comments.js +191 -186
- package/lib/rules/no-whitespace-before-property.js +131 -115
- package/lib/rules/no-with.js +24 -26
- package/lib/rules/nonblock-statement-body-position.js +149 -130
- package/lib/rules/object-curly-newline.js +306 -265
- package/lib/rules/object-curly-spacing.js +360 -314
- package/lib/rules/object-property-newline.js +137 -106
- package/lib/rules/object-shorthand.js +607 -502
- package/lib/rules/one-var-declaration-per-line.js +104 -100
- package/lib/rules/one-var.js +653 -537
- package/lib/rules/operator-assignment.js +219 -161
- package/lib/rules/operator-linebreak.js +295 -251
- package/lib/rules/padded-blocks.js +346 -308
- package/lib/rules/padding-line-between-statements.js +443 -439
- package/lib/rules/prefer-arrow-callback.js +362 -313
- package/lib/rules/prefer-const.js +418 -377
- package/lib/rules/prefer-destructuring.js +301 -279
- package/lib/rules/prefer-exponentiation-operator.js +176 -133
- package/lib/rules/prefer-named-capture-group.js +153 -140
- package/lib/rules/prefer-numeric-literals.js +121 -113
- package/lib/rules/prefer-object-has-own.js +116 -82
- package/lib/rules/prefer-object-spread.js +213 -193
- package/lib/rules/prefer-promise-reject-errors.js +140 -122
- package/lib/rules/prefer-reflect.js +127 -107
- package/lib/rules/prefer-regex-literals.js +578 -466
- package/lib/rules/prefer-rest-params.js +79 -80
- package/lib/rules/prefer-spread.js +47 -44
- package/lib/rules/prefer-template.js +266 -195
- package/lib/rules/quote-props.js +373 -307
- package/lib/rules/quotes.js +374 -326
- package/lib/rules/radix.js +152 -136
- package/lib/rules/require-atomic-updates.js +316 -285
- package/lib/rules/require-await.js +144 -116
- package/lib/rules/require-unicode-regexp.js +282 -177
- package/lib/rules/require-yield.js +53 -54
- package/lib/rules/rest-spread-spacing.js +128 -116
- package/lib/rules/semi-spacing.js +281 -250
- package/lib/rules/semi-style.js +176 -134
- package/lib/rules/semi.js +456 -436
- package/lib/rules/sort-imports.js +306 -233
- package/lib/rules/sort-keys.js +219 -188
- package/lib/rules/sort-vars.js +127 -93
- package/lib/rules/space-before-blocks.js +199 -189
- package/lib/rules/space-before-function-paren.js +186 -166
- package/lib/rules/space-in-parens.js +359 -288
- package/lib/rules/space-infix-ops.js +237 -201
- package/lib/rules/space-unary-ops.js +356 -298
- package/lib/rules/spaced-comment.js +363 -319
- package/lib/rules/strict.js +265 -230
- package/lib/rules/switch-colon-spacing.js +130 -122
- package/lib/rules/symbol-description.js +45 -48
- package/lib/rules/template-curly-spacing.js +148 -142
- package/lib/rules/template-tag-spacing.js +98 -88
- package/lib/rules/unicode-bom.js +54 -56
- package/lib/rules/use-isnan.js +237 -206
- package/lib/rules/utils/ast-utils.js +2039 -1860
- package/lib/rules/utils/char-source.js +162 -155
- package/lib/rules/utils/fix-tracker.js +83 -80
- package/lib/rules/utils/keywords.js +59 -59
- package/lib/rules/utils/lazy-loading-rule-map.js +79 -76
- package/lib/rules/utils/regular-expressions.js +32 -24
- package/lib/rules/utils/unicode/index.js +4 -4
- package/lib/rules/utils/unicode/is-combining-character.js +1 -1
- package/lib/rules/utils/unicode/is-emoji-modifier.js +1 -1
- package/lib/rules/utils/unicode/is-regional-indicator-symbol.js +1 -1
- package/lib/rules/utils/unicode/is-surrogate-pair.js +1 -1
- package/lib/rules/valid-typeof.js +153 -111
- package/lib/rules/vars-on-top.js +152 -145
- package/lib/rules/wrap-iife.js +204 -191
- package/lib/rules/wrap-regex.js +70 -58
- package/lib/rules/yield-star-spacing.js +145 -134
- package/lib/rules/yoda.js +283 -272
- package/lib/services/parser-service.js +35 -35
- package/lib/services/processor-service.js +66 -73
- package/lib/services/suppressions-service.js +289 -0
- package/lib/shared/ajv.js +14 -14
- package/lib/shared/assert.js +3 -4
- package/lib/shared/ast-utils.js +7 -6
- package/lib/shared/deep-merge-arrays.js +24 -22
- package/lib/shared/directives.js +3 -2
- package/lib/shared/flags.js +50 -17
- package/lib/shared/logging.js +24 -25
- package/lib/shared/option-utils.js +43 -36
- package/lib/shared/runtime-info.js +136 -127
- package/lib/shared/serialization.js +27 -27
- package/lib/shared/severity.js +22 -22
- package/lib/shared/stats.js +5 -5
- package/lib/shared/string-utils.js +16 -16
- package/lib/shared/text-table.js +28 -27
- package/lib/shared/traverser.js +153 -146
- package/lib/shared/types.js +4 -27
- package/lib/types/index.d.ts +2010 -1559
- package/lib/types/rules.d.ts +5253 -5140
- package/lib/types/use-at-your-own-risk.d.ts +32 -30
- package/lib/unsupported-api.js +5 -5
- package/messages/all-files-ignored.js +3 -3
- package/messages/all-matched-files-ignored.js +3 -3
- package/messages/config-file-missing.js +2 -2
- package/messages/config-plugin-missing.js +3 -3
- package/messages/config-serialize-function.js +9 -7
- package/messages/eslintrc-incompat.js +13 -15
- package/messages/eslintrc-plugins.js +3 -4
- package/messages/extend-config-missing.js +3 -3
- package/messages/failed-to-read-json.js +3 -3
- package/messages/file-not-found.js +3 -3
- package/messages/invalid-rule-options.js +2 -2
- package/messages/invalid-rule-severity.js +2 -2
- package/messages/no-config-found.js +3 -3
- package/messages/plugin-conflict.js +8 -8
- package/messages/plugin-invalid.js +3 -3
- package/messages/plugin-missing.js +3 -3
- package/messages/print-config-with-directory-path.js +2 -2
- package/messages/shared.js +6 -1
- package/messages/whitespace-found.js +3 -3
- package/package.json +14 -20
@@ -42,10 +42,7 @@ const escapeRegExp = require("escape-string-regexp");
|
|
42
42
|
const { Minimatch } = require("minimatch");
|
43
43
|
|
44
44
|
const {
|
45
|
-
|
46
|
-
IgnorePattern,
|
47
|
-
CascadingConfigArrayFactory
|
48
|
-
}
|
45
|
+
Legacy: { IgnorePattern, CascadingConfigArrayFactory },
|
49
46
|
} = require("@eslint/eslintrc");
|
50
47
|
const debug = require("debug")("eslint:file-enumerator");
|
51
48
|
|
@@ -108,7 +105,7 @@ const internalSlotsMap = new WeakMap();
|
|
108
105
|
* @returns {boolean} `true` if the string is a glob pattern.
|
109
106
|
*/
|
110
107
|
function isGlobPattern(pattern) {
|
111
|
-
|
108
|
+
return isGlob(path.sep === "\\" ? pattern.replace(/\\/gu, "/") : pattern);
|
112
109
|
}
|
113
110
|
|
114
111
|
/**
|
@@ -119,16 +116,15 @@ function isGlobPattern(pattern) {
|
|
119
116
|
* @private
|
120
117
|
*/
|
121
118
|
function statSafeSync(filePath) {
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
}
|
119
|
+
try {
|
120
|
+
return fs.statSync(filePath);
|
121
|
+
} catch (error) {
|
122
|
+
/* c8 ignore next */
|
123
|
+
if (error.code !== "ENOENT") {
|
124
|
+
throw error;
|
125
|
+
}
|
126
|
+
return null;
|
127
|
+
}
|
132
128
|
}
|
133
129
|
|
134
130
|
/**
|
@@ -139,16 +135,15 @@ function statSafeSync(filePath) {
|
|
139
135
|
* @private
|
140
136
|
*/
|
141
137
|
function readdirSafeSync(directoryPath) {
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
}
|
138
|
+
try {
|
139
|
+
return fs.readdirSync(directoryPath, { withFileTypes: true });
|
140
|
+
} catch (error) {
|
141
|
+
/* c8 ignore next */
|
142
|
+
if (error.code !== "ENOENT") {
|
143
|
+
throw error;
|
144
|
+
}
|
145
|
+
return [];
|
146
|
+
}
|
152
147
|
}
|
153
148
|
|
154
149
|
/**
|
@@ -157,50 +152,45 @@ function readdirSafeSync(directoryPath) {
|
|
157
152
|
* @returns {RegExp | null} The created `RegExp` object or null.
|
158
153
|
*/
|
159
154
|
function createExtensionRegExp(extensions) {
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
`.\\.(?:${normalizedExts.join("|")})$`,
|
169
|
-
"u"
|
170
|
-
);
|
171
|
-
}
|
172
|
-
return null;
|
155
|
+
if (extensions) {
|
156
|
+
const normalizedExts = extensions.map(ext =>
|
157
|
+
escapeRegExp(ext.startsWith(".") ? ext.slice(1) : ext),
|
158
|
+
);
|
159
|
+
|
160
|
+
return new RegExp(`.\\.(?:${normalizedExts.join("|")})$`, "u");
|
161
|
+
}
|
162
|
+
return null;
|
173
163
|
}
|
174
164
|
|
175
165
|
/**
|
176
166
|
* The error type when no files match a glob.
|
177
167
|
*/
|
178
168
|
class NoFilesFoundError extends Error {
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
169
|
+
/**
|
170
|
+
* @param {string} pattern The glob pattern which was not found.
|
171
|
+
* @param {boolean} globDisabled If `true` then the pattern was a glob pattern, but glob was disabled.
|
172
|
+
*/
|
173
|
+
constructor(pattern, globDisabled) {
|
174
|
+
super(
|
175
|
+
`No files matching '${pattern}' were found${globDisabled ? " (glob was disabled)" : ""}.`,
|
176
|
+
);
|
177
|
+
this.messageTemplate = "file-not-found";
|
178
|
+
this.messageData = { pattern, globDisabled };
|
179
|
+
}
|
189
180
|
}
|
190
181
|
|
191
182
|
/**
|
192
183
|
* The error type when there are files matched by a glob, but all of them have been ignored.
|
193
184
|
*/
|
194
185
|
class AllFilesIgnoredError extends Error {
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
}
|
186
|
+
/**
|
187
|
+
* @param {string} pattern The glob pattern which was not found.
|
188
|
+
*/
|
189
|
+
constructor(pattern) {
|
190
|
+
super(`All files matched by '${pattern}' are ignored.`);
|
191
|
+
this.messageTemplate = "all-files-ignored";
|
192
|
+
this.messageData = { pattern };
|
193
|
+
}
|
204
194
|
}
|
205
195
|
|
206
196
|
/**
|
@@ -208,336 +198,340 @@ class AllFilesIgnoredError extends Error {
|
|
208
198
|
* matched by given glob patterns and that configuration.
|
209
199
|
*/
|
210
200
|
class FileEnumerator {
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
|
304
|
-
|
305
|
-
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
|
337
|
-
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
|
372
|
-
|
373
|
-
|
374
|
-
|
375
|
-
|
376
|
-
|
377
|
-
|
378
|
-
|
379
|
-
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
|
384
|
-
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
|
389
|
-
|
390
|
-
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
|
409
|
-
|
410
|
-
|
411
|
-
|
412
|
-
|
413
|
-
|
414
|
-
|
415
|
-
|
416
|
-
|
417
|
-
|
418
|
-
|
419
|
-
|
420
|
-
|
421
|
-
|
422
|
-
|
423
|
-
|
424
|
-
|
425
|
-
|
426
|
-
|
427
|
-
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
|
451
|
-
|
452
|
-
|
453
|
-
|
454
|
-
|
455
|
-
|
456
|
-
|
457
|
-
|
458
|
-
|
459
|
-
|
460
|
-
|
461
|
-
|
462
|
-
|
463
|
-
|
464
|
-
|
465
|
-
|
466
|
-
|
467
|
-
|
468
|
-
|
469
|
-
|
470
|
-
|
471
|
-
|
472
|
-
|
473
|
-
|
474
|
-
|
475
|
-
|
476
|
-
|
477
|
-
|
478
|
-
|
479
|
-
|
480
|
-
|
481
|
-
|
482
|
-
|
483
|
-
|
484
|
-
|
485
|
-
|
486
|
-
|
487
|
-
|
488
|
-
|
489
|
-
|
490
|
-
|
491
|
-
|
492
|
-
|
493
|
-
|
494
|
-
|
495
|
-
|
496
|
-
|
497
|
-
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
|
509
|
-
|
510
|
-
|
511
|
-
|
512
|
-
|
513
|
-
|
514
|
-
|
515
|
-
|
516
|
-
|
517
|
-
|
518
|
-
|
519
|
-
|
520
|
-
|
521
|
-
|
522
|
-
|
523
|
-
|
524
|
-
|
525
|
-
|
526
|
-
|
527
|
-
|
528
|
-
|
529
|
-
|
530
|
-
|
531
|
-
|
532
|
-
|
533
|
-
|
534
|
-
|
535
|
-
|
536
|
-
|
537
|
-
|
538
|
-
|
539
|
-
|
540
|
-
|
201
|
+
/**
|
202
|
+
* Initialize this enumerator.
|
203
|
+
* @param {FileEnumeratorOptions} options The options.
|
204
|
+
*/
|
205
|
+
constructor({
|
206
|
+
cwd = process.cwd(),
|
207
|
+
configArrayFactory = new CascadingConfigArrayFactory({
|
208
|
+
cwd,
|
209
|
+
getEslintRecommendedConfig: () =>
|
210
|
+
require("@eslint/js").configs.recommended,
|
211
|
+
getEslintAllConfig: () => require("@eslint/js").configs.all,
|
212
|
+
}),
|
213
|
+
extensions = null,
|
214
|
+
globInputPaths = true,
|
215
|
+
errorOnUnmatchedPattern = true,
|
216
|
+
ignore = true,
|
217
|
+
} = {}) {
|
218
|
+
internalSlotsMap.set(this, {
|
219
|
+
configArrayFactory,
|
220
|
+
cwd,
|
221
|
+
defaultIgnores: IgnorePattern.createDefaultIgnore(cwd),
|
222
|
+
extensionRegExp: createExtensionRegExp(extensions),
|
223
|
+
globInputPaths,
|
224
|
+
errorOnUnmatchedPattern,
|
225
|
+
ignoreFlag: ignore,
|
226
|
+
});
|
227
|
+
}
|
228
|
+
|
229
|
+
/**
|
230
|
+
* Check if a given file is target or not.
|
231
|
+
* @param {string} filePath The path to a candidate file.
|
232
|
+
* @param {ConfigArray} [providedConfig] Optional. The configuration for the file.
|
233
|
+
* @returns {boolean} `true` if the file is a target.
|
234
|
+
*/
|
235
|
+
isTargetPath(filePath, providedConfig) {
|
236
|
+
const { configArrayFactory, extensionRegExp } =
|
237
|
+
internalSlotsMap.get(this);
|
238
|
+
|
239
|
+
// If `--ext` option is present, use it.
|
240
|
+
if (extensionRegExp) {
|
241
|
+
return extensionRegExp.test(filePath);
|
242
|
+
}
|
243
|
+
|
244
|
+
// `.js` file is target by default.
|
245
|
+
if (filePath.endsWith(".js")) {
|
246
|
+
return true;
|
247
|
+
}
|
248
|
+
|
249
|
+
// use `overrides[].files` to check additional targets.
|
250
|
+
const config =
|
251
|
+
providedConfig ||
|
252
|
+
configArrayFactory.getConfigArrayForFile(filePath, {
|
253
|
+
ignoreNotFoundError: true,
|
254
|
+
});
|
255
|
+
|
256
|
+
return config.isAdditionalTargetPath(filePath);
|
257
|
+
}
|
258
|
+
|
259
|
+
/**
|
260
|
+
* Iterate files which are matched by given glob patterns.
|
261
|
+
* @param {string|string[]} patternOrPatterns The glob patterns to iterate files.
|
262
|
+
* @throws {NoFilesFoundError|AllFilesIgnoredError} On an unmatched pattern.
|
263
|
+
* @returns {IterableIterator<FileAndConfig>} The found files.
|
264
|
+
*/
|
265
|
+
*iterateFiles(patternOrPatterns) {
|
266
|
+
const { globInputPaths, errorOnUnmatchedPattern } =
|
267
|
+
internalSlotsMap.get(this);
|
268
|
+
const patterns = Array.isArray(patternOrPatterns)
|
269
|
+
? patternOrPatterns
|
270
|
+
: [patternOrPatterns];
|
271
|
+
|
272
|
+
debug("Start to iterate files: %o", patterns);
|
273
|
+
|
274
|
+
// The set of paths to remove duplicate.
|
275
|
+
const set = new Set();
|
276
|
+
|
277
|
+
for (const pattern of patterns) {
|
278
|
+
let foundRegardlessOfIgnored = false;
|
279
|
+
let found = false;
|
280
|
+
|
281
|
+
// Skip empty string.
|
282
|
+
if (!pattern) {
|
283
|
+
continue;
|
284
|
+
}
|
285
|
+
|
286
|
+
// Iterate files of this pattern.
|
287
|
+
for (const { config, filePath, flag } of this._iterateFiles(
|
288
|
+
pattern,
|
289
|
+
)) {
|
290
|
+
foundRegardlessOfIgnored = true;
|
291
|
+
if (flag === IGNORED_SILENTLY) {
|
292
|
+
continue;
|
293
|
+
}
|
294
|
+
found = true;
|
295
|
+
|
296
|
+
// Remove duplicate paths while yielding paths.
|
297
|
+
if (!set.has(filePath)) {
|
298
|
+
set.add(filePath);
|
299
|
+
yield {
|
300
|
+
config,
|
301
|
+
filePath,
|
302
|
+
ignored: flag === IGNORED,
|
303
|
+
};
|
304
|
+
}
|
305
|
+
}
|
306
|
+
|
307
|
+
// Raise an error if any files were not found.
|
308
|
+
if (errorOnUnmatchedPattern) {
|
309
|
+
if (!foundRegardlessOfIgnored) {
|
310
|
+
throw new NoFilesFoundError(
|
311
|
+
pattern,
|
312
|
+
!globInputPaths && isGlob(pattern),
|
313
|
+
);
|
314
|
+
}
|
315
|
+
if (!found) {
|
316
|
+
throw new AllFilesIgnoredError(pattern);
|
317
|
+
}
|
318
|
+
}
|
319
|
+
}
|
320
|
+
|
321
|
+
debug(`Complete iterating files: ${JSON.stringify(patterns)}`);
|
322
|
+
}
|
323
|
+
|
324
|
+
/**
|
325
|
+
* Iterate files which are matched by a given glob pattern.
|
326
|
+
* @param {string} pattern The glob pattern to iterate files.
|
327
|
+
* @returns {IterableIterator<FileEntry>} The found files.
|
328
|
+
*/
|
329
|
+
_iterateFiles(pattern) {
|
330
|
+
const { cwd, globInputPaths } = internalSlotsMap.get(this);
|
331
|
+
const absolutePath = path.resolve(cwd, pattern);
|
332
|
+
const isDot = dotfilesPattern.test(pattern);
|
333
|
+
const stat = statSafeSync(absolutePath);
|
334
|
+
|
335
|
+
if (stat && stat.isDirectory()) {
|
336
|
+
return this._iterateFilesWithDirectory(absolutePath, isDot);
|
337
|
+
}
|
338
|
+
if (stat && stat.isFile()) {
|
339
|
+
return this._iterateFilesWithFile(absolutePath);
|
340
|
+
}
|
341
|
+
if (globInputPaths && isGlobPattern(pattern)) {
|
342
|
+
return this._iterateFilesWithGlob(pattern, isDot);
|
343
|
+
}
|
344
|
+
|
345
|
+
return [];
|
346
|
+
}
|
347
|
+
|
348
|
+
/**
|
349
|
+
* Iterate a file which is matched by a given path.
|
350
|
+
* @param {string} filePath The path to the target file.
|
351
|
+
* @returns {IterableIterator<FileEntry>} The found files.
|
352
|
+
* @private
|
353
|
+
*/
|
354
|
+
_iterateFilesWithFile(filePath) {
|
355
|
+
debug(`File: ${filePath}`);
|
356
|
+
|
357
|
+
const { configArrayFactory } = internalSlotsMap.get(this);
|
358
|
+
const config = configArrayFactory.getConfigArrayForFile(filePath);
|
359
|
+
const ignored = this._isIgnoredFile(filePath, { config, direct: true });
|
360
|
+
const flag = ignored ? IGNORED : NONE;
|
361
|
+
|
362
|
+
return [{ config, filePath, flag }];
|
363
|
+
}
|
364
|
+
|
365
|
+
/**
|
366
|
+
* Iterate files in a given path.
|
367
|
+
* @param {string} directoryPath The path to the target directory.
|
368
|
+
* @param {boolean} dotfiles If `true` then it doesn't skip dot files by default.
|
369
|
+
* @returns {IterableIterator<FileEntry>} The found files.
|
370
|
+
* @private
|
371
|
+
*/
|
372
|
+
_iterateFilesWithDirectory(directoryPath, dotfiles) {
|
373
|
+
debug(`Directory: ${directoryPath}`);
|
374
|
+
|
375
|
+
return this._iterateFilesRecursive(directoryPath, {
|
376
|
+
dotfiles,
|
377
|
+
recursive: true,
|
378
|
+
selector: null,
|
379
|
+
});
|
380
|
+
}
|
381
|
+
|
382
|
+
/**
|
383
|
+
* Iterate files which are matched by a given glob pattern.
|
384
|
+
* @param {string} pattern The glob pattern to iterate files.
|
385
|
+
* @param {boolean} dotfiles If `true` then it doesn't skip dot files by default.
|
386
|
+
* @returns {IterableIterator<FileEntry>} The found files.
|
387
|
+
* @private
|
388
|
+
*/
|
389
|
+
_iterateFilesWithGlob(pattern, dotfiles) {
|
390
|
+
debug(`Glob: ${pattern}`);
|
391
|
+
|
392
|
+
const { cwd } = internalSlotsMap.get(this);
|
393
|
+
const directoryPath = path.resolve(cwd, getGlobParent(pattern));
|
394
|
+
const absolutePath = path.resolve(cwd, pattern);
|
395
|
+
const globPart = absolutePath.slice(directoryPath.length + 1);
|
396
|
+
|
397
|
+
/*
|
398
|
+
* recursive if there are `**` or path separators in the glob part.
|
399
|
+
* Otherwise, patterns such as `src/*.js`, it doesn't need recursive.
|
400
|
+
*/
|
401
|
+
const recursive = /\*\*|\/|\\/u.test(globPart);
|
402
|
+
const selector = new Minimatch(absolutePath, minimatchOpts);
|
403
|
+
|
404
|
+
debug(`recursive? ${recursive}`);
|
405
|
+
|
406
|
+
return this._iterateFilesRecursive(directoryPath, {
|
407
|
+
dotfiles,
|
408
|
+
recursive,
|
409
|
+
selector,
|
410
|
+
});
|
411
|
+
}
|
412
|
+
|
413
|
+
/**
|
414
|
+
* Iterate files in a given path.
|
415
|
+
* @param {string} directoryPath The path to the target directory.
|
416
|
+
* @param {Object} options The options to iterate files.
|
417
|
+
* @param {boolean} [options.dotfiles] If `true` then it doesn't skip dot files by default.
|
418
|
+
* @param {boolean} [options.recursive] If `true` then it dives into sub directories.
|
419
|
+
* @param {InstanceType<Minimatch>} [options.selector] The matcher to choose files.
|
420
|
+
* @returns {IterableIterator<FileEntry>} The found files.
|
421
|
+
* @private
|
422
|
+
*/
|
423
|
+
*_iterateFilesRecursive(directoryPath, options) {
|
424
|
+
debug(`Enter the directory: ${directoryPath}`);
|
425
|
+
const { configArrayFactory } = internalSlotsMap.get(this);
|
426
|
+
|
427
|
+
/** @type {ConfigArray|null} */
|
428
|
+
let config = null;
|
429
|
+
|
430
|
+
// Enumerate the files of this directory.
|
431
|
+
for (const entry of readdirSafeSync(directoryPath)) {
|
432
|
+
const filePath = path.join(directoryPath, entry.name);
|
433
|
+
const fileInfo = entry.isSymbolicLink()
|
434
|
+
? statSafeSync(filePath)
|
435
|
+
: entry;
|
436
|
+
|
437
|
+
if (!fileInfo) {
|
438
|
+
continue;
|
439
|
+
}
|
440
|
+
|
441
|
+
// Check if the file is matched.
|
442
|
+
if (fileInfo.isFile()) {
|
443
|
+
if (!config) {
|
444
|
+
config = configArrayFactory.getConfigArrayForFile(
|
445
|
+
filePath,
|
446
|
+
|
447
|
+
/*
|
448
|
+
* We must ignore `ConfigurationNotFoundError` at this
|
449
|
+
* point because we don't know if target files exist in
|
450
|
+
* this directory.
|
451
|
+
*/
|
452
|
+
{ ignoreNotFoundError: true },
|
453
|
+
);
|
454
|
+
}
|
455
|
+
const matched = options.selector
|
456
|
+
? // Started with a glob pattern; choose by the pattern.
|
457
|
+
options.selector.match(filePath)
|
458
|
+
: // Started with a directory path; choose by file extensions.
|
459
|
+
this.isTargetPath(filePath, config);
|
460
|
+
|
461
|
+
if (matched) {
|
462
|
+
const ignored = this._isIgnoredFile(filePath, {
|
463
|
+
...options,
|
464
|
+
config,
|
465
|
+
});
|
466
|
+
const flag = ignored ? IGNORED_SILENTLY : NONE;
|
467
|
+
|
468
|
+
debug(
|
469
|
+
`Yield: ${entry.name}${ignored ? " but ignored" : ""}`,
|
470
|
+
);
|
471
|
+
yield {
|
472
|
+
config: configArrayFactory.getConfigArrayForFile(
|
473
|
+
filePath,
|
474
|
+
),
|
475
|
+
filePath,
|
476
|
+
flag,
|
477
|
+
};
|
478
|
+
} else {
|
479
|
+
debug(`Didn't match: ${entry.name}`);
|
480
|
+
}
|
481
|
+
|
482
|
+
// Dive into the sub directory.
|
483
|
+
} else if (options.recursive && fileInfo.isDirectory()) {
|
484
|
+
if (!config) {
|
485
|
+
config = configArrayFactory.getConfigArrayForFile(
|
486
|
+
filePath,
|
487
|
+
{ ignoreNotFoundError: true },
|
488
|
+
);
|
489
|
+
}
|
490
|
+
const ignored = this._isIgnoredFile(filePath + path.sep, {
|
491
|
+
...options,
|
492
|
+
config,
|
493
|
+
});
|
494
|
+
|
495
|
+
if (!ignored) {
|
496
|
+
yield* this._iterateFilesRecursive(filePath, options);
|
497
|
+
}
|
498
|
+
}
|
499
|
+
}
|
500
|
+
|
501
|
+
debug(`Leave the directory: ${directoryPath}`);
|
502
|
+
}
|
503
|
+
|
504
|
+
/**
|
505
|
+
* Check if a given file should be ignored.
|
506
|
+
* @param {string} filePath The path to a file to check.
|
507
|
+
* @param {Object} options Options
|
508
|
+
* @param {ConfigArray} [options.config] The config for this file.
|
509
|
+
* @param {boolean} [options.dotfiles] If `true` then this is not ignore dot files by default.
|
510
|
+
* @param {boolean} [options.direct] If `true` then this is a direct specified file.
|
511
|
+
* @returns {boolean} `true` if the file should be ignored.
|
512
|
+
* @private
|
513
|
+
*/
|
514
|
+
_isIgnoredFile(
|
515
|
+
filePath,
|
516
|
+
{ config: providedConfig, dotfiles = false, direct = false },
|
517
|
+
) {
|
518
|
+
const { configArrayFactory, defaultIgnores, ignoreFlag } =
|
519
|
+
internalSlotsMap.get(this);
|
520
|
+
|
521
|
+
if (ignoreFlag) {
|
522
|
+
const config =
|
523
|
+
providedConfig ||
|
524
|
+
configArrayFactory.getConfigArrayForFile(filePath, {
|
525
|
+
ignoreNotFoundError: true,
|
526
|
+
});
|
527
|
+
const ignores =
|
528
|
+
config.extractConfig(filePath).ignores || defaultIgnores;
|
529
|
+
|
530
|
+
return ignores(filePath, dotfiles);
|
531
|
+
}
|
532
|
+
|
533
|
+
return !direct && defaultIgnores(filePath, dotfiles);
|
534
|
+
}
|
541
535
|
}
|
542
536
|
|
543
537
|
//------------------------------------------------------------------------------
|