obsidian-dev-utils 13.7.0 → 13.7.2

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.
@@ -33,7 +33,12 @@ module.exports = __toCommonJS(NpmPublish_exports);
33
33
  var import_dotenv = require('dotenv');
34
34
  var import_NodeModules = require('./NodeModules.cjs');
35
35
  var import_Root = require('./Root.cjs');
36
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
36
+ var __process = globalThis["process"] ?? {
37
+ "browser": true,
38
+ "cwd": "[[Function0]]",
39
+ "env": {},
40
+ "platform": "android"
41
+ };
37
42
  async function publish(isBeta) {
38
43
  (0, import_dotenv.config)();
39
44
  const npmEnv = import_NodeModules.process.env;
@@ -45,4 +50,4 @@ async function publish(isBeta) {
45
50
  0 && (module.exports = {
46
51
  publish
47
52
  });
48
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvTnBtUHVibGlzaC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XCJicm93c2VyXCI6dHJ1ZSxcImN3ZFwiOlwiW1tGdW5jdGlvbjowXV1cIixcImVudlwiOnt9LFwicGxhdGZvcm1cIjpcImFuZHJvaWRcIn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBOcG1QdWJsaXNoXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgTlBNIHB1Ymxpc2guXG4gKi9cblxuaW1wb3J0IHsgY29uZmlnIH0gZnJvbSAnZG90ZW52JztcblxuaW1wb3J0IHsgcHJvY2VzcyB9IGZyb20gJy4vTm9kZU1vZHVsZXMudHMnO1xuaW1wb3J0IHsgZXhlY0Zyb21Sb290IH0gZnJvbSAnLi9Sb290LnRzJztcblxuaW50ZXJmYWNlIE5wbUVudiB7XG4gIE5QTV9UT0tFTjogc3RyaW5nO1xufVxuXG4vKipcbiAqIFB1Ymxpc2ggdG8gTlBNLlxuICogQHBhcmFtIGlzQmV0YSAtIFdoZXRoZXIgdG8gcHVibGlzaCB0byB0aGUgYmV0YSBOUE0gcmVnaXN0cnkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwdWJsaXNoKGlzQmV0YT86IGJvb2xlYW4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uZmlnKCk7XG4gIGNvbnN0IG5wbUVudiA9IHByb2Nlc3MuZW52IGFzIFBhcnRpYWw8TnBtRW52PjtcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnBtJywgJ2NvbmZpZycsICdzZXQnLCBgLy9yZWdpc3RyeS5ucG1qcy5vcmcvOl9hdXRoVG9rZW49JHtucG1FbnYuTlBNX1RPS0VOID8/ICcnfWBdKTtcblxuICBjb25zdCB0YWcgPSBpc0JldGEgPyAnYmV0YScgOiAnbGF0ZXN0JztcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnBtJywgJ3B1Ymxpc2gnLCAnLS10YWcnLCB0YWddKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFNQSxvQkFBdUI7QUFFdkIseUJBQXdCO0FBQ3hCLGtCQUE2QjtBQVQ3QixJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUssRUFBQyxXQUFVLE1BQUssT0FBTSxrQkFBaUIsT0FBTSxDQUFDLEdBQUUsWUFBVyxVQUFTO0FBbUI3RyxlQUFzQixRQUFRLFFBQWlDO0FBQzdELDRCQUFPO0FBQ1AsUUFBTSxTQUFTLDJCQUFRO0FBQ3ZCLFlBQU0sMEJBQWEsQ0FBQyxPQUFPLFVBQVUsT0FBTyxvQ0FBb0MsT0FBTyxhQUFhLEVBQUUsRUFBRSxDQUFDO0FBRXpHLFFBQU0sTUFBTSxTQUFTLFNBQVM7QUFDOUIsWUFBTSwwQkFBYSxDQUFDLE9BQU8sV0FBVyxTQUFTLEdBQUcsQ0FBQztBQUNyRDsiLAogICJuYW1lcyI6IFtdCn0K
53
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvTnBtUHVibGlzaC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XG4gIFwiYnJvd3NlclwiOiB0cnVlLFxuICBcImN3ZFwiOiBcIltbRnVuY3Rpb24wXV1cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBOcG1QdWJsaXNoXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgTlBNIHB1Ymxpc2guXG4gKi9cblxuaW1wb3J0IHsgY29uZmlnIH0gZnJvbSAnZG90ZW52JztcblxuaW1wb3J0IHsgcHJvY2VzcyB9IGZyb20gJy4vTm9kZU1vZHVsZXMudHMnO1xuaW1wb3J0IHsgZXhlY0Zyb21Sb290IH0gZnJvbSAnLi9Sb290LnRzJztcblxuaW50ZXJmYWNlIE5wbUVudiB7XG4gIE5QTV9UT0tFTjogc3RyaW5nO1xufVxuXG4vKipcbiAqIFB1Ymxpc2ggdG8gTlBNLlxuICogQHBhcmFtIGlzQmV0YSAtIFdoZXRoZXIgdG8gcHVibGlzaCB0byB0aGUgYmV0YSBOUE0gcmVnaXN0cnkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwdWJsaXNoKGlzQmV0YT86IGJvb2xlYW4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uZmlnKCk7XG4gIGNvbnN0IG5wbUVudiA9IHByb2Nlc3MuZW52IGFzIFBhcnRpYWw8TnBtRW52PjtcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnBtJywgJ2NvbmZpZycsICdzZXQnLCBgLy9yZWdpc3RyeS5ucG1qcy5vcmcvOl9hdXRoVG9rZW49JHtucG1FbnYuTlBNX1RPS0VOID8/ICcnfWBdKTtcblxuICBjb25zdCB0YWcgPSBpc0JldGEgPyAnYmV0YScgOiAnbGF0ZXN0JztcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnBtJywgJ3B1Ymxpc2gnLCAnLS10YWcnLCB0YWddKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFXQSxvQkFBdUI7QUFFdkIseUJBQXdCO0FBQ3hCLGtCQUE2QjtBQWQ3QixJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxXQUFXO0FBQUEsRUFDWCxPQUFPO0FBQUEsRUFDUCxPQUFPLENBQUM7QUFBQSxFQUNSLFlBQVk7QUFDZDtBQW1CQSxlQUFzQixRQUFRLFFBQWlDO0FBQzdELDRCQUFPO0FBQ1AsUUFBTSxTQUFTLDJCQUFRO0FBQ3ZCLFlBQU0sMEJBQWEsQ0FBQyxPQUFPLFVBQVUsT0FBTyxvQ0FBb0MsT0FBTyxhQUFhLEVBQUUsRUFBRSxDQUFDO0FBRXpHLFFBQU0sTUFBTSxTQUFTLFNBQVM7QUFDOUIsWUFBTSwwQkFBYSxDQUFDLE9BQU8sV0FBVyxTQUFTLEdBQUcsQ0FBQztBQUNyRDsiLAogICJuYW1lcyI6IFtdCn0K
@@ -30,7 +30,12 @@ __export(ObsidianDevUtilsRepoPaths_exports, {
30
30
  ObsidianDevUtilsRepoPaths: () => ObsidianDevUtilsRepoPaths
31
31
  });
32
32
  module.exports = __toCommonJS(ObsidianDevUtilsRepoPaths_exports);
33
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
33
+ var __process = globalThis["process"] ?? {
34
+ "browser": true,
35
+ "cwd": "[[Function0]]",
36
+ "env": {},
37
+ "platform": "android"
38
+ };
34
39
  var ObsidianDevUtilsRepoPaths = /* @__PURE__ */ ((ObsidianDevUtilsRepoPaths2) => {
35
40
  ObsidianDevUtilsRepoPaths2["Any"] = "*";
36
41
  ObsidianDevUtilsRepoPaths2["AnyCjs"] = "*.cjs";
@@ -63,4 +68,4 @@ var ObsidianDevUtilsRepoPaths = /* @__PURE__ */ ((ObsidianDevUtilsRepoPaths2) =>
63
68
  0 && (module.exports = {
64
69
  ObsidianDevUtilsRepoPaths
65
70
  });
66
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XCJicm93c2VyXCI6dHJ1ZSxcImN3ZFwiOlwiW1tGdW5jdGlvbjowXV1cIixcImVudlwiOnt9LFwicGxhdGZvcm1cIjpcImFuZHJvaWRcIn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzXG4gKiBUaGlzIG1vZHVsZSBkZWZpbmVzIGFuIGVudW1lcmF0aW9uIG9mIGNvbW1vbiBmaWxlIHBhdGhzIGFuZCBwYXR0ZXJucyB1c2VkIGluIHRoZSBPYnNpZGlhbiBkZXZlbG9wbWVudCB1dGlsaXRpZXMgcmVwb3NpdG9yeS5cbiAqIFRoZXNlIHBhdGhzIGFyZSB1c2VkIHRocm91Z2hvdXQgdGhlIGJ1aWxkIHByb2Nlc3MgYW5kIG90aGVyIHV0aWxpdGllcywgZW5zdXJpbmcgY29uc2lzdGVuY3kgYW5kIHJlZHVjaW5nIHRoZSBsaWtlbGlob29kXG4gKiBvZiBlcnJvcnMgZHVlIHRvIGhhcmRjb2RlZCBzdHJpbmdzLlxuICovXG5cbmV4cG9ydCBlbnVtIE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMge1xuICAvKiogTWF0Y2hlcyBhbnkgZmlsZSBvciBkaXJlY3RvcnkgKGAqYCkuICovXG4gIEFueSA9ICcqJyxcblxuICAvKiogTWF0Y2hlcyBhbnkgYC5janNgIGZpbGUgKGAqLmNqc2ApLiAqL1xuICBBbnlDanMgPSAnKi5janMnLFxuXG4gIC8qKiBNYXRjaGVzIGFueSBUeXBlU2NyaXB0IGRlY2xhcmF0aW9uIGZpbGUgKGAqLmQudHNgKS4gKi9cbiAgQW55RHRzID0gJyouZC50cycsXG5cbiAgLyoqIE1hdGNoZXMgYW55IHBhdGggcmVjdXJzaXZlbHkgKGAqKmApLiAqL1xuICBBbnlQYXRoID0gJyoqJyxcblxuICAvKiogTWF0Y2hlcyBhbnkgVHlwZVNjcmlwdCBmaWxlIChgKi50c2ApLiAqL1xuICBBbnlUcyA9ICcqLnRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBDSEFOR0VMT0cubWRgIGZpbGUuICovXG4gIENoYW5nZWxvZ01kID0gJ0NIQU5HRUxPRy5tZCcsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBkaXN0cmlidXRpb24gKGBkaXN0YCkgZGlyZWN0b3J5LiAqL1xuICBEaXN0ID0gJ2Rpc3QnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgZW1wdHkgRVNMaW50IGNvbmZpZyBpbiBDb21tb25KUyBmb3JtYXQgd2l0aGluIHRoZSBgZGlzdGAgZGlyZWN0b3J5LiAqL1xuICBEaXN0RXNsaW50Q29uZmlnRW1wdHlDanMgPSAnZGlzdC9lc2xpbnQuY29uZmlnLmVtcHR5LmNqcycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgbGliYCBkaXJlY3Rvcnkgd2l0aGluIHRoZSBgZGlzdGAgZGlyZWN0b3J5LiAqL1xuICBEaXN0TGliID0gJ2Rpc3QvbGliJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBfZGVwZW5kZW5jaWVzLmNqc2AgZmlsZSB3aXRoaW4gdGhlIGBsaWJgIGRpcmVjdG9yeSBpbiB0aGUgYGRpc3RgIGRpcmVjdG9yeS4gKi9cbiAgRGlzdExpYkRlcGVuZGVuY2llc0NqcyA9ICcuL2Rpc3QvbGliL19kZXBlbmRlbmNpZXMuY2pzJyxcblxuICAvKiogVGhlIGAuZC50c2AgZmlsZSBleHRlbnNpb24uICovXG4gIER0c0V4dGVuc2lvbiA9ICcuZC50cycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgaW5kZXguY2pzYCBmaWxlLiAqL1xuICBJbmRleENqcyA9ICdpbmRleC5janMnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYGluZGV4LmQudHNgIGZpbGUuICovXG4gIEluZGV4RHRzID0gJ2luZGV4LmQudHMnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYGluZGV4LnRzYCBmaWxlLiAqL1xuICBJbmRleFRzID0gJ2luZGV4LnRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBMSUNFTlNFYCBmaWxlLiAqL1xuICBMaWNlbnNlID0gJ0xJQ0VOU0UnLFxuXG4gIC8qKlxuICAgKiBUaGUgcGF0aCB0byB0aGUgYG5vZGVfbW9kdWxlc2AgZGlyZWN0b3J5LlxuICAgKi9cbiAgTm9kZU1vZHVsZXMgPSAnbm9kZV9tb2R1bGVzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBwYWNrYWdlLmpzb25gIGZpbGUuICovXG4gIFBhY2thZ2VKc29uID0gJ3BhY2thZ2UuanNvbicsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgUkVBRE1FLm1kYCBmaWxlLiAqL1xuICBSZWFkbWVNZCA9ICdSRUFETUUubWQnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYHNjcmlwdHNgIGRpcmVjdG9yeS4gKi9cbiAgU2NyaXB0cyA9ICdzY3JpcHRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBzcmNgIGRpcmVjdG9yeS4gKi9cbiAgU3JjID0gJ3NyYycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgX2RlcGVuZGVuY2llcy50c2AgZmlsZSB3aXRoaW4gdGhlIGBzcmNgIGRpcmVjdG9yeS4gKi9cbiAgU3JjRGVwZW5kZW5jaWVzVHMgPSAnLi9zcmMvX2RlcGVuZGVuY2llcy50cycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgc3JjYCBkaXJlY3RvcnkuICovXG4gIFNyY09ic2lkaWFuVHlwZXNEYXRhdmlldyA9ICdzcmMvb2JzaWRpYW4vQHR5cGVzL0RhdGF2aWV3JyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBzdGF0aWNgIGRpcmVjdG9yeS4gKi9cbiAgU3RhdGljID0gJ3N0YXRpYycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgdHNjb25maWcuanNvbmAgZmlsZS4gKi9cbiAgVHNDb25maWdKc29uID0gJ3RzY29uZmlnLmpzb24nLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYEB0eXBlc2AgZGlyZWN0b3J5LCB0eXBpY2FsbHkgdXNlZCBmb3IgVHlwZVNjcmlwdCB0eXBlIGRlY2xhcmF0aW9ucy4gKi9cbiAgVHlwZXMgPSAnQHR5cGVzJ1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSyxFQUFDLFdBQVUsTUFBSyxPQUFNLGtCQUFpQixPQUFNLENBQUMsR0FBRSxZQUFXLFVBQVM7QUFRdEcsSUFBSyw0QkFBTCxrQkFBS0EsK0JBQUw7QUFFTCxFQUFBQSwyQkFBQSxTQUFNO0FBR04sRUFBQUEsMkJBQUEsWUFBUztBQUdULEVBQUFBLDJCQUFBLFlBQVM7QUFHVCxFQUFBQSwyQkFBQSxhQUFVO0FBR1YsRUFBQUEsMkJBQUEsV0FBUTtBQUdSLEVBQUFBLDJCQUFBLGlCQUFjO0FBR2QsRUFBQUEsMkJBQUEsVUFBTztBQUdQLEVBQUFBLDJCQUFBLDhCQUEyQjtBQUczQixFQUFBQSwyQkFBQSxhQUFVO0FBR1YsRUFBQUEsMkJBQUEsNEJBQXlCO0FBR3pCLEVBQUFBLDJCQUFBLGtCQUFlO0FBR2YsRUFBQUEsMkJBQUEsY0FBVztBQUdYLEVBQUFBLDJCQUFBLGNBQVc7QUFHWCxFQUFBQSwyQkFBQSxhQUFVO0FBR1YsRUFBQUEsMkJBQUEsYUFBVTtBQUtWLEVBQUFBLDJCQUFBLGlCQUFjO0FBR2QsRUFBQUEsMkJBQUEsaUJBQWM7QUFHZCxFQUFBQSwyQkFBQSxjQUFXO0FBR1gsRUFBQUEsMkJBQUEsYUFBVTtBQUdWLEVBQUFBLDJCQUFBLFNBQU07QUFHTixFQUFBQSwyQkFBQSx1QkFBb0I7QUFHcEIsRUFBQUEsMkJBQUEsOEJBQTJCO0FBRzNCLEVBQUFBLDJCQUFBLFlBQVM7QUFHVCxFQUFBQSwyQkFBQSxrQkFBZTtBQUdmLEVBQUFBLDJCQUFBLFdBQVE7QUE1RUUsU0FBQUE7QUFBQSxHQUFBOyIsCiAgIm5hbWVzIjogWyJPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIl0KfQo=
71
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XG4gIFwiYnJvd3NlclwiOiB0cnVlLFxuICBcImN3ZFwiOiBcIltbRnVuY3Rpb24wXV1cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzXG4gKiBUaGlzIG1vZHVsZSBkZWZpbmVzIGFuIGVudW1lcmF0aW9uIG9mIGNvbW1vbiBmaWxlIHBhdGhzIGFuZCBwYXR0ZXJucyB1c2VkIGluIHRoZSBPYnNpZGlhbiBkZXZlbG9wbWVudCB1dGlsaXRpZXMgcmVwb3NpdG9yeS5cbiAqIFRoZXNlIHBhdGhzIGFyZSB1c2VkIHRocm91Z2hvdXQgdGhlIGJ1aWxkIHByb2Nlc3MgYW5kIG90aGVyIHV0aWxpdGllcywgZW5zdXJpbmcgY29uc2lzdGVuY3kgYW5kIHJlZHVjaW5nIHRoZSBsaWtlbGlob29kXG4gKiBvZiBlcnJvcnMgZHVlIHRvIGhhcmRjb2RlZCBzdHJpbmdzLlxuICovXG5cbmV4cG9ydCBlbnVtIE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMge1xuICAvKiogTWF0Y2hlcyBhbnkgZmlsZSBvciBkaXJlY3RvcnkgKGAqYCkuICovXG4gIEFueSA9ICcqJyxcblxuICAvKiogTWF0Y2hlcyBhbnkgYC5janNgIGZpbGUgKGAqLmNqc2ApLiAqL1xuICBBbnlDanMgPSAnKi5janMnLFxuXG4gIC8qKiBNYXRjaGVzIGFueSBUeXBlU2NyaXB0IGRlY2xhcmF0aW9uIGZpbGUgKGAqLmQudHNgKS4gKi9cbiAgQW55RHRzID0gJyouZC50cycsXG5cbiAgLyoqIE1hdGNoZXMgYW55IHBhdGggcmVjdXJzaXZlbHkgKGAqKmApLiAqL1xuICBBbnlQYXRoID0gJyoqJyxcblxuICAvKiogTWF0Y2hlcyBhbnkgVHlwZVNjcmlwdCBmaWxlIChgKi50c2ApLiAqL1xuICBBbnlUcyA9ICcqLnRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBDSEFOR0VMT0cubWRgIGZpbGUuICovXG4gIENoYW5nZWxvZ01kID0gJ0NIQU5HRUxPRy5tZCcsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBkaXN0cmlidXRpb24gKGBkaXN0YCkgZGlyZWN0b3J5LiAqL1xuICBEaXN0ID0gJ2Rpc3QnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgZW1wdHkgRVNMaW50IGNvbmZpZyBpbiBDb21tb25KUyBmb3JtYXQgd2l0aGluIHRoZSBgZGlzdGAgZGlyZWN0b3J5LiAqL1xuICBEaXN0RXNsaW50Q29uZmlnRW1wdHlDanMgPSAnZGlzdC9lc2xpbnQuY29uZmlnLmVtcHR5LmNqcycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgbGliYCBkaXJlY3Rvcnkgd2l0aGluIHRoZSBgZGlzdGAgZGlyZWN0b3J5LiAqL1xuICBEaXN0TGliID0gJ2Rpc3QvbGliJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBfZGVwZW5kZW5jaWVzLmNqc2AgZmlsZSB3aXRoaW4gdGhlIGBsaWJgIGRpcmVjdG9yeSBpbiB0aGUgYGRpc3RgIGRpcmVjdG9yeS4gKi9cbiAgRGlzdExpYkRlcGVuZGVuY2llc0NqcyA9ICcuL2Rpc3QvbGliL19kZXBlbmRlbmNpZXMuY2pzJyxcblxuICAvKiogVGhlIGAuZC50c2AgZmlsZSBleHRlbnNpb24uICovXG4gIER0c0V4dGVuc2lvbiA9ICcuZC50cycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgaW5kZXguY2pzYCBmaWxlLiAqL1xuICBJbmRleENqcyA9ICdpbmRleC5janMnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYGluZGV4LmQudHNgIGZpbGUuICovXG4gIEluZGV4RHRzID0gJ2luZGV4LmQudHMnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYGluZGV4LnRzYCBmaWxlLiAqL1xuICBJbmRleFRzID0gJ2luZGV4LnRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBMSUNFTlNFYCBmaWxlLiAqL1xuICBMaWNlbnNlID0gJ0xJQ0VOU0UnLFxuXG4gIC8qKlxuICAgKiBUaGUgcGF0aCB0byB0aGUgYG5vZGVfbW9kdWxlc2AgZGlyZWN0b3J5LlxuICAgKi9cbiAgTm9kZU1vZHVsZXMgPSAnbm9kZV9tb2R1bGVzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBwYWNrYWdlLmpzb25gIGZpbGUuICovXG4gIFBhY2thZ2VKc29uID0gJ3BhY2thZ2UuanNvbicsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgUkVBRE1FLm1kYCBmaWxlLiAqL1xuICBSZWFkbWVNZCA9ICdSRUFETUUubWQnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYHNjcmlwdHNgIGRpcmVjdG9yeS4gKi9cbiAgU2NyaXB0cyA9ICdzY3JpcHRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBzcmNgIGRpcmVjdG9yeS4gKi9cbiAgU3JjID0gJ3NyYycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgX2RlcGVuZGVuY2llcy50c2AgZmlsZSB3aXRoaW4gdGhlIGBzcmNgIGRpcmVjdG9yeS4gKi9cbiAgU3JjRGVwZW5kZW5jaWVzVHMgPSAnLi9zcmMvX2RlcGVuZGVuY2llcy50cycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgc3JjYCBkaXJlY3RvcnkuICovXG4gIFNyY09ic2lkaWFuVHlwZXNEYXRhdmlldyA9ICdzcmMvb2JzaWRpYW4vQHR5cGVzL0RhdGF2aWV3JyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBzdGF0aWNgIGRpcmVjdG9yeS4gKi9cbiAgU3RhdGljID0gJ3N0YXRpYycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgdHNjb25maWcuanNvbmAgZmlsZS4gKi9cbiAgVHNDb25maWdKc29uID0gJ3RzY29uZmlnLmpzb24nLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYEB0eXBlc2AgZGlyZWN0b3J5LCB0eXBpY2FsbHkgdXNlZCBmb3IgVHlwZVNjcmlwdCB0eXBlIGRlY2xhcmF0aW9ucy4gKi9cbiAgVHlwZXMgPSAnQHR5cGVzJ1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSztBQUFBLEVBQ3ZDLFdBQVc7QUFBQSxFQUNYLE9BQU87QUFBQSxFQUNQLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBUU8sSUFBSyw0QkFBTCxrQkFBS0EsK0JBQUw7QUFFTCxFQUFBQSwyQkFBQSxTQUFNO0FBR04sRUFBQUEsMkJBQUEsWUFBUztBQUdULEVBQUFBLDJCQUFBLFlBQVM7QUFHVCxFQUFBQSwyQkFBQSxhQUFVO0FBR1YsRUFBQUEsMkJBQUEsV0FBUTtBQUdSLEVBQUFBLDJCQUFBLGlCQUFjO0FBR2QsRUFBQUEsMkJBQUEsVUFBTztBQUdQLEVBQUFBLDJCQUFBLDhCQUEyQjtBQUczQixFQUFBQSwyQkFBQSxhQUFVO0FBR1YsRUFBQUEsMkJBQUEsNEJBQXlCO0FBR3pCLEVBQUFBLDJCQUFBLGtCQUFlO0FBR2YsRUFBQUEsMkJBQUEsY0FBVztBQUdYLEVBQUFBLDJCQUFBLGNBQVc7QUFHWCxFQUFBQSwyQkFBQSxhQUFVO0FBR1YsRUFBQUEsMkJBQUEsYUFBVTtBQUtWLEVBQUFBLDJCQUFBLGlCQUFjO0FBR2QsRUFBQUEsMkJBQUEsaUJBQWM7QUFHZCxFQUFBQSwyQkFBQSxjQUFXO0FBR1gsRUFBQUEsMkJBQUEsYUFBVTtBQUdWLEVBQUFBLDJCQUFBLFNBQU07QUFHTixFQUFBQSwyQkFBQSx1QkFBb0I7QUFHcEIsRUFBQUEsMkJBQUEsOEJBQTJCO0FBRzNCLEVBQUFBLDJCQUFBLFlBQVM7QUFHVCxFQUFBQSwyQkFBQSxrQkFBZTtBQUdmLEVBQUFBLDJCQUFBLFdBQVE7QUE1RUUsU0FBQUE7QUFBQSxHQUFBOyIsCiAgIm5hbWVzIjogWyJPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIl0KfQo=
@@ -37,7 +37,12 @@ var import_Path = require('../Path.cjs');
37
37
  var import_Exec = require('./Exec.cjs');
38
38
  var import_NodeModules = require('./NodeModules.cjs');
39
39
  var import_ObsidianDevUtilsRepoPaths = require('./ObsidianDevUtilsRepoPaths.cjs');
40
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
40
+ var __process = globalThis["process"] ?? {
41
+ "browser": true,
42
+ "cwd": "[[Function0]]",
43
+ "env": {},
44
+ "platform": "android"
45
+ };
41
46
  function execFromRoot(command, options = {}) {
42
47
  let root = getRootDir(options.cwd);
43
48
  if (!root) {
@@ -83,4 +88,4 @@ function toRelativeFromRoot(path, cwd) {
83
88
  resolvePathFromRoot,
84
89
  toRelativeFromRoot
85
90
  });
86
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/Root.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\"browser\":true,\"cwd\":\"[[Function:0]]\",\"env\":{},\"platform\":\"android\"};\n/**\n * @packageDocumentation Root\n * Contains utility functions for executing commands from the root directory of a project,\n * resolving paths relative to the root.\n */\n\nimport type {\n  ExecOption,\n  ExecResult\n} from './Exec.ts';\n\nimport {\n  dirname,\n  join,\n  relative,\n  resolve,\n  toPosixPath\n} from '../Path.ts';\nimport { exec } from './Exec.ts';\nimport { existsSync } from './NodeModules.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\n\n/**\n * Executes a command from the root directory of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A Promise that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function execFromRoot(command: string | string[], options?: { withDetails?: false } & ExecOption): Promise<string>;\n\n/**\n * Executes a command from the root directory of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A Promise that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: { withDetails: true } & ExecOption): Promise<ExecResult>;\n\n/**\n * Executes a command from the root directory of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A Promise that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: ExecOption = {}): Promise<ExecResult | string> {\n  let root = getRootDir(options.cwd);\n\n  if (!root) {\n    if (options.shouldFailIfCalledFromOutsideRoot ?? true) {\n      throw new Error('Could not find root directory');\n    }\n\n    root = options.cwd ?? process.cwd();\n  }\n\n  if (options.shouldIncludeDetails) {\n    return exec(command, { ...options, cwd: root, shouldIncludeDetails: true });\n  }\n\n  return exec(command, { ...options, cwd: root, shouldIncludeDetails: false });\n}\n\n/**\n * Retrieves the root directory of the project.\n *\n * @param cwd - The current working directory to resolve from.\n * @returns The path to the root directory.\n * @throws If the root directory cannot be found.\n */\nexport function getRootDir(cwd?: string): null | string {\n  let currentDir = toPosixPath(cwd ?? process.cwd());\n  while (currentDir !== '.' && currentDir !== '/') {\n    if (existsSync(join(currentDir, ObsidianDevUtilsRepoPaths.PackageJson))) {\n      return toPosixPath(currentDir);\n    }\n    currentDir = dirname(currentDir);\n  }\n\n  return null;\n}\n\n/**\n * Resolves a path relative to the root directory of the project.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working directory to resolve from.\n * @returns The resolved absolute path.\n */\nexport function resolvePathFromRoot(path: string, cwd?: string): null | string {\n  const rootDir = getRootDir(cwd);\n  if (!rootDir) {\n    return null;\n  }\n\n  return resolve(rootDir, path);\n}\n\n/**\n * Converts an absolute path to a relative path from the root directory of the project.\n *\n * @param path - The absolute path to convert.\n * @param cwd - The current working directory to resolve from.\n * @returns The relative path from the root directory.\n */\nexport function toRelativeFromRoot(path: string, cwd?: string): null | string {\n  const rootDir = getRootDir(cwd);\n  if (!rootDir) {\n    return null;\n  }\n\n  path = toPosixPath(path);\n  return relative(rootDir, path);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,kBAMO;AACP,kBAAqB;AACrB,yBAA2B;AAC3B,uCAA0C;AArB1C,IAAI,YAAY,WAAW,SAAS,KAAK,EAAC,WAAU,MAAK,OAAM,kBAAiB,OAAM,CAAC,GAAE,YAAW,UAAS;AA8DtG,SAAS,aAAa,SAA4B,UAAsB,CAAC,GAAiC;AAC/G,MAAI,OAAO,WAAW,QAAQ,GAAG;AAEjC,MAAI,CAAC,MAAM;AACT,QAAI,QAAQ,qCAAqC,MAAM;AACrD,YAAM,IAAI,MAAM,+BAA+B;AAAA,IACjD;AAEA,WAAO,QAAQ,OAAO,UAAQ,IAAI;AAAA,EACpC;AAEA,MAAI,QAAQ,sBAAsB;AAChC,eAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,KAAK,CAAC;AAAA,EAC5E;AAEA,aAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,MAAM,CAAC;AAC7E;AASO,SAAS,WAAW,KAA6B;AACtD,MAAI,iBAAa,yBAAY,OAAO,UAAQ,IAAI,CAAC;AACjD,SAAO,eAAe,OAAO,eAAe,KAAK;AAC/C,YAAI,mCAAW,kBAAK,YAAY,2DAA0B,WAAW,CAAC,GAAG;AACvE,iBAAO,yBAAY,UAAU;AAAA,IAC/B;AACA,qBAAa,qBAAQ,UAAU;AAAA,EACjC;AAEA,SAAO;AACT;AASO,SAAS,oBAAoB,MAAc,KAA6B;AAC7E,QAAM,UAAU,WAAW,GAAG;AAC9B,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AAEA,aAAO,qBAAQ,SAAS,IAAI;AAC9B;AASO,SAAS,mBAAmB,MAAc,KAA6B;AAC5E,QAAM,UAAU,WAAW,GAAG;AAC9B,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AAEA,aAAO,yBAAY,IAAI;AACvB,aAAO,sBAAS,SAAS,IAAI;AAC/B;",
  "names": []
}

91
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/Root.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": \"[[Function0]]\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Root\n * Contains utility functions for executing commands from the root directory of a project,\n * resolving paths relative to the root.\n */\n\nimport type {\n  ExecOption,\n  ExecResult\n} from './Exec.ts';\n\nimport {\n  dirname,\n  join,\n  relative,\n  resolve,\n  toPosixPath\n} from '../Path.ts';\nimport { exec } from './Exec.ts';\nimport { existsSync } from './NodeModules.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\n\n/**\n * Executes a command from the root directory of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A Promise that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function execFromRoot(command: string | string[], options?: { withDetails?: false } & ExecOption): Promise<string>;\n\n/**\n * Executes a command from the root directory of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A Promise that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: { withDetails: true } & ExecOption): Promise<ExecResult>;\n\n/**\n * Executes a command from the root directory of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A Promise that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: ExecOption = {}): Promise<ExecResult | string> {\n  let root = getRootDir(options.cwd);\n\n  if (!root) {\n    if (options.shouldFailIfCalledFromOutsideRoot ?? true) {\n      throw new Error('Could not find root directory');\n    }\n\n    root = options.cwd ?? process.cwd();\n  }\n\n  if (options.shouldIncludeDetails) {\n    return exec(command, { ...options, cwd: root, shouldIncludeDetails: true });\n  }\n\n  return exec(command, { ...options, cwd: root, shouldIncludeDetails: false });\n}\n\n/**\n * Retrieves the root directory of the project.\n *\n * @param cwd - The current working directory to resolve from.\n * @returns The path to the root directory.\n * @throws If the root directory cannot be found.\n */\nexport function getRootDir(cwd?: string): null | string {\n  let currentDir = toPosixPath(cwd ?? process.cwd());\n  while (currentDir !== '.' && currentDir !== '/') {\n    if (existsSync(join(currentDir, ObsidianDevUtilsRepoPaths.PackageJson))) {\n      return toPosixPath(currentDir);\n    }\n    currentDir = dirname(currentDir);\n  }\n\n  return null;\n}\n\n/**\n * Resolves a path relative to the root directory of the project.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working directory to resolve from.\n * @returns The resolved absolute path.\n */\nexport function resolvePathFromRoot(path: string, cwd?: string): null | string {\n  const rootDir = getRootDir(cwd);\n  if (!rootDir) {\n    return null;\n  }\n\n  return resolve(rootDir, path);\n}\n\n/**\n * Converts an absolute path to a relative path from the root directory of the project.\n *\n * @param path - The absolute path to convert.\n * @param cwd - The current working directory to resolve from.\n * @returns The relative path from the root directory.\n */\nexport function toRelativeFromRoot(path: string, cwd?: string): null | string {\n  const rootDir = getRootDir(cwd);\n  if (!rootDir) {\n    return null;\n  }\n\n  path = toPosixPath(path);\n  return relative(rootDir, path);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAiBA,kBAMO;AACP,kBAAqB;AACrB,yBAA2B;AAC3B,uCAA0C;AA1B1C,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,WAAW;AAAA,EACX,OAAO;AAAA,EACP,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AA8DO,SAAS,aAAa,SAA4B,UAAsB,CAAC,GAAiC;AAC/G,MAAI,OAAO,WAAW,QAAQ,GAAG;AAEjC,MAAI,CAAC,MAAM;AACT,QAAI,QAAQ,qCAAqC,MAAM;AACrD,YAAM,IAAI,MAAM,+BAA+B;AAAA,IACjD;AAEA,WAAO,QAAQ,OAAO,UAAQ,IAAI;AAAA,EACpC;AAEA,MAAI,QAAQ,sBAAsB;AAChC,eAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,KAAK,CAAC;AAAA,EAC5E;AAEA,aAAO,kBAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,MAAM,CAAC;AAC7E;AASO,SAAS,WAAW,KAA6B;AACtD,MAAI,iBAAa,yBAAY,OAAO,UAAQ,IAAI,CAAC;AACjD,SAAO,eAAe,OAAO,eAAe,KAAK;AAC/C,YAAI,mCAAW,kBAAK,YAAY,2DAA0B,WAAW,CAAC,GAAG;AACvE,iBAAO,yBAAY,UAAU;AAAA,IAC/B;AACA,qBAAa,qBAAQ,UAAU;AAAA,EACjC;AAEA,SAAO;AACT;AASO,SAAS,oBAAoB,MAAc,KAA6B;AAC7E,QAAM,UAAU,WAAW,GAAG;AAC9B,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AAEA,aAAO,qBAAQ,SAAS,IAAI;AAC9B;AASO,SAAS,mBAAmB,MAAc,KAA6B;AAC5E,QAAM,UAAU,WAAW,GAAG;AAC9B,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AAEA,aAAO,yBAAY,IAAI;AACvB,aAAO,sBAAS,SAAS,IAAI;AAC/B;",
  "names": []
}

@@ -38,7 +38,12 @@ var import_Fs = require('./Fs.cjs');
38
38
  var import_NodeModules = require('./NodeModules.cjs');
39
39
  var import_ObsidianDevUtilsRepoPaths = require('./ObsidianDevUtilsRepoPaths.cjs');
40
40
  var import_Root = require('./Root.cjs');
41
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
41
+ var __process = globalThis["process"] ?? {
42
+ "browser": true,
43
+ "cwd": "[[Function0]]",
44
+ "env": {},
45
+ "platform": "android"
46
+ };
42
47
  async function buildClean() {
43
48
  await (0, import_NodeModules.rm)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.Dist, { force: true, recursive: true });
44
49
  }
@@ -60,4 +65,4 @@ async function buildValidate() {
60
65
  buildStatic,
61
66
  buildValidate
62
67
  });
63
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvYnVpbGQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzWydwcm9jZXNzJ10gPz8ge1wiYnJvd3NlclwiOnRydWUsXCJjd2RcIjpcIltbRnVuY3Rpb246MF1dXCIsXCJlbnZcIjp7fSxcInBsYXRmb3JtXCI6XCJhbmRyb2lkXCJ9O1xuLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gYnVpbGRcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIHV0aWxpdHkgZnVuY3Rpb25zIHRvIGhhbmRsZSB0aGUgYnVpbGQgcHJvY2VzcyBmb3Igc3RhdGljIGFzc2V0cyBhbmQgY2xlYW5pbmdcbiAqIHRoZSBidWlsZCBvdXRwdXQgZGlyZWN0b3J5LiBJdCBpbmNsdWRlcyBmdW5jdGlvbnMgdG8gY29weSBzdGF0aWMgZmlsZXMgdG8gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnlcbiAqIGFuZCB0byByZW1vdmUgdGhlIGV4aXN0aW5nIGJ1aWxkIG91dHB1dC5cbiAqL1xuXG5pbXBvcnQgeyBqb2luIH0gZnJvbSAnLi4vUGF0aC50cyc7XG5pbXBvcnQgeyB0cmltU3RhcnQgfSBmcm9tICcuLi9TdHJpbmcudHMnO1xuaW1wb3J0IHsgcmVhZGRpclBvc2l4IH0gZnJvbSAnLi9Gcy50cyc7XG5pbXBvcnQge1xuICBjcCxcbiAgcm1cbn0gZnJvbSAnLi9Ob2RlTW9kdWxlcy50cyc7XG5pbXBvcnQgeyBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIH0gZnJvbSAnLi9PYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7IGV4ZWNGcm9tUm9vdCB9IGZyb20gJy4vUm9vdC50cyc7XG5cbi8qKlxuICogUmVtb3ZlcyB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeSBhbmQgaXRzIGNvbnRlbnRzLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gZGVsZXRlcyB0aGUgZW50aXJlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkgdG8gZW5zdXJlIGEgY2xlYW4gYnVpbGQgZW52aXJvbm1lbnQuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgZGlyZWN0b3J5IGhhcyBiZWVuIHJlbW92ZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENsZWFuKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBybShPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRpc3QsIHsgZm9yY2U6IHRydWUsIHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbn1cblxuLyoqXG4gKiBDb3BpZXMgYWxsIHN0YXRpYyBmaWxlcyBmcm9tIHRoZSBzdGF0aWMgYXNzZXRzIGRpcmVjdG9yeSB0byB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHJlY3Vyc2l2ZWx5IHJlYWRzIHRoZSBjb250ZW50cyBvZiB0aGUgc3RhdGljIGFzc2V0cyBkaXJlY3RvcnkgYW5kIGNvcGllc1xuICogZWFjaCBmaWxlIHRvIHRoZSBjb3JyZXNwb25kaW5nIHBhdGggaW4gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiBhbGwgZmlsZXMgaGF2ZSBiZWVuIGNvcGllZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkU3RhdGljKCk6IFByb21pc2U8dm9pZD4ge1xuICBmb3IgKGNvbnN0IGRpcmVudCBvZiBhd2FpdCByZWFkZGlyUG9zaXgoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWMsIHsgcmVjdXJzaXZlOiB0cnVlLCB3aXRoRmlsZVR5cGVzOiB0cnVlIH0pKSB7XG4gICAgaWYgKCFkaXJlbnQuaXNGaWxlKCkpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IHBhdGggPSB0cmltU3RhcnQoam9pbihkaXJlbnQucGFyZW50UGF0aCwgZGlyZW50Lm5hbWUpLCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYyArICcvJyk7XG4gICAgYXdhaXQgY3Aoam9pbihPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYywgcGF0aCksIGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBwYXRoKSk7XG4gIH1cbn1cblxuLyoqXG4gKiBWYWxpZGF0ZXMgaWYgdGhlIFR5cGVTY3JpcHQgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZFZhbGlkYXRlKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBleGVjRnJvbVJvb3QoWyd0c2MnLCAnLS1idWlsZCcsICctLWZvcmNlJ10pO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFRQSxrQkFBcUI7QUFDckIsb0JBQTBCO0FBQzFCLGdCQUE2QjtBQUM3Qix5QkFHTztBQUNQLHVDQUEwQztBQUMxQyxrQkFBNkI7QUFoQjdCLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSyxFQUFDLFdBQVUsTUFBSyxPQUFNLGtCQUFpQixPQUFNLENBQUMsR0FBRSxZQUFXLFVBQVM7QUF5QjdHLGVBQXNCLGFBQTRCO0FBQ2hELFlBQU0sdUJBQUcsMkRBQTBCLE1BQU0sRUFBRSxPQUFPLE1BQU0sV0FBVyxLQUFLLENBQUM7QUFDM0U7QUFVQSxlQUFzQixjQUE2QjtBQUNqRCxhQUFXLFVBQVUsVUFBTSx3QkFBYSwyREFBMEIsUUFBUSxFQUFFLFdBQVcsTUFBTSxlQUFlLEtBQUssQ0FBQyxHQUFHO0FBQ25ILFFBQUksQ0FBQyxPQUFPLE9BQU8sR0FBRztBQUNwQjtBQUFBLElBQ0Y7QUFFQSxVQUFNLFdBQU8sNkJBQVUsa0JBQUssT0FBTyxZQUFZLE9BQU8sSUFBSSxHQUFHLDJEQUEwQixTQUFTLEdBQUc7QUFDbkcsY0FBTSwyQkFBRyxrQkFBSywyREFBMEIsUUFBUSxJQUFJLE9BQUcsa0JBQUssMkRBQTBCLE1BQU0sSUFBSSxDQUFDO0FBQUEsRUFDbkc7QUFDRjtBQU9BLGVBQXNCLGdCQUErQjtBQUNuRCxZQUFNLDBCQUFhLENBQUMsT0FBTyxXQUFXLFNBQVMsQ0FBQztBQUNsRDsiLAogICJuYW1lcyI6IFtdCn0K
68
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvYnVpbGQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzWydwcm9jZXNzJ10gPz8ge1xuICBcImJyb3dzZXJcIjogdHJ1ZSxcbiAgXCJjd2RcIjogXCJbW0Z1bmN0aW9uMF1dXCIsXG4gIFwiZW52XCI6IHt9LFxuICBcInBsYXRmb3JtXCI6IFwiYW5kcm9pZFwiXG59O1xuLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gYnVpbGRcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIHV0aWxpdHkgZnVuY3Rpb25zIHRvIGhhbmRsZSB0aGUgYnVpbGQgcHJvY2VzcyBmb3Igc3RhdGljIGFzc2V0cyBhbmQgY2xlYW5pbmdcbiAqIHRoZSBidWlsZCBvdXRwdXQgZGlyZWN0b3J5LiBJdCBpbmNsdWRlcyBmdW5jdGlvbnMgdG8gY29weSBzdGF0aWMgZmlsZXMgdG8gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnlcbiAqIGFuZCB0byByZW1vdmUgdGhlIGV4aXN0aW5nIGJ1aWxkIG91dHB1dC5cbiAqL1xuXG5pbXBvcnQgeyBqb2luIH0gZnJvbSAnLi4vUGF0aC50cyc7XG5pbXBvcnQgeyB0cmltU3RhcnQgfSBmcm9tICcuLi9TdHJpbmcudHMnO1xuaW1wb3J0IHsgcmVhZGRpclBvc2l4IH0gZnJvbSAnLi9Gcy50cyc7XG5pbXBvcnQge1xuICBjcCxcbiAgcm1cbn0gZnJvbSAnLi9Ob2RlTW9kdWxlcy50cyc7XG5pbXBvcnQgeyBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIH0gZnJvbSAnLi9PYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7IGV4ZWNGcm9tUm9vdCB9IGZyb20gJy4vUm9vdC50cyc7XG5cbi8qKlxuICogUmVtb3ZlcyB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeSBhbmQgaXRzIGNvbnRlbnRzLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gZGVsZXRlcyB0aGUgZW50aXJlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkgdG8gZW5zdXJlIGEgY2xlYW4gYnVpbGQgZW52aXJvbm1lbnQuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgZGlyZWN0b3J5IGhhcyBiZWVuIHJlbW92ZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENsZWFuKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBybShPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRpc3QsIHsgZm9yY2U6IHRydWUsIHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbn1cblxuLyoqXG4gKiBDb3BpZXMgYWxsIHN0YXRpYyBmaWxlcyBmcm9tIHRoZSBzdGF0aWMgYXNzZXRzIGRpcmVjdG9yeSB0byB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHJlY3Vyc2l2ZWx5IHJlYWRzIHRoZSBjb250ZW50cyBvZiB0aGUgc3RhdGljIGFzc2V0cyBkaXJlY3RvcnkgYW5kIGNvcGllc1xuICogZWFjaCBmaWxlIHRvIHRoZSBjb3JyZXNwb25kaW5nIHBhdGggaW4gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiBhbGwgZmlsZXMgaGF2ZSBiZWVuIGNvcGllZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkU3RhdGljKCk6IFByb21pc2U8dm9pZD4ge1xuICBmb3IgKGNvbnN0IGRpcmVudCBvZiBhd2FpdCByZWFkZGlyUG9zaXgoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWMsIHsgcmVjdXJzaXZlOiB0cnVlLCB3aXRoRmlsZVR5cGVzOiB0cnVlIH0pKSB7XG4gICAgaWYgKCFkaXJlbnQuaXNGaWxlKCkpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IHBhdGggPSB0cmltU3RhcnQoam9pbihkaXJlbnQucGFyZW50UGF0aCwgZGlyZW50Lm5hbWUpLCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYyArICcvJyk7XG4gICAgYXdhaXQgY3Aoam9pbihPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYywgcGF0aCksIGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBwYXRoKSk7XG4gIH1cbn1cblxuLyoqXG4gKiBWYWxpZGF0ZXMgaWYgdGhlIFR5cGVTY3JpcHQgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZFZhbGlkYXRlKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBleGVjRnJvbVJvb3QoWyd0c2MnLCAnLS1idWlsZCcsICctLWZvcmNlJ10pO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFhQSxrQkFBcUI7QUFDckIsb0JBQTBCO0FBQzFCLGdCQUE2QjtBQUM3Qix5QkFHTztBQUNQLHVDQUEwQztBQUMxQyxrQkFBNkI7QUFyQjdCLElBQUksWUFBWSxXQUFXLFNBQVMsS0FBSztBQUFBLEVBQ3ZDLFdBQVc7QUFBQSxFQUNYLE9BQU87QUFBQSxFQUNQLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBeUJBLGVBQXNCLGFBQTRCO0FBQ2hELFlBQU0sdUJBQUcsMkRBQTBCLE1BQU0sRUFBRSxPQUFPLE1BQU0sV0FBVyxLQUFLLENBQUM7QUFDM0U7QUFVQSxlQUFzQixjQUE2QjtBQUNqRCxhQUFXLFVBQVUsVUFBTSx3QkFBYSwyREFBMEIsUUFBUSxFQUFFLFdBQVcsTUFBTSxlQUFlLEtBQUssQ0FBQyxHQUFHO0FBQ25ILFFBQUksQ0FBQyxPQUFPLE9BQU8sR0FBRztBQUNwQjtBQUFBLElBQ0Y7QUFFQSxVQUFNLFdBQU8sNkJBQVUsa0JBQUssT0FBTyxZQUFZLE9BQU8sSUFBSSxHQUFHLDJEQUEwQixTQUFTLEdBQUc7QUFDbkcsY0FBTSwyQkFBRyxrQkFBSywyREFBMEIsUUFBUSxJQUFJLE9BQUcsa0JBQUssMkRBQTBCLE1BQU0sSUFBSSxDQUFDO0FBQUEsRUFDbkc7QUFDRjtBQU9BLGVBQXNCLGdCQUErQjtBQUNuRCxZQUFNLDBCQUFhLENBQUMsT0FBTyxXQUFXLFNBQVMsQ0FBQztBQUNsRDsiLAogICJuYW1lcyI6IFtdCn0K
@@ -52,7 +52,12 @@ var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
52
52
  }
53
53
  return "";
54
54
  })();
55
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
55
+ var __process = globalThis["process"] ?? {
56
+ "browser": true,
57
+ "cwd": "[[Function0]]",
58
+ "env": {},
59
+ "platform": "android"
60
+ };
56
61
  const NODE_SCRIPT_ARGV_SKIP_COUNT = 2;
57
62
  function cli(argv = import_NodeModules.process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)) {
58
63
  (0, import_Async.invokeAsyncSafely)(() => (0, import_CliUtils.wrapCliTask)(async () => {
@@ -80,4 +85,4 @@ function addCommand(program, name, description, taskFn) {
80
85
  0 && (module.exports = {
81
86
  cli
82
87
  });
83
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const url=require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\nvar __process = globalThis['process'] ?? {\"browser\":true,\"cwd\":\"[[Function:0]]\",\"env\":{},\"platform\":\"android\"};\n/**\n * @packageDocumentation cli\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport { Command } from 'commander';\n\nimport type { MaybePromise } from '../Async.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport { getDirname } from '../Path.ts';\nimport {\n  buildClean,\n  buildStatic,\n  buildValidate\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { process } from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildStatic = 'build:static',\n  BuildValidate = 'build:validate',\n  Dev = 'dev',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() => wrapCliTask(async () => {\n    const packageJson = await readPackageJson(getDirname(import.meta.url));\n    const program = new Command();\n\n    program\n      .name(packageJson.name ?? '(unknown)')\n      .description('CLI for Obsidian plugin development utilities')\n      .version(packageJson.version ?? '(unknown)');\n\n    addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n    addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n    addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n    addCommand(program, CommandNames.BuildValidate, 'Validates if TypeScript code compiles', () => buildValidate());\n    addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n    addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n    addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n    addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n      .argument('[isBeta]', 'Publish to NPM beta');\n    addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n    addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n      .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n    await program.parseAsync(argv, { from: 'user' });\n    return CliTaskResult.DoNotExit();\n  }));\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters, @typescript-eslint/no-invalid-void-type\nfunction addCommand<Args extends unknown[]>(program: Command, name: string, description: string, taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAUA,uBAAwB;AAIxB,mBAAkC;AAClC,kBAA2B;AAC3B,mBAIO;AACP,sBAGO;AACP,mCAGO;AACP,oBAAqB;AACrB,yBAAwB;AACxB,iBAAgC;AAChC,wBAAwB;AACxB,wBAA2B;AAC3B,qBAA8B;AAlC9B,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,QAAQ,UAAU;AAAE,WAAO,IAAI,cAAc,UAAU,EAAE;AAAA,EAAI;AAAC,MAAG,OAAO,WAAS,aAAY;AAAC,WAAO,OAAO,SAAS;AAAA,EAAI;AAAC,SAAM;AAAE,GAAG;AAC/O,IAAI,YAAY,WAAW,SAAS,KAAK,EAAC,WAAU,MAAK,OAAM,kBAAiB,OAAM,CAAC,GAAE,YAAW,UAAS;AAwC7G,MAAM,8BAA8B;AAwB7B,SAAS,IAAI,OAAiB,2BAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F,sCAAkB,UAAM,6BAAY,YAAY;AAC9C,UAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,UAAM,UAAU,IAAI,yBAAQ;AAE5B,YACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,eAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,eAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,eAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,eAAW,SAAS,sCAA4B,yCAAyC,UAAM,4BAAc,CAAC;AAC9G,eAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,eAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,eAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,eAAW,SAAS,yBAAsB,kBAAkB,CAAC,eAAoB,2BAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,eAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,eAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,UAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,WAAO,8BAAc,UAAU;AAAA,EACjC,CAAC,CAAC;AACJ;AAYA,SAAS,WAAmC,SAAkB,MAAc,aAAqB,QAAwE;AACvK,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,aAAe,6BAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

88
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const url=require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\nvar __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": \"[[Function0]]\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation cli\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport { Command } from 'commander';\n\nimport type { MaybePromise } from '../Async.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport { getDirname } from '../Path.ts';\nimport {\n  buildClean,\n  buildStatic,\n  buildValidate\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { process } from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildStatic = 'build:static',\n  BuildValidate = 'build:validate',\n  Dev = 'dev',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() => wrapCliTask(async () => {\n    const packageJson = await readPackageJson(getDirname(import.meta.url));\n    const program = new Command();\n\n    program\n      .name(packageJson.name ?? '(unknown)')\n      .description('CLI for Obsidian plugin development utilities')\n      .version(packageJson.version ?? '(unknown)');\n\n    addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n    addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n    addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n    addCommand(program, CommandNames.BuildValidate, 'Validates if TypeScript code compiles', () => buildValidate());\n    addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n    addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n    addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n    addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n      .argument('[isBeta]', 'Publish to NPM beta');\n    addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n    addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n      .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n    await program.parseAsync(argv, { from: 'user' });\n    return CliTaskResult.DoNotExit();\n  }));\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters, @typescript-eslint/no-invalid-void-type\nfunction addCommand<Args extends unknown[]>(program: Command, name: string, description: string, taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAeA,uBAAwB;AAIxB,mBAAkC;AAClC,kBAA2B;AAC3B,mBAIO;AACP,sBAGO;AACP,mCAGO;AACP,oBAAqB;AACrB,yBAAwB;AACxB,iBAAgC;AAChC,wBAAwB;AACxB,wBAA2B;AAC3B,qBAA8B;AAvC9B,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,QAAQ,UAAU;AAAE,WAAO,IAAI,cAAc,UAAU,EAAE;AAAA,EAAI;AAAC,MAAG,OAAO,WAAS,aAAY;AAAC,WAAO,OAAO,SAAS;AAAA,EAAI;AAAC,SAAM;AAAE,GAAG;AAC/O,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,WAAW;AAAA,EACX,OAAO;AAAA,EACP,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAwCA,MAAM,8BAA8B;AAwB7B,SAAS,IAAI,OAAiB,2BAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F,sCAAkB,UAAM,6BAAY,YAAY;AAC9C,UAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,UAAM,UAAU,IAAI,yBAAQ;AAE5B,YACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,eAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,eAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,eAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,eAAW,SAAS,sCAA4B,yCAAyC,UAAM,4BAAc,CAAC;AAC9G,eAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,eAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,eAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,eAAW,SAAS,yBAAsB,kBAAkB,CAAC,eAAoB,2BAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,eAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,eAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,UAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,WAAO,8BAAc,UAAU;AAAA,EACjC,CAAC,CAAC;AACJ;AAYA,SAAS,WAAmC,SAAkB,MAAc,aAAqB,QAAwE;AACvK,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,aAAe,6BAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

@@ -50,7 +50,12 @@ var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
50
50
  }
51
51
  return "";
52
52
  })();
53
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
53
+ var __process = globalThis["process"] ?? {
54
+ "browser": true,
55
+ "cwd": "[[Function0]]",
56
+ "env": {},
57
+ "platform": "android"
58
+ };
54
59
  const esmRequire = (0, import_NodeModules.createRequire)(__import_meta_url);
55
60
  async function getDependenciesToBundle() {
56
61
  const dependenciesToSkip = await getDependenciesToSkip();
@@ -121,4 +126,4 @@ function extractDependenciesToBundlePlugin(dependenciesToSkip, dependenciesToBun
121
126
  getDependenciesToBundle,
122
127
  getDependenciesToSkip
123
128
  });
124
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/Dependency.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const url=require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\nvar __process = globalThis['process'] ?? {\"browser\":true,\"cwd\":\"[[Function:0]]\",\"env\":{},\"platform\":\"android\"};\n/**\n * @packageDocumentation Dependency\n * This module provides utilities for managing dependencies during the esbuild process.\n * It includes functions to determine which dependencies should be skipped and which\n * should be bundled, as well as an esbuild plugin for extracting dependencies to bundle.\n */\n\nimport type {\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\n\nimport { throwExpression } from '../../Error.ts';\nimport {\n  getDirname,\n  join\n} from '../../Path.ts';\nimport { trimStart } from '../../String.ts';\nimport {\n  builtinModules,\n  createRequire\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../ObsidianDevUtilsRepoPaths.ts';\nimport {\n  banner,\n  invokeEsbuild\n} from './ObsidianPluginBuilder.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\n\nconst esmRequire = createRequire(import.meta.url);\n\ninterface ModuleWithDefaultExport {\n  default: unknown;\n}\n\n/**\n * Determines which dependencies should be bundled by esbuild.\n *\n * @returns A `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 `Promise` that resolves to a `Set` of dependency names to skip.\n */\nexport async function getDependenciesToSkip(): Promise<Set<string>> {\n  const packageJson = await readPackageJson(getDirname(import.meta.url));\n  const dependenciesToSkip = new Set<string>([...builtinModules, ...Object.keys(packageJson.dependencies ?? {}).filter(canSkipFromBundling)]);\n  return dependenciesToSkip;\n}\n\n/**\n * Determines whether a module can be skipped from bundling.\n *\n * @param moduleName - The name of the module.\n * @returns A boolean indicating whether the module can be skipped from bundling.\n */\nfunction canSkipFromBundling(moduleName: string): boolean {\n  if (moduleName.startsWith('@types/')) {\n    return true;\n  }\n\n  if (moduleName.startsWith('obsidian')) {\n    return true;\n  }\n\n  if (moduleName === 'esbuild') {\n    return true;\n  }\n\n  try {\n    const module = esmRequire(moduleName) as ModuleWithDefaultExport;\n    return !module.default;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Creates an esbuild plugin that identifies which dependencies should be bundled.\n *\n * @param dependenciesToSkip - A set of dependency names that should be skipped during bundling.\n * @param dependenciesToBundle - A set where the names of dependencies to be bundled will be added.\n * @returns An esbuild `Plugin` object that extracts dependencies to bundle.\n */\nfunction extractDependenciesToBundlePlugin(dependenciesToSkip: Set<string>, dependenciesToBundle: Set<string>): Plugin {\n  return {\n    name: 'test',\n    setup(build): void {\n      build.onResolve({ filter: /^[^./]/ }, (args) => {\n        if (!args.importer.endsWith('.d.ts')) {\n          const moduleName = trimStart(args.path.split('/')[0] ?? throwExpression(new Error('Wrong path')), 'node:');\n          if (!dependenciesToSkip.has(args.path) && !dependenciesToSkip.has(moduleName)) {\n            dependenciesToBundle.add(args.path);\n          }\n        }\n        return { external: true, path: args.path };\n      });\n    }\n  };\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,qBAAwB;AAExB,mBAAgC;AAChC,kBAGO;AACP,oBAA0B;AAC1B,yBAGO;AACP,iBAAgC;AAChC,uCAA0C;AAC1C,mCAGO;AACP,8BAAiC;AAhCjC,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,QAAQ,UAAU;AAAE,WAAO,IAAI,cAAc,UAAU,EAAE;AAAA,EAAI;AAAC,MAAG,OAAO,WAAS,aAAY;AAAC,WAAO,OAAO,SAAS;AAAA,EAAI;AAAC,SAAM;AAAE,GAAG;AAC/O,IAAI,YAAY,WAAW,SAAS,KAAK,EAAC,WAAU,MAAK,OAAM,kBAAiB,OAAM,CAAC,GAAE,YAAW,UAAS;AAiC7G,MAAM,iBAAa,kCAAc,iBAAe;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,KAAC,kBAAK,2DAA0B,KAAK,2DAA0B,SAAS,2DAA0B,KAAK,CAAC;AAAA,IACrH,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,UACP,0CAAiB;AAAA,MACjB,kCAAkC,oBAAoB,oBAAoB;AAAA,IAC5E;AAAA,IACA,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,aAAa;AAAA,IACb,OAAO;AAAA,EACT;AAEA,QAAM,eAAe,UAAM,wBAAQ,YAAY;AAC/C,YAAM,4CAAc,cAAc,IAAI;AACtC,SAAO,MAAM,KAAK,oBAAoB,EAAE,KAAK;AAC/C;AAOA,eAAsB,wBAA8C;AAClE,QAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,QAAM,qBAAqB,oBAAI,IAAY,CAAC,GAAG,mCAAgB,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,UAAMA,UAAS,WAAW,UAAU;AACpC,WAAO,CAACA,QAAO;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,OAAO,GAAG;AACpC,gBAAM,iBAAa,yBAAU,KAAK,KAAK,MAAM,GAAG,EAAE,CAAC,SAAK,8BAAgB,IAAI,MAAM,YAAY,CAAC,GAAG,OAAO;AACzG,cAAI,CAAC,mBAAmB,IAAI,KAAK,IAAI,KAAK,CAAC,mBAAmB,IAAI,UAAU,GAAG;AAC7E,iCAAqB,IAAI,KAAK,IAAI;AAAA,UACpC;AAAA,QACF;AACA,eAAO,EAAE,UAAU,MAAM,MAAM,KAAK,KAAK;AAAA,MAC3C,CAAC;AAAA,IACH;AAAA,EACF;AACF;",
  "names": ["module"]
}

129
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/Dependency.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const url=require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\nvar __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": \"[[Function0]]\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation Dependency\n * This module provides utilities for managing dependencies during the esbuild process.\n * It includes functions to determine which dependencies should be skipped and which\n * should be bundled, as well as an esbuild plugin for extracting dependencies to bundle.\n */\n\nimport type {\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { context } from 'esbuild';\n\nimport { throwExpression } from '../../Error.ts';\nimport {\n  getDirname,\n  join\n} from '../../Path.ts';\nimport { trimStart } from '../../String.ts';\nimport {\n  builtinModules,\n  createRequire\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../ObsidianDevUtilsRepoPaths.ts';\nimport {\n  banner,\n  invokeEsbuild\n} from './ObsidianPluginBuilder.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\n\nconst esmRequire = createRequire(import.meta.url);\n\ninterface ModuleWithDefaultExport {\n  default: unknown;\n}\n\n/**\n * Determines which dependencies should be bundled by esbuild.\n *\n * @returns A `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 `Promise` that resolves to a `Set` of dependency names to skip.\n */\nexport async function getDependenciesToSkip(): Promise<Set<string>> {\n  const packageJson = await readPackageJson(getDirname(import.meta.url));\n  const dependenciesToSkip = new Set<string>([...builtinModules, ...Object.keys(packageJson.dependencies ?? {}).filter(canSkipFromBundling)]);\n  return dependenciesToSkip;\n}\n\n/**\n * Determines whether a module can be skipped from bundling.\n *\n * @param moduleName - The name of the module.\n * @returns A boolean indicating whether the module can be skipped from bundling.\n */\nfunction canSkipFromBundling(moduleName: string): boolean {\n  if (moduleName.startsWith('@types/')) {\n    return true;\n  }\n\n  if (moduleName.startsWith('obsidian')) {\n    return true;\n  }\n\n  if (moduleName === 'esbuild') {\n    return true;\n  }\n\n  try {\n    const module = esmRequire(moduleName) as ModuleWithDefaultExport;\n    return !module.default;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Creates an esbuild plugin that identifies which dependencies should be bundled.\n *\n * @param dependenciesToSkip - A set of dependency names that should be skipped during bundling.\n * @param dependenciesToBundle - A set where the names of dependencies to be bundled will be added.\n * @returns An esbuild `Plugin` object that extracts dependencies to bundle.\n */\nfunction extractDependenciesToBundlePlugin(dependenciesToSkip: Set<string>, dependenciesToBundle: Set<string>): Plugin {\n  return {\n    name: 'test',\n    setup(build): void {\n      build.onResolve({ filter: /^[^./]/ }, (args) => {\n        if (!args.importer.endsWith('.d.ts')) {\n          const moduleName = trimStart(args.path.split('/')[0] ?? throwExpression(new Error('Wrong path')), 'node:');\n          if (!dependenciesToSkip.has(args.path) && !dependenciesToSkip.has(moduleName)) {\n            dependenciesToBundle.add(args.path);\n          }\n        }\n        return { external: true, path: args.path };\n      });\n    }\n  };\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAmBA,qBAAwB;AAExB,mBAAgC;AAChC,kBAGO;AACP,oBAA0B;AAC1B,yBAGO;AACP,iBAAgC;AAChC,uCAA0C;AAC1C,mCAGO;AACP,8BAAiC;AArCjC,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,QAAQ,UAAU;AAAE,WAAO,IAAI,cAAc,UAAU,EAAE;AAAA,EAAI;AAAC,MAAG,OAAO,WAAS,aAAY;AAAC,WAAO,OAAO,SAAS;AAAA,EAAI;AAAC,SAAM;AAAE,GAAG;AAC/O,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,WAAW;AAAA,EACX,OAAO;AAAA,EACP,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAiCA,MAAM,iBAAa,kCAAc,iBAAe;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,KAAC,kBAAK,2DAA0B,KAAK,2DAA0B,SAAS,2DAA0B,KAAK,CAAC;AAAA,IACrH,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,UACP,0CAAiB;AAAA,MACjB,kCAAkC,oBAAoB,oBAAoB;AAAA,IAC5E;AAAA,IACA,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,aAAa;AAAA,IACb,OAAO;AAAA,EACT;AAEA,QAAM,eAAe,UAAM,wBAAQ,YAAY;AAC/C,YAAM,4CAAc,cAAc,IAAI;AACtC,SAAO,MAAM,KAAK,oBAAoB,EAAE,KAAK;AAC/C;AAOA,eAAsB,wBAA8C;AAClE,QAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,QAAM,qBAAqB,oBAAI,IAAY,CAAC,GAAG,mCAAgB,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,UAAMA,UAAS,WAAW,UAAU;AACpC,WAAO,CAACA,QAAO;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,OAAO,GAAG;AACpC,gBAAM,iBAAa,yBAAU,KAAK,KAAK,MAAM,GAAG,EAAE,CAAC,SAAK,8BAAgB,IAAI,MAAM,YAAY,CAAC,GAAG,OAAO;AACzG,cAAI,CAAC,mBAAmB,IAAI,KAAK,IAAI,KAAK,CAAC,mBAAmB,IAAI,UAAU,GAAG;AAC7E,iCAAqB,IAAI,KAAK,IAAI;AAAA,UACpC;AAAA,QACF;AACA,eAAO,EAAE,UAAU,MAAM,MAAM,KAAK,KAAK;AAAA,MAC3C,CAAC;AAAA,IACH;AAAA,EACF;AACF;",
  "names": ["module"]
}

@@ -47,7 +47,12 @@ var import_copyToObsidianPluginsFolderPlugin = require('./copyToObsidianPluginsF
47
47
  var import_fixEsmPlugin = require('./fixEsmPlugin.cjs');
48
48
  var import_fixSourceMapsPlugin = require('./fixSourceMapsPlugin.cjs');
49
49
  var import_preprocessPlugin = require('./preprocessPlugin.cjs');
50
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
50
+ var __process = globalThis["process"] ?? {
51
+ "browser": true,
52
+ "cwd": "[[Function0]]",
53
+ "env": {},
54
+ "platform": "android"
55
+ };
51
56
  var BuildMode = /* @__PURE__ */ ((BuildMode2) => {
52
57
  BuildMode2[BuildMode2["Development"] = 0] = "Development";
53
58
  BuildMode2[BuildMode2["Production"] = 1] = "Production";
@@ -157,4 +162,4 @@ async function invokeEsbuild(buildContext, isProductionBuild) {
157
162
  buildObsidianPlugin,
158
163
  invokeEsbuild
159
164
  });
160
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/ObsidianPluginBuilder.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\"browser\":true,\"cwd\":\"[[Function:0]]\",\"env\":{},\"platform\":\"android\"};\n/**\n * @packageDocumentation ObsidianPluginBuilder\n * This module provides functionality to build and bundle an Obsidian plugin using esbuild.\n * It includes functions to handle the build process based on different build modes (development or production),\n * and it sets up various esbuild plugins to preprocess, lint, fix source maps, and copy files to the Obsidian plugins folder.\n */\n\nimport type {\n  BuildContext,\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { config } from 'dotenv';\nimport { context } from 'esbuild';\n\nimport { throwExpression } from '../../Error.ts';\nimport { ObsidianPluginRepoPaths } from '../../obsidian/Plugin/ObsidianPluginRepoPaths.ts';\nimport { join } from '../../Path.ts';\nimport { buildValidate } from '../build.ts';\nimport { CliTaskResult } from '../CliUtils.ts';\nimport {\n  builtinModules,\n  cp,\n  existsSync,\n  mkdir,\n  process,\n  rm,\n  writeFile\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { resolvePathFromRoot } from '../Root.ts';\nimport { copyToObsidianPluginsFolderPlugin } from './copyToObsidianPluginsFolderPlugin.ts';\nimport { fixEsmPlugin } from './fixEsmPlugin.ts';\nimport { fixSourceMapsPlugin } from './fixSourceMapsPlugin.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\n\n/**\n * Enumeration representing the build modes.\n */\nexport enum BuildMode {\n  /** Development mode for building the plugin */\n  Development,\n  /** Production mode for building the plugin */\n  Production\n}\n\n/**\n * Banner text to be included at the top of the generated files.\n */\nexport const banner = `/*\nTHIS IS A GENERATED/BUNDLED FILE BY ESBUILD\nif you want to view the source, please visit the github repository of this plugin\n*/\n`;\n\n/**\n * Options for building an Obsidian plugin.\n */\nexport interface BuildObsidianPluginOptions {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  customEsbuildPlugins?: Plugin[];\n\n  /**\n   * The build mode, either Development or Production\n   */\n  mode: BuildMode;\n\n  /**\n   * The directory for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_DIR` environment variable.\n   */\n  obsidianConfigDir?: string;\n}\n\ninterface ObsidianPluginBuilderEnv {\n  OBSIDIAN_CONFIG_DIR: string;\n}\n\n/**\n * Builds the Obsidian plugin based on the specified mode and configuration directory.\n *\n * @param options - The parameters for building the plugin.\n * @returns A promise that resolves to a `TaskResult` indicating the success or failure of the build.\n */\nexport async function buildObsidianPlugin(options: BuildObsidianPluginOptions): Promise<CliTaskResult> {\n  await buildValidate();\n  config();\n  const obsidianPluginBuilderEnv = process.env as Partial<ObsidianPluginBuilderEnv>;\n\n  const {\n    customEsbuildPlugins = [],\n    mode,\n    obsidianConfigDir: _obsidianConfigDir\n  } = options;\n\n  const obsidianConfigDir = _obsidianConfigDir ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_DIR ?? '';\n  const isProductionBuild = mode === BuildMode.Production;\n\n  const distDir = resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev);\n  if (!distDir) {\n    throw new Error('Could not determine the dist directory');\n  }\n\n  if (existsSync(distDir)) {\n    await rm(distDir, { recursive: true });\n  }\n  await mkdir(distDir, { recursive: true });\n\n  const distFileNames = [\n    ObsidianPluginRepoPaths.ManifestJson,\n    ObsidianPluginRepoPaths.StylesCss\n  ];\n  if (!isProductionBuild) {\n    await writeFile(join(distDir, ObsidianPluginRepoPaths.HotReload), '', 'utf-8');\n  }\n\n  for (const fileName of distFileNames) {\n    const localFile = resolvePathFromRoot(fileName);\n    if (!localFile) {\n      throw new Error(`Could not determine the local file for ${fileName}`);\n    }\n    const distFile = join(distDir, fileName);\n\n    if (existsSync(localFile)) {\n      await cp(localFile, distFile);\n    }\n  }\n\n  const distPath = join(distDir, ObsidianPluginRepoPaths.MainJs);\n\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    entryPoints: [resolvePathFromRoot(join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs)) ?? throwExpression(new Error('Could not determine the entry point for the plugin'))],\n    external: [\n      'obsidian',\n      'electron',\n      '@codemirror/autocomplete',\n      '@codemirror/collab',\n      '@codemirror/commands',\n      '@codemirror/language',\n      '@codemirror/lint',\n      '@codemirror/search',\n      '@codemirror/state',\n      '@codemirror/view',\n      '@lezer/common',\n      '@lezer/highlight',\n      '@lezer/lr',\n      'esbuild',\n      'eslint',\n      ...builtinModules\n    ],\n    format: 'cjs',\n    logLevel: 'info',\n    minify: isProductionBuild,\n    outfile: distPath,\n    platform: 'node',\n    plugins: [\n      preprocessPlugin(),\n      fixEsmPlugin(),\n      fixSourceMapsPlugin(isProductionBuild, distPath, pluginName),\n      ...customEsbuildPlugins,\n      copyToObsidianPluginsFolderPlugin(isProductionBuild, distDir, obsidianConfigDir, pluginName)\n    ],\n    sourcemap: isProductionBuild ? false : 'inline',\n    target: 'esnext',\n    treeShaking: true\n  };\n\n  const buildContext = await context(buildOptions);\n  return await invokeEsbuild(buildContext, isProductionBuild);\n}\n\n/**\n * Invokes the build process with the provided build context.\n *\n * @param buildContext - The build context generated by esbuild.\n * @param isProductionBuild - A boolean indicating whether the build is a production build.\n * @returns A promise that resolves to a `TaskResult` 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  } else {\n    await buildContext.watch();\n    return CliTaskResult.DoNotExit();\n  }\n}\n"],
  "mappings": "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",
  "names": ["BuildMode"]
}

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

@@ -53,7 +53,12 @@ var fixSourceMapsPlugin = __toESM(__extractDefault(require('./fixSourceMapsPlugi
53
53
  var ObsidianPluginBuilder = __toESM(__extractDefault(require('./ObsidianPluginBuilder.cjs')), 1);
54
54
  var preprocessPlugin = __toESM(__extractDefault(require('./preprocessPlugin.cjs')), 1);
55
55
  var renameToCjsPlugin = __toESM(__extractDefault(require('./renameToCjsPlugin.cjs')), 1);
56
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
56
+ var __process = globalThis["process"] ?? {
57
+ "browser": true,
58
+ "cwd": "[[Function0]]",
59
+ "env": {},
60
+ "platform": "android"
61
+ };
57
62
  // Annotate the CommonJS export names for ESM import in node:
58
63
  0 && (module.exports = {
59
64
  Dependency,
@@ -64,4 +69,4 @@ var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0
64
69
  preprocessPlugin,
65
70
  renameToCjsPlugin
66
71
  });
67
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XCJicm93c2VyXCI6dHJ1ZSxcImN3ZFwiOlwiW1tGdW5jdGlvbjowXV1cIixcImVudlwiOnt9LFwicGxhdGZvcm1cIjpcImFuZHJvaWRcIn07XG4vKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luIGZyb20gJy4vY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luLnRzJztcbmV4cG9ydCAqIGFzIERlcGVuZGVuY3kgZnJvbSAnLi9EZXBlbmRlbmN5LnRzJztcbmV4cG9ydCAqIGFzIGZpeEVzbVBsdWdpbiBmcm9tICcuL2ZpeEVzbVBsdWdpbi50cyc7XG5leHBvcnQgKiBhcyBmaXhTb3VyY2VNYXBzUGx1Z2luIGZyb20gJy4vZml4U291cmNlTWFwc1BsdWdpbi50cyc7XG5leHBvcnQgKiBhcyBPYnNpZGlhblBsdWdpbkJ1aWxkZXIgZnJvbSAnLi9PYnNpZGlhblBsdWdpbkJ1aWxkZXIudHMnO1xuZXhwb3J0ICogYXMgcHJlcHJvY2Vzc1BsdWdpbiBmcm9tICcuL3ByZXByb2Nlc3NQbHVnaW4udHMnO1xuZXhwb3J0ICogYXMgcmVuYW1lVG9DanNQbHVnaW4gZnJvbSAnLi9yZW5hbWVUb0Nqc1BsdWdpbi50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUdBLHdDQUFtRDtBQUNuRCxpQkFBNEI7QUFDNUIsbUJBQThCO0FBQzlCLDBCQUFxQztBQUNyQyw0QkFBdUM7QUFDdkMsdUJBQWtDO0FBQ2xDLHdCQUFtQztBQVRuQyxJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUssRUFBQyxXQUFVLE1BQUssT0FBTSxrQkFBaUIsT0FBTSxDQUFDLEdBQUUsWUFBVyxVQUFTOyIsCiAgIm5hbWVzIjogW10KfQo=
72
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XG4gIFwiYnJvd3NlclwiOiB0cnVlLFxuICBcImN3ZFwiOiBcIltbRnVuY3Rpb24wXV1cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luIGZyb20gJy4vY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luLnRzJztcbmV4cG9ydCAqIGFzIERlcGVuZGVuY3kgZnJvbSAnLi9EZXBlbmRlbmN5LnRzJztcbmV4cG9ydCAqIGFzIGZpeEVzbVBsdWdpbiBmcm9tICcuL2ZpeEVzbVBsdWdpbi50cyc7XG5leHBvcnQgKiBhcyBmaXhTb3VyY2VNYXBzUGx1Z2luIGZyb20gJy4vZml4U291cmNlTWFwc1BsdWdpbi50cyc7XG5leHBvcnQgKiBhcyBPYnNpZGlhblBsdWdpbkJ1aWxkZXIgZnJvbSAnLi9PYnNpZGlhblBsdWdpbkJ1aWxkZXIudHMnO1xuZXhwb3J0ICogYXMgcHJlcHJvY2Vzc1BsdWdpbiBmcm9tICcuL3ByZXByb2Nlc3NQbHVnaW4udHMnO1xuZXhwb3J0ICogYXMgcmVuYW1lVG9DanNQbHVnaW4gZnJvbSAnLi9yZW5hbWVUb0Nqc1BsdWdpbi50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVFBLHdDQUFtRDtBQUNuRCxpQkFBNEI7QUFDNUIsbUJBQThCO0FBQzlCLDBCQUFxQztBQUNyQyw0QkFBdUM7QUFDdkMsdUJBQWtDO0FBQ2xDLHdCQUFtQztBQWRuQyxJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxXQUFXO0FBQUEsRUFDWCxPQUFPO0FBQUEsRUFDUCxPQUFPLENBQUM7QUFBQSxFQUNSLFlBQVk7QUFDZDsiLAogICJuYW1lcyI6IFtdCn0K
@@ -33,7 +33,12 @@ module.exports = __toCommonJS(preprocessPlugin_exports);
33
33
  var import_Object = require('../../Object.cjs');
34
34
  var import_String = require('../../String.cjs');
35
35
  var import_NodeModules = require('../NodeModules.cjs');
36
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
36
+ var __process = globalThis["process"] ?? {
37
+ "browser": true,
38
+ "cwd": "[[Function0]]",
39
+ "env": {},
40
+ "platform": "android"
41
+ };
37
42
  function preprocessPlugin() {
38
43
  const replacements = {
39
44
  process: {
@@ -105,4 +110,4 @@ ${__extractDefault.toString()}
105
110
  0 && (module.exports = {
106
111
  preprocessPlugin
107
112
  });
108
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/preprocessPlugin.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\"browser\":true,\"cwd\":\"[[Function:0]]\",\"env\":{},\"platform\":\"android\"};\n/**\n * @packageDocumentation preprocessPlugin\n * This module defines a custom esbuild plugin that preprocesses JavaScript and TypeScript files.\n * The preprocessing includes replacing `import(dot)meta(dot)url` with a Node.js-compatible alternative,\n * ensuring compatibility with Obsidian's plugin system, and adding a basic `process` object for environments\n * where `process` is not available (like mobile or web environments).\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\nimport type { Plugin } from 'esbuild';\n\nimport {\n  FunctionHandlingMode,\n  toJson\n} from '../../Object.ts';\nimport {\n  makeValidVariableName,\n  replaceAll\n} from '../../String.ts';\nimport {\n  process,\n  readFile\n} from '../NodeModules.ts';\n\ninterface EsmModule {\n  __esModule: boolean;\n  default: unknown;\n}\n\ntype ProcessEx = {\n  browser: boolean;\n} & typeof process;\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 * @returns An esbuild `Plugin` object that handles the preprocessing.\n */\nexport function preprocessPlugin(): Plugin {\n  const replacements = {\n    process: {\n      browser: true,\n      cwd: () => '/',\n      env: {},\n      platform: 'android'\n    } as ProcessEx,\n    [replaceAll('import(dot)meta(dot)url', '(dot)', '.')]: (): string => {\n      if (typeof __filename === 'string') {\n        // eslint-disable-next-line import-x/no-nodejs-modules, @typescript-eslint/no-require-imports\n        const url = require('node:url') as typeof import('node:url');\n        return url.pathToFileURL(__filename).href;\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' + `${__extractDefault.toString()}\\n`;\n      build.initialOptions.banner['js'] += '\\n' + `(${patchRequireEsmDefault.toString()})()\\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' ? `(${value.toString()})()` : 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        contents = replaceAll(contents, /`\\r?\\n\\/\\/# sourceMappingURL/g, '`\\n//#${\\'\\'} sourceMappingURL');\n\n        return {\n          contents,\n          loader: 'ts'\n        };\n      });\n    }\n  };\n\n  function __extractDefault(module: Partial<EsmModule> | undefined): unknown {\n    return module && module.__esModule && module.default ? module.default : module;\n  }\n\n  function patchRequireEsmDefault(): void {\n    const __require = require;\n    require = Object.assign((id: string): unknown => {\n      const module = __require(id) as (Partial<EsmModule> | undefined) ?? {};\n      return __extractDefault(module);\n    }, __require) as NodeRequire;\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,oBAGO;AACP,oBAGO;AACP,yBAGO;AAzBP,IAAI,YAAY,WAAW,SAAS,KAAK,EAAC,WAAU,MAAK,OAAM,kBAAiB,OAAM,CAAC,GAAE,YAAW,UAAS;AA8CtG,SAAS,mBAA2B;AACzC,QAAM,eAAe;AAAA,IACnB,SAAS;AAAA,MACP,SAAS;AAAA,MACT,KAAK,MAAM;AAAA,MACX,KAAK,CAAC;AAAA,MACN,UAAU;AAAA,IACZ;AAAA,IACA,KAAC,0BAAW,2BAA2B,SAAS,GAAG,CAAC,GAAG,MAAc;AACnE,UAAI,OAAO,eAAe,UAAU;AAElC,cAAM,MAAM,QAAQ,UAAU;AAC9B,eAAO,IAAI,cAAc,UAAU,EAAE;AAAA,MACvC;AAEA,UAAI,OAAO,WAAW,aAAa;AACjC,eAAO,OAAO,SAAS;AAAA,MACzB;AAGA,aAAO;AAAA,IACT;AAAA,EACF;AAEA,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM,OAAa;AACjB,YAAM,eAAe,WAAW,CAAC;AAEjC,iBAAW,OAAO,OAAO,KAAK,YAAY,GAAG;AAC3C,cAAM,eAAe,OAAO,GAAG,IAAI,SAAK,qCAAsB,GAAG,CAAC;AAAA,MACpE;AAEA,YAAM,eAAe,WAAW,CAAC;AACjC,YAAM,eAAe,OAAO,IAAI,MAAM;AACtC,YAAM,eAAe,OAAO,IAAI,KAAK;AAAA,EAAU,iBAAiB,SAAS,CAAC;AAAA;AAC1E,YAAM,eAAe,OAAO,IAAI,KAAK;AAAA,GAAW,uBAAuB,SAAS,CAAC;AAAA;AAEjF,YAAM,OAAO,EAAE,QAAQ,6BAA6B,GAAG,OAAO,SAAS;AACrE,YAAI,WAAW,UAAM,6BAAS,KAAK,MAAM,OAAO;AAEhD,mBAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,YAAY,GAAG;AACvD,gBAAM,WAAW,SAAK,qCAAsB,GAAG,CAAC;AAChD,cAAI,CAAC,SAAS,SAAS,GAAG,GAAG;AAC3B;AAAA,UACF;AACA,gBAAM,WAAW,OAAO,UAAU,aAAa,IAAI,MAAM,SAAS,CAAC,YAAQ,sBAAO,OAAO,EAAE,sBAAsB,mCAAqB,KAAK,CAAC;AAC5I,cAAI,SAAS,SAAS,OAAO,QAAQ,EAAE,GAAG;AACxC;AAAA,UACF;AACA,qBAAW,OAAO,QAAQ,kBAAkB,GAAG,SAAS,QAAQ;AAAA,IAAQ;AAAA,QAC1E;AAIA,uBAAW,0BAAW,UAAU,iCAAiC,8BAAgC;AAEjG,eAAO;AAAA,UACL;AAAA,UACA,QAAQ;AAAA,QACV;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAEA,WAAS,iBAAiBA,SAAiD;AACzE,WAAOA,WAAUA,QAAO,cAAcA,QAAO,UAAUA,QAAO,UAAUA;AAAA,EAC1E;AAEA,WAAS,yBAA+B;AACtC,UAAM,YAAY;AAClB,cAAU,OAAO,OAAO,CAAC,OAAwB;AAC/C,YAAMA,UAAS,UAAU,EAAE,KAAyC,CAAC;AACrE,aAAO,iBAAiBA,OAAM;AAAA,IAChC,GAAG,SAAS;AAAA,EACd;AACF;",
  "names": ["module"]
}

113
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/preprocessPlugin.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": \"[[Function0]]\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation preprocessPlugin\n * This module defines a custom esbuild plugin that preprocesses JavaScript and TypeScript files.\n * The preprocessing includes replacing `import(dot)meta(dot)url` with a Node.js-compatible alternative,\n * ensuring compatibility with Obsidian's plugin system, and adding a basic `process` object for environments\n * where `process` is not available (like mobile or web environments).\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\nimport type { Plugin } from 'esbuild';\n\nimport {\n  FunctionHandlingMode,\n  toJson\n} from '../../Object.ts';\nimport {\n  makeValidVariableName,\n  replaceAll\n} from '../../String.ts';\nimport {\n  process,\n  readFile\n} from '../NodeModules.ts';\n\ninterface EsmModule {\n  __esModule: boolean;\n  default: unknown;\n}\n\ntype ProcessEx = {\n  browser: boolean;\n} & typeof process;\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 * @returns An esbuild `Plugin` object that handles the preprocessing.\n */\nexport function preprocessPlugin(): Plugin {\n  const replacements = {\n    process: {\n      browser: true,\n      cwd: () => '/',\n      env: {},\n      platform: 'android'\n    } as ProcessEx,\n    [replaceAll('import(dot)meta(dot)url', '(dot)', '.')]: (): string => {\n      if (typeof __filename === 'string') {\n        // eslint-disable-next-line import-x/no-nodejs-modules, @typescript-eslint/no-require-imports\n        const url = require('node:url') as typeof import('node:url');\n        return url.pathToFileURL(__filename).href;\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' + `${__extractDefault.toString()}\\n`;\n      build.initialOptions.banner['js'] += '\\n' + `(${patchRequireEsmDefault.toString()})()\\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' ? `(${value.toString()})()` : 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        contents = replaceAll(contents, /`\\r?\\n\\/\\/# sourceMappingURL/g, '`\\n//#${\\'\\'} sourceMappingURL');\n\n        return {\n          contents,\n          loader: 'ts'\n        };\n      });\n    }\n  };\n\n  function __extractDefault(module: Partial<EsmModule> | undefined): unknown {\n    return module && module.__esModule && module.default ? module.default : module;\n  }\n\n  function patchRequireEsmDefault(): void {\n    const __require = require;\n    require = Object.assign((id: string): unknown => {\n      const module = __require(id) as (Partial<EsmModule> | undefined) ?? {};\n      return __extractDefault(module);\n    }, __require) as NodeRequire;\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAmBA,oBAGO;AACP,oBAGO;AACP,yBAGO;AA9BP,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,WAAW;AAAA,EACX,OAAO;AAAA,EACP,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AA8CO,SAAS,mBAA2B;AACzC,QAAM,eAAe;AAAA,IACnB,SAAS;AAAA,MACP,SAAS;AAAA,MACT,KAAK,MAAM;AAAA,MACX,KAAK,CAAC;AAAA,MACN,UAAU;AAAA,IACZ;AAAA,IACA,KAAC,0BAAW,2BAA2B,SAAS,GAAG,CAAC,GAAG,MAAc;AACnE,UAAI,OAAO,eAAe,UAAU;AAElC,cAAM,MAAM,QAAQ,UAAU;AAC9B,eAAO,IAAI,cAAc,UAAU,EAAE;AAAA,MACvC;AAEA,UAAI,OAAO,WAAW,aAAa;AACjC,eAAO,OAAO,SAAS;AAAA,MACzB;AAGA,aAAO;AAAA,IACT;AAAA,EACF;AAEA,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM,OAAa;AACjB,YAAM,eAAe,WAAW,CAAC;AAEjC,iBAAW,OAAO,OAAO,KAAK,YAAY,GAAG;AAC3C,cAAM,eAAe,OAAO,GAAG,IAAI,SAAK,qCAAsB,GAAG,CAAC;AAAA,MACpE;AAEA,YAAM,eAAe,WAAW,CAAC;AACjC,YAAM,eAAe,OAAO,IAAI,MAAM;AACtC,YAAM,eAAe,OAAO,IAAI,KAAK;AAAA,EAAU,iBAAiB,SAAS,CAAC;AAAA;AAC1E,YAAM,eAAe,OAAO,IAAI,KAAK;AAAA,GAAW,uBAAuB,SAAS,CAAC;AAAA;AAEjF,YAAM,OAAO,EAAE,QAAQ,6BAA6B,GAAG,OAAO,SAAS;AACrE,YAAI,WAAW,UAAM,6BAAS,KAAK,MAAM,OAAO;AAEhD,mBAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,YAAY,GAAG;AACvD,gBAAM,WAAW,SAAK,qCAAsB,GAAG,CAAC;AAChD,cAAI,CAAC,SAAS,SAAS,GAAG,GAAG;AAC3B;AAAA,UACF;AACA,gBAAM,WAAW,OAAO,UAAU,aAAa,IAAI,MAAM,SAAS,CAAC,YAAQ,sBAAO,OAAO,EAAE,sBAAsB,mCAAqB,KAAK,CAAC;AAC5I,cAAI,SAAS,SAAS,OAAO,QAAQ,EAAE,GAAG;AACxC;AAAA,UACF;AACA,qBAAW,OAAO,QAAQ,kBAAkB,GAAG,SAAS,QAAQ;AAAA,IAAQ;AAAA,QAC1E;AAIA,uBAAW,0BAAW,UAAU,iCAAiC,8BAAgC;AAEjG,eAAO;AAAA,UACL;AAAA,UACA,QAAQ;AAAA,QACV;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAEA,WAAS,iBAAiBA,SAAiD;AACzE,WAAOA,WAAUA,QAAO,cAAcA,QAAO,UAAUA,QAAO,UAAUA;AAAA,EAC1E;AAEA,WAAS,yBAA+B;AACtC,UAAM,YAAY;AAClB,cAAU,OAAO,OAAO,CAAC,OAAwB;AAC/C,YAAMA,UAAS,UAAU,EAAE,KAAyC,CAAC;AACrE,aAAO,iBAAiBA,OAAM;AAAA,IAChC,GAAG,SAAS;AAAA,EACd;AACF;",
  "names": ["module"]
}

@@ -32,7 +32,12 @@ __export(renameToCjsPlugin_exports, {
32
32
  module.exports = __toCommonJS(renameToCjsPlugin_exports);
33
33
  var import_String = require('../../String.cjs');
34
34
  var import_NodeModules = require('../NodeModules.cjs');
35
- var __process = globalThis["process"] ?? { "browser": true, "cwd": "[[Function:0]]", "env": {}, "platform": "android" };
35
+ var __process = globalThis["process"] ?? {
36
+ "browser": true,
37
+ "cwd": "[[Function0]]",
38
+ "env": {},
39
+ "platform": "android"
40
+ };
36
41
  function renameToCjsPlugin() {
37
42
  return {
38
43
  name: "rename-to-cjs",
@@ -61,4 +66,4 @@ function renameToCjsPlugin() {
61
66
  0 && (module.exports = {
62
67
  renameToCjsPlugin
63
68
  });
64
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC9yZW5hbWVUb0Nqc1BsdWdpbi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XCJicm93c2VyXCI6dHJ1ZSxcImN3ZFwiOlwiW1tGdW5jdGlvbjowXV1cIixcImVudlwiOnt9LFwicGxhdGZvcm1cIjpcImFuZHJvaWRcIn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiByZW5hbWVUb0Nqc1BsdWdpblxuICogVGhpcyBtb2R1bGUgZGVmaW5lcyBhbiBlc2J1aWxkIHBsdWdpbiB0aGF0IHJlbmFtZXMgSmF2YVNjcmlwdCBmaWxlcyB0byBDb21tb25KUyAoYC5janNgKSBmaWxlcyBhZnRlciB0aGUgYnVpbGQgcHJvY2Vzcy5cbiAqIEl0IGFsc28gYWRqdXN0cyB0aGUgYHJlcXVpcmVgIHN0YXRlbWVudHMgdG8gZW5zdXJlIGNvbXBhdGliaWxpdHkgd2l0aCB0aGUgQ29tbW9uSlMgZm9ybWF0LCBwYXJ0aWN1bGFybHkgd2hlbiBkZWFsaW5nXG4gKiB3aXRoIGRlcGVuZGVuY2llcyB0aGF0IGFyZSBub3QgdG8gYmUgc2tpcHBlZC5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ2VzYnVpbGQnO1xuXG5pbXBvcnQgeyByZXBsYWNlQWxsIH0gZnJvbSAnLi4vLi4vU3RyaW5nLnRzJztcbmltcG9ydCB7IHdyaXRlRmlsZSB9IGZyb20gJy4uL05vZGVNb2R1bGVzLnRzJztcblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVzYnVpbGQgcGx1Z2luIHRoYXQgcmVuYW1lcyBKYXZhU2NyaXB0IGZpbGVzIHRvIENvbW1vbkpTIChgLmNqc2ApIGZpbGVzXG4gKiBhbmQgbW9kaWZpZXMgYHJlcXVpcmVgIHN0YXRlbWVudHMgdG8gZW5zdXJlIHByb3BlciBtb2R1bGUgcmVzb2x1dGlvbi5cbiAqXG4gKiBAcmV0dXJucyBBbiBlc2J1aWxkIGBQbHVnaW5gIG9iamVjdCB0aGF0IGhhbmRsZXMgdGhlIHJlbmFtaW5nIGFuZCBtb2RpZmljYXRpb24gb2Ygb3V0cHV0IGZpbGVzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVuYW1lVG9DanNQbHVnaW4oKTogUGx1Z2luIHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAncmVuYW1lLXRvLWNqcycsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jIChyZXN1bHQpID0+IHtcbiAgICAgICAgZm9yIChjb25zdCBmaWxlIG9mIHJlc3VsdC5vdXRwdXRGaWxlcyA/PyBbXSkge1xuICAgICAgICAgIGlmICghZmlsZS5wYXRoLmVuZHNXaXRoKCcuanMnKSB8fCBmaWxlLnBhdGguZW5kc1dpdGgoJy5kLmpzJykpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IG5ld1BhdGggPSByZXBsYWNlQWxsKGZpbGUucGF0aCwgL1xcLmpzJC9nLCAnLmNqcycpO1xuXG4gICAgICAgICAgY29uc3QgbmV3VGV4dCA9IHJlcGxhY2VBbGwoZmlsZS50ZXh0LCAvcmVxdWlyZVxcKFtcIiddKC4rPylbXCInXVxcKS9nLCAoXywgX2ltcG9ydFBhdGg6IG51bWJlciB8IHN0cmluZykgPT4ge1xuICAgICAgICAgICAgY29uc3QgaW1wb3J0UGF0aCA9IF9pbXBvcnRQYXRoIGFzIHN0cmluZztcbiAgICAgICAgICAgIGlmIChpbXBvcnRQYXRoLmVuZHNXaXRoKCcuZC50cycpKSB7XG4gICAgICAgICAgICAgIHJldHVybiAndW5kZWZpbmVkJztcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc3QgY2pzSW1wb3J0UGF0aCA9IHJlcGxhY2VBbGwoaW1wb3J0UGF0aCwgL1xcLnRzJC9nLCAnLmNqcycpO1xuICAgICAgICAgICAgcmV0dXJuIGByZXF1aXJlKCcke2Nqc0ltcG9ydFBhdGh9JylgO1xuICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgYXdhaXQgd3JpdGVGaWxlKG5ld1BhdGgsIG5ld1RleHQpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBVUEsb0JBQTJCO0FBQzNCLHlCQUEwQjtBQVgxQixJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUssRUFBQyxXQUFVLE1BQUssT0FBTSxrQkFBaUIsT0FBTSxDQUFDLEdBQUUsWUFBVyxVQUFTO0FBbUJ0RyxTQUFTLG9CQUE0QjtBQUMxQyxTQUFPO0FBQUEsSUFDTCxNQUFNO0FBQUEsSUFDTixNQUFNLE9BQWE7QUFDakIsWUFBTSxNQUFNLE9BQU8sV0FBVztBQUM1QixtQkFBVyxRQUFRLE9BQU8sZUFBZSxDQUFDLEdBQUc7QUFDM0MsY0FBSSxDQUFDLEtBQUssS0FBSyxTQUFTLEtBQUssS0FBSyxLQUFLLEtBQUssU0FBUyxPQUFPLEdBQUc7QUFDN0Q7QUFBQSxVQUNGO0FBRUEsZ0JBQU0sY0FBVSwwQkFBVyxLQUFLLE1BQU0sVUFBVSxNQUFNO0FBRXRELGdCQUFNLGNBQVUsMEJBQVcsS0FBSyxNQUFNLDZCQUE2QixDQUFDLEdBQUcsZ0JBQWlDO0FBQ3RHLGtCQUFNLGFBQWE7QUFDbkIsZ0JBQUksV0FBVyxTQUFTLE9BQU8sR0FBRztBQUNoQyxxQkFBTztBQUFBLFlBQ1Q7QUFFQSxrQkFBTSxvQkFBZ0IsMEJBQVcsWUFBWSxVQUFVLE1BQU07QUFDN0QsbUJBQU8sWUFBWSxhQUFhO0FBQUEsVUFDbEMsQ0FBQztBQUVELG9CQUFNLDhCQUFVLFNBQVMsT0FBTztBQUFBLFFBQ2xDO0FBQUEsTUFDRixDQUFDO0FBQUEsSUFDSDtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
69
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC9yZW5hbWVUb0Nqc1BsdWdpbi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XG4gIFwiYnJvd3NlclwiOiB0cnVlLFxuICBcImN3ZFwiOiBcIltbRnVuY3Rpb24wXV1cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiByZW5hbWVUb0Nqc1BsdWdpblxuICogVGhpcyBtb2R1bGUgZGVmaW5lcyBhbiBlc2J1aWxkIHBsdWdpbiB0aGF0IHJlbmFtZXMgSmF2YVNjcmlwdCBmaWxlcyB0byBDb21tb25KUyAoYC5janNgKSBmaWxlcyBhZnRlciB0aGUgYnVpbGQgcHJvY2Vzcy5cbiAqIEl0IGFsc28gYWRqdXN0cyB0aGUgYHJlcXVpcmVgIHN0YXRlbWVudHMgdG8gZW5zdXJlIGNvbXBhdGliaWxpdHkgd2l0aCB0aGUgQ29tbW9uSlMgZm9ybWF0LCBwYXJ0aWN1bGFybHkgd2hlbiBkZWFsaW5nXG4gKiB3aXRoIGRlcGVuZGVuY2llcyB0aGF0IGFyZSBub3QgdG8gYmUgc2tpcHBlZC5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ2VzYnVpbGQnO1xuXG5pbXBvcnQgeyByZXBsYWNlQWxsIH0gZnJvbSAnLi4vLi4vU3RyaW5nLnRzJztcbmltcG9ydCB7IHdyaXRlRmlsZSB9IGZyb20gJy4uL05vZGVNb2R1bGVzLnRzJztcblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVzYnVpbGQgcGx1Z2luIHRoYXQgcmVuYW1lcyBKYXZhU2NyaXB0IGZpbGVzIHRvIENvbW1vbkpTIChgLmNqc2ApIGZpbGVzXG4gKiBhbmQgbW9kaWZpZXMgYHJlcXVpcmVgIHN0YXRlbWVudHMgdG8gZW5zdXJlIHByb3BlciBtb2R1bGUgcmVzb2x1dGlvbi5cbiAqXG4gKiBAcmV0dXJucyBBbiBlc2J1aWxkIGBQbHVnaW5gIG9iamVjdCB0aGF0IGhhbmRsZXMgdGhlIHJlbmFtaW5nIGFuZCBtb2RpZmljYXRpb24gb2Ygb3V0cHV0IGZpbGVzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVuYW1lVG9DanNQbHVnaW4oKTogUGx1Z2luIHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAncmVuYW1lLXRvLWNqcycsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jIChyZXN1bHQpID0+IHtcbiAgICAgICAgZm9yIChjb25zdCBmaWxlIG9mIHJlc3VsdC5vdXRwdXRGaWxlcyA/PyBbXSkge1xuICAgICAgICAgIGlmICghZmlsZS5wYXRoLmVuZHNXaXRoKCcuanMnKSB8fCBmaWxlLnBhdGguZW5kc1dpdGgoJy5kLmpzJykpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IG5ld1BhdGggPSByZXBsYWNlQWxsKGZpbGUucGF0aCwgL1xcLmpzJC9nLCAnLmNqcycpO1xuXG4gICAgICAgICAgY29uc3QgbmV3VGV4dCA9IHJlcGxhY2VBbGwoZmlsZS50ZXh0LCAvcmVxdWlyZVxcKFtcIiddKC4rPylbXCInXVxcKS9nLCAoXywgX2ltcG9ydFBhdGg6IG51bWJlciB8IHN0cmluZykgPT4ge1xuICAgICAgICAgICAgY29uc3QgaW1wb3J0UGF0aCA9IF9pbXBvcnRQYXRoIGFzIHN0cmluZztcbiAgICAgICAgICAgIGlmIChpbXBvcnRQYXRoLmVuZHNXaXRoKCcuZC50cycpKSB7XG4gICAgICAgICAgICAgIHJldHVybiAndW5kZWZpbmVkJztcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc3QgY2pzSW1wb3J0UGF0aCA9IHJlcGxhY2VBbGwoaW1wb3J0UGF0aCwgL1xcLnRzJC9nLCAnLmNqcycpO1xuICAgICAgICAgICAgcmV0dXJuIGByZXF1aXJlKCcke2Nqc0ltcG9ydFBhdGh9JylgO1xuICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgYXdhaXQgd3JpdGVGaWxlKG5ld1BhdGgsIG5ld1RleHQpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBZUEsb0JBQTJCO0FBQzNCLHlCQUEwQjtBQWhCMUIsSUFBSSxZQUFZLFdBQVcsU0FBUyxLQUFLO0FBQUEsRUFDdkMsV0FBVztBQUFBLEVBQ1gsT0FBTztBQUFBLEVBQ1AsT0FBTyxDQUFDO0FBQUEsRUFDUixZQUFZO0FBQ2Q7QUFtQk8sU0FBUyxvQkFBNEI7QUFDMUMsU0FBTztBQUFBLElBQ0wsTUFBTTtBQUFBLElBQ04sTUFBTSxPQUFhO0FBQ2pCLFlBQU0sTUFBTSxPQUFPLFdBQVc7QUFDNUIsbUJBQVcsUUFBUSxPQUFPLGVBQWUsQ0FBQyxHQUFHO0FBQzNDLGNBQUksQ0FBQyxLQUFLLEtBQUssU0FBUyxLQUFLLEtBQUssS0FBSyxLQUFLLFNBQVMsT0FBTyxHQUFHO0FBQzdEO0FBQUEsVUFDRjtBQUVBLGdCQUFNLGNBQVUsMEJBQVcsS0FBSyxNQUFNLFVBQVUsTUFBTTtBQUV0RCxnQkFBTSxjQUFVLDBCQUFXLEtBQUssTUFBTSw2QkFBNkIsQ0FBQyxHQUFHLGdCQUFpQztBQUN0RyxrQkFBTSxhQUFhO0FBQ25CLGdCQUFJLFdBQVcsU0FBUyxPQUFPLEdBQUc7QUFDaEMscUJBQU87QUFBQSxZQUNUO0FBRUEsa0JBQU0sb0JBQWdCLDBCQUFXLFlBQVksVUFBVSxNQUFNO0FBQzdELG1CQUFPLFlBQVksYUFBYTtBQUFBLFVBQ2xDLENBQUM7QUFFRCxvQkFBTSw4QkFBVSxTQUFTLE9BQU87QUFBQSxRQUNsQztBQUFBLE1BQ0YsQ0FBQztBQUFBLElBQ0g7QUFBQSxFQUNGO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==