obsidian-dev-utils 23.0.5 → 24.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/README.md +1 -1
  3. package/dist/lib/cjs/Async.cjs +3 -3
  4. package/dist/lib/cjs/Async.d.cts +2 -2
  5. package/dist/lib/cjs/Library.cjs +1 -1
  6. package/dist/lib/cjs/Path.cjs +6 -6
  7. package/dist/lib/cjs/Path.d.cts +9 -7
  8. package/dist/lib/cjs/ScriptUtils/ESLint/ESLint.cjs +6 -6
  9. package/dist/lib/cjs/ScriptUtils/ESLint/eslint.config.cjs +2 -2
  10. package/dist/lib/cjs/ScriptUtils/Exec.cjs +1 -1
  11. package/dist/lib/cjs/ScriptUtils/Exec.d.cts +1 -1
  12. package/dist/lib/cjs/ScriptUtils/Fs.cjs +1 -1
  13. package/dist/lib/cjs/ScriptUtils/Fs.d.cts +2 -0
  14. package/dist/lib/cjs/ScriptUtils/Npm.cjs +1 -1
  15. package/dist/lib/cjs/ScriptUtils/Npm.d.cts +23 -23
  16. package/dist/lib/cjs/ScriptUtils/ObsidianDevUtilsRepoPaths.cjs +3 -3
  17. package/dist/lib/cjs/ScriptUtils/ObsidianDevUtilsRepoPaths.d.cts +15 -15
  18. package/dist/lib/cjs/ScriptUtils/Root.cjs +17 -17
  19. package/dist/lib/cjs/ScriptUtils/Root.d.cts +15 -15
  20. package/dist/lib/cjs/ScriptUtils/build.cjs +1 -1
  21. package/dist/lib/cjs/ScriptUtils/build.d.cts +7 -7
  22. package/dist/lib/cjs/ScriptUtils/cli.cjs +4 -4
  23. package/dist/lib/cjs/ScriptUtils/esbuild/Dependency.cjs +2 -2
  24. package/dist/lib/cjs/ScriptUtils/esbuild/ObsidianPluginBuilder.cjs +14 -14
  25. package/dist/lib/cjs/ScriptUtils/esbuild/ObsidianPluginBuilder.d.cts +3 -3
  26. package/dist/lib/cjs/ScriptUtils/esbuild/copyToObsidianPluginsFolderPlugin.cjs +18 -12
  27. package/dist/lib/cjs/ScriptUtils/esbuild/copyToObsidianPluginsFolderPlugin.d.cts +4 -4
  28. package/dist/lib/cjs/ScriptUtils/esbuild/renameCssPlugin.cjs +4 -4
  29. package/dist/lib/cjs/ScriptUtils/esbuild/renameCssPlugin.d.cts +2 -2
  30. package/dist/lib/cjs/ScriptUtils/format.cjs +8 -8
  31. package/dist/lib/cjs/ScriptUtils/spellcheck.cjs +1 -1
  32. package/dist/lib/cjs/ScriptUtils/spellcheck.d.cts +1 -1
  33. package/dist/lib/cjs/ScriptUtils/version.cjs +4 -4
  34. package/dist/lib/cjs/ScriptUtils/version.d.cts +1 -1
  35. package/dist/lib/cjs/obsidian/Link.cjs +7 -7
  36. package/dist/lib/cjs/obsidian/Loop.cjs +3 -3
  37. package/dist/lib/cjs/obsidian/Loop.d.cts +1 -1
  38. package/dist/lib/cjs/obsidian/Plugin/ObsidianPluginRepoPaths.cjs +2 -2
  39. package/dist/lib/cjs/obsidian/Plugin/ObsidianPluginRepoPaths.d.cts +9 -9
  40. package/dist/lib/cjs/obsidian/Plugin/PluginBase.cjs +1 -1
  41. package/dist/lib/cjs/obsidian/Plugin/PluginBase.d.cts +1 -1
  42. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.cjs +1 -1
  43. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsManagerBase.d.cts +1 -1
  44. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.cjs +1 -1
  45. package/dist/lib/cjs/obsidian/Plugin/PluginSettingsTabBase.d.cts +1 -1
  46. package/dist/lib/cjs/obsidian/RenameDeleteHandler.cjs +4 -4
  47. package/dist/lib/cjs/obsidian/Vault.cjs +3 -3
  48. package/dist/lib/esm/Async.d.mts +2 -2
  49. package/dist/lib/esm/Async.mjs +3 -3
  50. package/dist/lib/esm/Library.mjs +1 -1
  51. package/dist/lib/esm/Path.d.mts +9 -7
  52. package/dist/lib/esm/Path.mjs +5 -5
  53. package/dist/lib/esm/ScriptUtils/ESLint/ESLint.mjs +8 -8
  54. package/dist/lib/esm/ScriptUtils/ESLint/eslint.config.mjs +3 -3
  55. package/dist/lib/esm/ScriptUtils/Exec.d.mts +1 -1
  56. package/dist/lib/esm/ScriptUtils/Exec.mjs +1 -1
  57. package/dist/lib/esm/ScriptUtils/Fs.d.mts +2 -0
  58. package/dist/lib/esm/ScriptUtils/Fs.mjs +1 -1
  59. package/dist/lib/esm/ScriptUtils/Npm.d.mts +23 -23
  60. package/dist/lib/esm/ScriptUtils/Npm.mjs +1 -1
  61. package/dist/lib/esm/ScriptUtils/ObsidianDevUtilsRepoPaths.d.mts +15 -15
  62. package/dist/lib/esm/ScriptUtils/ObsidianDevUtilsRepoPaths.mjs +3 -3
  63. package/dist/lib/esm/ScriptUtils/Root.d.mts +15 -15
  64. package/dist/lib/esm/ScriptUtils/Root.mjs +16 -16
  65. package/dist/lib/esm/ScriptUtils/build.d.mts +7 -7
  66. package/dist/lib/esm/ScriptUtils/build.mjs +1 -1
  67. package/dist/lib/esm/ScriptUtils/cli.mjs +5 -5
  68. package/dist/lib/esm/ScriptUtils/esbuild/Dependency.mjs +3 -3
  69. package/dist/lib/esm/ScriptUtils/esbuild/ObsidianPluginBuilder.d.mts +3 -3
  70. package/dist/lib/esm/ScriptUtils/esbuild/ObsidianPluginBuilder.mjs +14 -14
  71. package/dist/lib/esm/ScriptUtils/esbuild/copyToObsidianPluginsFolderPlugin.d.mts +4 -4
  72. package/dist/lib/esm/ScriptUtils/esbuild/copyToObsidianPluginsFolderPlugin.mjs +18 -12
  73. package/dist/lib/esm/ScriptUtils/esbuild/renameCssPlugin.d.mts +2 -2
  74. package/dist/lib/esm/ScriptUtils/esbuild/renameCssPlugin.mjs +4 -4
  75. package/dist/lib/esm/ScriptUtils/format.mjs +10 -10
  76. package/dist/lib/esm/ScriptUtils/spellcheck.d.mts +1 -1
  77. package/dist/lib/esm/ScriptUtils/spellcheck.mjs +1 -1
  78. package/dist/lib/esm/ScriptUtils/version.d.mts +1 -1
  79. package/dist/lib/esm/ScriptUtils/version.mjs +4 -4
  80. package/dist/lib/esm/obsidian/Link.mjs +7 -7
  81. package/dist/lib/esm/obsidian/Loop.d.mts +1 -1
  82. package/dist/lib/esm/obsidian/Loop.mjs +3 -3
  83. package/dist/lib/esm/obsidian/Plugin/ObsidianPluginRepoPaths.d.mts +9 -9
  84. package/dist/lib/esm/obsidian/Plugin/ObsidianPluginRepoPaths.mjs +2 -2
  85. package/dist/lib/esm/obsidian/Plugin/PluginBase.d.mts +1 -1
  86. package/dist/lib/esm/obsidian/Plugin/PluginBase.mjs +1 -1
  87. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.d.mts +1 -1
  88. package/dist/lib/esm/obsidian/Plugin/PluginSettingsManagerBase.mjs +1 -1
  89. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.d.mts +1 -1
  90. package/dist/lib/esm/obsidian/Plugin/PluginSettingsTabBase.mjs +1 -1
  91. package/dist/lib/esm/obsidian/RenameDeleteHandler.mjs +4 -4
  92. package/dist/lib/esm/obsidian/Vault.mjs +3 -3
  93. package/dist/scripts/examples/format.prettier.ts +5 -5
  94. package/package.json +1 -1
@@ -2,15 +2,15 @@
2
2
  * @packageDocumentation
3
3
  *
4
4
  * This module provides utility functions to handle the build process for static assets and cleaning
5
- * the build output directory. It includes functions to copy static files to the distribution directory
5
+ * the build output folder. It includes functions to copy static files to the distribution folder
6
6
  * and to remove the existing build output.
7
7
  */
8
8
  /**
9
- * Removes the distribution directory and its contents.
9
+ * Removes the distribution folder and its contents.
10
10
  *
11
- * This function deletes the entire distribution directory to ensure a clean build environment.
11
+ * This function deletes the entire distribution folder to ensure a clean build environment.
12
12
  *
13
- * @returns A {@link Promise} that resolves when the directory has been removed.
13
+ * @returns A {@link Promise} that resolves when the folder has been removed.
14
14
  */
15
15
  export declare function buildClean(): Promise<void>;
16
16
  /**
@@ -32,10 +32,10 @@ export declare function buildCompileSvelte(): Promise<void>;
32
32
  */
33
33
  export declare function buildCompileTypeScript(): Promise<void>;
34
34
  /**
35
- * Copies all static files from the static assets directory to the distribution directory.
35
+ * Copies all static files from the static assets folder to the distribution folder.
36
36
  *
37
- * This function recursively reads the contents of the static assets directory and copies
38
- * each file to the corresponding path in the distribution directory.
37
+ * This function recursively reads the contents of the static assets folder and copies
38
+ * each file to the corresponding path in the distribution folder.
39
39
  *
40
40
  * @returns A {@link Promise} that resolves when all files have been copied.
41
41
  */
@@ -58,4 +58,4 @@ export {
58
58
  buildCompileTypeScript,
59
59
  buildStatic
60
60
  };
61
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2J1aWxkLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIHV0aWxpdHkgZnVuY3Rpb25zIHRvIGhhbmRsZSB0aGUgYnVpbGQgcHJvY2VzcyBmb3Igc3RhdGljIGFzc2V0cyBhbmQgY2xlYW5pbmdcbiAqIHRoZSBidWlsZCBvdXRwdXQgZGlyZWN0b3J5LiBJdCBpbmNsdWRlcyBmdW5jdGlvbnMgdG8gY29weSBzdGF0aWMgZmlsZXMgdG8gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnlcbiAqIGFuZCB0byByZW1vdmUgdGhlIGV4aXN0aW5nIGJ1aWxkIG91dHB1dC5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFRzQ29uZmlnSnNvbiB9IGZyb20gJ3R5cGUtZmVzdCc7XG5cbmltcG9ydCB7IGdsb2IgfSBmcm9tICdnbG9iJztcblxuaW1wb3J0IHsgZ2V0TGliRGVidWdnZXIgfSBmcm9tICcuLi9EZWJ1Zy50cyc7XG5pbXBvcnQgeyBqb2luIH0gZnJvbSAnLi4vUGF0aC50cyc7XG5pbXBvcnQgeyB0cmltU3RhcnQgfSBmcm9tICcuLi9TdHJpbmcudHMnO1xuaW1wb3J0IHsgcmVhZGRpclBvc2l4IH0gZnJvbSAnLi9Gcy50cyc7XG5pbXBvcnQgeyByZWFkSnNvbiB9IGZyb20gJy4vSlNPTi50cyc7XG5pbXBvcnQge1xuICBjcCxcbiAgcm1cbn0gZnJvbSAnLi9Ob2RlTW9kdWxlcy50cyc7XG5pbXBvcnQgeyBucG1SdW4gfSBmcm9tICcuL05wbVJ1bi50cyc7XG5pbXBvcnQgeyBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIH0gZnJvbSAnLi9PYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7XG4gIGV4ZWNGcm9tUm9vdCxcbiAgcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmVcbn0gZnJvbSAnLi9Sb290LnRzJztcblxuLyoqXG4gKiBSZW1vdmVzIHRoZSBkaXN0cmlidXRpb24gZGlyZWN0b3J5IGFuZCBpdHMgY29udGVudHMuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBkZWxldGVzIHRoZSBlbnRpcmUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeSB0byBlbnN1cmUgYSBjbGVhbiBidWlsZCBlbnZpcm9ubWVudC5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGRpcmVjdG9yeSBoYXMgYmVlbiByZW1vdmVkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDbGVhbigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgcm0oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCB7IGZvcmNlOiB0cnVlLCByZWN1cnNpdmU6IHRydWUgfSk7XG59XG5cbi8qKlxuICogQ29tcGlsZXMgdGhlIGNvZGUuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZSgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgbnBtUnVuKCdidWlsZDpjb21waWxlOnN2ZWx0ZScpO1xuICBhd2FpdCBucG1SdW4oJ2J1aWxkOmNvbXBpbGU6dHlwZXNjcmlwdCcpO1xufVxuXG4vKipcbiAqIENvbXBpbGVzIHRoZSBTdmVsdGUgY29kZS5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGNvZGUgY29tcGlsZXMgc3VjY2Vzc2Z1bGx5LlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDb21waWxlU3ZlbHRlKCk6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCB0c0NvbmZpZ1BhdGggPSByZXNvbHZlUGF0aEZyb21Sb290U2FmZShPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlRzQ29uZmlnSnNvbik7XG4gIGNvbnN0IHRzQ29uZmlnID0gYXdhaXQgcmVhZEpzb248VHNDb25maWdKc29uPih0c0NvbmZpZ1BhdGgpO1xuICBjb25zdCBhbGxGaWxlcyA9IGF3YWl0IGdsb2IodHNDb25maWcuaW5jbHVkZSA/PyBbXSwgeyBpZ25vcmU6IHRzQ29uZmlnLmV4Y2x1ZGUgPz8gW10gfSk7XG4gIGNvbnN0IHN2ZWx0ZUZpbGVzID0gYWxsRmlsZXMuZmlsdGVyKChmaWxlKSA9PiBmaWxlLmVuZHNXaXRoKCcuc3ZlbHRlJykgfHwgZmlsZS5lbmRzV2l0aCgnLnN2ZWx0ZS5qcycpIHx8IGZpbGUuZW5kc1dpdGgoJy5zdmVsdGUudHMnKSk7XG5cbiAgaWYgKHN2ZWx0ZUZpbGVzLmxlbmd0aCA9PT0gMCkge1xuICAgIGdldExpYkRlYnVnZ2VyKCdidWlsZDpidWlsZENvbXBpbGVTdmVsdGUnKSgnTm8gU3ZlbHRlIGZpbGVzIGZvdW5kIGluIHRoZSBwcm9qZWN0LCBza2lwcGluZyBTdmVsdGUgY29tcGlsYXRpb24nKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBhd2FpdCBleGVjRnJvbVJvb3QoWyducHgnLCAnc3ZlbHRlLWNoZWNrJywgJy0tdHNjb25maWcnLCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlRzQ29uZmlnSnNvbl0pO1xufVxuXG4vKipcbiAqIENvbXBpbGVzIHRoZSBUeXBlU2NyaXB0IGNvZGUuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZVR5cGVTY3JpcHQoKTogUHJvbWlzZTx2b2lkPiB7XG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ25weCcsICd0c2MnLCAnLS1idWlsZCcsICctLWZvcmNlJ10pO1xufVxuXG4vKipcbiAqIENvcGllcyBhbGwgc3RhdGljIGZpbGVzIGZyb20gdGhlIHN0YXRpYyBhc3NldHMgZGlyZWN0b3J5IHRvIHRoZSBkaXN0cmlidXRpb24gZGlyZWN0b3J5LlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gcmVjdXJzaXZlbHkgcmVhZHMgdGhlIGNvbnRlbnRzIG9mIHRoZSBzdGF0aWMgYXNzZXRzIGRpcmVjdG9yeSBhbmQgY29waWVzXG4gKiBlYWNoIGZpbGUgdG8gdGhlIGNvcnJlc3BvbmRpbmcgcGF0aCBpbiB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gYWxsIGZpbGVzIGhhdmUgYmVlbiBjb3BpZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZFN0YXRpYygpOiBQcm9taXNlPHZvaWQ+IHtcbiAgZm9yIChjb25zdCBkaXJlbnQgb2YgYXdhaXQgcmVhZGRpclBvc2l4KE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuU3RhdGljLCB7IHJlY3Vyc2l2ZTogdHJ1ZSwgd2l0aEZpbGVUeXBlczogdHJ1ZSB9KSkge1xuICAgIGlmICghZGlyZW50LmlzRmlsZSgpKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb25zdCBwYXRoID0gdHJpbVN0YXJ0KGpvaW4oZGlyZW50LnBhcmVudFBhdGgsIGRpcmVudC5uYW1lKSwgYCR7T2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWN9L2ApO1xuICAgIGF3YWl0IGNwKGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWMsIHBhdGgpLCBqb2luKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRGlzdCwgcGF0aCkpO1xuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBVUEsU0FBUyxZQUFZO0FBRXJCLFNBQVMsc0JBQXNCO0FBQy9CLFNBQVMsWUFBWTtBQUNyQixTQUFTLGlCQUFpQjtBQUMxQixTQUFTLG9CQUFvQjtBQUM3QixTQUFTLGdCQUFnQjtBQUN6QjtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQUNQLFNBQVMsY0FBYztBQUN2QixTQUFTLGlDQUFpQztBQUMxQztBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQVNQLGVBQXNCLGFBQTRCO0FBQ2hELFFBQU0sR0FBRywwQkFBMEIsTUFBTSxFQUFFLE9BQU8sTUFBTSxXQUFXLEtBQUssQ0FBQztBQUMzRTtBQU9BLGVBQXNCLGVBQThCO0FBQ2xELFFBQU0sT0FBTyxzQkFBc0I7QUFDbkMsUUFBTSxPQUFPLDBCQUEwQjtBQUN6QztBQU9BLGVBQXNCLHFCQUFvQztBQUN4RCxRQUFNLGVBQWUsd0JBQXdCLDBCQUEwQixZQUFZO0FBQ25GLFFBQU0sV0FBVyxNQUFNLFNBQXVCLFlBQVk7QUFDMUQsUUFBTSxXQUFXLE1BQU0sS0FBSyxTQUFTLFdBQVcsQ0FBQyxHQUFHLEVBQUUsUUFBUSxTQUFTLFdBQVcsQ0FBQyxFQUFFLENBQUM7QUFDdEYsUUFBTSxjQUFjLFNBQVMsT0FBTyxDQUFDLFNBQVMsS0FBSyxTQUFTLFNBQVMsS0FBSyxLQUFLLFNBQVMsWUFBWSxLQUFLLEtBQUssU0FBUyxZQUFZLENBQUM7QUFFcEksTUFBSSxZQUFZLFdBQVcsR0FBRztBQUM1QixtQkFBZSwwQkFBMEIsRUFBRSxtRUFBbUU7QUFDOUc7QUFBQSxFQUNGO0FBRUEsUUFBTSxhQUFhLENBQUMsT0FBTyxnQkFBZ0IsY0FBYywwQkFBMEIsWUFBWSxDQUFDO0FBQ2xHO0FBT0EsZUFBc0IseUJBQXdDO0FBQzVELFFBQU0sYUFBYSxDQUFDLE9BQU8sT0FBTyxXQUFXLFNBQVMsQ0FBQztBQUN6RDtBQVVBLGVBQXNCLGNBQTZCO0FBQ2pELGFBQVcsVUFBVSxNQUFNLGFBQWEsMEJBQTBCLFFBQVEsRUFBRSxXQUFXLE1BQU0sZUFBZSxLQUFLLENBQUMsR0FBRztBQUNuSCxRQUFJLENBQUMsT0FBTyxPQUFPLEdBQUc7QUFDcEI7QUFBQSxJQUNGO0FBRUEsVUFBTSxPQUFPLFVBQVUsS0FBSyxPQUFPLFlBQVksT0FBTyxJQUFJLEdBQUcsR0FBRywwQkFBMEIsTUFBTSxHQUFHO0FBQ25HLFVBQU0sR0FBRyxLQUFLLDBCQUEwQixRQUFRLElBQUksR0FBRyxLQUFLLDBCQUEwQixNQUFNLElBQUksQ0FBQztBQUFBLEVBQ25HO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
61
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2J1aWxkLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIHV0aWxpdHkgZnVuY3Rpb25zIHRvIGhhbmRsZSB0aGUgYnVpbGQgcHJvY2VzcyBmb3Igc3RhdGljIGFzc2V0cyBhbmQgY2xlYW5pbmdcbiAqIHRoZSBidWlsZCBvdXRwdXQgZm9sZGVyLiBJdCBpbmNsdWRlcyBmdW5jdGlvbnMgdG8gY29weSBzdGF0aWMgZmlsZXMgdG8gdGhlIGRpc3RyaWJ1dGlvbiBmb2xkZXJcbiAqIGFuZCB0byByZW1vdmUgdGhlIGV4aXN0aW5nIGJ1aWxkIG91dHB1dC5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFRzQ29uZmlnSnNvbiB9IGZyb20gJ3R5cGUtZmVzdCc7XG5cbmltcG9ydCB7IGdsb2IgfSBmcm9tICdnbG9iJztcblxuaW1wb3J0IHsgZ2V0TGliRGVidWdnZXIgfSBmcm9tICcuLi9EZWJ1Zy50cyc7XG5pbXBvcnQgeyBqb2luIH0gZnJvbSAnLi4vUGF0aC50cyc7XG5pbXBvcnQgeyB0cmltU3RhcnQgfSBmcm9tICcuLi9TdHJpbmcudHMnO1xuaW1wb3J0IHsgcmVhZGRpclBvc2l4IH0gZnJvbSAnLi9Gcy50cyc7XG5pbXBvcnQgeyByZWFkSnNvbiB9IGZyb20gJy4vSlNPTi50cyc7XG5pbXBvcnQge1xuICBjcCxcbiAgcm1cbn0gZnJvbSAnLi9Ob2RlTW9kdWxlcy50cyc7XG5pbXBvcnQgeyBucG1SdW4gfSBmcm9tICcuL05wbVJ1bi50cyc7XG5pbXBvcnQgeyBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIH0gZnJvbSAnLi9PYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7XG4gIGV4ZWNGcm9tUm9vdCxcbiAgcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmVcbn0gZnJvbSAnLi9Sb290LnRzJztcblxuLyoqXG4gKiBSZW1vdmVzIHRoZSBkaXN0cmlidXRpb24gZm9sZGVyIGFuZCBpdHMgY29udGVudHMuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBkZWxldGVzIHRoZSBlbnRpcmUgZGlzdHJpYnV0aW9uIGZvbGRlciB0byBlbnN1cmUgYSBjbGVhbiBidWlsZCBlbnZpcm9ubWVudC5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGZvbGRlciBoYXMgYmVlbiByZW1vdmVkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDbGVhbigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgcm0oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCB7IGZvcmNlOiB0cnVlLCByZWN1cnNpdmU6IHRydWUgfSk7XG59XG5cbi8qKlxuICogQ29tcGlsZXMgdGhlIGNvZGUuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZSgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgbnBtUnVuKCdidWlsZDpjb21waWxlOnN2ZWx0ZScpO1xuICBhd2FpdCBucG1SdW4oJ2J1aWxkOmNvbXBpbGU6dHlwZXNjcmlwdCcpO1xufVxuXG4vKipcbiAqIENvbXBpbGVzIHRoZSBTdmVsdGUgY29kZS5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGNvZGUgY29tcGlsZXMgc3VjY2Vzc2Z1bGx5LlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDb21waWxlU3ZlbHRlKCk6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCB0c0NvbmZpZ1BhdGggPSByZXNvbHZlUGF0aEZyb21Sb290U2FmZShPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlRzQ29uZmlnSnNvbik7XG4gIGNvbnN0IHRzQ29uZmlnID0gYXdhaXQgcmVhZEpzb248VHNDb25maWdKc29uPih0c0NvbmZpZ1BhdGgpO1xuICBjb25zdCBhbGxGaWxlcyA9IGF3YWl0IGdsb2IodHNDb25maWcuaW5jbHVkZSA/PyBbXSwgeyBpZ25vcmU6IHRzQ29uZmlnLmV4Y2x1ZGUgPz8gW10gfSk7XG4gIGNvbnN0IHN2ZWx0ZUZpbGVzID0gYWxsRmlsZXMuZmlsdGVyKChmaWxlKSA9PiBmaWxlLmVuZHNXaXRoKCcuc3ZlbHRlJykgfHwgZmlsZS5lbmRzV2l0aCgnLnN2ZWx0ZS5qcycpIHx8IGZpbGUuZW5kc1dpdGgoJy5zdmVsdGUudHMnKSk7XG5cbiAgaWYgKHN2ZWx0ZUZpbGVzLmxlbmd0aCA9PT0gMCkge1xuICAgIGdldExpYkRlYnVnZ2VyKCdidWlsZDpidWlsZENvbXBpbGVTdmVsdGUnKSgnTm8gU3ZlbHRlIGZpbGVzIGZvdW5kIGluIHRoZSBwcm9qZWN0LCBza2lwcGluZyBTdmVsdGUgY29tcGlsYXRpb24nKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBhd2FpdCBleGVjRnJvbVJvb3QoWyducHgnLCAnc3ZlbHRlLWNoZWNrJywgJy0tdHNjb25maWcnLCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlRzQ29uZmlnSnNvbl0pO1xufVxuXG4vKipcbiAqIENvbXBpbGVzIHRoZSBUeXBlU2NyaXB0IGNvZGUuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZVR5cGVTY3JpcHQoKTogUHJvbWlzZTx2b2lkPiB7XG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ25weCcsICd0c2MnLCAnLS1idWlsZCcsICctLWZvcmNlJ10pO1xufVxuXG4vKipcbiAqIENvcGllcyBhbGwgc3RhdGljIGZpbGVzIGZyb20gdGhlIHN0YXRpYyBhc3NldHMgZm9sZGVyIHRvIHRoZSBkaXN0cmlidXRpb24gZm9sZGVyLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gcmVjdXJzaXZlbHkgcmVhZHMgdGhlIGNvbnRlbnRzIG9mIHRoZSBzdGF0aWMgYXNzZXRzIGZvbGRlciBhbmQgY29waWVzXG4gKiBlYWNoIGZpbGUgdG8gdGhlIGNvcnJlc3BvbmRpbmcgcGF0aCBpbiB0aGUgZGlzdHJpYnV0aW9uIGZvbGRlci5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gYWxsIGZpbGVzIGhhdmUgYmVlbiBjb3BpZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZFN0YXRpYygpOiBQcm9taXNlPHZvaWQ+IHtcbiAgZm9yIChjb25zdCBkaXJlbnQgb2YgYXdhaXQgcmVhZGRpclBvc2l4KE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuU3RhdGljLCB7IHJlY3Vyc2l2ZTogdHJ1ZSwgd2l0aEZpbGVUeXBlczogdHJ1ZSB9KSkge1xuICAgIGlmICghZGlyZW50LmlzRmlsZSgpKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb25zdCBwYXRoID0gdHJpbVN0YXJ0KGpvaW4oZGlyZW50LnBhcmVudFBhdGgsIGRpcmVudC5uYW1lKSwgYCR7T2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWN9L2ApO1xuICAgIGF3YWl0IGNwKGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWMsIHBhdGgpLCBqb2luKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRGlzdCwgcGF0aCkpO1xuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBVUEsU0FBUyxZQUFZO0FBRXJCLFNBQVMsc0JBQXNCO0FBQy9CLFNBQVMsWUFBWTtBQUNyQixTQUFTLGlCQUFpQjtBQUMxQixTQUFTLG9CQUFvQjtBQUM3QixTQUFTLGdCQUFnQjtBQUN6QjtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQUNQLFNBQVMsY0FBYztBQUN2QixTQUFTLGlDQUFpQztBQUMxQztBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQVNQLGVBQXNCLGFBQTRCO0FBQ2hELFFBQU0sR0FBRywwQkFBMEIsTUFBTSxFQUFFLE9BQU8sTUFBTSxXQUFXLEtBQUssQ0FBQztBQUMzRTtBQU9BLGVBQXNCLGVBQThCO0FBQ2xELFFBQU0sT0FBTyxzQkFBc0I7QUFDbkMsUUFBTSxPQUFPLDBCQUEwQjtBQUN6QztBQU9BLGVBQXNCLHFCQUFvQztBQUN4RCxRQUFNLGVBQWUsd0JBQXdCLDBCQUEwQixZQUFZO0FBQ25GLFFBQU0sV0FBVyxNQUFNLFNBQXVCLFlBQVk7QUFDMUQsUUFBTSxXQUFXLE1BQU0sS0FBSyxTQUFTLFdBQVcsQ0FBQyxHQUFHLEVBQUUsUUFBUSxTQUFTLFdBQVcsQ0FBQyxFQUFFLENBQUM7QUFDdEYsUUFBTSxjQUFjLFNBQVMsT0FBTyxDQUFDLFNBQVMsS0FBSyxTQUFTLFNBQVMsS0FBSyxLQUFLLFNBQVMsWUFBWSxLQUFLLEtBQUssU0FBUyxZQUFZLENBQUM7QUFFcEksTUFBSSxZQUFZLFdBQVcsR0FBRztBQUM1QixtQkFBZSwwQkFBMEIsRUFBRSxtRUFBbUU7QUFDOUc7QUFBQSxFQUNGO0FBRUEsUUFBTSxhQUFhLENBQUMsT0FBTyxnQkFBZ0IsY0FBYywwQkFBMEIsWUFBWSxDQUFDO0FBQ2xHO0FBT0EsZUFBc0IseUJBQXdDO0FBQzVELFFBQU0sYUFBYSxDQUFDLE9BQU8sT0FBTyxXQUFXLFNBQVMsQ0FBQztBQUN6RDtBQVVBLGVBQXNCLGNBQTZCO0FBQ2pELGFBQVcsVUFBVSxNQUFNLGFBQWEsMEJBQTBCLFFBQVEsRUFBRSxXQUFXLE1BQU0sZUFBZSxLQUFLLENBQUMsR0FBRztBQUNuSCxRQUFJLENBQUMsT0FBTyxPQUFPLEdBQUc7QUFDcEI7QUFBQSxJQUNGO0FBRUEsVUFBTSxPQUFPLFVBQVUsS0FBSyxPQUFPLFlBQVksT0FBTyxJQUFJLEdBQUcsR0FBRywwQkFBMEIsTUFBTSxHQUFHO0FBQ25HLFVBQU0sR0FBRyxLQUFLLDBCQUEwQixRQUFRLElBQUksR0FBRyxLQUFLLDBCQUEwQixNQUFNLElBQUksQ0FBQztBQUFBLEVBQ25HO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -9,7 +9,7 @@ import { Command } from "commander";
9
9
  import { tsImport } from "tsx/esm/api";
10
10
  import { invokeAsyncSafely } from "../Async.mjs";
11
11
  import {
12
- getDirname,
12
+ getFolderName,
13
13
  join,
14
14
  relative
15
15
  } from "../Path.mjs";
@@ -44,7 +44,7 @@ const NODE_SCRIPT_ARGV_SKIP_COUNT = 2;
44
44
  function cli(argv = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)) {
45
45
  invokeAsyncSafely(
46
46
  () => wrapCliTask(async () => {
47
- const packageJson = await readPackageJson(getDirname(import.meta.url));
47
+ const packageJson = await readPackageJson(getFolderName(import.meta.url));
48
48
  const program = new Command();
49
49
  program.name(packageJson.name ?? "(unknown)").description("CLI for Obsidian plugin development utilities").version(packageJson.version ?? "(unknown)");
50
50
  addCommand(program, "build" /* Build */, "Build the plugin", () => buildObsidianPlugin({ mode: BuildMode.Production }));
@@ -71,8 +71,8 @@ function addCommand(program, name, description, taskFn) {
71
71
  (...args) => wrapCliTask(async () => {
72
72
  const scriptPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(":", "-")}.ts`));
73
73
  if (existsSync(scriptPath)) {
74
- const dir = getDirname(import.meta.url);
75
- const relativeScriptPath = relative(dir, scriptPath);
74
+ const folder = getFolderName(import.meta.url);
75
+ const relativeScriptPath = relative(folder, scriptPath);
76
76
  const module = await tsImport(relativeScriptPath, { parentURL: import.meta.url });
77
77
  if (typeof module.invoke !== "function") {
78
78
  throw new Error(`${relativeScriptPath} does not export an invoke function`);
@@ -86,4 +86,4 @@ function addCommand(program, name, description, taskFn) {
86
86
  export {
87
87
  cli
88
88
  };
89
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/cli.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport { Command } from 'commander';\nimport { tsImport } from 'tsx/esm/api';\n\nimport type { MaybeReturn } from '../Type.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport {\n  getDirname,\n  join,\n  relative\n} from '../Path.ts';\nimport {\n  buildClean,\n  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport {\n  existsSync,\n  process\n} from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\nimport { resolvePathFromRootSafe } from './Root.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\ninterface OverrideModule<Args extends unknown[]> {\n  invoke(...args: Args): Promise<MaybeReturn<CliTaskResult>>;\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a {@link CliTaskResult} or `void`.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  taskFn: (...args: Args) => Promisable<MaybeReturn<CliTaskResult>>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) =>\n      wrapCliTask(async () => {\n        const scriptPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(':', '-')}.ts`));\n        if (existsSync(scriptPath)) {\n          const dir = getDirname(import.meta.url);\n          const relativeScriptPath = relative(dir, scriptPath);\n          const module = await tsImport(relativeScriptPath, { parentURL: import.meta.url }) as Partial<OverrideModule<Args>>;\n          if (typeof module.invoke !== 'function') {\n            throw new Error(`${relativeScriptPath} does not export an invoke function`);\n          }\n          return module.invoke(...args);\n        }\n\n        return await taskFn(...args);\n      })\n    );\n}\n"],
  "mappings": "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",
  "names": []
}

89
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/cli.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport type { Promisable } from 'type-fest';\n\nimport { Command } from 'commander';\nimport { tsImport } from 'tsx/esm/api';\n\nimport type { MaybeReturn } from '../Type.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport {\n  getFolderName,\n  join,\n  relative\n} from '../Path.ts';\nimport {\n  buildClean,\n  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport {\n  existsSync,\n  process\n} from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\nimport { resolvePathFromRootSafe } from './Root.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\ninterface OverrideModule<Args extends unknown[]> {\n  invoke(...args: Args): Promise<MaybeReturn<CliTaskResult>>;\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getFolderName(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a {@link CliTaskResult} or `void`.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  taskFn: (...args: Args) => Promisable<MaybeReturn<CliTaskResult>>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) =>\n      wrapCliTask(async () => {\n        const scriptPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(':', '-')}.ts`));\n        if (existsSync(scriptPath)) {\n          const folder = getFolderName(import.meta.url);\n          const relativeScriptPath = relative(folder, scriptPath);\n          const module = await tsImport(relativeScriptPath, { parentURL: import.meta.url }) as Partial<OverrideModule<Args>>;\n          if (typeof module.invoke !== 'function') {\n            throw new Error(`${relativeScriptPath} does not export an invoke function`);\n          }\n          return module.invoke(...args);\n        }\n\n        return await taskFn(...args);\n      })\n    );\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -8,7 +8,7 @@ if you want to view the source, please visit the github repository of this plugi
8
8
  import { context } from "esbuild";
9
9
  import { throwExpression } from "../../Error.mjs";
10
10
  import {
11
- getDirname,
11
+ getFolderName,
12
12
  join
13
13
  } from "../../Path.mjs";
14
14
  import { trimStart } from "../../String.mjs";
@@ -51,7 +51,7 @@ async function getDependenciesToBundle() {
51
51
  return Array.from(dependenciesToBundle).sort();
52
52
  }
53
53
  async function getDependenciesToSkip() {
54
- const packageJson = await readPackageJson(getDirname(import.meta.url));
54
+ const packageJson = await readPackageJson(getFolderName(import.meta.url));
55
55
  const dependenciesToSkip = /* @__PURE__ */ new Set([...builtinModules, ...Object.keys(packageJson.dependencies ?? {}).filter(canSkipFromBundling)]);
56
56
  return dependenciesToSkip;
57
57
  }
@@ -92,4 +92,4 @@ export {
92
92
  getDependenciesToBundle,
93
93
  getDependenciesToSkip
94
94
  };
95
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/ScriptUtils/esbuild/Dependency.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module provides utilities for managing dependencies during the esbuild process.\n * It includes functions to determine which dependencies should be skipped and which\n * should be bundled, as well as an esbuild plugin for extracting dependencies to bundle.\n */\n\nimport type {\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\n\nimport { throwExpression } from '../../Error.ts';\nimport {\n  getDirname,\n  join\n} from '../../Path.ts';\nimport { trimStart } from '../../String.ts';\nimport {\n  builtinModules,\n  createRequire\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../ObsidianDevUtilsRepoPaths.ts';\nimport {\n  banner,\n  invokeEsbuild\n} from './ObsidianPluginBuilder.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\n\nconst esmRequire = createRequire(import.meta.url);\n\ninterface ModuleWithDefaultExport {\n  default: unknown;\n}\n\n/**\n * Determines which dependencies should be bundled by esbuild.\n *\n * @returns A {@link Promise} that resolves to an array of dependency names to bundle.\n */\nexport async function getDependenciesToBundle(): Promise<string[]> {\n  const dependenciesToSkip = await getDependenciesToSkip();\n  const dependenciesToBundle = new Set<string>();\n\n  const buildOptions: BuildOptions = {\n    banner: {\n      js: banner\n    },\n    bundle: true,\n    entryPoints: [join(ObsidianDevUtilsRepoPaths.Src, ObsidianDevUtilsRepoPaths.AnyPath, ObsidianDevUtilsRepoPaths.AnyTs)],\n    format: 'cjs',\n    logLevel: 'info',\n    outdir: 'nothing-will-be-written-on-disk-so-this-does-not-matter',\n    platform: 'node',\n    plugins: [\n      preprocessPlugin(),\n      extractDependenciesToBundlePlugin(dependenciesToSkip, dependenciesToBundle)\n    ],\n    sourcemap: 'inline',\n    target: 'ESNext',\n    treeShaking: true,\n    write: false\n  };\n\n  const buildContext = await context(buildOptions);\n  await invokeEsbuild(buildContext, true);\n  return Array.from(dependenciesToBundle).sort();\n}\n\n/**\n * Retrieves the list of dependencies that should be skipped during the bundling process.\n *\n * @returns A {@link Promise} that resolves to a {@link Set} of dependency names to skip.\n */\nexport async function getDependenciesToSkip(): Promise<Set<string>> {\n  const packageJson = await readPackageJson(getDirname(import.meta.url));\n  const dependenciesToSkip = new Set<string>([...builtinModules, ...Object.keys(packageJson.dependencies ?? {}).filter(canSkipFromBundling)]);\n  return dependenciesToSkip;\n}\n\n/**\n * Determines whether a module can be skipped from bundling.\n *\n * @param moduleName - The name of the module.\n * @returns A boolean indicating whether the module can be skipped from bundling.\n */\nfunction canSkipFromBundling(moduleName: string): boolean {\n  if (moduleName.startsWith('@types/')) {\n    return true;\n  }\n\n  if (moduleName.startsWith('obsidian')) {\n    return true;\n  }\n\n  if (moduleName === 'esbuild') {\n    return true;\n  }\n\n  try {\n    const module = esmRequire(moduleName) as ModuleWithDefaultExport;\n    return !module.default;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Creates an esbuild plugin that identifies which dependencies should be bundled.\n *\n * @param dependenciesToSkip - A set of dependency names that should be skipped during bundling.\n * @param dependenciesToBundle - A set where the names of dependencies to be bundled will be added.\n * @returns An esbuild `Plugin` object that extracts dependencies to bundle.\n */\nfunction extractDependenciesToBundlePlugin(dependenciesToSkip: Set<string>, dependenciesToBundle: Set<string>): Plugin {\n  return {\n    name: 'test',\n    setup(build): void {\n      build.onResolve({ filter: /^[^./]/ }, (args) => {\n        if (!args.importer.endsWith(ObsidianDevUtilsRepoPaths.DtsExtension)) {\n          const moduleName = trimStart(args.path.split('/')[0] ?? throwExpression(new Error('Wrong path')), 'node:');\n          if (!dependenciesToSkip.has(args.path) && !dependenciesToSkip.has(moduleName)) {\n            dependenciesToBundle.add(args.path);\n          }\n        }\n        return { external: true, path: args.path };\n      });\n    }\n  };\n}\n"],
  "mappings": ";;;;;;;AAaA,SAAS,eAAe;AAExB,SAAS,uBAAuB;AAChC;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,iBAAiB;AAC1B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,uBAAuB;AAChC,SAAS,iCAAiC;AAC1C;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,wBAAwB;AAEjC,MAAM,aAAa,cAAc,YAAY,GAAG;AAWhD,eAAsB,0BAA6C;AACjE,QAAM,qBAAqB,MAAM,sBAAsB;AACvD,QAAM,uBAAuB,oBAAI,IAAY;AAE7C,QAAM,eAA6B;AAAA,IACjC,QAAQ;AAAA,MACN,IAAI;AAAA,IACN;AAAA,IACA,QAAQ;AAAA,IACR,aAAa,CAAC,KAAK,0BAA0B,KAAK,0BAA0B,SAAS,0BAA0B,KAAK,CAAC;AAAA,IACrH,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,MACP,iBAAiB;AAAA,MACjB,kCAAkC,oBAAoB,oBAAoB;AAAA,IAC5E;AAAA,IACA,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,aAAa;AAAA,IACb,OAAO;AAAA,EACT;AAEA,QAAM,eAAe,MAAM,QAAQ,YAAY;AAC/C,QAAM,cAAc,cAAc,IAAI;AACtC,SAAO,MAAM,KAAK,oBAAoB,EAAE,KAAK;AAC/C;AAOA,eAAsB,wBAA8C;AAClE,QAAM,cAAc,MAAM,gBAAgB,WAAW,YAAY,GAAG,CAAC;AACrE,QAAM,qBAAqB,oBAAI,IAAY,CAAC,GAAG,gBAAgB,GAAG,OAAO,KAAK,YAAY,gBAAgB,CAAC,CAAC,EAAE,OAAO,mBAAmB,CAAC,CAAC;AAC1I,SAAO;AACT;AAQA,SAAS,oBAAoB,YAA6B;AACxD,MAAI,WAAW,WAAW,SAAS,GAAG;AACpC,WAAO;AAAA,EACT;AAEA,MAAI,WAAW,WAAW,UAAU,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,MAAI,eAAe,WAAW;AAC5B,WAAO;AAAA,EACT;AAEA,MAAI;AACF,UAAM,SAAS,WAAW,UAAU;AACpC,WAAO,CAAC,OAAO;AAAA,EACjB,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AASA,SAAS,kCAAkC,oBAAiC,sBAA2C;AACrH,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM,OAAa;AACjB,YAAM,UAAU,EAAE,QAAQ,SAAS,GAAG,CAAC,SAAS;AAC9C,YAAI,CAAC,KAAK,SAAS,SAAS,0BAA0B,YAAY,GAAG;AACnE,gBAAM,aAAa,UAAU,KAAK,KAAK,MAAM,GAAG,EAAE,CAAC,KAAK,gBAAgB,IAAI,MAAM,YAAY,CAAC,GAAG,OAAO;AACzG,cAAI,CAAC,mBAAmB,IAAI,KAAK,IAAI,KAAK,CAAC,mBAAmB,IAAI,UAAU,GAAG;AAC7E,iCAAqB,IAAI,KAAK,IAAI;AAAA,UACpC;AAAA,QACF;AACA,eAAO,EAAE,UAAU,MAAM,MAAM,KAAK,KAAK;AAAA,MAC3C,CAAC;AAAA,IACH;AAAA,EACF;AACF;",
  "names": []
}

95
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/ScriptUtils/esbuild/Dependency.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module provides utilities for managing dependencies during the esbuild process.\n * It includes functions to determine which dependencies should be skipped and which\n * should be bundled, as well as an esbuild plugin for extracting dependencies to bundle.\n */\n\nimport type {\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\n\nimport { throwExpression } from '../../Error.ts';\nimport {\n  getFolderName,\n  join\n} from '../../Path.ts';\nimport { trimStart } from '../../String.ts';\nimport {\n  builtinModules,\n  createRequire\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../ObsidianDevUtilsRepoPaths.ts';\nimport {\n  banner,\n  invokeEsbuild\n} from './ObsidianPluginBuilder.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\n\nconst esmRequire = createRequire(import.meta.url);\n\ninterface ModuleWithDefaultExport {\n  default: unknown;\n}\n\n/**\n * Determines which dependencies should be bundled by esbuild.\n *\n * @returns A {@link Promise} that resolves to an array of dependency names to bundle.\n */\nexport async function getDependenciesToBundle(): Promise<string[]> {\n  const dependenciesToSkip = await getDependenciesToSkip();\n  const dependenciesToBundle = new Set<string>();\n\n  const buildOptions: BuildOptions = {\n    banner: {\n      js: banner\n    },\n    bundle: true,\n    entryPoints: [join(ObsidianDevUtilsRepoPaths.Src, ObsidianDevUtilsRepoPaths.AnyPath, ObsidianDevUtilsRepoPaths.AnyTs)],\n    format: 'cjs',\n    logLevel: 'info',\n    outdir: 'nothing-will-be-written-on-disk-so-this-does-not-matter',\n    platform: 'node',\n    plugins: [\n      preprocessPlugin(),\n      extractDependenciesToBundlePlugin(dependenciesToSkip, dependenciesToBundle)\n    ],\n    sourcemap: 'inline',\n    target: 'ESNext',\n    treeShaking: true,\n    write: false\n  };\n\n  const buildContext = await context(buildOptions);\n  await invokeEsbuild(buildContext, true);\n  return Array.from(dependenciesToBundle).sort();\n}\n\n/**\n * Retrieves the list of dependencies that should be skipped during the bundling process.\n *\n * @returns A {@link Promise} that resolves to a {@link Set} of dependency names to skip.\n */\nexport async function getDependenciesToSkip(): Promise<Set<string>> {\n  const packageJson = await readPackageJson(getFolderName(import.meta.url));\n  const dependenciesToSkip = new Set<string>([...builtinModules, ...Object.keys(packageJson.dependencies ?? {}).filter(canSkipFromBundling)]);\n  return dependenciesToSkip;\n}\n\n/**\n * Determines whether a module can be skipped from bundling.\n *\n * @param moduleName - The name of the module.\n * @returns A boolean indicating whether the module can be skipped from bundling.\n */\nfunction canSkipFromBundling(moduleName: string): boolean {\n  if (moduleName.startsWith('@types/')) {\n    return true;\n  }\n\n  if (moduleName.startsWith('obsidian')) {\n    return true;\n  }\n\n  if (moduleName === 'esbuild') {\n    return true;\n  }\n\n  try {\n    const module = esmRequire(moduleName) as ModuleWithDefaultExport;\n    return !module.default;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Creates an esbuild plugin that identifies which dependencies should be bundled.\n *\n * @param dependenciesToSkip - A set of dependency names that should be skipped during bundling.\n * @param dependenciesToBundle - A set where the names of dependencies to be bundled will be added.\n * @returns An esbuild `Plugin` object that extracts dependencies to bundle.\n */\nfunction extractDependenciesToBundlePlugin(dependenciesToSkip: Set<string>, dependenciesToBundle: Set<string>): Plugin {\n  return {\n    name: 'test',\n    setup(build): void {\n      build.onResolve({ filter: /^[^./]/ }, (args) => {\n        if (!args.importer.endsWith(ObsidianDevUtilsRepoPaths.DtsExtension)) {\n          const moduleName = trimStart(args.path.split('/')[0] ?? throwExpression(new Error('Wrong path')), 'node:');\n          if (!dependenciesToSkip.has(args.path) && !dependenciesToSkip.has(moduleName)) {\n            dependenciesToBundle.add(args.path);\n          }\n        }\n        return { external: true, path: args.path };\n      });\n    }\n  };\n}\n"],
  "mappings": ";;;;;;;AAaA,SAAS,eAAe;AAExB,SAAS,uBAAuB;AAChC;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,iBAAiB;AAC1B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,uBAAuB;AAChC,SAAS,iCAAiC;AAC1C;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,wBAAwB;AAEjC,MAAM,aAAa,cAAc,YAAY,GAAG;AAWhD,eAAsB,0BAA6C;AACjE,QAAM,qBAAqB,MAAM,sBAAsB;AACvD,QAAM,uBAAuB,oBAAI,IAAY;AAE7C,QAAM,eAA6B;AAAA,IACjC,QAAQ;AAAA,MACN,IAAI;AAAA,IACN;AAAA,IACA,QAAQ;AAAA,IACR,aAAa,CAAC,KAAK,0BAA0B,KAAK,0BAA0B,SAAS,0BAA0B,KAAK,CAAC;AAAA,IACrH,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,MACP,iBAAiB;AAAA,MACjB,kCAAkC,oBAAoB,oBAAoB;AAAA,IAC5E;AAAA,IACA,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,aAAa;AAAA,IACb,OAAO;AAAA,EACT;AAEA,QAAM,eAAe,MAAM,QAAQ,YAAY;AAC/C,QAAM,cAAc,cAAc,IAAI;AACtC,SAAO,MAAM,KAAK,oBAAoB,EAAE,KAAK;AAC/C;AAOA,eAAsB,wBAA8C;AAClE,QAAM,cAAc,MAAM,gBAAgB,cAAc,YAAY,GAAG,CAAC;AACxE,QAAM,qBAAqB,oBAAI,IAAY,CAAC,GAAG,gBAAgB,GAAG,OAAO,KAAK,YAAY,gBAAgB,CAAC,CAAC,EAAE,OAAO,mBAAmB,CAAC,CAAC;AAC1I,SAAO;AACT;AAQA,SAAS,oBAAoB,YAA6B;AACxD,MAAI,WAAW,WAAW,SAAS,GAAG;AACpC,WAAO;AAAA,EACT;AAEA,MAAI,WAAW,WAAW,UAAU,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,MAAI,eAAe,WAAW;AAC5B,WAAO;AAAA,EACT;AAEA,MAAI;AACF,UAAM,SAAS,WAAW,UAAU;AACpC,WAAO,CAAC,OAAO;AAAA,EACjB,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AASA,SAAS,kCAAkC,oBAAiC,sBAA2C;AACrH,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM,OAAa;AACjB,YAAM,UAAU,EAAE,QAAQ,SAAS,GAAG,CAAC,SAAS;AAC9C,YAAI,CAAC,KAAK,SAAS,SAAS,0BAA0B,YAAY,GAAG;AACnE,gBAAM,aAAa,UAAU,KAAK,KAAK,MAAM,GAAG,EAAE,CAAC,KAAK,gBAAgB,IAAI,MAAM,YAAY,CAAC,GAAG,OAAO;AACzG,cAAI,CAAC,mBAAmB,IAAI,KAAK,IAAI,KAAK,CAAC,mBAAmB,IAAI,UAAU,GAAG;AAC7E,iCAAqB,IAAI,KAAK,IAAI;AAAA,UACpC;AAAA,QACF;AACA,eAAO,EAAE,UAAU,MAAM,MAAM,KAAK,KAAK;AAAA,MAC3C,CAAC;AAAA,IACH;AAAA,EACF;AACF;",
  "names": []
}

@@ -37,12 +37,12 @@ export interface BuildObsidianPluginOptions {
37
37
  */
38
38
  mode: BuildMode;
39
39
  /**
40
- * The directory for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_DIR` environment variable.
40
+ * The folder for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_FOLDER` environment variable.
41
41
  */
42
- obsidianConfigDir?: string;
42
+ obsidianConfigFolder?: string;
43
43
  }
44
44
  /**
45
- * Builds the Obsidian plugin based on the specified mode and configuration directory.
45
+ * Builds the Obsidian plugin based on the specified mode and configuration folder.
46
46
  *
47
47
  * @param options - The parameters for building the plugin.
48
48
  * @returns A {@link Promise} that resolves to a {@link CliTaskResult} indicating the success or failure of the build.
@@ -46,34 +46,34 @@ async function buildObsidianPlugin(options) {
46
46
  await buildCompile();
47
47
  config();
48
48
  const obsidianPluginBuilderEnv = process.env;
49
- const obsidianConfigDir = options.obsidianConfigDir ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_DIR ?? "";
49
+ const obsidianConfigFolder = options.obsidianConfigFolder ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_FOLDER ?? "";
50
50
  const isProductionBuild = options.mode === 1 /* Production */;
51
- const distDir = resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev);
52
- if (!distDir) {
53
- throw new Error("Could not determine the dist directory");
51
+ const distFolder = resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev);
52
+ if (!distFolder) {
53
+ throw new Error("Could not determine the dist folder");
54
54
  }
55
- if (existsSync(distDir)) {
56
- await rm(distDir, { recursive: true });
55
+ if (existsSync(distFolder)) {
56
+ await rm(distFolder, { recursive: true });
57
57
  }
58
- await mkdir(distDir, { recursive: true });
58
+ await mkdir(distFolder, { recursive: true });
59
59
  const distFileNames = [
60
60
  ObsidianPluginRepoPaths.ManifestJson
61
61
  ];
62
62
  if (!isProductionBuild) {
63
- await writeFile(join(distDir, ObsidianPluginRepoPaths.HotReload), "", "utf-8");
63
+ await writeFile(join(distFolder, ObsidianPluginRepoPaths.HotReload), "", "utf-8");
64
64
  }
65
65
  for (const fileName of distFileNames) {
66
66
  const localFile = resolvePathFromRoot(fileName);
67
67
  if (!localFile) {
68
68
  throw new Error(`Could not determine the local file for ${fileName}`);
69
69
  }
70
- const distFile = join(distDir, fileName);
70
+ const distFile = join(distFolder, fileName);
71
71
  if (existsSync(localFile)) {
72
72
  await cp(localFile, distFile);
73
73
  }
74
74
  }
75
- const distPath = join(distDir, ObsidianPluginRepoPaths.MainJs);
76
- const cssPath = join(distDir, ObsidianPluginRepoPaths.StylesCss);
75
+ const distPath = join(distFolder, ObsidianPluginRepoPaths.MainJs);
76
+ const cssPath = join(distFolder, ObsidianPluginRepoPaths.StylesCss);
77
77
  const packageJson = await readPackageJson();
78
78
  const pluginName = packageJson.name ?? "(unknown)";
79
79
  const buildOptions = {
@@ -114,12 +114,12 @@ async function buildObsidianPlugin(options) {
114
114
  sassPlugin({
115
115
  sourceMap: !isProductionBuild
116
116
  }),
117
- renameCssPlugin(distDir),
117
+ renameCssPlugin(distFolder),
118
118
  preprocessPlugin(),
119
119
  fixEsmPlugin(),
120
120
  fixSourceMapsPlugin(isProductionBuild, [distPath, cssPath], pluginName),
121
121
  ...options.customEsbuildPlugins ?? [],
122
- copyToObsidianPluginsFolderPlugin(isProductionBuild, distDir, obsidianConfigDir, pluginName)
122
+ copyToObsidianPluginsFolderPlugin(isProductionBuild, distFolder, obsidianConfigFolder, pluginName)
123
123
  ],
124
124
  sourcemap: isProductionBuild ? false : "inline",
125
125
  target: "esnext",
@@ -143,4 +143,4 @@ export {
143
143
  buildObsidianPlugin,
144
144
  invokeEsbuild
145
145
  };
146
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/ScriptUtils/esbuild/ObsidianPluginBuilder.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module provides functionality to build and bundle an Obsidian plugin using esbuild.\n * It includes functions to handle the build process based on different build modes (development or production),\n * and it sets up various esbuild plugins to preprocess, lint, fix source maps, and copy files to the Obsidian plugins folder.\n */\n\nimport type {\n  BuildContext,\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { config } from 'dotenv';\nimport { context } from 'esbuild';\n// eslint-disable-next-line import-x/no-rename-default\nimport sassPlugin_ from 'esbuild-sass-plugin';\n\nimport { throwExpression } from '../../Error.ts';\nimport { ObsidianPluginRepoPaths } from '../../obsidian/Plugin/ObsidianPluginRepoPaths.ts';\nimport { join } from '../../Path.ts';\nimport { buildCompile } from '../build.ts';\nimport { CliTaskResult } from '../CliUtils.ts';\nimport {\n  builtinModules,\n  cp,\n  existsSync,\n  mkdir,\n  process,\n  rm,\n  writeFile\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { resolvePathFromRoot } from '../Root.ts';\nimport { copyToObsidianPluginsFolderPlugin } from './copyToObsidianPluginsFolderPlugin.ts';\nimport { customEsbuildOptionsPlugin } from './customEsbuildOptionsPlugin.ts';\nimport { fixEsmPlugin } from './fixEsmPlugin.ts';\nimport { fixSourceMapsPlugin } from './fixSourceMapsPlugin.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\nimport { renameCssPlugin } from './renameCssPlugin.ts';\nimport { svelteWrapperPlugin } from './svelteWrapperPlugin.ts';\n\nconst sassPlugin = ('default' in sassPlugin_ ? sassPlugin_.default : sassPlugin_) as unknown as typeof sassPlugin_.default;\n\n/**\n * Enumeration representing the build modes.\n */\nexport enum BuildMode {\n  /** Development mode for building the plugin */\n  Development,\n  /** Production mode for building the plugin */\n  Production\n}\n\n/**\n * Banner text to be included at the top of the generated files.\n */\nexport const banner = `/*\nTHIS IS A GENERATED/BUNDLED FILE BY ESBUILD\nif you want to view the source, please visit the github repository of this plugin\n*/\n`;\n\n/**\n * Options for building an Obsidian plugin.\n */\nexport interface BuildObsidianPluginOptions {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  customEsbuildPlugins?: Plugin[];\n\n  /**\n   * Customizes the esbuild options.\n   */\n  customizeEsbuildOptions?(options: BuildOptions): void;\n\n  /**\n   * The build mode, either Development or Production\n   */\n  mode: BuildMode;\n\n  /**\n   * The directory for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_DIR` environment variable.\n   */\n  obsidianConfigDir?: string;\n}\n\ninterface ObsidianPluginBuilderEnv {\n  OBSIDIAN_CONFIG_DIR: string;\n}\n\n/**\n * Builds the Obsidian plugin based on the specified mode and configuration directory.\n *\n * @param options - The parameters for building the plugin.\n * @returns A {@link Promise} that resolves to a {@link CliTaskResult} indicating the success or failure of the build.\n */\nexport async function buildObsidianPlugin(options: BuildObsidianPluginOptions): Promise<CliTaskResult> {\n  await buildCompile();\n  config();\n  const obsidianPluginBuilderEnv = process.env as Partial<ObsidianPluginBuilderEnv>;\n\n  const obsidianConfigDir = options.obsidianConfigDir ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_DIR ?? '';\n  const isProductionBuild = options.mode === BuildMode.Production;\n\n  const distDir = resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev);\n  if (!distDir) {\n    throw new Error('Could not determine the dist directory');\n  }\n\n  if (existsSync(distDir)) {\n    await rm(distDir, { recursive: true });\n  }\n  await mkdir(distDir, { recursive: true });\n\n  const distFileNames = [\n    ObsidianPluginRepoPaths.ManifestJson\n  ];\n  if (!isProductionBuild) {\n    await writeFile(join(distDir, ObsidianPluginRepoPaths.HotReload), '', 'utf-8');\n  }\n\n  for (const fileName of distFileNames) {\n    const localFile = resolvePathFromRoot(fileName);\n    if (!localFile) {\n      throw new Error(`Could not determine the local file for ${fileName}`);\n    }\n    const distFile = join(distDir, fileName);\n\n    if (existsSync(localFile)) {\n      await cp(localFile, distFile);\n    }\n  }\n\n  const distPath = join(distDir, ObsidianPluginRepoPaths.MainJs);\n  const cssPath = join(distDir, ObsidianPluginRepoPaths.StylesCss);\n\n  const packageJson = await readPackageJson();\n  const pluginName = packageJson.name ?? '(unknown)';\n\n  const buildOptions: BuildOptions = {\n    banner: {\n      js: banner\n    },\n    bundle: true,\n    conditions: ['browser'],\n    entryPoints: [\n      resolvePathFromRoot(join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs))\n        ?? throwExpression(new Error('Could not determine the entry point for the plugin'))\n    ],\n    external: [\n      'obsidian',\n      'electron',\n      '@codemirror/autocomplete',\n      '@codemirror/collab',\n      '@codemirror/commands',\n      '@codemirror/language',\n      '@codemirror/lint',\n      '@codemirror/search',\n      '@codemirror/state',\n      '@codemirror/view',\n      '@lezer/common',\n      '@lezer/highlight',\n      '@lezer/lr',\n      'esbuild',\n      'eslint',\n      ...builtinModules\n    ],\n    format: 'cjs',\n    logLevel: 'info',\n    minify: isProductionBuild,\n    outfile: distPath,\n    platform: 'node',\n    plugins: [\n      customEsbuildOptionsPlugin(options.customizeEsbuildOptions?.bind(options)),\n      svelteWrapperPlugin(isProductionBuild),\n      sassPlugin({\n        sourceMap: !isProductionBuild\n      }),\n      renameCssPlugin(distDir),\n      preprocessPlugin(),\n      fixEsmPlugin(),\n      fixSourceMapsPlugin(isProductionBuild, [distPath, cssPath], pluginName),\n      ...options.customEsbuildPlugins ?? [],\n      copyToObsidianPluginsFolderPlugin(isProductionBuild, distDir, obsidianConfigDir, pluginName)\n    ],\n    sourcemap: isProductionBuild ? false : 'inline',\n    target: 'esnext',\n    treeShaking: true\n  };\n\n  const buildContext = await context(buildOptions);\n  return await invokeEsbuild(buildContext, isProductionBuild);\n}\n\n/**\n * Invokes the build process with the provided build context.\n *\n * @param buildContext - The build context generated by esbuild.\n * @param isProductionBuild - A boolean indicating whether the build is a production build.\n * @returns A {@link Promise} that resolves to a {@link CliTaskResult} indicating the success or failure of the build.\n */\nexport async function invokeEsbuild(buildContext: BuildContext, isProductionBuild: boolean): Promise<CliTaskResult> {\n  if (isProductionBuild) {\n    const result = await buildContext.rebuild();\n    const isSuccess = result.errors.length === 0 && result.warnings.length === 0;\n    return CliTaskResult.Success(isSuccess);\n  }\n  await buildContext.watch();\n  return CliTaskResult.DoNotExit();\n}\n"],
  "mappings": "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",
  "names": ["BuildMode"]
}

146
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/ScriptUtils/esbuild/ObsidianPluginBuilder.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module provides functionality to build and bundle an Obsidian plugin using esbuild.\n * It includes functions to handle the build process based on different build modes (development or production),\n * and it sets up various esbuild plugins to preprocess, lint, fix source maps, and copy files to the Obsidian plugins folder.\n */\n\nimport type {\n  BuildContext,\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { config } from 'dotenv';\nimport { context } from 'esbuild';\n// eslint-disable-next-line import-x/no-rename-default\nimport sassPlugin_ from 'esbuild-sass-plugin';\n\nimport { throwExpression } from '../../Error.ts';\nimport { ObsidianPluginRepoPaths } from '../../obsidian/Plugin/ObsidianPluginRepoPaths.ts';\nimport { join } from '../../Path.ts';\nimport { buildCompile } from '../build.ts';\nimport { CliTaskResult } from '../CliUtils.ts';\nimport {\n  builtinModules,\n  cp,\n  existsSync,\n  mkdir,\n  process,\n  rm,\n  writeFile\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { resolvePathFromRoot } from '../Root.ts';\nimport { copyToObsidianPluginsFolderPlugin } from './copyToObsidianPluginsFolderPlugin.ts';\nimport { customEsbuildOptionsPlugin } from './customEsbuildOptionsPlugin.ts';\nimport { fixEsmPlugin } from './fixEsmPlugin.ts';\nimport { fixSourceMapsPlugin } from './fixSourceMapsPlugin.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\nimport { renameCssPlugin } from './renameCssPlugin.ts';\nimport { svelteWrapperPlugin } from './svelteWrapperPlugin.ts';\n\nconst sassPlugin = ('default' in sassPlugin_ ? sassPlugin_.default : sassPlugin_) as unknown as typeof sassPlugin_.default;\n\n/**\n * Enumeration representing the build modes.\n */\nexport enum BuildMode {\n  /** Development mode for building the plugin */\n  Development,\n  /** Production mode for building the plugin */\n  Production\n}\n\n/**\n * Banner text to be included at the top of the generated files.\n */\nexport const banner = `/*\nTHIS IS A GENERATED/BUNDLED FILE BY ESBUILD\nif you want to view the source, please visit the github repository of this plugin\n*/\n`;\n\n/**\n * Options for building an Obsidian plugin.\n */\nexport interface BuildObsidianPluginOptions {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  customEsbuildPlugins?: Plugin[];\n\n  /**\n   * Customizes the esbuild options.\n   */\n  customizeEsbuildOptions?(options: BuildOptions): void;\n\n  /**\n   * The build mode, either Development or Production\n   */\n  mode: BuildMode;\n\n  /**\n   * The folder for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_FOLDER` environment variable.\n   */\n  obsidianConfigFolder?: string;\n}\n\ninterface ObsidianPluginBuilderEnv {\n  OBSIDIAN_CONFIG_FOLDER: string;\n}\n\n/**\n * Builds the Obsidian plugin based on the specified mode and configuration folder.\n *\n * @param options - The parameters for building the plugin.\n * @returns A {@link Promise} that resolves to a {@link CliTaskResult} indicating the success or failure of the build.\n */\nexport async function buildObsidianPlugin(options: BuildObsidianPluginOptions): Promise<CliTaskResult> {\n  await buildCompile();\n  config();\n  const obsidianPluginBuilderEnv = process.env as Partial<ObsidianPluginBuilderEnv>;\n\n  const obsidianConfigFolder = options.obsidianConfigFolder ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_FOLDER ?? '';\n  const isProductionBuild = options.mode === BuildMode.Production;\n\n  const distFolder = resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev);\n  if (!distFolder) {\n    throw new Error('Could not determine the dist folder');\n  }\n\n  if (existsSync(distFolder)) {\n    await rm(distFolder, { recursive: true });\n  }\n  await mkdir(distFolder, { recursive: true });\n\n  const distFileNames = [\n    ObsidianPluginRepoPaths.ManifestJson\n  ];\n  if (!isProductionBuild) {\n    await writeFile(join(distFolder, ObsidianPluginRepoPaths.HotReload), '', 'utf-8');\n  }\n\n  for (const fileName of distFileNames) {\n    const localFile = resolvePathFromRoot(fileName);\n    if (!localFile) {\n      throw new Error(`Could not determine the local file for ${fileName}`);\n    }\n    const distFile = join(distFolder, fileName);\n\n    if (existsSync(localFile)) {\n      await cp(localFile, distFile);\n    }\n  }\n\n  const distPath = join(distFolder, ObsidianPluginRepoPaths.MainJs);\n  const cssPath = join(distFolder, ObsidianPluginRepoPaths.StylesCss);\n\n  const packageJson = await readPackageJson();\n  const pluginName = packageJson.name ?? '(unknown)';\n\n  const buildOptions: BuildOptions = {\n    banner: {\n      js: banner\n    },\n    bundle: true,\n    conditions: ['browser'],\n    entryPoints: [\n      resolvePathFromRoot(join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs))\n        ?? throwExpression(new Error('Could not determine the entry point for the plugin'))\n    ],\n    external: [\n      'obsidian',\n      'electron',\n      '@codemirror/autocomplete',\n      '@codemirror/collab',\n      '@codemirror/commands',\n      '@codemirror/language',\n      '@codemirror/lint',\n      '@codemirror/search',\n      '@codemirror/state',\n      '@codemirror/view',\n      '@lezer/common',\n      '@lezer/highlight',\n      '@lezer/lr',\n      'esbuild',\n      'eslint',\n      ...builtinModules\n    ],\n    format: 'cjs',\n    logLevel: 'info',\n    minify: isProductionBuild,\n    outfile: distPath,\n    platform: 'node',\n    plugins: [\n      customEsbuildOptionsPlugin(options.customizeEsbuildOptions?.bind(options)),\n      svelteWrapperPlugin(isProductionBuild),\n      sassPlugin({\n        sourceMap: !isProductionBuild\n      }),\n      renameCssPlugin(distFolder),\n      preprocessPlugin(),\n      fixEsmPlugin(),\n      fixSourceMapsPlugin(isProductionBuild, [distPath, cssPath], pluginName),\n      ...options.customEsbuildPlugins ?? [],\n      copyToObsidianPluginsFolderPlugin(isProductionBuild, distFolder, obsidianConfigFolder, pluginName)\n    ],\n    sourcemap: isProductionBuild ? false : 'inline',\n    target: 'esnext',\n    treeShaking: true\n  };\n\n  const buildContext = await context(buildOptions);\n  return await invokeEsbuild(buildContext, isProductionBuild);\n}\n\n/**\n * Invokes the build process with the provided build context.\n *\n * @param buildContext - The build context generated by esbuild.\n * @param isProductionBuild - A boolean indicating whether the build is a production build.\n * @returns A {@link Promise} that resolves to a {@link CliTaskResult} indicating the success or failure of the build.\n */\nexport async function invokeEsbuild(buildContext: BuildContext, isProductionBuild: boolean): Promise<CliTaskResult> {\n  if (isProductionBuild) {\n    const result = await buildContext.rebuild();\n    const isSuccess = result.errors.length === 0 && result.warnings.length === 0;\n    return CliTaskResult.Success(isSuccess);\n  }\n  await buildContext.watch();\n  return CliTaskResult.DoNotExit();\n}\n"],
  "mappings": "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",
  "names": ["BuildMode"]
}

@@ -4,16 +4,16 @@
4
4
  * This module defines an esbuild plugin that automatically copies the build output
5
5
  * to the Obsidian plugins folder during development. This plugin helps streamline
6
6
  * the development workflow by ensuring that the latest build is always available
7
- * in the correct Obsidian directory for testing and use.
7
+ * in the correct Obsidian folder for testing and use.
8
8
  */
9
9
  import type { Plugin } from 'esbuild';
10
10
  /**
11
11
  * Creates an esbuild plugin that copies the build output to the Obsidian plugins folder.
12
12
  *
13
13
  * @param isProductionBuild - A boolean indicating whether the build is a production build.
14
- * @param distDir - The directory where the built files are located.
15
- * @param obsidianConfigDir - The directory of the Obsidian configuration. If not provided, the plugin will not copy files.
14
+ * @param distFolder - The folder where the built files are located.
15
+ * @param obsidianConfigFolder - The folder of the Obsidian configuration. If not provided, the plugin will not copy files.
16
16
  * @param pluginName - The name of the Obsidian plugin.
17
17
  * @returns An esbuild `Plugin` object.
18
18
  */
19
- export declare function copyToObsidianPluginsFolderPlugin(isProductionBuild: boolean, distDir: string, obsidianConfigDir: string, pluginName: string): Plugin;
19
+ export declare function copyToObsidianPluginsFolderPlugin(isProductionBuild: boolean, distFolder: string, obsidianConfigFolder: string, pluginName: string): Plugin;
@@ -15,29 +15,35 @@ import {
15
15
  mkdir,
16
16
  writeFile
17
17
  } from "../NodeModules.mjs";
18
- function copyToObsidianPluginsFolderPlugin(isProductionBuild, distDir, obsidianConfigDir, pluginName) {
18
+ function copyToObsidianPluginsFolderPlugin(isProductionBuild, distFolder, obsidianConfigFolder, pluginName) {
19
19
  return {
20
20
  name: "copy-to-obsidian-plugins-folder",
21
21
  setup(build) {
22
22
  build.onEnd(async () => {
23
- if (isProductionBuild || !obsidianConfigDir) {
23
+ if (isProductionBuild) {
24
24
  return;
25
25
  }
26
- obsidianConfigDir = toPosixPath(obsidianConfigDir);
27
- const pluginDir = join(obsidianConfigDir, "plugins", pluginName);
28
- if (!existsSync(pluginDir)) {
29
- await mkdir(pluginDir, { recursive: true });
26
+ if (!obsidianConfigFolder) {
27
+ console.warn(
28
+ "No Obsidian config folder configured. `OBSIDIAN_CONFIG_FOLDER` environment variable is not set in system or in `.env` file. The compiled plugin will not be copied into Obsidian plugins folder."
29
+ );
30
+ return;
31
+ }
32
+ obsidianConfigFolder = toPosixPath(obsidianConfigFolder);
33
+ const pluginFolder = join(obsidianConfigFolder, "plugins", pluginName);
34
+ if (!existsSync(pluginFolder)) {
35
+ await mkdir(pluginFolder, { recursive: true });
30
36
  }
31
- await cp(distDir, pluginDir, { recursive: true });
32
- const hotReloadDir = join(obsidianConfigDir, "plugins/hot-reload");
33
- if (!existsSync(hotReloadDir)) {
34
- await mkdir(hotReloadDir, { recursive: true });
37
+ await cp(distFolder, pluginFolder, { recursive: true });
38
+ const hotReloadFolder = join(obsidianConfigFolder, "plugins/hot-reload");
39
+ if (!existsSync(hotReloadFolder)) {
40
+ await mkdir(hotReloadFolder, { recursive: true });
35
41
  const hotReloadRepoUrl = "https://raw.githubusercontent.com/pjeby/hot-reload/master/";
36
42
  for (const fileName of ["main.js", "manifest.json"]) {
37
43
  const fileUrl = hotReloadRepoUrl + fileName;
38
44
  const response = await fetch(fileUrl);
39
45
  const text = await response.text();
40
- await writeFile(join(hotReloadDir, fileName), text);
46
+ await writeFile(join(hotReloadFolder, fileName), text);
41
47
  }
42
48
  }
43
49
  });
@@ -47,4 +53,4 @@ function copyToObsidianPluginsFolderPlugin(isProductionBuild, distDir, obsidianC
47
53
  export {
48
54
  copyToObsidianPluginsFolderPlugin
49
55
  };
50
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2VzYnVpbGQvY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFRoaXMgbW9kdWxlIGRlZmluZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCBhdXRvbWF0aWNhbGx5IGNvcGllcyB0aGUgYnVpbGQgb3V0cHV0XG4gKiB0byB0aGUgT2JzaWRpYW4gcGx1Z2lucyBmb2xkZXIgZHVyaW5nIGRldmVsb3BtZW50LiBUaGlzIHBsdWdpbiBoZWxwcyBzdHJlYW1saW5lXG4gKiB0aGUgZGV2ZWxvcG1lbnQgd29ya2Zsb3cgYnkgZW5zdXJpbmcgdGhhdCB0aGUgbGF0ZXN0IGJ1aWxkIGlzIGFsd2F5cyBhdmFpbGFibGVcbiAqIGluIHRoZSBjb3JyZWN0IE9ic2lkaWFuIGRpcmVjdG9yeSBmb3IgdGVzdGluZyBhbmQgdXNlLlxuICovXG5cbmltcG9ydCB0eXBlIHsgUGx1Z2luIH0gZnJvbSAnZXNidWlsZCc7XG5cbmltcG9ydCB7XG4gIGpvaW4sXG4gIHRvUG9zaXhQYXRoXG59IGZyb20gJy4uLy4uL1BhdGgudHMnO1xuaW1wb3J0IHtcbiAgY3AsXG4gIGV4aXN0c1N5bmMsXG4gIG1rZGlyLFxuICB3cml0ZUZpbGVcbn0gZnJvbSAnLi4vTm9kZU1vZHVsZXMudHMnO1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCBjb3BpZXMgdGhlIGJ1aWxkIG91dHB1dCB0byB0aGUgT2JzaWRpYW4gcGx1Z2lucyBmb2xkZXIuXG4gKlxuICogQHBhcmFtIGlzUHJvZHVjdGlvbkJ1aWxkIC0gQSBib29sZWFuIGluZGljYXRpbmcgd2hldGhlciB0aGUgYnVpbGQgaXMgYSBwcm9kdWN0aW9uIGJ1aWxkLlxuICogQHBhcmFtIGRpc3REaXIgLSBUaGUgZGlyZWN0b3J5IHdoZXJlIHRoZSBidWlsdCBmaWxlcyBhcmUgbG9jYXRlZC5cbiAqIEBwYXJhbSBvYnNpZGlhbkNvbmZpZ0RpciAtIFRoZSBkaXJlY3Rvcnkgb2YgdGhlIE9ic2lkaWFuIGNvbmZpZ3VyYXRpb24uIElmIG5vdCBwcm92aWRlZCwgdGhlIHBsdWdpbiB3aWxsIG5vdCBjb3B5IGZpbGVzLlxuICogQHBhcmFtIHBsdWdpbk5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgT2JzaWRpYW4gcGx1Z2luLlxuICogQHJldHVybnMgQW4gZXNidWlsZCBgUGx1Z2luYCBvYmplY3QuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb3B5VG9PYnNpZGlhblBsdWdpbnNGb2xkZXJQbHVnaW4oXG4gIGlzUHJvZHVjdGlvbkJ1aWxkOiBib29sZWFuLFxuICBkaXN0RGlyOiBzdHJpbmcsXG4gIG9ic2lkaWFuQ29uZmlnRGlyOiBzdHJpbmcsXG4gIHBsdWdpbk5hbWU6IHN0cmluZ1xuKTogUGx1Z2luIHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAnY29weS10by1vYnNpZGlhbi1wbHVnaW5zLWZvbGRlcicsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jICgpID0+IHtcbiAgICAgICAgaWYgKGlzUHJvZHVjdGlvbkJ1aWxkIHx8ICFvYnNpZGlhbkNvbmZpZ0Rpcikge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIG9ic2lkaWFuQ29uZmlnRGlyID0gdG9Qb3NpeFBhdGgob2JzaWRpYW5Db25maWdEaXIpO1xuXG4gICAgICAgIGNvbnN0IHBsdWdpbkRpciA9IGpvaW4ob2JzaWRpYW5Db25maWdEaXIsICdwbHVnaW5zJywgcGx1Z2luTmFtZSk7XG5cbiAgICAgICAgaWYgKCFleGlzdHNTeW5jKHBsdWdpbkRpcikpIHtcbiAgICAgICAgICBhd2FpdCBta2RpcihwbHVnaW5EaXIsIHsgcmVjdXJzaXZlOiB0cnVlIH0pO1xuICAgICAgICB9XG5cbiAgICAgICAgYXdhaXQgY3AoZGlzdERpciwgcGx1Z2luRGlyLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcblxuICAgICAgICBjb25zdCBob3RSZWxvYWREaXIgPSBqb2luKG9ic2lkaWFuQ29uZmlnRGlyLCAncGx1Z2lucy9ob3QtcmVsb2FkJyk7XG4gICAgICAgIGlmICghZXhpc3RzU3luYyhob3RSZWxvYWREaXIpKSB7XG4gICAgICAgICAgYXdhaXQgbWtkaXIoaG90UmVsb2FkRGlyLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbiAgICAgICAgICBjb25zdCBob3RSZWxvYWRSZXBvVXJsID0gJ2h0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS9wamVieS9ob3QtcmVsb2FkL21hc3Rlci8nO1xuICAgICAgICAgIGZvciAoY29uc3QgZmlsZU5hbWUgb2YgWydtYWluLmpzJywgJ21hbmlmZXN0Lmpzb24nXSkge1xuICAgICAgICAgICAgY29uc3QgZmlsZVVybCA9IGhvdFJlbG9hZFJlcG9VcmwgKyBmaWxlTmFtZTtcbiAgICAgICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmV0Y2goZmlsZVVybCk7XG4gICAgICAgICAgICBjb25zdCB0ZXh0ID0gYXdhaXQgcmVzcG9uc2UudGV4dCgpO1xuICAgICAgICAgICAgYXdhaXQgd3JpdGVGaWxlKGpvaW4oaG90UmVsb2FkRGlyLCBmaWxlTmFtZSksIHRleHQpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuICB9O1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7OztBQVdBO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBQ1A7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsT0FDSztBQVdBLFNBQVMsa0NBQ2QsbUJBQ0EsU0FDQSxtQkFDQSxZQUNRO0FBQ1IsU0FBTztBQUFBLElBQ0wsTUFBTTtBQUFBLElBQ04sTUFBTSxPQUFhO0FBQ2pCLFlBQU0sTUFBTSxZQUFZO0FBQ3RCLFlBQUkscUJBQXFCLENBQUMsbUJBQW1CO0FBQzNDO0FBQUEsUUFDRjtBQUVBLDRCQUFvQixZQUFZLGlCQUFpQjtBQUVqRCxjQUFNLFlBQVksS0FBSyxtQkFBbUIsV0FBVyxVQUFVO0FBRS9ELFlBQUksQ0FBQyxXQUFXLFNBQVMsR0FBRztBQUMxQixnQkFBTSxNQUFNLFdBQVcsRUFBRSxXQUFXLEtBQUssQ0FBQztBQUFBLFFBQzVDO0FBRUEsY0FBTSxHQUFHLFNBQVMsV0FBVyxFQUFFLFdBQVcsS0FBSyxDQUFDO0FBRWhELGNBQU0sZUFBZSxLQUFLLG1CQUFtQixvQkFBb0I7QUFDakUsWUFBSSxDQUFDLFdBQVcsWUFBWSxHQUFHO0FBQzdCLGdCQUFNLE1BQU0sY0FBYyxFQUFFLFdBQVcsS0FBSyxDQUFDO0FBQzdDLGdCQUFNLG1CQUFtQjtBQUN6QixxQkFBVyxZQUFZLENBQUMsV0FBVyxlQUFlLEdBQUc7QUFDbkQsa0JBQU0sVUFBVSxtQkFBbUI7QUFDbkMsa0JBQU0sV0FBVyxNQUFNLE1BQU0sT0FBTztBQUNwQyxrQkFBTSxPQUFPLE1BQU0sU0FBUyxLQUFLO0FBQ2pDLGtCQUFNLFVBQVUsS0FBSyxjQUFjLFFBQVEsR0FBRyxJQUFJO0FBQUEsVUFDcEQ7QUFBQSxRQUNGO0FBQUEsTUFDRixDQUFDO0FBQUEsSUFDSDtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
56
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2VzYnVpbGQvY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFRoaXMgbW9kdWxlIGRlZmluZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCBhdXRvbWF0aWNhbGx5IGNvcGllcyB0aGUgYnVpbGQgb3V0cHV0XG4gKiB0byB0aGUgT2JzaWRpYW4gcGx1Z2lucyBmb2xkZXIgZHVyaW5nIGRldmVsb3BtZW50LiBUaGlzIHBsdWdpbiBoZWxwcyBzdHJlYW1saW5lXG4gKiB0aGUgZGV2ZWxvcG1lbnQgd29ya2Zsb3cgYnkgZW5zdXJpbmcgdGhhdCB0aGUgbGF0ZXN0IGJ1aWxkIGlzIGFsd2F5cyBhdmFpbGFibGVcbiAqIGluIHRoZSBjb3JyZWN0IE9ic2lkaWFuIGZvbGRlciBmb3IgdGVzdGluZyBhbmQgdXNlLlxuICovXG5cbmltcG9ydCB0eXBlIHsgUGx1Z2luIH0gZnJvbSAnZXNidWlsZCc7XG5cbmltcG9ydCB7XG4gIGpvaW4sXG4gIHRvUG9zaXhQYXRoXG59IGZyb20gJy4uLy4uL1BhdGgudHMnO1xuaW1wb3J0IHtcbiAgY3AsXG4gIGV4aXN0c1N5bmMsXG4gIG1rZGlyLFxuICB3cml0ZUZpbGVcbn0gZnJvbSAnLi4vTm9kZU1vZHVsZXMudHMnO1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCBjb3BpZXMgdGhlIGJ1aWxkIG91dHB1dCB0byB0aGUgT2JzaWRpYW4gcGx1Z2lucyBmb2xkZXIuXG4gKlxuICogQHBhcmFtIGlzUHJvZHVjdGlvbkJ1aWxkIC0gQSBib29sZWFuIGluZGljYXRpbmcgd2hldGhlciB0aGUgYnVpbGQgaXMgYSBwcm9kdWN0aW9uIGJ1aWxkLlxuICogQHBhcmFtIGRpc3RGb2xkZXIgLSBUaGUgZm9sZGVyIHdoZXJlIHRoZSBidWlsdCBmaWxlcyBhcmUgbG9jYXRlZC5cbiAqIEBwYXJhbSBvYnNpZGlhbkNvbmZpZ0ZvbGRlciAtIFRoZSBmb2xkZXIgb2YgdGhlIE9ic2lkaWFuIGNvbmZpZ3VyYXRpb24uIElmIG5vdCBwcm92aWRlZCwgdGhlIHBsdWdpbiB3aWxsIG5vdCBjb3B5IGZpbGVzLlxuICogQHBhcmFtIHBsdWdpbk5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgT2JzaWRpYW4gcGx1Z2luLlxuICogQHJldHVybnMgQW4gZXNidWlsZCBgUGx1Z2luYCBvYmplY3QuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb3B5VG9PYnNpZGlhblBsdWdpbnNGb2xkZXJQbHVnaW4oXG4gIGlzUHJvZHVjdGlvbkJ1aWxkOiBib29sZWFuLFxuICBkaXN0Rm9sZGVyOiBzdHJpbmcsXG4gIG9ic2lkaWFuQ29uZmlnRm9sZGVyOiBzdHJpbmcsXG4gIHBsdWdpbk5hbWU6IHN0cmluZ1xuKTogUGx1Z2luIHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAnY29weS10by1vYnNpZGlhbi1wbHVnaW5zLWZvbGRlcicsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jICgpID0+IHtcbiAgICAgICAgaWYgKGlzUHJvZHVjdGlvbkJ1aWxkKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCFvYnNpZGlhbkNvbmZpZ0ZvbGRlcikge1xuICAgICAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgICAgICdObyBPYnNpZGlhbiBjb25maWcgZm9sZGVyIGNvbmZpZ3VyZWQuIGBPQlNJRElBTl9DT05GSUdfRk9MREVSYCBlbnZpcm9ubWVudCB2YXJpYWJsZSBpcyBub3Qgc2V0IGluIHN5c3RlbSBvciBpbiBgLmVudmAgZmlsZS4gVGhlIGNvbXBpbGVkIHBsdWdpbiB3aWxsIG5vdCBiZSBjb3BpZWQgaW50byBPYnNpZGlhbiBwbHVnaW5zIGZvbGRlci4nXG4gICAgICAgICAgKTtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBvYnNpZGlhbkNvbmZpZ0ZvbGRlciA9IHRvUG9zaXhQYXRoKG9ic2lkaWFuQ29uZmlnRm9sZGVyKTtcblxuICAgICAgICBjb25zdCBwbHVnaW5Gb2xkZXIgPSBqb2luKG9ic2lkaWFuQ29uZmlnRm9sZGVyLCAncGx1Z2lucycsIHBsdWdpbk5hbWUpO1xuXG4gICAgICAgIGlmICghZXhpc3RzU3luYyhwbHVnaW5Gb2xkZXIpKSB7XG4gICAgICAgICAgYXdhaXQgbWtkaXIocGx1Z2luRm9sZGVyLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIGF3YWl0IGNwKGRpc3RGb2xkZXIsIHBsdWdpbkZvbGRlciwgeyByZWN1cnNpdmU6IHRydWUgfSk7XG5cbiAgICAgICAgY29uc3QgaG90UmVsb2FkRm9sZGVyID0gam9pbihvYnNpZGlhbkNvbmZpZ0ZvbGRlciwgJ3BsdWdpbnMvaG90LXJlbG9hZCcpO1xuICAgICAgICBpZiAoIWV4aXN0c1N5bmMoaG90UmVsb2FkRm9sZGVyKSkge1xuICAgICAgICAgIGF3YWl0IG1rZGlyKGhvdFJlbG9hZEZvbGRlciwgeyByZWN1cnNpdmU6IHRydWUgfSk7XG4gICAgICAgICAgY29uc3QgaG90UmVsb2FkUmVwb1VybCA9ICdodHRwczovL3Jhdy5naXRodWJ1c2VyY29udGVudC5jb20vcGplYnkvaG90LXJlbG9hZC9tYXN0ZXIvJztcbiAgICAgICAgICBmb3IgKGNvbnN0IGZpbGVOYW1lIG9mIFsnbWFpbi5qcycsICdtYW5pZmVzdC5qc29uJ10pIHtcbiAgICAgICAgICAgIGNvbnN0IGZpbGVVcmwgPSBob3RSZWxvYWRSZXBvVXJsICsgZmlsZU5hbWU7XG4gICAgICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGZldGNoKGZpbGVVcmwpO1xuICAgICAgICAgICAgY29uc3QgdGV4dCA9IGF3YWl0IHJlc3BvbnNlLnRleHQoKTtcbiAgICAgICAgICAgIGF3YWl0IHdyaXRlRmlsZShqb2luKGhvdFJlbG9hZEZvbGRlciwgZmlsZU5hbWUpLCB0ZXh0KTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgfTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7QUFXQTtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQUNQO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFXQSxTQUFTLGtDQUNkLG1CQUNBLFlBQ0Esc0JBQ0EsWUFDUTtBQUNSLFNBQU87QUFBQSxJQUNMLE1BQU07QUFBQSxJQUNOLE1BQU0sT0FBYTtBQUNqQixZQUFNLE1BQU0sWUFBWTtBQUN0QixZQUFJLG1CQUFtQjtBQUNyQjtBQUFBLFFBQ0Y7QUFFQSxZQUFJLENBQUMsc0JBQXNCO0FBQ3pCLGtCQUFRO0FBQUEsWUFDTjtBQUFBLFVBQ0Y7QUFDQTtBQUFBLFFBQ0Y7QUFFQSwrQkFBdUIsWUFBWSxvQkFBb0I7QUFFdkQsY0FBTSxlQUFlLEtBQUssc0JBQXNCLFdBQVcsVUFBVTtBQUVyRSxZQUFJLENBQUMsV0FBVyxZQUFZLEdBQUc7QUFDN0IsZ0JBQU0sTUFBTSxjQUFjLEVBQUUsV0FBVyxLQUFLLENBQUM7QUFBQSxRQUMvQztBQUVBLGNBQU0sR0FBRyxZQUFZLGNBQWMsRUFBRSxXQUFXLEtBQUssQ0FBQztBQUV0RCxjQUFNLGtCQUFrQixLQUFLLHNCQUFzQixvQkFBb0I7QUFDdkUsWUFBSSxDQUFDLFdBQVcsZUFBZSxHQUFHO0FBQ2hDLGdCQUFNLE1BQU0saUJBQWlCLEVBQUUsV0FBVyxLQUFLLENBQUM7QUFDaEQsZ0JBQU0sbUJBQW1CO0FBQ3pCLHFCQUFXLFlBQVksQ0FBQyxXQUFXLGVBQWUsR0FBRztBQUNuRCxrQkFBTSxVQUFVLG1CQUFtQjtBQUNuQyxrQkFBTSxXQUFXLE1BQU0sTUFBTSxPQUFPO0FBQ3BDLGtCQUFNLE9BQU8sTUFBTSxTQUFTLEtBQUs7QUFDakMsa0JBQU0sVUFBVSxLQUFLLGlCQUFpQixRQUFRLEdBQUcsSUFBSTtBQUFBLFVBQ3ZEO0FBQUEsUUFDRjtBQUFBLE1BQ0YsQ0FBQztBQUFBLElBQ0g7QUFBQSxFQUNGO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -7,7 +7,7 @@ import type { Plugin } from 'esbuild';
7
7
  /**
8
8
  * Plugin that renames the CSS file to the correct name.
9
9
  *
10
- * @param distDir - The directory to rename the CSS file in.
10
+ * @param distFolder - The folder to rename the CSS file in.
11
11
  * @returns The plugin.
12
12
  */
13
- export declare function renameCssPlugin(distDir: string): Plugin;
13
+ export declare function renameCssPlugin(distFolder: string): Plugin;
@@ -11,13 +11,13 @@ import {
11
11
  existsSync,
12
12
  rename
13
13
  } from "../NodeModules.mjs";
14
- function renameCssPlugin(distDir) {
14
+ function renameCssPlugin(distFolder) {
15
15
  return {
16
16
  name: "rename-css",
17
17
  setup(build) {
18
18
  build.onEnd(async () => {
19
- const mainCssPath = join(distDir, ObsidianPluginRepoPaths.MainCss);
20
- const stylesCssPath = join(distDir, ObsidianPluginRepoPaths.StylesCss);
19
+ const mainCssPath = join(distFolder, ObsidianPluginRepoPaths.MainCss);
20
+ const stylesCssPath = join(distFolder, ObsidianPluginRepoPaths.StylesCss);
21
21
  if (existsSync(mainCssPath)) {
22
22
  await rename(mainCssPath, stylesCssPath);
23
23
  }
@@ -28,4 +28,4 @@ function renameCssPlugin(distDir) {
28
28
  export {
29
29
  renameCssPlugin
30
30
  };
31
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2VzYnVpbGQvcmVuYW1lQ3NzUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFJlbmFtZSBDU1MgZXNidWlsZCBwbHVnaW4uXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBQbHVnaW4gfSBmcm9tICdlc2J1aWxkJztcblxuaW1wb3J0IHsgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMgfSBmcm9tICcuLi8uLi9vYnNpZGlhbi9QbHVnaW4vT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMudHMnO1xuaW1wb3J0IHsgam9pbiB9IGZyb20gJy4uLy4uL1BhdGgudHMnO1xuaW1wb3J0IHtcbiAgZXhpc3RzU3luYyxcbiAgcmVuYW1lXG59IGZyb20gJy4uL05vZGVNb2R1bGVzLnRzJztcblxuLyoqXG4gKiBQbHVnaW4gdGhhdCByZW5hbWVzIHRoZSBDU1MgZmlsZSB0byB0aGUgY29ycmVjdCBuYW1lLlxuICpcbiAqIEBwYXJhbSBkaXN0RGlyIC0gVGhlIGRpcmVjdG9yeSB0byByZW5hbWUgdGhlIENTUyBmaWxlIGluLlxuICogQHJldHVybnMgVGhlIHBsdWdpbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlbmFtZUNzc1BsdWdpbihkaXN0RGlyOiBzdHJpbmcpOiBQbHVnaW4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdyZW5hbWUtY3NzJyxcbiAgICBzZXR1cChidWlsZCk6IHZvaWQge1xuICAgICAgYnVpbGQub25FbmQoYXN5bmMgKCkgPT4ge1xuICAgICAgICBjb25zdCBtYWluQ3NzUGF0aCA9IGpvaW4oZGlzdERpciwgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMuTWFpbkNzcyk7XG4gICAgICAgIGNvbnN0IHN0eWxlc0Nzc1BhdGggPSBqb2luKGRpc3REaXIsIE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzLlN0eWxlc0Nzcyk7XG4gICAgICAgIGlmIChleGlzdHNTeW5jKG1haW5Dc3NQYXRoKSkge1xuICAgICAgICAgIGF3YWl0IHJlbmFtZShtYWluQ3NzUGF0aCwgc3R5bGVzQ3NzUGF0aCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgfTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7QUFRQSxTQUFTLCtCQUErQjtBQUN4QyxTQUFTLFlBQVk7QUFDckI7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFRQSxTQUFTLGdCQUFnQixTQUF5QjtBQUN2RCxTQUFPO0FBQUEsSUFDTCxNQUFNO0FBQUEsSUFDTixNQUFNLE9BQWE7QUFDakIsWUFBTSxNQUFNLFlBQVk7QUFDdEIsY0FBTSxjQUFjLEtBQUssU0FBUyx3QkFBd0IsT0FBTztBQUNqRSxjQUFNLGdCQUFnQixLQUFLLFNBQVMsd0JBQXdCLFNBQVM7QUFDckUsWUFBSSxXQUFXLFdBQVcsR0FBRztBQUMzQixnQkFBTSxPQUFPLGFBQWEsYUFBYTtBQUFBLFFBQ3pDO0FBQUEsTUFDRixDQUFDO0FBQUEsSUFDSDtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
31
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2VzYnVpbGQvcmVuYW1lQ3NzUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFJlbmFtZSBDU1MgZXNidWlsZCBwbHVnaW4uXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBQbHVnaW4gfSBmcm9tICdlc2J1aWxkJztcblxuaW1wb3J0IHsgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMgfSBmcm9tICcuLi8uLi9vYnNpZGlhbi9QbHVnaW4vT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMudHMnO1xuaW1wb3J0IHsgam9pbiB9IGZyb20gJy4uLy4uL1BhdGgudHMnO1xuaW1wb3J0IHtcbiAgZXhpc3RzU3luYyxcbiAgcmVuYW1lXG59IGZyb20gJy4uL05vZGVNb2R1bGVzLnRzJztcblxuLyoqXG4gKiBQbHVnaW4gdGhhdCByZW5hbWVzIHRoZSBDU1MgZmlsZSB0byB0aGUgY29ycmVjdCBuYW1lLlxuICpcbiAqIEBwYXJhbSBkaXN0Rm9sZGVyIC0gVGhlIGZvbGRlciB0byByZW5hbWUgdGhlIENTUyBmaWxlIGluLlxuICogQHJldHVybnMgVGhlIHBsdWdpbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlbmFtZUNzc1BsdWdpbihkaXN0Rm9sZGVyOiBzdHJpbmcpOiBQbHVnaW4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdyZW5hbWUtY3NzJyxcbiAgICBzZXR1cChidWlsZCk6IHZvaWQge1xuICAgICAgYnVpbGQub25FbmQoYXN5bmMgKCkgPT4ge1xuICAgICAgICBjb25zdCBtYWluQ3NzUGF0aCA9IGpvaW4oZGlzdEZvbGRlciwgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMuTWFpbkNzcyk7XG4gICAgICAgIGNvbnN0IHN0eWxlc0Nzc1BhdGggPSBqb2luKGRpc3RGb2xkZXIsIE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzLlN0eWxlc0Nzcyk7XG4gICAgICAgIGlmIChleGlzdHNTeW5jKG1haW5Dc3NQYXRoKSkge1xuICAgICAgICAgIGF3YWl0IHJlbmFtZShtYWluQ3NzUGF0aCwgc3R5bGVzQ3NzUGF0aCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgfTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7QUFRQSxTQUFTLCtCQUErQjtBQUN4QyxTQUFTLFlBQVk7QUFDckI7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFRQSxTQUFTLGdCQUFnQixZQUE0QjtBQUMxRCxTQUFPO0FBQUEsSUFDTCxNQUFNO0FBQUEsSUFDTixNQUFNLE9BQWE7QUFDakIsWUFBTSxNQUFNLFlBQVk7QUFDdEIsY0FBTSxjQUFjLEtBQUssWUFBWSx3QkFBd0IsT0FBTztBQUNwRSxjQUFNLGdCQUFnQixLQUFLLFlBQVksd0JBQXdCLFNBQVM7QUFDeEUsWUFBSSxXQUFXLFdBQVcsR0FBRztBQUMzQixnQkFBTSxPQUFPLGFBQWEsYUFBYTtBQUFBLFFBQ3pDO0FBQUEsTUFDRixDQUFDO0FBQUEsSUFDSDtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -6,28 +6,28 @@ if you want to view the source, please visit the github repository of this plugi
6
6
  (function initEsm(){if(globalThis.process){return}const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};globalThis.process=browserProcess})();
7
7
 
8
8
  import {
9
- getDirname,
9
+ getFolderName,
10
10
  join
11
11
  } from "../Path.mjs";
12
12
  import { existsSync } from "./NodeModules.mjs";
13
13
  import { ObsidianDevUtilsRepoPaths } from "./ObsidianDevUtilsRepoPaths.mjs";
14
14
  import {
15
15
  execFromRoot,
16
- getRootDir,
16
+ getRootFolder,
17
17
  resolvePathFromRootSafe
18
18
  } from "./Root.mjs";
19
19
  async function format(rewrite = true) {
20
- const rootDir = getRootDir();
21
- if (!rootDir) {
22
- throw new Error("Root directory not found");
20
+ const rootFolder = getRootFolder();
21
+ if (!rootFolder) {
22
+ throw new Error("Root folder not found");
23
23
  }
24
24
  let dprintJsonPath = resolvePathFromRootSafe(ObsidianDevUtilsRepoPaths.DprintJson);
25
25
  if (!existsSync(dprintJsonPath)) {
26
- const packageDir = getRootDir(getDirname(import.meta.url));
27
- if (!packageDir) {
28
- throw new Error("Could not find package directory.");
26
+ const packageFolder = getRootFolder(getFolderName(import.meta.url));
27
+ if (!packageFolder) {
28
+ throw new Error("Could not find package folder.");
29
29
  }
30
- dprintJsonPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Dist, ObsidianDevUtilsRepoPaths.DprintJson), packageDir);
30
+ dprintJsonPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Dist, ObsidianDevUtilsRepoPaths.DprintJson), packageFolder);
31
31
  }
32
32
  if (!existsSync(dprintJsonPath)) {
33
33
  throw new Error("dprint.json not found");
@@ -38,4 +38,4 @@ async function format(rewrite = true) {
38
38
  export {
39
39
  format
40
40
  };
41
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2Zvcm1hdC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBGb3JtYXQgdGhlIHNvdXJjZSBjb2RlLlxuICovXG5cbmltcG9ydCB7XG4gIGdldERpcm5hbWUsXG4gIGpvaW5cbn0gZnJvbSAnLi4vUGF0aC50cyc7XG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSAnLi9Ob2RlTW9kdWxlcy50cyc7XG5pbXBvcnQgeyBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIH0gZnJvbSAnLi9PYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7XG4gIGV4ZWNGcm9tUm9vdCxcbiAgZ2V0Um9vdERpcixcbiAgcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmVcbn0gZnJvbSAnLi9Sb290LnRzJztcblxuLyoqXG4gKiBGb3JtYXQgdGhlIHNvdXJjZSBjb2RlLlxuICpcbiAqIEBwYXJhbSByZXdyaXRlIC0gV2hldGhlciB0byByZXdyaXRlIHRoZSBzb3VyY2UgY29kZS5cbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgc291cmNlIGNvZGUgaGFzIGJlZW4gZm9ybWF0dGVkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZm9ybWF0KHJld3JpdGUgPSB0cnVlKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHJvb3REaXIgPSBnZXRSb290RGlyKCk7XG4gIGlmICghcm9vdERpcikge1xuICAgIHRocm93IG5ldyBFcnJvcignUm9vdCBkaXJlY3Rvcnkgbm90IGZvdW5kJyk7XG4gIH1cbiAgbGV0IGRwcmludEpzb25QYXRoID0gcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmUoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EcHJpbnRKc29uKTtcbiAgaWYgKCFleGlzdHNTeW5jKGRwcmludEpzb25QYXRoKSkge1xuICAgIGNvbnN0IHBhY2thZ2VEaXIgPSBnZXRSb290RGlyKGdldERpcm5hbWUoaW1wb3J0Lm1ldGEudXJsKSk7XG4gICAgaWYgKCFwYWNrYWdlRGlyKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0NvdWxkIG5vdCBmaW5kIHBhY2thZ2UgZGlyZWN0b3J5LicpO1xuICAgIH1cbiAgICBkcHJpbnRKc29uUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRwcmludEpzb24pLCBwYWNrYWdlRGlyKTtcbiAgfVxuXG4gIGlmICghZXhpc3RzU3luYyhkcHJpbnRKc29uUGF0aCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2RwcmludC5qc29uIG5vdCBmb3VuZCcpO1xuICB9XG5cbiAgY29uc3QgY29tbWFuZCA9IHJld3JpdGUgPyAnZm10JyA6ICdjaGVjayc7XG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ25weCcsICdkcHJpbnQnLCBjb21tYW5kLCAnLS1jb25maWcnLCBkcHJpbnRKc29uUGF0aCwgJyoqLyonXSk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBTUE7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFDUCxTQUFTLGtCQUFrQjtBQUMzQixTQUFTLGlDQUFpQztBQUMxQztBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFRUCxlQUFzQixPQUFPLFVBQVUsTUFBcUI7QUFDMUQsUUFBTSxVQUFVLFdBQVc7QUFDM0IsTUFBSSxDQUFDLFNBQVM7QUFDWixVQUFNLElBQUksTUFBTSwwQkFBMEI7QUFBQSxFQUM1QztBQUNBLE1BQUksaUJBQWlCLHdCQUF3QiwwQkFBMEIsVUFBVTtBQUNqRixNQUFJLENBQUMsV0FBVyxjQUFjLEdBQUc7QUFDL0IsVUFBTSxhQUFhLFdBQVcsV0FBVyxZQUFZLEdBQUcsQ0FBQztBQUN6RCxRQUFJLENBQUMsWUFBWTtBQUNmLFlBQU0sSUFBSSxNQUFNLG1DQUFtQztBQUFBLElBQ3JEO0FBQ0EscUJBQWlCLHdCQUF3QixLQUFLLDBCQUEwQixNQUFNLDBCQUEwQixVQUFVLEdBQUcsVUFBVTtBQUFBLEVBQ2pJO0FBRUEsTUFBSSxDQUFDLFdBQVcsY0FBYyxHQUFHO0FBQy9CLFVBQU0sSUFBSSxNQUFNLHVCQUF1QjtBQUFBLEVBQ3pDO0FBRUEsUUFBTSxVQUFVLFVBQVUsUUFBUTtBQUNsQyxRQUFNLGFBQWEsQ0FBQyxPQUFPLFVBQVUsU0FBUyxZQUFZLGdCQUFnQixNQUFNLENBQUM7QUFDbkY7IiwKICAibmFtZXMiOiBbXQp9Cg==
41
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2Zvcm1hdC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBGb3JtYXQgdGhlIHNvdXJjZSBjb2RlLlxuICovXG5cbmltcG9ydCB7XG4gIGdldEZvbGRlck5hbWUsXG4gIGpvaW5cbn0gZnJvbSAnLi4vUGF0aC50cyc7XG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSAnLi9Ob2RlTW9kdWxlcy50cyc7XG5pbXBvcnQgeyBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIH0gZnJvbSAnLi9PYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7XG4gIGV4ZWNGcm9tUm9vdCxcbiAgZ2V0Um9vdEZvbGRlcixcbiAgcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmVcbn0gZnJvbSAnLi9Sb290LnRzJztcblxuLyoqXG4gKiBGb3JtYXQgdGhlIHNvdXJjZSBjb2RlLlxuICpcbiAqIEBwYXJhbSByZXdyaXRlIC0gV2hldGhlciB0byByZXdyaXRlIHRoZSBzb3VyY2UgY29kZS5cbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgc291cmNlIGNvZGUgaGFzIGJlZW4gZm9ybWF0dGVkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZm9ybWF0KHJld3JpdGUgPSB0cnVlKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHJvb3RGb2xkZXIgPSBnZXRSb290Rm9sZGVyKCk7XG4gIGlmICghcm9vdEZvbGRlcikge1xuICAgIHRocm93IG5ldyBFcnJvcignUm9vdCBmb2xkZXIgbm90IGZvdW5kJyk7XG4gIH1cbiAgbGV0IGRwcmludEpzb25QYXRoID0gcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmUoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EcHJpbnRKc29uKTtcbiAgaWYgKCFleGlzdHNTeW5jKGRwcmludEpzb25QYXRoKSkge1xuICAgIGNvbnN0IHBhY2thZ2VGb2xkZXIgPSBnZXRSb290Rm9sZGVyKGdldEZvbGRlck5hbWUoaW1wb3J0Lm1ldGEudXJsKSk7XG4gICAgaWYgKCFwYWNrYWdlRm9sZGVyKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0NvdWxkIG5vdCBmaW5kIHBhY2thZ2UgZm9sZGVyLicpO1xuICAgIH1cbiAgICBkcHJpbnRKc29uUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRwcmludEpzb24pLCBwYWNrYWdlRm9sZGVyKTtcbiAgfVxuXG4gIGlmICghZXhpc3RzU3luYyhkcHJpbnRKc29uUGF0aCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2RwcmludC5qc29uIG5vdCBmb3VuZCcpO1xuICB9XG5cbiAgY29uc3QgY29tbWFuZCA9IHJld3JpdGUgPyAnZm10JyA6ICdjaGVjayc7XG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ25weCcsICdkcHJpbnQnLCBjb21tYW5kLCAnLS1jb25maWcnLCBkcHJpbnRKc29uUGF0aCwgJyoqLyonXSk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBTUE7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFDUCxTQUFTLGtCQUFrQjtBQUMzQixTQUFTLGlDQUFpQztBQUMxQztBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFRUCxlQUFzQixPQUFPLFVBQVUsTUFBcUI7QUFDMUQsUUFBTSxhQUFhLGNBQWM7QUFDakMsTUFBSSxDQUFDLFlBQVk7QUFDZixVQUFNLElBQUksTUFBTSx1QkFBdUI7QUFBQSxFQUN6QztBQUNBLE1BQUksaUJBQWlCLHdCQUF3QiwwQkFBMEIsVUFBVTtBQUNqRixNQUFJLENBQUMsV0FBVyxjQUFjLEdBQUc7QUFDL0IsVUFBTSxnQkFBZ0IsY0FBYyxjQUFjLFlBQVksR0FBRyxDQUFDO0FBQ2xFLFFBQUksQ0FBQyxlQUFlO0FBQ2xCLFlBQU0sSUFBSSxNQUFNLGdDQUFnQztBQUFBLElBQ2xEO0FBQ0EscUJBQWlCLHdCQUF3QixLQUFLLDBCQUEwQixNQUFNLDBCQUEwQixVQUFVLEdBQUcsYUFBYTtBQUFBLEVBQ3BJO0FBRUEsTUFBSSxDQUFDLFdBQVcsY0FBYyxHQUFHO0FBQy9CLFVBQU0sSUFBSSxNQUFNLHVCQUF1QjtBQUFBLEVBQ3pDO0FBRUEsUUFBTSxVQUFVLFVBQVUsUUFBUTtBQUNsQyxRQUFNLGFBQWEsQ0FBQyxPQUFPLFVBQVUsU0FBUyxZQUFZLGdCQUFnQixNQUFNLENBQUM7QUFDbkY7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -7,7 +7,7 @@
7
7
  /**
8
8
  * Runs a spellcheck on the entire codebase using `cspell`.
9
9
  *
10
- * The function checks all files in the current directory and its subdirectories for spelling issues.
10
+ * The function checks all files in the current folder and its subfolders for spelling issues.
11
11
  * If issues are found, they are logged to the console with their file path, line, and column number.
12
12
  *
13
13
  * @returns A {@link Promise} that resolves to a {@link CliTaskResult}, indicating the success or failure of the spellcheck.
@@ -12,4 +12,4 @@ async function spellcheck() {
12
12
  export {
13
13
  spellcheck
14
14
  };
15
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL3NwZWxsY2hlY2sudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uXG4gKlxuICogVGhpcyBtb2R1bGUgcHJvdmlkZXMgYSBmdW5jdGlvbiBmb3IgcnVubmluZyBhIHNwZWxsY2hlY2sgb24gdGhlIGNvZGViYXNlIHVzaW5nIHRoZSBgY3NwZWxsYCBsaWJyYXJ5LlxuICogSXQgcmVwb3J0cyBhbnkgc3BlbGxpbmcgaXNzdWVzIGZvdW5kIGluIHRoZSBjb2RlIGFuZCByZXR1cm5zIGEge0BsaW5rIENsaVRhc2tSZXN1bHR9IGluZGljYXRpbmcgd2hldGhlciB0aGUgc3BlbGxjaGVjayB3YXMgc3VjY2Vzc2Z1bC5cbiAqL1xuXG5pbXBvcnQgeyBleGVjRnJvbVJvb3QgfSBmcm9tICcuL1Jvb3QudHMnO1xuXG4vKipcbiAqIFJ1bnMgYSBzcGVsbGNoZWNrIG9uIHRoZSBlbnRpcmUgY29kZWJhc2UgdXNpbmcgYGNzcGVsbGAuXG4gKlxuICogVGhlIGZ1bmN0aW9uIGNoZWNrcyBhbGwgZmlsZXMgaW4gdGhlIGN1cnJlbnQgZGlyZWN0b3J5IGFuZCBpdHMgc3ViZGlyZWN0b3JpZXMgZm9yIHNwZWxsaW5nIGlzc3Vlcy5cbiAqIElmIGlzc3VlcyBhcmUgZm91bmQsIHRoZXkgYXJlIGxvZ2dlZCB0byB0aGUgY29uc29sZSB3aXRoIHRoZWlyIGZpbGUgcGF0aCwgbGluZSwgYW5kIGNvbHVtbiBudW1iZXIuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB0byBhIHtAbGluayBDbGlUYXNrUmVzdWx0fSwgaW5kaWNhdGluZyB0aGUgc3VjY2VzcyBvciBmYWlsdXJlIG9mIHRoZSBzcGVsbGNoZWNrLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc3BlbGxjaGVjaygpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgZXhlY0Zyb21Sb290KCducHggY3NwZWxsIC4gLS1uby1wcm9ncmVzcycpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7OztBQU9BLFNBQVMsb0JBQW9CO0FBVTdCLGVBQXNCLGFBQTRCO0FBQ2hELFFBQU0sYUFBYSw0QkFBNEI7QUFDakQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
15
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL3NwZWxsY2hlY2sudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uXG4gKlxuICogVGhpcyBtb2R1bGUgcHJvdmlkZXMgYSBmdW5jdGlvbiBmb3IgcnVubmluZyBhIHNwZWxsY2hlY2sgb24gdGhlIGNvZGViYXNlIHVzaW5nIHRoZSBgY3NwZWxsYCBsaWJyYXJ5LlxuICogSXQgcmVwb3J0cyBhbnkgc3BlbGxpbmcgaXNzdWVzIGZvdW5kIGluIHRoZSBjb2RlIGFuZCByZXR1cm5zIGEge0BsaW5rIENsaVRhc2tSZXN1bHR9IGluZGljYXRpbmcgd2hldGhlciB0aGUgc3BlbGxjaGVjayB3YXMgc3VjY2Vzc2Z1bC5cbiAqL1xuXG5pbXBvcnQgeyBleGVjRnJvbVJvb3QgfSBmcm9tICcuL1Jvb3QudHMnO1xuXG4vKipcbiAqIFJ1bnMgYSBzcGVsbGNoZWNrIG9uIHRoZSBlbnRpcmUgY29kZWJhc2UgdXNpbmcgYGNzcGVsbGAuXG4gKlxuICogVGhlIGZ1bmN0aW9uIGNoZWNrcyBhbGwgZmlsZXMgaW4gdGhlIGN1cnJlbnQgZm9sZGVyIGFuZCBpdHMgc3ViZm9sZGVycyBmb3Igc3BlbGxpbmcgaXNzdWVzLlxuICogSWYgaXNzdWVzIGFyZSBmb3VuZCwgdGhleSBhcmUgbG9nZ2VkIHRvIHRoZSBjb25zb2xlIHdpdGggdGhlaXIgZmlsZSBwYXRoLCBsaW5lLCBhbmQgY29sdW1uIG51bWJlci5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHRvIGEge0BsaW5rIENsaVRhc2tSZXN1bHR9LCBpbmRpY2F0aW5nIHRoZSBzdWNjZXNzIG9yIGZhaWx1cmUgb2YgdGhlIHNwZWxsY2hlY2suXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzcGVsbGNoZWNrKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBleGVjRnJvbVJvb3QoJ25weCBjc3BlbGwgLiAtLW5vLXByb2dyZXNzJyk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBT0EsU0FBUyxvQkFBb0I7QUFVN0IsZUFBc0IsYUFBNEI7QUFDaEQsUUFBTSxhQUFhLDRCQUE0QjtBQUNqRDsiLAogICJuYW1lcyI6IFtdCn0K
@@ -83,7 +83,7 @@ export declare function checkGitInstalled(): Promise<void>;
83
83
  */
84
84
  export declare function checkGitRepoClean(): Promise<void>;
85
85
  /**
86
- * Copies the updated manifest file to the distribution build directory.
86
+ * Copies the updated manifest file to the distribution build folder.
87
87
  *
88
88
  * @returns A {@link Promise} that resolves when the copy operation is complete.
89
89
  */