obsidian-dev-utils 51.0.1 → 51.1.7

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 (216) hide show
  1. package/CHANGELOG.md +34 -0
  2. package/dist/lib/cjs/async.cjs +2 -2
  3. package/dist/lib/cjs/blob.cjs +2 -2
  4. package/dist/lib/cjs/debug.cjs +7 -8
  5. package/dist/lib/cjs/library.cjs +1 -1
  6. package/dist/lib/cjs/object-utils.cjs +23 -23
  7. package/dist/lib/cjs/obsidian/app.cjs +4 -3
  8. package/dist/lib/cjs/obsidian/components/setting-components/multiple-file-component.cjs +3 -2
  9. package/dist/lib/cjs/obsidian/components/setting-components/typed-text-component.cjs +1 -1
  10. package/dist/lib/cjs/obsidian/components/setting-components/validator-component.cjs +2 -2
  11. package/dist/lib/cjs/obsidian/constructors/getDomEventsHandlersConstructor.cjs +1 -1
  12. package/dist/lib/cjs/obsidian/constructors/getDomEventsHandlersConstructor.d.cts +3 -1
  13. package/dist/lib/cjs/obsidian/dataview-link.cjs +1 -1
  14. package/dist/lib/cjs/obsidian/dataview-link.d.cts +1 -1
  15. package/dist/lib/cjs/obsidian/file-change.cjs +1 -1
  16. package/dist/lib/cjs/obsidian/file-system.cjs +2 -2
  17. package/dist/lib/cjs/obsidian/i18n/custom-type-options-base.cjs +1 -1
  18. package/dist/lib/cjs/obsidian/i18n/custom-type-options-base.d.cts +12 -6
  19. package/dist/lib/cjs/obsidian/index.cjs +4 -1
  20. package/dist/lib/cjs/obsidian/index.d.cts +1 -0
  21. package/dist/lib/cjs/obsidian/is-in-obsidian.cjs +143 -0
  22. package/dist/lib/cjs/obsidian/is-in-obsidian.d.cts +11 -0
  23. package/dist/lib/cjs/obsidian/link.cjs +37 -37
  24. package/dist/lib/cjs/obsidian/markdown.cjs +1 -1
  25. package/dist/lib/cjs/obsidian/plugin/obsidian-plugin-repo-paths.cjs +2 -2
  26. package/dist/lib/cjs/obsidian/plugin/obsidian-plugin-repo-paths.d.cts +1 -1
  27. package/dist/lib/cjs/obsidian/plugin/path-settings.cjs +4 -5
  28. package/dist/lib/cjs/obsidian/plugin/plugin-settings-manager-base.cjs +2 -2
  29. package/dist/lib/cjs/obsidian/rename-delete-handler.cjs +2 -2
  30. package/dist/lib/cjs/obsidian/resource-url.cjs +3 -2
  31. package/dist/lib/cjs/obsidian/vault.cjs +2 -2
  32. package/dist/lib/cjs/reg-exp.cjs +5 -6
  33. package/dist/lib/cjs/script-utils/build.cjs +5 -5
  34. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/changeExtensionPlugin.cjs +3 -3
  35. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.cjs +12 -11
  36. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/dependency.cjs +4 -4
  37. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/fixSourceMapsPlugin.cjs +6 -5
  38. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.cjs +15 -12
  39. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/preprocessPlugin.cjs +3 -3
  40. package/dist/lib/cjs/script-utils/bundlers/esbuild-impl/renameCssPlugin.cjs +5 -4
  41. package/dist/lib/cjs/script-utils/bundlers/esbuild.cjs +1 -1
  42. package/dist/lib/cjs/script-utils/cli-utils.cjs +14 -4
  43. package/dist/lib/cjs/script-utils/code-generator.cjs +3 -3
  44. package/dist/lib/cjs/script-utils/commitlint-config.cjs +134 -0
  45. package/dist/lib/cjs/script-utils/commitlint-config.d.cts +10 -0
  46. package/dist/lib/cjs/script-utils/exec.cjs +99 -10
  47. package/dist/lib/cjs/script-utils/exec.d.cts +35 -6
  48. package/dist/lib/cjs/script-utils/formatters/dprint.cjs +8 -6
  49. package/dist/lib/cjs/script-utils/formatters/dprint.d.cts +15 -2
  50. package/dist/lib/cjs/script-utils/fs.cjs +8 -11
  51. package/dist/lib/cjs/script-utils/fs.d.cts +1 -1
  52. package/dist/lib/cjs/script-utils/index.cjs +7 -4
  53. package/dist/lib/cjs/script-utils/index.d.cts +2 -1
  54. package/dist/lib/cjs/script-utils/json.cjs +9 -8
  55. package/dist/lib/cjs/script-utils/linters/cspell.cjs +5 -3
  56. package/dist/lib/cjs/script-utils/linters/cspell.d.cts +14 -1
  57. package/dist/lib/cjs/script-utils/linters/eslint-config.cjs +32 -20
  58. package/dist/lib/cjs/script-utils/linters/eslint-rules/index.cjs +142 -0
  59. package/dist/lib/cjs/script-utils/linters/eslint-rules/index.d.cts +1 -0
  60. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.cjs +174 -0
  61. package/dist/lib/cjs/script-utils/linters/eslint-rules/no-used-underscore-params.d.cts +12 -0
  62. package/dist/lib/cjs/script-utils/linters/eslint-types/@types/@eslint-community__eslint-plugin-eslint-comments__configs.d.cts +4 -2
  63. package/dist/lib/cjs/script-utils/linters/eslint.cjs +9 -6
  64. package/dist/lib/cjs/script-utils/linters/eslint.d.cts +15 -2
  65. package/dist/lib/cjs/script-utils/linters/index.cjs +4 -1
  66. package/dist/lib/cjs/script-utils/linters/index.d.cts +1 -0
  67. package/dist/lib/cjs/script-utils/linters/markdownlint.cjs +13 -10
  68. package/dist/lib/cjs/script-utils/linters/markdownlint.d.cts +15 -2
  69. package/dist/lib/cjs/script-utils/nano-staged-config.cjs +143 -0
  70. package/dist/lib/cjs/script-utils/nano-staged-config.d.cts +14 -0
  71. package/dist/lib/cjs/script-utils/npm-publish.cjs +16 -5
  72. package/dist/lib/cjs/script-utils/obsidian-dev-utils-repo-paths.cjs +2 -1
  73. package/dist/lib/cjs/script-utils/obsidian-dev-utils-repo-paths.d.cts +2 -0
  74. package/dist/lib/cjs/script-utils/root.cjs +3 -3
  75. package/dist/lib/cjs/script-utils/root.d.cts +3 -7
  76. package/dist/lib/cjs/script-utils/test-runners/vitest.cjs +6 -3
  77. package/dist/lib/cjs/script-utils/test-runners/vitest.d.cts +12 -1
  78. package/dist/lib/cjs/script-utils/version.cjs +22 -31
  79. package/dist/lib/cjs/string.cjs +4 -13
  80. package/dist/lib/cjs/string.d.cts +2 -2
  81. package/dist/lib/cjs/type-guards.cjs +8 -1
  82. package/dist/lib/cjs/type-guards.d.cts +11 -1
  83. package/dist/lib/esm/async.mjs +6 -3
  84. package/dist/lib/esm/blob.mjs +2 -2
  85. package/dist/lib/esm/debug.mjs +5 -6
  86. package/dist/lib/esm/library.mjs +1 -1
  87. package/dist/lib/esm/object-utils.mjs +24 -23
  88. package/dist/lib/esm/obsidian/app.mjs +4 -3
  89. package/dist/lib/esm/obsidian/components/setting-components/multiple-file-component.mjs +3 -2
  90. package/dist/lib/esm/obsidian/components/setting-components/typed-text-component.mjs +1 -1
  91. package/dist/lib/esm/obsidian/components/setting-components/validator-component.mjs +2 -2
  92. package/dist/lib/esm/obsidian/constructors/getDomEventsHandlersConstructor.d.mts +3 -1
  93. package/dist/lib/esm/obsidian/constructors/getDomEventsHandlersConstructor.mjs +1 -1
  94. package/dist/lib/esm/obsidian/dataview-link.d.mts +1 -1
  95. package/dist/lib/esm/obsidian/dataview-link.mjs +1 -1
  96. package/dist/lib/esm/obsidian/file-change.mjs +1 -1
  97. package/dist/lib/esm/obsidian/file-system.mjs +3 -2
  98. package/dist/lib/esm/obsidian/i18n/custom-type-options-base.d.mts +12 -6
  99. package/dist/lib/esm/obsidian/i18n/custom-type-options-base.mjs +1 -1
  100. package/dist/lib/esm/obsidian/index.d.mts +1 -0
  101. package/dist/lib/esm/obsidian/index.mjs +3 -1
  102. package/dist/lib/esm/obsidian/is-in-obsidian.d.mts +11 -0
  103. package/dist/lib/esm/obsidian/is-in-obsidian.mjs +39 -0
  104. package/dist/lib/esm/obsidian/link.mjs +38 -41
  105. package/dist/lib/esm/obsidian/markdown.mjs +1 -1
  106. package/dist/lib/esm/obsidian/plugin/obsidian-plugin-repo-paths.d.mts +1 -1
  107. package/dist/lib/esm/obsidian/plugin/obsidian-plugin-repo-paths.mjs +2 -2
  108. package/dist/lib/esm/obsidian/plugin/path-settings.mjs +4 -5
  109. package/dist/lib/esm/obsidian/plugin/plugin-settings-manager-base.mjs +3 -2
  110. package/dist/lib/esm/obsidian/rename-delete-handler.mjs +6 -3
  111. package/dist/lib/esm/obsidian/resource-url.mjs +3 -2
  112. package/dist/lib/esm/obsidian/vault.mjs +3 -2
  113. package/dist/lib/esm/reg-exp.mjs +5 -6
  114. package/dist/lib/esm/script-utils/build.mjs +6 -6
  115. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/changeExtensionPlugin.mjs +2 -2
  116. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.mjs +8 -8
  117. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/dependency.mjs +5 -5
  118. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/fixSourceMapsPlugin.mjs +5 -5
  119. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.mjs +10 -11
  120. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/preprocessPlugin.mjs +2 -2
  121. package/dist/lib/esm/script-utils/bundlers/esbuild-impl/renameCssPlugin.mjs +3 -5
  122. package/dist/lib/esm/script-utils/bundlers/esbuild.mjs +1 -1
  123. package/dist/lib/esm/script-utils/cli-utils.mjs +2 -2
  124. package/dist/lib/esm/script-utils/code-generator.mjs +2 -2
  125. package/dist/lib/esm/script-utils/commitlint-config.d.mts +10 -0
  126. package/dist/lib/esm/script-utils/commitlint-config.mjs +28 -0
  127. package/dist/lib/esm/script-utils/exec.d.mts +35 -6
  128. package/dist/lib/esm/script-utils/exec.mjs +84 -8
  129. package/dist/lib/esm/script-utils/formatters/dprint.d.mts +15 -2
  130. package/dist/lib/esm/script-utils/formatters/dprint.mjs +6 -4
  131. package/dist/lib/esm/script-utils/fs.d.mts +1 -1
  132. package/dist/lib/esm/script-utils/fs.mjs +5 -8
  133. package/dist/lib/esm/script-utils/index.d.mts +2 -1
  134. package/dist/lib/esm/script-utils/index.mjs +5 -3
  135. package/dist/lib/esm/script-utils/json.mjs +7 -5
  136. package/dist/lib/esm/script-utils/linters/cspell.d.mts +14 -1
  137. package/dist/lib/esm/script-utils/linters/cspell.mjs +5 -3
  138. package/dist/lib/esm/script-utils/linters/eslint-config.mjs +32 -20
  139. package/dist/lib/esm/script-utils/linters/eslint-rules/index.d.mts +1 -0
  140. package/dist/lib/esm/script-utils/linters/eslint-rules/index.mjs +26 -0
  141. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.d.mts +12 -0
  142. package/dist/lib/esm/script-utils/linters/eslint-rules/no-used-underscore-params.mjs +68 -0
  143. package/dist/lib/esm/script-utils/linters/eslint-types/@types/@eslint-community__eslint-plugin-eslint-comments__configs.d.mts +4 -2
  144. package/dist/lib/esm/script-utils/linters/eslint.d.mts +15 -2
  145. package/dist/lib/esm/script-utils/linters/eslint.mjs +7 -7
  146. package/dist/lib/esm/script-utils/linters/index.d.mts +1 -0
  147. package/dist/lib/esm/script-utils/linters/index.mjs +3 -1
  148. package/dist/lib/esm/script-utils/linters/markdownlint.d.mts +15 -2
  149. package/dist/lib/esm/script-utils/linters/markdownlint.mjs +13 -11
  150. package/dist/lib/esm/script-utils/nano-staged-config.d.mts +14 -0
  151. package/dist/lib/esm/script-utils/nano-staged-config.mjs +37 -0
  152. package/dist/lib/esm/script-utils/npm-publish.mjs +3 -6
  153. package/dist/lib/esm/script-utils/obsidian-dev-utils-repo-paths.d.mts +2 -0
  154. package/dist/lib/esm/script-utils/obsidian-dev-utils-repo-paths.mjs +2 -1
  155. package/dist/lib/esm/script-utils/root.d.mts +3 -7
  156. package/dist/lib/esm/script-utils/root.mjs +2 -2
  157. package/dist/lib/esm/script-utils/test-runners/vitest.d.mts +12 -1
  158. package/dist/lib/esm/script-utils/test-runners/vitest.mjs +6 -3
  159. package/dist/lib/esm/script-utils/version.mjs +16 -27
  160. package/dist/lib/esm/string.d.mts +2 -2
  161. package/dist/lib/esm/string.mjs +7 -13
  162. package/dist/lib/esm/type-guards.d.mts +11 -1
  163. package/dist/lib/esm/type-guards.mjs +7 -1
  164. package/dist/scripts/build/build-clean.ts +4 -0
  165. package/dist/scripts/build/build-compile-svelte.ts +4 -0
  166. package/dist/scripts/build/build-compile-typescript.ts +4 -0
  167. package/dist/scripts/build/build-compile.ts +4 -0
  168. package/dist/scripts/build/build-static.ts +4 -0
  169. package/dist/scripts/bundlers/esbuild/build.ts +4 -0
  170. package/dist/scripts/bundlers/esbuild/dev.ts +4 -0
  171. package/dist/scripts/formatters/dprint/format-check.ts +8 -0
  172. package/dist/scripts/formatters/dprint/format.ts +8 -0
  173. package/dist/scripts/linters/cspell/spellcheck.ts +8 -0
  174. package/dist/scripts/linters/eslint/lint-fix.ts +8 -0
  175. package/dist/scripts/linters/eslint/lint.ts +8 -0
  176. package/dist/scripts/linters/markdownlint/lint-md-fix.ts +8 -0
  177. package/dist/scripts/linters/markdownlint/lint-md.ts +8 -0
  178. package/dist/scripts/test-runners/vitest/test-coverage.ts +4 -0
  179. package/dist/scripts/test-runners/vitest/test-watch.ts +4 -0
  180. package/dist/scripts/test-runners/vitest/test.ts +4 -0
  181. package/dist/scripts/version/version.ts +7 -0
  182. package/obsidian/is-in-obsidian/package.json +6 -0
  183. package/package.json +33 -6
  184. package/script-utils/commitlint-config/package.json +6 -0
  185. package/script-utils/linters/eslint-rules/index/package.json +6 -0
  186. package/script-utils/linters/eslint-rules/no-used-underscore-params/package.json +6 -0
  187. package/script-utils/linters/eslint-rules/package.json +6 -0
  188. package/script-utils/nano-staged-config/package.json +6 -0
  189. package/scripts/postinstall.mjs +29 -0
  190. package/dist/lib/cjs/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required.d.cts +0 -14
  191. package/dist/lib/cjs/script-utils/node-modules.cjs +0 -207
  192. package/dist/lib/cjs/script-utils/node-modules.d.cts +0 -17
  193. package/dist/lib/esm/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required.d.mts +0 -14
  194. package/dist/lib/esm/script-utils/node-modules.d.mts +0 -17
  195. package/dist/lib/esm/script-utils/node-modules.mjs +0 -92
  196. package/dist/scripts/default/build-clean.ts +0 -5
  197. package/dist/scripts/default/build-compile-svelte.ts +0 -5
  198. package/dist/scripts/default/build-compile-typescript.ts +0 -5
  199. package/dist/scripts/default/build-compile.ts +0 -5
  200. package/dist/scripts/default/build-static.ts +0 -5
  201. package/dist/scripts/default/build.ts +0 -9
  202. package/dist/scripts/default/dev.ts +0 -10
  203. package/dist/scripts/default/format-check.ts +0 -5
  204. package/dist/scripts/default/format.ts +0 -5
  205. package/dist/scripts/default/lint-fix.ts +0 -5
  206. package/dist/scripts/default/lint.ts +0 -5
  207. package/dist/scripts/default/publish.ts +0 -5
  208. package/dist/scripts/default/spellcheck.ts +0 -5
  209. package/dist/scripts/default/version.ts +0 -5
  210. package/dist/scripts/examples/build.customPlugin.ts +0 -38
  211. package/dist/scripts/examples/build.svelteConditions.ts +0 -18
  212. package/dist/scripts/examples/eslint.config.extend.mts +0 -14
  213. package/dist/scripts/examples/eslint.config.no-dev-utils.mts +0 -15
  214. package/dist/scripts/examples/format.prettier.ts +0 -25
  215. package/script-utils/linters/eslint-types/@types/@guardian__eslint-plugin-tsdoc-required/package.json +0 -4
  216. package/script-utils/node-modules/package.json +0 -6
@@ -19,6 +19,7 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
+ import { assert } from "./type-guards.mjs";
22
23
  var RegExpMergeFlagsConflictStrategy = /* @__PURE__ */ ((RegExpMergeFlagsConflictStrategy2) => {
23
24
  RegExpMergeFlagsConflictStrategy2["Intersect"] = "Intersect";
24
25
  RegExpMergeFlagsConflictStrategy2["Throw"] = "Throw";
@@ -50,7 +51,7 @@ function shouldPickFlag(regExps, flag, strategy) {
50
51
  case "Union" /* Union */:
51
52
  return count > 0;
52
53
  default:
53
- throw new Error(`Invalid strategy: ${strategy}`);
54
+ assert(false, `Invalid strategy: ${strategy}`);
54
55
  }
55
56
  const allSame = count === 0 || count === regExps.length;
56
57
  if (!allSame) {
@@ -118,12 +119,10 @@ function addUnicodeFlags(finalFlags, regExps, strategy) {
118
119
  shouldUseVFlag = countV > 0;
119
120
  break;
120
121
  default:
121
- throw new Error(`Invalid strategy: ${strategy}`);
122
+ assert(false, `Invalid strategy: ${strategy}`);
122
123
  }
123
124
  if (shouldUseUFlag && shouldUseVFlag) {
124
- if (strategy === "Throw" /* Throw */) {
125
- throw new Error("Cannot combine both 'u'/'v' flags in one RegExp.");
126
- }
125
+ assert(strategy !== "Throw" /* Throw */, "Cannot combine both 'u'/'v' flags in one RegExp.");
127
126
  shouldUseUFlag = false;
128
127
  }
129
128
  if (shouldUseUFlag) {
@@ -141,4 +140,4 @@ export {
141
140
  isValidRegExp,
142
141
  oneOf
143
142
  };
144
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/reg-exp.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for regular expressions.\n */\n\n/**\n * A strategy to use when merging multiple regex flags into one alternation.\n */\nexport enum RegExpMergeFlagsConflictStrategy {\n  /**\n   * Keep only the flags present in all regexes.\n   */\n  Intersect = 'Intersect',\n  /**\n   * Throw an error if the regexes have conflicting flags.\n   */\n  Throw = 'Throw',\n  /**\n   * Keep only the flags present in any regex.\n   */\n  Union = 'Union'\n}\n\n/**\n * Escapes special characters in a string to safely use it within a regular expression.\n *\n * @param str - The string to escape.\n * @returns The escaped string with special characters prefixed with a backslash.\n */\nexport function escapeRegExp(str: string): string {\n  // NOTE: We can't use `replaceAll()` from `String.ts` here because it introduces a circular dependency.\n  return str.replaceAll(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\n\n/**\n * Checks if a string is a valid regular expression.\n *\n * @param str - The string to check.\n * @returns `true` if the string is a valid regular expression, `false` otherwise.\n */\nexport function isValidRegExp(str: string): boolean {\n  try {\n    new RegExp(str);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\nfunction hasFlag(regExp: RegExp, flag: string): boolean {\n  return regExp.flags.includes(flag);\n}\n\nfunction shouldPickFlag(regExps: RegExp[], flag: string, strategy: RegExpMergeFlagsConflictStrategy): boolean {\n  const count = regExps.filter((regExp) => hasFlag(regExp, flag)).length;\n  /* v8 ignore start -- All branches covered but v8 reports switch as partial. */\n  switch (strategy) {\n    /* v8 ignore stop */\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      return count === regExps.length;\n    case RegExpMergeFlagsConflictStrategy.Throw:\n      break;\n    case RegExpMergeFlagsConflictStrategy.Union:\n      return count > 0;\n    default:\n      /* v8 ignore start -- All enum values are handled above. */\n      throw new Error(`Invalid strategy: ${strategy as string}`);\n      /* v8 ignore stop */\n  }\n\n  const allSame = count === 0 || count === regExps.length;\n  if (!allSame) {\n    throw new Error(`Conflicting flag '${flag}' across patterns.`);\n  }\n  return count === regExps.length;\n}\n\n/**\n * A regular expression that always matches.\n */\nexport const ALWAYS_MATCH_REG_EXP = /(?:)/;\n\n/**\n * A regular expression that never matches.\n */\nexport const NEVER_MATCH_REG_EXP = /.^/;\n\n/**\n * Combine multiple regexes into one alternation, handling flags.\n *\n * @param regExps - The regexes to combine.\n * @param strategy - The strategy to use when merging flags (default: `RegExpMergeFlagsConflictStrategy.Throw`).\n * @returns The combined regex.\n */\nexport function oneOf(\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy = RegExpMergeFlagsConflictStrategy.Throw\n): RegExp {\n  if (regExps.length === 0) {\n    return ALWAYS_MATCH_REG_EXP;\n  }\n\n  if (regExps.length === 1 && regExps[0] !== undefined) {\n    return regExps[0];\n  }\n\n  const source = regExps.map((regExp) => `(?:${regExp.source})`).join('|');\n\n  const finalFlags = new Set<string>();\n  addSemanticFlags(finalFlags, regExps, strategy);\n  addUnicodeFlags(finalFlags, regExps, strategy);\n  addMetaFlags(finalFlags, regExps);\n\n  return new RegExp(source, [...finalFlags].join(''));\n}\n\nfunction addMetaFlags(finalFlags: Set<string>, regExps: RegExp[]): void {\n  const META_FLAGS = ['g', 'd'];\n  for (const flag of META_FLAGS) {\n    if (regExps.some((regExp) => hasFlag(regExp, flag))) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addSemanticFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const SEMANTIC_FLAGS = ['i', 'm', 's', 'y'];\n  for (const flag of SEMANTIC_FLAGS) {\n    if (shouldPickFlag(regExps, flag, strategy)) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addUnicodeFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const countU = regExps.filter((regExp) => hasFlag(regExp, 'u')).length;\n  const countV = regExps.filter((regExp) => hasFlag(regExp, 'v')).length;\n\n  let shouldUseUFlag: boolean;\n  let shouldUseVFlag: boolean;\n\n  /* v8 ignore start -- All branches covered but v8 reports switch as partial. */\n  switch (strategy) {\n    /* v8 ignore stop */\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      shouldUseUFlag = countU === regExps.length;\n      shouldUseVFlag = countV === regExps.length;\n      break;\n    case RegExpMergeFlagsConflictStrategy.Throw: {\n      const allU = countU === regExps.length;\n      const noneU = countU === 0;\n      const allV = countV === regExps.length;\n      const noneV = countV === 0;\n\n      if (!(allU || noneU) || !(allV || noneV)) {\n        throw new Error('Conflicting \\'u\\'/\\'v\\' flags across patterns.');\n      }\n\n      shouldUseUFlag = allU;\n      shouldUseVFlag = allV;\n      break;\n    }\n    case RegExpMergeFlagsConflictStrategy.Union:\n      shouldUseUFlag = countU > 0;\n      shouldUseVFlag = countV > 0;\n      break;\n    default:\n      /* v8 ignore start -- All enum values are handled above. */\n      throw new Error(`Invalid strategy: ${strategy as string}`);\n      /* v8 ignore stop */\n  }\n\n  if (shouldUseUFlag && shouldUseVFlag) {\n    /* v8 ignore start -- Throw strategy cannot reach here; earlier checks would have thrown. */\n    if (strategy === RegExpMergeFlagsConflictStrategy.Throw) {\n      throw new Error('Cannot combine both \\'u\\'/\\'v\\' flags in one RegExp.');\n    }\n    /* v8 ignore stop */\n    shouldUseUFlag = false;\n  }\n\n  if (shouldUseUFlag) {\n    finalFlags.add('u');\n  }\n  if (shouldUseVFlag) {\n    finalFlags.add('v');\n  }\n}\n"],
  "mappings": "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",
  "names": ["RegExpMergeFlagsConflictStrategy"]
}

143
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/reg-exp.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for regular expressions.\n */\n\nimport { assert } from './type-guards.ts';\n\n/**\n * A strategy to use when merging multiple regex flags into one alternation.\n */\nexport enum RegExpMergeFlagsConflictStrategy {\n  /**\n   * Keep only the flags present in all regexes.\n   */\n  Intersect = 'Intersect',\n  /**\n   * Throw an error if the regexes have conflicting flags.\n   */\n  Throw = 'Throw',\n  /**\n   * Keep only the flags present in any regex.\n   */\n  Union = 'Union'\n}\n\n/**\n * Escapes special characters in a string to safely use it within a regular expression.\n *\n * @param str - The string to escape.\n * @returns The escaped string with special characters prefixed with a backslash.\n */\nexport function escapeRegExp(str: string): string {\n  // NOTE: We can't use `replaceAll()` from `String.ts` here because it introduces a circular dependency.\n  return str.replaceAll(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\n\n/**\n * Checks if a string is a valid regular expression.\n *\n * @param str - The string to check.\n * @returns `true` if the string is a valid regular expression, `false` otherwise.\n */\nexport function isValidRegExp(str: string): boolean {\n  try {\n    new RegExp(str);\n    return true;\n  } catch {\n    return false;\n  }\n}\n\nfunction hasFlag(regExp: RegExp, flag: string): boolean {\n  return regExp.flags.includes(flag);\n}\n\nfunction shouldPickFlag(regExps: RegExp[], flag: string, strategy: RegExpMergeFlagsConflictStrategy): boolean {\n  const count = regExps.filter((regExp) => hasFlag(regExp, flag)).length;\n  /* v8 ignore start -- v8 counts the implicit default branch as uncovered even when all enum cases are handled. */\n  switch (strategy) {\n    /* v8 ignore stop */\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      return count === regExps.length;\n    case RegExpMergeFlagsConflictStrategy.Throw:\n      break;\n    case RegExpMergeFlagsConflictStrategy.Union:\n      return count > 0;\n    default:\n      /* v8 ignore start -- Exhaustive switch guard. */\n      assert(false, `Invalid strategy: ${strategy as string}`);\n      /* v8 ignore stop */\n  }\n\n  const allSame = count === 0 || count === regExps.length;\n  if (!allSame) {\n    throw new Error(`Conflicting flag '${flag}' across patterns.`);\n  }\n  return count === regExps.length;\n}\n\n/**\n * A regular expression that always matches.\n */\nexport const ALWAYS_MATCH_REG_EXP = /(?:)/;\n\n/**\n * A regular expression that never matches.\n */\nexport const NEVER_MATCH_REG_EXP = /.^/;\n\n/**\n * Combine multiple regexes into one alternation, handling flags.\n *\n * @param regExps - The regexes to combine.\n * @param strategy - The strategy to use when merging flags (default: `RegExpMergeFlagsConflictStrategy.Throw`).\n * @returns The combined regex.\n */\nexport function oneOf(\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy = RegExpMergeFlagsConflictStrategy.Throw\n): RegExp {\n  if (regExps.length === 0) {\n    return ALWAYS_MATCH_REG_EXP;\n  }\n\n  if (regExps.length === 1 && regExps[0] !== undefined) {\n    return regExps[0];\n  }\n\n  const source = regExps.map((regExp) => `(?:${regExp.source})`).join('|');\n\n  const finalFlags = new Set<string>();\n  addSemanticFlags(finalFlags, regExps, strategy);\n  addUnicodeFlags(finalFlags, regExps, strategy);\n  addMetaFlags(finalFlags, regExps);\n\n  return new RegExp(source, [...finalFlags].join(''));\n}\n\nfunction addMetaFlags(finalFlags: Set<string>, regExps: RegExp[]): void {\n  const META_FLAGS = ['g', 'd'];\n  for (const flag of META_FLAGS) {\n    if (regExps.some((regExp) => hasFlag(regExp, flag))) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addSemanticFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const SEMANTIC_FLAGS = ['i', 'm', 's', 'y'];\n  for (const flag of SEMANTIC_FLAGS) {\n    if (shouldPickFlag(regExps, flag, strategy)) {\n      finalFlags.add(flag);\n    }\n  }\n}\n\nfunction addUnicodeFlags(\n  finalFlags: Set<string>,\n  regExps: RegExp[],\n  strategy: RegExpMergeFlagsConflictStrategy\n): void {\n  const countU = regExps.filter((regExp) => hasFlag(regExp, 'u')).length;\n  const countV = regExps.filter((regExp) => hasFlag(regExp, 'v')).length;\n\n  let shouldUseUFlag: boolean;\n  let shouldUseVFlag: boolean;\n\n  /* v8 ignore start -- v8 counts the implicit default branch as uncovered even when all enum cases are handled. */\n  switch (strategy) {\n    /* v8 ignore stop */\n    case RegExpMergeFlagsConflictStrategy.Intersect:\n      shouldUseUFlag = countU === regExps.length;\n      shouldUseVFlag = countV === regExps.length;\n      break;\n    case RegExpMergeFlagsConflictStrategy.Throw: {\n      const allU = countU === regExps.length;\n      const noneU = countU === 0;\n      const allV = countV === regExps.length;\n      const noneV = countV === 0;\n\n      if (!(allU || noneU) || !(allV || noneV)) {\n        throw new Error('Conflicting \\'u\\'/\\'v\\' flags across patterns.');\n      }\n\n      shouldUseUFlag = allU;\n      shouldUseVFlag = allV;\n      break;\n    }\n    case RegExpMergeFlagsConflictStrategy.Union:\n      shouldUseUFlag = countU > 0;\n      shouldUseVFlag = countV > 0;\n      break;\n    default:\n      /* v8 ignore start -- Exhaustive switch guard. */\n      assert(false, `Invalid strategy: ${strategy as string}`);\n      /* v8 ignore stop */\n  }\n\n  if (shouldUseUFlag && shouldUseVFlag) {\n    assert(strategy !== RegExpMergeFlagsConflictStrategy.Throw, 'Cannot combine both \\'u\\'/\\'v\\' flags in one RegExp.');\n    shouldUseUFlag = false;\n  }\n\n  if (shouldUseUFlag) {\n    finalFlags.add('u');\n  }\n  if (shouldUseVFlag) {\n    finalFlags.add('v');\n  }\n}\n"],
  "mappings": "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",
  "names": ["RegExpMergeFlagsConflictStrategy"]
}

@@ -19,17 +19,17 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
+ import {
23
+ cp,
24
+ glob,
25
+ rm
26
+ } from "node:fs/promises";
22
27
  import { toArray } from "../async.mjs";
23
28
  import { getLibDebugger } from "../debug.mjs";
24
29
  import { join } from "../path.mjs";
25
30
  import { trimStart } from "../string.mjs";
26
31
  import { readdirPosix } from "./fs.mjs";
27
32
  import { readJson } from "./json.mjs";
28
- import {
29
- cp,
30
- glob,
31
- rm
32
- } from "./node-modules.mjs";
33
33
  import { npmRun } from "./npm-run.mjs";
34
34
  import { ObsidianDevUtilsRepoPaths } from "./obsidian-dev-utils-repo-paths.mjs";
35
35
  import {
@@ -73,4 +73,4 @@ export {
73
73
  buildCompileTypeScript,
74
74
  buildStatic
75
75
  };
76
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idWlsZC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBUaGlzIG1vZHVsZSBwcm92aWRlcyB1dGlsaXR5IGZ1bmN0aW9ucyB0byBoYW5kbGUgdGhlIGJ1aWxkIHByb2Nlc3MgZm9yIHN0YXRpYyBhc3NldHMgYW5kIGNsZWFuaW5nXG4gKiB0aGUgYnVpbGQgb3V0cHV0IGZvbGRlci4gSXQgaW5jbHVkZXMgZnVuY3Rpb25zIHRvIGNvcHkgc3RhdGljIGZpbGVzIHRvIHRoZSBkaXN0cmlidXRpb24gZm9sZGVyXG4gKiBhbmQgdG8gcmVtb3ZlIHRoZSBleGlzdGluZyBidWlsZCBvdXRwdXQuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBUc0NvbmZpZ0pzb24gfSBmcm9tICd0eXBlLWZlc3QnO1xuXG5pbXBvcnQgeyB0b0FycmF5IH0gZnJvbSAnLi4vYXN5bmMudHMnO1xuaW1wb3J0IHsgZ2V0TGliRGVidWdnZXIgfSBmcm9tICcuLi9kZWJ1Zy50cyc7XG5pbXBvcnQgeyBqb2luIH0gZnJvbSAnLi4vcGF0aC50cyc7XG5pbXBvcnQgeyB0cmltU3RhcnQgfSBmcm9tICcuLi9zdHJpbmcudHMnO1xuaW1wb3J0IHsgcmVhZGRpclBvc2l4IH0gZnJvbSAnLi9mcy50cyc7XG5pbXBvcnQgeyByZWFkSnNvbiB9IGZyb20gJy4vanNvbi50cyc7XG5pbXBvcnQge1xuICBjcCxcbiAgZ2xvYixcbiAgcm1cbn0gZnJvbSAnLi9ub2RlLW1vZHVsZXMudHMnO1xuaW1wb3J0IHsgbnBtUnVuIH0gZnJvbSAnLi9ucG0tcnVuLnRzJztcbmltcG9ydCB7IE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMgfSBmcm9tICcuL29ic2lkaWFuLWRldi11dGlscy1yZXBvLXBhdGhzLnRzJztcbmltcG9ydCB7XG4gIGV4ZWNGcm9tUm9vdCxcbiAgcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmVcbn0gZnJvbSAnLi9yb290LnRzJztcblxuLyoqXG4gKiBSZW1vdmVzIHRoZSBkaXN0cmlidXRpb24gZm9sZGVyIGFuZCBpdHMgY29udGVudHMuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBkZWxldGVzIHRoZSBlbnRpcmUgZGlzdHJpYnV0aW9uIGZvbGRlciB0byBlbnN1cmUgYSBjbGVhbiBidWlsZCBlbnZpcm9ubWVudC5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGZvbGRlciBoYXMgYmVlbiByZW1vdmVkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDbGVhbigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgcm0oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCB7IGZvcmNlOiB0cnVlLCByZWN1cnNpdmU6IHRydWUgfSk7XG59XG5cbi8qKlxuICogQ29tcGlsZXMgdGhlIGNvZGUuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZSgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgbnBtUnVuKCdidWlsZDpjb21waWxlOnN2ZWx0ZScpO1xuICBhd2FpdCBucG1SdW4oJ2J1aWxkOmNvbXBpbGU6dHlwZXNjcmlwdCcpO1xufVxuXG4vKipcbiAqIENvbXBpbGVzIHRoZSBTdmVsdGUgY29kZS5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGNvZGUgY29tcGlsZXMgc3VjY2Vzc2Z1bGx5LlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDb21waWxlU3ZlbHRlKCk6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCB0c0NvbmZpZ1BhdGggPSByZXNvbHZlUGF0aEZyb21Sb290U2FmZShPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlRzQ29uZmlnSnNvbik7XG4gIGNvbnN0IHRzQ29uZmlnID0gYXdhaXQgcmVhZEpzb248VHNDb25maWdKc29uPih0c0NvbmZpZ1BhdGgpO1xuICBjb25zdCBhbGxGaWxlcyA9IGF3YWl0IHRvQXJyYXkoZ2xvYih0c0NvbmZpZy5pbmNsdWRlID8/IFtdLCB7IGV4Y2x1ZGU6IHRzQ29uZmlnLmV4Y2x1ZGUgPz8gW10gfSkpO1xuICBjb25zdCBzdmVsdGVGaWxlcyA9IGFsbEZpbGVzLmZpbHRlcigoZmlsZSkgPT4gZmlsZS5lbmRzV2l0aCgnLnN2ZWx0ZScpIHx8IGZpbGUuZW5kc1dpdGgoJy5zdmVsdGUuanMnKSB8fCBmaWxlLmVuZHNXaXRoKCcuc3ZlbHRlLnRzJykpO1xuXG4gIGlmIChzdmVsdGVGaWxlcy5sZW5ndGggPT09IDApIHtcbiAgICBnZXRMaWJEZWJ1Z2dlcignYnVpbGQ6YnVpbGRDb21waWxlU3ZlbHRlJykoJ05vIFN2ZWx0ZSBmaWxlcyBmb3VuZCBpbiB0aGUgcHJvamVjdCwgc2tpcHBpbmcgU3ZlbHRlIGNvbXBpbGF0aW9uJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnB4JywgJ3N2ZWx0ZS1jaGVjaycsICctLXRzY29uZmlnJywgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5Uc0NvbmZpZ0pzb25dKTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgVHlwZVNjcmlwdCBjb2RlLlxuICpcbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENvbXBpbGVUeXBlU2NyaXB0KCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBleGVjRnJvbVJvb3QoWyducHgnLCAndHNjJywgJy0tYnVpbGQnLCAnLS1mb3JjZSddKTtcbn1cblxuLyoqXG4gKiBDb3BpZXMgYWxsIHN0YXRpYyBmaWxlcyBmcm9tIHRoZSBzdGF0aWMgYXNzZXRzIGZvbGRlciB0byB0aGUgZGlzdHJpYnV0aW9uIGZvbGRlci5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHJlY3Vyc2l2ZWx5IHJlYWRzIHRoZSBjb250ZW50cyBvZiB0aGUgc3RhdGljIGFzc2V0cyBmb2xkZXIgYW5kIGNvcGllc1xuICogZWFjaCBmaWxlIHRvIHRoZSBjb3JyZXNwb25kaW5nIHBhdGggaW4gdGhlIGRpc3RyaWJ1dGlvbiBmb2xkZXIuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIGFsbCBmaWxlcyBoYXZlIGJlZW4gY29waWVkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRTdGF0aWMoKTogUHJvbWlzZTx2b2lkPiB7XG4gIGZvciAoY29uc3QgZGlyZW50IG9mIGF3YWl0IHJlYWRkaXJQb3NpeChPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYywgeyByZWN1cnNpdmU6IHRydWUsIHdpdGhGaWxlVHlwZXM6IHRydWUgfSkpIHtcbiAgICBpZiAoIWRpcmVudC5pc0ZpbGUoKSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgY29uc3QgcGF0aCA9IHRyaW1TdGFydChqb2luKGRpcmVudC5wYXJlbnRQYXRoLCBkaXJlbnQubmFtZSksIGAke09ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuU3RhdGljfS9gKTtcbiAgICBhd2FpdCBjcChqb2luKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuU3RhdGljLCBwYXRoKSwgam9pbihPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRpc3QsIHBhdGgpKTtcbiAgfVxufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBVUEsU0FBUyxlQUFlO0FBQ3hCLFNBQVMsc0JBQXNCO0FBQy9CLFNBQVMsWUFBWTtBQUNyQixTQUFTLGlCQUFpQjtBQUMxQixTQUFTLG9CQUFvQjtBQUM3QixTQUFTLGdCQUFnQjtBQUN6QjtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFDUCxTQUFTLGNBQWM7QUFDdkIsU0FBUyxpQ0FBaUM7QUFDMUM7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFTUCxlQUFzQixhQUE0QjtBQUNoRCxRQUFNLEdBQUcsMEJBQTBCLE1BQU0sRUFBRSxPQUFPLE1BQU0sV0FBVyxLQUFLLENBQUM7QUFDM0U7QUFPQSxlQUFzQixlQUE4QjtBQUNsRCxRQUFNLE9BQU8sc0JBQXNCO0FBQ25DLFFBQU0sT0FBTywwQkFBMEI7QUFDekM7QUFPQSxlQUFzQixxQkFBb0M7QUFDeEQsUUFBTSxlQUFlLHdCQUF3QiwwQkFBMEIsWUFBWTtBQUNuRixRQUFNLFdBQVcsTUFBTSxTQUF1QixZQUFZO0FBQzFELFFBQU0sV0FBVyxNQUFNLFFBQVEsS0FBSyxTQUFTLFdBQVcsQ0FBQyxHQUFHLEVBQUUsU0FBUyxTQUFTLFdBQVcsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUNoRyxRQUFNLGNBQWMsU0FBUyxPQUFPLENBQUMsU0FBUyxLQUFLLFNBQVMsU0FBUyxLQUFLLEtBQUssU0FBUyxZQUFZLEtBQUssS0FBSyxTQUFTLFlBQVksQ0FBQztBQUVwSSxNQUFJLFlBQVksV0FBVyxHQUFHO0FBQzVCLG1CQUFlLDBCQUEwQixFQUFFLG1FQUFtRTtBQUM5RztBQUFBLEVBQ0Y7QUFFQSxRQUFNLGFBQWEsQ0FBQyxPQUFPLGdCQUFnQixjQUFjLDBCQUEwQixZQUFZLENBQUM7QUFDbEc7QUFPQSxlQUFzQix5QkFBd0M7QUFDNUQsUUFBTSxhQUFhLENBQUMsT0FBTyxPQUFPLFdBQVcsU0FBUyxDQUFDO0FBQ3pEO0FBVUEsZUFBc0IsY0FBNkI7QUFDakQsYUFBVyxVQUFVLE1BQU0sYUFBYSwwQkFBMEIsUUFBUSxFQUFFLFdBQVcsTUFBTSxlQUFlLEtBQUssQ0FBQyxHQUFHO0FBQ25ILFFBQUksQ0FBQyxPQUFPLE9BQU8sR0FBRztBQUNwQjtBQUFBLElBQ0Y7QUFFQSxVQUFNLE9BQU8sVUFBVSxLQUFLLE9BQU8sWUFBWSxPQUFPLElBQUksR0FBRyxHQUFHLDBCQUEwQixNQUFNLEdBQUc7QUFDbkcsVUFBTSxHQUFHLEtBQUssMEJBQTBCLFFBQVEsSUFBSSxHQUFHLEtBQUssMEJBQTBCLE1BQU0sSUFBSSxDQUFDO0FBQUEsRUFDbkc7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
76
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idWlsZC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBUaGlzIG1vZHVsZSBwcm92aWRlcyB1dGlsaXR5IGZ1bmN0aW9ucyB0byBoYW5kbGUgdGhlIGJ1aWxkIHByb2Nlc3MgZm9yIHN0YXRpYyBhc3NldHMgYW5kIGNsZWFuaW5nXG4gKiB0aGUgYnVpbGQgb3V0cHV0IGZvbGRlci4gSXQgaW5jbHVkZXMgZnVuY3Rpb25zIHRvIGNvcHkgc3RhdGljIGZpbGVzIHRvIHRoZSBkaXN0cmlidXRpb24gZm9sZGVyXG4gKiBhbmQgdG8gcmVtb3ZlIHRoZSBleGlzdGluZyBidWlsZCBvdXRwdXQuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBUc0NvbmZpZ0pzb24gfSBmcm9tICd0eXBlLWZlc3QnO1xuXG5pbXBvcnQge1xuICBjcCxcbiAgZ2xvYixcbiAgcm1cbn0gZnJvbSAnbm9kZTpmcy9wcm9taXNlcyc7XG5cbmltcG9ydCB7IHRvQXJyYXkgfSBmcm9tICcuLi9hc3luYy50cyc7XG5pbXBvcnQgeyBnZXRMaWJEZWJ1Z2dlciB9IGZyb20gJy4uL2RlYnVnLnRzJztcbmltcG9ydCB7IGpvaW4gfSBmcm9tICcuLi9wYXRoLnRzJztcbmltcG9ydCB7IHRyaW1TdGFydCB9IGZyb20gJy4uL3N0cmluZy50cyc7XG5pbXBvcnQgeyByZWFkZGlyUG9zaXggfSBmcm9tICcuL2ZzLnRzJztcbmltcG9ydCB7IHJlYWRKc29uIH0gZnJvbSAnLi9qc29uLnRzJztcbmltcG9ydCB7IG5wbVJ1biB9IGZyb20gJy4vbnBtLXJ1bi50cyc7XG5pbXBvcnQgeyBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIH0gZnJvbSAnLi9vYnNpZGlhbi1kZXYtdXRpbHMtcmVwby1wYXRocy50cyc7XG5pbXBvcnQge1xuICBleGVjRnJvbVJvb3QsXG4gIHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlXG59IGZyb20gJy4vcm9vdC50cyc7XG5cbi8qKlxuICogUmVtb3ZlcyB0aGUgZGlzdHJpYnV0aW9uIGZvbGRlciBhbmQgaXRzIGNvbnRlbnRzLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gZGVsZXRlcyB0aGUgZW50aXJlIGRpc3RyaWJ1dGlvbiBmb2xkZXIgdG8gZW5zdXJlIGEgY2xlYW4gYnVpbGQgZW52aXJvbm1lbnQuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBmb2xkZXIgaGFzIGJlZW4gcmVtb3ZlZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ2xlYW4oKTogUHJvbWlzZTx2b2lkPiB7XG4gIGF3YWl0IHJtKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRGlzdCwgeyBmb3JjZTogdHJ1ZSwgcmVjdXJzaXZlOiB0cnVlIH0pO1xufVxuXG4vKipcbiAqIENvbXBpbGVzIHRoZSBjb2RlLlxuICpcbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENvbXBpbGUoKTogUHJvbWlzZTx2b2lkPiB7XG4gIGF3YWl0IG5wbVJ1bignYnVpbGQ6Y29tcGlsZTpzdmVsdGUnKTtcbiAgYXdhaXQgbnBtUnVuKCdidWlsZDpjb21waWxlOnR5cGVzY3JpcHQnKTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgU3ZlbHRlIGNvZGUuXG4gKlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZVN2ZWx0ZSgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgdHNDb25maWdQYXRoID0gcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmUoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5Uc0NvbmZpZ0pzb24pO1xuICBjb25zdCB0c0NvbmZpZyA9IGF3YWl0IHJlYWRKc29uPFRzQ29uZmlnSnNvbj4odHNDb25maWdQYXRoKTtcbiAgY29uc3QgYWxsRmlsZXMgPSBhd2FpdCB0b0FycmF5KGdsb2IodHNDb25maWcuaW5jbHVkZSA/PyBbXSwgeyBleGNsdWRlOiB0c0NvbmZpZy5leGNsdWRlID8/IFtdIH0pKTtcbiAgY29uc3Qgc3ZlbHRlRmlsZXMgPSBhbGxGaWxlcy5maWx0ZXIoKGZpbGUpID0+IGZpbGUuZW5kc1dpdGgoJy5zdmVsdGUnKSB8fCBmaWxlLmVuZHNXaXRoKCcuc3ZlbHRlLmpzJykgfHwgZmlsZS5lbmRzV2l0aCgnLnN2ZWx0ZS50cycpKTtcblxuICBpZiAoc3ZlbHRlRmlsZXMubGVuZ3RoID09PSAwKSB7XG4gICAgZ2V0TGliRGVidWdnZXIoJ2J1aWxkOmJ1aWxkQ29tcGlsZVN2ZWx0ZScpKCdObyBTdmVsdGUgZmlsZXMgZm91bmQgaW4gdGhlIHByb2plY3QsIHNraXBwaW5nIFN2ZWx0ZSBjb21waWxhdGlvbicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ25weCcsICdzdmVsdGUtY2hlY2snLCAnLS10c2NvbmZpZycsIE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuVHNDb25maWdKc29uXSk7XG59XG5cbi8qKlxuICogQ29tcGlsZXMgdGhlIFR5cGVTY3JpcHQgY29kZS5cbiAqXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGNvZGUgY29tcGlsZXMgc3VjY2Vzc2Z1bGx5LlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDb21waWxlVHlwZVNjcmlwdCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnB4JywgJ3RzYycsICctLWJ1aWxkJywgJy0tZm9yY2UnXSk7XG59XG5cbi8qKlxuICogQ29waWVzIGFsbCBzdGF0aWMgZmlsZXMgZnJvbSB0aGUgc3RhdGljIGFzc2V0cyBmb2xkZXIgdG8gdGhlIGRpc3RyaWJ1dGlvbiBmb2xkZXIuXG4gKlxuICogVGhpcyBmdW5jdGlvbiByZWN1cnNpdmVseSByZWFkcyB0aGUgY29udGVudHMgb2YgdGhlIHN0YXRpYyBhc3NldHMgZm9sZGVyIGFuZCBjb3BpZXNcbiAqIGVhY2ggZmlsZSB0byB0aGUgY29ycmVzcG9uZGluZyBwYXRoIGluIHRoZSBkaXN0cmlidXRpb24gZm9sZGVyLlxuICpcbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiBhbGwgZmlsZXMgaGF2ZSBiZWVuIGNvcGllZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkU3RhdGljKCk6IFByb21pc2U8dm9pZD4ge1xuICBmb3IgKGNvbnN0IGRpcmVudCBvZiBhd2FpdCByZWFkZGlyUG9zaXgoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWMsIHsgcmVjdXJzaXZlOiB0cnVlLCB3aXRoRmlsZVR5cGVzOiB0cnVlIH0pKSB7XG4gICAgaWYgKCFkaXJlbnQuaXNGaWxlKCkpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IHBhdGggPSB0cmltU3RhcnQoam9pbihkaXJlbnQucGFyZW50UGF0aCwgZGlyZW50Lm5hbWUpLCBgJHtPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpY30vYCk7XG4gICAgYXdhaXQgY3Aoam9pbihPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYywgcGF0aCksIGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBwYXRoKSk7XG4gIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVVBO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsT0FDSztBQUVQLFNBQVMsZUFBZTtBQUN4QixTQUFTLHNCQUFzQjtBQUMvQixTQUFTLFlBQVk7QUFDckIsU0FBUyxpQkFBaUI7QUFDMUIsU0FBUyxvQkFBb0I7QUFDN0IsU0FBUyxnQkFBZ0I7QUFDekIsU0FBUyxjQUFjO0FBQ3ZCLFNBQVMsaUNBQWlDO0FBQzFDO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBU1AsZUFBc0IsYUFBNEI7QUFDaEQsUUFBTSxHQUFHLDBCQUEwQixNQUFNLEVBQUUsT0FBTyxNQUFNLFdBQVcsS0FBSyxDQUFDO0FBQzNFO0FBT0EsZUFBc0IsZUFBOEI7QUFDbEQsUUFBTSxPQUFPLHNCQUFzQjtBQUNuQyxRQUFNLE9BQU8sMEJBQTBCO0FBQ3pDO0FBT0EsZUFBc0IscUJBQW9DO0FBQ3hELFFBQU0sZUFBZSx3QkFBd0IsMEJBQTBCLFlBQVk7QUFDbkYsUUFBTSxXQUFXLE1BQU0sU0FBdUIsWUFBWTtBQUMxRCxRQUFNLFdBQVcsTUFBTSxRQUFRLEtBQUssU0FBUyxXQUFXLENBQUMsR0FBRyxFQUFFLFNBQVMsU0FBUyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDaEcsUUFBTSxjQUFjLFNBQVMsT0FBTyxDQUFDLFNBQVMsS0FBSyxTQUFTLFNBQVMsS0FBSyxLQUFLLFNBQVMsWUFBWSxLQUFLLEtBQUssU0FBUyxZQUFZLENBQUM7QUFFcEksTUFBSSxZQUFZLFdBQVcsR0FBRztBQUM1QixtQkFBZSwwQkFBMEIsRUFBRSxtRUFBbUU7QUFDOUc7QUFBQSxFQUNGO0FBRUEsUUFBTSxhQUFhLENBQUMsT0FBTyxnQkFBZ0IsY0FBYywwQkFBMEIsWUFBWSxDQUFDO0FBQ2xHO0FBT0EsZUFBc0IseUJBQXdDO0FBQzVELFFBQU0sYUFBYSxDQUFDLE9BQU8sT0FBTyxXQUFXLFNBQVMsQ0FBQztBQUN6RDtBQVVBLGVBQXNCLGNBQTZCO0FBQ2pELGFBQVcsVUFBVSxNQUFNLGFBQWEsMEJBQTBCLFFBQVEsRUFBRSxXQUFXLE1BQU0sZUFBZSxLQUFLLENBQUMsR0FBRztBQUNuSCxRQUFJLENBQUMsT0FBTyxPQUFPLEdBQUc7QUFDcEI7QUFBQSxJQUNGO0FBRUEsVUFBTSxPQUFPLFVBQVUsS0FBSyxPQUFPLFlBQVksT0FBTyxJQUFJLEdBQUcsR0FBRywwQkFBMEIsTUFBTSxHQUFHO0FBQ25HLFVBQU0sR0FBRyxLQUFLLDBCQUEwQixRQUFRLElBQUksR0FBRyxLQUFLLDBCQUEwQixNQUFNLElBQUksQ0FBQztBQUFBLEVBQ25HO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -19,8 +19,8 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
+ import { writeFile } from "node:fs/promises";
22
23
  import { replaceAll } from "../../../string.mjs";
23
- import { writeFile } from "../../node-modules.mjs";
24
24
  import { ObsidianDevUtilsRepoPaths } from "../../obsidian-dev-utils-repo-paths.mjs";
25
25
  function changeExtensionPlugin(extension) {
26
26
  return {
@@ -55,4 +55,4 @@ function changeExtensionPlugin(extension) {
55
55
  export {
56
56
  changeExtensionPlugin
57
57
  };
58
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLWltcGwvY2hhbmdlRXh0ZW5zaW9uUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFRoaXMgbW9kdWxlIGRlZmluZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCBjaGFuZ2VzIHRoZSBleHRlbnNpb24gb2YgSmF2YVNjcmlwdCBmaWxlcyBhZnRlciB0aGUgYnVpbGQgcHJvY2Vzcy5cbiAqL1xuXG4vKiB2OCBpZ25vcmUgc3RhcnQgLS0gZXNidWlsZCBwbHVnaW4gdGhhdCByZXdyaXRlcyBmaWxlIGV4dGVuc2lvbnMgYXQgYnVpbGQgdGltZTsgcmVxdWlyZXMgYSBsaXZlIGVzYnVpbGQgY29udGV4dC4gKi9cblxuaW1wb3J0IHR5cGUgeyBQbHVnaW4gfSBmcm9tICdlc2J1aWxkJztcblxuaW1wb3J0IHsgcmVwbGFjZUFsbCB9IGZyb20gJy4uLy4uLy4uL3N0cmluZy50cyc7XG5pbXBvcnQgeyB3cml0ZUZpbGUgfSBmcm9tICcuLi8uLi9ub2RlLW1vZHVsZXMudHMnO1xuaW1wb3J0IHsgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocyB9IGZyb20gJy4uLy4uL29ic2lkaWFuLWRldi11dGlscy1yZXBvLXBhdGhzLnRzJztcblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVzYnVpbGQgcGx1Z2luIHRoYXQgY2hhbmdlcyB0aGUgZXh0ZW5zaW9uIG9mIEphdmFTY3JpcHQgZmlsZXMgYWZ0ZXIgdGhlIGJ1aWxkIHByb2Nlc3MuXG4gKlxuICogQHBhcmFtIGV4dGVuc2lvbiAtIFRoZSBleHRlbnNpb24gdG8gY2hhbmdlIHRoZSBmaWxlcyB0by5cbiAqIEByZXR1cm5zIEFuIGVzYnVpbGQgYFBsdWdpbmAgb2JqZWN0IHRoYXQgaGFuZGxlcyB0aGUgcmVuYW1pbmcgYW5kIG1vZGlmaWNhdGlvbiBvZiBvdXRwdXQgZmlsZXMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjaGFuZ2VFeHRlbnNpb25QbHVnaW4oZXh0ZW5zaW9uOiBzdHJpbmcpOiBQbHVnaW4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdjaGFuZ2UtZXh0ZW5zaW9uJyxcbiAgICBzZXR1cChidWlsZCk6IHZvaWQge1xuICAgICAgYnVpbGQub25FbmQoYXN5bmMgKHJlc3VsdCkgPT4ge1xuICAgICAgICBmb3IgKGNvbnN0IGZpbGUgb2YgcmVzdWx0Lm91dHB1dEZpbGVzID8/IFtdKSB7XG4gICAgICAgICAgaWYgKCFmaWxlLnBhdGguZW5kc1dpdGgoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5Kc0V4dGVuc2lvbikgfHwgZmlsZS5wYXRoLmVuZHNXaXRoKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRGpzRXh0ZW5zaW9uKSkge1xuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgbmV3UGF0aCA9IHJlcGxhY2VBbGwoZmlsZS5wYXRoLCAvXFwuanMkL2csIGV4dGVuc2lvbik7XG5cbiAgICAgICAgICBsZXQgbmV3VGV4dCA9IHJlcGxhY2VBbGwoZmlsZS50ZXh0LCAvcmVxdWlyZVxcKFtcIiddKD88SW1wb3J0UGF0aD4uKz8pW1wiJ11cXCkvZywgKF8sIGltcG9ydFBhdGgpID0+IHtcbiAgICAgICAgICAgIGlmIChpbXBvcnRQYXRoLmVuZHNXaXRoKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRHRzRXh0ZW5zaW9uKSkge1xuICAgICAgICAgICAgICByZXR1cm4gJ3VuZGVmaW5lZCc7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNvbnN0IGZpeGVkSW1wb3J0UGF0aCA9IHJlcGxhY2VBbGwoaW1wb3J0UGF0aCwgL1xcLnRzJC9nLCBleHRlbnNpb24pO1xuICAgICAgICAgICAgcmV0dXJuIGByZXF1aXJlKCcke2ZpeGVkSW1wb3J0UGF0aH0nKWA7XG4gICAgICAgICAgfSk7XG5cbiAgICAgICAgICBuZXdUZXh0ID0gcmVwbGFjZUFsbChuZXdUZXh0LCAvZnJvbSBcIig/PEltcG9ydFBhdGg+Lis/KVwiL2csIChfLCBpbXBvcnRQYXRoKSA9PiB7XG4gICAgICAgICAgICBpZiAoaW1wb3J0UGF0aC5lbmRzV2l0aChPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkR0c0V4dGVuc2lvbikpIHtcbiAgICAgICAgICAgICAgcmV0dXJuICd1bmRlZmluZWQnO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBjb25zdCBmaXhlZEltcG9ydFBhdGggPSByZXBsYWNlQWxsKGltcG9ydFBhdGgsIC9cXC50cyQvZywgZXh0ZW5zaW9uKTtcbiAgICAgICAgICAgIHJldHVybiBgZnJvbSBcIiR7Zml4ZWRJbXBvcnRQYXRofVwiYDtcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGF3YWl0IHdyaXRlRmlsZShuZXdQYXRoLCBuZXdUZXh0KTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuICB9O1xufVxuXG4vKiB2OCBpZ25vcmUgc3RvcCAqL1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBVUEsU0FBUyxrQkFBa0I7QUFDM0IsU0FBUyxpQkFBaUI7QUFDMUIsU0FBUyxpQ0FBaUM7QUFRbkMsU0FBUyxzQkFBc0IsV0FBMkI7QUFDL0QsU0FBTztBQUFBLElBQ0wsTUFBTTtBQUFBLElBQ04sTUFBTSxPQUFhO0FBQ2pCLFlBQU0sTUFBTSxPQUFPLFdBQVc7QUFDNUIsbUJBQVcsUUFBUSxPQUFPLGVBQWUsQ0FBQyxHQUFHO0FBQzNDLGNBQUksQ0FBQyxLQUFLLEtBQUssU0FBUywwQkFBMEIsV0FBVyxLQUFLLEtBQUssS0FBSyxTQUFTLDBCQUEwQixZQUFZLEdBQUc7QUFDNUg7QUFBQSxVQUNGO0FBRUEsZ0JBQU0sVUFBVSxXQUFXLEtBQUssTUFBTSxVQUFVLFNBQVM7QUFFekQsY0FBSSxVQUFVLFdBQVcsS0FBSyxNQUFNLDBDQUEwQyxDQUFDLEdBQUcsZUFBZTtBQUMvRixnQkFBSSxXQUFXLFNBQVMsMEJBQTBCLFlBQVksR0FBRztBQUMvRCxxQkFBTztBQUFBLFlBQ1Q7QUFFQSxrQkFBTSxrQkFBa0IsV0FBVyxZQUFZLFVBQVUsU0FBUztBQUNsRSxtQkFBTyxZQUFZLGVBQWU7QUFBQSxVQUNwQyxDQUFDO0FBRUQsb0JBQVUsV0FBVyxTQUFTLDhCQUE4QixDQUFDLEdBQUcsZUFBZTtBQUM3RSxnQkFBSSxXQUFXLFNBQVMsMEJBQTBCLFlBQVksR0FBRztBQUMvRCxxQkFBTztBQUFBLFlBQ1Q7QUFFQSxrQkFBTSxrQkFBa0IsV0FBVyxZQUFZLFVBQVUsU0FBUztBQUNsRSxtQkFBTyxTQUFTLGVBQWU7QUFBQSxVQUNqQyxDQUFDO0FBRUQsZ0JBQU0sVUFBVSxTQUFTLE9BQU87QUFBQSxRQUNsQztBQUFBLE1BQ0YsQ0FBQztBQUFBLElBQ0g7QUFBQSxFQUNGO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
58
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLWltcGwvY2hhbmdlRXh0ZW5zaW9uUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFRoaXMgbW9kdWxlIGRlZmluZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCBjaGFuZ2VzIHRoZSBleHRlbnNpb24gb2YgSmF2YVNjcmlwdCBmaWxlcyBhZnRlciB0aGUgYnVpbGQgcHJvY2Vzcy5cbiAqL1xuXG4vKiB2OCBpZ25vcmUgc3RhcnQgLS0gZXNidWlsZCBwbHVnaW4gdGhhdCByZXdyaXRlcyBmaWxlIGV4dGVuc2lvbnMgYXQgYnVpbGQgdGltZTsgcmVxdWlyZXMgYSBsaXZlIGVzYnVpbGQgY29udGV4dC4gKi9cblxuaW1wb3J0IHR5cGUgeyBQbHVnaW4gfSBmcm9tICdlc2J1aWxkJztcblxuaW1wb3J0IHsgd3JpdGVGaWxlIH0gZnJvbSAnbm9kZTpmcy9wcm9taXNlcyc7XG5cbmltcG9ydCB7IHJlcGxhY2VBbGwgfSBmcm9tICcuLi8uLi8uLi9zdHJpbmcudHMnO1xuaW1wb3J0IHsgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocyB9IGZyb20gJy4uLy4uL29ic2lkaWFuLWRldi11dGlscy1yZXBvLXBhdGhzLnRzJztcblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVzYnVpbGQgcGx1Z2luIHRoYXQgY2hhbmdlcyB0aGUgZXh0ZW5zaW9uIG9mIEphdmFTY3JpcHQgZmlsZXMgYWZ0ZXIgdGhlIGJ1aWxkIHByb2Nlc3MuXG4gKlxuICogQHBhcmFtIGV4dGVuc2lvbiAtIFRoZSBleHRlbnNpb24gdG8gY2hhbmdlIHRoZSBmaWxlcyB0by5cbiAqIEByZXR1cm5zIEFuIGVzYnVpbGQgYFBsdWdpbmAgb2JqZWN0IHRoYXQgaGFuZGxlcyB0aGUgcmVuYW1pbmcgYW5kIG1vZGlmaWNhdGlvbiBvZiBvdXRwdXQgZmlsZXMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjaGFuZ2VFeHRlbnNpb25QbHVnaW4oZXh0ZW5zaW9uOiBzdHJpbmcpOiBQbHVnaW4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdjaGFuZ2UtZXh0ZW5zaW9uJyxcbiAgICBzZXR1cChidWlsZCk6IHZvaWQge1xuICAgICAgYnVpbGQub25FbmQoYXN5bmMgKHJlc3VsdCkgPT4ge1xuICAgICAgICBmb3IgKGNvbnN0IGZpbGUgb2YgcmVzdWx0Lm91dHB1dEZpbGVzID8/IFtdKSB7XG4gICAgICAgICAgaWYgKCFmaWxlLnBhdGguZW5kc1dpdGgoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5Kc0V4dGVuc2lvbikgfHwgZmlsZS5wYXRoLmVuZHNXaXRoKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRGpzRXh0ZW5zaW9uKSkge1xuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgbmV3UGF0aCA9IHJlcGxhY2VBbGwoZmlsZS5wYXRoLCAvXFwuanMkL2csIGV4dGVuc2lvbik7XG5cbiAgICAgICAgICBsZXQgbmV3VGV4dCA9IHJlcGxhY2VBbGwoZmlsZS50ZXh0LCAvcmVxdWlyZVxcKFtcIiddKD88SW1wb3J0UGF0aD4uKz8pW1wiJ11cXCkvZywgKF8sIGltcG9ydFBhdGgpID0+IHtcbiAgICAgICAgICAgIGlmIChpbXBvcnRQYXRoLmVuZHNXaXRoKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRHRzRXh0ZW5zaW9uKSkge1xuICAgICAgICAgICAgICByZXR1cm4gJ3VuZGVmaW5lZCc7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNvbnN0IGZpeGVkSW1wb3J0UGF0aCA9IHJlcGxhY2VBbGwoaW1wb3J0UGF0aCwgL1xcLnRzJC9nLCBleHRlbnNpb24pO1xuICAgICAgICAgICAgcmV0dXJuIGByZXF1aXJlKCcke2ZpeGVkSW1wb3J0UGF0aH0nKWA7XG4gICAgICAgICAgfSk7XG5cbiAgICAgICAgICBuZXdUZXh0ID0gcmVwbGFjZUFsbChuZXdUZXh0LCAvZnJvbSBcIig/PEltcG9ydFBhdGg+Lis/KVwiL2csIChfLCBpbXBvcnRQYXRoKSA9PiB7XG4gICAgICAgICAgICBpZiAoaW1wb3J0UGF0aC5lbmRzV2l0aChPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkR0c0V4dGVuc2lvbikpIHtcbiAgICAgICAgICAgICAgcmV0dXJuICd1bmRlZmluZWQnO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBjb25zdCBmaXhlZEltcG9ydFBhdGggPSByZXBsYWNlQWxsKGltcG9ydFBhdGgsIC9cXC50cyQvZywgZXh0ZW5zaW9uKTtcbiAgICAgICAgICAgIHJldHVybiBgZnJvbSBcIiR7Zml4ZWRJbXBvcnRQYXRofVwiYDtcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGF3YWl0IHdyaXRlRmlsZShuZXdQYXRoLCBuZXdUZXh0KTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuICB9O1xufVxuXG4vKiB2OCBpZ25vcmUgc3RvcCAqL1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBVUEsU0FBUyxpQkFBaUI7QUFFMUIsU0FBUyxrQkFBa0I7QUFDM0IsU0FBUyxpQ0FBaUM7QUFRbkMsU0FBUyxzQkFBc0IsV0FBMkI7QUFDL0QsU0FBTztBQUFBLElBQ0wsTUFBTTtBQUFBLElBQ04sTUFBTSxPQUFhO0FBQ2pCLFlBQU0sTUFBTSxPQUFPLFdBQVc7QUFDNUIsbUJBQVcsUUFBUSxPQUFPLGVBQWUsQ0FBQyxHQUFHO0FBQzNDLGNBQUksQ0FBQyxLQUFLLEtBQUssU0FBUywwQkFBMEIsV0FBVyxLQUFLLEtBQUssS0FBSyxTQUFTLDBCQUEwQixZQUFZLEdBQUc7QUFDNUg7QUFBQSxVQUNGO0FBRUEsZ0JBQU0sVUFBVSxXQUFXLEtBQUssTUFBTSxVQUFVLFNBQVM7QUFFekQsY0FBSSxVQUFVLFdBQVcsS0FBSyxNQUFNLDBDQUEwQyxDQUFDLEdBQUcsZUFBZTtBQUMvRixnQkFBSSxXQUFXLFNBQVMsMEJBQTBCLFlBQVksR0FBRztBQUMvRCxxQkFBTztBQUFBLFlBQ1Q7QUFFQSxrQkFBTSxrQkFBa0IsV0FBVyxZQUFZLFVBQVUsU0FBUztBQUNsRSxtQkFBTyxZQUFZLGVBQWU7QUFBQSxVQUNwQyxDQUFDO0FBRUQsb0JBQVUsV0FBVyxTQUFTLDhCQUE4QixDQUFDLEdBQUcsZUFBZTtBQUM3RSxnQkFBSSxXQUFXLFNBQVMsMEJBQTBCLFlBQVksR0FBRztBQUMvRCxxQkFBTztBQUFBLFlBQ1Q7QUFFQSxrQkFBTSxrQkFBa0IsV0FBVyxZQUFZLFVBQVUsU0FBUztBQUNsRSxtQkFBTyxTQUFTLGVBQWU7QUFBQSxVQUNqQyxDQUFDO0FBRUQsZ0JBQU0sVUFBVSxTQUFTLE9BQU87QUFBQSxRQUNsQztBQUFBLE1BQ0YsQ0FBQztBQUFBLElBQ0g7QUFBQSxFQUNGO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -19,18 +19,18 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
- import { getLibDebugger } from "../../../debug.mjs";
23
- import {
24
- join,
25
- toPosixPath
26
- } from "../../../path.mjs";
22
+ import { existsSync } from "node:fs";
27
23
  import {
28
24
  cp,
29
- existsSync,
30
25
  mkdir,
31
26
  readFile,
32
27
  writeFile
33
- } from "../../node-modules.mjs";
28
+ } from "node:fs/promises";
29
+ import { getLibDebugger } from "../../../debug.mjs";
30
+ import {
31
+ join,
32
+ toPosixPath
33
+ } from "../../../path.mjs";
34
34
  import { evalObsidianCli } from "../../obsidian-cli.mjs";
35
35
  function copyToObsidianPluginsFolderPlugin(isProductionBuild, distFolder, obsidianConfigFolder, pluginName) {
36
36
  return {
@@ -96,4 +96,4 @@ async function enableCommunityPlugin(obsidianConfigFolder, pluginId) {
96
96
  export {
97
97
  copyToObsidianPluginsFolderPlugin
98
98
  };
99
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines an esbuild plugin that automatically copies the build output\n * to the Obsidian plugins folder during development. This plugin helps streamline\n * the development workflow by ensuring that the latest build is always available\n * in the correct Obsidian folder for testing and use.\n */\n\n/* v8 ignore start -- esbuild plugin that copies build output to Obsidian plugins folder; requires a live esbuild context. */\n\nimport type { Plugin } from 'esbuild';\n\nimport { getLibDebugger } from '../../../debug.ts';\nimport {\n  join,\n  toPosixPath\n} from '../../../path.ts';\nimport {\n  cp,\n  existsSync,\n  mkdir,\n  readFile,\n  writeFile\n} from '../../node-modules.ts';\nimport { evalObsidianCli } from '../../obsidian-cli.ts';\n\n/**\n * Creates an esbuild plugin that copies the build output to the Obsidian plugins folder.\n *\n * @param isProductionBuild - A boolean indicating whether the build is a production build.\n * @param distFolder - The folder where the built files are located.\n * @param obsidianConfigFolder - The folder of the Obsidian configuration. If not provided, the plugin will not copy files.\n * @param pluginName - The name of the Obsidian plugin.\n * @returns An esbuild `Plugin` object.\n */\nexport function copyToObsidianPluginsFolderPlugin(\n  isProductionBuild: boolean,\n  distFolder: string,\n  obsidianConfigFolder: string,\n  pluginName: string\n): Plugin {\n  return {\n    name: 'copy-to-obsidian-plugins-folder',\n    setup(build): void {\n      build.onEnd(async () => {\n        if (isProductionBuild) {\n          return;\n        }\n\n        if (!obsidianConfigFolder) {\n          getLibDebugger('copyToObsidianPluginsFolderPlugin')(\n            '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.'\n          );\n          return;\n        }\n\n        obsidianConfigFolder = toPosixPath(obsidianConfigFolder);\n\n        const pluginFolder = join(obsidianConfigFolder, 'plugins', pluginName);\n\n        if (!existsSync(pluginFolder)) {\n          await mkdir(pluginFolder, { recursive: true });\n        }\n\n        await cp(distFolder, pluginFolder, { recursive: true });\n\n        const hotReloadFolder = join(obsidianConfigFolder, 'plugins/hot-reload');\n        if (!existsSync(hotReloadFolder)) {\n          await mkdir(hotReloadFolder, { recursive: true });\n          const hotReloadRepoUrl = 'https://raw.githubusercontent.com/pjeby/hot-reload/master/';\n          for (const fileName of ['main.js', 'manifest.json']) {\n            const fileUrl = hotReloadRepoUrl + fileName;\n            // eslint-disable-next-line no-restricted-globals -- We run this outside of Obsidian, so we don't have `requestUrl()`.\n            const response = await fetch(fileUrl);\n            const text = await response.text();\n            await writeFile(join(hotReloadFolder, fileName), text);\n          }\n        }\n\n        await enableCommunityPlugin(obsidianConfigFolder, 'hot-reload');\n        await enableCommunityPlugin(obsidianConfigFolder, pluginName);\n      });\n    }\n  };\n}\n\nasync function enableCommunityPlugin(obsidianConfigFolder: string, pluginId: string): Promise<void> {\n  const communityPluginsPath = join(obsidianConfigFolder, 'community-plugins.json');\n  let plugins: string[] = [];\n  if (existsSync(communityPluginsPath)) {\n    const content = await readFile(communityPluginsPath, 'utf-8');\n    plugins = JSON.parse(content) as string[];\n  }\n\n  if (!plugins.includes(pluginId)) {\n    plugins.push(pluginId);\n    const JSON_INDENT = 2;\n    await writeFile(communityPluginsPath, JSON.stringify(plugins, null, JSON_INDENT), 'utf-8');\n  }\n\n  try {\n    await evalObsidianCli((app, id) => app.plugins.enablePlugin(id), pluginId);\n  } catch (e: unknown) {\n    const errorMessage = e instanceof Error ? e.message : String(e);\n    const isNotFound = errorMessage.includes('ENOENT') || errorMessage.includes('not found') || errorMessage.includes('not recognized');\n    if (isNotFound) {\n      console.error(`Obsidian CLI is not installed. Plugin '${pluginId}' will be enabled on next vault open. See https://help.obsidian.md/cli`);\n    } else {\n      console.error(`Failed to enable plugin '${pluginId}' via Obsidian CLI.`, e);\n    }\n  }\n}\n\n/* v8 ignore stop */\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAaA,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,uBAAuB;AAWzB,SAAS,kCACd,mBACA,YACA,sBACA,YACQ;AACR,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM,OAAa;AACjB,YAAM,MAAM,YAAY;AACtB,YAAI,mBAAmB;AACrB;AAAA,QACF;AAEA,YAAI,CAAC,sBAAsB;AACzB,yBAAe,mCAAmC;AAAA,YAChD;AAAA,UACF;AACA;AAAA,QACF;AAEA,+BAAuB,YAAY,oBAAoB;AAEvD,cAAM,eAAe,KAAK,sBAAsB,WAAW,UAAU;AAErE,YAAI,CAAC,WAAW,YAAY,GAAG;AAC7B,gBAAM,MAAM,cAAc,EAAE,WAAW,KAAK,CAAC;AAAA,QAC/C;AAEA,cAAM,GAAG,YAAY,cAAc,EAAE,WAAW,KAAK,CAAC;AAEtD,cAAM,kBAAkB,KAAK,sBAAsB,oBAAoB;AACvE,YAAI,CAAC,WAAW,eAAe,GAAG;AAChC,gBAAM,MAAM,iBAAiB,EAAE,WAAW,KAAK,CAAC;AAChD,gBAAM,mBAAmB;AACzB,qBAAW,YAAY,CAAC,WAAW,eAAe,GAAG;AACnD,kBAAM,UAAU,mBAAmB;AAEnC,kBAAM,WAAW,MAAM,MAAM,OAAO;AACpC,kBAAM,OAAO,MAAM,SAAS,KAAK;AACjC,kBAAM,UAAU,KAAK,iBAAiB,QAAQ,GAAG,IAAI;AAAA,UACvD;AAAA,QACF;AAEA,cAAM,sBAAsB,sBAAsB,YAAY;AAC9D,cAAM,sBAAsB,sBAAsB,UAAU;AAAA,MAC9D,CAAC;AAAA,IACH;AAAA,EACF;AACF;AAEA,eAAe,sBAAsB,sBAA8B,UAAiC;AAClG,QAAM,uBAAuB,KAAK,sBAAsB,wBAAwB;AAChF,MAAI,UAAoB,CAAC;AACzB,MAAI,WAAW,oBAAoB,GAAG;AACpC,UAAM,UAAU,MAAM,SAAS,sBAAsB,OAAO;AAC5D,cAAU,KAAK,MAAM,OAAO;AAAA,EAC9B;AAEA,MAAI,CAAC,QAAQ,SAAS,QAAQ,GAAG;AAC/B,YAAQ,KAAK,QAAQ;AACrB,UAAM,cAAc;AACpB,UAAM,UAAU,sBAAsB,KAAK,UAAU,SAAS,MAAM,WAAW,GAAG,OAAO;AAAA,EAC3F;AAEA,MAAI;AACF,UAAM,gBAAgB,CAAC,KAAK,OAAO,IAAI,QAAQ,aAAa,EAAE,GAAG,QAAQ;AAAA,EAC3E,SAAS,GAAY;AACnB,UAAM,eAAe,aAAa,QAAQ,EAAE,UAAU,OAAO,CAAC;AAC9D,UAAM,aAAa,aAAa,SAAS,QAAQ,KAAK,aAAa,SAAS,WAAW,KAAK,aAAa,SAAS,gBAAgB;AAClI,QAAI,YAAY;AACd,cAAQ,MAAM,0CAA0C,QAAQ,wEAAwE;AAAA,IAC1I,OAAO;AACL,cAAQ,MAAM,4BAA4B,QAAQ,uBAAuB,CAAC;AAAA,IAC5E;AAAA,EACF;AACF;",
  "names": []
}

99
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/copyToObsidianPluginsFolderPlugin.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines an esbuild plugin that automatically copies the build output\n * to the Obsidian plugins folder during development. This plugin helps streamline\n * the development workflow by ensuring that the latest build is always available\n * in the correct Obsidian folder for testing and use.\n */\n\n/* v8 ignore start -- esbuild plugin that copies build output to Obsidian plugins folder; requires a live esbuild context. */\n\nimport type { Plugin } from 'esbuild';\n\nimport { existsSync } from 'node:fs';\nimport {\n  cp,\n  mkdir,\n  readFile,\n  writeFile\n} from 'node:fs/promises';\n\nimport { getLibDebugger } from '../../../debug.ts';\nimport {\n  join,\n  toPosixPath\n} from '../../../path.ts';\nimport { evalObsidianCli } from '../../obsidian-cli.ts';\n\n/**\n * Creates an esbuild plugin that copies the build output to the Obsidian plugins folder.\n *\n * @param isProductionBuild - A boolean indicating whether the build is a production build.\n * @param distFolder - The folder where the built files are located.\n * @param obsidianConfigFolder - The folder of the Obsidian configuration. If not provided, the plugin will not copy files.\n * @param pluginName - The name of the Obsidian plugin.\n * @returns An esbuild `Plugin` object.\n */\nexport function copyToObsidianPluginsFolderPlugin(\n  isProductionBuild: boolean,\n  distFolder: string,\n  obsidianConfigFolder: string,\n  pluginName: string\n): Plugin {\n  return {\n    name: 'copy-to-obsidian-plugins-folder',\n    setup(build): void {\n      build.onEnd(async () => {\n        if (isProductionBuild) {\n          return;\n        }\n\n        if (!obsidianConfigFolder) {\n          getLibDebugger('copyToObsidianPluginsFolderPlugin')(\n            '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.'\n          );\n          return;\n        }\n\n        obsidianConfigFolder = toPosixPath(obsidianConfigFolder);\n\n        const pluginFolder = join(obsidianConfigFolder, 'plugins', pluginName);\n\n        if (!existsSync(pluginFolder)) {\n          await mkdir(pluginFolder, { recursive: true });\n        }\n\n        await cp(distFolder, pluginFolder, { recursive: true });\n\n        const hotReloadFolder = join(obsidianConfigFolder, 'plugins/hot-reload');\n        if (!existsSync(hotReloadFolder)) {\n          await mkdir(hotReloadFolder, { recursive: true });\n          const hotReloadRepoUrl = 'https://raw.githubusercontent.com/pjeby/hot-reload/master/';\n          for (const fileName of ['main.js', 'manifest.json']) {\n            const fileUrl = hotReloadRepoUrl + fileName;\n            // eslint-disable-next-line no-restricted-globals -- We run this outside of Obsidian, so we don't have `requestUrl()`.\n            const response = await fetch(fileUrl);\n            const text = await response.text();\n            await writeFile(join(hotReloadFolder, fileName), text);\n          }\n        }\n\n        await enableCommunityPlugin(obsidianConfigFolder, 'hot-reload');\n        await enableCommunityPlugin(obsidianConfigFolder, pluginName);\n      });\n    }\n  };\n}\n\nasync function enableCommunityPlugin(obsidianConfigFolder: string, pluginId: string): Promise<void> {\n  const communityPluginsPath = join(obsidianConfigFolder, 'community-plugins.json');\n  let plugins: string[] = [];\n  if (existsSync(communityPluginsPath)) {\n    const content = await readFile(communityPluginsPath, 'utf-8');\n    plugins = JSON.parse(content) as string[];\n  }\n\n  if (!plugins.includes(pluginId)) {\n    plugins.push(pluginId);\n    const JSON_INDENT = 2;\n    await writeFile(communityPluginsPath, JSON.stringify(plugins, null, JSON_INDENT), 'utf-8');\n  }\n\n  try {\n    await evalObsidianCli((app, id) => app.plugins.enablePlugin(id), pluginId);\n  } catch (e: unknown) {\n    const errorMessage = e instanceof Error ? e.message : String(e);\n    const isNotFound = errorMessage.includes('ENOENT') || errorMessage.includes('not found') || errorMessage.includes('not recognized');\n    if (isNotFound) {\n      console.error(`Obsidian CLI is not installed. Plugin '${pluginId}' will be enabled on next vault open. See https://help.obsidian.md/cli`);\n    } else {\n      console.error(`Failed to enable plugin '${pluginId}' via Obsidian CLI.`, e);\n    }\n  }\n}\n\n/* v8 ignore stop */\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAaA,SAAS,kBAAkB;AAC3B;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAEP,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,uBAAuB;AAWzB,SAAS,kCACd,mBACA,YACA,sBACA,YACQ;AACR,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM,OAAa;AACjB,YAAM,MAAM,YAAY;AACtB,YAAI,mBAAmB;AACrB;AAAA,QACF;AAEA,YAAI,CAAC,sBAAsB;AACzB,yBAAe,mCAAmC;AAAA,YAChD;AAAA,UACF;AACA;AAAA,QACF;AAEA,+BAAuB,YAAY,oBAAoB;AAEvD,cAAM,eAAe,KAAK,sBAAsB,WAAW,UAAU;AAErE,YAAI,CAAC,WAAW,YAAY,GAAG;AAC7B,gBAAM,MAAM,cAAc,EAAE,WAAW,KAAK,CAAC;AAAA,QAC/C;AAEA,cAAM,GAAG,YAAY,cAAc,EAAE,WAAW,KAAK,CAAC;AAEtD,cAAM,kBAAkB,KAAK,sBAAsB,oBAAoB;AACvE,YAAI,CAAC,WAAW,eAAe,GAAG;AAChC,gBAAM,MAAM,iBAAiB,EAAE,WAAW,KAAK,CAAC;AAChD,gBAAM,mBAAmB;AACzB,qBAAW,YAAY,CAAC,WAAW,eAAe,GAAG;AACnD,kBAAM,UAAU,mBAAmB;AAEnC,kBAAM,WAAW,MAAM,MAAM,OAAO;AACpC,kBAAM,OAAO,MAAM,SAAS,KAAK;AACjC,kBAAM,UAAU,KAAK,iBAAiB,QAAQ,GAAG,IAAI;AAAA,UACvD;AAAA,QACF;AAEA,cAAM,sBAAsB,sBAAsB,YAAY;AAC9D,cAAM,sBAAsB,sBAAsB,UAAU;AAAA,MAC9D,CAAC;AAAA,IACH;AAAA,EACF;AACF;AAEA,eAAe,sBAAsB,sBAA8B,UAAiC;AAClG,QAAM,uBAAuB,KAAK,sBAAsB,wBAAwB;AAChF,MAAI,UAAoB,CAAC;AACzB,MAAI,WAAW,oBAAoB,GAAG;AACpC,UAAM,UAAU,MAAM,SAAS,sBAAsB,OAAO;AAC5D,cAAU,KAAK,MAAM,OAAO;AAAA,EAC9B;AAEA,MAAI,CAAC,QAAQ,SAAS,QAAQ,GAAG;AAC/B,YAAQ,KAAK,QAAQ;AACrB,UAAM,cAAc;AACpB,UAAM,UAAU,sBAAsB,KAAK,UAAU,SAAS,MAAM,WAAW,GAAG,OAAO;AAAA,EAC3F;AAEA,MAAI;AACF,UAAM,gBAAgB,CAAC,KAAK,OAAO,IAAI,QAAQ,aAAa,EAAE,GAAG,QAAQ;AAAA,EAC3E,SAAS,GAAY;AACnB,UAAM,eAAe,aAAa,QAAQ,EAAE,UAAU,OAAO,CAAC;AAC9D,UAAM,aAAa,aAAa,SAAS,QAAQ,KAAK,aAAa,SAAS,WAAW,KAAK,aAAa,SAAS,gBAAgB;AAClI,QAAI,YAAY;AACd,cAAQ,MAAM,0CAA0C,QAAQ,wEAAwE;AAAA,IAC1I,OAAO;AACL,cAAQ,MAAM,4BAA4B,QAAQ,uBAAuB,CAAC;AAAA,IAC5E;AAAA,EACF;AACF;",
  "names": []
}

@@ -20,16 +20,16 @@ if you want to view the source, please visit the github repository of this plugi
20
20
  })();
21
21
 
22
22
  import { context } from "esbuild";
23
+ import {
24
+ builtinModules,
25
+ createRequire
26
+ } from "node:module";
23
27
  import {
24
28
  getFolderName,
25
29
  join
26
30
  } from "../../../path.mjs";
27
31
  import { trimStart } from "../../../string.mjs";
28
32
  import { ensureNonNullable } from "../../../type-guards.mjs";
29
- import {
30
- builtinModules,
31
- createRequire
32
- } from "../../node-modules.mjs";
33
33
  import { readPackageJson } from "../../npm.mjs";
34
34
  import { ObsidianDevUtilsRepoPaths } from "../../obsidian-dev-utils-repo-paths.mjs";
35
35
  import {
@@ -106,4 +106,4 @@ export {
106
106
  getDependenciesToBundle,
107
107
  getDependenciesToSkip
108
108
  };
109
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/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\n/* v8 ignore start -- esbuild plugin that resolves dependencies at build time; requires a live esbuild context. */\n\nimport type {\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\n\nimport {\n  getFolderName,\n  join\n} from '../../../path.ts';\nimport { trimStart } from '../../../string.ts';\nimport { ensureNonNullable } from '../../../type-guards.ts';\nimport {\n  builtinModules,\n  createRequire\n} from '../../node-modules.ts';\nimport { readPackageJson } from '../../npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../../obsidian-dev-utils-repo-paths.ts';\nimport {\n  banner,\n  invokeEsbuild\n} from './obsidian-plugin-builder.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(ensureNonNullable(args.path.split('/')[0], '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\n/* v8 ignore stop */\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAeA,SAAS,eAAe;AAExB;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,iBAAiB;AAC1B,SAAS,yBAAyB;AAClC;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,kBAAkB,KAAK,KAAK,MAAM,GAAG,EAAE,CAAC,GAAG,YAAY,GAAG,OAAO;AAC9F,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": []
}

109
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/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\n/* v8 ignore start -- esbuild plugin that resolves dependencies at build time; requires a live esbuild context. */\n\nimport type {\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\nimport {\n  builtinModules,\n  createRequire\n} from 'node:module';\n\nimport {\n  getFolderName,\n  join\n} from '../../../path.ts';\nimport { trimStart } from '../../../string.ts';\nimport { ensureNonNullable } from '../../../type-guards.ts';\nimport { readPackageJson } from '../../npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../../obsidian-dev-utils-repo-paths.ts';\nimport {\n  banner,\n  invokeEsbuild\n} from './obsidian-plugin-builder.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(ensureNonNullable(args.path.split('/')[0], '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\n/* v8 ignore stop */\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAeA,SAAS,eAAe;AACxB;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAEP;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,iBAAiB;AAC1B,SAAS,yBAAyB;AAClC,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,kBAAkB,KAAK,KAAK,MAAM,GAAG,EAAE,CAAC,GAAG,YAAY,GAAG,OAAO;AAC9F,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": []
}

@@ -19,13 +19,13 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
- import { toPosixPath } from "../../../path.mjs";
23
- import { replaceAll } from "../../../string.mjs";
22
+ import { existsSync } from "node:fs";
24
23
  import {
25
- existsSync,
26
24
  readFile,
27
25
  writeFile
28
- } from "../../node-modules.mjs";
26
+ } from "node:fs/promises";
27
+ import { toPosixPath } from "../../../path.mjs";
28
+ import { replaceAll } from "../../../string.mjs";
29
29
  function fixSourceMapsPlugin(isProductionBuild, distPaths, pluginName) {
30
30
  return {
31
31
  name: "fix-source-maps",
@@ -66,4 +66,4 @@ function fixSourceMap(sourceMapBase64, pluginName) {
66
66
  export {
67
67
  fixSourceMapsPlugin
68
68
  };
69
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLWltcGwvZml4U291cmNlTWFwc1BsdWdpbi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBUaGlzIG1vZHVsZSBkZWZpbmVzIGFuIGVzYnVpbGQgcGx1Z2luIHRoYXQgZml4ZXMgc291cmNlIG1hcHMgZ2VuZXJhdGVkIGR1cmluZyBkZXZlbG9wbWVudC5cbiAqIEl0IGFkanVzdHMgdGhlIHBhdGhzIGluIHRoZSBzb3VyY2UgbWFwcyB0byBiZSBjb21wYXRpYmxlIHdpdGggT2JzaWRpYW4ncyBpbnRlcm5hbCBVUkwgc2NoZW1lLlxuICogQSBwbHVnaW4gaXMgb25seSBhY3RpdmUgZHVyaW5nIGRldmVsb3BtZW50IGJ1aWxkcy5cbiAqL1xuXG4vKiB2OCBpZ25vcmUgc3RhcnQgLS0gZXNidWlsZCBwbHVnaW4gdGhhdCByZXdyaXRlcyBzb3VyY2UgbWFwcyBmb3IgT2JzaWRpYW4gVVJMIHNjaGVtZTsgcmVxdWlyZXMgYSBsaXZlIGVzYnVpbGQgY29udGV4dC4gKi9cblxuaW1wb3J0IHR5cGUgeyBQbHVnaW4gfSBmcm9tICdlc2J1aWxkJztcblxuaW1wb3J0IHsgdG9Qb3NpeFBhdGggfSBmcm9tICcuLi8uLi8uLi9wYXRoLnRzJztcbmltcG9ydCB7IHJlcGxhY2VBbGwgfSBmcm9tICcuLi8uLi8uLi9zdHJpbmcudHMnO1xuaW1wb3J0IHtcbiAgZXhpc3RzU3luYyxcbiAgcmVhZEZpbGUsXG4gIHdyaXRlRmlsZVxufSBmcm9tICcuLi8uLi9ub2RlLW1vZHVsZXMudHMnO1xuXG5pbnRlcmZhY2UgU291cmNlTWFwIHtcbiAgc291cmNlczogc3RyaW5nW107XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBlc2J1aWxkIHBsdWdpbiB0aGF0IGZpeGVzIHNvdXJjZSBtYXBzIGJ5IGFkanVzdGluZyB0aGUgcGF0aHMgdG8gYmUgY29tcGF0aWJsZVxuICogd2l0aCBPYnNpZGlhbidzIGludGVybmFsIFVSTCBzY2hlbWUuXG4gKlxuICogQHBhcmFtIGlzUHJvZHVjdGlvbkJ1aWxkIC0gQSBib29sZWFuIGluZGljYXRpbmcgd2hldGhlciB0aGUgYnVpbGQgaXMgYSBwcm9kdWN0aW9uIGJ1aWxkLiBUaGUgcGx1Z2luIG9ubHkgcnVucyBpbiBub24tcHJvZHVjdGlvbiBidWlsZHMuXG4gKiBAcGFyYW0gZGlzdFBhdGhzIC0gVGhlIHBhdGhzIHRvIHRoZSBvdXRwdXQgZmlsZXMgY29udGFpbmluZyB0aGUgc291cmNlIG1hcHMuXG4gKiBAcGFyYW0gcGx1Z2luTmFtZSAtIFRoZSBuYW1lIG9mIHRoZSBPYnNpZGlhbiBwbHVnaW4sIHVzZWQgdG8gY29uc3RydWN0IHRoZSBPYnNpZGlhbi1zcGVjaWZpYyBVUkxzLlxuICogQHJldHVybnMgQW4gZXNidWlsZCBgUGx1Z2luYCBvYmplY3QgdGhhdCBmaXhlcyBzb3VyY2UgbWFwcy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGZpeFNvdXJjZU1hcHNQbHVnaW4oaXNQcm9kdWN0aW9uQnVpbGQ6IGJvb2xlYW4sIGRpc3RQYXRoczogc3RyaW5nW10sIHBsdWdpbk5hbWU6IHN0cmluZyk6IFBsdWdpbiB7XG4gIHJldHVybiB7XG4gICAgbmFtZTogJ2ZpeC1zb3VyY2UtbWFwcycsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jICgpID0+IHtcbiAgICAgICAgaWYgKGlzUHJvZHVjdGlvbkJ1aWxkKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgZm9yIChjb25zdCBkaXN0UGF0aCBvZiBkaXN0UGF0aHMpIHtcbiAgICAgICAgICBpZiAoIWV4aXN0c1N5bmMoZGlzdFBhdGgpKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCBjb250ZW50ID0gYXdhaXQgcmVhZEZpbGUoZGlzdFBhdGgsICd1dGYtOCcpO1xuICAgICAgICAgIGNvbnN0IG5ld0NvbnRlbnQgPSByZXBsYWNlQWxsKFxuICAgICAgICAgICAgY29udGVudCxcbiAgICAgICAgICAgIC8oPzxQcmVmaXg+XFxuKD86XFwvXFwvfFxcL1xcKikjIHNvdXJjZU1hcHBpbmdVUkw9ZGF0YTphcHBsaWNhdGlvblxcL2pzb247YmFzZTY0LCkoPzxTb3VyY2VNYXBCYXNlNjQ+Lis/KSg/PFN1ZmZpeD4kfFxcbnwgXFwqXFwvKSg/Oi58XFxuKSovZyxcbiAgICAgICAgICAgIChfLCBwcmVmaXgsIHNvdXJjZU1hcEJhc2U2NCwgc3VmZml4KTogc3RyaW5nID0+IGAke3ByZWZpeCArIGZpeFNvdXJjZU1hcChzb3VyY2VNYXBCYXNlNjQsIHBsdWdpbk5hbWUpICsgc3VmZml4LnRyaW0oKX1cXG4vKiBub3NvdXJjZW1hcCAqL2BcbiAgICAgICAgICApO1xuXG4gICAgICAgICAgaWYgKGNvbnRlbnQgIT09IG5ld0NvbnRlbnQpIHtcbiAgICAgICAgICAgIGF3YWl0IHdyaXRlRmlsZShkaXN0UGF0aCwgbmV3Q29udGVudCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG5cbi8qKlxuICogQ29udmVydHMgYSBnaXZlbiBmaWxlIHBhdGggdG8gYW4gT2JzaWRpYW4tc3BlY2lmaWMgVVJMLlxuICpcbiAqIEBwYXJhbSBwYXRoIC0gVGhlIG9yaWdpbmFsIGZpbGUgcGF0aC5cbiAqIEBwYXJhbSBwbHVnaW5OYW1lIC0gVGhlIG5hbWUgb2YgdGhlIE9ic2lkaWFuIHBsdWdpbi5cbiAqIEByZXR1cm5zIFRoZSBjb252ZXJ0ZWQgcGF0aCBhcyBhbiBPYnNpZGlhbi1zcGVjaWZpYyBVUkwuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRQYXRoVG9PYnNpZGlhblVybChwYXRoOiBzdHJpbmcsIHBsdWdpbk5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IGNvbnZlcnRlZFBhdGggPSByZXBsYWNlQWxsKHRvUG9zaXhQYXRoKHBhdGgpLCAvXig/OlxcLlxcLlxcLykrL2csICcnKTtcbiAgcmV0dXJuIGBhcHA6Ly9vYnNpZGlhbi5tZC9wbHVnaW46JHtwbHVnaW5OYW1lfS8ke2NvbnZlcnRlZFBhdGh9YDtcbn1cblxuLyoqXG4gKiBBZGp1c3RzIHRoZSBwYXRocyBpbiB0aGUgYmFzZTY0LWVuY29kZWQgc291cmNlIG1hcCB0byBiZSBjb21wYXRpYmxlIHdpdGggT2JzaWRpYW4ncyBVUkwgc2NoZW1lLlxuICpcbiAqIEBwYXJhbSBzb3VyY2VNYXBCYXNlNjQgLSBUaGUgYmFzZTY0LWVuY29kZWQgc291cmNlIG1hcCBjb250ZW50LlxuICogQHBhcmFtIHBsdWdpbk5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgT2JzaWRpYW4gcGx1Z2luLCB1c2VkIHRvIGNvbnN0cnVjdCB0aGUgT2JzaWRpYW4tc3BlY2lmaWMgVVJMcy5cbiAqIEByZXR1cm5zIEEgYmFzZTY0LWVuY29kZWQgc3RyaW5nIHdpdGggdGhlIGFkanVzdGVkIHNvdXJjZSBtYXAuXG4gKi9cbmZ1bmN0aW9uIGZpeFNvdXJjZU1hcChzb3VyY2VNYXBCYXNlNjQ6IHN0cmluZywgcGx1Z2luTmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgY29uc3Qgc291cmNlTWFwSnNvbiA9IEJ1ZmZlci5mcm9tKHNvdXJjZU1hcEJhc2U2NCwgJ2Jhc2U2NCcpLnRvU3RyaW5nKCd1dGYtOCcpO1xuICBjb25zdCBzb3VyY2VNYXAgPSBKU09OLnBhcnNlKHNvdXJjZU1hcEpzb24pIGFzIFBhcnRpYWw8U291cmNlTWFwPjtcbiAgc291cmNlTWFwLnNvdXJjZXMgPSAoc291cmNlTWFwLnNvdXJjZXMgPz8gW10pLm1hcCgocGF0aCkgPT4gY29udmVydFBhdGhUb09ic2lkaWFuVXJsKHBhdGgsIHBsdWdpbk5hbWUpKTtcbiAgcmV0dXJuIEJ1ZmZlci5mcm9tKEpTT04uc3RyaW5naWZ5KHNvdXJjZU1hcCkpLnRvU3RyaW5nKCdiYXNlNjQnKTtcbn1cblxuLyogdjggaWdub3JlIHN0b3AgKi9cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVlBLFNBQVMsbUJBQW1CO0FBQzVCLFNBQVMsa0JBQWtCO0FBQzNCO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsT0FDSztBQWVBLFNBQVMsb0JBQW9CLG1CQUE0QixXQUFxQixZQUE0QjtBQUMvRyxTQUFPO0FBQUEsSUFDTCxNQUFNO0FBQUEsSUFDTixNQUFNLE9BQWE7QUFDakIsWUFBTSxNQUFNLFlBQVk7QUFDdEIsWUFBSSxtQkFBbUI7QUFDckI7QUFBQSxRQUNGO0FBRUEsbUJBQVcsWUFBWSxXQUFXO0FBQ2hDLGNBQUksQ0FBQyxXQUFXLFFBQVEsR0FBRztBQUN6QjtBQUFBLFVBQ0Y7QUFFQSxnQkFBTSxVQUFVLE1BQU0sU0FBUyxVQUFVLE9BQU87QUFDaEQsZ0JBQU0sYUFBYTtBQUFBLFlBQ2pCO0FBQUEsWUFDQTtBQUFBLFlBQ0EsQ0FBQyxHQUFHLFFBQVEsaUJBQWlCLFdBQW1CLEdBQUcsU0FBUyxhQUFhLGlCQUFpQixVQUFVLElBQUksT0FBTyxLQUFLLENBQUM7QUFBQTtBQUFBLFVBQ3ZIO0FBRUEsY0FBSSxZQUFZLFlBQVk7QUFDMUIsa0JBQU0sVUFBVSxVQUFVLFVBQVU7QUFBQSxVQUN0QztBQUFBLFFBQ0Y7QUFBQSxNQUNGLENBQUM7QUFBQSxJQUNIO0FBQUEsRUFDRjtBQUNGO0FBU0EsU0FBUyx5QkFBeUIsTUFBYyxZQUE0QjtBQUMxRSxRQUFNLGdCQUFnQixXQUFXLFlBQVksSUFBSSxHQUFHLGlCQUFpQixFQUFFO0FBQ3ZFLFNBQU8sNEJBQTRCLFVBQVUsSUFBSSxhQUFhO0FBQ2hFO0FBU0EsU0FBUyxhQUFhLGlCQUF5QixZQUE0QjtBQUN6RSxRQUFNLGdCQUFnQixPQUFPLEtBQUssaUJBQWlCLFFBQVEsRUFBRSxTQUFTLE9BQU87QUFDN0UsUUFBTSxZQUFZLEtBQUssTUFBTSxhQUFhO0FBQzFDLFlBQVUsV0FBVyxVQUFVLFdBQVcsQ0FBQyxHQUFHLElBQUksQ0FBQyxTQUFTLHlCQUF5QixNQUFNLFVBQVUsQ0FBQztBQUN0RyxTQUFPLE9BQU8sS0FBSyxLQUFLLFVBQVUsU0FBUyxDQUFDLEVBQUUsU0FBUyxRQUFRO0FBQ2pFOyIsCiAgIm5hbWVzIjogW10KfQo=
69
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLWltcGwvZml4U291cmNlTWFwc1BsdWdpbi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBUaGlzIG1vZHVsZSBkZWZpbmVzIGFuIGVzYnVpbGQgcGx1Z2luIHRoYXQgZml4ZXMgc291cmNlIG1hcHMgZ2VuZXJhdGVkIGR1cmluZyBkZXZlbG9wbWVudC5cbiAqIEl0IGFkanVzdHMgdGhlIHBhdGhzIGluIHRoZSBzb3VyY2UgbWFwcyB0byBiZSBjb21wYXRpYmxlIHdpdGggT2JzaWRpYW4ncyBpbnRlcm5hbCBVUkwgc2NoZW1lLlxuICogQSBwbHVnaW4gaXMgb25seSBhY3RpdmUgZHVyaW5nIGRldmVsb3BtZW50IGJ1aWxkcy5cbiAqL1xuXG4vKiB2OCBpZ25vcmUgc3RhcnQgLS0gZXNidWlsZCBwbHVnaW4gdGhhdCByZXdyaXRlcyBzb3VyY2UgbWFwcyBmb3IgT2JzaWRpYW4gVVJMIHNjaGVtZTsgcmVxdWlyZXMgYSBsaXZlIGVzYnVpbGQgY29udGV4dC4gKi9cblxuaW1wb3J0IHR5cGUgeyBQbHVnaW4gfSBmcm9tICdlc2J1aWxkJztcblxuaW1wb3J0IHsgZXhpc3RzU3luYyB9IGZyb20gJ25vZGU6ZnMnO1xuaW1wb3J0IHtcbiAgcmVhZEZpbGUsXG4gIHdyaXRlRmlsZVxufSBmcm9tICdub2RlOmZzL3Byb21pc2VzJztcblxuaW1wb3J0IHsgdG9Qb3NpeFBhdGggfSBmcm9tICcuLi8uLi8uLi9wYXRoLnRzJztcbmltcG9ydCB7IHJlcGxhY2VBbGwgfSBmcm9tICcuLi8uLi8uLi9zdHJpbmcudHMnO1xuXG5pbnRlcmZhY2UgU291cmNlTWFwIHtcbiAgc291cmNlczogc3RyaW5nW107XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBlc2J1aWxkIHBsdWdpbiB0aGF0IGZpeGVzIHNvdXJjZSBtYXBzIGJ5IGFkanVzdGluZyB0aGUgcGF0aHMgdG8gYmUgY29tcGF0aWJsZVxuICogd2l0aCBPYnNpZGlhbidzIGludGVybmFsIFVSTCBzY2hlbWUuXG4gKlxuICogQHBhcmFtIGlzUHJvZHVjdGlvbkJ1aWxkIC0gQSBib29sZWFuIGluZGljYXRpbmcgd2hldGhlciB0aGUgYnVpbGQgaXMgYSBwcm9kdWN0aW9uIGJ1aWxkLiBUaGUgcGx1Z2luIG9ubHkgcnVucyBpbiBub24tcHJvZHVjdGlvbiBidWlsZHMuXG4gKiBAcGFyYW0gZGlzdFBhdGhzIC0gVGhlIHBhdGhzIHRvIHRoZSBvdXRwdXQgZmlsZXMgY29udGFpbmluZyB0aGUgc291cmNlIG1hcHMuXG4gKiBAcGFyYW0gcGx1Z2luTmFtZSAtIFRoZSBuYW1lIG9mIHRoZSBPYnNpZGlhbiBwbHVnaW4sIHVzZWQgdG8gY29uc3RydWN0IHRoZSBPYnNpZGlhbi1zcGVjaWZpYyBVUkxzLlxuICogQHJldHVybnMgQW4gZXNidWlsZCBgUGx1Z2luYCBvYmplY3QgdGhhdCBmaXhlcyBzb3VyY2UgbWFwcy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGZpeFNvdXJjZU1hcHNQbHVnaW4oaXNQcm9kdWN0aW9uQnVpbGQ6IGJvb2xlYW4sIGRpc3RQYXRoczogc3RyaW5nW10sIHBsdWdpbk5hbWU6IHN0cmluZyk6IFBsdWdpbiB7XG4gIHJldHVybiB7XG4gICAgbmFtZTogJ2ZpeC1zb3VyY2UtbWFwcycsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jICgpID0+IHtcbiAgICAgICAgaWYgKGlzUHJvZHVjdGlvbkJ1aWxkKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgZm9yIChjb25zdCBkaXN0UGF0aCBvZiBkaXN0UGF0aHMpIHtcbiAgICAgICAgICBpZiAoIWV4aXN0c1N5bmMoZGlzdFBhdGgpKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCBjb250ZW50ID0gYXdhaXQgcmVhZEZpbGUoZGlzdFBhdGgsICd1dGYtOCcpO1xuICAgICAgICAgIGNvbnN0IG5ld0NvbnRlbnQgPSByZXBsYWNlQWxsKFxuICAgICAgICAgICAgY29udGVudCxcbiAgICAgICAgICAgIC8oPzxQcmVmaXg+XFxuKD86XFwvXFwvfFxcL1xcKikjIHNvdXJjZU1hcHBpbmdVUkw9ZGF0YTphcHBsaWNhdGlvblxcL2pzb247YmFzZTY0LCkoPzxTb3VyY2VNYXBCYXNlNjQ+Lis/KSg/PFN1ZmZpeD4kfFxcbnwgXFwqXFwvKSg/Oi58XFxuKSovZyxcbiAgICAgICAgICAgIChfLCBwcmVmaXgsIHNvdXJjZU1hcEJhc2U2NCwgc3VmZml4KTogc3RyaW5nID0+IGAke3ByZWZpeCArIGZpeFNvdXJjZU1hcChzb3VyY2VNYXBCYXNlNjQsIHBsdWdpbk5hbWUpICsgc3VmZml4LnRyaW0oKX1cXG4vKiBub3NvdXJjZW1hcCAqL2BcbiAgICAgICAgICApO1xuXG4gICAgICAgICAgaWYgKGNvbnRlbnQgIT09IG5ld0NvbnRlbnQpIHtcbiAgICAgICAgICAgIGF3YWl0IHdyaXRlRmlsZShkaXN0UGF0aCwgbmV3Q29udGVudCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG5cbi8qKlxuICogQ29udmVydHMgYSBnaXZlbiBmaWxlIHBhdGggdG8gYW4gT2JzaWRpYW4tc3BlY2lmaWMgVVJMLlxuICpcbiAqIEBwYXJhbSBwYXRoIC0gVGhlIG9yaWdpbmFsIGZpbGUgcGF0aC5cbiAqIEBwYXJhbSBwbHVnaW5OYW1lIC0gVGhlIG5hbWUgb2YgdGhlIE9ic2lkaWFuIHBsdWdpbi5cbiAqIEByZXR1cm5zIFRoZSBjb252ZXJ0ZWQgcGF0aCBhcyBhbiBPYnNpZGlhbi1zcGVjaWZpYyBVUkwuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRQYXRoVG9PYnNpZGlhblVybChwYXRoOiBzdHJpbmcsIHBsdWdpbk5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IGNvbnZlcnRlZFBhdGggPSByZXBsYWNlQWxsKHRvUG9zaXhQYXRoKHBhdGgpLCAvXig/OlxcLlxcLlxcLykrL2csICcnKTtcbiAgcmV0dXJuIGBhcHA6Ly9vYnNpZGlhbi5tZC9wbHVnaW46JHtwbHVnaW5OYW1lfS8ke2NvbnZlcnRlZFBhdGh9YDtcbn1cblxuLyoqXG4gKiBBZGp1c3RzIHRoZSBwYXRocyBpbiB0aGUgYmFzZTY0LWVuY29kZWQgc291cmNlIG1hcCB0byBiZSBjb21wYXRpYmxlIHdpdGggT2JzaWRpYW4ncyBVUkwgc2NoZW1lLlxuICpcbiAqIEBwYXJhbSBzb3VyY2VNYXBCYXNlNjQgLSBUaGUgYmFzZTY0LWVuY29kZWQgc291cmNlIG1hcCBjb250ZW50LlxuICogQHBhcmFtIHBsdWdpbk5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgT2JzaWRpYW4gcGx1Z2luLCB1c2VkIHRvIGNvbnN0cnVjdCB0aGUgT2JzaWRpYW4tc3BlY2lmaWMgVVJMcy5cbiAqIEByZXR1cm5zIEEgYmFzZTY0LWVuY29kZWQgc3RyaW5nIHdpdGggdGhlIGFkanVzdGVkIHNvdXJjZSBtYXAuXG4gKi9cbmZ1bmN0aW9uIGZpeFNvdXJjZU1hcChzb3VyY2VNYXBCYXNlNjQ6IHN0cmluZywgcGx1Z2luTmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgY29uc3Qgc291cmNlTWFwSnNvbiA9IEJ1ZmZlci5mcm9tKHNvdXJjZU1hcEJhc2U2NCwgJ2Jhc2U2NCcpLnRvU3RyaW5nKCd1dGYtOCcpO1xuICBjb25zdCBzb3VyY2VNYXAgPSBKU09OLnBhcnNlKHNvdXJjZU1hcEpzb24pIGFzIFBhcnRpYWw8U291cmNlTWFwPjtcbiAgc291cmNlTWFwLnNvdXJjZXMgPSAoc291cmNlTWFwLnNvdXJjZXMgPz8gW10pLm1hcCgocGF0aCkgPT4gY29udmVydFBhdGhUb09ic2lkaWFuVXJsKHBhdGgsIHBsdWdpbk5hbWUpKTtcbiAgcmV0dXJuIEJ1ZmZlci5mcm9tKEpTT04uc3RyaW5naWZ5KHNvdXJjZU1hcCkpLnRvU3RyaW5nKCdiYXNlNjQnKTtcbn1cblxuLyogdjggaWdub3JlIHN0b3AgKi9cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVlBLFNBQVMsa0JBQWtCO0FBQzNCO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBRVAsU0FBUyxtQkFBbUI7QUFDNUIsU0FBUyxrQkFBa0I7QUFlcEIsU0FBUyxvQkFBb0IsbUJBQTRCLFdBQXFCLFlBQTRCO0FBQy9HLFNBQU87QUFBQSxJQUNMLE1BQU07QUFBQSxJQUNOLE1BQU0sT0FBYTtBQUNqQixZQUFNLE1BQU0sWUFBWTtBQUN0QixZQUFJLG1CQUFtQjtBQUNyQjtBQUFBLFFBQ0Y7QUFFQSxtQkFBVyxZQUFZLFdBQVc7QUFDaEMsY0FBSSxDQUFDLFdBQVcsUUFBUSxHQUFHO0FBQ3pCO0FBQUEsVUFDRjtBQUVBLGdCQUFNLFVBQVUsTUFBTSxTQUFTLFVBQVUsT0FBTztBQUNoRCxnQkFBTSxhQUFhO0FBQUEsWUFDakI7QUFBQSxZQUNBO0FBQUEsWUFDQSxDQUFDLEdBQUcsUUFBUSxpQkFBaUIsV0FBbUIsR0FBRyxTQUFTLGFBQWEsaUJBQWlCLFVBQVUsSUFBSSxPQUFPLEtBQUssQ0FBQztBQUFBO0FBQUEsVUFDdkg7QUFFQSxjQUFJLFlBQVksWUFBWTtBQUMxQixrQkFBTSxVQUFVLFVBQVUsVUFBVTtBQUFBLFVBQ3RDO0FBQUEsUUFDRjtBQUFBLE1BQ0YsQ0FBQztBQUFBLElBQ0g7QUFBQSxFQUNGO0FBQ0Y7QUFTQSxTQUFTLHlCQUF5QixNQUFjLFlBQTRCO0FBQzFFLFFBQU0sZ0JBQWdCLFdBQVcsWUFBWSxJQUFJLEdBQUcsaUJBQWlCLEVBQUU7QUFDdkUsU0FBTyw0QkFBNEIsVUFBVSxJQUFJLGFBQWE7QUFDaEU7QUFTQSxTQUFTLGFBQWEsaUJBQXlCLFlBQTRCO0FBQ3pFLFFBQU0sZ0JBQWdCLE9BQU8sS0FBSyxpQkFBaUIsUUFBUSxFQUFFLFNBQVMsT0FBTztBQUM3RSxRQUFNLFlBQVksS0FBSyxNQUFNLGFBQWE7QUFDMUMsWUFBVSxXQUFXLFVBQVUsV0FBVyxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMseUJBQXlCLE1BQU0sVUFBVSxDQUFDO0FBQ3RHLFNBQU8sT0FBTyxLQUFLLEtBQUssVUFBVSxTQUFTLENBQUMsRUFBRSxTQUFTLFFBQVE7QUFDakU7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -21,22 +21,21 @@ if you want to view the source, please visit the github repository of this plugi
21
21
 
22
22
  import { context } from "esbuild";
23
23
  import sassPlugin_ from "esbuild-sass-plugin";
24
+ import { existsSync } from "node:fs";
25
+ import {
26
+ cp,
27
+ mkdir,
28
+ rm,
29
+ writeFile
30
+ } from "node:fs/promises";
31
+ import { builtinModules } from "node:module";
32
+ import process, { loadEnvFile } from "node:process";
24
33
  import { extractDefaultExportInterop } from "../../../object-utils.mjs";
25
34
  import { ObsidianPluginRepoPaths } from "../../../obsidian/plugin/obsidian-plugin-repo-paths.mjs";
26
35
  import { join } from "../../../path.mjs";
27
36
  import { ensureNonNullable } from "../../../type-guards.mjs";
28
37
  import { buildCompile } from "../../build.mjs";
29
38
  import { CliTaskResult } from "../../cli-utils.mjs";
30
- import {
31
- builtinModules,
32
- cp,
33
- existsSync,
34
- loadEnvFile,
35
- mkdir,
36
- process,
37
- rm,
38
- writeFile
39
- } from "../../node-modules.mjs";
40
39
  import { readPackageJson } from "../../npm.mjs";
41
40
  import { resolvePathFromRoot } from "../../root.mjs";
42
41
  import { copyToObsidianPluginsFolderPlugin } from "./copyToObsidianPluginsFolderPlugin.mjs";
@@ -171,4 +170,4 @@ export {
171
170
  dev,
172
171
  invokeEsbuild
173
172
  };
174
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.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\n/* v8 ignore start -- esbuild-based build pipeline with sass/svelte plugins and file watchers; requires a live esbuild context. */\n\nimport type {\n  BuildContext,\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\n// eslint-disable-next-line import-x/no-rename-default -- We need a temp variable to apply `extractDefaultExportInterop()` fix below.\nimport sassPlugin_ from 'esbuild-sass-plugin';\n\nimport { extractDefaultExportInterop } from '../../../object-utils.ts';\nimport { ObsidianPluginRepoPaths } from '../../../obsidian/plugin/obsidian-plugin-repo-paths.ts';\nimport { join } from '../../../path.ts';\nimport { ensureNonNullable } from '../../../type-guards.ts';\nimport { buildCompile } from '../../build.ts';\nimport { CliTaskResult } from '../../cli-utils.ts';\nimport {\n  builtinModules,\n  cp,\n  existsSync,\n  loadEnvFile,\n  mkdir,\n  process,\n  rm,\n  writeFile\n} from '../../node-modules.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 = extractDefaultExportInterop(sassPlugin_);\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 {@link buildObsidianPlugin}.\n */\nexport interface BuildObsidianPluginParams {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  readonly customEsbuildPlugins?: Plugin[];\n\n  /**\n   * Customizes the `esbuild` options.\n   */\n  readonly customizeEsbuildOptions?: (options: BuildOptions) => void;\n\n  /**\n   * A build mode, either `Development` or `Production`\n   */\n  readonly mode: BuildMode;\n\n  /**\n   * A folder for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_FOLDER` environment variable.\n   */\n  readonly obsidianConfigFolder?: string;\n}\n\n/**\n * Build parameters without the mode field, for use with {@link build} and {@link dev}.\n */\nexport interface BuildParams {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  readonly customEsbuildPlugins?: Plugin[];\n\n  /**\n   * Customizes the `esbuild` options.\n   */\n  readonly customizeEsbuildOptions?: (options: BuildOptions) => void;\n\n  /**\n   * A folder for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_FOLDER` environment variable.\n   */\n  readonly obsidianConfigFolder?: string;\n}\n\ninterface ObsidianPluginBuilderEnv {\n  OBSIDIAN_CONFIG_FOLDER: string;\n}\n\n/**\n * Builds the Obsidian plugin in production mode using esbuild.\n *\n * @param params - Optional build parameters (mode is set to Production automatically).\n * @returns A {@link Promise} that resolves when the build is complete.\n */\nexport async function build(params?: BuildParams): Promise<void> {\n  const result = await buildObsidianPlugin({ ...params, mode: BuildMode.Production });\n  result.throwOnFailure();\n}\n\n/**\n * Builds the Obsidian plugin based on the specified mode and configuration folder.\n *\n * @param params - 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(params: BuildObsidianPluginParams): Promise<CliTaskResult> {\n  await buildCompile();\n  const envPath = resolvePathFromRoot('.env');\n  if (envPath && existsSync(envPath)) {\n    loadEnvFile(envPath);\n  }\n  const obsidianPluginBuilderEnv = process.env as Partial<ObsidianPluginBuilderEnv>;\n\n  const obsidianConfigFolder = params.obsidianConfigFolder ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_FOLDER ?? '';\n  const isProductionBuild = params.mode === BuildMode.Production;\n\n  const distFolder = ensureNonNullable(\n    resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev),\n    '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 = ensureNonNullable(resolvePathFromRoot(fileName), `Could not determine the local file for ${fileName}`);\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      ensureNonNullable(\n        resolvePathFromRoot(join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs)),\n        'Could not determine the entry point for the plugin'\n      )\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    keepNames: true,\n    logLevel: 'info',\n    minify: isProductionBuild,\n    outfile: distPath,\n    platform: 'node',\n    plugins: [\n      customEsbuildOptionsPlugin(params.customizeEsbuildOptions?.bind(params)),\n      svelteWrapperPlugin(isProductionBuild),\n      sassPlugin({\n        sourceMap: !isProductionBuild\n      }),\n      renameCssPlugin(distFolder),\n      preprocessPlugin(),\n      fixEsmPlugin(),\n      fixSourceMapsPlugin(isProductionBuild, [distPath, cssPath], pluginName),\n      ...params.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 * Builds the Obsidian plugin in development mode using esbuild with watch.\n *\n * @param params - Optional build parameters (mode is set to Development automatically).\n * @returns A {@link Promise} that resolves when the dev build starts (keeps process alive for watch mode).\n */\nexport async function dev(params?: BuildParams): Promise<void> {\n  await buildObsidianPlugin({ ...params, mode: BuildMode.Development });\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\n/* v8 ignore stop */\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;AAgBA,SAAS,eAAe;AAExB,OAAO,iBAAiB;AAExB,SAAS,mCAAmC;AAC5C,SAAS,+BAA+B;AACxC,SAAS,YAAY;AACrB,SAAS,yBAAyB;AAClC,SAAS,oBAAoB;AAC7B,SAAS,qBAAqB;AAC9B;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,uBAAuB;AAChC,SAAS,2BAA2B;AACpC,SAAS,yCAAyC;AAClD,SAAS,kCAAkC;AAC3C,SAAS,oBAAoB;AAC7B,SAAS,2BAA2B;AACpC,SAAS,wBAAwB;AACjC,SAAS,uBAAuB;AAChC,SAAS,2BAA2B;AAEpC,MAAM,aAAa,4BAA4B,WAAW;AAKnD,IAAK,YAAL,kBAAKA,eAAL;AAEL,EAAAA,sBAAA;AAEA,EAAAA,sBAAA;AAJU,SAAAA;AAAA,GAAA;AAUL,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA;AA6DtB,eAAsB,MAAM,QAAqC;AAC/D,QAAM,SAAS,MAAM,oBAAoB,EAAE,GAAG,QAAQ,MAAM,mBAAqB,CAAC;AAClF,SAAO,eAAe;AACxB;AAQA,eAAsB,oBAAoB,QAA2D;AACnG,QAAM,aAAa;AACnB,QAAM,UAAU,oBAAoB,MAAM;AAC1C,MAAI,WAAW,WAAW,OAAO,GAAG;AAClC,gBAAY,OAAO;AAAA,EACrB;AACA,QAAM,2BAA2B,QAAQ;AAEzC,QAAM,uBAAuB,OAAO,wBAAwB,yBAAyB,0BAA0B;AAC/G,QAAM,oBAAoB,OAAO,SAAS;AAE1C,QAAM,aAAa;AAAA,IACjB,oBAAoB,oBAAoB,wBAAwB,YAAY,wBAAwB,OAAO;AAAA,IAC3G;AAAA,EACF;AAEA,MAAI,WAAW,UAAU,GAAG;AAC1B,UAAM,GAAG,YAAY,EAAE,WAAW,KAAK,CAAC;AAAA,EAC1C;AACA,QAAM,MAAM,YAAY,EAAE,WAAW,KAAK,CAAC;AAE3C,QAAM,gBAAgB;AAAA,IACpB,wBAAwB;AAAA,EAC1B;AACA,MAAI,CAAC,mBAAmB;AACtB,UAAM,UAAU,KAAK,YAAY,wBAAwB,SAAS,GAAG,IAAI,OAAO;AAAA,EAClF;AAEA,aAAW,YAAY,eAAe;AACpC,UAAM,YAAY,kBAAkB,oBAAoB,QAAQ,GAAG,0CAA0C,QAAQ,EAAE;AACvH,UAAM,WAAW,KAAK,YAAY,QAAQ;AAE1C,QAAI,WAAW,SAAS,GAAG;AACzB,YAAM,GAAG,WAAW,QAAQ;AAAA,IAC9B;AAAA,EACF;AAEA,QAAM,WAAW,KAAK,YAAY,wBAAwB,MAAM;AAChE,QAAM,UAAU,KAAK,YAAY,wBAAwB,SAAS;AAElE,QAAM,cAAc,MAAM,gBAAgB;AAC1C,QAAM,aAAa,YAAY,QAAQ;AAEvC,QAAM,eAA6B;AAAA,IACjC,QAAQ;AAAA,MACN,IAAI;AAAA,IACN;AAAA,IACA,QAAQ;AAAA,IACR,YAAY,CAAC,SAAS;AAAA,IACtB,aAAa;AAAA,MACX;AAAA,QACE,oBAAoB,KAAK,wBAAwB,KAAK,wBAAwB,MAAM,CAAC;AAAA,QACrF;AAAA,MACF;AAAA,IACF;AAAA,IACA,UAAU;AAAA,MACR;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL;AAAA,IACA,QAAQ;AAAA,IACR,WAAW;AAAA,IACX,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,SAAS;AAAA,IACT,UAAU;AAAA,IACV,SAAS;AAAA,MACP,2BAA2B,OAAO,yBAAyB,KAAK,MAAM,CAAC;AAAA,MACvE,oBAAoB,iBAAiB;AAAA,MACrC,WAAW;AAAA,QACT,WAAW,CAAC;AAAA,MACd,CAAC;AAAA,MACD,gBAAgB,UAAU;AAAA,MAC1B,iBAAiB;AAAA,MACjB,aAAa;AAAA,MACb,oBAAoB,mBAAmB,CAAC,UAAU,OAAO,GAAG,UAAU;AAAA,MACtE,GAAG,OAAO,wBAAwB,CAAC;AAAA,MACnC,kCAAkC,mBAAmB,YAAY,sBAAsB,UAAU;AAAA,IACnG;AAAA,IACA,WAAW,oBAAoB,QAAQ;AAAA,IACvC,QAAQ;AAAA,IACR,aAAa;AAAA,EACf;AAEA,QAAM,eAAe,MAAM,QAAQ,YAAY;AAC/C,SAAO,MAAM,cAAc,cAAc,iBAAiB;AAC5D;AAQA,eAAsB,IAAI,QAAqC;AAC7D,QAAM,oBAAoB,EAAE,GAAG,QAAQ,MAAM,oBAAsB,CAAC;AACtE;AASA,eAAsB,cAAc,cAA4B,mBAAoD;AAClH,MAAI,mBAAmB;AACrB,UAAM,SAAS,MAAM,aAAa,QAAQ;AAC1C,UAAM,YAAY,OAAO,OAAO,WAAW,KAAK,OAAO,SAAS,WAAW;AAC3E,WAAO,cAAc,QAAQ,SAAS;AAAA,EACxC;AACA,QAAM,aAAa,MAAM;AACzB,SAAO,cAAc,UAAU;AACjC;",
  "names": ["BuildMode"]
}

173
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/obsidian-plugin-builder.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\n/* v8 ignore start -- esbuild-based build pipeline with sass/svelte plugins and file watchers; requires a live esbuild context. */\n\nimport type {\n  BuildContext,\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\n// eslint-disable-next-line import-x/no-rename-default -- We need a temp variable to apply `extractDefaultExportInterop()` fix below.\nimport sassPlugin_ from 'esbuild-sass-plugin';\nimport { existsSync } from 'node:fs';\nimport {\n  cp,\n  mkdir,\n  rm,\n  writeFile\n} from 'node:fs/promises';\nimport { builtinModules } from 'node:module';\nimport process, { loadEnvFile } from 'node:process';\n\nimport { extractDefaultExportInterop } from '../../../object-utils.ts';\nimport { ObsidianPluginRepoPaths } from '../../../obsidian/plugin/obsidian-plugin-repo-paths.ts';\nimport { join } from '../../../path.ts';\nimport { ensureNonNullable } from '../../../type-guards.ts';\nimport { buildCompile } from '../../build.ts';\nimport { CliTaskResult } from '../../cli-utils.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 = extractDefaultExportInterop(sassPlugin_);\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 {@link buildObsidianPlugin}.\n */\nexport interface BuildObsidianPluginParams {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  readonly customEsbuildPlugins?: Plugin[];\n\n  /**\n   * Customizes the `esbuild` options.\n   */\n  readonly customizeEsbuildOptions?: (options: BuildOptions) => void;\n\n  /**\n   * A build mode, either `Development` or `Production`\n   */\n  readonly mode: BuildMode;\n\n  /**\n   * A folder for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_FOLDER` environment variable.\n   */\n  readonly obsidianConfigFolder?: string;\n}\n\n/**\n * Build parameters without the mode field, for use with {@link build} and {@link dev}.\n */\nexport interface BuildParams {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  readonly customEsbuildPlugins?: Plugin[];\n\n  /**\n   * Customizes the `esbuild` options.\n   */\n  readonly customizeEsbuildOptions?: (options: BuildOptions) => void;\n\n  /**\n   * A folder for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_FOLDER` environment variable.\n   */\n  readonly obsidianConfigFolder?: string;\n}\n\ninterface ObsidianPluginBuilderEnv {\n  OBSIDIAN_CONFIG_FOLDER: string;\n}\n\n/**\n * Builds the Obsidian plugin in production mode using esbuild.\n *\n * @param params - Optional build parameters (mode is set to Production automatically).\n * @returns A {@link Promise} that resolves when the build is complete.\n */\nexport async function build(params?: BuildParams): Promise<void> {\n  const result = await buildObsidianPlugin({ ...params, mode: BuildMode.Production });\n  result.throwOnFailure();\n}\n\n/**\n * Builds the Obsidian plugin based on the specified mode and configuration folder.\n *\n * @param params - 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(params: BuildObsidianPluginParams): Promise<CliTaskResult> {\n  await buildCompile();\n  const envPath = resolvePathFromRoot('.env');\n  if (envPath && existsSync(envPath)) {\n    loadEnvFile(envPath);\n  }\n  const obsidianPluginBuilderEnv = process.env as Partial<ObsidianPluginBuilderEnv>;\n\n  const obsidianConfigFolder = params.obsidianConfigFolder ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_FOLDER ?? '';\n  const isProductionBuild = params.mode === BuildMode.Production;\n\n  const distFolder = ensureNonNullable(\n    resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev),\n    '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 = ensureNonNullable(resolvePathFromRoot(fileName), `Could not determine the local file for ${fileName}`);\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      ensureNonNullable(\n        resolvePathFromRoot(join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs)),\n        'Could not determine the entry point for the plugin'\n      )\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    keepNames: true,\n    logLevel: 'info',\n    minify: isProductionBuild,\n    outfile: distPath,\n    platform: 'node',\n    plugins: [\n      customEsbuildOptionsPlugin(params.customizeEsbuildOptions?.bind(params)),\n      svelteWrapperPlugin(isProductionBuild),\n      sassPlugin({\n        sourceMap: !isProductionBuild\n      }),\n      renameCssPlugin(distFolder),\n      preprocessPlugin(),\n      fixEsmPlugin(),\n      fixSourceMapsPlugin(isProductionBuild, [distPath, cssPath], pluginName),\n      ...params.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 * Builds the Obsidian plugin in development mode using esbuild with watch.\n *\n * @param params - Optional build parameters (mode is set to Development automatically).\n * @returns A {@link Promise} that resolves when the dev build starts (keeps process alive for watch mode).\n */\nexport async function dev(params?: BuildParams): Promise<void> {\n  await buildObsidianPlugin({ ...params, mode: BuildMode.Development });\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\n/* v8 ignore stop */\n"],
  "mappings": "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",
  "names": ["BuildMode"]
}

@@ -19,6 +19,7 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
+ import { readFile } from "node:fs/promises";
22
23
  import {
23
24
  FunctionHandlingMode,
24
25
  toJson
@@ -27,7 +28,6 @@ import {
27
28
  makeValidVariableName,
28
29
  replaceAll
29
30
  } from "../../../string.mjs";
30
- import { readFile } from "../../node-modules.mjs";
31
31
  function preprocessPlugin(isEsm) {
32
32
  const replacements = isEsm ? {} : {
33
33
  [replaceAll("import(dot)meta(dot)url", "(dot)", ".")]: () => {
@@ -182,4 +182,4 @@ function initEsm() {
182
182
  export {
183
183
  preprocessPlugin
184
184
  };
185
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/preprocessPlugin.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a custom esbuild plugin that preprocesses JavaScript and TypeScript files.\n *\n * @remarks\n * We cannot use `.` instead of `(dot)` in the above description because the file itself is preprocessed with the same rule.\n */\n\n/* v8 ignore start -- esbuild plugin that preprocesses source files with import.meta.url shims and process polyfills; requires a live esbuild context. */\n\nimport type { Plugin } from 'esbuild';\n\nimport type { GenericObject } from '../../../type-guards.ts';\n\nimport {\n  FunctionHandlingMode,\n  toJson\n} from '../../../object-utils.ts';\nimport {\n  makeValidVariableName,\n  replaceAll\n} from '../../../string.ts';\nimport { readFile } from '../../node-modules.ts';\n\ninterface BrowserProcess extends Partial<NodeJS.Process> {\n  browser: boolean;\n}\n\ninterface EsmModule {\n  __esModule: boolean;\n  default: unknown;\n}\n\ninterface RequirePatched extends NodeJS.Require {\n  __isPatched: boolean;\n}\n\n/**\n * Creates an esbuild plugin that preprocesses JavaScript and TypeScript files.\n *\n * This plugin performs the following tasks:\n * - Replaces instances of `import(dot)meta(dot)url` with a Node.js-compatible `__filename` alternative.\n * - Modifies the `sourceMappingURL` comment to ensure compatibility with Obsidian's plugin system.\n * - Adds a basic `process` object to the global scope if `process` is referenced but not defined.\n *\n * @param isEsm - Whether the build is for an ESM format.\n * @returns An esbuild `Plugin` object that handles the preprocessing.\n */\nexport function preprocessPlugin(isEsm?: boolean): Plugin {\n  const replacements = isEsm\n    ? {}\n    : {\n      [replaceAll('import(dot)meta(dot)url', '(dot)', '.')]: (): string => {\n        if (typeof __filename === 'string') {\n          const localRequire = require;\n          const url = localRequire('node:url') as typeof import('node:url');\n          if (typeof url.pathToFileURL === 'function') {\n            return url.pathToFileURL(__filename).href;\n          }\n        }\n\n        if (typeof window !== 'undefined') {\n          return window.location.href;\n        }\n\n        // Fallback to an empty string if the environment is unknown\n        return '';\n      }\n    };\n\n  return {\n    name: 'preprocess',\n    setup(build): void {\n      build.initialOptions.define ??= {};\n\n      for (const key of Object.keys(replacements)) {\n        build.initialOptions.define[key] = `__${makeValidVariableName(key)}`;\n      }\n\n      build.initialOptions.banner ??= {};\n      build.initialOptions.banner['js'] ??= '';\n      build.initialOptions.banner['js'] += `\\n(${String(isEsm ? initEsm : initCjs)})();\\n`;\n\n      build.onLoad({ filter: /\\.(?:js|ts|cjs|mjs|cts|mts)$/ }, async (args) => {\n        let contents = await readFile(args.path, 'utf-8');\n\n        for (const [key, value] of Object.entries(replacements)) {\n          const variable = `__${makeValidVariableName(key)}`;\n          if (!contents.includes(key)) {\n            continue;\n          }\n          const valueStr = typeof value === 'function' ? `(${String(value)})()` : toJson(value, { functionHandlingMode: FunctionHandlingMode.Full });\n          if (contents.includes(`var ${variable}`)) {\n            continue;\n          }\n          contents = `var ${variable} = globalThis['${key}'] ?? ${valueStr};\\n${contents}`;\n        }\n\n        // HACK: The ${''} part is used to ensure Obsidian loads the plugin properly,\n        // Otherwise, it stops loading after the first line of the sourceMappingURL comment.\n        // eslint-disable-next-line no-template-curly-in-string -- It is intentional, the string looks like a template literal, but it is not.\n        contents = replaceAll(contents, /`\\r?\\n\\/\\/# sourceMappingURL/g, '`\\n//#${\\'\\'} sourceMappingURL');\n\n        return {\n          contents,\n          loader: 'ts'\n        };\n      });\n    }\n  };\n}\n\nfunction initCjs(): void {\n  const globalThisRecord = globalThis as GenericObject;\n  globalThisRecord['__name'] ??= name;\n  const originalRequire = require as (NodeJS.Require & Partial<RequirePatched> | undefined);\n  if (originalRequire && !originalRequire.__isPatched) {\n    // eslint-disable-next-line no-global-assign, no-implicit-globals -- We need to patch the `require()` function.\n    require = Object.assign(\n      (id: string) => requirePatched(id),\n      originalRequire,\n      {\n        __isPatched: true\n      }\n    ) as RequirePatched;\n  }\n\n  const newFuncs: Record<string, () => unknown> = {\n    __extractDefault() {\n      return extractDefault;\n    },\n    process() {\n      const browserProcess: BrowserProcess = {\n        browser: true,\n        cwd() {\n          return '/';\n        },\n        env: {},\n        platform: 'android'\n      };\n      return browserProcess;\n    }\n  };\n\n  for (const key of Object.keys(newFuncs)) {\n    globalThisRecord[key] ??= newFuncs[key]?.();\n  }\n\n  function name(obj: unknown): unknown {\n    return obj;\n  }\n\n  function extractDefault(module: Partial<EsmModule> | undefined): unknown {\n    return module && module.__esModule && 'default' in module ? module.default : module;\n  }\n\n  const OBSIDIAN_BUILT_IN_MODULE_NAMES = [\n    'obsidian',\n    '@codemirror/autocomplete',\n    '@codemirror/collab',\n    '@codemirror/commands',\n    '@codemirror/language',\n    '@codemirror/lint',\n    '@codemirror/search',\n    '@codemirror/state',\n    '@codemirror/text',\n    '@codemirror/view',\n    '@lezer/common',\n    '@lezer/lr',\n    '@lezer/highlight'\n  ];\n\n  const DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES = [\n    '@codemirror/closebrackets',\n    '@codemirror/comment',\n    '@codemirror/fold',\n    '@codemirror/gutter',\n    '@codemirror/highlight',\n    '@codemirror/history',\n    '@codemirror/matchbrackets',\n    '@codemirror/panel',\n    '@codemirror/rangeset',\n    '@codemirror/rectangular-selection',\n    '@codemirror/stream-parser',\n    '@codemirror/tooltip'\n  ];\n\n  function requirePatched(id: string): unknown {\n    if (OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id) || DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id)) {\n      return originalRequire?.(id);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-deprecated, @typescript-eslint/no-unnecessary-condition -- We need access to app here which might not be available yet.\n    if (globalThis?.app?.isMobile) {\n      if (id === 'process' || id === 'node:process') {\n        console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Fake process object is returned instead.`);\n        return globalThis.process;\n      }\n    } else {\n      const module = originalRequire?.(id) as (Partial<EsmModule> | undefined);\n      if (module) {\n        return extractDefault(module);\n      }\n    }\n\n    console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Empty object is returned instead.`);\n    return {};\n  }\n}\n\nfunction initEsm(): void {\n  if ((globalThis.process as NodeJS.Process | undefined)) {\n    return;\n  }\n\n  const browserProcess: BrowserProcess = {\n    browser: true,\n    cwd() {\n      return '/';\n    },\n    env: {},\n    platform: 'android'\n  };\n  globalThis.process = browserProcess as NodeJS.Process;\n}\n\n/* v8 ignore stop */\n"],
  "mappings": "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",
  "names": []
}

185
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../../src/script-utils/bundlers/esbuild-impl/preprocessPlugin.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * This module defines a custom esbuild plugin that preprocesses JavaScript and TypeScript files.\n *\n * @remarks\n * We cannot use `.` instead of `(dot)` in the above description because the file itself is preprocessed with the same rule.\n */\n\n/* v8 ignore start -- esbuild plugin that preprocesses source files with import.meta.url shims and process polyfills; requires a live esbuild context. */\n\nimport type { Plugin } from 'esbuild';\nimport type { pathToFileURL } from 'node:url';\n\nimport { readFile } from 'node:fs/promises';\n\nimport type { GenericObject } from '../../../type-guards.ts';\n\nimport {\n  FunctionHandlingMode,\n  toJson\n} from '../../../object-utils.ts';\nimport {\n  makeValidVariableName,\n  replaceAll\n} from '../../../string.ts';\n\ninterface BrowserProcess extends Partial<NodeJS.Process> {\n  browser: boolean;\n}\n\ninterface EsmModule {\n  __esModule: boolean;\n  default: unknown;\n}\n\ninterface RequirePatched extends NodeJS.Require {\n  __isPatched: boolean;\n}\n\n/**\n * Creates an esbuild plugin that preprocesses JavaScript and TypeScript files.\n *\n * This plugin performs the following tasks:\n * - Replaces instances of `import(dot)meta(dot)url` with a Node.js-compatible `__filename` alternative.\n * - Modifies the `sourceMappingURL` comment to ensure compatibility with Obsidian's plugin system.\n * - Adds a basic `process` object to the global scope if `process` is referenced but not defined.\n *\n * @param isEsm - Whether the build is for an ESM format.\n * @returns An esbuild `Plugin` object that handles the preprocessing.\n */\nexport function preprocessPlugin(isEsm?: boolean): Plugin {\n  const replacements = isEsm\n    ? {}\n    : {\n      [replaceAll('import(dot)meta(dot)url', '(dot)', '.')]: (): string => {\n        if (typeof __filename === 'string') {\n          const localRequire = require;\n          const url = localRequire('node:url') as { pathToFileURL: typeof pathToFileURL };\n          if (typeof url.pathToFileURL === 'function') {\n            return url.pathToFileURL(__filename).href;\n          }\n        }\n\n        if (typeof window !== 'undefined') {\n          return window.location.href;\n        }\n\n        // Fallback to an empty string if the environment is unknown\n        return '';\n      }\n    };\n\n  return {\n    name: 'preprocess',\n    setup(build): void {\n      build.initialOptions.define ??= {};\n\n      for (const key of Object.keys(replacements)) {\n        build.initialOptions.define[key] = `__${makeValidVariableName(key)}`;\n      }\n\n      build.initialOptions.banner ??= {};\n      build.initialOptions.banner['js'] ??= '';\n      build.initialOptions.banner['js'] += `\\n(${String(isEsm ? initEsm : initCjs)})();\\n`;\n\n      build.onLoad({ filter: /\\.(?:js|ts|cjs|mjs|cts|mts)$/ }, async (args) => {\n        let contents = await readFile(args.path, 'utf-8');\n\n        for (const [key, value] of Object.entries(replacements)) {\n          const variable = `__${makeValidVariableName(key)}`;\n          if (!contents.includes(key)) {\n            continue;\n          }\n          const valueStr = typeof value === 'function' ? `(${String(value)})()` : toJson(value, { functionHandlingMode: FunctionHandlingMode.Full });\n          if (contents.includes(`var ${variable}`)) {\n            continue;\n          }\n          contents = `var ${variable} = globalThis['${key}'] ?? ${valueStr};\\n${contents}`;\n        }\n\n        // HACK: The ${''} part is used to ensure Obsidian loads the plugin properly,\n        // Otherwise, it stops loading after the first line of the sourceMappingURL comment.\n        // eslint-disable-next-line no-template-curly-in-string -- It is intentional, the string looks like a template literal, but it is not.\n        contents = replaceAll(contents, /`\\r?\\n\\/\\/# sourceMappingURL/g, '`\\n//#${\\'\\'} sourceMappingURL');\n\n        return {\n          contents,\n          loader: 'ts'\n        };\n      });\n    }\n  };\n}\n\nfunction initCjs(): void {\n  const globalThisRecord = globalThis as GenericObject;\n  globalThisRecord['__name'] ??= name;\n  const originalRequire = require as (NodeJS.Require & Partial<RequirePatched> | undefined);\n  if (originalRequire && !originalRequire.__isPatched) {\n    // eslint-disable-next-line no-global-assign, no-implicit-globals -- We need to patch the `require()` function.\n    require = Object.assign(\n      (id: string) => requirePatched(id),\n      originalRequire,\n      {\n        __isPatched: true\n      }\n    ) as RequirePatched;\n  }\n\n  const newFuncs: Record<string, () => unknown> = {\n    __extractDefault() {\n      return extractDefault;\n    },\n    process() {\n      const browserProcess: BrowserProcess = {\n        browser: true,\n        cwd() {\n          return '/';\n        },\n        env: {},\n        platform: 'android'\n      };\n      return browserProcess;\n    }\n  };\n\n  for (const key of Object.keys(newFuncs)) {\n    globalThisRecord[key] ??= newFuncs[key]?.();\n  }\n\n  function name(obj: unknown): unknown {\n    return obj;\n  }\n\n  function extractDefault(module: Partial<EsmModule> | undefined): unknown {\n    return module && module.__esModule && 'default' in module ? module.default : module;\n  }\n\n  const OBSIDIAN_BUILT_IN_MODULE_NAMES = [\n    'obsidian',\n    '@codemirror/autocomplete',\n    '@codemirror/collab',\n    '@codemirror/commands',\n    '@codemirror/language',\n    '@codemirror/lint',\n    '@codemirror/search',\n    '@codemirror/state',\n    '@codemirror/text',\n    '@codemirror/view',\n    '@lezer/common',\n    '@lezer/lr',\n    '@lezer/highlight'\n  ];\n\n  const DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES = [\n    '@codemirror/closebrackets',\n    '@codemirror/comment',\n    '@codemirror/fold',\n    '@codemirror/gutter',\n    '@codemirror/highlight',\n    '@codemirror/history',\n    '@codemirror/matchbrackets',\n    '@codemirror/panel',\n    '@codemirror/rangeset',\n    '@codemirror/rectangular-selection',\n    '@codemirror/stream-parser',\n    '@codemirror/tooltip'\n  ];\n\n  function requirePatched(id: string): unknown {\n    if (OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id) || DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id)) {\n      return originalRequire?.(id);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-deprecated, @typescript-eslint/no-unnecessary-condition -- We need access to app here which might not be available yet.\n    if (globalThis?.app?.isMobile) {\n      if (id === 'process' || id === 'node:process') {\n        console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Fake process object is returned instead.`);\n        return globalThis.process;\n      }\n    } else {\n      const module = originalRequire?.(id) as (Partial<EsmModule> | undefined);\n      if (module) {\n        return extractDefault(module);\n      }\n    }\n\n    console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Empty object is returned instead.`);\n    return {};\n  }\n}\n\nfunction initEsm(): void {\n  if ((globalThis.process as NodeJS.Process | undefined)) {\n    return;\n  }\n\n  const browserProcess: BrowserProcess = {\n    browser: true,\n    cwd() {\n      return '/';\n    },\n    env: {},\n    platform: 'android'\n  };\n  globalThis.process = browserProcess as NodeJS.Process;\n}\n\n/* v8 ignore stop */\n"],
  "mappings": "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",
  "names": []
}

@@ -19,12 +19,10 @@ if you want to view the source, please visit the github repository of this plugi
19
19
  globalThis.process = browserProcess;
20
20
  })();
21
21
 
22
+ import { existsSync } from "node:fs";
23
+ import { rename } from "node:fs/promises";
22
24
  import { ObsidianPluginRepoPaths } from "../../../obsidian/plugin/obsidian-plugin-repo-paths.mjs";
23
25
  import { join } from "../../../path.mjs";
24
- import {
25
- existsSync,
26
- rename
27
- } from "../../node-modules.mjs";
28
26
  function renameCssPlugin(distFolder) {
29
27
  return {
30
28
  name: "rename-css",
@@ -42,4 +40,4 @@ function renameCssPlugin(distFolder) {
42
40
  export {
43
41
  renameCssPlugin
44
42
  };
45
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLWltcGwvcmVuYW1lQ3NzUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFJlbmFtZSBDU1MgZXNidWlsZCBwbHVnaW4uXG4gKi9cblxuLyogdjggaWdub3JlIHN0YXJ0IC0tIGVzYnVpbGQgcGx1Z2luIHRoYXQgcmVuYW1lcyBDU1Mgb3V0cHV0IGZpbGVzOyByZXF1aXJlcyBhIGxpdmUgZXNidWlsZCBjb250ZXh0LiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ2VzYnVpbGQnO1xuXG5pbXBvcnQgeyBPYnNpZGlhblBsdWdpblJlcG9QYXRocyB9IGZyb20gJy4uLy4uLy4uL29ic2lkaWFuL3BsdWdpbi9vYnNpZGlhbi1wbHVnaW4tcmVwby1wYXRocy50cyc7XG5pbXBvcnQgeyBqb2luIH0gZnJvbSAnLi4vLi4vLi4vcGF0aC50cyc7XG5pbXBvcnQge1xuICBleGlzdHNTeW5jLFxuICByZW5hbWVcbn0gZnJvbSAnLi4vLi4vbm9kZS1tb2R1bGVzLnRzJztcblxuLyoqXG4gKiBQbHVnaW4gdGhhdCByZW5hbWVzIHRoZSBDU1MgZmlsZSB0byB0aGUgY29ycmVjdCBuYW1lLlxuICpcbiAqIEBwYXJhbSBkaXN0Rm9sZGVyIC0gVGhlIGZvbGRlciB0byByZW5hbWUgdGhlIENTUyBmaWxlIGluLlxuICogQHJldHVybnMgVGhlIHBsdWdpbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlbmFtZUNzc1BsdWdpbihkaXN0Rm9sZGVyOiBzdHJpbmcpOiBQbHVnaW4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdyZW5hbWUtY3NzJyxcbiAgICBzZXR1cChidWlsZCk6IHZvaWQge1xuICAgICAgYnVpbGQub25FbmQoYXN5bmMgKCkgPT4ge1xuICAgICAgICBjb25zdCBtYWluQ3NzUGF0aCA9IGpvaW4oZGlzdEZvbGRlciwgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMuTWFpbkNzcyk7XG4gICAgICAgIGNvbnN0IHN0eWxlc0Nzc1BhdGggPSBqb2luKGRpc3RGb2xkZXIsIE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzLlN0eWxlc0Nzcyk7XG4gICAgICAgIGlmIChleGlzdHNTeW5jKG1haW5Dc3NQYXRoKSkge1xuICAgICAgICAgIGF3YWl0IHJlbmFtZShtYWluQ3NzUGF0aCwgc3R5bGVzQ3NzUGF0aCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cbiAgfTtcbn1cblxuLyogdjggaWdub3JlIHN0b3AgKi9cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVVBLFNBQVMsK0JBQStCO0FBQ3hDLFNBQVMsWUFBWTtBQUNyQjtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsT0FDSztBQVFBLFNBQVMsZ0JBQWdCLFlBQTRCO0FBQzFELFNBQU87QUFBQSxJQUNMLE1BQU07QUFBQSxJQUNOLE1BQU0sT0FBYTtBQUNqQixZQUFNLE1BQU0sWUFBWTtBQUN0QixjQUFNLGNBQWMsS0FBSyxZQUFZLHdCQUF3QixPQUFPO0FBQ3BFLGNBQU0sZ0JBQWdCLEtBQUssWUFBWSx3QkFBd0IsU0FBUztBQUN4RSxZQUFJLFdBQVcsV0FBVyxHQUFHO0FBQzNCLGdCQUFNLE9BQU8sYUFBYSxhQUFhO0FBQUEsUUFDekM7QUFBQSxNQUNGLENBQUM7QUFBQSxJQUNIO0FBQUEsRUFDRjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
43
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLWltcGwvcmVuYW1lQ3NzUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFJlbmFtZSBDU1MgZXNidWlsZCBwbHVnaW4uXG4gKi9cblxuLyogdjggaWdub3JlIHN0YXJ0IC0tIGVzYnVpbGQgcGx1Z2luIHRoYXQgcmVuYW1lcyBDU1Mgb3V0cHV0IGZpbGVzOyByZXF1aXJlcyBhIGxpdmUgZXNidWlsZCBjb250ZXh0LiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ2VzYnVpbGQnO1xuXG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSAnbm9kZTpmcyc7XG5pbXBvcnQgeyByZW5hbWUgfSBmcm9tICdub2RlOmZzL3Byb21pc2VzJztcblxuaW1wb3J0IHsgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMgfSBmcm9tICcuLi8uLi8uLi9vYnNpZGlhbi9wbHVnaW4vb2JzaWRpYW4tcGx1Z2luLXJlcG8tcGF0aHMudHMnO1xuaW1wb3J0IHsgam9pbiB9IGZyb20gJy4uLy4uLy4uL3BhdGgudHMnO1xuXG4vKipcbiAqIFBsdWdpbiB0aGF0IHJlbmFtZXMgdGhlIENTUyBmaWxlIHRvIHRoZSBjb3JyZWN0IG5hbWUuXG4gKlxuICogQHBhcmFtIGRpc3RGb2xkZXIgLSBUaGUgZm9sZGVyIHRvIHJlbmFtZSB0aGUgQ1NTIGZpbGUgaW4uXG4gKiBAcmV0dXJucyBUaGUgcGx1Z2luLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVuYW1lQ3NzUGx1Z2luKGRpc3RGb2xkZXI6IHN0cmluZyk6IFBsdWdpbiB7XG4gIHJldHVybiB7XG4gICAgbmFtZTogJ3JlbmFtZS1jc3MnLFxuICAgIHNldHVwKGJ1aWxkKTogdm9pZCB7XG4gICAgICBidWlsZC5vbkVuZChhc3luYyAoKSA9PiB7XG4gICAgICAgIGNvbnN0IG1haW5Dc3NQYXRoID0gam9pbihkaXN0Rm9sZGVyLCBPYnNpZGlhblBsdWdpblJlcG9QYXRocy5NYWluQ3NzKTtcbiAgICAgICAgY29uc3Qgc3R5bGVzQ3NzUGF0aCA9IGpvaW4oZGlzdEZvbGRlciwgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMuU3R5bGVzQ3NzKTtcbiAgICAgICAgaWYgKGV4aXN0c1N5bmMobWFpbkNzc1BhdGgpKSB7XG4gICAgICAgICAgYXdhaXQgcmVuYW1lKG1haW5Dc3NQYXRoLCBzdHlsZXNDc3NQYXRoKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuICB9O1xufVxuXG4vKiB2OCBpZ25vcmUgc3RvcCAqL1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBVUEsU0FBUyxrQkFBa0I7QUFDM0IsU0FBUyxjQUFjO0FBRXZCLFNBQVMsK0JBQStCO0FBQ3hDLFNBQVMsWUFBWTtBQVFkLFNBQVMsZ0JBQWdCLFlBQTRCO0FBQzFELFNBQU87QUFBQSxJQUNMLE1BQU07QUFBQSxJQUNOLE1BQU0sT0FBYTtBQUNqQixZQUFNLE1BQU0sWUFBWTtBQUN0QixjQUFNLGNBQWMsS0FBSyxZQUFZLHdCQUF3QixPQUFPO0FBQ3BFLGNBQU0sZ0JBQWdCLEtBQUssWUFBWSx3QkFBd0IsU0FBUztBQUN4RSxZQUFJLFdBQVcsV0FBVyxHQUFHO0FBQzNCLGdCQUFNLE9BQU8sYUFBYSxhQUFhO0FBQUEsUUFDekM7QUFBQSxNQUNGLENBQUM7QUFBQSxJQUNIO0FBQUEsRUFDRjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -35,4 +35,4 @@ export {
35
35
  dev,
36
36
  invokeEsbuild
37
37
  };
38
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFB1YmxpYyBBUEkgZm9yIHRoZSBlc2J1aWxkIGJ1bmRsZXIuIFJlLWV4cG9ydHMgdGhlIG1haW4gYnVpbGQgZnVuY3Rpb25zLlxuICovXG5cbmV4cG9ydCB7XG4gIGJhbm5lcixcbiAgYnVpbGQsXG4gIEJ1aWxkTW9kZSxcbiAgYnVpbGRPYnNpZGlhblBsdWdpbixcbiAgZGV2LFxuICBpbnZva2VFc2J1aWxkXG59IGZyb20gJy4vZXNidWlsZC1pbXBsL29ic2lkaWFuLXBsdWdpbi1idWlsZGVyLnRzJztcblxuLyoqXG4gKiBSZS1leHBvcnRlZCB0eXBlcyBmb3IgdGhlIGVzYnVpbGQgYnVuZGxlci5cbiAqL1xuZXhwb3J0IHR5cGUge1xuICBCdWlsZE9ic2lkaWFuUGx1Z2luUGFyYW1zLFxuICBCdWlsZFBhcmFtc1xufSBmcm9tICcuL2VzYnVpbGQtaW1wbC9vYnNpZGlhbi1wbHVnaW4tYnVpbGRlci50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFNQTtBQUFBLEVBQ0U7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLE9BQ0s7IiwKICAibmFtZXMiOiBbXQp9Cg==
38
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL3NjcmlwdC11dGlscy9idW5kbGVycy9lc2J1aWxkLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFB1YmxpYyBBUEkgZm9yIHRoZSBlc2J1aWxkIGJ1bmRsZXIuIFJlLWV4cG9ydHMgdGhlIG1haW4gYnVpbGQgZnVuY3Rpb25zLlxuICovXG5cbi8qIHY4IGlnbm9yZSBzdGFydCAtLSBSZS1leHBvcnQgbW9kdWxlOyBjb3ZlcmFnZSBpcyB0cmFja2VkIGluIHRoZSBpbXBsZW1lbnRhdGlvbiBmaWxlcy4gKi9cblxuZXhwb3J0IHtcbiAgYmFubmVyLFxuICBidWlsZCxcbiAgQnVpbGRNb2RlLFxuICBidWlsZE9ic2lkaWFuUGx1Z2luLFxuICBkZXYsXG4gIGludm9rZUVzYnVpbGRcbn0gZnJvbSAnLi9lc2J1aWxkLWltcGwvb2JzaWRpYW4tcGx1Z2luLWJ1aWxkZXIudHMnO1xuXG4vKipcbiAqIFJlLWV4cG9ydGVkIHR5cGVzIGZvciB0aGUgZXNidWlsZCBidW5kbGVyLlxuICovXG5leHBvcnQgdHlwZSB7XG4gIEJ1aWxkT2JzaWRpYW5QbHVnaW5QYXJhbXMsXG4gIEJ1aWxkUGFyYW1zXG59IGZyb20gJy4vZXNidWlsZC1pbXBsL29ic2lkaWFuLXBsdWdpbi1idWlsZGVyLnRzJztcblxuLyogdjggaWdub3JlIHN0b3AgKi9cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVFBO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsT0FDSzsiLAogICJuYW1lcyI6IFtdCn0K