obsidian-dev-utils 51.0.1 → 51.1.6

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 (215) hide show
  1. package/CHANGELOG.md +30 -0
  2. package/dist/lib/cjs/async.cjs +2 -2
  3. package/dist/lib/cjs/blob.cjs +2 -2
  4. package/dist/lib/cjs/debug.cjs +7 -8
  5. package/dist/lib/cjs/library.cjs +1 -1
  6. package/dist/lib/cjs/object-utils.cjs +23 -23
  7. package/dist/lib/cjs/obsidian/app.cjs +4 -3
  8. package/dist/lib/cjs/obsidian/components/setting-components/multiple-file-component.cjs +3 -2
  9. package/dist/lib/cjs/obsidian/components/setting-components/typed-text-component.cjs +1 -1
  10. package/dist/lib/cjs/obsidian/components/setting-components/validator-component.cjs +2 -2
  11. package/dist/lib/cjs/obsidian/constructors/getDomEventsHandlersConstructor.cjs +1 -1
  12. package/dist/lib/cjs/obsidian/constructors/getDomEventsHandlersConstructor.d.cts +3 -1
  13. package/dist/lib/cjs/obsidian/dataview-link.cjs +1 -1
  14. package/dist/lib/cjs/obsidian/dataview-link.d.cts +1 -1
  15. package/dist/lib/cjs/obsidian/file-change.cjs +1 -1
  16. package/dist/lib/cjs/obsidian/file-system.cjs +2 -2
  17. package/dist/lib/cjs/obsidian/i18n/custom-type-options-base.cjs +1 -1
  18. package/dist/lib/cjs/obsidian/i18n/custom-type-options-base.d.cts +12 -6
  19. package/dist/lib/cjs/obsidian/index.cjs +4 -1
  20. package/dist/lib/cjs/obsidian/index.d.cts +1 -0
  21. package/dist/lib/cjs/obsidian/is-in-obsidian.cjs +143 -0
  22. package/dist/lib/cjs/obsidian/is-in-obsidian.d.cts +11 -0
  23. package/dist/lib/cjs/obsidian/link.cjs +37 -37
  24. package/dist/lib/cjs/obsidian/markdown.cjs +1 -1
  25. package/dist/lib/cjs/obsidian/plugin/obsidian-plugin-repo-paths.cjs +2 -2
  26. package/dist/lib/cjs/obsidian/plugin/obsidian-plugin-repo-paths.d.cts +1 -1
  27. package/dist/lib/cjs/obsidian/plugin/path-settings.cjs +4 -5
  28. package/dist/lib/cjs/obsidian/plugin/plugin-settings-manager-base.cjs +2 -2
  29. package/dist/lib/cjs/obsidian/rename-delete-handler.cjs +2 -2
  30. package/dist/lib/cjs/obsidian/resource-url.cjs +3 -2
  31. package/dist/lib/cjs/obsidian/vault.cjs +2 -2
  32. package/dist/lib/cjs/reg-exp.cjs +5 -6
  33. package/dist/lib/cjs/script-utils/build.cjs +5 -5
  34. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/changeExtensionPlugin.cjs +3 -3
  35. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.cjs +12 -11
  36. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/dependency.cjs +4 -4
  37. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/fixSourceMapsPlugin.cjs +6 -5
  38. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.cjs +15 -12
  39. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/preprocessPlugin.cjs +3 -3
  40. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/renameCssPlugin.cjs +5 -4
  41. package/dist/lib/cjs/script-utils/bundlers/esbuild.cjs +1 -1
  42. package/dist/lib/cjs/script-utils/cli-utils.cjs +14 -4
  43. package/dist/lib/cjs/script-utils/code-generator.cjs +3 -3
  44. package/dist/lib/cjs/script-utils/commitlint-config.cjs +134 -0
  45. package/dist/lib/cjs/script-utils/commitlint-config.d.cts +10 -0
  46. package/dist/lib/cjs/script-utils/exec.cjs +99 -10
  47. package/dist/lib/cjs/script-utils/exec.d.cts +35 -6
  48. package/dist/lib/cjs/script-utils/formatters/dprint.cjs +8 -6
  49. package/dist/lib/cjs/script-utils/formatters/dprint.d.cts +15 -2
  50. package/dist/lib/cjs/script-utils/fs.cjs +8 -11
  51. package/dist/lib/cjs/script-utils/fs.d.cts +1 -1
  52. package/dist/lib/cjs/script-utils/index.cjs +7 -4
  53. package/dist/lib/cjs/script-utils/index.d.cts +2 -1
  54. package/dist/lib/cjs/script-utils/json.cjs +9 -8
  55. package/dist/lib/cjs/script-utils/linters/cspell.cjs +5 -3
  56. package/dist/lib/cjs/script-utils/linters/cspell.d.cts +14 -1
  57. package/dist/lib/cjs/script-utils/linters/eslint-config.cjs +32 -20
  58. package/dist/lib/cjs/script-utils/linters/eslint-rules/index.cjs +142 -0
  59. package/dist/lib/cjs/script-utils/linters/eslint-rules/index.d.cts +1 -0
  60. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.cjs +174 -0
  61. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.d.cts +12 -0
  62. package/dist/lib/cjs/script-utils/linters/eslint-types/@types/@eslint-community__eslint-plugin-eslint-comments__configs.d.cts +4 -2
  63. package/dist/lib/cjs/script-utils/linters/eslint.cjs +9 -6
  64. package/dist/lib/cjs/script-utils/linters/eslint.d.cts +15 -2
  65. package/dist/lib/cjs/script-utils/linters/index.cjs +4 -1
  66. package/dist/lib/cjs/script-utils/linters/index.d.cts +1 -0
  67. package/dist/lib/cjs/script-utils/linters/markdownlint.cjs +13 -10
  68. package/dist/lib/cjs/script-utils/linters/markdownlint.d.cts +15 -2
  69. package/dist/lib/cjs/script-utils/nano-staged-config.cjs +143 -0
  70. package/dist/lib/cjs/script-utils/nano-staged-config.d.cts +14 -0
  71. package/dist/lib/cjs/script-utils/npm-publish.cjs +16 -5
  72. package/dist/lib/cjs/script-utils/obsidian-dev-utils-repo-paths.cjs +2 -1
  73. package/dist/lib/cjs/script-utils/obsidian-dev-utils-repo-paths.d.cts +2 -0
  74. package/dist/lib/cjs/script-utils/root.cjs +3 -3
  75. package/dist/lib/cjs/script-utils/root.d.cts +3 -7
  76. package/dist/lib/cjs/script-utils/test-runners/vitest.cjs +6 -3
  77. package/dist/lib/cjs/script-utils/test-runners/vitest.d.cts +12 -1
  78. package/dist/lib/cjs/script-utils/version.cjs +22 -31
  79. package/dist/lib/cjs/string.cjs +4 -13
  80. package/dist/lib/cjs/string.d.cts +2 -2
  81. package/dist/lib/cjs/type-guards.cjs +8 -1
  82. package/dist/lib/cjs/type-guards.d.cts +11 -1
  83. package/dist/lib/esm/async.mjs +6 -3
  84. package/dist/lib/esm/blob.mjs +2 -2
  85. package/dist/lib/esm/debug.mjs +5 -6
  86. package/dist/lib/esm/library.mjs +1 -1
  87. package/dist/lib/esm/object-utils.mjs +24 -23
  88. package/dist/lib/esm/obsidian/app.mjs +4 -3
  89. package/dist/lib/esm/obsidian/components/setting-components/multiple-file-component.mjs +3 -2
  90. package/dist/lib/esm/obsidian/components/setting-components/typed-text-component.mjs +1 -1
  91. package/dist/lib/esm/obsidian/components/setting-components/validator-component.mjs +2 -2
  92. package/dist/lib/esm/obsidian/constructors/getDomEventsHandlersConstructor.d.mts +3 -1
  93. package/dist/lib/esm/obsidian/constructors/getDomEventsHandlersConstructor.mjs +1 -1
  94. package/dist/lib/esm/obsidian/dataview-link.d.mts +1 -1
  95. package/dist/lib/esm/obsidian/dataview-link.mjs +1 -1
  96. package/dist/lib/esm/obsidian/file-change.mjs +1 -1
  97. package/dist/lib/esm/obsidian/file-system.mjs +3 -2
  98. package/dist/lib/esm/obsidian/i18n/custom-type-options-base.d.mts +12 -6
  99. package/dist/lib/esm/obsidian/i18n/custom-type-options-base.mjs +1 -1
  100. package/dist/lib/esm/obsidian/index.d.mts +1 -0
  101. package/dist/lib/esm/obsidian/index.mjs +3 -1
  102. package/dist/lib/esm/obsidian/is-in-obsidian.d.mts +11 -0
  103. package/dist/lib/esm/obsidian/is-in-obsidian.mjs +39 -0
  104. package/dist/lib/esm/obsidian/link.mjs +38 -41
  105. package/dist/lib/esm/obsidian/markdown.mjs +1 -1
  106. package/dist/lib/esm/obsidian/plugin/obsidian-plugin-repo-paths.d.mts +1 -1
  107. package/dist/lib/esm/obsidian/plugin/obsidian-plugin-repo-paths.mjs +2 -2
  108. package/dist/lib/esm/obsidian/plugin/path-settings.mjs +4 -5
  109. package/dist/lib/esm/obsidian/plugin/plugin-settings-manager-base.mjs +3 -2
  110. package/dist/lib/esm/obsidian/rename-delete-handler.mjs +6 -3
  111. package/dist/lib/esm/obsidian/resource-url.mjs +3 -2
  112. package/dist/lib/esm/obsidian/vault.mjs +3 -2
  113. package/dist/lib/esm/reg-exp.mjs +5 -6
  114. package/dist/lib/esm/script-utils/build.mjs +6 -6
  115. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/changeExtensionPlugin.mjs +2 -2
  116. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.mjs +8 -8
  117. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/dependency.mjs +5 -5
  118. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/fixSourceMapsPlugin.mjs +5 -5
  119. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.mjs +10 -11
  120. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/preprocessPlugin.mjs +2 -2
  121. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/renameCssPlugin.mjs +3 -5
  122. package/dist/lib/esm/script-utils/bundlers/esbuild.mjs +1 -1
  123. package/dist/lib/esm/script-utils/cli-utils.mjs +2 -2
  124. package/dist/lib/esm/script-utils/code-generator.mjs +2 -2
  125. package/dist/lib/esm/script-utils/commitlint-config.d.mts +10 -0
  126. package/dist/lib/esm/script-utils/commitlint-config.mjs +28 -0
  127. package/dist/lib/esm/script-utils/exec.d.mts +35 -6
  128. package/dist/lib/esm/script-utils/exec.mjs +84 -8
  129. package/dist/lib/esm/script-utils/formatters/dprint.d.mts +15 -2
  130. package/dist/lib/esm/script-utils/formatters/dprint.mjs +6 -4
  131. package/dist/lib/esm/script-utils/fs.d.mts +1 -1
  132. package/dist/lib/esm/script-utils/fs.mjs +5 -8
  133. package/dist/lib/esm/script-utils/index.d.mts +2 -1
  134. package/dist/lib/esm/script-utils/index.mjs +5 -3
  135. package/dist/lib/esm/script-utils/json.mjs +7 -5
  136. package/dist/lib/esm/script-utils/linters/cspell.d.mts +14 -1
  137. package/dist/lib/esm/script-utils/linters/cspell.mjs +5 -3
  138. package/dist/lib/esm/script-utils/linters/eslint-config.mjs +32 -20
  139. package/dist/lib/esm/script-utils/linters/eslint-rules/index.d.mts +1 -0
  140. package/dist/lib/esm/script-utils/linters/eslint-rules/index.mjs +26 -0
  141. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.d.mts +12 -0
  142. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.mjs +68 -0
  143. package/dist/lib/esm/script-utils/linters/eslint-types/@types/@eslint-community__eslint-plugin-eslint-comments__configs.d.mts +4 -2
  144. package/dist/lib/esm/script-utils/linters/eslint.d.mts +15 -2
  145. package/dist/lib/esm/script-utils/linters/eslint.mjs +7 -7
  146. package/dist/lib/esm/script-utils/linters/index.d.mts +1 -0
  147. package/dist/lib/esm/script-utils/linters/index.mjs +3 -1
  148. package/dist/lib/esm/script-utils/linters/markdownlint.d.mts +15 -2
  149. package/dist/lib/esm/script-utils/linters/markdownlint.mjs +13 -11
  150. package/dist/lib/esm/script-utils/nano-staged-config.d.mts +14 -0
  151. package/dist/lib/esm/script-utils/nano-staged-config.mjs +37 -0
  152. package/dist/lib/esm/script-utils/npm-publish.mjs +3 -6
  153. package/dist/lib/esm/script-utils/obsidian-dev-utils-repo-paths.d.mts +2 -0
  154. package/dist/lib/esm/script-utils/obsidian-dev-utils-repo-paths.mjs +2 -1
  155. package/dist/lib/esm/script-utils/root.d.mts +3 -7
  156. package/dist/lib/esm/script-utils/root.mjs +2 -2
  157. package/dist/lib/esm/script-utils/test-runners/vitest.d.mts +12 -1
  158. package/dist/lib/esm/script-utils/test-runners/vitest.mjs +6 -3
  159. package/dist/lib/esm/script-utils/version.mjs +16 -27
  160. package/dist/lib/esm/string.d.mts +2 -2
  161. package/dist/lib/esm/string.mjs +7 -13
  162. package/dist/lib/esm/type-guards.d.mts +11 -1
  163. package/dist/lib/esm/type-guards.mjs +7 -1
  164. package/dist/scripts/build/build-clean.ts +4 -0
  165. package/dist/scripts/build/build-compile-svelte.ts +4 -0
  166. package/dist/scripts/build/build-compile-typescript.ts +4 -0
  167. package/dist/scripts/build/build-compile.ts +4 -0
  168. package/dist/scripts/build/build-static.ts +4 -0
  169. package/dist/scripts/bundlers/esbuild/build.ts +4 -0
  170. package/dist/scripts/bundlers/esbuild/dev.ts +4 -0
  171. package/dist/scripts/formatters/dprint/format-check.ts +8 -0
  172. package/dist/scripts/formatters/dprint/format.ts +8 -0
  173. package/dist/scripts/linters/cspell/spellcheck.ts +8 -0
  174. package/dist/scripts/linters/eslint/lint-fix.ts +8 -0
  175. package/dist/scripts/linters/eslint/lint.ts +8 -0
  176. package/dist/scripts/linters/markdownlint/lint-md-fix.ts +8 -0
  177. package/dist/scripts/linters/markdownlint/lint-md.ts +8 -0
  178. package/dist/scripts/test-runners/vitest/test-coverage.ts +4 -0
  179. package/dist/scripts/test-runners/vitest/test-watch.ts +4 -0
  180. package/dist/scripts/test-runners/vitest/test.ts +4 -0
  181. package/dist/scripts/version/version.ts +7 -0
  182. package/obsidian/is-in-obsidian/package.json +6 -0
  183. package/package.json +30 -4
  184. package/script-utils/commitlint-config/package.json +6 -0
  185. package/script-utils/linters/eslint-rules/index/package.json +6 -0
  186. package/script-utils/linters/eslint-rules/no-used-underscore-params/package.json +6 -0
  187. package/script-utils/linters/eslint-rules/package.json +6 -0
  188. package/script-utils/nano-staged-config/package.json +6 -0
  189. package/dist/lib/cjs/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required.d.cts +0 -14
  190. package/dist/lib/cjs/script-utils/node-modules.cjs +0 -207
  191. package/dist/lib/cjs/script-utils/node-modules.d.cts +0 -17
  192. package/dist/lib/esm/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required.d.mts +0 -14
  193. package/dist/lib/esm/script-utils/node-modules.d.mts +0 -17
  194. package/dist/lib/esm/script-utils/node-modules.mjs +0 -92
  195. package/dist/scripts/default/build-clean.ts +0 -5
  196. package/dist/scripts/default/build-compile-svelte.ts +0 -5
  197. package/dist/scripts/default/build-compile-typescript.ts +0 -5
  198. package/dist/scripts/default/build-compile.ts +0 -5
  199. package/dist/scripts/default/build-static.ts +0 -5
  200. package/dist/scripts/default/build.ts +0 -9
  201. package/dist/scripts/default/dev.ts +0 -10
  202. package/dist/scripts/default/format-check.ts +0 -5
  203. package/dist/scripts/default/format.ts +0 -5
  204. package/dist/scripts/default/lint-fix.ts +0 -5
  205. package/dist/scripts/default/lint.ts +0 -5
  206. package/dist/scripts/default/publish.ts +0 -5
  207. package/dist/scripts/default/spellcheck.ts +0 -5
  208. package/dist/scripts/default/version.ts +0 -5
  209. package/dist/scripts/examples/build.customPlugin.ts +0 -38
  210. package/dist/scripts/examples/build.svelteConditions.ts +0 -18
  211. package/dist/scripts/examples/eslint.config.extend.mts +0 -14
  212. package/dist/scripts/examples/eslint.config.no-dev-utils.mts +0 -15
  213. package/dist/scripts/examples/format.prettier.ts +0 -25
  214. package/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required/package.json +0 -4
  215. package/script-utils/node-modules/package.json +0 -6
@@ -19,11 +19,11 @@ 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 process from "node:process";
22
23
  import { enableLibraryDebuggers } from "../debug.mjs";
23
24
  import { printError } from "../error.mjs";
24
25
  import { noop } from "../function.mjs";
25
26
  import { replaceAll } from "../string.mjs";
26
- import { process } from "./node-modules.mjs";
27
27
  class CliTaskResult {
28
28
  /**
29
29
  * Chains multiple tasks together, executing them sequentially until one fails.
@@ -153,4 +153,4 @@ export {
153
153
  toCommandLine,
154
154
  wrapCliTask
155
155
  };
156
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/cli-utils.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility classes and functions for managing task results, including\n * success, exit codes, and chaining multiple tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport type { MaybeReturn } from '../type.ts';\n\nimport { enableLibraryDebuggers } from '../debug.ts';\nimport { printError } from '../error.ts';\nimport { noop } from '../function.ts';\nimport { replaceAll } from '../string.ts';\nimport { process } from './node-modules.ts';\n\n/**\n * Abstract class representing the result of a task. Includes methods for handling success,\n * exit codes, and chaining tasks.\n */\nexport abstract class CliTaskResult {\n  /**\n   * Chains multiple tasks together, executing them sequentially until one fails.\n   *\n   * @param tasks - An array of task functions that return a {@link CliTaskResult} or `void`.\n   * @returns A {@link Promise} that resolves with the first failed {@link CliTaskResult} or a success result.\n   */\n  public static async chain(tasks: (() => Promisable<MaybeReturn<CliTaskResult>>)[]): Promise<CliTaskResult> {\n    for (const task of tasks) {\n      const result = await wrapResult(task);\n      if (!result.isSuccessful()) {\n        return result;\n      }\n    }\n\n    return CliTaskResult.Success();\n  }\n\n  /**\n   * Creates a {@link CliTaskResult} that does not exit the process.\n   *\n   * @returns A {@link CliTaskResult} that does not exit the process.\n   */\n  public static DoNotExit(): CliTaskResult {\n    return new DoNotExitTaskResult();\n  }\n\n  /**\n   * A failure result of a CLI task.\n   *\n   * @returns The failure result.\n   */\n  public static Failure(): CliTaskResult {\n    return this.Success(false);\n  }\n\n  /**\n   * Creates a {@link CliTaskResult} based on an exit code.\n   *\n   * @param exitCode - The exit code to represent.\n   * @returns A {@link CliTaskResult} representing the exit code.\n   */\n  public static FromExitCode(exitCode: number): CliTaskResult {\n    return new ExitCodeTaskResult(exitCode);\n  }\n\n  /**\n   * Creates a CliTaskResult representing a successful task result.\n   *\n   * @param isSuccess - A boolean indicating whether the task was successful. Default is `true`.\n   * @returns A CliTaskResult object representing a successful task result.\n   */\n  public static Success(isSuccess = true): CliTaskResult {\n    return new SuccessTaskResult(isSuccess);\n  }\n\n  /**\n   * Exits the process based on the task result.\n   */\n  public abstract exit(): void;\n\n  /**\n   * Throws an error if the task was not successful.\n   */\n  public throwOnFailure(): void {\n    if (!this.isSuccessful()) {\n      throw new Error('Task failed');\n    }\n  }\n\n  /**\n   * Determines if the task was successful.\n   *\n   * @returns `true` if the task was successful, otherwise `false`.\n   */\n  protected abstract isSuccessful(): boolean;\n}\n\n/**\n * A task result that does not exit the process.\n */\nclass DoNotExitTaskResult extends CliTaskResult {\n  /**\n   * Does not exit the process.\n   */\n  public override exit(): void {\n    noop();\n  }\n\n  protected override isSuccessful(): boolean {\n    return true;\n  }\n}\n\n/**\n * A task result based on an exit code.\n */\nclass ExitCodeTaskResult extends CliTaskResult {\n  public constructor(private readonly exitCode: number) {\n    super();\n  }\n\n  /**\n   * Exits the process with the specified exit code.\n   */\n  public override exit(): void {\n    process.exit(this.exitCode);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this.exitCode === 0;\n  }\n}\n\n/**\n * A task result based on success or failure.\n */\nclass SuccessTaskResult extends CliTaskResult {\n  public constructor(private readonly _isSuccessful: boolean) {\n    super();\n  }\n\n  /**\n   * Exits the process based on the success of the task.\n   */\n  public override exit(): void {\n    process.exit(this._isSuccessful ? 0 : 1);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this._isSuccessful;\n  }\n}\n\n/**\n * Converts an array of command-line arguments into a single command-line string.\n * Handles escaping of special characters such as spaces, quotes, and newlines.\n *\n * @param args - The array of command-line arguments to convert.\n * @returns A string representing the command-line invocation.\n */\nexport function toCommandLine(args: string[]): string {\n  return args\n    .map((arg) => {\n      if (/[\\s\"\\n]/.test(arg)) {\n        let escapedArg = arg;\n        escapedArg = replaceAll(escapedArg, /\"/g, '\\\\\"');\n        escapedArg = replaceAll(escapedArg, /\\n/g, '\\\\n');\n        return `\"${escapedArg}\"`;\n      }\n      return arg;\n    })\n    .join(' ');\n}\n\n/**\n * Wraps a CLI task function to ensure it runs safely and handles its {@link CliTaskResult}.\n *\n * @param taskFn - The task function to execute, which may return a {@link CliTaskResult} or `void`.\n * @returns A {@link Promise} that resolves when the task is completed and exits with the appropriate status.\n */\nexport async function wrapCliTask(taskFn: () => Promisable<MaybeReturn<CliTaskResult>>): Promise<void> {\n  enableLibraryDebuggers();\n  const result = await wrapResult(taskFn);\n  result.exit();\n}\n\n/**\n * Safely executes a task function and returns a {@link CliTaskResult}. If the task function throws an error,\n * An error is caught, and a failure {@link CliTaskResult} is returned.\n *\n * @param taskFn - The task function to execute.\n * @returns A {@link Promise} that resolves with a {@link CliTaskResult} representing the outcome of the task.\n */\nasync function wrapResult(taskFn: () => Promisable<MaybeReturn<CliTaskResult>>): Promise<CliTaskResult> {\n  try {\n    return (await taskFn()) as CliTaskResult | undefined ?? CliTaskResult.Success();\n  } catch (error) {\n    printError(new Error('An error occurred during task execution', { cause: error }));\n    return CliTaskResult.Failure();\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAWA,SAAS,8BAA8B;AACvC,SAAS,kBAAkB;AAC3B,SAAS,YAAY;AACrB,SAAS,kBAAkB;AAC3B,SAAS,eAAe;AAMjB,MAAe,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOlC,aAAoB,MAAM,OAAiF;AACzG,eAAW,QAAQ,OAAO;AACxB,YAAM,SAAS,MAAM,WAAW,IAAI;AACpC,UAAI,CAAC,OAAO,aAAa,GAAG;AAC1B,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO,cAAc,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,YAA2B;AACvC,WAAO,IAAI,oBAAoB;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAyB;AACrC,WAAO,KAAK,QAAQ,KAAK;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,aAAa,UAAiC;AAC1D,WAAO,IAAI,mBAAmB,QAAQ;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,QAAQ,YAAY,MAAqB;AACrD,WAAO,IAAI,kBAAkB,SAAS;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA,EAUO,iBAAuB;AAC5B,QAAI,CAAC,KAAK,aAAa,GAAG;AACxB,YAAM,IAAI,MAAM,aAAa;AAAA,IAC/B;AAAA,EACF;AAQF;AAKA,MAAM,4BAA4B,cAAc;AAAA;AAAA;AAAA;AAAA,EAI9B,OAAa;AAC3B,SAAK;AAAA,EACP;AAAA,EAEmB,eAAwB;AACzC,WAAO;AAAA,EACT;AACF;AAKA,MAAM,2BAA2B,cAAc;AAAA,EACtC,YAA6B,UAAkB;AACpD,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,YAAQ,KAAK,KAAK,QAAQ;AAAA,EAC5B;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK,aAAa;AAAA,EAC3B;AACF;AAKA,MAAM,0BAA0B,cAAc;AAAA,EACrC,YAA6B,eAAwB;AAC1D,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,YAAQ,KAAK,KAAK,gBAAgB,IAAI,CAAC;AAAA,EACzC;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK;AAAA,EACd;AACF;AASO,SAAS,cAAc,MAAwB;AACpD,SAAO,KACJ,IAAI,CAAC,QAAQ;AACZ,QAAI,UAAU,KAAK,GAAG,GAAG;AACvB,UAAI,aAAa;AACjB,mBAAa,WAAW,YAAY,MAAM,KAAK;AAC/C,mBAAa,WAAW,YAAY,OAAO,KAAK;AAChD,aAAO,IAAI,UAAU;AAAA,IACvB;AACA,WAAO;AAAA,EACT,CAAC,EACA,KAAK,GAAG;AACb;AAQA,eAAsB,YAAY,QAAqE;AACrG,yBAAuB;AACvB,QAAM,SAAS,MAAM,WAAW,MAAM;AACtC,SAAO,KAAK;AACd;AASA,eAAe,WAAW,QAA8E;AACtG,MAAI;AACF,WAAQ,MAAM,OAAO,KAAmC,cAAc,QAAQ;AAAA,EAChF,SAAS,OAAO;AACd,eAAW,IAAI,MAAM,2CAA2C,EAAE,OAAO,MAAM,CAAC,CAAC;AACjF,WAAO,cAAc,QAAQ;AAAA,EAC/B;AACF;",
  "names": []
}

156
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/cli-utils.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility classes and functions for managing task results, including\n * success, exit codes, and chaining multiple tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport process from 'node:process';\n\nimport type { MaybeReturn } from '../type.ts';\n\nimport { enableLibraryDebuggers } from '../debug.ts';\nimport { printError } from '../error.ts';\nimport { noop } from '../function.ts';\nimport { replaceAll } from '../string.ts';\n\n/**\n * Abstract class representing the result of a task. Includes methods for handling success,\n * exit codes, and chaining tasks.\n */\nexport abstract class CliTaskResult {\n  /**\n   * Chains multiple tasks together, executing them sequentially until one fails.\n   *\n   * @param tasks - An array of task functions that return a {@link CliTaskResult} or `void`.\n   * @returns A {@link Promise} that resolves with the first failed {@link CliTaskResult} or a success result.\n   */\n  public static async chain(tasks: (() => Promisable<MaybeReturn<CliTaskResult>>)[]): Promise<CliTaskResult> {\n    for (const task of tasks) {\n      const result = await wrapResult(task);\n      if (!result.isSuccessful()) {\n        return result;\n      }\n    }\n\n    return CliTaskResult.Success();\n  }\n\n  /**\n   * Creates a {@link CliTaskResult} that does not exit the process.\n   *\n   * @returns A {@link CliTaskResult} that does not exit the process.\n   */\n  public static DoNotExit(): CliTaskResult {\n    return new DoNotExitTaskResult();\n  }\n\n  /**\n   * A failure result of a CLI task.\n   *\n   * @returns The failure result.\n   */\n  public static Failure(): CliTaskResult {\n    return this.Success(false);\n  }\n\n  /**\n   * Creates a {@link CliTaskResult} based on an exit code.\n   *\n   * @param exitCode - The exit code to represent.\n   * @returns A {@link CliTaskResult} representing the exit code.\n   */\n  public static FromExitCode(exitCode: number): CliTaskResult {\n    return new ExitCodeTaskResult(exitCode);\n  }\n\n  /**\n   * Creates a CliTaskResult representing a successful task result.\n   *\n   * @param isSuccess - A boolean indicating whether the task was successful. Default is `true`.\n   * @returns A CliTaskResult object representing a successful task result.\n   */\n  public static Success(isSuccess = true): CliTaskResult {\n    return new SuccessTaskResult(isSuccess);\n  }\n\n  /**\n   * Exits the process based on the task result.\n   */\n  public abstract exit(): void;\n\n  /**\n   * Throws an error if the task was not successful.\n   */\n  public throwOnFailure(): void {\n    if (!this.isSuccessful()) {\n      throw new Error('Task failed');\n    }\n  }\n\n  /**\n   * Determines if the task was successful.\n   *\n   * @returns `true` if the task was successful, otherwise `false`.\n   */\n  protected abstract isSuccessful(): boolean;\n}\n\n/**\n * A task result that does not exit the process.\n */\nclass DoNotExitTaskResult extends CliTaskResult {\n  /**\n   * Does not exit the process.\n   */\n  public override exit(): void {\n    noop();\n  }\n\n  protected override isSuccessful(): boolean {\n    return true;\n  }\n}\n\n/**\n * A task result based on an exit code.\n */\nclass ExitCodeTaskResult extends CliTaskResult {\n  public constructor(private readonly exitCode: number) {\n    super();\n  }\n\n  /**\n   * Exits the process with the specified exit code.\n   */\n  public override exit(): void {\n    process.exit(this.exitCode);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this.exitCode === 0;\n  }\n}\n\n/**\n * A task result based on success or failure.\n */\nclass SuccessTaskResult extends CliTaskResult {\n  public constructor(private readonly _isSuccessful: boolean) {\n    super();\n  }\n\n  /**\n   * Exits the process based on the success of the task.\n   */\n  public override exit(): void {\n    process.exit(this._isSuccessful ? 0 : 1);\n  }\n\n  protected override isSuccessful(): boolean {\n    return this._isSuccessful;\n  }\n}\n\n/**\n * Converts an array of command-line arguments into a single command-line string.\n * Handles escaping of special characters such as spaces, quotes, and newlines.\n *\n * @param args - The array of command-line arguments to convert.\n * @returns A string representing the command-line invocation.\n */\nexport function toCommandLine(args: string[]): string {\n  return args\n    .map((arg) => {\n      if (/[\\s\"\\n]/.test(arg)) {\n        let escapedArg = arg;\n        escapedArg = replaceAll(escapedArg, /\"/g, '\\\\\"');\n        escapedArg = replaceAll(escapedArg, /\\n/g, '\\\\n');\n        return `\"${escapedArg}\"`;\n      }\n      return arg;\n    })\n    .join(' ');\n}\n\n/**\n * Wraps a CLI task function to ensure it runs safely and handles its {@link CliTaskResult}.\n *\n * @param taskFn - The task function to execute, which may return a {@link CliTaskResult} or `void`.\n * @returns A {@link Promise} that resolves when the task is completed and exits with the appropriate status.\n */\nexport async function wrapCliTask(taskFn: () => Promisable<MaybeReturn<CliTaskResult>>): Promise<void> {\n  enableLibraryDebuggers();\n  const result = await wrapResult(taskFn);\n  result.exit();\n}\n\n/**\n * Safely executes a task function and returns a {@link CliTaskResult}. If the task function throws an error,\n * An error is caught, and a failure {@link CliTaskResult} is returned.\n *\n * @param taskFn - The task function to execute.\n * @returns A {@link Promise} that resolves with a {@link CliTaskResult} representing the outcome of the task.\n */\nasync function wrapResult(taskFn: () => Promisable<MaybeReturn<CliTaskResult>>): Promise<CliTaskResult> {\n  try {\n    return (await taskFn()) as CliTaskResult | undefined ?? CliTaskResult.Success();\n  } catch (error) {\n    printError(new Error('An error occurred during task execution', { cause: error }));\n    return CliTaskResult.Failure();\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AASA,OAAO,aAAa;AAIpB,SAAS,8BAA8B;AACvC,SAAS,kBAAkB;AAC3B,SAAS,YAAY;AACrB,SAAS,kBAAkB;AAMpB,MAAe,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOlC,aAAoB,MAAM,OAAiF;AACzG,eAAW,QAAQ,OAAO;AACxB,YAAM,SAAS,MAAM,WAAW,IAAI;AACpC,UAAI,CAAC,OAAO,aAAa,GAAG;AAC1B,eAAO;AAAA,MACT;AAAA,IACF;AAEA,WAAO,cAAc,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,YAA2B;AACvC,WAAO,IAAI,oBAAoB;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAyB;AACrC,WAAO,KAAK,QAAQ,KAAK;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,aAAa,UAAiC;AAC1D,WAAO,IAAI,mBAAmB,QAAQ;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,QAAQ,YAAY,MAAqB;AACrD,WAAO,IAAI,kBAAkB,SAAS;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA,EAUO,iBAAuB;AAC5B,QAAI,CAAC,KAAK,aAAa,GAAG;AACxB,YAAM,IAAI,MAAM,aAAa;AAAA,IAC/B;AAAA,EACF;AAQF;AAKA,MAAM,4BAA4B,cAAc;AAAA;AAAA;AAAA;AAAA,EAI9B,OAAa;AAC3B,SAAK;AAAA,EACP;AAAA,EAEmB,eAAwB;AACzC,WAAO;AAAA,EACT;AACF;AAKA,MAAM,2BAA2B,cAAc;AAAA,EACtC,YAA6B,UAAkB;AACpD,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,YAAQ,KAAK,KAAK,QAAQ;AAAA,EAC5B;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK,aAAa;AAAA,EAC3B;AACF;AAKA,MAAM,0BAA0B,cAAc;AAAA,EACrC,YAA6B,eAAwB;AAC1D,UAAM;AAD4B;AAAA,EAEpC;AAAA;AAAA;AAAA;AAAA,EAKgB,OAAa;AAC3B,YAAQ,KAAK,KAAK,gBAAgB,IAAI,CAAC;AAAA,EACzC;AAAA,EAEmB,eAAwB;AACzC,WAAO,KAAK;AAAA,EACd;AACF;AASO,SAAS,cAAc,MAAwB;AACpD,SAAO,KACJ,IAAI,CAAC,QAAQ;AACZ,QAAI,UAAU,KAAK,GAAG,GAAG;AACvB,UAAI,aAAa;AACjB,mBAAa,WAAW,YAAY,MAAM,KAAK;AAC/C,mBAAa,WAAW,YAAY,OAAO,KAAK;AAChD,aAAO,IAAI,UAAU;AAAA,IACvB;AACA,WAAO;AAAA,EACT,CAAC,EACA,KAAK,GAAG;AACb;AAQA,eAAsB,YAAY,QAAqE;AACrG,yBAAuB;AACvB,QAAM,SAAS,MAAM,WAAW,MAAM;AACtC,SAAO,KAAK;AACd;AASA,eAAe,WAAW,QAA8E;AACtG,MAAI;AACF,WAAQ,MAAM,OAAO,KAAmC,cAAc,QAAQ;AAAA,EAChF,SAAS,OAAO;AACd,eAAW,IAAI,MAAM,2CAA2C,EAAE,OAAO,MAAM,CAAC,CAAC;AACjF,WAAO,cAAc,QAAQ;AAAA,EAC/B;AACF;",
  "names": []
}

@@ -19,7 +19,7 @@ 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 { writeFile } from "./node-modules.mjs";
22
+ import { writeFile } from "node:fs/promises";
23
23
  async function generate(path, lines) {
24
24
  if (lines.at(-1)) {
25
25
  lines.push("");
@@ -30,4 +30,4 @@ async function generate(path, lines) {
30
30
  export {
31
31
  generate
32
32
  };
33
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9jb2RlLWdlbmVyYXRvci50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgY29kZSBnZW5lcmF0aW9uLlxuICovXG5cbmltcG9ydCB7IHdyaXRlRmlsZSB9IGZyb20gJy4vbm9kZS1tb2R1bGVzLnRzJztcblxuLyoqXG4gKiBHZW5lcmF0ZXMgYSBmaWxlIGF0IHRoZSBzcGVjaWZpZWQgcGF0aCB3aXRoIHRoZSBwcm92aWRlZCBsaW5lcyBvZiBjb2RlLlxuICpcbiAqIEBwYXJhbSBwYXRoIC0gVGhlIHBhdGggd2hlcmUgdGhlIGZpbGUgd2lsbCBiZSBnZW5lcmF0ZWQuXG4gKiBAcGFyYW0gbGluZXMgLSBBbiBhcnJheSBvZiBzdHJpbmdzIHJlcHJlc2VudGluZyB0aGUgbGluZXMgb2YgY29kZSB0byBiZSB3cml0dGVuIGluIHRoZSBmaWxlLlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBmaWxlIGdlbmVyYXRpb24gaXMgY29tcGxldGUuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZW5lcmF0ZShwYXRoOiBzdHJpbmcsIGxpbmVzOiBzdHJpbmdbXSk6IFByb21pc2U8dm9pZD4ge1xuICBpZiAobGluZXMuYXQoLTEpKSB7XG4gICAgbGluZXMucHVzaCgnJyk7XG4gIH1cbiAgbGluZXMudW5zaGlmdCgnLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovJywgJycpO1xuICBhd2FpdCB3cml0ZUZpbGUocGF0aCwgbGluZXMuam9pbignXFxuJyksICd1dGYtOCcpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBTUEsU0FBUyxpQkFBaUI7QUFTMUIsZUFBc0IsU0FBUyxNQUFjLE9BQWdDO0FBQzNFLE1BQUksTUFBTSxHQUFHLEVBQUUsR0FBRztBQUNoQixVQUFNLEtBQUssRUFBRTtBQUFBLEVBQ2Y7QUFDQSxRQUFNLFFBQVEsMERBQTBELEVBQUU7QUFDMUUsUUFBTSxVQUFVLE1BQU0sTUFBTSxLQUFLLElBQUksR0FBRyxPQUFPO0FBQ2pEOyIsCiAgIm5hbWVzIjogW10KfQo=
33
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9jb2RlLWdlbmVyYXRvci50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgY29kZSBnZW5lcmF0aW9uLlxuICovXG5cbmltcG9ydCB7IHdyaXRlRmlsZSB9IGZyb20gJ25vZGU6ZnMvcHJvbWlzZXMnO1xuXG4vKipcbiAqIEdlbmVyYXRlcyBhIGZpbGUgYXQgdGhlIHNwZWNpZmllZCBwYXRoIHdpdGggdGhlIHByb3ZpZGVkIGxpbmVzIG9mIGNvZGUuXG4gKlxuICogQHBhcmFtIHBhdGggLSBUaGUgcGF0aCB3aGVyZSB0aGUgZmlsZSB3aWxsIGJlIGdlbmVyYXRlZC5cbiAqIEBwYXJhbSBsaW5lcyAtIEFuIGFycmF5IG9mIHN0cmluZ3MgcmVwcmVzZW50aW5nIHRoZSBsaW5lcyBvZiBjb2RlIHRvIGJlIHdyaXR0ZW4gaW4gdGhlIGZpbGUuXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGZpbGUgZ2VuZXJhdGlvbiBpcyBjb21wbGV0ZS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlKHBhdGg6IHN0cmluZywgbGluZXM6IHN0cmluZ1tdKTogUHJvbWlzZTx2b2lkPiB7XG4gIGlmIChsaW5lcy5hdCgtMSkpIHtcbiAgICBsaW5lcy5wdXNoKCcnKTtcbiAgfVxuICBsaW5lcy51bnNoaWZ0KCcvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi8nLCAnJyk7XG4gIGF3YWl0IHdyaXRlRmlsZShwYXRoLCBsaW5lcy5qb2luKCdcXG4nKSwgJ3V0Zi04Jyk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFNQSxTQUFTLGlCQUFpQjtBQVMxQixlQUFzQixTQUFTLE1BQWMsT0FBZ0M7QUFDM0UsTUFBSSxNQUFNLEdBQUcsRUFBRSxHQUFHO0FBQ2hCLFVBQU0sS0FBSyxFQUFFO0FBQUEsRUFDZjtBQUNBLFFBQU0sUUFBUSwwREFBMEQsRUFBRTtBQUMxRSxRQUFNLFVBQVUsTUFBTSxNQUFNLEtBQUssSUFBSSxHQUFHLE9BQU87QUFDakQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -0,0 +1,10 @@
1
+ /**
2
+ * @packageDocumentation
3
+ *
4
+ * Shared commitlint configuration for Conventional Commits.
5
+ */
6
+ import type { UserConfig } from '@commitlint/types';
7
+ /**
8
+ * Commitlint configuration extending `@commitlint/config-conventional`.
9
+ */
10
+ export declare const obsidianDevUtilsConfig: UserConfig;
@@ -0,0 +1,28 @@
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
+ const obsidianDevUtilsConfig = {
23
+ extends: ["@commitlint/config-conventional"]
24
+ };
25
+ export {
26
+ obsidianDevUtilsConfig
27
+ };
28
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9jb21taXRsaW50LWNvbmZpZy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBTaGFyZWQgY29tbWl0bGludCBjb25maWd1cmF0aW9uIGZvciBDb252ZW50aW9uYWwgQ29tbWl0cy5cbiAqL1xuXG4vKiB2OCBpZ25vcmUgc3RhcnQgLS0gRGVjbGFyYXRpdmUgY29tbWl0bGludCBjb25maWd1cmF0aW9uOyBjb3JyZWN0bmVzcyBpcyB2ZXJpZmllZCBieSBydW5uaW5nIGNvbW1pdGxpbnQsIG5vdCB1bml0IHRlc3RzLiAqL1xuXG5pbXBvcnQgdHlwZSB7IFVzZXJDb25maWcgfSBmcm9tICdAY29tbWl0bGludC90eXBlcyc7XG5cbi8qKlxuICogQ29tbWl0bGludCBjb25maWd1cmF0aW9uIGV4dGVuZGluZyBgQGNvbW1pdGxpbnQvY29uZmlnLWNvbnZlbnRpb25hbGAuXG4gKi9cbmV4cG9ydCBjb25zdCBvYnNpZGlhbkRldlV0aWxzQ29uZmlnOiBVc2VyQ29uZmlnID0ge1xuICBleHRlbmRzOiBbJ0Bjb21taXRsaW50L2NvbmZpZy1jb252ZW50aW9uYWwnXVxufTtcblxuLyogdjggaWdub3JlIHN0b3AgKi9cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQWFPLE1BQU0seUJBQXFDO0FBQUEsRUFDaEQsU0FBUyxDQUFDLGlDQUFpQztBQUM3QzsiLAogICJuYW1lcyI6IFtdCn0K
@@ -3,6 +3,30 @@
3
3
  *
4
4
  * Contains utility functions for executing commands.
5
5
  */
6
+ /**
7
+ * A command part: either a plain string or an {@link ExecArg} with batched arguments.
8
+ */
9
+ export type CommandPart = ExecArg | string;
10
+ /**
11
+ * A command argument that contains a list of args to be batched.
12
+ * If the expanded command exceeds the platform's max command length,
13
+ * the batched args are split into sequential executions.
14
+ */
15
+ export interface ExecArg {
16
+ /**
17
+ * The arguments to batch.
18
+ */
19
+ batchedArgs: string[];
20
+ }
21
+ /**
22
+ * Options for {@link exec} that return detailed results.
23
+ */
24
+ export interface ExecDetailedOptions extends ExecOption {
25
+ /**
26
+ * Must be `true` to receive detailed results.
27
+ */
28
+ withDetails: true;
29
+ }
6
30
  /**
7
31
  * Options for executing a command.
8
32
  */
@@ -53,6 +77,15 @@ export interface ExecResult {
53
77
  */
54
78
  stdout: string;
55
79
  }
80
+ /**
81
+ * Options for {@link exec} that return only stdout.
82
+ */
83
+ export interface ExecSimpleOptions extends ExecOption {
84
+ /**
85
+ * Must be `false` or omitted to receive only stdout.
86
+ */
87
+ withDetails?: false;
88
+ }
56
89
  /**
57
90
  * Executes a command.
58
91
  *
@@ -64,9 +97,7 @@ export interface ExecResult {
64
97
  * If an error occurs during the execution and ignoreExitCode is `true`,
65
98
  * the error is resolved with the stdout and stderr.
66
99
  */
67
- export declare function exec(command: string | string[], options?: {
68
- withDetails?: false;
69
- } & ExecOption): Promise<string>;
100
+ export declare function exec(command: CommandPart[] | string, options?: ExecSimpleOptions): Promise<string>;
70
101
  /**
71
102
  * Executes a command.
72
103
  *
@@ -79,6 +110,4 @@ export declare function exec(command: string | string[], options?: {
79
110
  * If an error occurs during the execution and ignoreExitCode is `true`,
80
111
  * the error is resolved with the stdout and stderr.
81
112
  */
82
- export declare function exec(command: string | string[], options: {
83
- withDetails: true;
84
- } & ExecOption): Promise<ExecResult>;
113
+ export declare function exec(command: CommandPart[] | string, options: ExecDetailedOptions): Promise<ExecResult>;
@@ -19,14 +19,31 @@ 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 { spawn } from "node:child_process";
23
+ import process from "node:process";
22
24
  import { getLibDebugger } from "../debug.mjs";
23
25
  import { trimEnd } from "../string.mjs";
26
+ import { assertNonNullable } from "../type-guards.mjs";
24
27
  import { toCommandLine } from "./cli-utils.mjs";
25
- import {
26
- process,
27
- spawn
28
- } from "./node-modules.mjs";
29
28
  function exec(command, options = {}) {
29
+ if (Array.isArray(command)) {
30
+ const batchResult = handleBatchedCommand(command, options);
31
+ if (batchResult) {
32
+ return batchResult;
33
+ }
34
+ command = toCommandLine(command.filter((part) => typeof part === "string"));
35
+ }
36
+ const maxCommandLength = getMaxCommandLength();
37
+ if (command.length > maxCommandLength) {
38
+ return Promise.reject(
39
+ new Error(
40
+ `Command line is too long (${String(command.length)} chars, max ${String(maxCommandLength)} on ${process.platform}). Consider splitting into smaller batches or use ExecArg.`
41
+ )
42
+ );
43
+ }
44
+ return execString(command, options);
45
+ }
46
+ function execString(command, options = {}) {
30
47
  const {
31
48
  cwd = process.cwd(),
32
49
  isQuiet: quiet = false,
@@ -34,9 +51,6 @@ function exec(command, options = {}) {
34
51
  shouldIncludeDetails: withDetails = false,
35
52
  stdin = ""
36
53
  } = options;
37
- if (Array.isArray(command)) {
38
- command = toCommandLine(command);
39
- }
40
54
  return new Promise((resolve, reject) => {
41
55
  getLibDebugger("Exec")(`Executing command: ${command}`);
42
56
  const child = spawn(command, [], {
@@ -105,7 +119,69 @@ ${stderr}`));
105
119
  });
106
120
  });
107
121
  }
122
+ async function executeBatches(baseCommand, batches, options) {
123
+ const results = [];
124
+ for (const batch of batches) {
125
+ const batchCommand = `${baseCommand} ${batch.join(" ")}`;
126
+ const result = await execString(batchCommand, options);
127
+ if (typeof result === "string") {
128
+ results.push(result);
129
+ }
130
+ }
131
+ if (options.shouldIncludeDetails) {
132
+ return { exitCode: 0, exitSignal: null, stderr: "", stdout: results.join("\n") };
133
+ }
134
+ return results.join("\n");
135
+ }
136
+ function getMaxCommandLength() {
137
+ const WINDOWS_MAX_COMMAND_LENGTH = 8191;
138
+ const UNIX_MAX_COMMAND_LENGTH = 131072;
139
+ return process.platform === "win32" ? WINDOWS_MAX_COMMAND_LENGTH : UNIX_MAX_COMMAND_LENGTH;
140
+ }
141
+ function handleBatchedCommand(parts, options) {
142
+ const execArgs = parts.filter(isExecArg);
143
+ if (execArgs.length === 0) {
144
+ return void 0;
145
+ }
146
+ if (execArgs.length > 1) {
147
+ return Promise.reject(new Error("Only one ExecArg with batchedArgs is allowed per command"));
148
+ }
149
+ const execArg = execArgs[0];
150
+ assertNonNullable(execArg);
151
+ const staticParts = parts.filter((part) => typeof part === "string");
152
+ const baseCommand = toCommandLine(staticParts);
153
+ const maxCommandLength = getMaxCommandLength();
154
+ const fullCommand = `${baseCommand} ${execArg.batchedArgs.join(" ")}`;
155
+ if (fullCommand.length <= maxCommandLength) {
156
+ return execString(fullCommand, options);
157
+ }
158
+ const batches = [];
159
+ let currentBatch = [];
160
+ for (const arg of execArg.batchedArgs) {
161
+ const tentative = `${baseCommand} ${[...currentBatch, arg].join(" ")}`;
162
+ if (tentative.length > maxCommandLength) {
163
+ if (currentBatch.length === 0) {
164
+ return Promise.reject(
165
+ new Error(
166
+ `Cannot split command into batches: a single argument (${String(arg.length)} chars) plus the base command (${String(baseCommand.length)} chars) exceeds the max command length (${String(maxCommandLength)}).`
167
+ )
168
+ );
169
+ }
170
+ batches.push(currentBatch);
171
+ currentBatch = [arg];
172
+ } else {
173
+ currentBatch.push(arg);
174
+ }
175
+ }
176
+ if (currentBatch.length > 0) {
177
+ batches.push(currentBatch);
178
+ }
179
+ return executeBatches(baseCommand, batches, options);
180
+ }
181
+ function isExecArg(part) {
182
+ return typeof part === "object" && "batchedArgs" in part;
183
+ }
108
184
  export {
109
185
  exec
110
186
  };
111
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/exec.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for executing commands.\n */\n\nimport { getLibDebugger } from '../debug.ts';\nimport { trimEnd } from '../string.ts';\nimport { toCommandLine } from './cli-utils.ts';\nimport {\n  process,\n  spawn\n} from './node-modules.ts';\n\n/**\n * Options for executing a command.\n */\nexport interface ExecOption {\n  /**\n   * A current working folder for the command execution.\n   */\n  readonly cwd?: string;\n\n  /**\n   * If `true`, suppresses the output of the command.\n   */\n  readonly isQuiet?: boolean;\n\n  /**\n   * If `true`, throws an error if the command fails.\n   */\n  readonly shouldFailIfCalledFromOutsideRoot?: boolean;\n\n  /**\n   * If `true`, ignores the exit code of the command.\n   */\n  readonly shouldIgnoreExitCode?: boolean;\n\n  /**\n   * If `false`, only returns the output of the command.\n   */\n  readonly shouldIncludeDetails?: boolean;\n\n  /**\n   * An input to be passed to the command.\n   */\n  readonly stdin?: string;\n}\n\n/**\n * A result of {@link exec}.\n */\nexport interface ExecResult {\n  /**\n   * An exit code of the command. A value of `null` indicates that the process did not exit normally.\n   */\n  exitCode: null | number;\n\n  /**\n   * A signal that caused the process to be terminated. A value of `null` indicates that no signal was received.\n   */\n  exitSignal: NodeJS.Signals | null;\n\n  /**\n   * A standard error output from the command.\n   */\n  stderr: string;\n\n  /**\n   * A standard output from the command.\n   */\n  stdout: string;\n}\n\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function exec(command: string | string[], options?: { withDetails?: false } & ExecOption): Promise<string>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: string | string[], options: { withDetails: true } & ExecOption): Promise<ExecResult>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: string | string[], options: ExecOption = {}): Promise<ExecResult | string> {\n  const {\n    cwd = process.cwd(),\n    isQuiet: quiet = false,\n    shouldIgnoreExitCode: ignoreExitCode = false,\n    shouldIncludeDetails: withDetails = false,\n    stdin = ''\n  } = options;\n  if (Array.isArray(command)) {\n    command = toCommandLine(command);\n  }\n\n  return new Promise((resolve, reject) => {\n    getLibDebugger('Exec')(`Executing command: ${command}`);\n\n    const child = spawn(command, [], {\n      cwd,\n      env: {\n        DEBUG_COLORS: '1',\n        ...process.env\n      },\n      shell: true,\n      stdio: 'pipe'\n    });\n\n    let stdout = '';\n    let stderr = '';\n\n    child.stdin.write(stdin);\n    child.stdin.end();\n\n    child.stdout.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stdout.write(data);\n      }\n      stdout += data.toString('utf-8');\n    });\n\n    child.stdout.on('end', () => {\n      stdout = trimEnd(stdout, '\\n');\n    });\n\n    child.stderr.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stderr.write(data);\n      }\n      stderr += data.toString('utf-8');\n    });\n\n    child.stderr.on('end', () => {\n      stderr = trimEnd(stderr, '\\n');\n    });\n\n    child.on('close', (exitCode, exitSignal) => {\n      if (exitCode !== 0 && !ignoreExitCode) {\n        reject(new Error(`Command failed with exit code ${exitCode ? String(exitCode) : '(null)'}\\n${stderr}`));\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n      resolve({\n        exitCode,\n        exitSignal,\n        stderr,\n        stdout\n      });\n    });\n\n    child.on('error', (err) => {\n      if (!ignoreExitCode) {\n        reject(err);\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n\n      resolve({\n        exitCode: null,\n        exitSignal: null,\n        stderr,\n        stdout\n      });\n    });\n  });\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAMA,SAAS,sBAAsB;AAC/B,SAAS,eAAe;AACxB,SAAS,qBAAqB;AAC9B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAmGA,SAAS,KAAK,SAA4B,UAAsB,CAAC,GAAiC;AACvG,QAAM;AAAA,IACJ,MAAM,QAAQ,IAAI;AAAA,IAClB,SAAS,QAAQ;AAAA,IACjB,sBAAsB,iBAAiB;AAAA,IACvC,sBAAsB,cAAc;AAAA,IACpC,QAAQ;AAAA,EACV,IAAI;AACJ,MAAI,MAAM,QAAQ,OAAO,GAAG;AAC1B,cAAU,cAAc,OAAO;AAAA,EACjC;AAEA,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,mBAAe,MAAM,EAAE,sBAAsB,OAAO,EAAE;AAEtD,UAAM,QAAQ,MAAM,SAAS,CAAC,GAAG;AAAA,MAC/B;AAAA,MACA,KAAK;AAAA,QACH,cAAc;AAAA,QACd,GAAG,QAAQ;AAAA,MACb;AAAA,MACA,OAAO;AAAA,MACP,OAAO;AAAA,IACT,CAAC;AAED,QAAI,SAAS;AACb,QAAI,SAAS;AAEb,UAAM,MAAM,MAAM,KAAK;AACvB,UAAM,MAAM,IAAI;AAEhB,UAAM,OAAO,GAAG,QAAQ,CAAC,SAAiB;AACxC,UAAI,CAAC,OAAO;AACV,gBAAQ,OAAO,MAAM,IAAI;AAAA,MAC3B;AACA,gBAAU,KAAK,SAAS,OAAO;AAAA,IACjC,CAAC;AAED,UAAM,OAAO,GAAG,OAAO,MAAM;AAC3B,eAAS,QAAQ,QAAQ,IAAI;AAAA,IAC/B,CAAC;AAED,UAAM,OAAO,GAAG,QAAQ,CAAC,SAAiB;AACxC,UAAI,CAAC,OAAO;AACV,gBAAQ,OAAO,MAAM,IAAI;AAAA,MAC3B;AACA,gBAAU,KAAK,SAAS,OAAO;AAAA,IACjC,CAAC;AAED,UAAM,OAAO,GAAG,OAAO,MAAM;AAC3B,eAAS,QAAQ,QAAQ,IAAI;AAAA,IAC/B,CAAC;AAED,UAAM,GAAG,SAAS,CAAC,UAAU,eAAe;AAC1C,UAAI,aAAa,KAAK,CAAC,gBAAgB;AACrC,eAAO,IAAI,MAAM,iCAAiC,WAAW,OAAO,QAAQ,IAAI,QAAQ;AAAA,EAAK,MAAM,EAAE,CAAC;AACtG;AAAA,MACF;AAEA,UAAI,CAAC,aAAa;AAChB,gBAAQ,MAAM;AACd;AAAA,MACF;AACA,cAAQ;AAAA,QACN;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAED,UAAM,GAAG,SAAS,CAAC,QAAQ;AACzB,UAAI,CAAC,gBAAgB;AACnB,eAAO,GAAG;AACV;AAAA,MACF;AAEA,UAAI,CAAC,aAAa;AAChB,gBAAQ,MAAM;AACd;AAAA,MACF;AAEA,cAAQ;AAAA,QACN,UAAU;AAAA,QACV,YAAY;AAAA,QACZ;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAAA,EACH,CAAC;AACH;",
  "names": []
}

187
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/exec.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for executing commands.\n */\n\nimport { spawn } from 'node:child_process';\nimport process from 'node:process';\n\nimport { getLibDebugger } from '../debug.ts';\nimport { trimEnd } from '../string.ts';\nimport { assertNonNullable } from '../type-guards.ts';\nimport { toCommandLine } from './cli-utils.ts';\n\n/**\n * A command part: either a plain string or an {@link ExecArg} with batched arguments.\n */\nexport type CommandPart = ExecArg | string;\n\n/**\n * A command argument that contains a list of args to be batched.\n * If the expanded command exceeds the platform's max command length,\n * the batched args are split into sequential executions.\n */\nexport interface ExecArg {\n  /**\n   * The arguments to batch.\n   */\n  batchedArgs: string[];\n}\n\n/**\n * Options for {@link exec} that return detailed results.\n */\nexport interface ExecDetailedOptions extends ExecOption {\n  /**\n   * Must be `true` to receive detailed results.\n   */\n  withDetails: true;\n}\n\n/**\n * Options for executing a command.\n */\nexport interface ExecOption {\n  /**\n   * A current working folder for the command execution.\n   */\n  readonly cwd?: string;\n\n  /**\n   * If `true`, suppresses the output of the command.\n   */\n  readonly isQuiet?: boolean;\n\n  /**\n   * If `true`, throws an error if the command fails.\n   */\n  readonly shouldFailIfCalledFromOutsideRoot?: boolean;\n\n  /**\n   * If `true`, ignores the exit code of the command.\n   */\n  readonly shouldIgnoreExitCode?: boolean;\n\n  /**\n   * If `false`, only returns the output of the command.\n   */\n  readonly shouldIncludeDetails?: boolean;\n\n  /**\n   * An input to be passed to the command.\n   */\n  readonly stdin?: string;\n}\n\n/**\n * A result of {@link exec}.\n */\nexport interface ExecResult {\n  /**\n   * An exit code of the command. A value of `null` indicates that the process did not exit normally.\n   */\n  exitCode: null | number;\n\n  /**\n   * A signal that caused the process to be terminated. A value of `null` indicates that no signal was received.\n   */\n  exitSignal: NodeJS.Signals | null;\n\n  /**\n   * A standard error output from the command.\n   */\n  stderr: string;\n\n  /**\n   * A standard output from the command.\n   */\n  stdout: string;\n}\n\n/**\n * Options for {@link exec} that return only stdout.\n */\nexport interface ExecSimpleOptions extends ExecOption {\n  /**\n   * Must be `false` or omitted to receive only stdout.\n   */\n  withDetails?: false;\n}\n\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function exec(command: CommandPart[] | string, options?: ExecSimpleOptions): Promise<string>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: CommandPart[] | string, options: ExecDetailedOptions): Promise<ExecResult>;\n/**\n * Executes a command.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is `false`.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is `true`,\n *         the error is resolved with the stdout and stderr.\n */\nexport function exec(command: CommandPart[] | string, options: ExecOption = {}): Promise<ExecResult | string> {\n  if (Array.isArray(command)) {\n    const batchResult = handleBatchedCommand(command, options);\n    if (batchResult) {\n      return batchResult;\n    }\n    command = toCommandLine(command.filter((part): part is string => typeof part === 'string'));\n  }\n\n  const maxCommandLength = getMaxCommandLength();\n  if (command.length > maxCommandLength) {\n    return Promise.reject(\n      new Error(\n        `Command line is too long (${String(command.length)} chars, max ${\n          String(maxCommandLength)\n        } on ${process.platform}). Consider splitting into smaller batches or use ExecArg.`\n      )\n    );\n  }\n\n  return execString(command, options);\n}\n\n/**\n * Executes a single string command.\n *\n * @param command - The command string.\n * @param options - The exec options.\n * @returns A Promise resolving to the result.\n */\nfunction execString(command: string, options: ExecOption = {}): Promise<ExecResult | string> {\n  const {\n    cwd = process.cwd(),\n    isQuiet: quiet = false,\n    shouldIgnoreExitCode: ignoreExitCode = false,\n    shouldIncludeDetails: withDetails = false,\n    stdin = ''\n  } = options;\n\n  return new Promise((resolve, reject) => {\n    getLibDebugger('Exec')(`Executing command: ${command}`);\n\n    const child = spawn(command, [], {\n      cwd,\n      env: {\n        DEBUG_COLORS: '1',\n        ...process.env\n      },\n      shell: true,\n      stdio: 'pipe'\n    });\n\n    let stdout = '';\n    let stderr = '';\n\n    child.stdin.write(stdin);\n    child.stdin.end();\n\n    child.stdout.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stdout.write(data);\n      }\n      stdout += data.toString('utf-8');\n    });\n\n    child.stdout.on('end', () => {\n      stdout = trimEnd(stdout, '\\n');\n    });\n\n    child.stderr.on('data', (data: Buffer) => {\n      if (!quiet) {\n        process.stderr.write(data);\n      }\n      stderr += data.toString('utf-8');\n    });\n\n    child.stderr.on('end', () => {\n      stderr = trimEnd(stderr, '\\n');\n    });\n\n    child.on('close', (exitCode, exitSignal) => {\n      if (exitCode !== 0 && !ignoreExitCode) {\n        reject(new Error(`Command failed with exit code ${exitCode ? String(exitCode) : '(null)'}\\n${stderr}`));\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n      resolve({\n        exitCode,\n        exitSignal,\n        stderr,\n        stdout\n      });\n    });\n\n    child.on('error', (err) => {\n      if (!ignoreExitCode) {\n        reject(err);\n        return;\n      }\n\n      if (!withDetails) {\n        resolve(stdout);\n        return;\n      }\n\n      resolve({\n        exitCode: null,\n        exitSignal: null,\n        stderr,\n        stdout\n      });\n    });\n  });\n}\n\n/**\n * Executes batched commands sequentially and concatenates stdout.\n *\n * @param baseCommand - The base command without batched args.\n * @param batches - The batches of args.\n * @param options - The exec options.\n * @returns A Promise resolving to the concatenated result.\n */\nasync function executeBatches(baseCommand: string, batches: string[][], options: ExecOption): Promise<ExecResult | string> {\n  const results: string[] = [];\n\n  for (const batch of batches) {\n    const batchCommand = `${baseCommand} ${batch.join(' ')}`;\n    const result = await execString(batchCommand, options);\n    if (typeof result === 'string') {\n      results.push(result);\n    }\n  }\n\n  if (options.shouldIncludeDetails) {\n    return { exitCode: 0, exitSignal: null, stderr: '', stdout: results.join('\\n') };\n  }\n\n  return results.join('\\n');\n}\n\n/**\n * Returns the platform-specific max command line length.\n *\n * @returns The max command length in characters.\n */\nfunction getMaxCommandLength(): number {\n  const WINDOWS_MAX_COMMAND_LENGTH = 8191;\n  const UNIX_MAX_COMMAND_LENGTH = 131072;\n  return process.platform === 'win32' ? WINDOWS_MAX_COMMAND_LENGTH : UNIX_MAX_COMMAND_LENGTH;\n}\n\n/**\n * Handles a command array that may contain an {@link ExecArg}.\n * Returns a Promise if batching is needed, or `undefined` if the command\n * has no ExecArg and should be processed normally.\n *\n * @param parts - The command parts.\n * @param options - The exec options.\n * @returns A Promise if batching is handled, or `undefined`.\n */\nfunction handleBatchedCommand(parts: CommandPart[], options: ExecOption): Promise<ExecResult | string> | undefined {\n  const execArgs = parts.filter(isExecArg);\n  if (execArgs.length === 0) {\n    return undefined;\n  }\n  if (execArgs.length > 1) {\n    return Promise.reject(new Error('Only one ExecArg with batchedArgs is allowed per command'));\n  }\n\n  const execArg = execArgs[0];\n  assertNonNullable(execArg);\n  const staticParts = parts.filter((part): part is string => typeof part === 'string');\n  const baseCommand = toCommandLine(staticParts);\n  const maxCommandLength = getMaxCommandLength();\n\n  // Try expanding all args inline\n  const fullCommand = `${baseCommand} ${execArg.batchedArgs.join(' ')}`;\n  if (fullCommand.length <= maxCommandLength) {\n    return execString(fullCommand, options);\n  }\n\n  // Split into batches\n  const batches: string[][] = [];\n  let currentBatch: string[] = [];\n\n  for (const arg of execArg.batchedArgs) {\n    const tentative = `${baseCommand} ${[...currentBatch, arg].join(' ')}`;\n    if (tentative.length > maxCommandLength) {\n      if (currentBatch.length === 0) {\n        return Promise.reject(\n          new Error(\n            `Cannot split command into batches: a single argument (${String(arg.length)} chars) plus the base command (${\n              String(baseCommand.length)\n            } chars) exceeds the max command length (${String(maxCommandLength)}).`\n          )\n        );\n      }\n      batches.push(currentBatch);\n      currentBatch = [arg];\n    } else {\n      currentBatch.push(arg);\n    }\n  }\n  /* v8 ignore start -- Always true after the loop; batchedArgs is non-empty at this point. */\n  if (currentBatch.length > 0) {\n    /* v8 ignore stop */\n    batches.push(currentBatch);\n  }\n\n  return executeBatches(baseCommand, batches, options);\n}\n\n/**\n * Checks if a command part is an {@link ExecArg}.\n *\n * @param part - The command part to check.\n * @returns Whether the part is an ExecArg.\n */\nfunction isExecArg(part: CommandPart): part is ExecArg {\n  return typeof part === 'object' && 'batchedArgs' in part;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAMA,SAAS,aAAa;AACtB,OAAO,aAAa;AAEpB,SAAS,sBAAsB;AAC/B,SAAS,eAAe;AACxB,SAAS,yBAAyB;AAClC,SAAS,qBAAqB;AAwIvB,SAAS,KAAK,SAAiC,UAAsB,CAAC,GAAiC;AAC5G,MAAI,MAAM,QAAQ,OAAO,GAAG;AAC1B,UAAM,cAAc,qBAAqB,SAAS,OAAO;AACzD,QAAI,aAAa;AACf,aAAO;AAAA,IACT;AACA,cAAU,cAAc,QAAQ,OAAO,CAAC,SAAyB,OAAO,SAAS,QAAQ,CAAC;AAAA,EAC5F;AAEA,QAAM,mBAAmB,oBAAoB;AAC7C,MAAI,QAAQ,SAAS,kBAAkB;AACrC,WAAO,QAAQ;AAAA,MACb,IAAI;AAAA,QACF,6BAA6B,OAAO,QAAQ,MAAM,CAAC,eACjD,OAAO,gBAAgB,CACzB,OAAO,QAAQ,QAAQ;AAAA,MACzB;AAAA,IACF;AAAA,EACF;AAEA,SAAO,WAAW,SAAS,OAAO;AACpC;AASA,SAAS,WAAW,SAAiB,UAAsB,CAAC,GAAiC;AAC3F,QAAM;AAAA,IACJ,MAAM,QAAQ,IAAI;AAAA,IAClB,SAAS,QAAQ;AAAA,IACjB,sBAAsB,iBAAiB;AAAA,IACvC,sBAAsB,cAAc;AAAA,IACpC,QAAQ;AAAA,EACV,IAAI;AAEJ,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,mBAAe,MAAM,EAAE,sBAAsB,OAAO,EAAE;AAEtD,UAAM,QAAQ,MAAM,SAAS,CAAC,GAAG;AAAA,MAC/B;AAAA,MACA,KAAK;AAAA,QACH,cAAc;AAAA,QACd,GAAG,QAAQ;AAAA,MACb;AAAA,MACA,OAAO;AAAA,MACP,OAAO;AAAA,IACT,CAAC;AAED,QAAI,SAAS;AACb,QAAI,SAAS;AAEb,UAAM,MAAM,MAAM,KAAK;AACvB,UAAM,MAAM,IAAI;AAEhB,UAAM,OAAO,GAAG,QAAQ,CAAC,SAAiB;AACxC,UAAI,CAAC,OAAO;AACV,gBAAQ,OAAO,MAAM,IAAI;AAAA,MAC3B;AACA,gBAAU,KAAK,SAAS,OAAO;AAAA,IACjC,CAAC;AAED,UAAM,OAAO,GAAG,OAAO,MAAM;AAC3B,eAAS,QAAQ,QAAQ,IAAI;AAAA,IAC/B,CAAC;AAED,UAAM,OAAO,GAAG,QAAQ,CAAC,SAAiB;AACxC,UAAI,CAAC,OAAO;AACV,gBAAQ,OAAO,MAAM,IAAI;AAAA,MAC3B;AACA,gBAAU,KAAK,SAAS,OAAO;AAAA,IACjC,CAAC;AAED,UAAM,OAAO,GAAG,OAAO,MAAM;AAC3B,eAAS,QAAQ,QAAQ,IAAI;AAAA,IAC/B,CAAC;AAED,UAAM,GAAG,SAAS,CAAC,UAAU,eAAe;AAC1C,UAAI,aAAa,KAAK,CAAC,gBAAgB;AACrC,eAAO,IAAI,MAAM,iCAAiC,WAAW,OAAO,QAAQ,IAAI,QAAQ;AAAA,EAAK,MAAM,EAAE,CAAC;AACtG;AAAA,MACF;AAEA,UAAI,CAAC,aAAa;AAChB,gBAAQ,MAAM;AACd;AAAA,MACF;AACA,cAAQ;AAAA,QACN;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAED,UAAM,GAAG,SAAS,CAAC,QAAQ;AACzB,UAAI,CAAC,gBAAgB;AACnB,eAAO,GAAG;AACV;AAAA,MACF;AAEA,UAAI,CAAC,aAAa;AAChB,gBAAQ,MAAM;AACd;AAAA,MACF;AAEA,cAAQ;AAAA,QACN,UAAU;AAAA,QACV,YAAY;AAAA,QACZ;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAAA,EACH,CAAC;AACH;AAUA,eAAe,eAAe,aAAqB,SAAqB,SAAmD;AACzH,QAAM,UAAoB,CAAC;AAE3B,aAAW,SAAS,SAAS;AAC3B,UAAM,eAAe,GAAG,WAAW,IAAI,MAAM,KAAK,GAAG,CAAC;AACtD,UAAM,SAAS,MAAM,WAAW,cAAc,OAAO;AACrD,QAAI,OAAO,WAAW,UAAU;AAC9B,cAAQ,KAAK,MAAM;AAAA,IACrB;AAAA,EACF;AAEA,MAAI,QAAQ,sBAAsB;AAChC,WAAO,EAAE,UAAU,GAAG,YAAY,MAAM,QAAQ,IAAI,QAAQ,QAAQ,KAAK,IAAI,EAAE;AAAA,EACjF;AAEA,SAAO,QAAQ,KAAK,IAAI;AAC1B;AAOA,SAAS,sBAA8B;AACrC,QAAM,6BAA6B;AACnC,QAAM,0BAA0B;AAChC,SAAO,QAAQ,aAAa,UAAU,6BAA6B;AACrE;AAWA,SAAS,qBAAqB,OAAsB,SAA+D;AACjH,QAAM,WAAW,MAAM,OAAO,SAAS;AACvC,MAAI,SAAS,WAAW,GAAG;AACzB,WAAO;AAAA,EACT;AACA,MAAI,SAAS,SAAS,GAAG;AACvB,WAAO,QAAQ,OAAO,IAAI,MAAM,0DAA0D,CAAC;AAAA,EAC7F;AAEA,QAAM,UAAU,SAAS,CAAC;AAC1B,oBAAkB,OAAO;AACzB,QAAM,cAAc,MAAM,OAAO,CAAC,SAAyB,OAAO,SAAS,QAAQ;AACnF,QAAM,cAAc,cAAc,WAAW;AAC7C,QAAM,mBAAmB,oBAAoB;AAG7C,QAAM,cAAc,GAAG,WAAW,IAAI,QAAQ,YAAY,KAAK,GAAG,CAAC;AACnE,MAAI,YAAY,UAAU,kBAAkB;AAC1C,WAAO,WAAW,aAAa,OAAO;AAAA,EACxC;AAGA,QAAM,UAAsB,CAAC;AAC7B,MAAI,eAAyB,CAAC;AAE9B,aAAW,OAAO,QAAQ,aAAa;AACrC,UAAM,YAAY,GAAG,WAAW,IAAI,CAAC,GAAG,cAAc,GAAG,EAAE,KAAK,GAAG,CAAC;AACpE,QAAI,UAAU,SAAS,kBAAkB;AACvC,UAAI,aAAa,WAAW,GAAG;AAC7B,eAAO,QAAQ;AAAA,UACb,IAAI;AAAA,YACF,yDAAyD,OAAO,IAAI,MAAM,CAAC,kCACzE,OAAO,YAAY,MAAM,CAC3B,2CAA2C,OAAO,gBAAgB,CAAC;AAAA,UACrE;AAAA,QACF;AAAA,MACF;AACA,cAAQ,KAAK,YAAY;AACzB,qBAAe,CAAC,GAAG;AAAA,IACrB,OAAO;AACL,mBAAa,KAAK,GAAG;AAAA,IACvB;AAAA,EACF;AAEA,MAAI,aAAa,SAAS,GAAG;AAE3B,YAAQ,KAAK,YAAY;AAAA,EAC3B;AAEA,SAAO,eAAe,aAAa,SAAS,OAAO;AACrD;AAQA,SAAS,UAAU,MAAoC;AACrD,SAAO,OAAO,SAAS,YAAY,iBAAiB;AACtD;",
  "names": []
}

@@ -3,10 +3,23 @@
3
3
  *
4
4
  * Format the source code.
5
5
  */
6
+ /**
7
+ * Parameters for the {@link format} function.
8
+ */
9
+ export interface FormatParams {
10
+ /**
11
+ * Optional file paths to format. If omitted, formats the entire project.
12
+ */
13
+ paths?: string[] | undefined;
14
+ /**
15
+ * Whether to rewrite the source code.
16
+ */
17
+ rewrite?: boolean | undefined;
18
+ }
6
19
  /**
7
20
  * Format the source code.
8
21
  *
9
- * @param rewrite - Whether to rewrite the source code.
22
+ * @param params - The {@link FormatParams}.
10
23
  * @returns A {@link Promise} that resolves when the source code has been formatted.
11
24
  */
12
- export declare function format(rewrite?: boolean): Promise<void>;
25
+ export declare function format(params?: FormatParams): Promise<void>;
@@ -19,19 +19,20 @@ 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 { existsSync } from "node:fs";
22
23
  import {
23
24
  getFolderName,
24
25
  join
25
26
  } from "../../path.mjs";
26
27
  import { assertNonNullable } from "../../type-guards.mjs";
27
- import { existsSync } from "../node-modules.mjs";
28
28
  import { ObsidianDevUtilsRepoPaths } from "../obsidian-dev-utils-repo-paths.mjs";
29
29
  import {
30
30
  execFromRoot,
31
31
  getRootFolder,
32
32
  resolvePathFromRootSafe
33
33
  } from "../root.mjs";
34
- async function format(rewrite = true) {
34
+ async function format(params) {
35
+ const { paths, rewrite = true } = params ?? {};
35
36
  const rootFolder = getRootFolder();
36
37
  assertNonNullable(rootFolder, "Root folder not found");
37
38
  let dprintJsonPath = resolvePathFromRootSafe(ObsidianDevUtilsRepoPaths.DprintJson);
@@ -44,9 +45,10 @@ async function format(rewrite = true) {
44
45
  throw new Error("dprint.json not found");
45
46
  }
46
47
  const command = rewrite ? "fmt" : "check";
47
- await execFromRoot(["npx", "dprint", command, "--config", dprintJsonPath, "**/*"]);
48
+ const targets = paths?.length ? paths : ["**/*"];
49
+ await execFromRoot(["npx", "dprint", command, "--config", dprintJsonPath, { batchedArgs: targets }]);
48
50
  }
49
51
  export {
50
52
  format
51
53
  };
52
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9mb3JtYXR0ZXJzL2RwcmludC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBGb3JtYXQgdGhlIHNvdXJjZSBjb2RlLlxuICovXG5cbmltcG9ydCB7XG4gIGdldEZvbGRlck5hbWUsXG4gIGpvaW5cbn0gZnJvbSAnLi4vLi4vcGF0aC50cyc7XG5pbXBvcnQgeyBhc3NlcnROb25OdWxsYWJsZSB9IGZyb20gJy4uLy4uL3R5cGUtZ3VhcmRzLnRzJztcbmltcG9ydCB7IGV4aXN0c1N5bmMgfSBmcm9tICcuLi9ub2RlLW1vZHVsZXMudHMnO1xuaW1wb3J0IHsgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocyB9IGZyb20gJy4uL29ic2lkaWFuLWRldi11dGlscy1yZXBvLXBhdGhzLnRzJztcbmltcG9ydCB7XG4gIGV4ZWNGcm9tUm9vdCxcbiAgZ2V0Um9vdEZvbGRlcixcbiAgcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmVcbn0gZnJvbSAnLi4vcm9vdC50cyc7XG5cbi8qKlxuICogRm9ybWF0IHRoZSBzb3VyY2UgY29kZS5cbiAqXG4gKiBAcGFyYW0gcmV3cml0ZSAtIFdoZXRoZXIgdG8gcmV3cml0ZSB0aGUgc291cmNlIGNvZGUuXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIHNvdXJjZSBjb2RlIGhhcyBiZWVuIGZvcm1hdHRlZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGZvcm1hdChyZXdyaXRlID0gdHJ1ZSk6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCByb290Rm9sZGVyID0gZ2V0Um9vdEZvbGRlcigpO1xuICBhc3NlcnROb25OdWxsYWJsZShyb290Rm9sZGVyLCAnUm9vdCBmb2xkZXIgbm90IGZvdW5kJyk7XG4gIGxldCBkcHJpbnRKc29uUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRHByaW50SnNvbik7XG4gIGlmICghZXhpc3RzU3luYyhkcHJpbnRKc29uUGF0aCkpIHtcbiAgICBjb25zdCBwYWNrYWdlRm9sZGVyID0gZ2V0Um9vdEZvbGRlcihnZXRGb2xkZXJOYW1lKGltcG9ydC5tZXRhLnVybCkpO1xuICAgIGFzc2VydE5vbk51bGxhYmxlKHBhY2thZ2VGb2xkZXIsICdDb3VsZCBub3QgZmluZCBwYWNrYWdlIGZvbGRlci4nKTtcbiAgICBkcHJpbnRKc29uUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRwcmludEpzb24pLCBwYWNrYWdlRm9sZGVyKTtcbiAgfVxuXG4gIGlmICghZXhpc3RzU3luYyhkcHJpbnRKc29uUGF0aCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2RwcmludC5qc29uIG5vdCBmb3VuZCcpO1xuICB9XG5cbiAgY29uc3QgY29tbWFuZCA9IHJld3JpdGUgPyAnZm10JyA6ICdjaGVjayc7XG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ25weCcsICdkcHJpbnQnLCBjb21tYW5kLCAnLS1jb25maWcnLCBkcHJpbnRKc29uUGF0aCwgJyoqLyonXSk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFNQTtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQUNQLFNBQVMseUJBQXlCO0FBQ2xDLFNBQVMsa0JBQWtCO0FBQzNCLFNBQVMsaUNBQWlDO0FBQzFDO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsT0FDSztBQVFQLGVBQXNCLE9BQU8sVUFBVSxNQUFxQjtBQUMxRCxRQUFNLGFBQWEsY0FBYztBQUNqQyxvQkFBa0IsWUFBWSx1QkFBdUI7QUFDckQsTUFBSSxpQkFBaUIsd0JBQXdCLDBCQUEwQixVQUFVO0FBQ2pGLE1BQUksQ0FBQyxXQUFXLGNBQWMsR0FBRztBQUMvQixVQUFNLGdCQUFnQixjQUFjLGNBQWMsWUFBWSxHQUFHLENBQUM7QUFDbEUsc0JBQWtCLGVBQWUsZ0NBQWdDO0FBQ2pFLHFCQUFpQix3QkFBd0IsS0FBSywwQkFBMEIsTUFBTSwwQkFBMEIsVUFBVSxHQUFHLGFBQWE7QUFBQSxFQUNwSTtBQUVBLE1BQUksQ0FBQyxXQUFXLGNBQWMsR0FBRztBQUMvQixVQUFNLElBQUksTUFBTSx1QkFBdUI7QUFBQSxFQUN6QztBQUVBLFFBQU0sVUFBVSxVQUFVLFFBQVE7QUFDbEMsUUFBTSxhQUFhLENBQUMsT0FBTyxVQUFVLFNBQVMsWUFBWSxnQkFBZ0IsTUFBTSxDQUFDO0FBQ25GOyIsCiAgIm5hbWVzIjogW10KfQo=
54
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9mb3JtYXR0ZXJzL2RwcmludC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBGb3JtYXQgdGhlIHNvdXJjZSBjb2RlLlxuICovXG5cbmltcG9ydCB7IGV4aXN0c1N5bmMgfSBmcm9tICdub2RlOmZzJztcblxuaW1wb3J0IHtcbiAgZ2V0Rm9sZGVyTmFtZSxcbiAgam9pblxufSBmcm9tICcuLi8uLi9wYXRoLnRzJztcbmltcG9ydCB7IGFzc2VydE5vbk51bGxhYmxlIH0gZnJvbSAnLi4vLi4vdHlwZS1ndWFyZHMudHMnO1xuaW1wb3J0IHsgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocyB9IGZyb20gJy4uL29ic2lkaWFuLWRldi11dGlscy1yZXBvLXBhdGhzLnRzJztcbmltcG9ydCB7XG4gIGV4ZWNGcm9tUm9vdCxcbiAgZ2V0Um9vdEZvbGRlcixcbiAgcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmVcbn0gZnJvbSAnLi4vcm9vdC50cyc7XG5cbi8qKlxuICogUGFyYW1ldGVycyBmb3IgdGhlIHtAbGluayBmb3JtYXR9IGZ1bmN0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZvcm1hdFBhcmFtcyB7XG4gIC8qKlxuICAgKiBPcHRpb25hbCBmaWxlIHBhdGhzIHRvIGZvcm1hdC4gSWYgb21pdHRlZCwgZm9ybWF0cyB0aGUgZW50aXJlIHByb2plY3QuXG4gICAqL1xuICBwYXRocz86IHN0cmluZ1tdIHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIHJld3JpdGUgdGhlIHNvdXJjZSBjb2RlLlxuICAgKi9cbiAgcmV3cml0ZT86IGJvb2xlYW4gfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogRm9ybWF0IHRoZSBzb3VyY2UgY29kZS5cbiAqXG4gKiBAcGFyYW0gcGFyYW1zIC0gVGhlIHtAbGluayBGb3JtYXRQYXJhbXN9LlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBzb3VyY2UgY29kZSBoYXMgYmVlbiBmb3JtYXR0ZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBmb3JtYXQocGFyYW1zPzogRm9ybWF0UGFyYW1zKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHsgcGF0aHMsIHJld3JpdGUgPSB0cnVlIH0gPSBwYXJhbXMgPz8ge307XG4gIGNvbnN0IHJvb3RGb2xkZXIgPSBnZXRSb290Rm9sZGVyKCk7XG4gIGFzc2VydE5vbk51bGxhYmxlKHJvb3RGb2xkZXIsICdSb290IGZvbGRlciBub3QgZm91bmQnKTtcbiAgbGV0IGRwcmludEpzb25QYXRoID0gcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmUoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EcHJpbnRKc29uKTtcbiAgaWYgKCFleGlzdHNTeW5jKGRwcmludEpzb25QYXRoKSkge1xuICAgIGNvbnN0IHBhY2thZ2VGb2xkZXIgPSBnZXRSb290Rm9sZGVyKGdldEZvbGRlck5hbWUoaW1wb3J0Lm1ldGEudXJsKSk7XG4gICAgYXNzZXJ0Tm9uTnVsbGFibGUocGFja2FnZUZvbGRlciwgJ0NvdWxkIG5vdCBmaW5kIHBhY2thZ2UgZm9sZGVyLicpO1xuICAgIGRwcmludEpzb25QYXRoID0gcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmUoam9pbihPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRpc3QsIE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRHByaW50SnNvbiksIHBhY2thZ2VGb2xkZXIpO1xuICB9XG5cbiAgaWYgKCFleGlzdHNTeW5jKGRwcmludEpzb25QYXRoKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignZHByaW50Lmpzb24gbm90IGZvdW5kJyk7XG4gIH1cblxuICBjb25zdCBjb21tYW5kID0gcmV3cml0ZSA/ICdmbXQnIDogJ2NoZWNrJztcbiAgLyogdjggaWdub3JlIHN0YXJ0IC0tIFRoZSBwYXRocy1wcm92aWRlZCBicmFuY2ggaXMgb25seSBleGVyY2lzZWQgYnkgY29uc3VtZXIgcHJvamVjdHMgcGFzc2luZyBmaWxlIGxpc3RzLiAqL1xuICBjb25zdCB0YXJnZXRzID0gcGF0aHM/Lmxlbmd0aCA/IHBhdGhzIDogWycqKi8qJ107XG4gIC8qIHY4IGlnbm9yZSBzdG9wICovXG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ25weCcsICdkcHJpbnQnLCBjb21tYW5kLCAnLS1jb25maWcnLCBkcHJpbnRKc29uUGF0aCwgeyBiYXRjaGVkQXJnczogdGFyZ2V0cyB9XSk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFNQSxTQUFTLGtCQUFrQjtBQUUzQjtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQUNQLFNBQVMseUJBQXlCO0FBQ2xDLFNBQVMsaUNBQWlDO0FBQzFDO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsT0FDSztBQXVCUCxlQUFzQixPQUFPLFFBQXNDO0FBQ2pFLFFBQU0sRUFBRSxPQUFPLFVBQVUsS0FBSyxJQUFJLFVBQVUsQ0FBQztBQUM3QyxRQUFNLGFBQWEsY0FBYztBQUNqQyxvQkFBa0IsWUFBWSx1QkFBdUI7QUFDckQsTUFBSSxpQkFBaUIsd0JBQXdCLDBCQUEwQixVQUFVO0FBQ2pGLE1BQUksQ0FBQyxXQUFXLGNBQWMsR0FBRztBQUMvQixVQUFNLGdCQUFnQixjQUFjLGNBQWMsWUFBWSxHQUFHLENBQUM7QUFDbEUsc0JBQWtCLGVBQWUsZ0NBQWdDO0FBQ2pFLHFCQUFpQix3QkFBd0IsS0FBSywwQkFBMEIsTUFBTSwwQkFBMEIsVUFBVSxHQUFHLGFBQWE7QUFBQSxFQUNwSTtBQUVBLE1BQUksQ0FBQyxXQUFXLGNBQWMsR0FBRztBQUMvQixVQUFNLElBQUksTUFBTSx1QkFBdUI7QUFBQSxFQUN6QztBQUVBLFFBQU0sVUFBVSxVQUFVLFFBQVE7QUFFbEMsUUFBTSxVQUFVLE9BQU8sU0FBUyxRQUFRLENBQUMsTUFBTTtBQUUvQyxRQUFNLGFBQWEsQ0FBQyxPQUFPLFVBQVUsU0FBUyxZQUFZLGdCQUFnQixFQUFFLGFBQWEsUUFBUSxDQUFDLENBQUM7QUFDckc7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -3,7 +3,7 @@
3
3
  *
4
4
  * Contains utility functions for file system operations.
5
5
  */
6
- import type { Dirent, ObjectEncodingOptions, PathLike } from './node-modules.mjs';
6
+ import type { Dirent, ObjectEncodingOptions, PathLike } from 'node:fs';
7
7
  /**
8
8
  * Options for controlling the format of the result when returning buffers.
9
9
  *
@@ -19,11 +19,12 @@ 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 { readdir } from "node:fs/promises";
22
23
  import {
23
24
  toPosixBuffer,
24
25
  toPosixPath
25
26
  } from "../path.mjs";
26
- import { readdir } from "./node-modules.mjs";
27
+ import { assertNonNullable } from "../type-guards.mjs";
27
28
  async function readdirPosix(path, options = {}) {
28
29
  if (isStringResultOptions(options)) {
29
30
  const paths = await readdir(path, options);
@@ -41,9 +42,7 @@ async function readdirPosix(path, options = {}) {
41
42
  return dirents;
42
43
  }
43
44
  function isBufferResultOptions(options) {
44
- if (options === void 0) {
45
- return false;
46
- }
45
+ assertNonNullable(options);
47
46
  if (options === "buffer") {
48
47
  return true;
49
48
  }
@@ -57,9 +56,7 @@ function isBufferResultOptions(options) {
57
56
  return true;
58
57
  }
59
58
  function isStringResultOptions(options) {
60
- if (options === void 0) {
61
- return true;
62
- }
59
+ assertNonNullable(options);
63
60
  if (options === "buffer") {
64
61
  return false;
65
62
  }
@@ -75,4 +72,4 @@ function isStringResultOptions(options) {
75
72
  export {
76
73
  readdirPosix
77
74
  };
78
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/fs.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for file system operations.\n */\n\nimport type {\n  Dirent,\n  ObjectEncodingOptions,\n  PathLike\n} from './node-modules.ts';\n\nimport {\n  toPosixBuffer,\n  toPosixPath\n} from '../path.ts';\nimport { readdir } from './node-modules.ts';\n\n/**\n * Options for controlling the format of the result when returning buffers.\n *\n * `directory` is used instead of `folder` to preserve compatibility with `node:fs` module.\n */\nexport type BufferResultOptions = 'buffer' | {\n  /**\n   * Should be set to \"buffer\" to return buffers.\n   */\n  readonly encoding: 'buffer';\n\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  readonly recursive?: boolean;\n\n  /**\n   * Should be set to `false` to return buffers.\n   */\n  readonly withFileTypes?: false;\n};\n\n/**\n * Options for controlling the format of the result when returning Dirent objects.\n */\nexport type DirentResultOptions = {\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  readonly recursive?: boolean;\n\n  /**\n   * Should be set to `true` to return Dirent objects.\n   */\n  readonly withFileTypes: true;\n} & ObjectEncodingOptions;\n\n/**\n * Options for controlling the format of the result when returning strings.\n */\nexport type StringResultOptions =\n  | {\n    /**\n     * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n     */\n    readonly recursive?: boolean;\n\n    /**\n     * Should be set to `false` to return strings.\n     */\n    readonly withFileTypes?: false;\n  } & ObjectEncodingOptions\n  | undefined;\n\n/**\n * Common options for controlling the format of the result.\n */\ninterface CommonOptions {\n  /**\n   * Encoding to use when returning strings.\n   */\n  readonly encoding?: 'buffer' | NodeJS.BufferEncoding;\n\n  /**\n   * Set `true` to return Dirent objects or `false` to return strings or buffers.\n   */\n  readonly withFileTypes?: boolean;\n}\n\n/**\n * Reads the contents of a directory and returns an array of strings with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. If not provided, returns strings.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths.\n */\nexport async function readdirPosix(path: PathLike, options?: StringResultOptions): Promise<string[]>;\n/**\n * Reads the contents of a directory and returns an array of buffers with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify \"buffer\" to return buffers.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted buffers.\n */\nexport async function readdirPosix(path: PathLike, options: BufferResultOptions): Promise<Buffer[]>;\n/**\n * Reads the contents of a directory and returns an array of Dirent objects with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify `withFileTypes: true` to return Dirent objects.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted Dirent objects.\n */\nexport async function readdirPosix(path: PathLike, options: DirentResultOptions): Promise<Dirent[]>;\n/**\n * Reads the contents of a directory and converts file paths or buffer results to POSIX format.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths, buffers, or Dirent objects.\n */\nexport async function readdirPosix(\n  path: PathLike,\n  options: BufferResultOptions | DirentResultOptions | StringResultOptions = {}\n): Promise<Buffer[] | Dirent[] | string[]> {\n  if (isStringResultOptions(options)) {\n    const paths = await readdir(path, options);\n    return paths.map(toPosixPath);\n  }\n\n  if (isBufferResultOptions(options)) {\n    const buffers = await readdir(path, options);\n    return buffers.map(toPosixBuffer);\n  }\n\n  const dirents = await readdir(path, options);\n  for (const dirent of dirents) {\n    dirent.name = toPosixPath(dirent.name);\n    dirent.parentPath = toPosixPath(dirent.parentPath);\n  }\n\n  return dirents;\n}\n\n/**\n * Type guard to check if the options are for returning buffers.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning buffers, otherwise `false`.\n */\nfunction isBufferResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is BufferResultOptions {\n  /* v8 ignore start -- Dead code: readdirPosix defaults options to {}, so undefined never reaches here. */\n  if (options === undefined) {\n    return false;\n  }\n  /* v8 ignore stop */\n\n  if (options === 'buffer') {\n    return true;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  /* v8 ignore start -- Dead code: isStringResultOptions already handles non-buffer encoding before this is called. */\n  if (commonOptions.encoding !== 'buffer') {\n    return false;\n  }\n  /* v8 ignore stop */\n\n  return true;\n}\n\n/**\n * Type guard to check if the options are for returning strings.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning strings, otherwise `false`.\n */\nfunction isStringResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is StringResultOptions {\n  /* v8 ignore start -- Dead code: readdirPosix defaults options to {}, so undefined never reaches here. */\n  if (options === undefined) {\n    return true;\n  }\n  /* v8 ignore stop */\n\n  if (options === 'buffer') {\n    return false;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.encoding === 'buffer') {\n    return false;\n  }\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  return true;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAYA;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,eAAe;AAsGxB,eAAsB,aACpB,MACA,UAA2E,CAAC,GACnC;AACzC,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,QAAQ,MAAM,QAAQ,MAAM,OAAO;AACzC,WAAO,MAAM,IAAI,WAAW;AAAA,EAC9B;AAEA,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,UAAU,MAAM,QAAQ,MAAM,OAAO;AAC3C,WAAO,QAAQ,IAAI,aAAa;AAAA,EAClC;AAEA,QAAM,UAAU,MAAM,QAAQ,MAAM,OAAO;AAC3C,aAAW,UAAU,SAAS;AAC5B,WAAO,OAAO,YAAY,OAAO,IAAI;AACrC,WAAO,aAAa,YAAY,OAAO,UAAU;AAAA,EACnD;AAEA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AAEvI,MAAI,YAAY,QAAW;AACzB,WAAO;AAAA,EACT;AAGA,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAGA,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAGA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AAEvI,MAAI,YAAY,QAAW;AACzB,WAAO;AAAA,EACT;AAGA,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAEA,SAAO;AACT;",
  "names": []
}

75
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/script-utils/fs.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for file system operations.\n */\n\nimport type {\n  Dirent,\n  ObjectEncodingOptions,\n  PathLike\n} from 'node:fs';\n\nimport { readdir } from 'node:fs/promises';\n\nimport {\n  toPosixBuffer,\n  toPosixPath\n} from '../path.ts';\nimport { assertNonNullable } from '../type-guards.ts';\n\n/**\n * Options for controlling the format of the result when returning buffers.\n *\n * `directory` is used instead of `folder` to preserve compatibility with `node:fs` module.\n */\nexport type BufferResultOptions = 'buffer' | {\n  /**\n   * Should be set to \"buffer\" to return buffers.\n   */\n  readonly encoding: 'buffer';\n\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  readonly recursive?: boolean;\n\n  /**\n   * Should be set to `false` to return buffers.\n   */\n  readonly withFileTypes?: false;\n};\n\n/**\n * Options for controlling the format of the result when returning Dirent objects.\n */\nexport type DirentResultOptions = {\n  /**\n   * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n   */\n  readonly recursive?: boolean;\n\n  /**\n   * Should be set to `true` to return Dirent objects.\n   */\n  readonly withFileTypes: true;\n} & ObjectEncodingOptions;\n\n/**\n * Options for controlling the format of the result when returning strings.\n */\nexport type StringResultOptions =\n  | {\n    /**\n     * Whether to include subdirectories when reading the directory. If not provided, defaults to `false`.\n     */\n    readonly recursive?: boolean;\n\n    /**\n     * Should be set to `false` to return strings.\n     */\n    readonly withFileTypes?: false;\n  } & ObjectEncodingOptions\n  | undefined;\n\n/**\n * Common options for controlling the format of the result.\n */\ninterface CommonOptions {\n  /**\n   * Encoding to use when returning strings.\n   */\n  readonly encoding?: 'buffer' | NodeJS.BufferEncoding;\n\n  /**\n   * Set `true` to return Dirent objects or `false` to return strings or buffers.\n   */\n  readonly withFileTypes?: boolean;\n}\n\n/**\n * Reads the contents of a directory and returns an array of strings with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. If not provided, returns strings.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths.\n */\nexport async function readdirPosix(path: PathLike, options?: StringResultOptions): Promise<string[]>;\n/**\n * Reads the contents of a directory and returns an array of buffers with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify \"buffer\" to return buffers.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted buffers.\n */\nexport async function readdirPosix(path: PathLike, options: BufferResultOptions): Promise<Buffer[]>;\n/**\n * Reads the contents of a directory and returns an array of Dirent objects with POSIX paths.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result. Specify `withFileTypes: true` to return Dirent objects.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted Dirent objects.\n */\nexport async function readdirPosix(path: PathLike, options: DirentResultOptions): Promise<Dirent[]>;\n/**\n * Reads the contents of a directory and converts file paths or buffer results to POSIX format.\n *\n * @param path - The path to the directory.\n * @param options - Options to control the format of the result.\n * @returns A {@link Promise} that resolves with an array of POSIX-formatted file paths, buffers, or Dirent objects.\n */\nexport async function readdirPosix(\n  path: PathLike,\n  options: BufferResultOptions | DirentResultOptions | StringResultOptions = {}\n): Promise<Buffer[] | Dirent[] | string[]> {\n  if (isStringResultOptions(options)) {\n    const paths = await readdir(path, options);\n    return paths.map(toPosixPath);\n  }\n\n  if (isBufferResultOptions(options)) {\n    const buffers = await readdir(path, options);\n    return buffers.map(toPosixBuffer);\n  }\n\n  const dirents = await readdir(path, options);\n  for (const dirent of dirents) {\n    dirent.name = toPosixPath(dirent.name);\n    dirent.parentPath = toPosixPath(dirent.parentPath);\n  }\n\n  return dirents;\n}\n\n/**\n * Type guard to check if the options are for returning buffers.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning buffers, otherwise `false`.\n */\nfunction isBufferResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is BufferResultOptions {\n  assertNonNullable(options);\n\n  if (options === 'buffer') {\n    return true;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  /* v8 ignore start -- Dead code: isStringResultOptions already handles non-buffer encoding before this is called. */\n  if (commonOptions.encoding !== 'buffer') {\n    return false;\n  }\n  /* v8 ignore stop */\n\n  return true;\n}\n\n/**\n * Type guard to check if the options are for returning strings.\n *\n * @param options - The options to check.\n * @returns `true` if the options are for returning strings, otherwise `false`.\n */\nfunction isStringResultOptions(options: BufferResultOptions | DirentResultOptions | StringResultOptions): options is StringResultOptions {\n  assertNonNullable(options);\n\n  if (options === 'buffer') {\n    return false;\n  }\n\n  const commonOptions = options as CommonOptions;\n\n  if (commonOptions.encoding === 'buffer') {\n    return false;\n  }\n\n  if (commonOptions.withFileTypes === true) {\n    return false;\n  }\n\n  return true;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAYA,SAAS,eAAe;AAExB;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,yBAAyB;AAsGlC,eAAsB,aACpB,MACA,UAA2E,CAAC,GACnC;AACzC,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,QAAQ,MAAM,QAAQ,MAAM,OAAO;AACzC,WAAO,MAAM,IAAI,WAAW;AAAA,EAC9B;AAEA,MAAI,sBAAsB,OAAO,GAAG;AAClC,UAAM,UAAU,MAAM,QAAQ,MAAM,OAAO;AAC3C,WAAO,QAAQ,IAAI,aAAa;AAAA,EAClC;AAEA,QAAM,UAAU,MAAM,QAAQ,MAAM,OAAO;AAC3C,aAAW,UAAU,SAAS;AAC5B,WAAO,OAAO,YAAY,OAAO,IAAI;AACrC,WAAO,aAAa,YAAY,OAAO,UAAU;AAAA,EACnD;AAEA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,oBAAkB,OAAO;AAEzB,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAGA,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAGA,SAAO;AACT;AAQA,SAAS,sBAAsB,SAA0G;AACvI,oBAAkB,OAAO;AAEzB,MAAI,YAAY,UAAU;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB;AAEtB,MAAI,cAAc,aAAa,UAAU;AACvC,WAAO;AAAA,EACT;AAEA,MAAI,cAAc,kBAAkB,MAAM;AACxC,WAAO;AAAA,EACT;AAEA,SAAO;AACT;",
  "names": []
}

@@ -2,12 +2,13 @@ export * as build from './build.mjs';
2
2
  export * as bundlers from './bundlers/index.mjs';
3
3
  export * as cli_utils from './cli-utils.mjs';
4
4
  export * as code_generator from './code-generator.mjs';
5
+ export * as commitlint_config from './commitlint-config.mjs';
5
6
  export * as exec from './exec.mjs';
6
7
  export * as formatters from './formatters/index.mjs';
7
8
  export * as fs from './fs.mjs';
8
9
  export * as json from './json.mjs';
9
10
  export * as linters from './linters/index.mjs';
10
- export * as node_modules from './node-modules.mjs';
11
+ export * as nano_staged_config from './nano-staged-config.mjs';
11
12
  export * as npm_publish from './npm-publish.mjs';
12
13
  export * as npm_run from './npm-run.mjs';
13
14
  export * as npm from './npm.mjs';
@@ -23,12 +23,13 @@ import * as build from "./build.mjs";
23
23
  import * as bundlers from "./bundlers/index.mjs";
24
24
  import * as cli_utils from "./cli-utils.mjs";
25
25
  import * as code_generator from "./code-generator.mjs";
26
+ import * as commitlint_config from "./commitlint-config.mjs";
26
27
  import * as exec from "./exec.mjs";
27
28
  import * as formatters from "./formatters/index.mjs";
28
29
  import * as fs from "./fs.mjs";
29
30
  import * as json from "./json.mjs";
30
31
  import * as linters from "./linters/index.mjs";
31
- import * as node_modules from "./node-modules.mjs";
32
+ import * as nano_staged_config from "./nano-staged-config.mjs";
32
33
  import * as npm_publish from "./npm-publish.mjs";
33
34
  import * as npm_run from "./npm-run.mjs";
34
35
  import * as npm from "./npm.mjs";
@@ -42,12 +43,13 @@ export {
42
43
  bundlers,
43
44
  cli_utils,
44
45
  code_generator,
46
+ commitlint_config,
45
47
  exec,
46
48
  formatters,
47
49
  fs,
48
50
  json,
49
51
  linters,
50
- node_modules,
52
+ nano_staged_config,
51
53
  npm,
52
54
  npm_publish,
53
55
  npm_run,
@@ -57,4 +59,4 @@ export {
57
59
  test_runners,
58
60
  version
59
61
  };
60
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovXG5cbmV4cG9ydCAqIGFzIGJ1aWxkIGZyb20gJy4vYnVpbGQudHMnO1xuZXhwb3J0ICogYXMgYnVuZGxlcnMgZnJvbSAnLi9idW5kbGVycy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBjbGlfdXRpbHMgZnJvbSAnLi9jbGktdXRpbHMudHMnO1xuZXhwb3J0ICogYXMgY29kZV9nZW5lcmF0b3IgZnJvbSAnLi9jb2RlLWdlbmVyYXRvci50cyc7XG5leHBvcnQgKiBhcyBleGVjIGZyb20gJy4vZXhlYy50cyc7XG5leHBvcnQgKiBhcyBmb3JtYXR0ZXJzIGZyb20gJy4vZm9ybWF0dGVycy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBmcyBmcm9tICcuL2ZzLnRzJztcbmV4cG9ydCAqIGFzIGpzb24gZnJvbSAnLi9qc29uLnRzJztcbmV4cG9ydCAqIGFzIGxpbnRlcnMgZnJvbSAnLi9saW50ZXJzL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIG5vZGVfbW9kdWxlcyBmcm9tICcuL25vZGUtbW9kdWxlcy50cyc7XG5leHBvcnQgKiBhcyBucG1fcHVibGlzaCBmcm9tICcuL25wbS1wdWJsaXNoLnRzJztcbmV4cG9ydCAqIGFzIG5wbV9ydW4gZnJvbSAnLi9ucG0tcnVuLnRzJztcbmV4cG9ydCAqIGFzIG5wbSBmcm9tICcuL25wbS50cyc7XG5leHBvcnQgKiBhcyBvYnNpZGlhbl9jbGkgZnJvbSAnLi9vYnNpZGlhbi1jbGkudHMnO1xuZXhwb3J0ICogYXMgb2JzaWRpYW5fZGV2X3V0aWxzX3JlcG9fcGF0aHMgZnJvbSAnLi9vYnNpZGlhbi1kZXYtdXRpbHMtcmVwby1wYXRocy50cyc7XG5leHBvcnQgKiBhcyByb290IGZyb20gJy4vcm9vdC50cyc7XG5leHBvcnQgKiBhcyB0ZXN0X3J1bm5lcnMgZnJvbSAnLi90ZXN0LXJ1bm5lcnMvaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgdmVyc2lvbiBmcm9tICcuL3ZlcnNpb24udHMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsWUFBWSxXQUFXO0FBQ3ZCLFlBQVksY0FBYztBQUMxQixZQUFZLGVBQWU7QUFDM0IsWUFBWSxvQkFBb0I7QUFDaEMsWUFBWSxVQUFVO0FBQ3RCLFlBQVksZ0JBQWdCO0FBQzVCLFlBQVksUUFBUTtBQUNwQixZQUFZLFVBQVU7QUFDdEIsWUFBWSxhQUFhO0FBQ3pCLFlBQVksa0JBQWtCO0FBQzlCLFlBQVksaUJBQWlCO0FBQzdCLFlBQVksYUFBYTtBQUN6QixZQUFZLFNBQVM7QUFDckIsWUFBWSxrQkFBa0I7QUFDOUIsWUFBWSxtQ0FBbUM7QUFDL0MsWUFBWSxVQUFVO0FBQ3RCLFlBQVksa0JBQWtCO0FBQzlCLFlBQVksYUFBYTsiLAogICJuYW1lcyI6IFtdCn0K
62
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovXG5cbmV4cG9ydCAqIGFzIGJ1aWxkIGZyb20gJy4vYnVpbGQudHMnO1xuZXhwb3J0ICogYXMgYnVuZGxlcnMgZnJvbSAnLi9idW5kbGVycy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBjbGlfdXRpbHMgZnJvbSAnLi9jbGktdXRpbHMudHMnO1xuZXhwb3J0ICogYXMgY29kZV9nZW5lcmF0b3IgZnJvbSAnLi9jb2RlLWdlbmVyYXRvci50cyc7XG5leHBvcnQgKiBhcyBjb21taXRsaW50X2NvbmZpZyBmcm9tICcuL2NvbW1pdGxpbnQtY29uZmlnLnRzJztcbmV4cG9ydCAqIGFzIGV4ZWMgZnJvbSAnLi9leGVjLnRzJztcbmV4cG9ydCAqIGFzIGZvcm1hdHRlcnMgZnJvbSAnLi9mb3JtYXR0ZXJzL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIGZzIGZyb20gJy4vZnMudHMnO1xuZXhwb3J0ICogYXMganNvbiBmcm9tICcuL2pzb24udHMnO1xuZXhwb3J0ICogYXMgbGludGVycyBmcm9tICcuL2xpbnRlcnMvaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgbmFub19zdGFnZWRfY29uZmlnIGZyb20gJy4vbmFuby1zdGFnZWQtY29uZmlnLnRzJztcbmV4cG9ydCAqIGFzIG5wbV9wdWJsaXNoIGZyb20gJy4vbnBtLXB1Ymxpc2gudHMnO1xuZXhwb3J0ICogYXMgbnBtX3J1biBmcm9tICcuL25wbS1ydW4udHMnO1xuZXhwb3J0ICogYXMgbnBtIGZyb20gJy4vbnBtLnRzJztcbmV4cG9ydCAqIGFzIG9ic2lkaWFuX2NsaSBmcm9tICcuL29ic2lkaWFuLWNsaS50cyc7XG5leHBvcnQgKiBhcyBvYnNpZGlhbl9kZXZfdXRpbHNfcmVwb19wYXRocyBmcm9tICcuL29ic2lkaWFuLWRldi11dGlscy1yZXBvLXBhdGhzLnRzJztcbmV4cG9ydCAqIGFzIHJvb3QgZnJvbSAnLi9yb290LnRzJztcbmV4cG9ydCAqIGFzIHRlc3RfcnVubmVycyBmcm9tICcuL3Rlc3QtcnVubmVycy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyB2ZXJzaW9uIGZyb20gJy4vdmVyc2lvbi50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxZQUFZLFdBQVc7QUFDdkIsWUFBWSxjQUFjO0FBQzFCLFlBQVksZUFBZTtBQUMzQixZQUFZLG9CQUFvQjtBQUNoQyxZQUFZLHVCQUF1QjtBQUNuQyxZQUFZLFVBQVU7QUFDdEIsWUFBWSxnQkFBZ0I7QUFDNUIsWUFBWSxRQUFRO0FBQ3BCLFlBQVksVUFBVTtBQUN0QixZQUFZLGFBQWE7QUFDekIsWUFBWSx3QkFBd0I7QUFDcEMsWUFBWSxpQkFBaUI7QUFDN0IsWUFBWSxhQUFhO0FBQ3pCLFlBQVksU0FBUztBQUNyQixZQUFZLGtCQUFrQjtBQUM5QixZQUFZLG1DQUFtQztBQUMvQyxZQUFZLFVBQVU7QUFDdEIsWUFBWSxrQkFBa0I7QUFDOUIsWUFBWSxhQUFhOyIsCiAgIm5hbWVzIjogW10KfQo=