obsidian-dev-utils 2.16.0 → 2.17.1

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 (120) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/dist/lib/@types/compare-versions.d.ts +1 -1
  3. package/dist/lib/@types.cjs +1 -1
  4. package/dist/lib/@types.d.ts +5 -5
  5. package/dist/lib/Async.cjs +1 -1
  6. package/dist/lib/Async.d.ts +12 -12
  7. package/dist/lib/Blob.cjs +1 -1
  8. package/dist/lib/Blob.d.ts +1 -1
  9. package/dist/lib/CodeGenerator.cjs +1 -1
  10. package/dist/lib/CodeGenerator.d.ts +1 -1
  11. package/dist/lib/DocumentFragment.cjs +1 -1
  12. package/dist/lib/DocumentFragment.d.ts +1 -1
  13. package/dist/lib/Error.cjs +1 -1
  14. package/dist/lib/Error.d.ts +1 -1
  15. package/dist/lib/Fs.cjs +1 -1
  16. package/dist/lib/Fs.d.ts +1 -1
  17. package/dist/lib/JSON.cjs +10 -8
  18. package/dist/lib/JSON.d.ts +28 -14
  19. package/dist/lib/Npm.cjs +11 -9
  20. package/dist/lib/Npm.d.ts +19 -13
  21. package/dist/lib/Object.cjs +1 -1
  22. package/dist/lib/Object.d.ts +3 -3
  23. package/dist/lib/Path.cjs +10 -10
  24. package/dist/lib/Path.d.ts +75 -10
  25. package/dist/lib/RegExp.cjs +1 -1
  26. package/dist/lib/RegExp.d.ts +1 -1
  27. package/dist/lib/Root.cjs +9 -8
  28. package/dist/lib/Root.d.ts +57 -24
  29. package/dist/lib/String.cjs +1 -1
  30. package/dist/lib/String.d.ts +2 -2
  31. package/dist/lib/ValueProvider.cjs +1 -1
  32. package/dist/lib/ValueProvider.d.ts +5 -5
  33. package/dist/lib/bin/ESLint/@types/@guardian__eslint-plugin-tsdoc-required.d.ts +10 -0
  34. package/dist/lib/bin/ESLint/@types/@stylistic__eslint-plugin.d.ts +1 -1
  35. package/dist/lib/bin/ESLint/@types/@typescript-eslint__eslint-plugin.d.ts +1 -1
  36. package/dist/lib/bin/ESLint/@types/@typescript-eslint__parser.d.ts +1 -1
  37. package/dist/lib/bin/ESLint/@types/eslint-plugin-deprecation.d.ts +1 -1
  38. package/dist/lib/bin/ESLint/@types/eslint-plugin-import.d.ts +1 -1
  39. package/dist/lib/bin/ESLint/@types/eslint-plugin-modules-newlines.d.ts +1 -1
  40. package/dist/lib/bin/ESLint/@types/eslint-plugin-verify-tsdoc.d.ts +10 -0
  41. package/dist/lib/bin/ESLint/@types/globals.d.ts +1 -1
  42. package/dist/lib/bin/ESLint/ESLint.cjs +11 -11
  43. package/dist/lib/bin/ESLint/ESLint.d.ts +7 -5
  44. package/dist/lib/bin/ESLint/eslint.config.cjs +1 -1
  45. package/dist/lib/bin/ESLint/eslint.config.d.ts +2 -4
  46. package/dist/lib/bin/ObsidianDevUtilsRepoPaths.cjs +1 -1
  47. package/dist/lib/bin/ObsidianDevUtilsRepoPaths.d.ts +1 -1
  48. package/dist/lib/bin/build.cjs +1 -1
  49. package/dist/lib/bin/build.d.ts +1 -1
  50. package/dist/lib/bin/cli.cjs +1 -1
  51. package/dist/lib/bin/cli.d.ts +1 -1
  52. package/dist/lib/bin/esbuild/Dependency.cjs +1 -1
  53. package/dist/lib/bin/esbuild/Dependency.d.ts +1 -1
  54. package/dist/lib/bin/esbuild/ObsidianPluginBuilder.cjs +7 -6
  55. package/dist/lib/bin/esbuild/ObsidianPluginBuilder.d.ts +21 -9
  56. package/dist/lib/bin/esbuild/copyToObsidianPluginsFolderPlugin.cjs +1 -1
  57. package/dist/lib/bin/esbuild/copyToObsidianPluginsFolderPlugin.d.ts +1 -1
  58. package/dist/lib/bin/esbuild/fixSourceMapsPlugin.cjs +1 -1
  59. package/dist/lib/bin/esbuild/fixSourceMapsPlugin.d.ts +1 -1
  60. package/dist/lib/bin/esbuild/lintPlugin.cjs +1 -1
  61. package/dist/lib/bin/esbuild/lintPlugin.d.ts +1 -1
  62. package/dist/lib/bin/esbuild/preprocessPlugin.cjs +1 -1
  63. package/dist/lib/bin/esbuild/preprocessPlugin.d.ts +2 -2
  64. package/dist/lib/bin/esbuild/renameToCjsPlugin.cjs +1 -1
  65. package/dist/lib/bin/esbuild/renameToCjsPlugin.d.ts +1 -1
  66. package/dist/lib/bin/spellcheck.cjs +1 -1
  67. package/dist/lib/bin/spellcheck.d.ts +1 -1
  68. package/dist/lib/bin/version.cjs +1 -1
  69. package/dist/lib/bin/version.d.ts +1 -1
  70. package/dist/lib/cli.cjs +2 -8
  71. package/dist/lib/cli.d.ts +2 -8
  72. package/dist/lib/obsidian/App.cjs +1 -1
  73. package/dist/lib/obsidian/App.d.ts +1 -1
  74. package/dist/lib/obsidian/AttachmentPath.cjs +1 -1
  75. package/dist/lib/obsidian/AttachmentPath.d.ts +1 -1
  76. package/dist/lib/obsidian/Backlink.cjs +15 -13
  77. package/dist/lib/obsidian/Backlink.d.ts +36 -16
  78. package/dist/lib/obsidian/Callout.cjs +9 -8
  79. package/dist/lib/obsidian/Callout.d.ts +26 -11
  80. package/dist/lib/obsidian/Dataview.cjs +28 -24
  81. package/dist/lib/obsidian/Dataview.d.ts +132 -79
  82. package/dist/lib/obsidian/DataviewLink.cjs +1 -1
  83. package/dist/lib/obsidian/DataviewLink.d.ts +7 -9
  84. package/dist/lib/obsidian/FrontMatter.cjs +1 -1
  85. package/dist/lib/obsidian/FrontMatter.d.ts +15 -18
  86. package/dist/lib/obsidian/Link.cjs +33 -30
  87. package/dist/lib/obsidian/Link.d.ts +93 -41
  88. package/dist/lib/obsidian/MarkdownCodeBlockProcessor.cjs +1 -1
  89. package/dist/lib/obsidian/MarkdownCodeBlockProcessor.d.ts +1 -1
  90. package/dist/lib/obsidian/MetadataCache.cjs +1 -1
  91. package/dist/lib/obsidian/MetadataCache.d.ts +11 -10
  92. package/dist/lib/obsidian/Modal/Alert.cjs +1 -1
  93. package/dist/lib/obsidian/Modal/Alert.d.ts +4 -4
  94. package/dist/lib/obsidian/Modal/Prompt.cjs +8 -7
  95. package/dist/lib/obsidian/Modal/Prompt.d.ts +26 -11
  96. package/dist/lib/obsidian/Modal/SelectItem.cjs +1 -1
  97. package/dist/lib/obsidian/Modal/SelectItem.d.ts +26 -11
  98. package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.cjs +1 -1
  99. package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.d.ts +1 -1
  100. package/dist/lib/obsidian/Plugin/Plugin.cjs +1 -1
  101. package/dist/lib/obsidian/Plugin/Plugin.d.ts +6 -6
  102. package/dist/lib/obsidian/Plugin/PluginBase.cjs +10 -11
  103. package/dist/lib/obsidian/Plugin/PluginBase.d.ts +14 -15
  104. package/dist/lib/obsidian/Plugin/PluginSettings.cjs +1 -1
  105. package/dist/lib/obsidian/Plugin/PluginSettings.d.ts +9 -9
  106. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.cjs +12 -19
  107. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.d.ts +27 -22
  108. package/dist/lib/obsidian/ResourceUrl.cjs +1 -1
  109. package/dist/lib/obsidian/ResourceUrl.d.ts +1 -1
  110. package/dist/lib/obsidian/TAbstractFile.cjs +1 -1
  111. package/dist/lib/obsidian/TAbstractFile.d.ts +4 -4
  112. package/dist/lib/obsidian/TFile.cjs +1 -1
  113. package/dist/lib/obsidian/TFile.d.ts +1 -1
  114. package/dist/lib/obsidian/TFolder.cjs +1 -1
  115. package/dist/lib/obsidian/TFolder.d.ts +11 -8
  116. package/dist/lib/obsidian/Vault.cjs +1 -1
  117. package/dist/lib/obsidian/Vault.d.ts +1 -1
  118. package/dist/lib/url.cjs +1 -1
  119. package/dist/lib/url.d.ts +1 -1
  120. package/package.json +7 -4
package/dist/lib/Npm.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @module Npm
2
+ * @packageDocumentation Npm
3
3
  * Contains utility functions for NPM package.json.
4
4
  */
5
5
  import type { MaybePromise } from "./Async.ts";
@@ -26,6 +26,9 @@ export interface NpmPackage {
26
26
  * The name of the package.
27
27
  */
28
28
  name: string;
29
+ /**
30
+ * An optional object that contains the package's peer dependencies, where the key is the package name
31
+ */
29
32
  packages?: Record<string, NpmPackage>;
30
33
  /**
31
34
  * The version of the package.
@@ -60,19 +63,27 @@ export declare function readNpmPackage(cwd?: string): Promise<NpmPackage>;
60
63
  * @returns A promise that resolves when the file has been written.
61
64
  */
62
65
  export declare function writeNpmPackage(npmPackage: NpmPackage, cwd?: string): Promise<void>;
66
+ /**
67
+ * Options for editing an NPM package.
68
+ */
69
+ type EditNpmPackageOptions = {
70
+ /**
71
+ * The current working directory where `package.json` is located.
72
+ */
73
+ cwd?: string | undefined;
74
+ /**
75
+ * If true, skips editing if the file does not exist.
76
+ */
77
+ skipIfMissing?: boolean | undefined;
78
+ };
63
79
  /**
64
80
  * Reads, edits, and writes back the `package.json` file using the provided edit function.
65
81
  *
66
82
  * @param editFn - The function to edit the parsed `NpmPackage` object.
67
83
  * @param options - Additional options for editing.
68
- * @param options.cwd - The current working directory where `package.json` is located.
69
- * @param options.skipIfMissing - If true, skips editing if the file does not exist.
70
84
  * @returns A promise that resolves when the file has been edited and written.
71
85
  */
72
- export declare function editNpmPackage(editFn: (npmPackage: NpmPackage) => MaybePromise<void>, { cwd, skipIfMissing }?: {
73
- cwd?: string | undefined;
74
- skipIfMissing?: boolean | undefined;
75
- }): Promise<void>;
86
+ export declare function editNpmPackage(editFn: (npmPackage: NpmPackage) => MaybePromise<void>, options?: EditNpmPackageOptions): Promise<void>;
76
87
  /**
77
88
  * Reads the `package-lock.json` file from the specified directory or from the root if no directory is specified.
78
89
  *
@@ -93,14 +104,9 @@ export declare function writeNpmPackageLock(npmPackage: NpmPackage, cwd?: string
93
104
  *
94
105
  * @param editFn - The function to edit the parsed `NpmPackage` object.
95
106
  * @param options - Additional options for editing.
96
- * @param options.cwd - The current working directory where `package-lock.json` is located.
97
- * @param options.skipIfMissing - If true, skips editing if the file does not exist.
98
107
  * @returns A promise that resolves when the file has been edited and written.
99
108
  */
100
- export declare function editNpmPackageLock(editFn: (npmPackage: NpmPackage) => MaybePromise<void>, { cwd, skipIfMissing }?: {
101
- cwd?: string | undefined;
102
- skipIfMissing?: boolean | undefined;
103
- }): Promise<void>;
109
+ export declare function editNpmPackageLock(editFn: (npmPackage: NpmPackage) => MaybePromise<void>, options?: EditNpmPackageOptions): Promise<void>;
104
110
  /**
105
111
  * Resolves the path to the `package.json` file in the specified directory or in the root if no directory is specified.
106
112
  *
@@ -67,4 +67,4 @@ function getPrototypeOf(instance) {
67
67
  getPrototypeOf,
68
68
  nameof
69
69
  });
70
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL09iamVjdC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9faW1wb3J0X21ldGFfdXJsID0gZ2xvYmFsVGhpc1tcImltcG9ydC5tZXRhLnVybFwiXSA/PyAoKCk9PnJlcXVpcmUoXCJub2RlOnVybFwiKS5wYXRoVG9GaWxlVVJMKF9fZmlsZW5hbWUpKSgpO1xudmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbXCJwcm9jZXNzXCJdID8/IHtcbiAgXCJjd2RcIjogKCk9PlwiL1wiLFxuICBcImVudlwiOiB7fSxcbiAgXCJwbGF0Zm9ybVwiOiBcImFuZHJvaWRcIlxufTtcbi8qKlxuICogQG1vZHVsZSBPYmplY3RcbiAqIENvbnRhaW5zIHV0aWxpdHkgZnVuY3Rpb25zIGZvciBPYmplY3RzLlxuICovXG5cbi8qKlxuICogQ29tcGFyZXMgdHdvIHZhbHVlcyB0byBkZXRlcm1pbmUgaWYgdGhleSBhcmUgZGVlcGx5IGVxdWFsLlxuICpcbiAqIEBwYXJhbSBhIC0gVGhlIGZpcnN0IHZhbHVlIHRvIGNvbXBhcmUuXG4gKiBAcGFyYW0gYiAtIFRoZSBzZWNvbmQgdmFsdWUgdG8gY29tcGFyZS5cbiAqIEByZXR1cm5zIGB0cnVlYCBpZiB0aGUgdmFsdWVzIGFyZSBkZWVwbHkgZXF1YWwsIG90aGVyd2lzZSBgZmFsc2VgLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVlcEVxdWFsKGE6IHVua25vd24sIGI6IHVua25vd24pOiBib29sZWFuIHtcbiAgaWYgKGEgPT09IGIpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGlmICh0eXBlb2YgYSAhPT0gXCJvYmplY3RcIiB8fCB0eXBlb2YgYiAhPT0gXCJvYmplY3RcIiB8fCBhID09PSBudWxsIHx8IGIgPT09IG51bGwgfHwgYSA9PT0gdW5kZWZpbmVkIHx8IGIgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGNvbnN0IGtleXNBID0gT2JqZWN0LmtleXMoYSk7XG4gIGNvbnN0IGtleXNCID0gT2JqZWN0LmtleXMoYik7XG5cbiAgaWYgKGtleXNBLmxlbmd0aCAhPT0ga2V5c0IubGVuZ3RoKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY29uc3QgYVJlY29yZCA9IGEgYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG4gIGNvbnN0IGJSZWNvcmQgPSBiIGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuXG4gIGZvciAoY29uc3Qga2V5IG9mIGtleXNBKSB7XG4gICAgaWYgKCFrZXlzQi5pbmNsdWRlcyhrZXkpIHx8ICFkZWVwRXF1YWwoYVJlY29yZFtrZXldLCBiUmVjb3JkW2tleV0pKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59XG5cbi8qKlxuICogUmV0cmlldmVzIHRoZSBuYW1lIG9mIGEgcHJvcGVydHkgb2YgYSBnaXZlbiB0eXBlIGBUYC5cbiAqXG4gKiBAdGVtcGxhdGUgVCAtIFRoZSB0eXBlIG9mIHRoZSBvYmplY3QgY29udGFpbmluZyB0aGUgcHJvcGVydHkuXG4gKiBAcGFyYW0gbmFtZSAtIFRoZSBuYW1lIG9mIHRoZSBwcm9wZXJ0eSBhcyBhIHN0cmluZy5cbiAqIEByZXR1cm5zIFRoZSBuYW1lIG9mIHRoZSBwcm9wZXJ0eS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG5hbWVvZjxUPihuYW1lOiBFeHRyYWN0PGtleW9mIFQsIHN0cmluZz4pOiBzdHJpbmcge1xuICByZXR1cm4gbmFtZTtcbn1cblxuLyoqXG4gKiBHZXRzIHRoZSBwcm90b3R5cGUgb2YgdGhlIHNwZWNpZmllZCBvYmplY3QuXG4gKlxuICogQHRlbXBsYXRlIFQgLSBUaGUgdHlwZSBvZiB0aGUgb2JqZWN0LlxuICogQHBhcmFtIGluc3RhbmNlIC0gVGhlIG9iamVjdCBpbnN0YW5jZSB0byByZXRyaWV2ZSB0aGUgcHJvdG90eXBlIG9mLlxuICogQHJldHVybnMgVGhlIHByb3RvdHlwZSBvZiB0aGUgb2JqZWN0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0UHJvdG90eXBlT2Y8VD4oaW5zdGFuY2U6IFQpOiBUIHtcbiAgcmV0dXJuIE9iamVjdC5nZXRQcm90b3R5cGVPZihpbnN0YW5jZSkgYXMgVDtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxJQUFJLG9CQUFvQixXQUFXLGlCQUFpQixNQUFNLE1BQUksUUFBUSxVQUFVLEVBQUUsY0FBYyxVQUFVLEdBQUc7QUFDN0csSUFBSSxZQUFZLFdBQVcsU0FBUyxLQUFLO0FBQUEsRUFDdkMsT0FBTyxNQUFJO0FBQUEsRUFDWCxPQUFPLENBQUM7QUFBQSxFQUNSLFlBQVk7QUFDZDtBQWFPLFNBQVMsVUFBVSxHQUFZLEdBQXFCO0FBQ3pELE1BQUksTUFBTSxHQUFHO0FBQ1gsV0FBTztBQUFBLEVBQ1Q7QUFFQSxNQUFJLE9BQU8sTUFBTSxZQUFZLE9BQU8sTUFBTSxZQUFZLE1BQU0sUUFBUSxNQUFNLFFBQVEsTUFBTSxVQUFhLE1BQU0sUUFBVztBQUNwSCxXQUFPO0FBQUEsRUFDVDtBQUVBLFFBQU0sUUFBUSxPQUFPLEtBQUssQ0FBQztBQUMzQixRQUFNLFFBQVEsT0FBTyxLQUFLLENBQUM7QUFFM0IsTUFBSSxNQUFNLFdBQVcsTUFBTSxRQUFRO0FBQ2pDLFdBQU87QUFBQSxFQUNUO0FBRUEsUUFBTSxVQUFVO0FBQ2hCLFFBQU0sVUFBVTtBQUVoQixhQUFXLE9BQU8sT0FBTztBQUN2QixRQUFJLENBQUMsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLFVBQVUsUUFBUSxHQUFHLEdBQUcsUUFBUSxHQUFHLENBQUMsR0FBRztBQUNsRSxhQUFPO0FBQUEsSUFDVDtBQUFBLEVBQ0Y7QUFFQSxTQUFPO0FBQ1Q7QUFTTyxTQUFTLE9BQVUsTUFBd0M7QUFDaEUsU0FBTztBQUNUO0FBU08sU0FBUyxlQUFrQixVQUFnQjtBQUNoRCxTQUFPLE9BQU8sZUFBZSxRQUFRO0FBQ3ZDOyIsCiAgIm5hbWVzIjogW10KfQo=
70
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL09iamVjdC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9faW1wb3J0X21ldGFfdXJsID0gZ2xvYmFsVGhpc1tcImltcG9ydC5tZXRhLnVybFwiXSA/PyAoKCk9PnJlcXVpcmUoXCJub2RlOnVybFwiKS5wYXRoVG9GaWxlVVJMKF9fZmlsZW5hbWUpKSgpO1xudmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbXCJwcm9jZXNzXCJdID8/IHtcbiAgXCJjd2RcIjogKCk9PlwiL1wiLFxuICBcImVudlwiOiB7fSxcbiAgXCJwbGF0Zm9ybVwiOiBcImFuZHJvaWRcIlxufTtcbi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIE9iamVjdFxuICogQ29udGFpbnMgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIE9iamVjdHMuXG4gKi9cblxuLyoqXG4gKiBDb21wYXJlcyB0d28gdmFsdWVzIHRvIGRldGVybWluZSBpZiB0aGV5IGFyZSBkZWVwbHkgZXF1YWwuXG4gKlxuICogQHBhcmFtIGEgLSBUaGUgZmlyc3QgdmFsdWUgdG8gY29tcGFyZS5cbiAqIEBwYXJhbSBiIC0gVGhlIHNlY29uZCB2YWx1ZSB0byBjb21wYXJlLlxuICogQHJldHVybnMgYHRydWVgIGlmIHRoZSB2YWx1ZXMgYXJlIGRlZXBseSBlcXVhbCwgb3RoZXJ3aXNlIGBmYWxzZWAuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZWVwRXF1YWwoYTogdW5rbm93biwgYjogdW5rbm93bik6IGJvb2xlYW4ge1xuICBpZiAoYSA9PT0gYikge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBhICE9PSBcIm9iamVjdFwiIHx8IHR5cGVvZiBiICE9PSBcIm9iamVjdFwiIHx8IGEgPT09IG51bGwgfHwgYiA9PT0gbnVsbCB8fCBhID09PSB1bmRlZmluZWQgfHwgYiA9PT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY29uc3Qga2V5c0EgPSBPYmplY3Qua2V5cyhhKTtcbiAgY29uc3Qga2V5c0IgPSBPYmplY3Qua2V5cyhiKTtcblxuICBpZiAoa2V5c0EubGVuZ3RoICE9PSBrZXlzQi5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBjb25zdCBhUmVjb3JkID0gYSBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgY29uc3QgYlJlY29yZCA9IGIgYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG5cbiAgZm9yIChjb25zdCBrZXkgb2Yga2V5c0EpIHtcbiAgICBpZiAoIWtleXNCLmluY2x1ZGVzKGtleSkgfHwgIWRlZXBFcXVhbChhUmVjb3JkW2tleV0sIGJSZWNvcmRba2V5XSkpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgdGhlIG5hbWUgb2YgYSBwcm9wZXJ0eSBvZiBhIGdpdmVuIHR5cGUgYFRgLlxuICpcbiAqIEB0eXBlUGFyYW0gVCAtIFRoZSB0eXBlIG9mIHRoZSBvYmplY3QgY29udGFpbmluZyB0aGUgcHJvcGVydHkuXG4gKiBAcGFyYW0gbmFtZSAtIFRoZSBuYW1lIG9mIHRoZSBwcm9wZXJ0eSBhcyBhIHN0cmluZy5cbiAqIEByZXR1cm5zIFRoZSBuYW1lIG9mIHRoZSBwcm9wZXJ0eS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG5hbWVvZjxUPihuYW1lOiBFeHRyYWN0PGtleW9mIFQsIHN0cmluZz4pOiBzdHJpbmcge1xuICByZXR1cm4gbmFtZTtcbn1cblxuLyoqXG4gKiBHZXRzIHRoZSBwcm90b3R5cGUgb2YgdGhlIHNwZWNpZmllZCBvYmplY3QuXG4gKlxuICogQHR5cGVQYXJhbSBUIC0gVGhlIHR5cGUgb2YgdGhlIG9iamVjdC5cbiAqIEBwYXJhbSBpbnN0YW5jZSAtIFRoZSBvYmplY3QgaW5zdGFuY2UgdG8gcmV0cmlldmUgdGhlIHByb3RvdHlwZSBvZi5cbiAqIEByZXR1cm5zIFRoZSBwcm90b3R5cGUgb2YgdGhlIG9iamVjdC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFByb3RvdHlwZU9mPFQ+KGluc3RhbmNlOiBUKTogVCB7XG4gIHJldHVybiBPYmplY3QuZ2V0UHJvdG90eXBlT2YoaW5zdGFuY2UpIGFzIFQ7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFBSSxvQkFBb0IsV0FBVyxpQkFBaUIsTUFBTSxNQUFJLFFBQVEsVUFBVSxFQUFFLGNBQWMsVUFBVSxHQUFHO0FBQzdHLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSztBQUFBLEVBQ3ZDLE9BQU8sTUFBSTtBQUFBLEVBQ1gsT0FBTyxDQUFDO0FBQUEsRUFDUixZQUFZO0FBQ2Q7QUFhTyxTQUFTLFVBQVUsR0FBWSxHQUFxQjtBQUN6RCxNQUFJLE1BQU0sR0FBRztBQUNYLFdBQU87QUFBQSxFQUNUO0FBRUEsTUFBSSxPQUFPLE1BQU0sWUFBWSxPQUFPLE1BQU0sWUFBWSxNQUFNLFFBQVEsTUFBTSxRQUFRLE1BQU0sVUFBYSxNQUFNLFFBQVc7QUFDcEgsV0FBTztBQUFBLEVBQ1Q7QUFFQSxRQUFNLFFBQVEsT0FBTyxLQUFLLENBQUM7QUFDM0IsUUFBTSxRQUFRLE9BQU8sS0FBSyxDQUFDO0FBRTNCLE1BQUksTUFBTSxXQUFXLE1BQU0sUUFBUTtBQUNqQyxXQUFPO0FBQUEsRUFDVDtBQUVBLFFBQU0sVUFBVTtBQUNoQixRQUFNLFVBQVU7QUFFaEIsYUFBVyxPQUFPLE9BQU87QUFDdkIsUUFBSSxDQUFDLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxVQUFVLFFBQVEsR0FBRyxHQUFHLFFBQVEsR0FBRyxDQUFDLEdBQUc7QUFDbEUsYUFBTztBQUFBLElBQ1Q7QUFBQSxFQUNGO0FBRUEsU0FBTztBQUNUO0FBU08sU0FBUyxPQUFVLE1BQXdDO0FBQ2hFLFNBQU87QUFDVDtBQVNPLFNBQVMsZUFBa0IsVUFBZ0I7QUFDaEQsU0FBTyxPQUFPLGVBQWUsUUFBUTtBQUN2QzsiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @module Object
2
+ * @packageDocumentation Object
3
3
  * Contains utility functions for Objects.
4
4
  */
5
5
  /**
@@ -13,7 +13,7 @@ export declare function deepEqual(a: unknown, b: unknown): boolean;
13
13
  /**
14
14
  * Retrieves the name of a property of a given type `T`.
15
15
  *
16
- * @template T - The type of the object containing the property.
16
+ * @typeParam T - The type of the object containing the property.
17
17
  * @param name - The name of the property as a string.
18
18
  * @returns The name of the property.
19
19
  */
@@ -21,7 +21,7 @@ export declare function nameof<T>(name: Extract<keyof T, string>): string;
21
21
  /**
22
22
  * Gets the prototype of the specified object.
23
23
  *
24
- * @template T - The type of the object.
24
+ * @typeParam T - The type of the object.
25
25
  * @param instance - The object instance to retrieve the prototype of.
26
26
  * @returns The prototype of the object.
27
27
  */
package/dist/lib/Path.cjs CHANGED
@@ -65,15 +65,15 @@ var __process = globalThis["process"] ?? {
65
65
  const posix = import_path_browserify.default.posix;
66
66
  const delimiter = posix.delimiter;
67
67
  const sep = import_path_browserify.default.posix.sep;
68
- const basename = posix.basename.bind(posix);
69
- const dirname = posix.dirname.bind(posix);
70
- const extname = posix.extname.bind(posix);
71
- const format = posix.format.bind(posix);
72
- const isAbsolute = posix.isAbsolute.bind(posix);
73
- const join = posix.join.bind(posix);
74
- const normalize = posix.normalize.bind(posix);
75
- const parse = posix.parse.bind(posix);
76
- const relative = posix.relative.bind(posix);
68
+ const basename = posix.basename;
69
+ const dirname = posix.dirname;
70
+ const extname = posix.extname;
71
+ const format = posix.format;
72
+ const isAbsolute = posix.isAbsolute;
73
+ const join = posix.join;
74
+ const normalize = posix.normalize;
75
+ const parse = posix.parse;
76
+ const relative = posix.relative;
77
77
  function resolve(...pathSegments) {
78
78
  let path2 = posix.resolve(...pathSegments);
79
79
  path2 = toPosixPath(path2);
@@ -119,4 +119,4 @@ function normalizeIfRelative(path2) {
119
119
  toPosixBuffer,
120
120
  toPosixPath
121
121
  });
122
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL1BhdGgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX2ltcG9ydF9tZXRhX3VybCA9IGdsb2JhbFRoaXNbXCJpbXBvcnQubWV0YS51cmxcIl0gPz8gKCgpPT5yZXF1aXJlKFwibm9kZTp1cmxcIikucGF0aFRvRmlsZVVSTChfX2ZpbGVuYW1lKSkoKTtcbnZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzW1wicHJvY2Vzc1wiXSA/PyB7XG4gIFwiY3dkXCI6ICgpPT5cIi9cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBtb2R1bGUgUGF0aFxuICogQ29udGFpbnMgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIGhhbmRsaW5nIHBhdGhzLlxuICovXG5cbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoLWJyb3dzZXJpZnlcIjtcbmltcG9ydCB7IGZpbGVVUkxUb1BhdGggfSBmcm9tIFwibm9kZTp1cmxcIjtcbmltcG9ydCB7IGVuc3VyZVN0YXJ0c1dpdGggfSBmcm9tIFwiLi9TdHJpbmcudHNcIjtcblxuZXhwb3J0IGNvbnN0IHBvc2l4ID0gcGF0aC5wb3NpeDtcbmV4cG9ydCBjb25zdCBkZWxpbWl0ZXIgPSBwb3NpeC5kZWxpbWl0ZXI7XG5leHBvcnQgY29uc3Qgc2VwID0gcGF0aC5wb3NpeC5zZXA7XG5cbmV4cG9ydCBjb25zdCBiYXNlbmFtZSA9IHBvc2l4LmJhc2VuYW1lLmJpbmQocG9zaXgpO1xuZXhwb3J0IGNvbnN0IGRpcm5hbWUgPSBwb3NpeC5kaXJuYW1lLmJpbmQocG9zaXgpO1xuZXhwb3J0IGNvbnN0IGV4dG5hbWUgPSBwb3NpeC5leHRuYW1lLmJpbmQocG9zaXgpO1xuZXhwb3J0IGNvbnN0IGZvcm1hdCA9IHBvc2l4LmZvcm1hdC5iaW5kKHBvc2l4KTtcbmV4cG9ydCBjb25zdCBpc0Fic29sdXRlID0gcG9zaXguaXNBYnNvbHV0ZS5iaW5kKHBvc2l4KTtcbmV4cG9ydCBjb25zdCBqb2luID0gcG9zaXguam9pbi5iaW5kKHBvc2l4KTtcbmV4cG9ydCBjb25zdCBub3JtYWxpemUgPSBwb3NpeC5ub3JtYWxpemUuYmluZChwb3NpeCk7XG5leHBvcnQgY29uc3QgcGFyc2UgPSBwb3NpeC5wYXJzZS5iaW5kKHBvc2l4KTtcbmV4cG9ydCBjb25zdCByZWxhdGl2ZSA9IHBvc2l4LnJlbGF0aXZlLmJpbmQocG9zaXgpO1xuXG4vKipcbiAqIFJlc29sdmVzIGEgc2VxdWVuY2Ugb2YgcGF0aHMgb3IgcGF0aCBzZWdtZW50cyBpbnRvIGFuIGFic29sdXRlIHBhdGguXG4gKlxuICogQHBhcmFtIHBhdGhTZWdtZW50cyAtIFRoZSBzZXF1ZW5jZSBvZiBwYXRoIHNlZ21lbnRzIHRvIHJlc29sdmUuXG4gKiBAcmV0dXJucyBUaGUgcmVzb2x2ZWQgYWJzb2x1dGUgcGF0aC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlc29sdmUoLi4ucGF0aFNlZ21lbnRzOiBzdHJpbmdbXSk6IHN0cmluZyB7XG4gIGxldCBwYXRoID0gcG9zaXgucmVzb2x2ZSguLi5wYXRoU2VnbWVudHMpO1xuICBwYXRoID0gdG9Qb3NpeFBhdGgocGF0aCk7XG4gIGNvbnN0IG1hdGNoID0gcGF0aC5tYXRjaCgvLjpbXjpdKiQvKTtcbiAgcmV0dXJuIG1hdGNoPy5bMF0gPz8gcGF0aDtcbn1cblxuLyoqXG4gKiBDb252ZXJ0cyBhIGdpdmVuIHBhdGggdG8gYSBQT1NJWC1zdHlsZSBwYXRoIGJ5IHJlcGxhY2luZyBiYWNrc2xhc2hlcyB3aXRoIGZvcndhcmQgc2xhc2hlcy5cbiAqXG4gKiBAcGFyYW0gcGF0aCAtIFRoZSBwYXRoIHRvIGNvbnZlcnQuXG4gKiBAcmV0dXJucyBUaGUgUE9TSVgtc3R5bGUgcGF0aC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvUG9zaXhQYXRoKHBhdGg6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBwYXRoLnJlcGxhY2UoL1xcXFwvZywgXCIvXCIpO1xufVxuXG4vKipcbiAqIENvbnZlcnRzIGEgYnVmZmVyIGNvbnRhaW5pbmcgYSBwYXRoIHRvIGEgUE9TSVgtc3R5bGUgYnVmZmVyIGJ5IHJlcGxhY2luZyBiYWNrc2xhc2hlcyB3aXRoIGZvcndhcmQgc2xhc2hlcy5cbiAqXG4gKiBAcGFyYW0gYnVmZmVyIC0gVGhlIGJ1ZmZlciB0byBjb252ZXJ0LlxuICogQHJldHVybnMgQSBuZXcgYnVmZmVyIGNvbnRhaW5pbmcgdGhlIFBPU0lYLXN0eWxlIHBhdGguXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0b1Bvc2l4QnVmZmVyKGJ1ZmZlcjogQnVmZmVyKTogQnVmZmVyIHtcbiAgcmV0dXJuIEJ1ZmZlci5mcm9tKHRvUG9zaXhQYXRoKGJ1ZmZlci50b1N0cmluZygpKSk7XG59XG5cbi8qKlxuICogR2V0cyB0aGUgZmlsZW5hbWUgZnJvbSB0aGUgYGltcG9ydC5tZXRhLnVybGAsIGNvbnZlcnRpbmcgaXQgdG8gYSBQT1NJWC1zdHlsZSBwYXRoLlxuICpcbiAqIEBwYXJhbSBpbXBvcnRNZXRhVXJsIC0gVGhlIGBpbXBvcnQubWV0YS51cmxgIGZyb20gd2hpY2ggdG8gZXh0cmFjdCB0aGUgZmlsZW5hbWUuXG4gKiBAcmV0dXJucyBUaGUgUE9TSVgtc3R5bGUgZmlsZW5hbWUuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRGaWxlbmFtZShpbXBvcnRNZXRhVXJsOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gdG9Qb3NpeFBhdGgoZmlsZVVSTFRvUGF0aChpbXBvcnRNZXRhVXJsKSk7XG59XG5cbi8qKlxuICogR2V0cyB0aGUgZGlyZWN0b3J5IG5hbWUgZnJvbSB0aGUgYGltcG9ydC5tZXRhLnVybGAsIGNvbnZlcnRpbmcgaXQgdG8gYSBQT1NJWC1zdHlsZSBwYXRoLlxuICpcbiAqIEBwYXJhbSBpbXBvcnRNZXRhVXJsIC0gVGhlIGBpbXBvcnQubWV0YS51cmxgIGZyb20gd2hpY2ggdG8gZXh0cmFjdCB0aGUgZGlyZWN0b3J5IG5hbWUuXG4gKiBAcmV0dXJucyBUaGUgUE9TSVgtc3R5bGUgZGlyZWN0b3J5IG5hbWUuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXREaXJuYW1lKGltcG9ydE1ldGFVcmw6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBkaXJuYW1lKGdldEZpbGVuYW1lKGltcG9ydE1ldGFVcmwpKTtcbn1cblxuLyoqXG4gKiBOb3JtYWxpemVzIGEgZ2l2ZW4gcGF0aCBieSBlbnN1cmluZyBpdCBpcyByZWxhdGl2ZSwgYWRkaW5nIFwiLi9cIiBpZiBuZWNlc3NhcnkuXG4gKlxuICogQHBhcmFtIHBhdGggLSBUaGUgcGF0aCB0byBub3JtYWxpemUuXG4gKiBAcmV0dXJucyBUaGUgbm9ybWFsaXplZCBwYXRoLCBzdGFydGluZyB3aXRoIFwiLi9cIiBpZiBpdCB3YXMgcmVsYXRpdmUuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBub3JtYWxpemVJZlJlbGF0aXZlKHBhdGg6IHN0cmluZyk6IHN0cmluZyB7XG4gIGlmIChwYXRoWzBdID09PSBcIi9cIiB8fCBwYXRoLmluY2x1ZGVzKFwiOlwiKSkge1xuICAgIHJldHVybiBwYXRoO1xuICB9XG5cbiAgcmV0dXJuIGVuc3VyZVN0YXJ0c1dpdGgocGF0aCwgXCIuL1wiKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBV0EsNkJBQWlCO0FBQ2pCLHNCQUE4QjtBQUM5QixvQkFBaUM7QUFiakMsSUFBSSxvQkFBb0IsV0FBVyxpQkFBaUIsTUFBTSxNQUFJLFFBQVEsVUFBVSxFQUFFLGNBQWMsVUFBVSxHQUFHO0FBQzdHLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSztBQUFBLEVBQ3ZDLE9BQU8sTUFBSTtBQUFBLEVBQ1gsT0FBTyxDQUFDO0FBQUEsRUFDUixZQUFZO0FBQ2Q7QUFVTyxNQUFNLFFBQVEsdUJBQUFBLFFBQUs7QUFDbkIsTUFBTSxZQUFZLE1BQU07QUFDeEIsTUFBTSxNQUFNLHVCQUFBQSxRQUFLLE1BQU07QUFFdkIsTUFBTSxXQUFXLE1BQU0sU0FBUyxLQUFLLEtBQUs7QUFDMUMsTUFBTSxVQUFVLE1BQU0sUUFBUSxLQUFLLEtBQUs7QUFDeEMsTUFBTSxVQUFVLE1BQU0sUUFBUSxLQUFLLEtBQUs7QUFDeEMsTUFBTSxTQUFTLE1BQU0sT0FBTyxLQUFLLEtBQUs7QUFDdEMsTUFBTSxhQUFhLE1BQU0sV0FBVyxLQUFLLEtBQUs7QUFDOUMsTUFBTSxPQUFPLE1BQU0sS0FBSyxLQUFLLEtBQUs7QUFDbEMsTUFBTSxZQUFZLE1BQU0sVUFBVSxLQUFLLEtBQUs7QUFDNUMsTUFBTSxRQUFRLE1BQU0sTUFBTSxLQUFLLEtBQUs7QUFDcEMsTUFBTSxXQUFXLE1BQU0sU0FBUyxLQUFLLEtBQUs7QUFRMUMsU0FBUyxXQUFXLGNBQWdDO0FBQ3pELE1BQUlBLFFBQU8sTUFBTSxRQUFRLEdBQUcsWUFBWTtBQUN4QyxFQUFBQSxRQUFPLFlBQVlBLEtBQUk7QUFDdkIsUUFBTSxRQUFRQSxNQUFLLE1BQU0sVUFBVTtBQUNuQyxTQUFPLFFBQVEsQ0FBQyxLQUFLQTtBQUN2QjtBQVFPLFNBQVMsWUFBWUEsT0FBc0I7QUFDaEQsU0FBT0EsTUFBSyxRQUFRLE9BQU8sR0FBRztBQUNoQztBQVFPLFNBQVMsY0FBYyxRQUF3QjtBQUNwRCxTQUFPLE9BQU8sS0FBSyxZQUFZLE9BQU8sU0FBUyxDQUFDLENBQUM7QUFDbkQ7QUFRTyxTQUFTLFlBQVksZUFBK0I7QUFDekQsU0FBTyxnQkFBWSwrQkFBYyxhQUFhLENBQUM7QUFDakQ7QUFRTyxTQUFTLFdBQVcsZUFBK0I7QUFDeEQsU0FBTyxRQUFRLFlBQVksYUFBYSxDQUFDO0FBQzNDO0FBUU8sU0FBUyxvQkFBb0JBLE9BQXNCO0FBQ3hELE1BQUlBLE1BQUssQ0FBQyxNQUFNLE9BQU9BLE1BQUssU0FBUyxHQUFHLEdBQUc7QUFDekMsV0FBT0E7QUFBQSxFQUNUO0FBRUEsYUFBTyxnQ0FBaUJBLE9BQU0sSUFBSTtBQUNwQzsiLAogICJuYW1lcyI6IFsicGF0aCJdCn0K
122
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Path.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Path\n * Contains utility functions for handling paths.\n */\n\nimport path from \"path-browserify\";\nimport { fileURLToPath } from \"node:url\";\nimport { ensureStartsWith } from \"./String.ts\";\n\n/**\n * Provides methods for handling POSIX paths.\n */\nexport const posix = path.posix;\n\n/**\n * The POSIX path delimiter.\n */\nexport const delimiter = posix.delimiter;\n\n/**\n * The POSIX segment separator.\n */\nexport const sep = path.posix.sep;\n\n/**\n * Returns the base name of a file, optionally removing the file extension.\n *\n * @param path - The path to get the base name from.\n * @param ext - An optional extension to remove from the base name.\n * @returns The base name of the file.\n */\nexport const basename = posix.basename;\n\n\n/**\n * Returns the directory name of a path.\n *\n * @param path - The path to get the directory name from.\n * @returns The directory name of the path.\n */\nexport const dirname = posix.dirname;\n\n/**\n * Returns the file extension of a path.\n *\n * @param path - The path to get the extension from.\n * @returns The file extension of the path.\n */\nexport const extname = posix.extname;\n\n/**\n * Formats a path object into a path string.\n *\n * @param pathObject - The path object to format.\n * @returns The formatted path string.\n */\nexport const format = posix.format;\n\n/**\n * Determines if a path is absolute.\n *\n * @param path - The path to check.\n * @returns `true` if the path is absolute, `false` otherwise.\n */\nexport const isAbsolute = posix.isAbsolute;\n\n/**\n * Joins multiple path segments into a single path.\n *\n * @param paths - The path segments to join.\n * @returns The joined path.\n */\nexport const join = posix.join;\n\n/**\n  * Normalizes a path, resolving '..' and '.' segments.\n  *\n  * @param path - The path to normalize.\n  * @returns The normalized path.\n  */\nexport const normalize = posix.normalize;\n\n\n/**\n * Parses a path string into a path object.\n *\n * @param path - The path string to parse.\n * @returns The parsed path object.\n */\nexport const parse = posix.parse;\n\n\n/**\n * Returns the relative path from one path to another.\n *\n * @param from - The starting path.\n * @param to - The destination path.\n * @returns The relative path from `from` to `to`.\n */\nexport const relative = posix.relative;\n\n/**\n * Resolves a sequence of paths or path segments into an absolute path.\n *\n * @param pathSegments - The sequence of path segments to resolve.\n * @returns The resolved absolute path.\n */\nexport function resolve(...pathSegments: string[]): string {\n  let path = posix.resolve(...pathSegments);\n  path = toPosixPath(path);\n  const match = path.match(/.:[^:]*$/);\n  return match?.[0] ?? path;\n}\n\n/**\n * Converts a given path to a POSIX-style path by replacing backslashes with forward slashes.\n *\n * @param path - The path to convert.\n * @returns The POSIX-style path.\n */\nexport function toPosixPath(path: string): string {\n  return path.replace(/\\\\/g, \"/\");\n}\n\n/**\n * Converts a buffer containing a path to a POSIX-style buffer by replacing backslashes with forward slashes.\n *\n * @param buffer - The buffer to convert.\n * @returns A new buffer containing the POSIX-style path.\n */\nexport function toPosixBuffer(buffer: Buffer): Buffer {\n  return Buffer.from(toPosixPath(buffer.toString()));\n}\n\n/**\n * Gets the filename from the `import.meta.url`, converting it to a POSIX-style path.\n *\n * @param importMetaUrl - The `import.meta.url` from which to extract the filename.\n * @returns The POSIX-style filename.\n */\nexport function getFilename(importMetaUrl: string): string {\n  return toPosixPath(fileURLToPath(importMetaUrl));\n}\n\n/**\n * Gets the directory name from the `import.meta.url`, converting it to a POSIX-style path.\n *\n * @param importMetaUrl - The `import.meta.url` from which to extract the directory name.\n * @returns The POSIX-style directory name.\n */\nexport function getDirname(importMetaUrl: string): string {\n  return dirname(getFilename(importMetaUrl));\n}\n\n/**\n * Normalizes a given path by ensuring it is relative, adding \"./\" if necessary.\n *\n * @param path - The path to normalize.\n * @returns The normalized path, starting with \"./\" if it was relative.\n */\nexport function normalizeIfRelative(path: string): string {\n  if (path[0] === \"/\" || path.includes(\":\")) {\n    return path;\n  }\n\n  return ensureStartsWith(path, \"./\");\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,6BAAiB;AACjB,sBAA8B;AAC9B,oBAAiC;AAbjC,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI,QAAQ,UAAU,EAAE,cAAc,UAAU,GAAG;AAC7G,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAaO,MAAM,QAAQ,uBAAAA,QAAK;AAKnB,MAAM,YAAY,MAAM;AAKxB,MAAM,MAAM,uBAAAA,QAAK,MAAM;AASvB,MAAM,WAAW,MAAM;AASvB,MAAM,UAAU,MAAM;AAQtB,MAAM,UAAU,MAAM;AAQtB,MAAM,SAAS,MAAM;AAQrB,MAAM,aAAa,MAAM;AAQzB,MAAM,OAAO,MAAM;AAQnB,MAAM,YAAY,MAAM;AASxB,MAAM,QAAQ,MAAM;AAUpB,MAAM,WAAW,MAAM;AAQvB,SAAS,WAAW,cAAgC;AACzD,MAAIA,QAAO,MAAM,QAAQ,GAAG,YAAY;AACxC,EAAAA,QAAO,YAAYA,KAAI;AACvB,QAAM,QAAQA,MAAK,MAAM,UAAU;AACnC,SAAO,QAAQ,CAAC,KAAKA;AACvB;AAQO,SAAS,YAAYA,OAAsB;AAChD,SAAOA,MAAK,QAAQ,OAAO,GAAG;AAChC;AAQO,SAAS,cAAc,QAAwB;AACpD,SAAO,OAAO,KAAK,YAAY,OAAO,SAAS,CAAC,CAAC;AACnD;AAQO,SAAS,YAAY,eAA+B;AACzD,SAAO,gBAAY,+BAAc,aAAa,CAAC;AACjD;AAQO,SAAS,WAAW,eAA+B;AACxD,SAAO,QAAQ,YAAY,aAAa,CAAC;AAC3C;AAQO,SAAS,oBAAoBA,OAAsB;AACxD,MAAIA,MAAK,CAAC,MAAM,OAAOA,MAAK,SAAS,GAAG,GAAG;AACzC,WAAOA;AAAA,EACT;AAEA,aAAO,gCAAiBA,OAAM,IAAI;AACpC;",
  "names": ["path"]
}

@@ -1,20 +1,85 @@
1
1
  /**
2
- * @module Path
2
+ * @packageDocumentation Path
3
3
  * Contains utility functions for handling paths.
4
4
  */
5
5
  import path from "path-browserify";
6
+ /**
7
+ * Provides methods for handling POSIX paths.
8
+ */
6
9
  export declare const posix: path.Path;
10
+ /**
11
+ * The POSIX path delimiter.
12
+ */
7
13
  export declare const delimiter: string;
14
+ /**
15
+ * The POSIX segment separator.
16
+ */
8
17
  export declare const sep: string;
9
- export declare const basename: (path: string, ext?: string) => string;
10
- export declare const dirname: (path: string) => string;
11
- export declare const extname: (path: string) => string;
12
- export declare const format: (pathObject: Partial<path.PathObject>) => string;
13
- export declare const isAbsolute: (path: string) => boolean;
14
- export declare const join: (...paths: string[]) => string;
15
- export declare const normalize: (path: string) => string;
16
- export declare const parse: (path: string) => path.PathObject;
17
- export declare const relative: (from: string, to: string) => string;
18
+ /**
19
+ * Returns the base name of a file, optionally removing the file extension.
20
+ *
21
+ * @param path - The path to get the base name from.
22
+ * @param ext - An optional extension to remove from the base name.
23
+ * @returns The base name of the file.
24
+ */
25
+ export declare const basename: (this: void, path: string, ext?: string) => string;
26
+ /**
27
+ * Returns the directory name of a path.
28
+ *
29
+ * @param path - The path to get the directory name from.
30
+ * @returns The directory name of the path.
31
+ */
32
+ export declare const dirname: (this: void, path: string) => string;
33
+ /**
34
+ * Returns the file extension of a path.
35
+ *
36
+ * @param path - The path to get the extension from.
37
+ * @returns The file extension of the path.
38
+ */
39
+ export declare const extname: (this: void, path: string) => string;
40
+ /**
41
+ * Formats a path object into a path string.
42
+ *
43
+ * @param pathObject - The path object to format.
44
+ * @returns The formatted path string.
45
+ */
46
+ export declare const format: (this: void, pathObject: Partial<path.PathObject>) => string;
47
+ /**
48
+ * Determines if a path is absolute.
49
+ *
50
+ * @param path - The path to check.
51
+ * @returns `true` if the path is absolute, `false` otherwise.
52
+ */
53
+ export declare const isAbsolute: (this: void, path: string) => boolean;
54
+ /**
55
+ * Joins multiple path segments into a single path.
56
+ *
57
+ * @param paths - The path segments to join.
58
+ * @returns The joined path.
59
+ */
60
+ export declare const join: (this: void, ...paths: string[]) => string;
61
+ /**
62
+ * Normalizes a path, resolving '..' and '.' segments.
63
+ *
64
+ * @param path - The path to normalize.
65
+ * @returns The normalized path.
66
+ */
67
+ export declare const normalize: (this: void, path: string) => string;
68
+ /**
69
+ * Parses a path string into a path object.
70
+ *
71
+ * @param path - The path string to parse.
72
+ * @returns The parsed path object.
73
+ */
74
+ export declare const parse: (this: void, path: string) => path.PathObject;
75
+ /**
76
+ * Returns the relative path from one path to another.
77
+ *
78
+ * @param from - The starting path.
79
+ * @param to - The destination path.
80
+ * @returns The relative path from `from` to `to`.
81
+ */
82
+ export declare const relative: (this: void, from: string, to: string) => string;
18
83
  /**
19
84
  * Resolves a sequence of paths or path segments into an absolute path.
20
85
  *
@@ -39,4 +39,4 @@ function escapeRegExp(str) {
39
39
  0 && (module.exports = {
40
40
  escapeRegExp
41
41
  });
42
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL1JlZ0V4cC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9faW1wb3J0X21ldGFfdXJsID0gZ2xvYmFsVGhpc1tcImltcG9ydC5tZXRhLnVybFwiXSA/PyAoKCk9PnJlcXVpcmUoXCJub2RlOnVybFwiKS5wYXRoVG9GaWxlVVJMKF9fZmlsZW5hbWUpKSgpO1xudmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbXCJwcm9jZXNzXCJdID8/IHtcbiAgXCJjd2RcIjogKCk9PlwiL1wiLFxuICBcImVudlwiOiB7fSxcbiAgXCJwbGF0Zm9ybVwiOiBcImFuZHJvaWRcIlxufTtcbi8qKlxuICogQG1vZHVsZSBSZWdFeHBcbiAqIENvbnRhaW5zIHV0aWxpdHkgZnVuY3Rpb25zIGZvciByZWd1bGFyIGV4cHJlc3Npb25zLlxuICovXG5cbi8qKlxuICogRXNjYXBlcyBzcGVjaWFsIGNoYXJhY3RlcnMgaW4gYSBzdHJpbmcgdG8gc2FmZWx5IHVzZSBpdCB3aXRoaW4gYSByZWd1bGFyIGV4cHJlc3Npb24uXG4gKlxuICogQHBhcmFtIHN0ciAtIFRoZSBzdHJpbmcgdG8gZXNjYXBlLlxuICogQHJldHVybnMgVGhlIGVzY2FwZWQgc3RyaW5nIHdpdGggc3BlY2lhbCBjaGFyYWN0ZXJzIHByZWZpeGVkIHdpdGggYSBiYWNrc2xhc2guXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBlc2NhcGVSZWdFeHAoc3RyOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gc3RyLnJlcGxhY2VBbGwoL1suKis/XiR7fSgpfFtcXF1cXFxcXS9nLCBcIlxcXFwkJlwiKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBQUksb0JBQW9CLFdBQVcsaUJBQWlCLE1BQU0sTUFBSSxRQUFRLFVBQVUsRUFBRSxjQUFjLFVBQVUsR0FBRztBQUM3RyxJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxPQUFPLE1BQUk7QUFBQSxFQUNYLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBWU8sU0FBUyxhQUFhLEtBQXFCO0FBQ2hELFNBQU8sSUFBSSxXQUFXLHVCQUF1QixNQUFNO0FBQ3JEOyIsCiAgIm5hbWVzIjogW10KfQo=
42
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL1JlZ0V4cC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9faW1wb3J0X21ldGFfdXJsID0gZ2xvYmFsVGhpc1tcImltcG9ydC5tZXRhLnVybFwiXSA/PyAoKCk9PnJlcXVpcmUoXCJub2RlOnVybFwiKS5wYXRoVG9GaWxlVVJMKF9fZmlsZW5hbWUpKSgpO1xudmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbXCJwcm9jZXNzXCJdID8/IHtcbiAgXCJjd2RcIjogKCk9PlwiL1wiLFxuICBcImVudlwiOiB7fSxcbiAgXCJwbGF0Zm9ybVwiOiBcImFuZHJvaWRcIlxufTtcbi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIFJlZ0V4cFxuICogQ29udGFpbnMgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIHJlZ3VsYXIgZXhwcmVzc2lvbnMuXG4gKi9cblxuLyoqXG4gKiBFc2NhcGVzIHNwZWNpYWwgY2hhcmFjdGVycyBpbiBhIHN0cmluZyB0byBzYWZlbHkgdXNlIGl0IHdpdGhpbiBhIHJlZ3VsYXIgZXhwcmVzc2lvbi5cbiAqXG4gKiBAcGFyYW0gc3RyIC0gVGhlIHN0cmluZyB0byBlc2NhcGUuXG4gKiBAcmV0dXJucyBUaGUgZXNjYXBlZCBzdHJpbmcgd2l0aCBzcGVjaWFsIGNoYXJhY3RlcnMgcHJlZml4ZWQgd2l0aCBhIGJhY2tzbGFzaC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGVzY2FwZVJlZ0V4cChzdHI6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBzdHIucmVwbGFjZUFsbCgvWy4qKz9eJHt9KCl8W1xcXVxcXFxdL2csIFwiXFxcXCQmXCIpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFBSSxvQkFBb0IsV0FBVyxpQkFBaUIsTUFBTSxNQUFJLFFBQVEsVUFBVSxFQUFFLGNBQWMsVUFBVSxHQUFHO0FBQzdHLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSztBQUFBLEVBQ3ZDLE9BQU8sTUFBSTtBQUFBLEVBQ1gsT0FBTyxDQUFDO0FBQUEsRUFDUixZQUFZO0FBQ2Q7QUFZTyxTQUFTLGFBQWEsS0FBcUI7QUFDaEQsU0FBTyxJQUFJLFdBQVcsdUJBQXVCLE1BQU07QUFDckQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @module RegExp
2
+ * @packageDocumentation RegExp
3
3
  * Contains utility functions for regular expressions.
4
4
  */
5
5
  /**
package/dist/lib/Root.cjs CHANGED
@@ -52,13 +52,14 @@ var __process = globalThis["process"] ?? {
52
52
  "env": {},
53
53
  "platform": "android"
54
54
  };
55
- function execFromRoot(command, {
56
- quiet = false,
57
- ignoreExitCode = false,
58
- stdin = "",
59
- cwd = void 0,
60
- withDetails = false
61
- } = {}) {
55
+ function execFromRoot(command, options = {}) {
56
+ const {
57
+ quiet = false,
58
+ ignoreExitCode = false,
59
+ stdin = "",
60
+ cwd = void 0,
61
+ withDetails = false
62
+ } = options;
62
63
  if (Array.isArray(command)) {
63
64
  command = (0, import_cli.toCommandLine)(command);
64
65
  }
@@ -141,4 +142,4 @@ function toRelativeFromRoot(path, cwd) {
141
142
  resolvePathFromRoot,
142
143
  toRelativeFromRoot
143
144
  });
144
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Root.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @module Root\n * Contains utility functions for executing commands from the root directory of a project,\n * resolving paths relative to the root.\n */\n\nimport { spawn } from \"node:child_process\";\nimport {\n  relative,\n  resolve\n} from \"./Path.ts\";\nimport process from \"node:process\";\nimport { packageDirectorySync } from \"pkg-dir\";\nimport { toPosixPath } from \"./Path.ts\";\nimport { trimEnd } from \"./String.ts\";\nimport { toCommandLine } from \"./cli.ts\";\n\ntype ExecResult = {\n  exitCode: number | null;\n  exitSignal: NodeJS.Signals | null;\n  stderr: string;\n  stdout: string;\n};\n\n/**\n * Executes a command from the root directory.\n * @param command - The command to execute. Can be a string or an array of strings.\n * @param options - The options for the execution.\n * @param options.quiet - If true, suppresses the output of the command. Default is false.\n * @param options.ignoreExitCode - If true, ignores the exit code of the command. Default is false.\n * @param options.stdin - The input to be passed to the command. Default is undefined.\n * @param options.cwd - The current working directory for the command execution. Default is undefined.\n * @param options.withDetails - If false, only returns the output of the command. Default is false.\n * @returns A promise that resolves with the output of the command.\n */\nexport async function execFromRoot(command: string | string[], options?: {\n  quiet?: boolean,\n  ignoreExitCode?: boolean,\n  stdin?: string,\n  cwd?: string | undefined,\n  withDetails?: false\n}): Promise<string>;\n\n/**\n * Executes a command from the root directory of the project.\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 * @param options.quiet - If set to true, suppresses the output of the command. Default is false.\n * @param options.ignoreExitCode - If set to true, ignores the exit code of the command. Default is false.\n * @param options.stdin - The input to be passed to the command. Default is undefined.\n * @param options.cwd - The current working directory for the command execution. Default is undefined.\n * @param options.withDetails - If set to true, returns detailed information about the execution. Default is true.\n * @returns A promise that resolves to the execution result.\n */\nexport function execFromRoot(command: string | string[], options?: {\n  quiet?: boolean,\n  ignoreExitCode?: boolean,\n  stdin?: string,\n  cwd?: string | undefined,\n  withDetails: true\n}): Promise<ExecResult>;\n\n/**\n * Executes a command from the root directory of the project.\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 * @param options.quiet - If set to true, suppresses the output of the command. Default is false.\n * @param options.ignoreExitCode - If set to true, ignores the exit code of the command. Default is false.\n * @param options.stdin - The input to be passed to the command. Default is undefined.\n * @param options.cwd - The current working directory for the command execution. Default is undefined.\n * @param options.withDetails - Whether to include detailed information in the output. Default is false.\n *\n * @returns A 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 *\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 execFromRoot(command: string | string[],\n  {\n    quiet = false,\n    ignoreExitCode = false,\n    stdin = \"\",\n    cwd = undefined,\n    withDetails = false\n  }: {\n    quiet?: boolean,\n    ignoreExitCode?: boolean,\n    stdin?: string,\n    cwd?: string | undefined,\n    withDetails?: boolean\n  } = {}): Promise<string | ExecResult> {\n  if (Array.isArray(command)) {\n    command = toCommandLine(command);\n  }\n\n  return new Promise((resolve, reject) => {\n    console.log(`Executing command: ${command}`);\n    const [cmd = \"\", ...args] = command.split(\" \");\n\n    const child = spawn(cmd, args, {\n      cwd: getRootDir(cwd),\n      stdio: \"pipe\",\n      shell: true\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}\\n${stderr}`));\n      } else {\n        resolve(!withDetails ? stdout : {\n          exitCode,\n          exitSignal,\n          stderr,\n          stdout\n        });\n      }\n    });\n\n    child.on(\"error\", (err) => {\n      if (!ignoreExitCode) {\n        reject(err);\n      } else {\n        resolve(!withDetails ? stdout : {\n          exitCode: null,\n          exitSignal: null,\n          stderr,\n          stdout\n        });\n      }\n    });\n  });\n}\n\n/**\n * Resolves a path relative to the root directory of the project.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working directory to resolve from.\n * @returns The resolved absolute path.\n */\nexport function resolvePathFromRoot(path: string, cwd?: string): string {\n  return resolve(getRootDir(cwd), path);\n}\n\n/**\n * Retrieves the root directory of the project.\n *\n * @param cwd - The current working directory to resolve from.\n * @returns The path to the root directory.\n * @throws If the root directory cannot be found.\n */\nexport function getRootDir(cwd?: string): string {\n  const rootDir = packageDirectorySync({ cwd: cwd ?? process.cwd() });\n  if (!rootDir) {\n    throw new Error(\"Could not find root directory\");\n  }\n\n  return toPosixPath(rootDir);\n}\n\n/**\n * Converts an absolute path to a relative path from the root directory of the project.\n *\n * @param path - The absolute path to convert.\n * @param cwd - The current working directory to resolve from.\n * @returns The relative path from the root directory.\n */\nexport function toRelativeFromRoot(path: string, cwd?: string): string {\n  const rootDir = getRootDir(cwd);\n  path = toPosixPath(path);\n  return relative(rootDir, path);\n}\n"],
  "mappings": "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",
  "names": ["import_Path", "resolve", "process"]
}

145
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Root.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Root\n * Contains utility functions for executing commands from the root directory of a project,\n * resolving paths relative to the root.\n */\n\nimport { spawn } from \"node:child_process\";\nimport {\n  relative,\n  resolve\n} from \"./Path.ts\";\nimport process from \"node:process\";\nimport { packageDirectorySync } from \"pkg-dir\";\nimport { toPosixPath } from \"./Path.ts\";\nimport { trimEnd } from \"./String.ts\";\nimport { toCommandLine } from \"./cli.ts\";\n\n/**\n * Represents the result of executing a command from the root directory.\n */\ntype ExecFromRootResult = {\n  /**\n   * The exit code of the command. A value of `null` indicates that the process did not exit normally.\n   */\n  exitCode: number | null;\n\n  /**\n   * The 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   * The standard error output from the command.\n   */\n  stderr: string;\n\n  /**\n   * The standard output from the command.\n   */\n  stdout: string;\n};\n\n/**\n * Options for executing a command from the root directory.\n */\ntype ExecFromRootOption = {\n  /**\n   * If true, suppresses the output of the command.\n   */\n  quiet?: boolean;\n\n  /**\n   * If true, ignores the exit code of the command.\n   */\n  ignoreExitCode?: boolean;\n\n  /**\n   * The input to be passed to the command.\n   */\n  stdin?: string;\n\n  /**\n   * The current working directory for the command execution.\n   */\n  cwd?: string | undefined;\n\n  /**\n   * If false, only returns the output of the command.\n   */\n  withDetails?: boolean;\n};\n\n/**\n * Executes a command from the root directory of the project.\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 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 execFromRoot(command: string | string[], options?: ExecFromRootOption & { withDetails?: false }): Promise<string>;\n\n/**\n * Executes a command from the root directory of the project.\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 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 execFromRoot(command: string | string[], options: ExecFromRootOption & { withDetails: true }): Promise<ExecFromRootResult>;\n\n/**\n * Executes a command from the root directory of the project.\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 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 execFromRoot(command: string | string[], options: ExecFromRootOption = {}): Promise<string | ExecFromRootResult> {\n  const {\n    quiet = false,\n    ignoreExitCode = false,\n    stdin = \"\",\n    cwd = undefined,\n    withDetails = false\n  } = options;\n  if (Array.isArray(command)) {\n    command = toCommandLine(command);\n  }\n\n  return new Promise((resolve, reject) => {\n    console.log(`Executing command: ${command}`);\n    const [cmd = \"\", ...args] = command.split(\" \");\n\n    const child = spawn(cmd, args, {\n      cwd: getRootDir(cwd),\n      stdio: \"pipe\",\n      shell: true\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}\\n${stderr}`));\n      } else {\n        resolve(!withDetails ? stdout : {\n          exitCode,\n          exitSignal,\n          stderr,\n          stdout\n        });\n      }\n    });\n\n    child.on(\"error\", (err) => {\n      if (!ignoreExitCode) {\n        reject(err);\n      } else {\n        resolve(!withDetails ? stdout : {\n          exitCode: null,\n          exitSignal: null,\n          stderr,\n          stdout\n        });\n      }\n    });\n  });\n}\n\n/**\n * Resolves a path relative to the root directory of the project.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working directory to resolve from.\n * @returns The resolved absolute path.\n */\nexport function resolvePathFromRoot(path: string, cwd?: string): string {\n  return resolve(getRootDir(cwd), path);\n}\n\n/**\n * Retrieves the root directory of the project.\n *\n * @param cwd - The current working directory to resolve from.\n * @returns The path to the root directory.\n * @throws If the root directory cannot be found.\n */\nexport function getRootDir(cwd?: string): string {\n  const rootDir = packageDirectorySync({ cwd: cwd ?? process.cwd() });\n  if (!rootDir) {\n    throw new Error(\"Could not find root directory\");\n  }\n\n  return toPosixPath(rootDir);\n}\n\n/**\n * Converts an absolute path to a relative path from the root directory of the project.\n *\n * @param path - The absolute path to convert.\n * @param cwd - The current working directory to resolve from.\n * @returns The relative path from the root directory.\n */\nexport function toRelativeFromRoot(path: string, cwd?: string): string {\n  const rootDir = getRootDir(cwd);\n  path = toPosixPath(path);\n  return relative(rootDir, path);\n}\n"],
  "mappings": "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",
  "names": ["import_Path", "resolve", "process"]
}

@@ -1,50 +1,83 @@
1
1
  /**
2
- * @module Root
2
+ * @packageDocumentation Root
3
3
  * Contains utility functions for executing commands from the root directory of a project,
4
4
  * resolving paths relative to the root.
5
5
  */
6
- type ExecResult = {
6
+ /**
7
+ * Represents the result of executing a command from the root directory.
8
+ */
9
+ type ExecFromRootResult = {
10
+ /**
11
+ * The exit code of the command. A value of `null` indicates that the process did not exit normally.
12
+ */
7
13
  exitCode: number | null;
14
+ /**
15
+ * The signal that caused the process to be terminated. A value of `null` indicates that no signal was received.
16
+ */
8
17
  exitSignal: NodeJS.Signals | null;
18
+ /**
19
+ * The standard error output from the command.
20
+ */
9
21
  stderr: string;
22
+ /**
23
+ * The standard output from the command.
24
+ */
10
25
  stdout: string;
11
26
  };
12
27
  /**
13
- * Executes a command from the root directory.
14
- * @param command - The command to execute. Can be a string or an array of strings.
15
- * @param options - The options for the execution.
16
- * @param options.quiet - If true, suppresses the output of the command. Default is false.
17
- * @param options.ignoreExitCode - If true, ignores the exit code of the command. Default is false.
18
- * @param options.stdin - The input to be passed to the command. Default is undefined.
19
- * @param options.cwd - The current working directory for the command execution. Default is undefined.
20
- * @param options.withDetails - If false, only returns the output of the command. Default is false.
21
- * @returns A promise that resolves with the output of the command.
28
+ * Options for executing a command from the root directory.
22
29
  */
23
- export declare function execFromRoot(command: string | string[], options?: {
30
+ type ExecFromRootOption = {
31
+ /**
32
+ * If true, suppresses the output of the command.
33
+ */
24
34
  quiet?: boolean;
35
+ /**
36
+ * If true, ignores the exit code of the command.
37
+ */
25
38
  ignoreExitCode?: boolean;
39
+ /**
40
+ * The input to be passed to the command.
41
+ */
26
42
  stdin?: string;
43
+ /**
44
+ * The current working directory for the command execution.
45
+ */
27
46
  cwd?: string | undefined;
47
+ /**
48
+ * If false, only returns the output of the command.
49
+ */
50
+ withDetails?: boolean;
51
+ };
52
+ /**
53
+ * Executes a command from the root directory of the project.
54
+ *
55
+ * @param command - The command to execute. It can be a string or an array of strings.
56
+ * @param options - The options for the execution.
57
+ * @returns A Promise that resolves with the output of the command.
58
+ * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.
59
+ * The error message includes the exit code and stderr.
60
+ * If an error occurs during the execution and ignoreExitCode is true,
61
+ * the error is resolved with the stdout and stderr.
62
+ */
63
+ export declare function execFromRoot(command: string | string[], options?: ExecFromRootOption & {
28
64
  withDetails?: false;
29
65
  }): Promise<string>;
30
66
  /**
31
67
  * Executes a command from the root directory of the project.
68
+ *
32
69
  * @param command - The command to execute. It can be a string or an array of strings.
33
70
  * @param options - The options for the execution.
34
- * @param options.quiet - If set to true, suppresses the output of the command. Default is false.
35
- * @param options.ignoreExitCode - If set to true, ignores the exit code of the command. Default is false.
36
- * @param options.stdin - The input to be passed to the command. Default is undefined.
37
- * @param options.cwd - The current working directory for the command execution. Default is undefined.
38
- * @param options.withDetails - If set to true, returns detailed information about the execution. Default is true.
39
- * @returns A promise that resolves to the execution result.
71
+ * @returns A Promise that resolves with ExecResult object.
72
+ * The ExecResult object contains the exit code, exit signal, stderr, and stdout.
73
+ * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.
74
+ * The error message includes the exit code and stderr.
75
+ * If an error occurs during the execution and ignoreExitCode is true,
76
+ * the error is resolved with the stdout and stderr.
40
77
  */
41
- export declare function execFromRoot(command: string | string[], options?: {
42
- quiet?: boolean;
43
- ignoreExitCode?: boolean;
44
- stdin?: string;
45
- cwd?: string | undefined;
78
+ export declare function execFromRoot(command: string | string[], options: ExecFromRootOption & {
46
79
  withDetails: true;
47
- }): Promise<ExecResult>;
80
+ }): Promise<ExecFromRootResult>;
48
81
  /**
49
82
  * Resolves a path relative to the root directory of the project.
50
83
  *
@@ -119,4 +119,4 @@ function replace(str, replacementsMap) {
119
119
  trimStart,
120
120
  unescape
121
121
  });
122
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/String.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @module String\n * Contains utility functions for string operations.\n */\n\nimport { escapeRegExp } from \"./RegExp.ts\";\nimport {\n  resolveValue,\n  type ValueProvider\n} from \"./ValueProvider.ts\";\n\ntype AsyncReplacer<Args extends unknown[]> = ValueProvider<string, [string, ...Args]>;\n\n/**\n * Mapping of special characters to their escaped counterparts.\n */\nconst ESCAPE_MAP: Record<string, string> = {\n  \"\\\\\": \"\\\\\\\\\",\n  \"\\\"\": \"\\\\\\\"\",\n  \"\\'\": \"\\\\\\'\",\n  \"\\n\": \"\\\\n\",\n  \"\\r\": \"\\\\r\",\n  \"\\t\": \"\\\\t\",\n  \"\\b\": \"\\\\b\",\n  \"\\f\": \"\\\\f\"\n} as const;\n\n/**\n * Mapping of escaped special characters to their unescaped counterparts.\n */\nconst UNESCAPE_MAP: Record<string, string> = {};\nfor (const [key, value] of Object.entries(ESCAPE_MAP)) {\n  UNESCAPE_MAP[value] = key;\n}\n\n/**\n * Trims the specified prefix from the start of a string.\n *\n * @param str - The string to trim.\n * @param prefix - The prefix to remove from the start of the string.\n * @param validate - If true, throws an error if the string does not start with the prefix.\n * @returns The trimmed string.\n * @throws If `validate` is true and the string does not start with the prefix.\n */\nexport function trimStart(str: string, prefix: string, validate?: boolean): string {\n  if (str.startsWith(prefix)) {\n    return str.slice(prefix.length);\n  }\n\n  if (validate) {\n    throw new Error(`String ${str} does not start with prefix ${prefix}`);\n  }\n\n  return str;\n}\n\n/**\n * Trims the specified suffix from the end of a string.\n *\n * @param str - The string to trim.\n * @param suffix - The suffix to remove from the end of the string.\n * @param validate - If true, throws an error if the string does not end with the suffix.\n * @returns The trimmed string.\n * @throws If `validate` is true and the string does not end with the suffix.\n */\nexport function trimEnd(str: string, suffix: string, validate?: boolean): string {\n  if (str.endsWith(suffix)) {\n    return str.slice(0, -suffix.length);\n  }\n\n  if (validate) {\n    throw new Error(`String ${str} does not end with suffix ${suffix}`);\n  }\n\n  return str;\n}\n\n/**\n * Normalizes a string by converting it to the NFC form and replacing non-breaking spaces with regular spaces.\n *\n * @param str - The string to normalize.\n * @returns The normalized string.\n */\nexport function normalize(str: string): string {\n  return str.replace(/\\u00A0/g, \" \").normalize(\"NFC\");\n}\n\n/**\n * Asynchronously replaces all occurrences of a search string or pattern with the results of an asynchronous replacer function.\n *\n * @template Args - The type of additional arguments passed to the replacer function.\n * @param str - The string in which to perform replacements.\n * @param searchValue - The string or regular expression to search for.\n * @param replacer - An asynchronous function that generates replacement strings.\n * @returns A promise that resolves to the string with all replacements made.\n */\nexport async function replaceAllAsync<Args extends unknown[]>(\n  str: string,\n  searchValue: string | RegExp,\n  replacer: AsyncReplacer<Args>\n): Promise<string> {\n  const replacementPromises: Promise<string>[] = [];\n\n  str.replaceAll(searchValue, (substring: string, ...args: unknown[]) => {\n    replacementPromises.push(resolveValue(replacer, substring, ...args as [...Args]));\n    return substring;\n  });\n  const replacements = await Promise.all(replacementPromises);\n  return str.replaceAll(searchValue, (): string => replacements.shift()!);\n}\n\n/**\n * Converts a string into a valid JavaScript variable name by replacing invalid characters with underscores.\n *\n * @param str - The string to convert.\n * @returns The valid variable name.\n */\nexport function makeValidVariableName(str: string): string {\n  return str.replace(/[^a-zA-Z0-9_]/g, \"_\");\n}\n\n/**\n * Ensures that a string starts with the specified prefix, adding it if necessary.\n *\n * @param str - The string to check.\n * @param prefix - The prefix to ensure.\n * @returns The string that starts with the prefix.\n */\nexport function ensureStartsWith(str: string, prefix: string): string {\n  return str.startsWith(prefix) ? str : prefix + str;\n}\n\n/**\n * Ensures that a string ends with the specified suffix, adding it if necessary.\n *\n * @param str - The string to check.\n * @param suffix - The suffix to ensure.\n * @returns The string that ends with the suffix.\n */\nexport function ensureEndsWith(str: string, suffix: string): string {\n  return str.endsWith(suffix) ? str : str + suffix;\n}\n\n/**\n * Escapes special characters in a string.\n *\n * @param str - The string to escape.\n * @returns The escaped string.\n */\nexport function escape(str: string): string {\n  return replace(str, ESCAPE_MAP);\n}\n\n/**\n * Unescapes a string by replacing escape sequences with their corresponding characters.\n *\n * @param str - The string to unescape.\n * @returns The unescaped string.\n */\nexport function unescape(str: string): string {\n  return replace(str, UNESCAPE_MAP);\n}\n\n/**\n * Replaces occurrences of strings in a given string based on a replacements map.\n *\n * @param str - The string to perform replacements on.\n * @param replacementsMap - An object mapping strings to their replacement values.\n * @returns The modified string with replacements applied.\n */\nexport function replace(str: string, replacementsMap: Record<string, string>): string {\n  const regExp = new RegExp(Object.keys(replacementsMap).map((source) => escapeRegExp(source)).join(\"|\"), \"g\");\n  return str.replaceAll(regExp, (source: string) => replacementsMap[source] as string);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,oBAA6B;AAC7B,2BAGO;AAfP,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI,QAAQ,UAAU,EAAE,cAAc,UAAU,GAAG;AAC7G,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAiBA,MAAM,aAAqC;AAAA,EACzC,MAAM;AAAA,EACN,KAAM;AAAA,EACN,KAAM;AAAA,EACN,MAAM;AAAA,EACN,MAAM;AAAA,EACN,KAAM;AAAA,EACN,MAAM;AAAA,EACN,MAAM;AACR;AAKA,MAAM,eAAuC,CAAC;AAC9C,WAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,UAAU,GAAG;AACrD,eAAa,KAAK,IAAI;AACxB;AAWO,SAAS,UAAU,KAAa,QAAgB,UAA4B;AACjF,MAAI,IAAI,WAAW,MAAM,GAAG;AAC1B,WAAO,IAAI,MAAM,OAAO,MAAM;AAAA,EAChC;AAEA,MAAI,UAAU;AACZ,UAAM,IAAI,MAAM,UAAU,GAAG,+BAA+B,MAAM,EAAE;AAAA,EACtE;AAEA,SAAO;AACT;AAWO,SAAS,QAAQ,KAAa,QAAgB,UAA4B;AAC/E,MAAI,IAAI,SAAS,MAAM,GAAG;AACxB,WAAO,IAAI,MAAM,GAAG,CAAC,OAAO,MAAM;AAAA,EACpC;AAEA,MAAI,UAAU;AACZ,UAAM,IAAI,MAAM,UAAU,GAAG,6BAA6B,MAAM,EAAE;AAAA,EACpE;AAEA,SAAO;AACT;AAQO,SAAS,UAAU,KAAqB;AAC7C,SAAO,IAAI,QAAQ,WAAW,GAAG,EAAE,UAAU,KAAK;AACpD;AAWA,eAAsB,gBACpB,KACA,aACA,UACiB;AACjB,QAAM,sBAAyC,CAAC;AAEhD,MAAI,WAAW,aAAa,CAAC,cAAsB,SAAoB;AACrE,wBAAoB,SAAK,mCAAa,UAAU,WAAW,GAAG,IAAiB,CAAC;AAChF,WAAO;AAAA,EACT,CAAC;AACD,QAAM,eAAe,MAAM,QAAQ,IAAI,mBAAmB;AAC1D,SAAO,IAAI,WAAW,aAAa,MAAc,aAAa,MAAM,CAAE;AACxE;AAQO,SAAS,sBAAsB,KAAqB;AACzD,SAAO,IAAI,QAAQ,kBAAkB,GAAG;AAC1C;AASO,SAAS,iBAAiB,KAAa,QAAwB;AACpE,SAAO,IAAI,WAAW,MAAM,IAAI,MAAM,SAAS;AACjD;AASO,SAAS,eAAe,KAAa,QAAwB;AAClE,SAAO,IAAI,SAAS,MAAM,IAAI,MAAM,MAAM;AAC5C;AAQO,SAAS,OAAO,KAAqB;AAC1C,SAAO,QAAQ,KAAK,UAAU;AAChC;AAQO,SAAS,SAAS,KAAqB;AAC5C,SAAO,QAAQ,KAAK,YAAY;AAClC;AASO,SAAS,QAAQ,KAAa,iBAAiD;AACpF,QAAM,SAAS,IAAI,OAAO,OAAO,KAAK,eAAe,EAAE,IAAI,CAAC,eAAW,4BAAa,MAAM,CAAC,EAAE,KAAK,GAAG,GAAG,GAAG;AAC3G,SAAO,IAAI,WAAW,QAAQ,CAAC,WAAmB,gBAAgB,MAAM,CAAW;AACrF;",
  "names": []
}

122
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/String.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation String\n * Contains utility functions for string operations.\n */\n\nimport { escapeRegExp } from \"./RegExp.ts\";\nimport {\n  resolveValue,\n  type ValueProvider\n} from \"./ValueProvider.ts\";\n\ntype AsyncReplacer<Args extends unknown[]> = ValueProvider<string, [string, ...Args]>;\n\n/**\n * Mapping of special characters to their escaped counterparts.\n */\nconst ESCAPE_MAP: Record<string, string> = {\n  \"\\\\\": \"\\\\\\\\\",\n  \"\\\"\": \"\\\\\\\"\",\n  \"\\'\": \"\\\\\\'\",\n  \"\\n\": \"\\\\n\",\n  \"\\r\": \"\\\\r\",\n  \"\\t\": \"\\\\t\",\n  \"\\b\": \"\\\\b\",\n  \"\\f\": \"\\\\f\"\n} as const;\n\n/**\n * Mapping of escaped special characters to their unescaped counterparts.\n */\nconst UNESCAPE_MAP: Record<string, string> = {};\nfor (const [key, value] of Object.entries(ESCAPE_MAP)) {\n  UNESCAPE_MAP[value] = key;\n}\n\n/**\n * Trims the specified prefix from the start of a string.\n *\n * @param str - The string to trim.\n * @param prefix - The prefix to remove from the start of the string.\n * @param validate - If true, throws an error if the string does not start with the prefix.\n * @returns The trimmed string.\n * @throws If `validate` is true and the string does not start with the prefix.\n */\nexport function trimStart(str: string, prefix: string, validate?: boolean): string {\n  if (str.startsWith(prefix)) {\n    return str.slice(prefix.length);\n  }\n\n  if (validate) {\n    throw new Error(`String ${str} does not start with prefix ${prefix}`);\n  }\n\n  return str;\n}\n\n/**\n * Trims the specified suffix from the end of a string.\n *\n * @param str - The string to trim.\n * @param suffix - The suffix to remove from the end of the string.\n * @param validate - If true, throws an error if the string does not end with the suffix.\n * @returns The trimmed string.\n * @throws If `validate` is true and the string does not end with the suffix.\n */\nexport function trimEnd(str: string, suffix: string, validate?: boolean): string {\n  if (str.endsWith(suffix)) {\n    return str.slice(0, -suffix.length);\n  }\n\n  if (validate) {\n    throw new Error(`String ${str} does not end with suffix ${suffix}`);\n  }\n\n  return str;\n}\n\n/**\n * Normalizes a string by converting it to the NFC form and replacing non-breaking spaces with regular spaces.\n *\n * @param str - The string to normalize.\n * @returns The normalized string.\n */\nexport function normalize(str: string): string {\n  return str.replace(/\\u00A0/g, \" \").normalize(\"NFC\");\n}\n\n/**\n * Asynchronously replaces all occurrences of a search string or pattern with the results of an asynchronous replacer function.\n *\n * @typeParam Args - The type of additional arguments passed to the replacer function.\n * @param str - The string in which to perform replacements.\n * @param searchValue - The string or regular expression to search for.\n * @param replacer - An asynchronous function that generates replacement strings.\n * @returns A promise that resolves to the string with all replacements made.\n */\nexport async function replaceAllAsync<Args extends unknown[]>(\n  str: string,\n  searchValue: string | RegExp,\n  replacer: AsyncReplacer<Args>\n): Promise<string> {\n  const replacementPromises: Promise<string>[] = [];\n\n  str.replaceAll(searchValue, (substring: string, ...args: unknown[]) => {\n    replacementPromises.push(resolveValue(replacer, substring, ...args as [...Args]));\n    return substring;\n  });\n  const replacements = await Promise.all(replacementPromises);\n  return str.replaceAll(searchValue, (): string => replacements.shift()!);\n}\n\n/**\n * Converts a string into a valid JavaScript variable name by replacing invalid characters with underscores.\n *\n * @param str - The string to convert.\n * @returns The valid variable name.\n */\nexport function makeValidVariableName(str: string): string {\n  return str.replace(/[^a-zA-Z0-9_]/g, \"_\");\n}\n\n/**\n * Ensures that a string starts with the specified prefix, adding it if necessary.\n *\n * @param str - The string to check.\n * @param prefix - The prefix to ensure.\n * @returns The string that starts with the prefix.\n */\nexport function ensureStartsWith(str: string, prefix: string): string {\n  return str.startsWith(prefix) ? str : prefix + str;\n}\n\n/**\n * Ensures that a string ends with the specified suffix, adding it if necessary.\n *\n * @param str - The string to check.\n * @param suffix - The suffix to ensure.\n * @returns The string that ends with the suffix.\n */\nexport function ensureEndsWith(str: string, suffix: string): string {\n  return str.endsWith(suffix) ? str : str + suffix;\n}\n\n/**\n * Escapes special characters in a string.\n *\n * @param str - The string to escape.\n * @returns The escaped string.\n */\nexport function escape(str: string): string {\n  return replace(str, ESCAPE_MAP);\n}\n\n/**\n * Unescapes a string by replacing escape sequences with their corresponding characters.\n *\n * @param str - The string to unescape.\n * @returns The unescaped string.\n */\nexport function unescape(str: string): string {\n  return replace(str, UNESCAPE_MAP);\n}\n\n/**\n * Replaces occurrences of strings in a given string based on a replacements map.\n *\n * @param str - The string to perform replacements on.\n * @param replacementsMap - An object mapping strings to their replacement values.\n * @returns The modified string with replacements applied.\n */\nexport function replace(str: string, replacementsMap: Record<string, string>): string {\n  const regExp = new RegExp(Object.keys(replacementsMap).map((source) => escapeRegExp(source)).join(\"|\"), \"g\");\n  return str.replaceAll(regExp, (source: string) => replacementsMap[source] as string);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,oBAA6B;AAC7B,2BAGO;AAfP,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI,QAAQ,UAAU,EAAE,cAAc,UAAU,GAAG;AAC7G,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAiBA,MAAM,aAAqC;AAAA,EACzC,MAAM;AAAA,EACN,KAAM;AAAA,EACN,KAAM;AAAA,EACN,MAAM;AAAA,EACN,MAAM;AAAA,EACN,KAAM;AAAA,EACN,MAAM;AAAA,EACN,MAAM;AACR;AAKA,MAAM,eAAuC,CAAC;AAC9C,WAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,UAAU,GAAG;AACrD,eAAa,KAAK,IAAI;AACxB;AAWO,SAAS,UAAU,KAAa,QAAgB,UAA4B;AACjF,MAAI,IAAI,WAAW,MAAM,GAAG;AAC1B,WAAO,IAAI,MAAM,OAAO,MAAM;AAAA,EAChC;AAEA,MAAI,UAAU;AACZ,UAAM,IAAI,MAAM,UAAU,GAAG,+BAA+B,MAAM,EAAE;AAAA,EACtE;AAEA,SAAO;AACT;AAWO,SAAS,QAAQ,KAAa,QAAgB,UAA4B;AAC/E,MAAI,IAAI,SAAS,MAAM,GAAG;AACxB,WAAO,IAAI,MAAM,GAAG,CAAC,OAAO,MAAM;AAAA,EACpC;AAEA,MAAI,UAAU;AACZ,UAAM,IAAI,MAAM,UAAU,GAAG,6BAA6B,MAAM,EAAE;AAAA,EACpE;AAEA,SAAO;AACT;AAQO,SAAS,UAAU,KAAqB;AAC7C,SAAO,IAAI,QAAQ,WAAW,GAAG,EAAE,UAAU,KAAK;AACpD;AAWA,eAAsB,gBACpB,KACA,aACA,UACiB;AACjB,QAAM,sBAAyC,CAAC;AAEhD,MAAI,WAAW,aAAa,CAAC,cAAsB,SAAoB;AACrE,wBAAoB,SAAK,mCAAa,UAAU,WAAW,GAAG,IAAiB,CAAC;AAChF,WAAO;AAAA,EACT,CAAC;AACD,QAAM,eAAe,MAAM,QAAQ,IAAI,mBAAmB;AAC1D,SAAO,IAAI,WAAW,aAAa,MAAc,aAAa,MAAM,CAAE;AACxE;AAQO,SAAS,sBAAsB,KAAqB;AACzD,SAAO,IAAI,QAAQ,kBAAkB,GAAG;AAC1C;AASO,SAAS,iBAAiB,KAAa,QAAwB;AACpE,SAAO,IAAI,WAAW,MAAM,IAAI,MAAM,SAAS;AACjD;AASO,SAAS,eAAe,KAAa,QAAwB;AAClE,SAAO,IAAI,SAAS,MAAM,IAAI,MAAM,MAAM;AAC5C;AAQO,SAAS,OAAO,KAAqB;AAC1C,SAAO,QAAQ,KAAK,UAAU;AAChC;AAQO,SAAS,SAAS,KAAqB;AAC5C,SAAO,QAAQ,KAAK,YAAY;AAClC;AASO,SAAS,QAAQ,KAAa,iBAAiD;AACpF,QAAM,SAAS,IAAI,OAAO,OAAO,KAAK,eAAe,EAAE,IAAI,CAAC,eAAW,4BAAa,MAAM,CAAC,EAAE,KAAK,GAAG,GAAG,GAAG;AAC3G,SAAO,IAAI,WAAW,QAAQ,CAAC,WAAmB,gBAAgB,MAAM,CAAW;AACrF;",
  "names": []
}

@@ -1,5 +1,5 @@
1
1
  /**
2
- * @module String
2
+ * @packageDocumentation String
3
3
  * Contains utility functions for string operations.
4
4
  */
5
5
  import { type ValueProvider } from "./ValueProvider.ts";
@@ -34,7 +34,7 @@ export declare function normalize(str: string): string;
34
34
  /**
35
35
  * Asynchronously replaces all occurrences of a search string or pattern with the results of an asynchronous replacer function.
36
36
  *
37
- * @template Args - The type of additional arguments passed to the replacer function.
37
+ * @typeParam Args - The type of additional arguments passed to the replacer function.
38
38
  * @param str - The string in which to perform replacements.
39
39
  * @param searchValue - The string or regular expression to search for.
40
40
  * @param replacer - An asynchronous function that generates replacement strings.
@@ -46,4 +46,4 @@ async function resolveValue(provider, ...args) {
46
46
  0 && (module.exports = {
47
47
  resolveValue
48
48
  });
49
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL1ZhbHVlUHJvdmlkZXIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX2ltcG9ydF9tZXRhX3VybCA9IGdsb2JhbFRoaXNbXCJpbXBvcnQubWV0YS51cmxcIl0gPz8gKCgpPT5yZXF1aXJlKFwibm9kZTp1cmxcIikucGF0aFRvRmlsZVVSTChfX2ZpbGVuYW1lKSkoKTtcbnZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzW1wicHJvY2Vzc1wiXSA/PyB7XG4gIFwiY3dkXCI6ICgpPT5cIi9cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBtb2R1bGUgVmFsdWVQcm92aWRlclxuICogQ29udGFpbnMgdXRpbGl0eSB0eXBlcyBhbmQgZnVuY3Rpb25zIGZvciBoYW5kbGluZyB2YWx1ZSBwcm92aWRlcnMsIHdoaWNoIGNhbiBiZSBlaXRoZXIgZGlyZWN0IHZhbHVlcyBvciBmdW5jdGlvbnMgdGhhdCByZXR1cm4gdmFsdWVzLlxuICovXG5cbmltcG9ydCB0eXBlIHsgTWF5YmVQcm9taXNlIH0gZnJvbSBcIi4vQXN5bmMudHNcIjtcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgdmFsdWUgcHJvdmlkZXIgdGhhdCBjYW4gZWl0aGVyIGJlIGEgZGlyZWN0IHZhbHVlIG9mIHR5cGUgYFZhbHVlYCBvciBhIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBhIHZhbHVlIG9mIHR5cGUgYFZhbHVlYC5cbiAqXG4gKiBAdGVtcGxhdGUgVmFsdWUgLSBUaGUgdHlwZSBvZiB0aGUgdmFsdWUgcHJvdmlkZWQuXG4gKiBAdGVtcGxhdGUgQXJncyAtIFRoZSB0eXBlcyBvZiBhcmd1bWVudHMgcGFzc2VkIHRvIHRoZSBmdW5jdGlvbiBpZiB0aGUgcHJvdmlkZXIgaXMgYSBmdW5jdGlvbi5cbiAqL1xuZXhwb3J0IHR5cGUgVmFsdWVQcm92aWRlcjxWYWx1ZSwgQXJncyBleHRlbmRzIHVua25vd25bXSA9IFtdPiA9IFZhbHVlIHwgKCguLi5hcmdzOiBBcmdzKSA9PiBNYXliZVByb21pc2U8VmFsdWU+KTtcblxuLyoqXG4gKiBEZXRlcm1pbmVzIHdoZXRoZXIgYSBnaXZlbiB2YWx1ZSBwcm92aWRlciBpcyBhIGZ1bmN0aW9uLlxuICpcbiAqIEB0ZW1wbGF0ZSBWYWx1ZSAtIFRoZSB0eXBlIG9mIHRoZSB2YWx1ZSBwcm92aWRlZC5cbiAqIEB0ZW1wbGF0ZSBBcmdzIC0gVGhlIHR5cGVzIG9mIGFyZ3VtZW50cyBwYXNzZWQgdG8gdGhlIGZ1bmN0aW9uIGlmIHRoZSBwcm92aWRlciBpcyBhIGZ1bmN0aW9uLlxuICogQHBhcmFtIHZhbHVlIC0gVGhlIHZhbHVlIHByb3ZpZGVyIHRvIGNoZWNrLlxuICogQHJldHVybnMgYHRydWVgIGlmIHRoZSB2YWx1ZSBwcm92aWRlciBpcyBhIGZ1bmN0aW9uLCBvdGhlcndpc2UgYGZhbHNlYC5cbiAqL1xuZnVuY3Rpb24gaXNGdW5jdGlvbjxWYWx1ZSwgQXJncyBleHRlbmRzIHVua25vd25bXT4odmFsdWU6IFZhbHVlUHJvdmlkZXI8VmFsdWUsIEFyZ3M+KTogdmFsdWUgaXMgKC4uLmFyZ3M6IEFyZ3MpID0+IE1heWJlUHJvbWlzZTxWYWx1ZT4ge1xuICByZXR1cm4gdHlwZW9mIHZhbHVlID09PSBcImZ1bmN0aW9uXCI7XG59XG5cbi8qKlxuICogUmVzb2x2ZXMgYSB2YWx1ZSBmcm9tIGEgdmFsdWUgcHJvdmlkZXIsIHdoaWNoIGNhbiBiZSBlaXRoZXIgYSBkaXJlY3QgdmFsdWUgb3IgYSBmdW5jdGlvbiB0aGF0IHJldHVybnMgYSB2YWx1ZS5cbiAqXG4gKiBAdGVtcGxhdGUgQXJncyAtIFRoZSB0eXBlcyBvZiBhcmd1bWVudHMgcGFzc2VkIHRvIHRoZSBmdW5jdGlvbiBpZiB0aGUgcHJvdmlkZXIgaXMgYSBmdW5jdGlvbi5cbiAqIEB0ZW1wbGF0ZSBWYWx1ZSAtIFRoZSB0eXBlIG9mIHRoZSB2YWx1ZSBwcm92aWRlZC5cbiAqIEBwYXJhbSBwcm92aWRlciAtIFRoZSB2YWx1ZSBwcm92aWRlciB0byByZXNvbHZlLlxuICogQHBhcmFtIGFyZ3MgLSBUaGUgYXJndW1lbnRzIHRvIHBhc3MgdG8gdGhlIGZ1bmN0aW9uIGlmIHRoZSBwcm92aWRlciBpcyBhIGZ1bmN0aW9uLlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2l0aCB0aGUgdmFsdWUgcHJvdmlkZWQgYnkgdGhlIHZhbHVlIHByb3ZpZGVyLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcmVzb2x2ZVZhbHVlPFZhbHVlLCBBcmdzIGV4dGVuZHMgdW5rbm93bltdPihwcm92aWRlcjogVmFsdWVQcm92aWRlcjxWYWx1ZSwgQXJncz4sIC4uLmFyZ3M6IEFyZ3MpOiBQcm9taXNlPFZhbHVlPiB7XG4gIGlmIChpc0Z1bmN0aW9uKHByb3ZpZGVyKSkge1xuICAgIHJldHVybiBhd2FpdCBwcm92aWRlciguLi5hcmdzKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gcHJvdmlkZXI7XG4gIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBQUksb0JBQW9CLFdBQVcsaUJBQWlCLE1BQU0sTUFBSSxRQUFRLFVBQVUsRUFBRSxjQUFjLFVBQVUsR0FBRztBQUM3RyxJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxPQUFPLE1BQUk7QUFBQSxFQUNYLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBd0JBLFNBQVMsV0FBMEMsT0FBb0Y7QUFDckksU0FBTyxPQUFPLFVBQVU7QUFDMUI7QUFXQSxlQUFzQixhQUE0QyxhQUF5QyxNQUE0QjtBQUNySSxNQUFJLFdBQVcsUUFBUSxHQUFHO0FBQ3hCLFdBQU8sTUFBTSxTQUFTLEdBQUcsSUFBSTtBQUFBLEVBQy9CLE9BQU87QUFDTCxXQUFPO0FBQUEsRUFDVDtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
49
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL1ZhbHVlUHJvdmlkZXIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX2ltcG9ydF9tZXRhX3VybCA9IGdsb2JhbFRoaXNbXCJpbXBvcnQubWV0YS51cmxcIl0gPz8gKCgpPT5yZXF1aXJlKFwibm9kZTp1cmxcIikucGF0aFRvRmlsZVVSTChfX2ZpbGVuYW1lKSkoKTtcbnZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzW1wicHJvY2Vzc1wiXSA/PyB7XG4gIFwiY3dkXCI6ICgpPT5cIi9cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBWYWx1ZVByb3ZpZGVyXG4gKiBDb250YWlucyB1dGlsaXR5IHR5cGVzIGFuZCBmdW5jdGlvbnMgZm9yIGhhbmRsaW5nIHZhbHVlIHByb3ZpZGVycywgd2hpY2ggY2FuIGJlIGVpdGhlciBkaXJlY3QgdmFsdWVzIG9yIGZ1bmN0aW9ucyB0aGF0IHJldHVybiB2YWx1ZXMuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBNYXliZVByb21pc2UgfSBmcm9tIFwiLi9Bc3luYy50c1wiO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSB2YWx1ZSBwcm92aWRlciB0aGF0IGNhbiBlaXRoZXIgYmUgYSBkaXJlY3QgdmFsdWUgb2YgdHlwZSBgVmFsdWVgIG9yIGEgZnVuY3Rpb24gdGhhdCByZXR1cm5zIGEgdmFsdWUgb2YgdHlwZSBgVmFsdWVgLlxuICpcbiAqIEB0eXBlUGFyYW0gVmFsdWUgLSBUaGUgdHlwZSBvZiB0aGUgdmFsdWUgcHJvdmlkZWQuXG4gKiBAdHlwZVBhcmFtIEFyZ3MgLSBUaGUgdHlwZXMgb2YgYXJndW1lbnRzIHBhc3NlZCB0byB0aGUgZnVuY3Rpb24gaWYgdGhlIHByb3ZpZGVyIGlzIGEgZnVuY3Rpb24uXG4gKi9cbmV4cG9ydCB0eXBlIFZhbHVlUHJvdmlkZXI8VmFsdWUsIEFyZ3MgZXh0ZW5kcyB1bmtub3duW10gPSBbXT4gPSBWYWx1ZSB8ICgoLi4uYXJnczogQXJncykgPT4gTWF5YmVQcm9taXNlPFZhbHVlPik7XG5cbi8qKlxuICogRGV0ZXJtaW5lcyB3aGV0aGVyIGEgZ2l2ZW4gdmFsdWUgcHJvdmlkZXIgaXMgYSBmdW5jdGlvbi5cbiAqXG4gKiBAdHlwZVBhcmFtIFZhbHVlIC0gVGhlIHR5cGUgb2YgdGhlIHZhbHVlIHByb3ZpZGVkLlxuICogQHR5cGVQYXJhbSBBcmdzIC0gVGhlIHR5cGVzIG9mIGFyZ3VtZW50cyBwYXNzZWQgdG8gdGhlIGZ1bmN0aW9uIGlmIHRoZSBwcm92aWRlciBpcyBhIGZ1bmN0aW9uLlxuICogQHBhcmFtIHZhbHVlIC0gVGhlIHZhbHVlIHByb3ZpZGVyIHRvIGNoZWNrLlxuICogQHJldHVybnMgYHRydWVgIGlmIHRoZSB2YWx1ZSBwcm92aWRlciBpcyBhIGZ1bmN0aW9uLCBvdGhlcndpc2UgYGZhbHNlYC5cbiAqL1xuZnVuY3Rpb24gaXNGdW5jdGlvbjxWYWx1ZSwgQXJncyBleHRlbmRzIHVua25vd25bXT4odmFsdWU6IFZhbHVlUHJvdmlkZXI8VmFsdWUsIEFyZ3M+KTogdmFsdWUgaXMgKC4uLmFyZ3M6IEFyZ3MpID0+IE1heWJlUHJvbWlzZTxWYWx1ZT4ge1xuICByZXR1cm4gdHlwZW9mIHZhbHVlID09PSBcImZ1bmN0aW9uXCI7XG59XG5cbi8qKlxuICogUmVzb2x2ZXMgYSB2YWx1ZSBmcm9tIGEgdmFsdWUgcHJvdmlkZXIsIHdoaWNoIGNhbiBiZSBlaXRoZXIgYSBkaXJlY3QgdmFsdWUgb3IgYSBmdW5jdGlvbiB0aGF0IHJldHVybnMgYSB2YWx1ZS5cbiAqXG4gKiBAdHlwZVBhcmFtIEFyZ3MgLSBUaGUgdHlwZXMgb2YgYXJndW1lbnRzIHBhc3NlZCB0byB0aGUgZnVuY3Rpb24gaWYgdGhlIHByb3ZpZGVyIGlzIGEgZnVuY3Rpb24uXG4gKiBAdHlwZVBhcmFtIFZhbHVlIC0gVGhlIHR5cGUgb2YgdGhlIHZhbHVlIHByb3ZpZGVkLlxuICogQHBhcmFtIHByb3ZpZGVyIC0gVGhlIHZhbHVlIHByb3ZpZGVyIHRvIHJlc29sdmUuXG4gKiBAcGFyYW0gYXJncyAtIFRoZSBhcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgZnVuY3Rpb24gaWYgdGhlIHByb3ZpZGVyIGlzIGEgZnVuY3Rpb24uXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB3aXRoIHRoZSB2YWx1ZSBwcm92aWRlZCBieSB0aGUgdmFsdWUgcHJvdmlkZXIuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiByZXNvbHZlVmFsdWU8VmFsdWUsIEFyZ3MgZXh0ZW5kcyB1bmtub3duW10+KHByb3ZpZGVyOiBWYWx1ZVByb3ZpZGVyPFZhbHVlLCBBcmdzPiwgLi4uYXJnczogQXJncyk6IFByb21pc2U8VmFsdWU+IHtcbiAgaWYgKGlzRnVuY3Rpb24ocHJvdmlkZXIpKSB7XG4gICAgcmV0dXJuIGF3YWl0IHByb3ZpZGVyKC4uLmFyZ3MpO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiBwcm92aWRlcjtcbiAgfVxufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFBSSxvQkFBb0IsV0FBVyxpQkFBaUIsTUFBTSxNQUFJLFFBQVEsVUFBVSxFQUFFLGNBQWMsVUFBVSxHQUFHO0FBQzdHLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSztBQUFBLEVBQ3ZDLE9BQU8sTUFBSTtBQUFBLEVBQ1gsT0FBTyxDQUFDO0FBQUEsRUFDUixZQUFZO0FBQ2Q7QUF3QkEsU0FBUyxXQUEwQyxPQUFvRjtBQUNySSxTQUFPLE9BQU8sVUFBVTtBQUMxQjtBQVdBLGVBQXNCLGFBQTRDLGFBQXlDLE1BQTRCO0FBQ3JJLE1BQUksV0FBVyxRQUFRLEdBQUc7QUFDeEIsV0FBTyxNQUFNLFNBQVMsR0FBRyxJQUFJO0FBQUEsRUFDL0IsT0FBTztBQUNMLFdBQU87QUFBQSxFQUNUO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -1,20 +1,20 @@
1
1
  /**
2
- * @module ValueProvider
2
+ * @packageDocumentation ValueProvider
3
3
  * Contains utility types and functions for handling value providers, which can be either direct values or functions that return values.
4
4
  */
5
5
  import type { MaybePromise } from "./Async.ts";
6
6
  /**
7
7
  * Represents a value provider that can either be a direct value of type `Value` or a function that returns a value of type `Value`.
8
8
  *
9
- * @template Value - The type of the value provided.
10
- * @template Args - The types of arguments passed to the function if the provider is a function.
9
+ * @typeParam Value - The type of the value provided.
10
+ * @typeParam Args - The types of arguments passed to the function if the provider is a function.
11
11
  */
12
12
  export type ValueProvider<Value, Args extends unknown[] = []> = Value | ((...args: Args) => MaybePromise<Value>);
13
13
  /**
14
14
  * Resolves a value from a value provider, which can be either a direct value or a function that returns a value.
15
15
  *
16
- * @template Args - The types of arguments passed to the function if the provider is a function.
17
- * @template Value - The type of the value provided.
16
+ * @typeParam Args - The types of arguments passed to the function if the provider is a function.
17
+ * @typeParam Value - The type of the value provided.
18
18
  * @param provider - The value provider to resolve.
19
19
  * @param args - The arguments to pass to the function if the provider is a function.
20
20
  * @returns A promise that resolves with the value provided by the value provider.
@@ -0,0 +1,10 @@
1
+ /**
2
+ * @packageDocumentation \@guardian/eslint-plugin-tsdoc-required
3
+ * @see {@link https://www.npmjs.com/package/@guardian/eslint-plugin-tsdoc-required} for more information.
4
+ */
5
+
6
+ declare module "@guardian/eslint-plugin-tsdoc-required" {
7
+ import type { ESLint } from "eslint";
8
+ const plugin: ESLint.Plugin;
9
+ export default plugin;
10
+ }
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @module @stylistic/eslint-plugin
2
+ * @packageDocumentation \@stylistic/eslint-plugin
3
3
  * @see {@link https://www.npmjs.com/package/@stylistic/eslint-plugin} for more information.
4
4
  */
5
5