obsidian-dev-utils 52.2.0 → 52.3.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.
Files changed (31) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/dist/lib/cjs/library.cjs +1 -1
  3. package/dist/lib/cjs/script-utils/linters/eslint-config.cjs +13 -4
  4. package/dist/lib/cjs/script-utils/linters/eslint-rules/index.cjs +12 -6
  5. package/dist/lib/cjs/script-utils/linters/eslint-rules/index.d.cts +3 -1
  6. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.cjs +217 -0
  7. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.d.cts +3 -0
  8. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-variables.cjs +180 -0
  9. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-variables.d.cts +13 -0
  10. package/dist/lib/cjs/script-utils/linters/eslint-rules/obsidian-dev-utils-plugin.cjs +5 -3
  11. package/dist/lib/cjs/script-utils/linters/eslint-rules/rule-tester-helper.cjs +135 -0
  12. package/dist/lib/cjs/script-utils/linters/eslint-rules/rule-tester-helper.d.cts +17 -0
  13. package/dist/lib/esm/library.mjs +1 -1
  14. package/dist/lib/esm/script-utils/linters/eslint-config.mjs +13 -4
  15. package/dist/lib/esm/script-utils/linters/eslint-rules/index.d.mts +3 -1
  16. package/dist/lib/esm/script-utils/linters/eslint-rules/index.mjs +8 -4
  17. package/dist/lib/esm/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.d.mts +3 -0
  18. package/dist/lib/esm/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.mjs +117 -0
  19. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-variables.d.mts +13 -0
  20. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-variables.mjs +73 -0
  21. package/dist/lib/esm/script-utils/linters/eslint-rules/obsidian-dev-utils-plugin.mjs +5 -3
  22. package/dist/lib/esm/script-utils/linters/eslint-rules/rule-tester-helper.d.mts +17 -0
  23. package/dist/lib/esm/script-utils/linters/eslint-rules/rule-tester-helper.mjs +29 -0
  24. package/package.json +5 -2
  25. package/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return/package.json +6 -0
  26. package/script-utils/linters/eslint-rules/no-used-underscore-variables/package.json +6 -0
  27. package/script-utils/linters/eslint-rules/{no-used-underscore-params → rule-tester-helper}/package.json +3 -3
  28. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.cjs +0 -174
  29. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.d.cts +0 -12
  30. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.d.mts +0 -12
  31. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.mjs +0 -68
@@ -29,6 +29,7 @@ import obsidianmd from "eslint-plugin-obsidianmd";
29
29
  import { configs as perfectionistConfigs } from "eslint-plugin-perfectionist";
30
30
  import { defineConfig } from "eslint/config";
31
31
  import globals from "globals";
32
+ import { existsSync } from "node:fs";
32
33
  import tseslint from "typescript-eslint";
33
34
  import { ObsidianPluginRepoPaths } from "../../obsidian/plugin/obsidian-plugin-repo-paths.mjs";
34
35
  import { join } from "../../path.mjs";
@@ -84,7 +85,7 @@ function defineEslintConfigs(params = {}) {
84
85
  }
85
86
  const customConfigs = params.customConfigs?.(context) ?? [];
86
87
  return defineConfig(
87
- includeIgnoreFile(join(getRootFolder() ?? "", ".gitignore")),
88
+ ...getGitIgnoreConfigs(),
88
89
  ...getEslintConfigs(context),
89
90
  ...getTseslintConfigs(context),
90
91
  ...getStylisticConfigs(context),
@@ -292,6 +293,13 @@ function getEslintImportResolverTypescriptConfigs() {
292
293
  }
293
294
  ]);
294
295
  }
296
+ function getGitIgnoreConfigs() {
297
+ const gitignorePath = join(getRootFolder() ?? "", ".gitignore");
298
+ if (!existsSync(gitignorePath)) {
299
+ return [];
300
+ }
301
+ return [includeIgnoreFile(gitignorePath)];
302
+ }
295
303
  function getImportXConfigs(context) {
296
304
  return defineConfig([
297
305
  {
@@ -367,7 +375,7 @@ function getObsidianDevUtilsPluginConfigs(context) {
367
375
  "obsidian-dev-utils": obsidianDevUtilsPlugin
368
376
  },
369
377
  rules: {
370
- "obsidian-dev-utils/no-used-underscore-params": "error"
378
+ "obsidian-dev-utils/no-used-underscore-variables": "error"
371
379
  }
372
380
  }
373
381
  ]);
@@ -518,7 +526,8 @@ function getTseslintConfigs(context) {
518
526
  }
519
527
  ],
520
528
  "@typescript-eslint/prefer-readonly": "error",
521
- "obsidian-dev-utils/no-used-underscore-params": "error"
529
+ "obsidian-dev-utils/no-async-callback-to-unsafe-return": "error",
530
+ "obsidian-dev-utils/no-used-underscore-variables": "error"
522
531
  }
523
532
  },
524
533
  {
@@ -534,4 +543,4 @@ export {
534
543
  EslintConfigContext,
535
544
  defineEslintConfigs
536
545
  };
537
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/script-utils/linters/eslint-config.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * ESLint configuration for TypeScript projects with various plugins.\n *\n * This module exports ESLint configurations for TypeScript projects, integrating multiple ESLint plugins\n * such as `@typescript-eslint/parser`, `@typescript-eslint/eslint-plugin`,\n * `eslint-plugin-modules-newlines`, `@stylistic/eslint-plugin`.\n * It sets up parsers, plugins, and rules for maintaining code quality and consistency.\n */\n\n/* v8 ignore start -- Declarative ESLint rule/plugin configuration; correctness is verified by running ESLint, not unit tests. */\n\nimport type {\n  ESLint,\n  Linter\n} from 'eslint';\n\n/* eslint-disable no-magic-numbers -- We disabled magic numbers because they are used all over the configs. */\nimport commentsConfigs from '@eslint-community/eslint-plugin-eslint-comments/configs';\nimport { includeIgnoreFile } from '@eslint/compat';\nimport eslint from '@eslint/js';\n// eslint-disable-next-line import-x/no-rename-default -- The default export name `plugin` is too confusing.\nimport stylistic from '@stylistic/eslint-plugin';\nimport { createTypeScriptImportResolver } from 'eslint-import-resolver-typescript';\nimport { flatConfigs as eslintPluginImportXFlatConfigs } from 'eslint-plugin-import-x';\n// eslint-disable-next-line import-x/no-rename-default -- The default export name `plugin` is too confusing.\nimport obsidianmd from 'eslint-plugin-obsidianmd';\nimport { configs as perfectionistConfigs } from 'eslint-plugin-perfectionist';\nimport { defineConfig } from 'eslint/config';\nimport globals from 'globals';\n// eslint-disable-next-line import-x/no-rename-default -- The default export name `_default` is too confusing.\nimport tseslint from 'typescript-eslint';\n\nimport { ObsidianPluginRepoPaths } from '../../obsidian/plugin/obsidian-plugin-repo-paths.ts';\nimport { join } from '../../path.ts';\nimport { getRootFolder } from '../root.ts';\nimport { obsidianDevUtilsPlugin } from './eslint-rules/obsidian-dev-utils-plugin.ts';\n\n/**\n * The parameters for defining ESLint configurations.\n */\nexport interface DefineEslintConfigsParams {\n  /**\n   * A function that builds custom ESLint configurations.\n   *\n   * @param context - The ESLint configuration context.\n   * @returns The custom ESLint configurations.\n   */\n  customConfigs?(context: EslintConfigContext): Linter.Config[];\n\n  /**\n   * A function that edits the ESLint configuration context.\n   *\n   * @param context - The ESLint configuration context.\n   */\n  editContext?(context: EslintConfigContext): void;\n}\n\n/**\n * The context for defining ESLint configurations.\n */\nexport class EslintConfigContext {\n  /**\n   * The root configuration files.\n   */\n  public readonly rootConfigFiles: string[] = [];\n\n  /**\n   * The script files.\n   */\n  public readonly scriptFiles: string[] = [];\n\n  /**\n   * The source files.\n   */\n  public readonly sourceFiles: string[] = [];\n\n  /**\n   * The test files.\n   */\n  public readonly testFiles: string[] = [];\n\n  /**\n   * The all files.\n   *\n   * @returns The all files.\n   */\n  public allFiles(): string[] {\n    return [...this.testFiles, ...this.scriptFiles, ...this.rootConfigFiles, ...this.sourceFiles];\n  }\n}\n\n/**\n * Build ESLint configurations.\n *\n * This function builds ESLint configurations for TypeScript projects, integrating multiple ESLint plugins\n *\n * @param params - The parameters for defining ESLint configurations.\n * @returns The ESLint configurations.\n */\nexport function defineEslintConfigs(params: DefineEslintConfigsParams = {}): Linter.Config[] {\n  const context = new EslintConfigContext();\n  context.rootConfigFiles.push(\n    ObsidianPluginRepoPaths.CommitlintConfigTs,\n    ObsidianPluginRepoPaths.EslintConfigMts,\n    ObsidianPluginRepoPaths.VitestConfigTs\n  );\n  context.scriptFiles.push(\n    join(ObsidianPluginRepoPaths.Scripts, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs)\n  );\n  context.sourceFiles.push(\n    join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs),\n    join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTsx)\n  );\n  context.testFiles.push(\n    join(ObsidianPluginRepoPaths.Tests, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs),\n    join(ObsidianPluginRepoPaths.Mocks, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs),\n    join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTestTs)\n  );\n\n  if (params.editContext) {\n    params.editContext(context);\n  }\n\n  const customConfigs = params.customConfigs?.(context) ?? [];\n\n  return defineConfig(\n    includeIgnoreFile(join(getRootFolder() ?? '', '.gitignore')),\n    ...getEslintConfigs(context),\n    ...getTseslintConfigs(context),\n    ...getStylisticConfigs(context),\n    ...getObsidianLintConfigs(context),\n    ...getImportXConfigs(context),\n    ...getPerfectionistConfigs(context),\n    ...getEslintImportResolverTypescriptConfigs(),\n    ...getEslintCommentsConfigs(context),\n    ...getObsidianDevUtilsPluginConfigs(context),\n    ...customConfigs\n  );\n}\n\nfunction getEslintCommentsConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      // eslint-disable-next-line import-x/no-named-as-default-member -- The default export name `recommended` is too confusing.\n      extends: [commentsConfigs.recommended],\n      files: context.allFiles(),\n      rules: {\n        '@eslint-community/eslint-comments/require-description': 'error'\n      }\n    }\n  ]);\n}\n\nfunction getEslintConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [eslint.configs.recommended],\n      files: context.allFiles(),\n      rules: {\n        'accessor-pairs': 'error',\n        'array-callback-return': 'error',\n        'camelcase': 'error',\n        'capitalized-comments': ['error', 'always', { block: { ignorePattern: 'v8' } }],\n        'complexity': 'error',\n        'consistent-this': 'error',\n        'curly': 'error',\n        'default-case': 'error',\n        'default-case-last': 'error',\n        'default-param-last': 'error',\n        'eqeqeq': 'error',\n        'func-name-matching': 'error',\n        'func-names': 'error',\n        'func-style': [\n          'error',\n          'declaration',\n          {\n            allowArrowFunctions: false\n          }\n        ],\n        'grouped-accessor-pairs': [\n          'error',\n          'getBeforeSet'\n        ],\n        'guard-for-in': 'error',\n        'no-alert': 'error',\n        'no-array-constructor': 'error',\n        'no-bitwise': 'error',\n        'no-caller': 'error',\n        'no-console': [\n          'error',\n          {\n            allow: [\n              'warn',\n              'error'\n            ]\n          }\n        ],\n        'no-constructor-return': 'error',\n        'no-div-regex': 'error',\n        'no-else-return': [\n          'error',\n          {\n            allowElseIf: false\n          }\n        ],\n        'no-empty-function': 'error',\n        'no-extend-native': 'error',\n        'no-extra-bind': 'error',\n        'no-extra-label': 'error',\n        'no-implicit-coercion': [\n          'error',\n          {\n            allow: [\n              '!!'\n            ]\n          }\n        ],\n        'no-implied-eval': 'error',\n        'no-inner-declarations': 'error',\n        'no-iterator': 'error',\n        'no-label-var': 'error',\n        'no-labels': 'error',\n        'no-lone-blocks': 'error',\n        'no-lonely-if': 'error',\n        'no-loop-func': 'error',\n        'no-magic-numbers': [\n          'error',\n          {\n            detectObjects: true,\n            enforceConst: true,\n            ignore: [\n              -1,\n              0,\n              1\n            ]\n          }\n        ],\n        'no-multi-assign': 'error',\n        'no-multi-str': 'error',\n        'no-negated-condition': 'error',\n        'no-nested-ternary': 'error',\n        'no-new-func': 'error',\n        'no-new-wrappers': 'error',\n        'no-object-constructor': 'error',\n        'no-octal-escape': 'error',\n        'no-promise-executor-return': 'error',\n        'no-proto': 'error',\n        'no-restricted-syntax': [\n          'error',\n          {\n            message: 'Do not use definite assignment assertions (!). Initialize the field or make it optional.',\n            selector: 'PropertyDefinition[definite=true]'\n          },\n          {\n            message: 'Do not use definite assignment assertions (!) on abstract fields.',\n            selector: 'TSAbstractPropertyDefinition[definite=true]'\n          },\n          {\n            message: 'Do not use anonymous inline object types in function parameters. Define a named interface instead.',\n            selector: ':function > Identifier TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types in function return types. Define a named interface instead.',\n            selector: ':function > TSTypeAnnotation TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types in interface/method signatures. Define a named interface instead.',\n            selector: 'TSMethodSignature TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types as type arguments. Define a named interface instead.',\n            selector: 'TSTypeParameterInstantiation TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types in type annotations. Define a named interface instead.',\n            selector: 'TSTypeAnnotation TSTypeLiteral'\n          }\n        ],\n        'no-return-assign': 'error',\n        'no-script-url': 'error',\n        'no-self-compare': 'error',\n        'no-sequences': 'error',\n        'no-shadow': 'error',\n        'no-template-curly-in-string': 'error',\n        'no-throw-literal': 'error',\n        'no-unmodified-loop-condition': 'error',\n        'no-unneeded-ternary': 'error',\n        'no-unreachable-loop': 'error',\n        'no-unused-expressions': 'error',\n        'no-useless-assignment': 'error',\n        'no-useless-call': 'error',\n        'no-useless-computed-key': 'error',\n        'no-useless-concat': 'error',\n        'no-useless-constructor': 'error',\n        'no-useless-rename': 'error',\n        'no-useless-return': 'error',\n        'no-var': 'error',\n        'no-void': 'error',\n        'object-shorthand': 'error',\n        'operator-assignment': 'error',\n        'prefer-arrow-callback': 'error',\n        'prefer-const': 'error',\n        'prefer-exponentiation-operator': 'error',\n        'prefer-named-capture-group': 'error',\n        'prefer-numeric-literals': 'error',\n        'prefer-object-has-own': 'error',\n        'prefer-object-spread': 'error',\n        'prefer-promise-reject-errors': 'error',\n        'prefer-regex-literals': 'error',\n        'prefer-rest-params': 'error',\n        'prefer-spread': 'error',\n        'prefer-template': 'error',\n        'radix': 'error',\n        'require-atomic-updates': 'error',\n        'require-await': 'error',\n        'symbol-description': 'error',\n        'unicode-bom': 'error',\n        'vars-on-top': 'error',\n        'yoda': 'error'\n      }\n    }\n  ]);\n}\n\nfunction getEslintImportResolverTypescriptConfigs(): Linter.Config[] {\n  return defineConfig([\n    {\n      settings: {\n        'import-x/resolver-next': [\n          createTypeScriptImportResolver({\n            alwaysTryTypes: true\n          })\n        ]\n      }\n    }\n  ]);\n}\n\nfunction getImportXConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [\n        eslintPluginImportXFlatConfigs.recommended as Linter.Config,\n        eslintPluginImportXFlatConfigs.typescript as Linter.Config,\n        eslintPluginImportXFlatConfigs.errors as Linter.Config,\n        eslintPluginImportXFlatConfigs.warnings as Linter.Config\n      ],\n      files: context.allFiles(),\n      rules: {\n        'import-x/consistent-type-specifier-style': 'error',\n        'import-x/extensions': ['error', 'ignorePackages'],\n        'import-x/first': 'error',\n        'import-x/imports-first': 'error',\n        'import-x/newline-after-import': 'error',\n        'import-x/no-absolute-path': 'error',\n        'import-x/no-amd': 'error',\n        'import-x/no-anonymous-default-export': 'error',\n        'import-x/no-commonjs': 'error',\n        'import-x/no-cycle': 'error',\n        'import-x/no-default-export': 'error',\n        'import-x/no-deprecated': 'error',\n        'import-x/no-duplicates': 'error',\n        'import-x/no-dynamic-require': 'error',\n        'import-x/no-empty-named-blocks': 'error',\n        'import-x/no-extraneous-dependencies': 'error',\n        'import-x/no-import-module-exports': 'error',\n        'import-x/no-mutable-exports': 'error',\n        'import-x/no-named-default': 'error',\n        'import-x/no-namespace': 'error',\n        'import-x/no-nodejs-modules': 'error',\n        'import-x/no-relative-packages': 'error',\n        'import-x/no-restricted-paths': 'error',\n        'import-x/no-self-import': 'error',\n        'import-x/no-unassigned-import': [\n          'error',\n          {\n            allow: [\n              '**/*.css',\n              '**/*.sass',\n              '**/*.scss'\n            ]\n          }\n        ],\n        'import-x/no-unused-modules': 'off',\n        'import-x/no-useless-path-segments': 'error',\n        'import-x/no-webpack-loader-syntax': 'error'\n      }\n    },\n    {\n      files: context.scriptFiles,\n      rules: {\n        'import-x/no-nodejs-modules': 'off'\n      }\n    },\n    {\n      files: [\n        ...context.rootConfigFiles,\n        join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs)\n      ],\n      rules: {\n        'import-x/no-default-export': 'off'\n      }\n    }\n  ]);\n}\n\nfunction getObsidianDevUtilsPluginConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      files: context.allFiles(),\n      plugins: {\n        'obsidian-dev-utils': obsidianDevUtilsPlugin\n      },\n      rules: {\n        'obsidian-dev-utils/no-used-underscore-params': 'error'\n      }\n    }\n  ]);\n}\n\nfunction getObsidianLintConfigs(context: EslintConfigContext): Linter.Config[] {\n  const obsidianRecommendedConfigs = Array.from(obsidianmd.configs?.['recommended'] as Iterable<Linter.Config>);\n\n  const scopedObsidianRecommendedConfigs = obsidianRecommendedConfigs.map((config) => {\n    if (config.files?.includes('package.json')) {\n      return config;\n    }\n\n    return {\n      ...config,\n      files: context.sourceFiles\n    };\n  });\n\n  return defineConfig([\n    ...scopedObsidianRecommendedConfigs,\n    {\n      plugins: {\n        obsidianmd: obsidianmd as ESLint.Plugin\n      }\n    },\n    {\n      languageOptions: {\n        globals: {\n          ...globals.browser,\n          ...globals.node,\n          activeDocument: 'readonly',\n          activeWindow: 'readonly',\n          ajax: 'readonly',\n          ajaxPromise: 'readonly',\n          createDiv: 'readonly',\n          createEl: 'readonly',\n          createFragment: 'readonly',\n          createSpan: 'readonly',\n          createSvg: 'readonly',\n          DomElementInfo: 'readonly',\n          fish: 'readonly',\n          fishAll: 'readonly',\n          isBoolean: 'readonly',\n          nextFrame: 'readonly',\n          NodeJS: 'readonly',\n          ready: 'readonly',\n          sleep: 'readonly'\n        }\n      }\n    }\n  ]);\n}\n\nfunction getPerfectionistConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([{\n    extends: [perfectionistConfigs['recommended-alphabetical']],\n    files: context.allFiles()\n  }]);\n}\n\nfunction getStylisticConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [\n        stylistic.configs.recommended,\n        stylistic.configs.customize({\n          arrowParens: true,\n          braceStyle: '1tbs',\n          commaDangle: 'never',\n          semi: true\n        })\n      ],\n      files: context.allFiles(),\n      rules: {\n        '@stylistic/generator-star-spacing': 'off',\n        '@stylistic/indent': 'off',\n        '@stylistic/indent-binary-ops': 'off',\n        '@stylistic/jsx-one-expression-per-line': 'off',\n        '@stylistic/no-extra-semi': 'error',\n        '@stylistic/object-curly-newline': [\n          'error',\n          {\n            ExportDeclaration: {\n              minProperties: 2,\n              multiline: true\n            },\n            ImportDeclaration: {\n              minProperties: 2,\n              multiline: true\n            }\n          }\n        ],\n        '@stylistic/operator-linebreak': [\n          'error',\n          'before',\n          {\n            overrides: {\n              '=': 'after'\n            }\n          }\n        ],\n        '@stylistic/quotes': [\n          'error',\n          'single',\n          {\n            allowTemplateLiterals: 'never'\n          }\n        ]\n      }\n    }\n  ]);\n}\n\nfunction getTseslintConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [\n        // eslint-disable-next-line import-x/no-named-as-default-member -- The default export name `_default` is too confusing.\n        ...tseslint.configs.strictTypeChecked,\n        // eslint-disable-next-line import-x/no-named-as-default-member -- The default export name `_default` is too confusing.\n        ...tseslint.configs.stylisticTypeChecked\n      ],\n      files: context.allFiles(),\n      languageOptions: {\n        parserOptions: {\n          ecmaFeatures: {\n            jsx: true\n          },\n          projectService: true,\n          tsconfigRootDir: getRootFolder() ?? ''\n        }\n      },\n      rules: {\n        '@typescript-eslint/explicit-function-return-type': 'error',\n        '@typescript-eslint/explicit-member-accessibility': 'error',\n        '@typescript-eslint/no-invalid-void-type': ['error', {\n          allowAsThisParameter: true\n        }],\n        '@typescript-eslint/no-this-alias': ['error', {\n          allowedNames: [\n            'that'\n          ]\n        }],\n        '@typescript-eslint/no-unused-vars': [\n          'error',\n          {\n            args: 'all',\n            argsIgnorePattern: '^_',\n            caughtErrors: 'all',\n            caughtErrorsIgnorePattern: '^_',\n            destructuredArrayIgnorePattern: '^_',\n            ignoreRestSiblings: true,\n            varsIgnorePattern: '^_'\n          }\n        ],\n        '@typescript-eslint/prefer-readonly': 'error',\n        'obsidian-dev-utils/no-used-underscore-params': 'error'\n      }\n    },\n    {\n      settings: {\n        react: {\n          version: 'detect'\n        }\n      }\n    }\n  ]);\n}\n\n/* eslint-enable no-magic-numbers -- We disabled magic numbers because they are used all over the configs. */\n\n/* v8 ignore stop */\n"],
  "mappings": "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",
  "names": []
}

546
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/script-utils/linters/eslint-config.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * ESLint configuration for TypeScript projects with various plugins.\n *\n * This module exports ESLint configurations for TypeScript projects, integrating multiple ESLint plugins\n * such as `@typescript-eslint/parser`, `@typescript-eslint/eslint-plugin`,\n * `eslint-plugin-modules-newlines`, `@stylistic/eslint-plugin`.\n * It sets up parsers, plugins, and rules for maintaining code quality and consistency.\n */\n\n/* v8 ignore start -- Declarative ESLint rule/plugin configuration; correctness is verified by running ESLint, not unit tests. */\n\nimport type {\n  ESLint,\n  Linter\n} from 'eslint';\n\n/* eslint-disable no-magic-numbers -- We disabled magic numbers because they are used all over the configs. */\nimport commentsConfigs from '@eslint-community/eslint-plugin-eslint-comments/configs';\nimport { includeIgnoreFile } from '@eslint/compat';\nimport eslint from '@eslint/js';\n// eslint-disable-next-line import-x/no-rename-default -- The default export name `plugin` is too confusing.\nimport stylistic from '@stylistic/eslint-plugin';\nimport { createTypeScriptImportResolver } from 'eslint-import-resolver-typescript';\nimport { flatConfigs as eslintPluginImportXFlatConfigs } from 'eslint-plugin-import-x';\n// eslint-disable-next-line import-x/no-rename-default -- The default export name `plugin` is too confusing.\nimport obsidianmd from 'eslint-plugin-obsidianmd';\nimport { configs as perfectionistConfigs } from 'eslint-plugin-perfectionist';\nimport { defineConfig } from 'eslint/config';\nimport globals from 'globals';\nimport { existsSync } from 'node:fs';\n// eslint-disable-next-line import-x/no-rename-default -- The default export name `_default` is too confusing.\nimport tseslint from 'typescript-eslint';\n\nimport { ObsidianPluginRepoPaths } from '../../obsidian/plugin/obsidian-plugin-repo-paths.ts';\nimport { join } from '../../path.ts';\nimport { getRootFolder } from '../root.ts';\nimport { obsidianDevUtilsPlugin } from './eslint-rules/obsidian-dev-utils-plugin.ts';\n\n/**\n * The parameters for defining ESLint configurations.\n */\nexport interface DefineEslintConfigsParams {\n  /**\n   * A function that builds custom ESLint configurations.\n   *\n   * @param context - The ESLint configuration context.\n   * @returns The custom ESLint configurations.\n   */\n  customConfigs?(context: EslintConfigContext): Linter.Config[];\n\n  /**\n   * A function that edits the ESLint configuration context.\n   *\n   * @param context - The ESLint configuration context.\n   */\n  editContext?(context: EslintConfigContext): void;\n}\n\n/**\n * The context for defining ESLint configurations.\n */\nexport class EslintConfigContext {\n  /**\n   * The root configuration files.\n   */\n  public readonly rootConfigFiles: string[] = [];\n\n  /**\n   * The script files.\n   */\n  public readonly scriptFiles: string[] = [];\n\n  /**\n   * The source files.\n   */\n  public readonly sourceFiles: string[] = [];\n\n  /**\n   * The test files.\n   */\n  public readonly testFiles: string[] = [];\n\n  /**\n   * The all files.\n   *\n   * @returns The all files.\n   */\n  public allFiles(): string[] {\n    return [...this.testFiles, ...this.scriptFiles, ...this.rootConfigFiles, ...this.sourceFiles];\n  }\n}\n\n/**\n * Build ESLint configurations.\n *\n * This function builds ESLint configurations for TypeScript projects, integrating multiple ESLint plugins\n *\n * @param params - The parameters for defining ESLint configurations.\n * @returns The ESLint configurations.\n */\nexport function defineEslintConfigs(params: DefineEslintConfigsParams = {}): Linter.Config[] {\n  const context = new EslintConfigContext();\n  context.rootConfigFiles.push(\n    ObsidianPluginRepoPaths.CommitlintConfigTs,\n    ObsidianPluginRepoPaths.EslintConfigMts,\n    ObsidianPluginRepoPaths.VitestConfigTs\n  );\n  context.scriptFiles.push(\n    join(ObsidianPluginRepoPaths.Scripts, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs)\n  );\n  context.sourceFiles.push(\n    join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs),\n    join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTsx)\n  );\n  context.testFiles.push(\n    join(ObsidianPluginRepoPaths.Tests, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs),\n    join(ObsidianPluginRepoPaths.Mocks, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTs),\n    join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.AnyPath, ObsidianPluginRepoPaths.AnyTestTs)\n  );\n\n  if (params.editContext) {\n    params.editContext(context);\n  }\n\n  const customConfigs = params.customConfigs?.(context) ?? [];\n\n  return defineConfig(\n    ...getGitIgnoreConfigs(),\n    ...getEslintConfigs(context),\n    ...getTseslintConfigs(context),\n    ...getStylisticConfigs(context),\n    ...getObsidianLintConfigs(context),\n    ...getImportXConfigs(context),\n    ...getPerfectionistConfigs(context),\n    ...getEslintImportResolverTypescriptConfigs(),\n    ...getEslintCommentsConfigs(context),\n    ...getObsidianDevUtilsPluginConfigs(context),\n    ...customConfigs\n  );\n}\n\nfunction getEslintCommentsConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      // eslint-disable-next-line import-x/no-named-as-default-member -- The default export name `recommended` is too confusing.\n      extends: [commentsConfigs.recommended],\n      files: context.allFiles(),\n      rules: {\n        '@eslint-community/eslint-comments/require-description': 'error'\n      }\n    }\n  ]);\n}\n\nfunction getEslintConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [eslint.configs.recommended],\n      files: context.allFiles(),\n      rules: {\n        'accessor-pairs': 'error',\n        'array-callback-return': 'error',\n        'camelcase': 'error',\n        'capitalized-comments': ['error', 'always', { block: { ignorePattern: 'v8' } }],\n        'complexity': 'error',\n        'consistent-this': 'error',\n        'curly': 'error',\n        'default-case': 'error',\n        'default-case-last': 'error',\n        'default-param-last': 'error',\n        'eqeqeq': 'error',\n        'func-name-matching': 'error',\n        'func-names': 'error',\n        'func-style': [\n          'error',\n          'declaration',\n          {\n            allowArrowFunctions: false\n          }\n        ],\n        'grouped-accessor-pairs': [\n          'error',\n          'getBeforeSet'\n        ],\n        'guard-for-in': 'error',\n        'no-alert': 'error',\n        'no-array-constructor': 'error',\n        'no-bitwise': 'error',\n        'no-caller': 'error',\n        'no-console': [\n          'error',\n          {\n            allow: [\n              'warn',\n              'error'\n            ]\n          }\n        ],\n        'no-constructor-return': 'error',\n        'no-div-regex': 'error',\n        'no-else-return': [\n          'error',\n          {\n            allowElseIf: false\n          }\n        ],\n        'no-empty-function': 'error',\n        'no-extend-native': 'error',\n        'no-extra-bind': 'error',\n        'no-extra-label': 'error',\n        'no-implicit-coercion': [\n          'error',\n          {\n            allow: [\n              '!!'\n            ]\n          }\n        ],\n        'no-implied-eval': 'error',\n        'no-inner-declarations': 'error',\n        'no-iterator': 'error',\n        'no-label-var': 'error',\n        'no-labels': 'error',\n        'no-lone-blocks': 'error',\n        'no-lonely-if': 'error',\n        'no-loop-func': 'error',\n        'no-magic-numbers': [\n          'error',\n          {\n            detectObjects: true,\n            enforceConst: true,\n            ignore: [\n              -1,\n              0,\n              1\n            ]\n          }\n        ],\n        'no-multi-assign': 'error',\n        'no-multi-str': 'error',\n        'no-negated-condition': 'error',\n        'no-nested-ternary': 'error',\n        'no-new-func': 'error',\n        'no-new-wrappers': 'error',\n        'no-object-constructor': 'error',\n        'no-octal-escape': 'error',\n        'no-promise-executor-return': 'error',\n        'no-proto': 'error',\n        'no-restricted-syntax': [\n          'error',\n          {\n            message: 'Do not use definite assignment assertions (!). Initialize the field or make it optional.',\n            selector: 'PropertyDefinition[definite=true]'\n          },\n          {\n            message: 'Do not use definite assignment assertions (!) on abstract fields.',\n            selector: 'TSAbstractPropertyDefinition[definite=true]'\n          },\n          {\n            message: 'Do not use anonymous inline object types in function parameters. Define a named interface instead.',\n            selector: ':function > Identifier TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types in function return types. Define a named interface instead.',\n            selector: ':function > TSTypeAnnotation TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types in interface/method signatures. Define a named interface instead.',\n            selector: 'TSMethodSignature TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types as type arguments. Define a named interface instead.',\n            selector: 'TSTypeParameterInstantiation TSTypeLiteral'\n          },\n          {\n            message: 'Do not use anonymous inline object types in type annotations. Define a named interface instead.',\n            selector: 'TSTypeAnnotation TSTypeLiteral'\n          }\n        ],\n        'no-return-assign': 'error',\n        'no-script-url': 'error',\n        'no-self-compare': 'error',\n        'no-sequences': 'error',\n        'no-shadow': 'error',\n        'no-template-curly-in-string': 'error',\n        'no-throw-literal': 'error',\n        'no-unmodified-loop-condition': 'error',\n        'no-unneeded-ternary': 'error',\n        'no-unreachable-loop': 'error',\n        'no-unused-expressions': 'error',\n        'no-useless-assignment': 'error',\n        'no-useless-call': 'error',\n        'no-useless-computed-key': 'error',\n        'no-useless-concat': 'error',\n        'no-useless-constructor': 'error',\n        'no-useless-rename': 'error',\n        'no-useless-return': 'error',\n        'no-var': 'error',\n        'no-void': 'error',\n        'object-shorthand': 'error',\n        'operator-assignment': 'error',\n        'prefer-arrow-callback': 'error',\n        'prefer-const': 'error',\n        'prefer-exponentiation-operator': 'error',\n        'prefer-named-capture-group': 'error',\n        'prefer-numeric-literals': 'error',\n        'prefer-object-has-own': 'error',\n        'prefer-object-spread': 'error',\n        'prefer-promise-reject-errors': 'error',\n        'prefer-regex-literals': 'error',\n        'prefer-rest-params': 'error',\n        'prefer-spread': 'error',\n        'prefer-template': 'error',\n        'radix': 'error',\n        'require-atomic-updates': 'error',\n        'require-await': 'error',\n        'symbol-description': 'error',\n        'unicode-bom': 'error',\n        'vars-on-top': 'error',\n        'yoda': 'error'\n      }\n    }\n  ]);\n}\n\nfunction getEslintImportResolverTypescriptConfigs(): Linter.Config[] {\n  return defineConfig([\n    {\n      settings: {\n        'import-x/resolver-next': [\n          createTypeScriptImportResolver({\n            alwaysTryTypes: true\n          })\n        ]\n      }\n    }\n  ]);\n}\n\nfunction getGitIgnoreConfigs(): Linter.Config[] {\n  const gitignorePath = join(getRootFolder() ?? '', '.gitignore');\n  if (!existsSync(gitignorePath)) {\n    return [];\n  }\n  return [includeIgnoreFile(gitignorePath)];\n}\n\nfunction getImportXConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [\n        eslintPluginImportXFlatConfigs.recommended as Linter.Config,\n        eslintPluginImportXFlatConfigs.typescript as Linter.Config,\n        eslintPluginImportXFlatConfigs.errors as Linter.Config,\n        eslintPluginImportXFlatConfigs.warnings as Linter.Config\n      ],\n      files: context.allFiles(),\n      rules: {\n        'import-x/consistent-type-specifier-style': 'error',\n        'import-x/extensions': ['error', 'ignorePackages'],\n        'import-x/first': 'error',\n        'import-x/imports-first': 'error',\n        'import-x/newline-after-import': 'error',\n        'import-x/no-absolute-path': 'error',\n        'import-x/no-amd': 'error',\n        'import-x/no-anonymous-default-export': 'error',\n        'import-x/no-commonjs': 'error',\n        'import-x/no-cycle': 'error',\n        'import-x/no-default-export': 'error',\n        'import-x/no-deprecated': 'error',\n        'import-x/no-duplicates': 'error',\n        'import-x/no-dynamic-require': 'error',\n        'import-x/no-empty-named-blocks': 'error',\n        'import-x/no-extraneous-dependencies': 'error',\n        'import-x/no-import-module-exports': 'error',\n        'import-x/no-mutable-exports': 'error',\n        'import-x/no-named-default': 'error',\n        'import-x/no-namespace': 'error',\n        'import-x/no-nodejs-modules': 'error',\n        'import-x/no-relative-packages': 'error',\n        'import-x/no-restricted-paths': 'error',\n        'import-x/no-self-import': 'error',\n        'import-x/no-unassigned-import': [\n          'error',\n          {\n            allow: [\n              '**/*.css',\n              '**/*.sass',\n              '**/*.scss'\n            ]\n          }\n        ],\n        'import-x/no-unused-modules': 'off',\n        'import-x/no-useless-path-segments': 'error',\n        'import-x/no-webpack-loader-syntax': 'error'\n      }\n    },\n    {\n      files: context.scriptFiles,\n      rules: {\n        'import-x/no-nodejs-modules': 'off'\n      }\n    },\n    {\n      files: [\n        ...context.rootConfigFiles,\n        join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs)\n      ],\n      rules: {\n        'import-x/no-default-export': 'off'\n      }\n    }\n  ]);\n}\n\nfunction getObsidianDevUtilsPluginConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      files: context.allFiles(),\n      plugins: {\n        'obsidian-dev-utils': obsidianDevUtilsPlugin\n      },\n      rules: {\n        'obsidian-dev-utils/no-used-underscore-variables': 'error'\n      }\n    }\n  ]);\n}\n\nfunction getObsidianLintConfigs(context: EslintConfigContext): Linter.Config[] {\n  const obsidianRecommendedConfigs = Array.from(obsidianmd.configs?.['recommended'] as Iterable<Linter.Config>);\n\n  const scopedObsidianRecommendedConfigs = obsidianRecommendedConfigs.map((config) => {\n    if (config.files?.includes('package.json')) {\n      return config;\n    }\n\n    return {\n      ...config,\n      files: context.sourceFiles\n    };\n  });\n\n  return defineConfig([\n    ...scopedObsidianRecommendedConfigs,\n    {\n      plugins: {\n        obsidianmd: obsidianmd as ESLint.Plugin\n      }\n    },\n    {\n      languageOptions: {\n        globals: {\n          ...globals.browser,\n          ...globals.node,\n          activeDocument: 'readonly',\n          activeWindow: 'readonly',\n          ajax: 'readonly',\n          ajaxPromise: 'readonly',\n          createDiv: 'readonly',\n          createEl: 'readonly',\n          createFragment: 'readonly',\n          createSpan: 'readonly',\n          createSvg: 'readonly',\n          DomElementInfo: 'readonly',\n          fish: 'readonly',\n          fishAll: 'readonly',\n          isBoolean: 'readonly',\n          nextFrame: 'readonly',\n          NodeJS: 'readonly',\n          ready: 'readonly',\n          sleep: 'readonly'\n        }\n      }\n    }\n  ]);\n}\n\nfunction getPerfectionistConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([{\n    extends: [perfectionistConfigs['recommended-alphabetical']],\n    files: context.allFiles()\n  }]);\n}\n\nfunction getStylisticConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [\n        stylistic.configs.recommended,\n        stylistic.configs.customize({\n          arrowParens: true,\n          braceStyle: '1tbs',\n          commaDangle: 'never',\n          semi: true\n        })\n      ],\n      files: context.allFiles(),\n      rules: {\n        '@stylistic/generator-star-spacing': 'off',\n        '@stylistic/indent': 'off',\n        '@stylistic/indent-binary-ops': 'off',\n        '@stylistic/jsx-one-expression-per-line': 'off',\n        '@stylistic/no-extra-semi': 'error',\n        '@stylistic/object-curly-newline': [\n          'error',\n          {\n            ExportDeclaration: {\n              minProperties: 2,\n              multiline: true\n            },\n            ImportDeclaration: {\n              minProperties: 2,\n              multiline: true\n            }\n          }\n        ],\n        '@stylistic/operator-linebreak': [\n          'error',\n          'before',\n          {\n            overrides: {\n              '=': 'after'\n            }\n          }\n        ],\n        '@stylistic/quotes': [\n          'error',\n          'single',\n          {\n            allowTemplateLiterals: 'never'\n          }\n        ]\n      }\n    }\n  ]);\n}\n\nfunction getTseslintConfigs(context: EslintConfigContext): Linter.Config[] {\n  return defineConfig([\n    {\n      extends: [\n        // eslint-disable-next-line import-x/no-named-as-default-member -- The default export name `_default` is too confusing.\n        ...tseslint.configs.strictTypeChecked,\n        // eslint-disable-next-line import-x/no-named-as-default-member -- The default export name `_default` is too confusing.\n        ...tseslint.configs.stylisticTypeChecked\n      ],\n      files: context.allFiles(),\n      languageOptions: {\n        parserOptions: {\n          ecmaFeatures: {\n            jsx: true\n          },\n          projectService: true,\n          tsconfigRootDir: getRootFolder() ?? ''\n        }\n      },\n      rules: {\n        '@typescript-eslint/explicit-function-return-type': 'error',\n        '@typescript-eslint/explicit-member-accessibility': 'error',\n        '@typescript-eslint/no-invalid-void-type': ['error', {\n          allowAsThisParameter: true\n        }],\n        '@typescript-eslint/no-this-alias': ['error', {\n          allowedNames: [\n            'that'\n          ]\n        }],\n        '@typescript-eslint/no-unused-vars': [\n          'error',\n          {\n            args: 'all',\n            argsIgnorePattern: '^_',\n            caughtErrors: 'all',\n            caughtErrorsIgnorePattern: '^_',\n            destructuredArrayIgnorePattern: '^_',\n            ignoreRestSiblings: true,\n            varsIgnorePattern: '^_'\n          }\n        ],\n        '@typescript-eslint/prefer-readonly': 'error',\n        'obsidian-dev-utils/no-async-callback-to-unsafe-return': 'error',\n        'obsidian-dev-utils/no-used-underscore-variables': 'error'\n      }\n    },\n    {\n      settings: {\n        react: {\n          version: 'detect'\n        }\n      }\n    }\n  ]);\n}\n\n/* eslint-enable no-magic-numbers -- We disabled magic numbers because they are used all over the configs. */\n\n/* v8 ignore stop */\n"],
  "mappings": "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",
  "names": []
}

@@ -1,2 +1,4 @@
1
- export * as no_used_underscore_params from './no-used-underscore-params.mjs';
1
+ export * as no_async_callback_to_unsafe_return from './no-async-callback-to-unsafe-return.mjs';
2
+ export * as no_used_underscore_variables from './no-used-underscore-variables.mjs';
2
3
  export * as obsidian_dev_utils_plugin from './obsidian-dev-utils-plugin.mjs';
4
+ export * as rule_tester_helper from './rule-tester-helper.mjs';
@@ -19,10 +19,14 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
- import * as no_used_underscore_params from "./no-used-underscore-params.mjs";
22
+ import * as no_async_callback_to_unsafe_return from "./no-async-callback-to-unsafe-return.mjs";
23
+ import * as no_used_underscore_variables from "./no-used-underscore-variables.mjs";
23
24
  import * as obsidian_dev_utils_plugin from "./obsidian-dev-utils-plugin.mjs";
25
+ import * as rule_tester_helper from "./rule-tester-helper.mjs";
24
26
  export {
25
- no_used_underscore_params,
26
- obsidian_dev_utils_plugin
27
+ no_async_callback_to_unsafe_return,
28
+ no_used_underscore_variables,
29
+ obsidian_dev_utils_plugin,
30
+ rule_tester_helper
27
31
  };
28
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9saW50ZXJzL2VzbGludC1ydWxlcy9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovXG5cbmV4cG9ydCAqIGFzIG5vX3VzZWRfdW5kZXJzY29yZV9wYXJhbXMgZnJvbSAnLi9uby11c2VkLXVuZGVyc2NvcmUtcGFyYW1zLnRzJztcbmV4cG9ydCAqIGFzIG9ic2lkaWFuX2Rldl91dGlsc19wbHVnaW4gZnJvbSAnLi9vYnNpZGlhbi1kZXYtdXRpbHMtcGx1Z2luLnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLFlBQVksK0JBQStCO0FBQzNDLFlBQVksK0JBQStCOyIsCiAgIm5hbWVzIjogW10KfQo=
32
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9saW50ZXJzL2VzbGludC1ydWxlcy9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovXG5cbmV4cG9ydCAqIGFzIG5vX2FzeW5jX2NhbGxiYWNrX3RvX3Vuc2FmZV9yZXR1cm4gZnJvbSAnLi9uby1hc3luYy1jYWxsYmFjay10by11bnNhZmUtcmV0dXJuLnRzJztcbmV4cG9ydCAqIGFzIG5vX3VzZWRfdW5kZXJzY29yZV92YXJpYWJsZXMgZnJvbSAnLi9uby11c2VkLXVuZGVyc2NvcmUtdmFyaWFibGVzLnRzJztcbmV4cG9ydCAqIGFzIG9ic2lkaWFuX2Rldl91dGlsc19wbHVnaW4gZnJvbSAnLi9vYnNpZGlhbi1kZXYtdXRpbHMtcGx1Z2luLnRzJztcbmV4cG9ydCAqIGFzIHJ1bGVfdGVzdGVyX2hlbHBlciBmcm9tICcuL3J1bGUtdGVzdGVyLWhlbHBlci50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxZQUFZLHdDQUF3QztBQUNwRCxZQUFZLGtDQUFrQztBQUM5QyxZQUFZLCtCQUErQjtBQUMzQyxZQUFZLHdCQUF3QjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,3 @@
1
+ import type { Rule } from 'eslint';
2
+ export declare const MESSAGE_ID = "noAsyncCallbackToUnsafeReturn";
3
+ export declare const noAsyncCallbackToUnsafeReturn: Rule.RuleModule;
@@ -0,0 +1,117 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function initEsm() {
7
+ if (globalThis.process) {
8
+ return;
9
+ }
10
+
11
+ const browserProcess = {
12
+ browser: true,
13
+ cwd() {
14
+ return '/';
15
+ },
16
+ env: {},
17
+ platform: 'android'
18
+ };
19
+ globalThis.process = browserProcess;
20
+ })();
21
+
22
+ import {
23
+ isIdentifier,
24
+ isTypeAliasDeclaration,
25
+ isTypeReferenceNode,
26
+ isUnionTypeNode,
27
+ SymbolFlags,
28
+ TypeFlags
29
+ } from "typescript";
30
+ import { assertNonNullable } from "../../../type-guards.mjs";
31
+ const MESSAGE_ID = "noAsyncCallbackToUnsafeReturn";
32
+ function hasUnsafeReturnCallSignature(checker, type) {
33
+ return type.getCallSignatures().some((sig) => isUnsafeReturnSignature(checker, sig));
34
+ }
35
+ function isAsyncFunctionNode(node) {
36
+ return (node.type === "ArrowFunctionExpression" || node.type === "FunctionExpression") && node.async;
37
+ }
38
+ const UNSAFE_RETURN_FLAGS = TypeFlags.Any | TypeFlags.Unknown;
39
+ const PROMISE_TYPE_NAMES = /* @__PURE__ */ new Set(["Promise", "PromiseLike"]);
40
+ function containsPromiseReference(checker, node) {
41
+ if (isUnionTypeNode(node)) {
42
+ return node.types.some((member) => containsPromiseReference(checker, member));
43
+ }
44
+ if (isTypeReferenceNode(node)) {
45
+ const name = isIdentifier(node.typeName) ? node.typeName.text : "";
46
+ if (PROMISE_TYPE_NAMES.has(name)) {
47
+ return true;
48
+ }
49
+ let symbol = checker.getSymbolAtLocation(node.typeName);
50
+ if (symbol && symbol.flags & SymbolFlags.Alias) {
51
+ symbol = checker.getAliasedSymbol(symbol);
52
+ }
53
+ const decl = symbol?.declarations?.[0];
54
+ if (decl && isTypeAliasDeclaration(decl)) {
55
+ return containsPromiseReference(checker, decl.type);
56
+ }
57
+ }
58
+ return false;
59
+ }
60
+ function isUnsafeReturnSignature(checker, sig) {
61
+ const returnType = checker.getReturnTypeOfSignature(sig);
62
+ if (!(returnType.flags & UNSAFE_RETURN_FLAGS)) {
63
+ return false;
64
+ }
65
+ const decl = sig.getDeclaration();
66
+ const returnTypeNode = decl.type;
67
+ assertNonNullable(returnTypeNode, "Signature declarations with any/unknown return always have a return type annotation");
68
+ return !containsPromiseReference(checker, returnTypeNode);
69
+ }
70
+ const noAsyncCallbackToUnsafeReturn = {
71
+ create(context) {
72
+ const services = context.sourceCode.parserServices;
73
+ const checker = services.program.getTypeChecker();
74
+ return {
75
+ CallExpression(node) {
76
+ const callNode = node;
77
+ for (let i = 0; i < callNode.arguments.length; i++) {
78
+ const arg = callNode.arguments[i];
79
+ if (!arg || !isAsyncFunctionNode(arg)) {
80
+ continue;
81
+ }
82
+ const tsCalleeNode = services.esTreeNodeToTSNodeMap.get(callNode.callee);
83
+ const calleeType = checker.getTypeAtLocation(tsCalleeNode);
84
+ for (const sig of calleeType.getCallSignatures()) {
85
+ const param = sig.getParameters()[i];
86
+ if (!param) {
87
+ continue;
88
+ }
89
+ const paramType = checker.getTypeOfSymbol(param);
90
+ if (hasUnsafeReturnCallSignature(checker, paramType)) {
91
+ context.report({
92
+ messageId: MESSAGE_ID,
93
+ node: arg
94
+ });
95
+ break;
96
+ }
97
+ }
98
+ }
99
+ }
100
+ };
101
+ },
102
+ meta: {
103
+ docs: {
104
+ description: "Disallow passing async functions as callbacks to parameters with `any` or `unknown` return type"
105
+ },
106
+ messages: {
107
+ [MESSAGE_ID]: "Async function passed as callback to a parameter with `any`/`unknown` return type. This may cause unhandled promise rejections. Wrap the call: `(...args) => { yourAsyncFn(...args); }`."
108
+ },
109
+ schema: [],
110
+ type: "problem"
111
+ }
112
+ };
113
+ export {
114
+ MESSAGE_ID,
115
+ noAsyncCallbackToUnsafeReturn
116
+ };
117
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * ESLint rule: no-async-callback-to-unsafe-return\n *\n * Reports an error when an async function is passed as a callback argument\n * to a function parameter whose return type is `any` or `unknown`. Because\n * these types silently accept `Promise<T>`, the caller won't await the\n * result, leading to unhandled promise rejections at runtime.\n *\n * Example:\n * ```typescript\n * // onClick(fn: (evt: MouseEvent) => any)\n * button.onClick(async () => {\n *   await someFn(); // Unhandled rejection if someFn throws\n * });\n * ```\n *\n * `@typescript-eslint/no-misused-promises` only catches `=> void` callbacks.\n * This rule closes the gap for `=> any` and `=> unknown` callbacks.\n */\nimport type {\n  ParserServicesWithTypeInformation,\n  TSESTree\n} from '@typescript-eslint/utils';\nimport type { Rule } from 'eslint';\nimport type {\n  Signature,\n  Type,\n  TypeChecker,\n  TypeNode\n} from 'typescript';\n\nimport {\n  isIdentifier,\n  isTypeAliasDeclaration,\n  isTypeReferenceNode,\n  isUnionTypeNode,\n  SymbolFlags,\n  TypeFlags\n} from 'typescript';\n\nimport { assertNonNullable } from '../../../type-guards.ts';\n\nexport const MESSAGE_ID = 'noAsyncCallbackToUnsafeReturn';\n\n/**\n * Checks whether the given TypeScript type is a function type with an unsafe\n * return type for async callbacks.\n *\n * @param checker - TypeScript type checker.\n * @param type - The type to inspect.\n * @returns `true` if the type has at least one call signature with an unsafe return.\n */\nfunction hasUnsafeReturnCallSignature(checker: TypeChecker, type: Type): boolean {\n  return type.getCallSignatures().some((sig) => isUnsafeReturnSignature(checker, sig));\n}\n\n/**\n * Checks whether a node is an async function expression (arrow or regular).\n *\n * @param node - AST node to check.\n * @returns `true` if the node is an async arrow or function expression.\n */\nfunction isAsyncFunctionNode(node: TSESTree.Node): node is TSESTree.ArrowFunctionExpression | TSESTree.FunctionExpression {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-enum-comparison -- AST node type string literals match the TSESTree enum values.\n  return (node.type === 'ArrowFunctionExpression' || node.type === 'FunctionExpression') && node.async;\n}\n\n// eslint-disable-next-line no-bitwise -- Bitwise flag mask is idiomatic for TypeScript compiler API.\nconst UNSAFE_RETURN_FLAGS = TypeFlags.Any | TypeFlags.Unknown;\n\nconst PROMISE_TYPE_NAMES = new Set(['Promise', 'PromiseLike']);\n\n/**\n * Checks whether a type node contains a reference to `Promise` or `PromiseLike`,\n * either directly or through a type alias. This indicates the caller explicitly\n * accounts for promise returns.\n *\n * @param checker - TypeScript type checker.\n * @param node - The type node to inspect.\n * @returns `true` if the node references `Promise` or `PromiseLike`.\n */\nfunction containsPromiseReference(checker: TypeChecker, node: TypeNode): boolean {\n  if (isUnionTypeNode(node)) {\n    return node.types.some((member) => containsPromiseReference(checker, member));\n  }\n\n  if (isTypeReferenceNode(node)) {\n    /* v8 ignore start -- Qualified names (e.g., ns.Promise) and import aliases require multi-file setup not available in RuleTester. */\n    const name = isIdentifier(node.typeName) ? node.typeName.text : '';\n    /* v8 ignore stop */\n    if (PROMISE_TYPE_NAMES.has(name)) {\n      return true;\n    }\n\n    // Resolve type alias (following imports) and check its definition body\n    let symbol = checker.getSymbolAtLocation(node.typeName);\n    /* v8 ignore start -- Import aliases require multi-file setup not available in RuleTester. */\n    // eslint-disable-next-line no-bitwise -- Bitwise flag check is idiomatic for TypeScript compiler API.\n    if (symbol && symbol.flags & SymbolFlags.Alias) {\n      symbol = checker.getAliasedSymbol(symbol);\n    }\n    /* v8 ignore stop */\n    const decl = symbol?.declarations?.[0];\n    if (decl && isTypeAliasDeclaration(decl)) {\n      return containsPromiseReference(checker, decl.type);\n    }\n  }\n\n  return false;\n}\n\n/**\n * Checks whether a call signature has an unsafe return type (`any` or `unknown`)\n * without explicitly accounting for promises.\n *\n * Flags bare `any`, `unknown`, and unions like `any | string` that resolve to\n * `any`/`unknown` without including `Promise`/`PromiseLike`. Does NOT flag type\n * aliases like `Awaitable<T>` or unions like `any | Promise<any>` that explicitly\n * handle promise returns.\n *\n * @param checker - TypeScript type checker.\n * @param sig - The call signature to inspect.\n * @returns `true` if the return type is unsafe for async callbacks.\n */\nfunction isUnsafeReturnSignature(checker: TypeChecker, sig: Signature): boolean {\n  const returnType = checker.getReturnTypeOfSignature(sig);\n\n  // eslint-disable-next-line no-bitwise -- Bitwise flag check is idiomatic for TypeScript compiler API.\n  if (!(returnType.flags & UNSAFE_RETURN_FLAGS)) {\n    return false;\n  }\n\n  // Check the syntactic return type annotation. If it contains a reference to\n  // Promise/PromiseLike (directly or via a type alias), the caller explicitly\n  // Handles async returns and should not be flagged.\n  const decl = sig.getDeclaration();\n  const returnTypeNode = decl.type;\n  assertNonNullable(returnTypeNode, 'Signature declarations with any/unknown return always have a return type annotation');\n\n  return !containsPromiseReference(checker, returnTypeNode);\n}\n\nexport const noAsyncCallbackToUnsafeReturn: Rule.RuleModule = {\n  create(context) {\n    const services = context.sourceCode.parserServices as ParserServicesWithTypeInformation;\n    const checker = services.program.getTypeChecker();\n\n    return {\n      CallExpression(node: Rule.Node): void {\n        const callNode = node as TSESTree.CallExpression;\n\n        for (let i = 0; i < callNode.arguments.length; i++) {\n          const arg = callNode.arguments[i];\n          if (!arg || !isAsyncFunctionNode(arg)) {\n            continue;\n          }\n\n          const tsCalleeNode = services.esTreeNodeToTSNodeMap.get(callNode.callee);\n          const calleeType = checker.getTypeAtLocation(tsCalleeNode);\n\n          for (const sig of calleeType.getCallSignatures()) {\n            const param = sig.getParameters()[i];\n            if (!param) {\n              continue;\n            }\n\n            const paramType = checker.getTypeOfSymbol(param);\n\n            if (hasUnsafeReturnCallSignature(checker, paramType)) {\n              context.report({\n                messageId: MESSAGE_ID,\n                node: arg as Rule.Node\n              });\n              break;\n            }\n          }\n        }\n      }\n    };\n  },\n  meta: {\n    docs: {\n      description: 'Disallow passing async functions as callbacks to parameters with `any` or `unknown` return type'\n    },\n    messages: {\n      [MESSAGE_ID]:\n        'Async function passed as callback to a parameter with `any`/`unknown` return type. This may cause unhandled promise rejections. Wrap the call: `(...args) => { yourAsyncFn(...args); }`.'\n    },\n    schema: [],\n    type: 'problem'\n  }\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAiCA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAEP,SAAS,yBAAyB;AAE3B,MAAM,aAAa;AAU1B,SAAS,6BAA6B,SAAsB,MAAqB;AAC/E,SAAO,KAAK,kBAAkB,EAAE,KAAK,CAAC,QAAQ,wBAAwB,SAAS,GAAG,CAAC;AACrF;AAQA,SAAS,oBAAoB,MAA6F;AAExH,UAAQ,KAAK,SAAS,6BAA6B,KAAK,SAAS,yBAAyB,KAAK;AACjG;AAGA,MAAM,sBAAsB,UAAU,MAAM,UAAU;AAEtD,MAAM,qBAAqB,oBAAI,IAAI,CAAC,WAAW,aAAa,CAAC;AAW7D,SAAS,yBAAyB,SAAsB,MAAyB;AAC/E,MAAI,gBAAgB,IAAI,GAAG;AACzB,WAAO,KAAK,MAAM,KAAK,CAAC,WAAW,yBAAyB,SAAS,MAAM,CAAC;AAAA,EAC9E;AAEA,MAAI,oBAAoB,IAAI,GAAG;AAE7B,UAAM,OAAO,aAAa,KAAK,QAAQ,IAAI,KAAK,SAAS,OAAO;AAEhE,QAAI,mBAAmB,IAAI,IAAI,GAAG;AAChC,aAAO;AAAA,IACT;AAGA,QAAI,SAAS,QAAQ,oBAAoB,KAAK,QAAQ;AAGtD,QAAI,UAAU,OAAO,QAAQ,YAAY,OAAO;AAC9C,eAAS,QAAQ,iBAAiB,MAAM;AAAA,IAC1C;AAEA,UAAM,OAAO,QAAQ,eAAe,CAAC;AACrC,QAAI,QAAQ,uBAAuB,IAAI,GAAG;AACxC,aAAO,yBAAyB,SAAS,KAAK,IAAI;AAAA,IACpD;AAAA,EACF;AAEA,SAAO;AACT;AAeA,SAAS,wBAAwB,SAAsB,KAAyB;AAC9E,QAAM,aAAa,QAAQ,yBAAyB,GAAG;AAGvD,MAAI,EAAE,WAAW,QAAQ,sBAAsB;AAC7C,WAAO;AAAA,EACT;AAKA,QAAM,OAAO,IAAI,eAAe;AAChC,QAAM,iBAAiB,KAAK;AAC5B,oBAAkB,gBAAgB,qFAAqF;AAEvH,SAAO,CAAC,yBAAyB,SAAS,cAAc;AAC1D;AAEO,MAAM,gCAAiD;AAAA,EAC5D,OAAO,SAAS;AACd,UAAM,WAAW,QAAQ,WAAW;AACpC,UAAM,UAAU,SAAS,QAAQ,eAAe;AAEhD,WAAO;AAAA,MACL,eAAe,MAAuB;AACpC,cAAM,WAAW;AAEjB,iBAAS,IAAI,GAAG,IAAI,SAAS,UAAU,QAAQ,KAAK;AAClD,gBAAM,MAAM,SAAS,UAAU,CAAC;AAChC,cAAI,CAAC,OAAO,CAAC,oBAAoB,GAAG,GAAG;AACrC;AAAA,UACF;AAEA,gBAAM,eAAe,SAAS,sBAAsB,IAAI,SAAS,MAAM;AACvE,gBAAM,aAAa,QAAQ,kBAAkB,YAAY;AAEzD,qBAAW,OAAO,WAAW,kBAAkB,GAAG;AAChD,kBAAM,QAAQ,IAAI,cAAc,EAAE,CAAC;AACnC,gBAAI,CAAC,OAAO;AACV;AAAA,YACF;AAEA,kBAAM,YAAY,QAAQ,gBAAgB,KAAK;AAE/C,gBAAI,6BAA6B,SAAS,SAAS,GAAG;AACpD,sBAAQ,OAAO;AAAA,gBACb,WAAW;AAAA,gBACX,MAAM;AAAA,cACR,CAAC;AACD;AAAA,YACF;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EACA,MAAM;AAAA,IACJ,MAAM;AAAA,MACJ,aAAa;AAAA,IACf;AAAA,IACA,UAAU;AAAA,MACR,CAAC,UAAU,GACT;AAAA,IACJ;AAAA,IACA,QAAQ,CAAC;AAAA,IACT,MAAM;AAAA,EACR;AACF;",
  "names": []
}

@@ -0,0 +1,13 @@
1
+ /**
2
+ * @packageDocumentation
3
+ *
4
+ * ESLint rule: no-used-underscore-variables
5
+ *
6
+ * Reports an error when a parameter or local variable with a `_` prefix is
7
+ * actually referenced in the function body. The `_` prefix convention signals
8
+ * "this identifier is intentionally unused" — if it IS used, the prefix is
9
+ * misleading and should be removed.
10
+ */
11
+ import type { Rule } from 'eslint';
12
+ export declare const MESSAGE_ID = "noUsedUnderscoreVariables";
13
+ export declare const noUsedUnderscoreVariables: Rule.RuleModule;
@@ -0,0 +1,73 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function initEsm() {
7
+ if (globalThis.process) {
8
+ return;
9
+ }
10
+
11
+ const browserProcess = {
12
+ browser: true,
13
+ cwd() {
14
+ return '/';
15
+ },
16
+ env: {},
17
+ platform: 'android'
18
+ };
19
+ globalThis.process = browserProcess;
20
+ })();
21
+
22
+ import { assertNonNullable } from "../../../type-guards.mjs";
23
+ const MESSAGE_ID = "noUsedUnderscoreVariables";
24
+ const noUsedUnderscoreVariables = {
25
+ create(context) {
26
+ return {
27
+ ":function"(node) {
28
+ const scope = context.sourceCode.getScope(node);
29
+ for (const variable of scope.variables) {
30
+ if (!variable.name.startsWith("_")) {
31
+ continue;
32
+ }
33
+ const defNode = variable.defs[0];
34
+ assertNonNullable(defNode, "User-declared _-prefixed variables always have at least one definition");
35
+ const funcBody = node.body;
36
+ const bodyRange = funcBody?.range;
37
+ const isParam = defNode.type === "Parameter";
38
+ const hasBodyReferences = variable.references.some((ref) => {
39
+ if (!ref.isRead()) {
40
+ return false;
41
+ }
42
+ if (isParam && bodyRange && ref.identifier.range) {
43
+ return ref.identifier.range[0] >= bodyRange[0] && ref.identifier.range[1] <= bodyRange[1];
44
+ }
45
+ return true;
46
+ });
47
+ if (hasBodyReferences) {
48
+ context.report({
49
+ data: { name: variable.name },
50
+ messageId: MESSAGE_ID,
51
+ node: defNode.name
52
+ });
53
+ }
54
+ }
55
+ }
56
+ };
57
+ },
58
+ meta: {
59
+ docs: {
60
+ description: "Disallow `_`-prefixed parameters and local variables that are actually used"
61
+ },
62
+ messages: {
63
+ [MESSAGE_ID]: '"{{ name }}" has a `_` prefix but is used. Remove the `_` prefix since it is not unused (G10e).'
64
+ },
65
+ schema: [],
66
+ type: "problem"
67
+ }
68
+ };
69
+ export {
70
+ MESSAGE_ID,
71
+ noUsedUnderscoreVariables
72
+ };
73
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9saW50ZXJzL2VzbGludC1ydWxlcy9uby11c2VkLXVuZGVyc2NvcmUtdmFyaWFibGVzLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIEVTTGludCBydWxlOiBuby11c2VkLXVuZGVyc2NvcmUtdmFyaWFibGVzXG4gKlxuICogUmVwb3J0cyBhbiBlcnJvciB3aGVuIGEgcGFyYW1ldGVyIG9yIGxvY2FsIHZhcmlhYmxlIHdpdGggYSBgX2AgcHJlZml4IGlzXG4gKiBhY3R1YWxseSByZWZlcmVuY2VkIGluIHRoZSBmdW5jdGlvbiBib2R5LiBUaGUgYF9gIHByZWZpeCBjb252ZW50aW9uIHNpZ25hbHNcbiAqIFwidGhpcyBpZGVudGlmaWVyIGlzIGludGVudGlvbmFsbHkgdW51c2VkXCIgXHUyMDE0IGlmIGl0IElTIHVzZWQsIHRoZSBwcmVmaXggaXNcbiAqIG1pc2xlYWRpbmcgYW5kIHNob3VsZCBiZSByZW1vdmVkLlxuICovXG5pbXBvcnQgdHlwZSB7IFJ1bGUgfSBmcm9tICdlc2xpbnQnO1xuXG5pbXBvcnQgeyBhc3NlcnROb25OdWxsYWJsZSB9IGZyb20gJy4uLy4uLy4uL3R5cGUtZ3VhcmRzLnRzJztcblxuZXhwb3J0IGNvbnN0IE1FU1NBR0VfSUQgPSAnbm9Vc2VkVW5kZXJzY29yZVZhcmlhYmxlcyc7XG5cbmV4cG9ydCBjb25zdCBub1VzZWRVbmRlcnNjb3JlVmFyaWFibGVzOiBSdWxlLlJ1bGVNb2R1bGUgPSB7XG4gIGNyZWF0ZShjb250ZXh0KSB7XG4gICAgcmV0dXJuIHtcbiAgICAgICc6ZnVuY3Rpb24nKG5vZGU6IFJ1bGUuTm9kZSk6IHZvaWQge1xuICAgICAgICBjb25zdCBzY29wZSA9IGNvbnRleHQuc291cmNlQ29kZS5nZXRTY29wZShub2RlKTtcblxuICAgICAgICBmb3IgKGNvbnN0IHZhcmlhYmxlIG9mIHNjb3BlLnZhcmlhYmxlcykge1xuICAgICAgICAgIGlmICghdmFyaWFibGUubmFtZS5zdGFydHNXaXRoKCdfJykpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IGRlZk5vZGUgPSB2YXJpYWJsZS5kZWZzWzBdO1xuICAgICAgICAgIGFzc2VydE5vbk51bGxhYmxlKGRlZk5vZGUsICdVc2VyLWRlY2xhcmVkIF8tcHJlZml4ZWQgdmFyaWFibGVzIGFsd2F5cyBoYXZlIGF0IGxlYXN0IG9uZSBkZWZpbml0aW9uJyk7XG5cbiAgICAgICAgICAvLyBGb3IgcGFyYW1ldGVycywgb25seSBjb3VudCByZWZlcmVuY2VzIGluc2lkZSB0aGUgZnVuY3Rpb24gYm9keVxuICAgICAgICAgIC8vIChub3QgaW4gdHlwZSBhbm5vdGF0aW9ucyBsaWtlIGBhc3NlcnRzIF9vYmogaXMgVGApLlxuICAgICAgICAgIC8vIEZvciBsb2NhbCB2YXJpYWJsZXMsIGFueSByZWFkIHJlZmVyZW5jZSBjb3VudHMuXG4gICAgICAgICAgY29uc3QgZnVuY0JvZHkgPSAobm9kZSBhcyB7IGJvZHk/OiBSdWxlLk5vZGUgfSkuYm9keTtcbiAgICAgICAgICBjb25zdCBib2R5UmFuZ2UgPSBmdW5jQm9keT8ucmFuZ2U7XG4gICAgICAgICAgY29uc3QgaXNQYXJhbSA9IGRlZk5vZGUudHlwZSA9PT0gJ1BhcmFtZXRlcic7XG4gICAgICAgICAgY29uc3QgaGFzQm9keVJlZmVyZW5jZXMgPSB2YXJpYWJsZS5yZWZlcmVuY2VzLnNvbWUoKHJlZikgPT4ge1xuICAgICAgICAgICAgaWYgKCFyZWYuaXNSZWFkKCkpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaWYgKGlzUGFyYW0gJiYgYm9keVJhbmdlICYmIHJlZi5pZGVudGlmaWVyLnJhbmdlKSB7XG4gICAgICAgICAgICAgIHJldHVybiByZWYuaWRlbnRpZmllci5yYW5nZVswXSA+PSBib2R5UmFuZ2VbMF1cbiAgICAgICAgICAgICAgICAmJiByZWYuaWRlbnRpZmllci5yYW5nZVsxXSA8PSBib2R5UmFuZ2VbMV07XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICAvLyBMb2NhbCB2YXJpYWJsZXMgb3IgZmFsbGJhY2s6IGNvdW50IGFsbCByZWFkc1xuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgICAgfSk7XG4gICAgICAgICAgaWYgKGhhc0JvZHlSZWZlcmVuY2VzKSB7XG4gICAgICAgICAgICBjb250ZXh0LnJlcG9ydCh7XG4gICAgICAgICAgICAgIGRhdGE6IHsgbmFtZTogdmFyaWFibGUubmFtZSB9LFxuICAgICAgICAgICAgICBtZXNzYWdlSWQ6IE1FU1NBR0VfSUQsXG4gICAgICAgICAgICAgIG5vZGU6IGRlZk5vZGUubmFtZVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfSxcbiAgbWV0YToge1xuICAgIGRvY3M6IHtcbiAgICAgIGRlc2NyaXB0aW9uOiAnRGlzYWxsb3cgYF9gLXByZWZpeGVkIHBhcmFtZXRlcnMgYW5kIGxvY2FsIHZhcmlhYmxlcyB0aGF0IGFyZSBhY3R1YWxseSB1c2VkJ1xuICAgIH0sXG4gICAgbWVzc2FnZXM6IHtcbiAgICAgIFtNRVNTQUdFX0lEXTogJ1wie3sgbmFtZSB9fVwiIGhhcyBhIGBfYCBwcmVmaXggYnV0IGlzIHVzZWQuIFJlbW92ZSB0aGUgYF9gIHByZWZpeCBzaW5jZSBpdCBpcyBub3QgdW51c2VkIChHMTBlKS4nXG4gICAgfSxcbiAgICBzY2hlbWE6IFtdLFxuICAgIHR5cGU6ICdwcm9ibGVtJ1xuICB9XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBWUEsU0FBUyx5QkFBeUI7QUFFM0IsTUFBTSxhQUFhO0FBRW5CLE1BQU0sNEJBQTZDO0FBQUEsRUFDeEQsT0FBTyxTQUFTO0FBQ2QsV0FBTztBQUFBLE1BQ0wsWUFBWSxNQUF1QjtBQUNqQyxjQUFNLFFBQVEsUUFBUSxXQUFXLFNBQVMsSUFBSTtBQUU5QyxtQkFBVyxZQUFZLE1BQU0sV0FBVztBQUN0QyxjQUFJLENBQUMsU0FBUyxLQUFLLFdBQVcsR0FBRyxHQUFHO0FBQ2xDO0FBQUEsVUFDRjtBQUVBLGdCQUFNLFVBQVUsU0FBUyxLQUFLLENBQUM7QUFDL0IsNEJBQWtCLFNBQVMsd0VBQXdFO0FBS25HLGdCQUFNLFdBQVksS0FBOEI7QUFDaEQsZ0JBQU0sWUFBWSxVQUFVO0FBQzVCLGdCQUFNLFVBQVUsUUFBUSxTQUFTO0FBQ2pDLGdCQUFNLG9CQUFvQixTQUFTLFdBQVcsS0FBSyxDQUFDLFFBQVE7QUFDMUQsZ0JBQUksQ0FBQyxJQUFJLE9BQU8sR0FBRztBQUNqQixxQkFBTztBQUFBLFlBQ1Q7QUFDQSxnQkFBSSxXQUFXLGFBQWEsSUFBSSxXQUFXLE9BQU87QUFDaEQscUJBQU8sSUFBSSxXQUFXLE1BQU0sQ0FBQyxLQUFLLFVBQVUsQ0FBQyxLQUN4QyxJQUFJLFdBQVcsTUFBTSxDQUFDLEtBQUssVUFBVSxDQUFDO0FBQUEsWUFDN0M7QUFFQSxtQkFBTztBQUFBLFVBQ1QsQ0FBQztBQUNELGNBQUksbUJBQW1CO0FBQ3JCLG9CQUFRLE9BQU87QUFBQSxjQUNiLE1BQU0sRUFBRSxNQUFNLFNBQVMsS0FBSztBQUFBLGNBQzVCLFdBQVc7QUFBQSxjQUNYLE1BQU0sUUFBUTtBQUFBLFlBQ2hCLENBQUM7QUFBQSxVQUNIO0FBQUEsUUFDRjtBQUFBLE1BQ0Y7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUFBLEVBQ0EsTUFBTTtBQUFBLElBQ0osTUFBTTtBQUFBLE1BQ0osYUFBYTtBQUFBLElBQ2Y7QUFBQSxJQUNBLFVBQVU7QUFBQSxNQUNSLENBQUMsVUFBVSxHQUFHO0FBQUEsSUFDaEI7QUFBQSxJQUNBLFFBQVEsQ0FBQztBQUFBLElBQ1QsTUFBTTtBQUFBLEVBQ1I7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -19,13 +19,15 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
- import { noUsedUnderscoreParams } from "./no-used-underscore-params.mjs";
22
+ import { noAsyncCallbackToUnsafeReturn } from "./no-async-callback-to-unsafe-return.mjs";
23
+ import { noUsedUnderscoreVariables } from "./no-used-underscore-variables.mjs";
23
24
  const obsidianDevUtilsPlugin = {
24
25
  rules: {
25
- "no-used-underscore-params": noUsedUnderscoreParams
26
+ "no-async-callback-to-unsafe-return": noAsyncCallbackToUnsafeReturn,
27
+ "no-used-underscore-variables": noUsedUnderscoreVariables
26
28
  }
27
29
  };
28
30
  export {
29
31
  obsidianDevUtilsPlugin
30
32
  };
31
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9saW50ZXJzL2VzbGludC1ydWxlcy9vYnNpZGlhbi1kZXYtdXRpbHMtcGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIEVTTGludCBwbHVnaW4gZm9yIE9ic2lkaWFuIGRldmVsb3BtZW50IHV0aWxpdGllcy5cbiAqL1xuaW1wb3J0IHR5cGUgeyBFU0xpbnQgfSBmcm9tICdlc2xpbnQnO1xuXG5pbXBvcnQgeyBub1VzZWRVbmRlcnNjb3JlUGFyYW1zIH0gZnJvbSAnLi9uby11c2VkLXVuZGVyc2NvcmUtcGFyYW1zLnRzJztcblxuZXhwb3J0IGNvbnN0IG9ic2lkaWFuRGV2VXRpbHNQbHVnaW46IEVTTGludC5QbHVnaW4gPSB7XG4gIHJ1bGVzOiB7XG4gICAgJ25vLXVzZWQtdW5kZXJzY29yZS1wYXJhbXMnOiBub1VzZWRVbmRlcnNjb3JlUGFyYW1zXG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFPQSxTQUFTLDhCQUE4QjtBQUVoQyxNQUFNLHlCQUF3QztBQUFBLEVBQ25ELE9BQU87QUFBQSxJQUNMLDZCQUE2QjtBQUFBLEVBQy9CO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
33
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9saW50ZXJzL2VzbGludC1ydWxlcy9vYnNpZGlhbi1kZXYtdXRpbHMtcGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIEVTTGludCBwbHVnaW4gZm9yIE9ic2lkaWFuIGRldmVsb3BtZW50IHV0aWxpdGllcy5cbiAqL1xuaW1wb3J0IHR5cGUgeyBFU0xpbnQgfSBmcm9tICdlc2xpbnQnO1xuXG5pbXBvcnQgeyBub0FzeW5jQ2FsbGJhY2tUb1Vuc2FmZVJldHVybiB9IGZyb20gJy4vbm8tYXN5bmMtY2FsbGJhY2stdG8tdW5zYWZlLXJldHVybi50cyc7XG5pbXBvcnQgeyBub1VzZWRVbmRlcnNjb3JlVmFyaWFibGVzIH0gZnJvbSAnLi9uby11c2VkLXVuZGVyc2NvcmUtdmFyaWFibGVzLnRzJztcblxuZXhwb3J0IGNvbnN0IG9ic2lkaWFuRGV2VXRpbHNQbHVnaW46IEVTTGludC5QbHVnaW4gPSB7XG4gIHJ1bGVzOiB7XG4gICAgJ25vLWFzeW5jLWNhbGxiYWNrLXRvLXVuc2FmZS1yZXR1cm4nOiBub0FzeW5jQ2FsbGJhY2tUb1Vuc2FmZVJldHVybixcbiAgICAnbm8tdXNlZC11bmRlcnNjb3JlLXZhcmlhYmxlcyc6IG5vVXNlZFVuZGVyc2NvcmVWYXJpYWJsZXNcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQU9BLFNBQVMscUNBQXFDO0FBQzlDLFNBQVMsaUNBQWlDO0FBRW5DLE1BQU0seUJBQXdDO0FBQUEsRUFDbkQsT0FBTztBQUFBLElBQ0wsc0NBQXNDO0FBQUEsSUFDdEMsZ0NBQWdDO0FBQUEsRUFDbEM7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,17 @@
1
+ /**
2
+ * @packageDocumentation
3
+ *
4
+ * Helper for bridging ESLint v10 rule types with `@typescript-eslint/rule-tester`.
5
+ */
6
+ import type { RuleTester } from '@typescript-eslint/rule-tester';
7
+ import type { Rule } from 'eslint';
8
+ /**
9
+ * Casts an ESLint v10 `Rule.RuleModule` to the type expected by
10
+ * `@typescript-eslint/rule-tester`. The types are incompatible at the type
11
+ * level because typescript-eslint hasn't updated for ESLint v10 yet, but
12
+ * they are compatible at runtime.
13
+ *
14
+ * @param rule - The ESLint rule module.
15
+ * @returns The same rule, typed for the rule tester.
16
+ */
17
+ export declare function toRuleTesterModule(rule: Rule.RuleModule): Parameters<RuleTester['run']>[1];
@@ -0,0 +1,29 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function initEsm() {
7
+ if (globalThis.process) {
8
+ return;
9
+ }
10
+
11
+ const browserProcess = {
12
+ browser: true,
13
+ cwd() {
14
+ return '/';
15
+ },
16
+ env: {},
17
+ platform: 'android'
18
+ };
19
+ globalThis.process = browserProcess;
20
+ })();
21
+
22
+ function toRuleTesterModule(rule) {
23
+ const bridged = rule;
24
+ return bridged;
25
+ }
26
+ export {
27
+ toRuleTesterModule
28
+ };
29
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9saW50ZXJzL2VzbGludC1ydWxlcy9ydWxlLXRlc3Rlci1oZWxwZXIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uXG4gKlxuICogSGVscGVyIGZvciBicmlkZ2luZyBFU0xpbnQgdjEwIHJ1bGUgdHlwZXMgd2l0aCBgQHR5cGVzY3JpcHQtZXNsaW50L3J1bGUtdGVzdGVyYC5cbiAqL1xuaW1wb3J0IHR5cGUgeyBSdWxlVGVzdGVyIH0gZnJvbSAnQHR5cGVzY3JpcHQtZXNsaW50L3J1bGUtdGVzdGVyJztcbmltcG9ydCB0eXBlIHsgUnVsZSB9IGZyb20gJ2VzbGludCc7XG5cbi8qKlxuICogQ2FzdHMgYW4gRVNMaW50IHYxMCBgUnVsZS5SdWxlTW9kdWxlYCB0byB0aGUgdHlwZSBleHBlY3RlZCBieVxuICogYEB0eXBlc2NyaXB0LWVzbGludC9ydWxlLXRlc3RlcmAuIFRoZSB0eXBlcyBhcmUgaW5jb21wYXRpYmxlIGF0IHRoZSB0eXBlXG4gKiBsZXZlbCBiZWNhdXNlIHR5cGVzY3JpcHQtZXNsaW50IGhhc24ndCB1cGRhdGVkIGZvciBFU0xpbnQgdjEwIHlldCwgYnV0XG4gKiB0aGV5IGFyZSBjb21wYXRpYmxlIGF0IHJ1bnRpbWUuXG4gKlxuICogQHBhcmFtIHJ1bGUgLSBUaGUgRVNMaW50IHJ1bGUgbW9kdWxlLlxuICogQHJldHVybnMgVGhlIHNhbWUgcnVsZSwgdHlwZWQgZm9yIHRoZSBydWxlIHRlc3Rlci5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvUnVsZVRlc3Rlck1vZHVsZShydWxlOiBSdWxlLlJ1bGVNb2R1bGUpOiBQYXJhbWV0ZXJzPFJ1bGVUZXN0ZXJbJ3J1biddPlsxXSB7XG4gIC8vIEJyaWRnZSBFU0xpbnQgdjEwIFJ1bGUuUnVsZU1vZHVsZSB0byBAdHlwZXNjcmlwdC1lc2xpbnQvcnVsZS10ZXN0ZXIncyBSdWxlTW9kdWxlLlxuICAvLyBTdHJ1Y3R1cmFsbHkgY29tcGF0aWJsZSBidXQgbm9taW5hbGx5IGluY29tcGF0aWJsZSB1bnRpbCB0eXBlc2NyaXB0LWVzbGludCB1cGRhdGVzLlxuICBjb25zdCBicmlkZ2VkOiB1bmtub3duID0gcnVsZTtcblxuICByZXR1cm4gYnJpZGdlZCBhcyBQYXJhbWV0ZXJzPFJ1bGVUZXN0ZXJbJ3J1biddPlsxXTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQWlCTyxTQUFTLG1CQUFtQixNQUF5RDtBQUcxRixRQUFNLFVBQW1CO0FBRXpCLFNBQU87QUFDVDsiLAogICJuYW1lcyI6IFtdCn0K
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "obsidian-dev-utils",
3
- "version": "52.2.0",
3
+ "version": "52.3.0",
4
4
  "description": "This is the collection of useful functions that you can use for your Obsidian plugin development",
5
5
  "keywords": [
6
6
  "obsidian"
@@ -639,8 +639,10 @@
639
639
  },
640
640
  "overrides": {
641
641
  "@antfu/utils": "9.2.0",
642
+ "@eslint/js": "latest",
642
643
  "dompurify": "3.0.1",
643
- "esbuild": "$esbuild",
644
+ "esbuild": "latest",
645
+ "eslint": "latest",
644
646
  "eslint-plugin-import": "npm:eslint-plugin-import-x@latest"
645
647
  },
646
648
  "dependencies": {
@@ -720,6 +722,7 @@
720
722
  "@commitlint/config-conventional": "latest",
721
723
  "@commitlint/types": "latest",
722
724
  "@types/markdown-it": "latest",
725
+ "@typescript-eslint/rule-tester": "latest",
723
726
  "@vitest/coverage-v8": "latest",
724
727
  "@vitest/runner": "4.1.0",
725
728
  "commitizen": "latest",
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.cjs",
3
+ "module": "../../../../dist/lib/esm/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/no-async-callback-to-unsafe-return.d.cts"
6
+ }
@@ -0,0 +1,6 @@
1
+ {
2
+ "main": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-variables.cjs",
3
+ "module": "../../../../dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-variables.mjs",
4
+ "type": "module",
5
+ "types": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-variables.d.cts"
6
+ }
@@ -1,6 +1,6 @@
1
1
  {
2
- "main": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.cjs",
3
- "module": "../../../../dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.mjs",
2
+ "main": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/rule-tester-helper.cjs",
3
+ "module": "../../../../dist/lib/esm/script-utils/linters/eslint-rules/rule-tester-helper.mjs",
4
4
  "type": "module",
5
- "types": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.d.cts"
5
+ "types": "../../../../dist/lib/cjs/script-utils/linters/eslint-rules/rule-tester-helper.d.cts"
6
6
  }