eslint 9.21.0 → 9.23.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 +52 -48
- 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 +828 -808
- 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 +541 -457
- package/lib/config/config-loader.js +648 -618
- 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 +65 -68
- package/lib/config/flat-config-schema.js +375 -368
- package/lib/config/rule-validator.js +139 -144
- package/lib/config-api.js +12 -0
- package/lib/eslint/eslint-helpers.js +709 -679
- package/lib/eslint/eslint.js +944 -886
- package/lib/eslint/index.js +2 -2
- package/lib/eslint/legacy-eslint.js +576 -532
- 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 +1129 -1054
- 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 +2402 -2044
- 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 +35 -35
- 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 +375 -361
- package/lib/rule-tester/index.js +1 -1
- package/lib/rule-tester/rule-tester.js +1307 -1045
- package/lib/rules/accessor-pairs.js +297 -262
- package/lib/rules/array-bracket-newline.js +249 -237
- package/lib/rules/array-bracket-spacing.js +262 -223
- package/lib/rules/array-callback-return.js +401 -355
- package/lib/rules/array-element-newline.js +357 -312
- package/lib/rules/arrow-body-style.js +399 -280
- package/lib/rules/arrow-parens.js +205 -172
- package/lib/rules/arrow-spacing.js +168 -162
- package/lib/rules/block-scoped-var.js +124 -122
- package/lib/rules/block-spacing.js +185 -175
- package/lib/rules/brace-style.js +261 -198
- package/lib/rules/callback-return.js +202 -189
- package/lib/rules/camelcase.js +402 -391
- package/lib/rules/capitalized-comments.js +252 -231
- package/lib/rules/class-methods-use-this.js +179 -171
- package/lib/rules/comma-dangle.js +378 -345
- package/lib/rules/comma-spacing.js +192 -194
- package/lib/rules/comma-style.js +374 -315
- package/lib/rules/complexity.js +172 -168
- package/lib/rules/computed-property-spacing.js +235 -210
- package/lib/rules/consistent-return.js +180 -169
- package/lib/rules/consistent-this.js +166 -146
- package/lib/rules/constructor-super.js +411 -403
- package/lib/rules/curly.js +406 -331
- package/lib/rules/default-case-last.js +37 -30
- package/lib/rules/default-case.js +88 -84
- package/lib/rules/default-param-last.js +68 -53
- package/lib/rules/dot-location.js +121 -109
- package/lib/rules/dot-notation.js +191 -155
- package/lib/rules/eol-last.js +121 -119
- package/lib/rules/eqeqeq.js +167 -154
- package/lib/rules/for-direction.js +145 -120
- package/lib/rules/func-call-spacing.js +260 -230
- package/lib/rules/func-name-matching.js +292 -208
- package/lib/rules/func-names.js +164 -163
- package/lib/rules/func-style.js +158 -126
- package/lib/rules/function-call-argument-newline.js +151 -128
- package/lib/rules/function-paren-newline.js +348 -290
- package/lib/rules/generator-star-spacing.js +228 -209
- package/lib/rules/getter-return.js +207 -171
- package/lib/rules/global-require.js +84 -73
- package/lib/rules/grouped-accessor-pairs.js +169 -149
- package/lib/rules/guard-for-in.js +71 -62
- package/lib/rules/handle-callback-err.js +107 -102
- package/lib/rules/id-blacklist.js +181 -198
- package/lib/rules/id-denylist.js +167 -186
- package/lib/rules/id-length.js +196 -170
- package/lib/rules/id-match.js +343 -288
- package/lib/rules/implicit-arrow-linebreak.js +101 -78
- package/lib/rules/indent-legacy.js +1343 -1117
- package/lib/rules/indent.js +2271 -1758
- package/lib/rules/index.js +317 -292
- package/lib/rules/init-declarations.js +115 -106
- package/lib/rules/jsx-quotes.js +93 -81
- package/lib/rules/key-spacing.js +749 -632
- package/lib/rules/keyword-spacing.js +647 -604
- package/lib/rules/line-comment-position.js +141 -127
- package/lib/rules/linebreak-style.js +106 -105
- package/lib/rules/lines-around-comment.js +539 -447
- package/lib/rules/lines-around-directive.js +232 -202
- package/lib/rules/lines-between-class-members.js +304 -233
- package/lib/rules/logical-assignment-operators.js +581 -398
- package/lib/rules/max-classes-per-file.js +68 -67
- package/lib/rules/max-depth.js +145 -142
- package/lib/rules/max-len.js +472 -433
- package/lib/rules/max-lines-per-function.js +200 -175
- package/lib/rules/max-lines.js +157 -161
- package/lib/rules/max-nested-callbacks.js +101 -103
- package/lib/rules/max-params.js +77 -75
- package/lib/rules/max-statements-per-line.js +204 -197
- package/lib/rules/max-statements.js +167 -163
- package/lib/rules/multiline-comment-style.js +636 -478
- package/lib/rules/multiline-ternary.js +240 -175
- package/lib/rules/new-cap.js +232 -212
- package/lib/rules/new-parens.js +87 -78
- package/lib/rules/newline-after-var.js +286 -249
- package/lib/rules/newline-before-return.js +228 -221
- package/lib/rules/newline-per-chained-call.js +141 -126
- package/lib/rules/no-alert.js +89 -78
- package/lib/rules/no-array-constructor.js +121 -112
- package/lib/rules/no-async-promise-executor.js +29 -23
- package/lib/rules/no-await-in-loop.js +68 -70
- package/lib/rules/no-bitwise.js +123 -99
- package/lib/rules/no-buffer-constructor.js +54 -46
- package/lib/rules/no-caller.js +38 -32
- package/lib/rules/no-case-declarations.js +60 -56
- package/lib/rules/no-catch-shadow.js +75 -72
- package/lib/rules/no-class-assign.js +50 -47
- package/lib/rules/no-compare-neg-zero.js +61 -47
- package/lib/rules/no-cond-assign.js +147 -131
- package/lib/rules/no-confusing-arrow.js +97 -80
- package/lib/rules/no-console.js +201 -190
- package/lib/rules/no-const-assign.js +46 -40
- package/lib/rules/no-constant-binary-expression.js +499 -404
- package/lib/rules/no-constant-condition.js +157 -142
- package/lib/rules/no-constructor-return.js +48 -48
- package/lib/rules/no-continue.js +24 -26
- package/lib/rules/no-control-regex.js +124 -120
- package/lib/rules/no-debugger.js +27 -29
- package/lib/rules/no-delete-var.js +28 -28
- package/lib/rules/no-div-regex.js +46 -40
- package/lib/rules/no-dupe-args.js +67 -68
- package/lib/rules/no-dupe-class-members.js +92 -88
- package/lib/rules/no-dupe-else-if.js +99 -76
- package/lib/rules/no-dupe-keys.js +132 -109
- package/lib/rules/no-duplicate-case.js +49 -42
- package/lib/rules/no-duplicate-imports.js +178 -175
- package/lib/rules/no-else-return.js +429 -384
- package/lib/rules/no-empty-character-class.js +56 -49
- package/lib/rules/no-empty-function.js +126 -127
- package/lib/rules/no-empty-pattern.js +62 -57
- package/lib/rules/no-empty-static-block.js +36 -34
- package/lib/rules/no-empty.js +97 -85
- package/lib/rules/no-eq-null.js +36 -31
- package/lib/rules/no-eval.js +255 -249
- package/lib/rules/no-ex-assign.js +41 -38
- package/lib/rules/no-extend-native.js +160 -158
- package/lib/rules/no-extra-bind.js +200 -189
- package/lib/rules/no-extra-boolean-cast.js +397 -347
- package/lib/rules/no-extra-label.js +149 -130
- package/lib/rules/no-extra-parens.js +1653 -1324
- package/lib/rules/no-extra-semi.js +145 -143
- package/lib/rules/no-fallthrough.js +198 -156
- package/lib/rules/no-floating-decimal.js +73 -65
- package/lib/rules/no-func-assign.js +53 -54
- package/lib/rules/no-global-assign.js +77 -72
- package/lib/rules/no-implicit-coercion.js +348 -292
- package/lib/rules/no-implicit-globals.js +157 -134
- package/lib/rules/no-implied-eval.js +139 -111
- package/lib/rules/no-import-assign.js +144 -158
- package/lib/rules/no-inline-comments.js +100 -94
- package/lib/rules/no-inner-declarations.js +114 -100
- package/lib/rules/no-invalid-regexp.js +221 -189
- package/lib/rules/no-invalid-this.js +122 -116
- package/lib/rules/no-irregular-whitespace.js +265 -251
- package/lib/rules/no-iterator.js +28 -32
- package/lib/rules/no-label-var.js +58 -61
- package/lib/rules/no-labels.js +137 -132
- package/lib/rules/no-lone-blocks.js +126 -122
- package/lib/rules/no-lonely-if.js +107 -76
- package/lib/rules/no-loop-func.js +233 -212
- package/lib/rules/no-loss-of-precision.js +215 -200
- package/lib/rules/no-magic-numbers.js +245 -217
- package/lib/rules/no-misleading-character-class.js +498 -445
- package/lib/rules/no-mixed-operators.js +187 -181
- package/lib/rules/no-mixed-requires.js +252 -239
- package/lib/rules/no-mixed-spaces-and-tabs.js +133 -120
- package/lib/rules/no-multi-assign.js +45 -43
- package/lib/rules/no-multi-spaces.js +162 -142
- package/lib/rules/no-multi-str.js +41 -40
- package/lib/rules/no-multiple-empty-lines.js +195 -157
- package/lib/rules/no-native-reassign.js +89 -84
- package/lib/rules/no-negated-condition.js +78 -74
- package/lib/rules/no-negated-in-lhs.js +44 -42
- package/lib/rules/no-nested-ternary.js +32 -31
- package/lib/rules/no-new-func.js +70 -61
- package/lib/rules/no-new-native-nonconstructor.js +42 -38
- package/lib/rules/no-new-object.js +47 -47
- package/lib/rules/no-new-require.js +47 -46
- package/lib/rules/no-new-symbol.js +51 -49
- package/lib/rules/no-new-wrappers.js +42 -40
- package/lib/rules/no-new.js +27 -28
- package/lib/rules/no-nonoctal-decimal-escape.js +140 -120
- package/lib/rules/no-obj-calls.js +65 -52
- package/lib/rules/no-object-constructor.js +103 -96
- package/lib/rules/no-octal-escape.js +39 -42
- package/lib/rules/no-octal.js +31 -31
- package/lib/rules/no-param-reassign.js +234 -216
- package/lib/rules/no-path-concat.js +65 -66
- package/lib/rules/no-plusplus.js +59 -60
- package/lib/rules/no-process-env.js +48 -47
- package/lib/rules/no-process-exit.js +53 -49
- package/lib/rules/no-promise-executor-return.js +213 -181
- package/lib/rules/no-proto.js +25 -28
- package/lib/rules/no-prototype-builtins.js +145 -123
- package/lib/rules/no-redeclare.js +153 -151
- package/lib/rules/no-regex-spaces.js +182 -160
- package/lib/rules/no-restricted-exports.js +207 -184
- package/lib/rules/no-restricted-globals.js +110 -111
- package/lib/rules/no-restricted-imports.js +656 -536
- package/lib/rules/no-restricted-modules.js +221 -201
- package/lib/rules/no-restricted-properties.js +180 -152
- package/lib/rules/no-restricted-syntax.js +55 -51
- package/lib/rules/no-return-assign.js +54 -49
- package/lib/rules/no-return-await.js +147 -123
- package/lib/rules/no-script-url.js +51 -44
- package/lib/rules/no-self-assign.js +147 -145
- package/lib/rules/no-self-compare.js +62 -45
- package/lib/rules/no-sequences.js +134 -115
- package/lib/rules/no-setter-return.js +184 -151
- package/lib/rules/no-shadow-restricted-names.js +60 -45
- package/lib/rules/no-shadow.js +341 -315
- package/lib/rules/no-spaced-func.js +81 -76
- package/lib/rules/no-sparse-arrays.js +53 -58
- package/lib/rules/no-sync.js +60 -59
- package/lib/rules/no-tabs.js +82 -71
- package/lib/rules/no-template-curly-in-string.js +32 -31
- package/lib/rules/no-ternary.js +24 -28
- package/lib/rules/no-this-before-super.js +320 -318
- package/lib/rules/no-throw-literal.js +30 -35
- package/lib/rules/no-trailing-spaces.js +198 -190
- package/lib/rules/no-undef-init.js +75 -60
- package/lib/rules/no-undef.js +50 -47
- package/lib/rules/no-undefined.js +72 -74
- package/lib/rules/no-underscore-dangle.js +369 -326
- package/lib/rules/no-unexpected-multiline.js +111 -101
- package/lib/rules/no-unmodified-loop-condition.js +253 -253
- package/lib/rules/no-unneeded-ternary.js +211 -146
- package/lib/rules/no-unreachable-loop.js +144 -141
- package/lib/rules/no-unreachable.js +254 -247
- package/lib/rules/no-unsafe-finally.js +92 -84
- package/lib/rules/no-unsafe-negation.js +104 -82
- package/lib/rules/no-unsafe-optional-chaining.js +191 -177
- package/lib/rules/no-unused-expressions.js +177 -161
- package/lib/rules/no-unused-labels.js +138 -123
- package/lib/rules/no-unused-private-class-members.js +205 -181
- package/lib/rules/no-unused-vars.js +1668 -1448
- package/lib/rules/no-use-before-define.js +228 -230
- package/lib/rules/no-useless-assignment.js +589 -510
- package/lib/rules/no-useless-backreference.js +211 -192
- package/lib/rules/no-useless-call.js +57 -52
- package/lib/rules/no-useless-catch.js +39 -39
- package/lib/rules/no-useless-computed-key.js +143 -114
- package/lib/rules/no-useless-concat.js +64 -59
- package/lib/rules/no-useless-constructor.js +157 -110
- package/lib/rules/no-useless-escape.js +341 -290
- package/lib/rules/no-useless-rename.js +182 -155
- package/lib/rules/no-useless-return.js +343 -311
- package/lib/rules/no-var.js +232 -211
- package/lib/rules/no-void.js +49 -47
- package/lib/rules/no-warning-comments.js +190 -185
- package/lib/rules/no-whitespace-before-property.js +130 -114
- package/lib/rules/no-with.js +23 -25
- package/lib/rules/nonblock-statement-body-position.js +148 -129
- package/lib/rules/object-curly-newline.js +305 -264
- package/lib/rules/object-curly-spacing.js +359 -313
- package/lib/rules/object-property-newline.js +136 -105
- package/lib/rules/object-shorthand.js +606 -501
- package/lib/rules/one-var-declaration-per-line.js +103 -99
- package/lib/rules/one-var.js +652 -536
- package/lib/rules/operator-assignment.js +218 -160
- package/lib/rules/operator-linebreak.js +294 -250
- package/lib/rules/padded-blocks.js +345 -307
- package/lib/rules/padding-line-between-statements.js +442 -438
- package/lib/rules/prefer-arrow-callback.js +361 -312
- package/lib/rules/prefer-const.js +417 -376
- package/lib/rules/prefer-destructuring.js +300 -278
- package/lib/rules/prefer-exponentiation-operator.js +175 -132
- package/lib/rules/prefer-named-capture-group.js +152 -139
- package/lib/rules/prefer-numeric-literals.js +120 -112
- package/lib/rules/prefer-object-has-own.js +115 -81
- package/lib/rules/prefer-object-spread.js +212 -192
- package/lib/rules/prefer-promise-reject-errors.js +139 -121
- package/lib/rules/prefer-reflect.js +126 -106
- package/lib/rules/prefer-regex-literals.js +577 -465
- package/lib/rules/prefer-rest-params.js +78 -79
- package/lib/rules/prefer-spread.js +46 -43
- package/lib/rules/prefer-template.js +265 -194
- package/lib/rules/quote-props.js +372 -306
- package/lib/rules/quotes.js +373 -325
- package/lib/rules/radix.js +151 -135
- package/lib/rules/require-atomic-updates.js +315 -284
- package/lib/rules/require-await.js +143 -115
- package/lib/rules/require-unicode-regexp.js +281 -176
- package/lib/rules/require-yield.js +52 -53
- package/lib/rules/rest-spread-spacing.js +127 -115
- package/lib/rules/semi-spacing.js +280 -249
- package/lib/rules/semi-style.js +175 -133
- package/lib/rules/semi.js +455 -435
- package/lib/rules/sort-imports.js +305 -232
- package/lib/rules/sort-keys.js +218 -187
- package/lib/rules/sort-vars.js +126 -92
- package/lib/rules/space-before-blocks.js +198 -188
- package/lib/rules/space-before-function-paren.js +185 -165
- package/lib/rules/space-in-parens.js +358 -287
- package/lib/rules/space-infix-ops.js +236 -200
- package/lib/rules/space-unary-ops.js +355 -297
- package/lib/rules/spaced-comment.js +362 -318
- package/lib/rules/strict.js +264 -229
- package/lib/rules/switch-colon-spacing.js +129 -121
- package/lib/rules/symbol-description.js +44 -47
- package/lib/rules/template-curly-spacing.js +147 -141
- package/lib/rules/template-tag-spacing.js +97 -87
- package/lib/rules/unicode-bom.js +53 -55
- package/lib/rules/use-isnan.js +236 -205
- 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 +152 -110
- package/lib/rules/vars-on-top.js +151 -144
- package/lib/rules/wrap-iife.js +203 -190
- package/lib/rules/wrap-regex.js +69 -57
- package/lib/rules/yield-star-spacing.js +144 -133
- package/lib/rules/yoda.js +282 -271
- package/lib/services/parser-service.js +35 -35
- package/lib/services/processor-service.js +66 -73
- 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 +46 -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/types/config-api.d.ts +8 -0
- package/lib/types/index.d.ts +2010 -1559
- package/lib/types/rules.d.ts +5312 -0
- 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 +22 -20
- package/lib/types/rules/best-practices.d.ts +0 -1143
- package/lib/types/rules/deprecated.d.ts +0 -252
- package/lib/types/rules/ecmascript-6.d.ts +0 -647
- package/lib/types/rules/index.d.ts +0 -50
- package/lib/types/rules/node-commonjs.d.ts +0 -171
- package/lib/types/rules/possible-errors.d.ts +0 -685
- package/lib/types/rules/strict-mode.d.ts +0 -38
- package/lib/types/rules/stylistic-issues.d.ts +0 -2043
- package/lib/types/rules/variables.d.ts +0 -234
package/lib/rules/key-spacing.js
CHANGED
@@ -19,7 +19,7 @@ const { getGraphemeCount } = require("../shared/string-utils");
|
|
19
19
|
* @returns {boolean} True if str contains a line terminator.
|
20
20
|
*/
|
21
21
|
function containsLineTerminator(str) {
|
22
|
-
|
22
|
+
return astUtils.LINEBREAK_MATCHER.test(str);
|
23
23
|
}
|
24
24
|
|
25
25
|
/**
|
@@ -28,7 +28,7 @@ function containsLineTerminator(str) {
|
|
28
28
|
* @returns {any} Last element of arr.
|
29
29
|
*/
|
30
30
|
function last(arr) {
|
31
|
-
|
31
|
+
return arr.at(-1);
|
32
32
|
}
|
33
33
|
|
34
34
|
/**
|
@@ -37,7 +37,7 @@ function last(arr) {
|
|
37
37
|
* @returns {boolean} True if the node is a single line.
|
38
38
|
*/
|
39
39
|
function isSingleLine(node) {
|
40
|
-
|
40
|
+
return node.loc.end.line === node.loc.start.line;
|
41
41
|
}
|
42
42
|
|
43
43
|
/**
|
@@ -46,10 +46,10 @@ function isSingleLine(node) {
|
|
46
46
|
* @returns {boolean} True if all properties is on a single line.
|
47
47
|
*/
|
48
48
|
function isSingleLineProperties(properties) {
|
49
|
-
|
50
|
-
|
49
|
+
const [firstProp] = properties,
|
50
|
+
lastProp = last(properties);
|
51
51
|
|
52
|
-
|
52
|
+
return firstProp.loc.start.line === lastProp.loc.end.line;
|
53
53
|
}
|
54
54
|
|
55
55
|
/**
|
@@ -59,37 +59,38 @@ function isSingleLineProperties(properties) {
|
|
59
59
|
* @returns {Object} The object with correctly initialized options and values
|
60
60
|
*/
|
61
61
|
function initOptionProperty(toOptions, fromOptions) {
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
62
|
+
toOptions.mode = fromOptions.mode || "strict";
|
63
|
+
|
64
|
+
// Set value of beforeColon
|
65
|
+
if (typeof fromOptions.beforeColon !== "undefined") {
|
66
|
+
toOptions.beforeColon = +fromOptions.beforeColon;
|
67
|
+
} else {
|
68
|
+
toOptions.beforeColon = 0;
|
69
|
+
}
|
70
|
+
|
71
|
+
// Set value of afterColon
|
72
|
+
if (typeof fromOptions.afterColon !== "undefined") {
|
73
|
+
toOptions.afterColon = +fromOptions.afterColon;
|
74
|
+
} else {
|
75
|
+
toOptions.afterColon = 1;
|
76
|
+
}
|
77
|
+
|
78
|
+
// Set align if exists
|
79
|
+
if (typeof fromOptions.align !== "undefined") {
|
80
|
+
if (typeof fromOptions.align === "object") {
|
81
|
+
toOptions.align = fromOptions.align;
|
82
|
+
} else {
|
83
|
+
// "string"
|
84
|
+
toOptions.align = {
|
85
|
+
on: fromOptions.align,
|
86
|
+
mode: toOptions.mode,
|
87
|
+
beforeColon: toOptions.beforeColon,
|
88
|
+
afterColon: toOptions.afterColon,
|
89
|
+
};
|
90
|
+
}
|
91
|
+
}
|
92
|
+
|
93
|
+
return toOptions;
|
93
94
|
}
|
94
95
|
|
95
96
|
/**
|
@@ -99,32 +100,44 @@ function initOptionProperty(toOptions, fromOptions) {
|
|
99
100
|
* @returns {Object} The object with correctly initialized options and values
|
100
101
|
*/
|
101
102
|
function initOptions(toOptions, fromOptions) {
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
103
|
+
if (typeof fromOptions.align === "object") {
|
104
|
+
// Initialize the alignment configuration
|
105
|
+
toOptions.align = initOptionProperty({}, fromOptions.align);
|
106
|
+
toOptions.align.on = fromOptions.align.on || "colon";
|
107
|
+
toOptions.align.mode = fromOptions.align.mode || "strict";
|
108
|
+
|
109
|
+
toOptions.multiLine = initOptionProperty(
|
110
|
+
{},
|
111
|
+
fromOptions.multiLine || fromOptions,
|
112
|
+
);
|
113
|
+
toOptions.singleLine = initOptionProperty(
|
114
|
+
{},
|
115
|
+
fromOptions.singleLine || fromOptions,
|
116
|
+
);
|
117
|
+
} else {
|
118
|
+
// string or undefined
|
119
|
+
toOptions.multiLine = initOptionProperty(
|
120
|
+
{},
|
121
|
+
fromOptions.multiLine || fromOptions,
|
122
|
+
);
|
123
|
+
toOptions.singleLine = initOptionProperty(
|
124
|
+
{},
|
125
|
+
fromOptions.singleLine || fromOptions,
|
126
|
+
);
|
127
|
+
|
128
|
+
// If alignment options are defined in multiLine, pull them out into the general align configuration
|
129
|
+
if (toOptions.multiLine.align) {
|
130
|
+
toOptions.align = {
|
131
|
+
on: toOptions.multiLine.align.on,
|
132
|
+
mode:
|
133
|
+
toOptions.multiLine.align.mode || toOptions.multiLine.mode,
|
134
|
+
beforeColon: toOptions.multiLine.align.beforeColon,
|
135
|
+
afterColon: toOptions.multiLine.align.afterColon,
|
136
|
+
};
|
137
|
+
}
|
138
|
+
}
|
139
|
+
|
140
|
+
return toOptions;
|
128
141
|
}
|
129
142
|
|
130
143
|
//------------------------------------------------------------------------------
|
@@ -133,573 +146,677 @@ function initOptions(toOptions, fromOptions) {
|
|
133
146
|
|
134
147
|
/** @type {import('../shared/types').Rule} */
|
135
148
|
module.exports = {
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
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
|
-
|
541
|
-
|
542
|
-
|
543
|
-
|
544
|
-
|
545
|
-
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
|
550
|
-
|
551
|
-
|
552
|
-
|
553
|
-
|
554
|
-
|
555
|
-
|
556
|
-
|
557
|
-
|
558
|
-
|
559
|
-
|
560
|
-
|
561
|
-
|
562
|
-
|
563
|
-
|
564
|
-
|
565
|
-
|
566
|
-
|
567
|
-
|
568
|
-
|
569
|
-
|
570
|
-
|
571
|
-
|
572
|
-
|
573
|
-
|
574
|
-
|
575
|
-
|
576
|
-
|
577
|
-
|
578
|
-
|
579
|
-
|
580
|
-
|
581
|
-
|
582
|
-
|
583
|
-
|
584
|
-
|
585
|
-
|
586
|
-
|
587
|
-
|
588
|
-
|
589
|
-
|
590
|
-
|
591
|
-
|
592
|
-
|
593
|
-
|
594
|
-
|
595
|
-
|
596
|
-
|
597
|
-
|
598
|
-
|
599
|
-
|
600
|
-
|
601
|
-
|
602
|
-
|
603
|
-
|
604
|
-
|
605
|
-
|
606
|
-
|
607
|
-
|
608
|
-
|
609
|
-
|
610
|
-
|
611
|
-
|
612
|
-
|
613
|
-
|
614
|
-
|
615
|
-
|
616
|
-
|
617
|
-
|
618
|
-
|
619
|
-
|
620
|
-
|
621
|
-
|
622
|
-
|
623
|
-
|
624
|
-
|
625
|
-
|
626
|
-
|
627
|
-
|
628
|
-
|
629
|
-
|
630
|
-
|
631
|
-
|
632
|
-
|
633
|
-
|
634
|
-
|
635
|
-
|
636
|
-
|
637
|
-
|
638
|
-
|
639
|
-
|
640
|
-
|
641
|
-
|
642
|
-
|
643
|
-
|
644
|
-
|
645
|
-
|
646
|
-
|
647
|
-
|
648
|
-
|
649
|
-
|
650
|
-
|
651
|
-
|
652
|
-
|
653
|
-
|
654
|
-
|
655
|
-
|
656
|
-
|
657
|
-
|
658
|
-
|
659
|
-
|
660
|
-
|
661
|
-
|
662
|
-
|
663
|
-
|
664
|
-
|
665
|
-
|
666
|
-
|
667
|
-
|
668
|
-
|
669
|
-
|
670
|
-
|
671
|
-
|
672
|
-
|
673
|
-
|
674
|
-
|
675
|
-
|
676
|
-
|
677
|
-
|
678
|
-
|
679
|
-
|
680
|
-
|
681
|
-
|
682
|
-
|
683
|
-
|
684
|
-
|
685
|
-
|
686
|
-
|
687
|
-
|
688
|
-
|
689
|
-
|
690
|
-
|
691
|
-
|
692
|
-
|
693
|
-
|
694
|
-
|
695
|
-
|
696
|
-
|
697
|
-
|
698
|
-
|
699
|
-
|
700
|
-
|
701
|
-
|
702
|
-
|
703
|
-
|
704
|
-
|
149
|
+
meta: {
|
150
|
+
deprecated: {
|
151
|
+
message: "Formatting rules are being moved out of ESLint core.",
|
152
|
+
url: "https://eslint.org/blog/2023/10/deprecating-formatting-rules/",
|
153
|
+
deprecatedSince: "8.53.0",
|
154
|
+
availableUntil: "10.0.0",
|
155
|
+
replacedBy: [
|
156
|
+
{
|
157
|
+
message:
|
158
|
+
"ESLint Stylistic now maintains deprecated stylistic core rules.",
|
159
|
+
url: "https://eslint.style/guide/migration",
|
160
|
+
plugin: {
|
161
|
+
name: "@stylistic/eslint-plugin-js",
|
162
|
+
url: "https://eslint.style/packages/js",
|
163
|
+
},
|
164
|
+
rule: {
|
165
|
+
name: "key-spacing",
|
166
|
+
url: "https://eslint.style/rules/js/key-spacing",
|
167
|
+
},
|
168
|
+
},
|
169
|
+
],
|
170
|
+
},
|
171
|
+
type: "layout",
|
172
|
+
|
173
|
+
docs: {
|
174
|
+
description:
|
175
|
+
"Enforce consistent spacing between keys and values in object literal properties",
|
176
|
+
recommended: false,
|
177
|
+
url: "https://eslint.org/docs/latest/rules/key-spacing",
|
178
|
+
},
|
179
|
+
|
180
|
+
fixable: "whitespace",
|
181
|
+
|
182
|
+
schema: [
|
183
|
+
{
|
184
|
+
anyOf: [
|
185
|
+
{
|
186
|
+
type: "object",
|
187
|
+
properties: {
|
188
|
+
align: {
|
189
|
+
anyOf: [
|
190
|
+
{
|
191
|
+
enum: ["colon", "value"],
|
192
|
+
},
|
193
|
+
{
|
194
|
+
type: "object",
|
195
|
+
properties: {
|
196
|
+
mode: {
|
197
|
+
enum: ["strict", "minimum"],
|
198
|
+
},
|
199
|
+
on: {
|
200
|
+
enum: ["colon", "value"],
|
201
|
+
},
|
202
|
+
beforeColon: {
|
203
|
+
type: "boolean",
|
204
|
+
},
|
205
|
+
afterColon: {
|
206
|
+
type: "boolean",
|
207
|
+
},
|
208
|
+
},
|
209
|
+
additionalProperties: false,
|
210
|
+
},
|
211
|
+
],
|
212
|
+
},
|
213
|
+
mode: {
|
214
|
+
enum: ["strict", "minimum"],
|
215
|
+
},
|
216
|
+
beforeColon: {
|
217
|
+
type: "boolean",
|
218
|
+
},
|
219
|
+
afterColon: {
|
220
|
+
type: "boolean",
|
221
|
+
},
|
222
|
+
},
|
223
|
+
additionalProperties: false,
|
224
|
+
},
|
225
|
+
{
|
226
|
+
type: "object",
|
227
|
+
properties: {
|
228
|
+
singleLine: {
|
229
|
+
type: "object",
|
230
|
+
properties: {
|
231
|
+
mode: {
|
232
|
+
enum: ["strict", "minimum"],
|
233
|
+
},
|
234
|
+
beforeColon: {
|
235
|
+
type: "boolean",
|
236
|
+
},
|
237
|
+
afterColon: {
|
238
|
+
type: "boolean",
|
239
|
+
},
|
240
|
+
},
|
241
|
+
additionalProperties: false,
|
242
|
+
},
|
243
|
+
multiLine: {
|
244
|
+
type: "object",
|
245
|
+
properties: {
|
246
|
+
align: {
|
247
|
+
anyOf: [
|
248
|
+
{
|
249
|
+
enum: ["colon", "value"],
|
250
|
+
},
|
251
|
+
{
|
252
|
+
type: "object",
|
253
|
+
properties: {
|
254
|
+
mode: {
|
255
|
+
enum: [
|
256
|
+
"strict",
|
257
|
+
"minimum",
|
258
|
+
],
|
259
|
+
},
|
260
|
+
on: {
|
261
|
+
enum: [
|
262
|
+
"colon",
|
263
|
+
"value",
|
264
|
+
],
|
265
|
+
},
|
266
|
+
beforeColon: {
|
267
|
+
type: "boolean",
|
268
|
+
},
|
269
|
+
afterColon: {
|
270
|
+
type: "boolean",
|
271
|
+
},
|
272
|
+
},
|
273
|
+
additionalProperties: false,
|
274
|
+
},
|
275
|
+
],
|
276
|
+
},
|
277
|
+
mode: {
|
278
|
+
enum: ["strict", "minimum"],
|
279
|
+
},
|
280
|
+
beforeColon: {
|
281
|
+
type: "boolean",
|
282
|
+
},
|
283
|
+
afterColon: {
|
284
|
+
type: "boolean",
|
285
|
+
},
|
286
|
+
},
|
287
|
+
additionalProperties: false,
|
288
|
+
},
|
289
|
+
},
|
290
|
+
additionalProperties: false,
|
291
|
+
},
|
292
|
+
{
|
293
|
+
type: "object",
|
294
|
+
properties: {
|
295
|
+
singleLine: {
|
296
|
+
type: "object",
|
297
|
+
properties: {
|
298
|
+
mode: {
|
299
|
+
enum: ["strict", "minimum"],
|
300
|
+
},
|
301
|
+
beforeColon: {
|
302
|
+
type: "boolean",
|
303
|
+
},
|
304
|
+
afterColon: {
|
305
|
+
type: "boolean",
|
306
|
+
},
|
307
|
+
},
|
308
|
+
additionalProperties: false,
|
309
|
+
},
|
310
|
+
multiLine: {
|
311
|
+
type: "object",
|
312
|
+
properties: {
|
313
|
+
mode: {
|
314
|
+
enum: ["strict", "minimum"],
|
315
|
+
},
|
316
|
+
beforeColon: {
|
317
|
+
type: "boolean",
|
318
|
+
},
|
319
|
+
afterColon: {
|
320
|
+
type: "boolean",
|
321
|
+
},
|
322
|
+
},
|
323
|
+
additionalProperties: false,
|
324
|
+
},
|
325
|
+
align: {
|
326
|
+
type: "object",
|
327
|
+
properties: {
|
328
|
+
mode: {
|
329
|
+
enum: ["strict", "minimum"],
|
330
|
+
},
|
331
|
+
on: {
|
332
|
+
enum: ["colon", "value"],
|
333
|
+
},
|
334
|
+
beforeColon: {
|
335
|
+
type: "boolean",
|
336
|
+
},
|
337
|
+
afterColon: {
|
338
|
+
type: "boolean",
|
339
|
+
},
|
340
|
+
},
|
341
|
+
additionalProperties: false,
|
342
|
+
},
|
343
|
+
},
|
344
|
+
additionalProperties: false,
|
345
|
+
},
|
346
|
+
],
|
347
|
+
},
|
348
|
+
],
|
349
|
+
messages: {
|
350
|
+
extraKey: "Extra space after {{computed}}key '{{key}}'.",
|
351
|
+
extraValue:
|
352
|
+
"Extra space before value for {{computed}}key '{{key}}'.",
|
353
|
+
missingKey: "Missing space after {{computed}}key '{{key}}'.",
|
354
|
+
missingValue:
|
355
|
+
"Missing space before value for {{computed}}key '{{key}}'.",
|
356
|
+
},
|
357
|
+
},
|
358
|
+
|
359
|
+
create(context) {
|
360
|
+
/**
|
361
|
+
* OPTIONS
|
362
|
+
* "key-spacing": [2, {
|
363
|
+
* beforeColon: false,
|
364
|
+
* afterColon: true,
|
365
|
+
* align: "colon" // Optional, or "value"
|
366
|
+
* }
|
367
|
+
*/
|
368
|
+
const options = context.options[0] || {},
|
369
|
+
ruleOptions = initOptions({}, options),
|
370
|
+
multiLineOptions = ruleOptions.multiLine,
|
371
|
+
singleLineOptions = ruleOptions.singleLine,
|
372
|
+
alignmentOptions = ruleOptions.align || null;
|
373
|
+
|
374
|
+
const sourceCode = context.sourceCode;
|
375
|
+
|
376
|
+
/**
|
377
|
+
* Determines if the given property is key-value property.
|
378
|
+
* @param {ASTNode} property Property node to check.
|
379
|
+
* @returns {boolean} Whether the property is a key-value property.
|
380
|
+
*/
|
381
|
+
function isKeyValueProperty(property) {
|
382
|
+
return !(
|
383
|
+
(
|
384
|
+
property.method ||
|
385
|
+
property.shorthand ||
|
386
|
+
property.kind !== "init" ||
|
387
|
+
property.type !== "Property"
|
388
|
+
) // Could be "ExperimentalSpreadProperty" or "SpreadElement"
|
389
|
+
);
|
390
|
+
}
|
391
|
+
|
392
|
+
/**
|
393
|
+
* Starting from the given node (a property.key node here) looks forward
|
394
|
+
* until it finds the colon punctuator and returns it.
|
395
|
+
* @param {ASTNode} node The node to start looking from.
|
396
|
+
* @returns {ASTNode} The colon punctuator.
|
397
|
+
*/
|
398
|
+
function getNextColon(node) {
|
399
|
+
return sourceCode.getTokenAfter(node, astUtils.isColonToken);
|
400
|
+
}
|
401
|
+
|
402
|
+
/**
|
403
|
+
* Starting from the given node (a property.key node here) looks forward
|
404
|
+
* until it finds the last token before a colon punctuator and returns it.
|
405
|
+
* @param {ASTNode} node The node to start looking from.
|
406
|
+
* @returns {ASTNode} The last token before a colon punctuator.
|
407
|
+
*/
|
408
|
+
function getLastTokenBeforeColon(node) {
|
409
|
+
const colonToken = getNextColon(node);
|
410
|
+
|
411
|
+
return sourceCode.getTokenBefore(colonToken);
|
412
|
+
}
|
413
|
+
|
414
|
+
/**
|
415
|
+
* Starting from the given node (a property.key node here) looks forward
|
416
|
+
* until it finds the first token after a colon punctuator and returns it.
|
417
|
+
* @param {ASTNode} node The node to start looking from.
|
418
|
+
* @returns {ASTNode} The first token after a colon punctuator.
|
419
|
+
*/
|
420
|
+
function getFirstTokenAfterColon(node) {
|
421
|
+
const colonToken = getNextColon(node);
|
422
|
+
|
423
|
+
return sourceCode.getTokenAfter(colonToken);
|
424
|
+
}
|
425
|
+
|
426
|
+
/**
|
427
|
+
* Checks whether a property is a member of the property group it follows.
|
428
|
+
* @param {ASTNode} lastMember The last Property known to be in the group.
|
429
|
+
* @param {ASTNode} candidate The next Property that might be in the group.
|
430
|
+
* @returns {boolean} True if the candidate property is part of the group.
|
431
|
+
*/
|
432
|
+
function continuesPropertyGroup(lastMember, candidate) {
|
433
|
+
const groupEndLine = lastMember.loc.start.line,
|
434
|
+
candidateValueStartLine = (
|
435
|
+
isKeyValueProperty(candidate)
|
436
|
+
? getFirstTokenAfterColon(candidate.key)
|
437
|
+
: candidate
|
438
|
+
).loc.start.line;
|
439
|
+
|
440
|
+
if (candidateValueStartLine - groupEndLine <= 1) {
|
441
|
+
return true;
|
442
|
+
}
|
443
|
+
|
444
|
+
/*
|
445
|
+
* Check that the first comment is adjacent to the end of the group, the
|
446
|
+
* last comment is adjacent to the candidate property, and that successive
|
447
|
+
* comments are adjacent to each other.
|
448
|
+
*/
|
449
|
+
const leadingComments = sourceCode.getCommentsBefore(candidate);
|
450
|
+
|
451
|
+
if (
|
452
|
+
leadingComments.length &&
|
453
|
+
leadingComments[0].loc.start.line - groupEndLine <= 1 &&
|
454
|
+
candidateValueStartLine - last(leadingComments).loc.end.line <=
|
455
|
+
1
|
456
|
+
) {
|
457
|
+
for (let i = 1; i < leadingComments.length; i++) {
|
458
|
+
if (
|
459
|
+
leadingComments[i].loc.start.line -
|
460
|
+
leadingComments[i - 1].loc.end.line >
|
461
|
+
1
|
462
|
+
) {
|
463
|
+
return false;
|
464
|
+
}
|
465
|
+
}
|
466
|
+
return true;
|
467
|
+
}
|
468
|
+
|
469
|
+
return false;
|
470
|
+
}
|
471
|
+
|
472
|
+
/**
|
473
|
+
* Gets an object literal property's key as the identifier name or string value.
|
474
|
+
* @param {ASTNode} property Property node whose key to retrieve.
|
475
|
+
* @returns {string} The property's key.
|
476
|
+
*/
|
477
|
+
function getKey(property) {
|
478
|
+
const key = property.key;
|
479
|
+
|
480
|
+
if (property.computed) {
|
481
|
+
return sourceCode.getText().slice(key.range[0], key.range[1]);
|
482
|
+
}
|
483
|
+
return astUtils.getStaticPropertyName(property);
|
484
|
+
}
|
485
|
+
|
486
|
+
/**
|
487
|
+
* Reports an appropriately-formatted error if spacing is incorrect on one
|
488
|
+
* side of the colon.
|
489
|
+
* @param {ASTNode} property Key-value pair in an object literal.
|
490
|
+
* @param {string} side Side being verified - either "key" or "value".
|
491
|
+
* @param {string} whitespace Actual whitespace string.
|
492
|
+
* @param {int} expected Expected whitespace length.
|
493
|
+
* @param {string} mode Value of the mode as "strict" or "minimum"
|
494
|
+
* @returns {void}
|
495
|
+
*/
|
496
|
+
function report(property, side, whitespace, expected, mode) {
|
497
|
+
const diff = whitespace.length - expected;
|
498
|
+
|
499
|
+
if (
|
500
|
+
((diff && mode === "strict") ||
|
501
|
+
(diff < 0 && mode === "minimum") ||
|
502
|
+
(diff > 0 && !expected && mode === "minimum")) &&
|
503
|
+
!(expected && containsLineTerminator(whitespace))
|
504
|
+
) {
|
505
|
+
const nextColon = getNextColon(property.key),
|
506
|
+
tokenBeforeColon = sourceCode.getTokenBefore(nextColon, {
|
507
|
+
includeComments: true,
|
508
|
+
}),
|
509
|
+
tokenAfterColon = sourceCode.getTokenAfter(nextColon, {
|
510
|
+
includeComments: true,
|
511
|
+
}),
|
512
|
+
isKeySide = side === "key",
|
513
|
+
isExtra = diff > 0,
|
514
|
+
diffAbs = Math.abs(diff),
|
515
|
+
spaces = Array(diffAbs + 1).join(" ");
|
516
|
+
|
517
|
+
const locStart = isKeySide
|
518
|
+
? tokenBeforeColon.loc.end
|
519
|
+
: nextColon.loc.start;
|
520
|
+
const locEnd = isKeySide
|
521
|
+
? nextColon.loc.start
|
522
|
+
: tokenAfterColon.loc.start;
|
523
|
+
const missingLoc = isKeySide
|
524
|
+
? tokenBeforeColon.loc
|
525
|
+
: tokenAfterColon.loc;
|
526
|
+
const loc = isExtra
|
527
|
+
? { start: locStart, end: locEnd }
|
528
|
+
: missingLoc;
|
529
|
+
|
530
|
+
let fix;
|
531
|
+
|
532
|
+
if (isExtra) {
|
533
|
+
let range;
|
534
|
+
|
535
|
+
// Remove whitespace
|
536
|
+
if (isKeySide) {
|
537
|
+
range = [
|
538
|
+
tokenBeforeColon.range[1],
|
539
|
+
tokenBeforeColon.range[1] + diffAbs,
|
540
|
+
];
|
541
|
+
} else {
|
542
|
+
range = [
|
543
|
+
tokenAfterColon.range[0] - diffAbs,
|
544
|
+
tokenAfterColon.range[0],
|
545
|
+
];
|
546
|
+
}
|
547
|
+
fix = function (fixer) {
|
548
|
+
return fixer.removeRange(range);
|
549
|
+
};
|
550
|
+
} else {
|
551
|
+
// Add whitespace
|
552
|
+
if (isKeySide) {
|
553
|
+
fix = function (fixer) {
|
554
|
+
return fixer.insertTextAfter(
|
555
|
+
tokenBeforeColon,
|
556
|
+
spaces,
|
557
|
+
);
|
558
|
+
};
|
559
|
+
} else {
|
560
|
+
fix = function (fixer) {
|
561
|
+
return fixer.insertTextBefore(
|
562
|
+
tokenAfterColon,
|
563
|
+
spaces,
|
564
|
+
);
|
565
|
+
};
|
566
|
+
}
|
567
|
+
}
|
568
|
+
|
569
|
+
let messageId;
|
570
|
+
|
571
|
+
if (isExtra) {
|
572
|
+
messageId = side === "key" ? "extraKey" : "extraValue";
|
573
|
+
} else {
|
574
|
+
messageId = side === "key" ? "missingKey" : "missingValue";
|
575
|
+
}
|
576
|
+
|
577
|
+
context.report({
|
578
|
+
node: property[side],
|
579
|
+
loc,
|
580
|
+
messageId,
|
581
|
+
data: {
|
582
|
+
computed: property.computed ? "computed " : "",
|
583
|
+
key: getKey(property),
|
584
|
+
},
|
585
|
+
fix,
|
586
|
+
});
|
587
|
+
}
|
588
|
+
}
|
589
|
+
|
590
|
+
/**
|
591
|
+
* Gets the number of characters in a key, including quotes around string
|
592
|
+
* keys and braces around computed property keys.
|
593
|
+
* @param {ASTNode} property Property of on object literal.
|
594
|
+
* @returns {int} Width of the key.
|
595
|
+
*/
|
596
|
+
function getKeyWidth(property) {
|
597
|
+
const startToken = sourceCode.getFirstToken(property);
|
598
|
+
const endToken = getLastTokenBeforeColon(property.key);
|
599
|
+
|
600
|
+
return getGraphemeCount(
|
601
|
+
sourceCode
|
602
|
+
.getText()
|
603
|
+
.slice(startToken.range[0], endToken.range[1]),
|
604
|
+
);
|
605
|
+
}
|
606
|
+
|
607
|
+
/**
|
608
|
+
* Gets the whitespace around the colon in an object literal property.
|
609
|
+
* @param {ASTNode} property Property node from an object literal.
|
610
|
+
* @returns {Object} Whitespace before and after the property's colon.
|
611
|
+
*/
|
612
|
+
function getPropertyWhitespace(property) {
|
613
|
+
const whitespace = /(\s*):(\s*)/u.exec(
|
614
|
+
sourceCode
|
615
|
+
.getText()
|
616
|
+
.slice(property.key.range[1], property.value.range[0]),
|
617
|
+
);
|
618
|
+
|
619
|
+
if (whitespace) {
|
620
|
+
return {
|
621
|
+
beforeColon: whitespace[1],
|
622
|
+
afterColon: whitespace[2],
|
623
|
+
};
|
624
|
+
}
|
625
|
+
return null;
|
626
|
+
}
|
627
|
+
|
628
|
+
/**
|
629
|
+
* Creates groups of properties.
|
630
|
+
* @param {ASTNode} node ObjectExpression node being evaluated.
|
631
|
+
* @returns {Array<ASTNode[]>} Groups of property AST node lists.
|
632
|
+
*/
|
633
|
+
function createGroups(node) {
|
634
|
+
if (node.properties.length === 1) {
|
635
|
+
return [node.properties];
|
636
|
+
}
|
637
|
+
|
638
|
+
return node.properties.reduce(
|
639
|
+
(groups, property) => {
|
640
|
+
const currentGroup = last(groups),
|
641
|
+
prev = last(currentGroup);
|
642
|
+
|
643
|
+
if (!prev || continuesPropertyGroup(prev, property)) {
|
644
|
+
currentGroup.push(property);
|
645
|
+
} else {
|
646
|
+
groups.push([property]);
|
647
|
+
}
|
648
|
+
|
649
|
+
return groups;
|
650
|
+
},
|
651
|
+
[[]],
|
652
|
+
);
|
653
|
+
}
|
654
|
+
|
655
|
+
/**
|
656
|
+
* Verifies correct vertical alignment of a group of properties.
|
657
|
+
* @param {ASTNode[]} properties List of Property AST nodes.
|
658
|
+
* @returns {void}
|
659
|
+
*/
|
660
|
+
function verifyGroupAlignment(properties) {
|
661
|
+
const length = properties.length,
|
662
|
+
widths = properties.map(getKeyWidth), // Width of keys, including quotes
|
663
|
+
align = alignmentOptions.on; // "value" or "colon"
|
664
|
+
let targetWidth = Math.max(...widths),
|
665
|
+
beforeColon,
|
666
|
+
afterColon,
|
667
|
+
mode;
|
668
|
+
|
669
|
+
if (alignmentOptions && length > 1) {
|
670
|
+
// When aligning values within a group, use the alignment configuration.
|
671
|
+
beforeColon = alignmentOptions.beforeColon;
|
672
|
+
afterColon = alignmentOptions.afterColon;
|
673
|
+
mode = alignmentOptions.mode;
|
674
|
+
} else {
|
675
|
+
beforeColon = multiLineOptions.beforeColon;
|
676
|
+
afterColon = multiLineOptions.afterColon;
|
677
|
+
mode = alignmentOptions.mode;
|
678
|
+
}
|
679
|
+
|
680
|
+
// Conditionally include one space before or after colon
|
681
|
+
targetWidth += align === "colon" ? beforeColon : afterColon;
|
682
|
+
|
683
|
+
for (let i = 0; i < length; i++) {
|
684
|
+
const property = properties[i];
|
685
|
+
const whitespace = getPropertyWhitespace(property);
|
686
|
+
|
687
|
+
if (whitespace) {
|
688
|
+
// Object literal getters/setters lack a colon
|
689
|
+
const width = widths[i];
|
690
|
+
|
691
|
+
if (align === "value") {
|
692
|
+
report(
|
693
|
+
property,
|
694
|
+
"key",
|
695
|
+
whitespace.beforeColon,
|
696
|
+
beforeColon,
|
697
|
+
mode,
|
698
|
+
);
|
699
|
+
report(
|
700
|
+
property,
|
701
|
+
"value",
|
702
|
+
whitespace.afterColon,
|
703
|
+
targetWidth - width,
|
704
|
+
mode,
|
705
|
+
);
|
706
|
+
} else {
|
707
|
+
// align = "colon"
|
708
|
+
report(
|
709
|
+
property,
|
710
|
+
"key",
|
711
|
+
whitespace.beforeColon,
|
712
|
+
targetWidth - width,
|
713
|
+
mode,
|
714
|
+
);
|
715
|
+
report(
|
716
|
+
property,
|
717
|
+
"value",
|
718
|
+
whitespace.afterColon,
|
719
|
+
afterColon,
|
720
|
+
mode,
|
721
|
+
);
|
722
|
+
}
|
723
|
+
}
|
724
|
+
}
|
725
|
+
}
|
726
|
+
|
727
|
+
/**
|
728
|
+
* Verifies spacing of property conforms to specified options.
|
729
|
+
* @param {ASTNode} node Property node being evaluated.
|
730
|
+
* @param {Object} lineOptions Configured singleLine or multiLine options
|
731
|
+
* @returns {void}
|
732
|
+
*/
|
733
|
+
function verifySpacing(node, lineOptions) {
|
734
|
+
const actual = getPropertyWhitespace(node);
|
735
|
+
|
736
|
+
if (actual) {
|
737
|
+
// Object literal getters/setters lack colons
|
738
|
+
report(
|
739
|
+
node,
|
740
|
+
"key",
|
741
|
+
actual.beforeColon,
|
742
|
+
lineOptions.beforeColon,
|
743
|
+
lineOptions.mode,
|
744
|
+
);
|
745
|
+
report(
|
746
|
+
node,
|
747
|
+
"value",
|
748
|
+
actual.afterColon,
|
749
|
+
lineOptions.afterColon,
|
750
|
+
lineOptions.mode,
|
751
|
+
);
|
752
|
+
}
|
753
|
+
}
|
754
|
+
|
755
|
+
/**
|
756
|
+
* Verifies spacing of each property in a list.
|
757
|
+
* @param {ASTNode[]} properties List of Property AST nodes.
|
758
|
+
* @param {Object} lineOptions Configured singleLine or multiLine options
|
759
|
+
* @returns {void}
|
760
|
+
*/
|
761
|
+
function verifyListSpacing(properties, lineOptions) {
|
762
|
+
const length = properties.length;
|
763
|
+
|
764
|
+
for (let i = 0; i < length; i++) {
|
765
|
+
verifySpacing(properties[i], lineOptions);
|
766
|
+
}
|
767
|
+
}
|
768
|
+
|
769
|
+
/**
|
770
|
+
* Verifies vertical alignment, taking into account groups of properties.
|
771
|
+
* @param {ASTNode} node ObjectExpression node being evaluated.
|
772
|
+
* @returns {void}
|
773
|
+
*/
|
774
|
+
function verifyAlignment(node) {
|
775
|
+
createGroups(node).forEach(group => {
|
776
|
+
const properties = group.filter(isKeyValueProperty);
|
777
|
+
|
778
|
+
if (
|
779
|
+
properties.length > 0 &&
|
780
|
+
isSingleLineProperties(properties)
|
781
|
+
) {
|
782
|
+
verifyListSpacing(properties, multiLineOptions);
|
783
|
+
} else {
|
784
|
+
verifyGroupAlignment(properties);
|
785
|
+
}
|
786
|
+
});
|
787
|
+
}
|
788
|
+
|
789
|
+
//--------------------------------------------------------------------------
|
790
|
+
// Public API
|
791
|
+
//--------------------------------------------------------------------------
|
792
|
+
|
793
|
+
if (alignmentOptions) {
|
794
|
+
// Verify vertical alignment
|
795
|
+
|
796
|
+
return {
|
797
|
+
ObjectExpression(node) {
|
798
|
+
if (isSingleLine(node)) {
|
799
|
+
verifyListSpacing(
|
800
|
+
node.properties.filter(isKeyValueProperty),
|
801
|
+
singleLineOptions,
|
802
|
+
);
|
803
|
+
} else {
|
804
|
+
verifyAlignment(node);
|
805
|
+
}
|
806
|
+
},
|
807
|
+
};
|
808
|
+
}
|
809
|
+
|
810
|
+
// Obey beforeColon and afterColon in each property as configured
|
811
|
+
return {
|
812
|
+
Property(node) {
|
813
|
+
verifySpacing(
|
814
|
+
node,
|
815
|
+
isSingleLine(node.parent)
|
816
|
+
? singleLineOptions
|
817
|
+
: multiLineOptions,
|
818
|
+
);
|
819
|
+
},
|
820
|
+
};
|
821
|
+
},
|
705
822
|
};
|