obsidian-dev-utils 17.10.0 → 17.10.2-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (152) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/README.md +4 -2
  3. package/dist/lib/Async.mjs +154 -0
  4. package/dist/lib/Blob.mjs +81 -0
  5. package/dist/lib/CssClass.mjs +32 -0
  6. package/dist/lib/Debug.mjs +137 -0
  7. package/dist/lib/DebugController.mjs +8 -0
  8. package/dist/lib/Enum.mjs +26 -0
  9. package/dist/lib/Error.mjs +82 -0
  10. package/dist/lib/Function.mjs +28 -0
  11. package/dist/lib/HTMLElement.mjs +65 -0
  12. package/dist/lib/Library.cjs +2 -2
  13. package/dist/lib/Library.mjs +16 -0
  14. package/dist/lib/Object.cjs +1 -1
  15. package/dist/lib/Object.d.ts +16 -0
  16. package/dist/lib/Object.mjs +273 -0
  17. package/dist/lib/Path.mjs +76 -0
  18. package/dist/lib/RegExp.mjs +23 -0
  19. package/dist/lib/String.mjs +119 -0
  20. package/dist/lib/Transformers/DateTransformer.cjs +71 -0
  21. package/dist/lib/Transformers/DateTransformer.d.ts +35 -0
  22. package/dist/lib/Transformers/DateTransformer.mjs +47 -0
  23. package/dist/lib/Transformers/GroupTransformer.cjs +118 -0
  24. package/dist/lib/Transformers/GroupTransformer.d.ts +65 -0
  25. package/dist/lib/Transformers/GroupTransformer.mjs +94 -0
  26. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.cjs +69 -0
  27. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.d.ts +32 -0
  28. package/dist/lib/Transformers/SkipPrivatePropertyTransformer.mjs +45 -0
  29. package/dist/lib/Transformers/Transformer.cjs +107 -0
  30. package/dist/lib/Transformers/Transformer.d.ts +67 -0
  31. package/dist/lib/Transformers/Transformer.mjs +83 -0
  32. package/dist/lib/Transformers/TypedTransformer.cjs +38 -0
  33. package/dist/lib/Transformers/TypedTransformer.d.ts +37 -0
  34. package/dist/lib/Transformers/TypedTransformer.mjs +14 -0
  35. package/dist/lib/Transformers/index.cjs +58 -0
  36. package/dist/lib/Transformers/index.d.ts +5 -0
  37. package/dist/lib/Transformers/index.mjs +20 -0
  38. package/dist/lib/ValueProvider.mjs +20 -0
  39. package/dist/lib/codemirror/StateFieldSpec.mjs +8 -0
  40. package/dist/lib/codemirror/index.mjs +12 -0
  41. package/dist/lib/index.cjs +4 -4
  42. package/dist/lib/index.d.ts +1 -1
  43. package/dist/lib/index.mjs +50 -0
  44. package/dist/lib/obsidian/App.mjs +33 -0
  45. package/dist/lib/obsidian/AttachmentPath.mjs +82 -0
  46. package/dist/lib/obsidian/Backlink.mjs +88 -0
  47. package/dist/lib/obsidian/Callout.mjs +71 -0
  48. package/dist/lib/obsidian/Components/DateComponent.mjs +43 -0
  49. package/dist/lib/obsidian/Components/DateTimeComponent.mjs +43 -0
  50. package/dist/lib/obsidian/Components/EmailComponent.mjs +32 -0
  51. package/dist/lib/obsidian/Components/FileComponent.mjs +48 -0
  52. package/dist/lib/obsidian/Components/MonthComponent.mjs +51 -0
  53. package/dist/lib/obsidian/Components/MultipleDropdownComponent.mjs +88 -0
  54. package/dist/lib/obsidian/Components/MultipleEmailComponent.mjs +42 -0
  55. package/dist/lib/obsidian/Components/MultipleFileComponent.mjs +49 -0
  56. package/dist/lib/obsidian/Components/NumberComponent.mjs +32 -0
  57. package/dist/lib/obsidian/Components/TimeComponent.mjs +53 -0
  58. package/dist/lib/obsidian/Components/TypedRangeTextComponent.mjs +44 -0
  59. package/dist/lib/obsidian/Components/TypedTextComponent.mjs +107 -0
  60. package/dist/lib/obsidian/Components/UrlComponent.mjs +32 -0
  61. package/dist/lib/obsidian/Components/ValidatorComponent.mjs +52 -0
  62. package/dist/lib/obsidian/Components/ValueComponentWithChangeTracking.mjs +9 -0
  63. package/dist/lib/obsidian/Components/WeekComponent.mjs +51 -0
  64. package/dist/lib/obsidian/Components/index.mjs +42 -0
  65. package/dist/lib/obsidian/Dataview.mjs +232 -0
  66. package/dist/lib/obsidian/DataviewLink.mjs +27 -0
  67. package/dist/lib/obsidian/FileChange.mjs +123 -0
  68. package/dist/lib/obsidian/FileManager.mjs +66 -0
  69. package/dist/lib/obsidian/FileSystem.mjs +197 -0
  70. package/dist/lib/obsidian/Frontmatter.mjs +32 -0
  71. package/dist/lib/obsidian/Link.mjs +415 -0
  72. package/dist/lib/obsidian/Logger.mjs +45 -0
  73. package/dist/lib/obsidian/Loop.mjs +39 -0
  74. package/dist/lib/obsidian/Markdown.mjs +40 -0
  75. package/dist/lib/obsidian/MarkdownCodeBlockProcessor.mjs +44 -0
  76. package/dist/lib/obsidian/MarkdownView.mjs +21 -0
  77. package/dist/lib/obsidian/MetadataCache.mjs +219 -0
  78. package/dist/lib/obsidian/Modals/Alert.mjs +52 -0
  79. package/dist/lib/obsidian/Modals/Confirm.mjs +65 -0
  80. package/dist/lib/obsidian/Modals/Prompt.mjs +98 -0
  81. package/dist/lib/obsidian/Modals/SelectItem.mjs +51 -0
  82. package/dist/lib/obsidian/Modals/index.mjs +18 -0
  83. package/dist/lib/obsidian/ObsidianSettings.mjs +18 -0
  84. package/dist/lib/obsidian/Pdf.mjs +42 -0
  85. package/dist/lib/obsidian/Plugin/EmptySettings.mjs +14 -0
  86. package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.mjs +35 -0
  87. package/dist/lib/obsidian/Plugin/Plugin.mjs +28 -0
  88. package/dist/lib/obsidian/Plugin/PluginBase.mjs +148 -0
  89. package/dist/lib/obsidian/Plugin/PluginContext.mjs +45 -0
  90. package/dist/lib/obsidian/Plugin/PluginId.mjs +23 -0
  91. package/dist/lib/obsidian/Plugin/PluginSettingsBase.cjs +13 -9
  92. package/dist/lib/obsidian/Plugin/PluginSettingsBase.mjs +63 -0
  93. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.cjs +1 -1
  94. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.d.ts +1 -1
  95. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.mjs +101 -0
  96. package/dist/lib/obsidian/Plugin/index.mjs +26 -0
  97. package/dist/lib/obsidian/Queue.mjs +50 -0
  98. package/dist/lib/obsidian/Reference.mjs +45 -0
  99. package/dist/lib/obsidian/RenameDeleteHandler.mjs +436 -0
  100. package/dist/lib/obsidian/ResourceUrl.mjs +19 -0
  101. package/dist/lib/obsidian/SettingEx.mjs +148 -0
  102. package/dist/lib/obsidian/Vault.mjs +248 -0
  103. package/dist/lib/obsidian/VaultEx.mjs +71 -0
  104. package/dist/lib/obsidian/index.mjs +68 -0
  105. package/dist/lib/scripts/CliUtils.mjs +135 -0
  106. package/dist/lib/scripts/CodeGenerator.mjs +19 -0
  107. package/dist/lib/scripts/ESLint/ESLint.cjs +2 -2
  108. package/dist/lib/scripts/ESLint/ESLint.mjs +68 -0
  109. package/dist/lib/scripts/ESLint/eslint.config.mjs +287 -0
  110. package/dist/lib/scripts/ESLint/index.mjs +14 -0
  111. package/dist/lib/scripts/Exec.mjs +98 -0
  112. package/dist/lib/scripts/Fs.mjs +64 -0
  113. package/dist/lib/scripts/JSON.mjs +60 -0
  114. package/dist/lib/scripts/NodeModules.mjs +62 -0
  115. package/dist/lib/scripts/Npm.mjs +106 -0
  116. package/dist/lib/scripts/NpmPublish.mjs +21 -0
  117. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.cjs +5 -1
  118. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.d.ts +8 -0
  119. package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.mjs +44 -0
  120. package/dist/lib/scripts/Root.mjs +66 -0
  121. package/dist/lib/scripts/build.mjs +60 -0
  122. package/dist/lib/scripts/cli.cjs +2 -2
  123. package/dist/lib/scripts/cli.mjs +65 -0
  124. package/dist/lib/scripts/esbuild/Dependency.cjs +2 -2
  125. package/dist/lib/scripts/esbuild/Dependency.mjs +95 -0
  126. package/dist/lib/scripts/esbuild/ObsidianPluginBuilder.mjs +149 -0
  127. package/dist/lib/scripts/esbuild/changeExtensionPlugin.cjs +67 -0
  128. package/dist/lib/scripts/esbuild/changeExtensionPlugin.d.ts +12 -0
  129. package/dist/lib/scripts/esbuild/changeExtensionPlugin.mjs +43 -0
  130. package/dist/lib/scripts/esbuild/copyToObsidianPluginsFolderPlugin.mjs +50 -0
  131. package/dist/lib/scripts/esbuild/fixEsmPlugin.mjs +25 -0
  132. package/dist/lib/scripts/esbuild/fixSourceMapsPlugin.mjs +55 -0
  133. package/dist/lib/scripts/esbuild/index.cjs +4 -4
  134. package/dist/lib/scripts/esbuild/index.d.ts +1 -1
  135. package/dist/lib/scripts/esbuild/index.mjs +28 -0
  136. package/dist/lib/scripts/esbuild/preprocessPlugin.cjs +4 -4
  137. package/dist/lib/scripts/esbuild/preprocessPlugin.d.ts +2 -1
  138. package/dist/lib/scripts/esbuild/preprocessPlugin.mjs +112 -0
  139. package/dist/lib/scripts/esbuild/renameCssPlugin.mjs +31 -0
  140. package/dist/lib/scripts/esbuild/svelteWrapperPlugin.mjs +41 -0
  141. package/dist/lib/scripts/format.cjs +2 -2
  142. package/dist/lib/scripts/format.mjs +41 -0
  143. package/dist/lib/scripts/index.mjs +44 -0
  144. package/dist/lib/scripts/spellcheck.mjs +15 -0
  145. package/dist/lib/scripts/version.mjs +361 -0
  146. package/dist/lib/url.mjs +25 -0
  147. package/dist/styles.css +19 -56
  148. package/package.json +161 -173
  149. package/dist/lib/@types.cjs +0 -24
  150. package/dist/lib/@types.d.ts +0 -20
  151. package/dist/lib/scripts/esbuild/renameToCjsPlugin.cjs +0 -60
  152. package/dist/lib/scripts/esbuild/renameToCjsPlugin.d.ts +0 -14
@@ -0,0 +1,148 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){const module=originalRequire(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})()
7
+
8
+ import { Setting } from "obsidian";
9
+ import { DateComponent } from "./Components/DateComponent.mjs";
10
+ import { DateTimeComponent } from "./Components/DateTimeComponent.mjs";
11
+ import { EmailComponent } from "./Components/EmailComponent.mjs";
12
+ import { FileComponent } from "./Components/FileComponent.mjs";
13
+ import { MonthComponent } from "./Components/MonthComponent.mjs";
14
+ import { MultipleDropdownComponent } from "./Components/MultipleDropdownComponent.mjs";
15
+ import { MultipleEmailComponent } from "./Components/MultipleEmailComponent.mjs";
16
+ import { MultipleFileComponent } from "./Components/MultipleFileComponent.mjs";
17
+ import { NumberComponent } from "./Components/NumberComponent.mjs";
18
+ import { TimeComponent } from "./Components/TimeComponent.mjs";
19
+ import { UrlComponent } from "./Components/UrlComponent.mjs";
20
+ import { WeekComponent } from "./Components/WeekComponent.mjs";
21
+ class SettingEx extends Setting {
22
+ /**
23
+ * Adds a component to the setting.
24
+ *
25
+ * @typeParam T - The type of the component to add.
26
+ * @param componentClass - The class of the component to add.
27
+ * @param cb - The callback to call with the component.
28
+ * @returns The setting instance.
29
+ */
30
+ addComponent(componentClass, cb) {
31
+ const component = new componentClass(this.controlEl);
32
+ this.components.push(component);
33
+ cb(component);
34
+ return this;
35
+ }
36
+ /**
37
+ * Adds a {@link DateComponent} to the setting.
38
+ *
39
+ * @param cb - The callback to call with the component.
40
+ * @returns The setting instance.
41
+ */
42
+ addDate(cb) {
43
+ return this.addComponent(DateComponent, cb);
44
+ }
45
+ /**
46
+ * Adds a {@link DateTimeComponent} to the setting.
47
+ *
48
+ * @param cb - The callback to call with the component.
49
+ * @returns The setting instance.
50
+ */
51
+ addDateTime(cb) {
52
+ return this.addComponent(DateTimeComponent, cb);
53
+ }
54
+ /**
55
+ * Adds an {@link EmailComponent} to the setting.
56
+ *
57
+ * @param cb - The callback to call with the component.
58
+ * @returns The setting instance.
59
+ */
60
+ addEmail(cb) {
61
+ return this.addComponent(EmailComponent, cb);
62
+ }
63
+ /**
64
+ * Adds a {@link FileComponent} to the setting.
65
+ *
66
+ * @param cb - The callback to call with the component.
67
+ * @returns The setting instance.
68
+ */
69
+ addFile(cb) {
70
+ return this.addComponent(FileComponent, cb);
71
+ }
72
+ /**
73
+ * Adds a {@link MonthComponent} to the setting.
74
+ *
75
+ * @param cb - The callback to call with the component.
76
+ * @returns The setting instance.
77
+ */
78
+ addMonth(cb) {
79
+ return this.addComponent(MonthComponent, cb);
80
+ }
81
+ /**
82
+ * Adds a {@link MultipleDropdownComponent} to the setting.
83
+ *
84
+ * @param cb - The callback to call with the component.
85
+ * @returns The setting instance.
86
+ */
87
+ addMultipleDropdown(cb) {
88
+ return this.addComponent(MultipleDropdownComponent, cb);
89
+ }
90
+ /**
91
+ * Adds a {@link MultipleEmailComponent} to the setting.
92
+ *
93
+ * @param cb - The callback to call with the component.
94
+ * @returns The setting instance.
95
+ */
96
+ addMultipleEmail(cb) {
97
+ return this.addComponent(MultipleEmailComponent, cb);
98
+ }
99
+ /**
100
+ * Adds a {@link MultipleFileComponent} to the setting.
101
+ *
102
+ * @param cb - The callback to call with the component.
103
+ * @returns The setting instance.
104
+ */
105
+ addMultipleFile(cb) {
106
+ return this.addComponent(MultipleFileComponent, cb);
107
+ }
108
+ /**
109
+ * Adds a {@link NumberComponent} to the setting.
110
+ *
111
+ * @param cb - The callback to call with the component.
112
+ * @returns The setting instance.
113
+ */
114
+ addNumber(cb) {
115
+ return this.addComponent(NumberComponent, cb);
116
+ }
117
+ /**
118
+ * Adds a {@link TimeComponent} to the setting.
119
+ *
120
+ * @param cb - The callback to call with the component.
121
+ * @returns The setting instance.
122
+ */
123
+ addTime(cb) {
124
+ return this.addComponent(TimeComponent, cb);
125
+ }
126
+ /**
127
+ * Adds an {@link UrlComponent} to the setting.
128
+ *
129
+ * @param cb - The callback to call with the component.
130
+ * @returns The setting instance.
131
+ */
132
+ addUrl(cb) {
133
+ return this.addComponent(UrlComponent, cb);
134
+ }
135
+ /**
136
+ * Adds a {@link WeekComponent} to the setting.
137
+ *
138
+ * @param cb - The callback to call with the component.
139
+ * @returns The setting instance.
140
+ */
141
+ addWeek(cb) {
142
+ return this.addComponent(WeekComponent, cb);
143
+ }
144
+ }
145
+ export {
146
+ SettingEx
147
+ };
148
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/SettingEx.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation SettingEx\n * Extends the Setting class with additional methods for adding components.\n */\n\nimport type { BaseComponent } from 'obsidian';\n\nimport { Setting } from 'obsidian';\n\nimport { DateComponent } from './Components/DateComponent.ts';\nimport { DateTimeComponent } from './Components/DateTimeComponent.ts';\nimport { EmailComponent } from './Components/EmailComponent.ts';\nimport { FileComponent } from './Components/FileComponent.ts';\nimport { MonthComponent } from './Components/MonthComponent.ts';\nimport { MultipleDropdownComponent } from './Components/MultipleDropdownComponent.ts';\nimport { MultipleEmailComponent } from './Components/MultipleEmailComponent.ts';\nimport { MultipleFileComponent } from './Components/MultipleFileComponent.ts';\nimport { NumberComponent } from './Components/NumberComponent.ts';\nimport { TimeComponent } from './Components/TimeComponent.ts';\nimport { UrlComponent } from './Components/UrlComponent.ts';\nimport { WeekComponent } from './Components/WeekComponent.ts';\n\n/**\n * Extends the Setting class with additional methods for adding components.\n */\nexport class SettingEx extends Setting {\n  /**\n   * Adds a component to the setting.\n   *\n   * @typeParam T - The type of the component to add.\n   * @param componentClass - The class of the component to add.\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addComponent<T extends BaseComponent>(componentClass: new (controlEl: HTMLElement) => T, cb: (component: T) => void): this {\n    const component = new componentClass(this.controlEl);\n    this.components.push(component);\n    cb(component);\n    return this;\n  }\n\n  /**\n   * Adds a {@link DateComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDate(cb: (component: DateComponent) => void): this {\n    return this.addComponent(DateComponent, cb);\n  }\n\n  /**\n   * Adds a {@link DateTimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDateTime(cb: (component: DateTimeComponent) => void): this {\n    return this.addComponent(DateTimeComponent, cb);\n  }\n\n  /**\n   * Adds an {@link EmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addEmail(cb: (component: EmailComponent) => void): this {\n    return this.addComponent(EmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link FileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addFile(cb: (component: FileComponent) => void): this {\n    return this.addComponent(FileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MonthComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMonth(cb: (component: MonthComponent) => void): this {\n    return this.addComponent(MonthComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleDropdown(cb: (component: MultipleDropdownComponent) => void): this {\n    return this.addComponent(MultipleDropdownComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleEmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleEmail(cb: (component: MultipleEmailComponent) => void): this {\n    return this.addComponent(MultipleEmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleFileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleFile(cb: (component: MultipleFileComponent) => void): this {\n    return this.addComponent(MultipleFileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link NumberComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addNumber(cb: (component: NumberComponent) => void): this {\n    return this.addComponent(NumberComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTime(cb: (component: TimeComponent) => void): this {\n    return this.addComponent(TimeComponent, cb);\n  }\n\n  /**\n   * Adds an {@link UrlComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addUrl(cb: (component: UrlComponent) => void): this {\n    return this.addComponent(UrlComponent, cb);\n  }\n\n  /**\n   * Adds a {@link WeekComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addWeek(cb: (component: WeekComponent) => void): this {\n    return this.addComponent(WeekComponent, cb);\n  }\n}\n"],
  "mappings": ";;;;;;;AAOA,SAAS,eAAe;AAExB,SAAS,qBAAqB;AAC9B,SAAS,yBAAyB;AAClC,SAAS,sBAAsB;AAC/B,SAAS,qBAAqB;AAC9B,SAAS,sBAAsB;AAC/B,SAAS,iCAAiC;AAC1C,SAAS,8BAA8B;AACvC,SAAS,6BAA6B;AACtC,SAAS,uBAAuB;AAChC,SAAS,qBAAqB;AAC9B,SAAS,oBAAoB;AAC7B,SAAS,qBAAqB;AAKvB,MAAM,kBAAkB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAS9B,aAAsC,gBAAmD,IAAkC;AAChI,UAAM,YAAY,IAAI,eAAe,KAAK,SAAS;AACnD,SAAK,WAAW,KAAK,SAAS;AAC9B,OAAG,SAAS;AACZ,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,eAAe,EAAE;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,YAAY,IAAkD;AACnE,WAAO,KAAK,aAAa,mBAAmB,EAAE;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,SAAS,IAA+C;AAC7D,WAAO,KAAK,aAAa,gBAAgB,EAAE;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,eAAe,EAAE;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,SAAS,IAA+C;AAC7D,WAAO,KAAK,aAAa,gBAAgB,EAAE;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,oBAAoB,IAA0D;AACnF,WAAO,KAAK,aAAa,2BAA2B,EAAE;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,iBAAiB,IAAuD;AAC7E,WAAO,KAAK,aAAa,wBAAwB,EAAE;AAAA,EACrD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,gBAAgB,IAAsD;AAC3E,WAAO,KAAK,aAAa,uBAAuB,EAAE;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAU,IAAgD;AAC/D,WAAO,KAAK,aAAa,iBAAiB,EAAE;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,eAAe,EAAE;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,OAAO,IAA6C;AACzD,WAAO,KAAK,aAAa,cAAc,EAAE;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,QAAQ,IAA8C;AAC3D,WAAO,KAAK,aAAa,eAAe,EAAE;AAAA,EAC5C;AACF;",
  "names": []
}

@@ -0,0 +1,248 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){const module=originalRequire(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})()
7
+
8
+ import {
9
+ App,
10
+ TFile
11
+ } from "obsidian";
12
+ import { parentFolderPath } from "obsidian-typings/implementations";
13
+ import { retryWithTimeout } from "../Async.mjs";
14
+ import { noopAsync } from "../Function.mjs";
15
+ import {
16
+ basename,
17
+ dirname,
18
+ extname,
19
+ join
20
+ } from "../Path.mjs";
21
+ import { resolveValue } from "../ValueProvider.mjs";
22
+ import {
23
+ getFile,
24
+ getFileOrNull,
25
+ getFolder,
26
+ getFolderOrNull,
27
+ getPath,
28
+ isFile,
29
+ isNote
30
+ } from "./FileSystem.mjs";
31
+ async function copySafe(app, oldPathOrFile, newPath) {
32
+ const file = getFile(app, oldPathOrFile);
33
+ const newFolderPath = parentFolderPath(newPath);
34
+ await createFolderSafe(app, newFolderPath);
35
+ const newAvailablePath = getAvailablePath(app, newPath);
36
+ try {
37
+ await app.vault.copy(file, newAvailablePath);
38
+ } catch (e) {
39
+ if (!await app.vault.exists(newAvailablePath)) {
40
+ throw e;
41
+ }
42
+ }
43
+ return newAvailablePath;
44
+ }
45
+ async function createFolderSafe(app, path) {
46
+ if (await app.vault.adapter.exists(path)) {
47
+ return false;
48
+ }
49
+ try {
50
+ await app.vault.createFolder(path);
51
+ return true;
52
+ } catch (e) {
53
+ if (!await app.vault.exists(path)) {
54
+ throw e;
55
+ }
56
+ return true;
57
+ }
58
+ }
59
+ async function createTempFile(app, path) {
60
+ let file = getFileOrNull(app, path);
61
+ if (file) {
62
+ return noopAsync;
63
+ }
64
+ const folderCleanup = await createTempFolder(app, parentFolderPath(path));
65
+ try {
66
+ await app.vault.create(path, "");
67
+ } catch (e) {
68
+ if (!await app.vault.exists(path)) {
69
+ throw e;
70
+ }
71
+ }
72
+ return async () => {
73
+ file = getFile(app, path);
74
+ if (!file.deleted) {
75
+ await app.fileManager.trashFile(file);
76
+ }
77
+ await folderCleanup();
78
+ };
79
+ }
80
+ async function createTempFolder(app, path) {
81
+ let folder = getFolderOrNull(app, path);
82
+ if (folder) {
83
+ return noopAsync;
84
+ }
85
+ const dirPath = parentFolderPath(path);
86
+ await createTempFolder(app, dirPath);
87
+ const folderCleanup = await createTempFolder(app, parentFolderPath(path));
88
+ await createFolderSafe(app, path);
89
+ return async () => {
90
+ folder = getFolder(app, path);
91
+ if (!folder.deleted) {
92
+ await app.fileManager.trashFile(folder);
93
+ }
94
+ await folderCleanup();
95
+ };
96
+ }
97
+ function getAvailablePath(app, path) {
98
+ const ext = extname(path);
99
+ return app.vault.getAvailablePath(join(dirname(path), basename(path, ext)), ext.slice(1));
100
+ }
101
+ function getMarkdownFilesSorted(app) {
102
+ return app.vault.getMarkdownFiles().sort((a, b) => a.path.localeCompare(b.path));
103
+ }
104
+ function getNoteFilesSorted(app) {
105
+ return app.vault.getAllLoadedFiles().filter((file) => isFile(file) && isNote(app, file)).sort((a, b) => a.path.localeCompare(b.path));
106
+ }
107
+ function getSafeRenamePath(app, oldPathOrFile, newPath) {
108
+ const oldPath = getPath(app, oldPathOrFile);
109
+ if (app.vault.adapter.insensitive) {
110
+ let folderPath = dirname(newPath);
111
+ let nonExistingPath = basename(newPath);
112
+ let folder;
113
+ for (; ; ) {
114
+ folder = getFolderOrNull(app, folderPath, true);
115
+ if (folder) {
116
+ break;
117
+ }
118
+ nonExistingPath = join(basename(folderPath), nonExistingPath);
119
+ folderPath = dirname(folderPath);
120
+ }
121
+ newPath = join(folder.getParentPrefix(), nonExistingPath);
122
+ }
123
+ if (oldPath.toLowerCase() === newPath.toLowerCase()) {
124
+ return newPath;
125
+ }
126
+ return getAvailablePath(app, newPath);
127
+ }
128
+ async function isEmptyFolder(app, pathOrFolder) {
129
+ const listedFiles = await listSafe(app, getPath(app, pathOrFolder));
130
+ return listedFiles.files.length === 0 && listedFiles.folders.length === 0;
131
+ }
132
+ async function listSafe(app, pathOrFolder) {
133
+ const path = getPath(app, pathOrFolder);
134
+ const EMPTY = { files: [], folders: [] };
135
+ if ((await app.vault.adapter.stat(path))?.type !== "folder") {
136
+ return EMPTY;
137
+ }
138
+ try {
139
+ return await app.vault.adapter.list(path);
140
+ } catch (e) {
141
+ if (await app.vault.exists(path)) {
142
+ throw e;
143
+ }
144
+ return EMPTY;
145
+ }
146
+ }
147
+ async function process(app, pathOrFile, newContentProvider, options = {}) {
148
+ const DEFAULT_RETRY_OPTIONS = {
149
+ shouldFailOnMissingFile: true
150
+ };
151
+ const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...options };
152
+ await retryWithTimeout(async () => {
153
+ const oldContent = await readSafe(app, pathOrFile);
154
+ if (oldContent === null) {
155
+ return handleMissingFile();
156
+ }
157
+ const newContent = await resolveValue(newContentProvider, oldContent);
158
+ if (newContent === null) {
159
+ return false;
160
+ }
161
+ let isSuccess = true;
162
+ const doesFileExist = await invokeFileActionSafe(app, pathOrFile, async (file) => {
163
+ await app.vault.process(file, (content) => {
164
+ if (content !== oldContent) {
165
+ console.warn("Content has changed since it was read. Retrying...", {
166
+ actualContent: content,
167
+ expectedContent: oldContent,
168
+ path: file.path
169
+ });
170
+ isSuccess = false;
171
+ return content;
172
+ }
173
+ return newContent;
174
+ });
175
+ });
176
+ if (!doesFileExist) {
177
+ return handleMissingFile();
178
+ }
179
+ return isSuccess;
180
+ function handleMissingFile() {
181
+ if (fullOptions.shouldFailOnMissingFile) {
182
+ const path = getPath(app, pathOrFile);
183
+ throw new Error(`File '${path}' not found`);
184
+ }
185
+ return true;
186
+ }
187
+ }, fullOptions);
188
+ }
189
+ async function readSafe(app, pathOrFile) {
190
+ let content = null;
191
+ await invokeFileActionSafe(app, pathOrFile, async (file) => {
192
+ content = await app.vault.read(file);
193
+ });
194
+ return content;
195
+ }
196
+ async function renameSafe(app, oldPathOrFile, newPath) {
197
+ const oldFile = getFile(app, oldPathOrFile, false, true);
198
+ const newAvailablePath = getSafeRenamePath(app, oldPathOrFile, newPath);
199
+ if (oldFile.path.toLowerCase() === newAvailablePath.toLowerCase()) {
200
+ if (oldFile.path !== newPath) {
201
+ await app.vault.rename(oldFile, newAvailablePath);
202
+ }
203
+ return newAvailablePath;
204
+ }
205
+ const newFolderPath = parentFolderPath(newAvailablePath);
206
+ await createFolderSafe(app, newFolderPath);
207
+ try {
208
+ await app.vault.rename(oldFile, newAvailablePath);
209
+ } catch (e) {
210
+ if (!await app.vault.exists(newAvailablePath) || await app.vault.exists(oldFile.path)) {
211
+ throw e;
212
+ }
213
+ }
214
+ return newAvailablePath;
215
+ }
216
+ async function invokeFileActionSafe(app, pathOrFile, fileAction) {
217
+ const path = getPath(app, pathOrFile);
218
+ let file = getFileOrNull(app, path);
219
+ if (!file || file.deleted) {
220
+ return false;
221
+ }
222
+ try {
223
+ await fileAction(file);
224
+ return true;
225
+ } catch (e) {
226
+ file = getFileOrNull(app, path);
227
+ if (!file || file.deleted) {
228
+ return false;
229
+ }
230
+ throw e;
231
+ }
232
+ }
233
+ export {
234
+ copySafe,
235
+ createFolderSafe,
236
+ createTempFile,
237
+ createTempFolder,
238
+ getAvailablePath,
239
+ getMarkdownFilesSorted,
240
+ getNoteFilesSorted,
241
+ getSafeRenamePath,
242
+ isEmptyFolder,
243
+ listSafe,
244
+ process,
245
+ readSafe,
246
+ renameSafe
247
+ };
248
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Vault.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Vault\n * This module provides utility functions for working with the Obsidian Vault.\n */\n\nimport type {\n  ListedFiles,\n  TFolder\n} from 'obsidian';\n\nimport {\n  App,\n  TFile\n} from 'obsidian';\nimport { parentFolderPath } from 'obsidian-typings/implementations';\n\nimport type { RetryOptions } from '../Async.ts';\nimport type { ValueProvider } from '../ValueProvider.ts';\nimport type {\n  PathOrFile,\n  PathOrFolder\n} from './FileSystem.ts';\n\nimport { retryWithTimeout } from '../Async.ts';\nimport { noopAsync } from '../Function.ts';\nimport {\n  basename,\n  dirname,\n  extname,\n  join\n} from '../Path.ts';\nimport { resolveValue } from '../ValueProvider.ts';\nimport {\n  getFile,\n  getFileOrNull,\n  getFolder,\n  getFolderOrNull,\n  getPath,\n  isFile,\n  isNote\n} from './FileSystem.ts';\n\n/**\n * Options for the `process` function.\n */\nexport interface ProcessOptions extends RetryOptions {\n  /**\n   * If `true`, the function will throw an error if the file is missing or deleted.\n   */\n  shouldFailOnMissingFile?: boolean;\n}\n\n/**\n * Copies a file safely in the vault.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to copy.\n * @param newPath - The new path to copy the file to.\n * @returns A promise that resolves to the new path of the copied file.\n */\nexport async function copySafe(app: App, oldPathOrFile: PathOrFile, newPath: string): Promise<string> {\n  const file = getFile(app, oldPathOrFile);\n\n  const newFolderPath = parentFolderPath(newPath);\n  await createFolderSafe(app, newFolderPath);\n\n  const newAvailablePath = getAvailablePath(app, newPath);\n\n  try {\n    await app.vault.copy(file, newAvailablePath);\n  } catch (e) {\n    if (!await app.vault.exists(newAvailablePath)) {\n      throw e;\n    }\n  }\n\n  return newAvailablePath;\n}\n\n/**\n * Creates a folder safely in the specified path.\n *\n * @param app - The application instance.\n * @param path - The path of the folder to create.\n * @returns A promise that resolves to a boolean indicating whether the folder was created.\n * @throws If an error occurs while creating the folder and it still doesn't exist.\n */\nexport async function createFolderSafe(app: App, path: string): Promise<boolean> {\n  if (await app.vault.adapter.exists(path)) {\n    return false;\n  }\n\n  try {\n    await app.vault.createFolder(path);\n    return true;\n  } catch (e) {\n    if (!await app.vault.exists(path)) {\n      throw e;\n    }\n    return true;\n  }\n}\n\n/**\n * Creates a temporary file in the vault with parent folders if needed.\n * @param app - The application instance.\n * @param path - The path of the file to create.\n * @returns A promise that resolves to a function that can be called to delete the temporary file and all its created parents.\n */\nexport async function createTempFile(app: App, path: string): Promise<() => Promise<void>> {\n  let file = getFileOrNull(app, path);\n  if (file) {\n    return noopAsync;\n  }\n\n  const folderCleanup = await createTempFolder(app, parentFolderPath(path));\n\n  try {\n    await app.vault.create(path, '');\n  } catch (e) {\n    if (!await app.vault.exists(path)) {\n      throw e;\n    }\n  }\n\n  return async () => {\n    file = getFile(app, path);\n    if (!file.deleted) {\n      await app.fileManager.trashFile(file);\n    }\n    await folderCleanup();\n  };\n}\n\n/**\n * Creates a temporary folder in the vault with parent folders if needed.\n * @param app - The application instance.\n * @param path - The path of the folder to create.\n * @returns A promise that resolves to a function that can be called to delete the temporary folder and all its created parents.\n */\nexport async function createTempFolder(app: App, path: string): Promise<() => Promise<void>> {\n  let folder = getFolderOrNull(app, path);\n  if (folder) {\n    return noopAsync;\n  }\n\n  const dirPath = parentFolderPath(path);\n  await createTempFolder(app, dirPath);\n\n  const folderCleanup = await createTempFolder(app, parentFolderPath(path));\n\n  await createFolderSafe(app, path);\n\n  return async () => {\n    folder = getFolder(app, path);\n    if (!folder.deleted) {\n      await app.fileManager.trashFile(folder);\n    }\n    await folderCleanup();\n  };\n}\n\n/**\n * Gets an available path for a file in the vault.\n *\n * @param app - The application instance.\n * @param path - The path of the file to get an available path for.\n * @returns The available path for the file.\n */\nexport function getAvailablePath(app: App, path: string): string {\n  const ext = extname(path);\n  return app.vault.getAvailablePath(join(dirname(path), basename(path, ext)), ext.slice(1));\n}\n\n/**\n * Retrieves an array of Markdown files from the app's vault and sorts them alphabetically by their file path.\n *\n * @param app - The Obsidian app instance.\n * @returns An array of Markdown files sorted by file path.\n */\nexport function getMarkdownFilesSorted(app: App): TFile[] {\n  return app.vault.getMarkdownFiles().sort((a, b) => a.path.localeCompare(b.path));\n}\n\n/**\n * Retrieves an array of all note files from the app's vault and sorts them alphabetically by their file path.\n * @param app - The Obsidian app instance.\n * @returns An array of all note files in the vault sorted by file path.\n */\nexport function getNoteFilesSorted(app: App): TFile[] {\n  return app.vault.getAllLoadedFiles().filter((file) => isFile(file) && isNote(app, file)).sort((a, b) => a.path.localeCompare(b.path)) as TFile[];\n}\n\n/**\n * Gets a safe rename path for a file.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to rename.\n * @param newPath - The new path to rename the file to.\n * @returns The safe rename path for the file.\n */\nexport function getSafeRenamePath(app: App, oldPathOrFile: PathOrFile, newPath: string): string {\n  const oldPath = getPath(app, oldPathOrFile);\n\n  if (app.vault.adapter.insensitive) {\n    let folderPath = dirname(newPath);\n    let nonExistingPath = basename(newPath);\n    let folder: null | TFolder;\n    for (;;) {\n      folder = getFolderOrNull(app, folderPath, true);\n      if (folder) {\n        break;\n      }\n      nonExistingPath = join(basename(folderPath), nonExistingPath);\n      folderPath = dirname(folderPath);\n    }\n    newPath = join(folder.getParentPrefix(), nonExistingPath);\n  }\n\n  if (oldPath.toLowerCase() === newPath.toLowerCase()) {\n    return newPath;\n  }\n\n  return getAvailablePath(app, newPath);\n}\n\n/**\n * Checks if a folder is empty.\n * @param app - The application instance.\n * @param pathOrFolder - The path or folder to check.\n * @returns A promise that resolves to a boolean indicating whether the folder is empty.\n */\nexport async function isEmptyFolder(app: App, pathOrFolder: PathOrFolder): Promise<boolean> {\n  const listedFiles = await listSafe(app, getPath(app, pathOrFolder));\n  return listedFiles.files.length === 0 && listedFiles.folders.length === 0;\n}\n\n/**\n * Safely lists the files and folders at the specified path in the vault.\n *\n * @param app - The Obsidian application instance.\n * @param pathOrFolder - The path or folder to list.\n * @returns A promise that resolves to a `ListedFiles` object containing the listed files and folders.\n */\nexport async function listSafe(app: App, pathOrFolder: PathOrFolder): Promise<ListedFiles> {\n  const path = getPath(app, pathOrFolder);\n  const EMPTY = { files: [], folders: [] };\n\n  if ((await app.vault.adapter.stat(path))?.type !== 'folder') {\n    return EMPTY;\n  }\n\n  try {\n    return await app.vault.adapter.list(path);\n  } catch (e) {\n    if (await app.vault.exists(path)) {\n      throw e;\n    }\n    return EMPTY;\n  }\n}\n\n/**\n * Processes a file with retry logic, updating its content based on a provided value or function.\n *\n * @param app - The application instance, typically used for accessing the vault.\n * @param pathOrFile - The path or file to be processed. It can be a string representing the path or a file object.\n * @param newContentProvider - A value provider that returns the new content based on the old content of the file.\n * It can be a string or a function that takes the old content as an argument and returns the new content.\n * If function is provided, it should return `null` if the process should be retried.\n * @param options - Optional options for processing/retrying the operation.\n *\n * @returns A promise that resolves once the process is complete.\n *\n * @throws Will throw an error if the process fails after the specified number of retries or timeout.\n */\nexport async function process(\n  app: App,\n  pathOrFile: PathOrFile,\n  newContentProvider: ValueProvider<null | string, [string]>,\n  options: ProcessOptions = {}\n): Promise<void> {\n  const DEFAULT_RETRY_OPTIONS = {\n    shouldFailOnMissingFile: true\n  };\n  const fullOptions = { ...DEFAULT_RETRY_OPTIONS, ...options };\n\n  await retryWithTimeout(async () => {\n    const oldContent = await readSafe(app, pathOrFile);\n\n    if (oldContent === null) {\n      return handleMissingFile();\n    }\n\n    const newContent = await resolveValue(newContentProvider, oldContent);\n    if (newContent === null) {\n      return false;\n    }\n\n    let isSuccess = true;\n    const doesFileExist = await invokeFileActionSafe(app, pathOrFile, async (file) => {\n      await app.vault.process(file, (content) => {\n        if (content !== oldContent) {\n          console.warn('Content has changed since it was read. Retrying...', {\n            actualContent: content,\n            expectedContent: oldContent,\n            path: file.path\n          });\n          isSuccess = false;\n          return content;\n        }\n\n        return newContent;\n      });\n    });\n\n    if (!doesFileExist) {\n      return handleMissingFile();\n    }\n\n    return isSuccess;\n\n    function handleMissingFile(): boolean {\n      if (fullOptions.shouldFailOnMissingFile) {\n        const path = getPath(app, pathOrFile);\n        throw new Error(`File '${path}' not found`);\n      }\n      return true;\n    }\n  }, fullOptions);\n}\n\n/**\n * Reads the content of a file safely from the vault.\n *\n * It covers the case when the file was removed during the reading.\n *\n * @param app - The application instance.\n * @param pathOrFile - The path or file to read.\n * @returns A promise that resolves to the content of the file or `null` if the file is missing or deleted.\n */\nexport async function readSafe(app: App, pathOrFile: PathOrFile): Promise<null | string> {\n  let content: null | string = null;\n  await invokeFileActionSafe(app, pathOrFile, async (file) => {\n    content = await app.vault.read(file);\n  });\n  return content;\n}\n\n/**\n * Renames a file safely in the vault.\n * If the new path already exists, the file will be renamed to an available path.\n *\n * @param app - The application instance.\n * @param oldPathOrFile - The old path or file to rename.\n * @param newPath - The new path to rename the file to.\n * @returns A promise that resolves to the new path of the file.\n */\nexport async function renameSafe(app: App, oldPathOrFile: PathOrFile, newPath: string): Promise<string> {\n  const oldFile = getFile(app, oldPathOrFile, false, true);\n\n  const newAvailablePath = getSafeRenamePath(app, oldPathOrFile, newPath);\n\n  if (oldFile.path.toLowerCase() === newAvailablePath.toLowerCase()) {\n    if (oldFile.path !== newPath) {\n      await app.vault.rename(oldFile, newAvailablePath);\n    }\n    return newAvailablePath;\n  }\n\n  const newFolderPath = parentFolderPath(newAvailablePath);\n  await createFolderSafe(app, newFolderPath);\n\n  try {\n    await app.vault.rename(oldFile, newAvailablePath);\n  } catch (e) {\n    if (!await app.vault.exists(newAvailablePath) || await app.vault.exists(oldFile.path)) {\n      throw e;\n    }\n  }\n\n  return newAvailablePath;\n}\n\nasync function invokeFileActionSafe(app: App, pathOrFile: PathOrFile, fileAction: (file: TFile) => Promise<void>): Promise<boolean> {\n  const path = getPath(app, pathOrFile);\n  let file = getFileOrNull(app, path);\n  if (!file || file.deleted) {\n    return false;\n  }\n  try {\n    await fileAction(file);\n    return true;\n  } catch (e) {\n    file = getFileOrNull(app, path);\n    if (!file || file.deleted) {\n      return false;\n    }\n    throw e;\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,71 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){const module=originalRequire(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})()
7
+
8
+ import { printError } from "../Error.mjs";
9
+ import {
10
+ getAbstractFileOrNull,
11
+ getFolderOrNull,
12
+ isFile,
13
+ isFolder
14
+ } from "./FileSystem.mjs";
15
+ import { getBacklinksForFileSafe } from "./MetadataCache.mjs";
16
+ import {
17
+ isEmptyFolder,
18
+ listSafe
19
+ } from "./Vault.mjs";
20
+ async function deleteEmptyFolderHierarchy(app, pathOrFolder) {
21
+ let folder = getFolderOrNull(app, pathOrFolder);
22
+ while (folder) {
23
+ if (!await isEmptyFolder(app, folder)) {
24
+ return;
25
+ }
26
+ const parent = folder.parent;
27
+ await deleteSafe(app, folder.path);
28
+ folder = parent;
29
+ }
30
+ }
31
+ async function deleteSafe(app, pathOrFile, deletedNotePath, shouldReportUsedAttachments, shouldDeleteEmptyFolders) {
32
+ const file = getAbstractFileOrNull(app, pathOrFile);
33
+ if (!file) {
34
+ return false;
35
+ }
36
+ let canDelete = isFile(file) || (shouldDeleteEmptyFolders ?? true);
37
+ if (isFile(file)) {
38
+ const backlinks = await getBacklinksForFileSafe(app, file);
39
+ if (deletedNotePath) {
40
+ backlinks.clear(deletedNotePath);
41
+ }
42
+ if (backlinks.count() !== 0) {
43
+ if (shouldReportUsedAttachments) {
44
+ new Notice(`Attachment ${file.path} is still used by other notes. It will not be deleted.`);
45
+ }
46
+ canDelete = false;
47
+ }
48
+ } else if (isFolder(file)) {
49
+ const listedFiles = await listSafe(app, file);
50
+ for (const child of [...listedFiles.files, ...listedFiles.folders]) {
51
+ canDelete &&= await deleteSafe(app, child, deletedNotePath, shouldReportUsedAttachments);
52
+ }
53
+ canDelete &&= await isEmptyFolder(app, file);
54
+ }
55
+ if (canDelete) {
56
+ try {
57
+ await app.fileManager.trashFile(file);
58
+ } catch (e) {
59
+ if (await app.vault.exists(file.path)) {
60
+ printError(new Error(`Failed to delete ${file.path}`, { cause: e }));
61
+ canDelete = false;
62
+ }
63
+ }
64
+ }
65
+ return canDelete;
66
+ }
67
+ export {
68
+ deleteEmptyFolderHierarchy,
69
+ deleteSafe
70
+ };
71
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL1ZhdWx0RXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIFZhdWx0RXhcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIGFkZGl0aW9uYWwgdXRpbGl0aWVzIGZvciB3b3JraW5nIHdpdGggdGhlIE9ic2lkaWFuIFZhdWx0LlxuICpcbiAqIEl0IGhhcyB0byBiZSBleHRyYWN0ZWQgZnJvbSBgVmF1bHRgIGJlY2F1c2Ugb2YgY2lyY3VsYXIgZGVwZW5kZW5jaWVzLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQXBwIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgdHlwZSB7XG4gIFBhdGhPckFic3RyYWN0RmlsZSxcbiAgUGF0aE9yRm9sZGVyXG59IGZyb20gJy4vRmlsZVN5c3RlbS50cyc7XG5cbmltcG9ydCB7IHByaW50RXJyb3IgfSBmcm9tICcuLi9FcnJvci50cyc7XG5pbXBvcnQge1xuICBnZXRBYnN0cmFjdEZpbGVPck51bGwsXG4gIGdldEZvbGRlck9yTnVsbCxcbiAgaXNGaWxlLFxuICBpc0ZvbGRlclxufSBmcm9tICcuL0ZpbGVTeXN0ZW0udHMnO1xuaW1wb3J0IHsgZ2V0QmFja2xpbmtzRm9yRmlsZVNhZmUgfSBmcm9tICcuL01ldGFkYXRhQ2FjaGUudHMnO1xuaW1wb3J0IHtcbiAgaXNFbXB0eUZvbGRlcixcbiAgbGlzdFNhZmVcbn0gZnJvbSAnLi9WYXVsdC50cyc7XG5cbi8qKlxuICogUmVtb3ZlcyBlbXB0eSBmb2xkZXIgaGllcmFyY2h5IHN0YXJ0aW5nIGZyb20gdGhlIGdpdmVuIGZvbGRlci5cbiAqXG4gKiBAcGFyYW0gYXBwIC0gVGhlIGFwcGxpY2F0aW9uIGluc3RhbmNlLlxuICogQHBhcmFtIHBhdGhPckZvbGRlciAtIFRoZSBmb2xkZXIgdG8gc3RhcnQgcmVtb3ZpbmcgZW1wdHkgaGllcmFyY2h5IGZyb20uXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBlbXB0eSBoaWVyYXJjaHkgaXMgZGVsZXRlZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRlbGV0ZUVtcHR5Rm9sZGVySGllcmFyY2h5KGFwcDogQXBwLCBwYXRoT3JGb2xkZXI6IG51bGwgfCBQYXRoT3JGb2xkZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgbGV0IGZvbGRlciA9IGdldEZvbGRlck9yTnVsbChhcHAsIHBhdGhPckZvbGRlcik7XG5cbiAgd2hpbGUgKGZvbGRlcikge1xuICAgIGlmICghYXdhaXQgaXNFbXB0eUZvbGRlcihhcHAsIGZvbGRlcikpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgY29uc3QgcGFyZW50ID0gZm9sZGVyLnBhcmVudDtcbiAgICBhd2FpdCBkZWxldGVTYWZlKGFwcCwgZm9sZGVyLnBhdGgpO1xuICAgIGZvbGRlciA9IHBhcmVudDtcbiAgfVxufVxuXG4vKipcbiAqIERlbGV0ZXMgYWJzdHJhY3QgZmlsZSBzYWZlbHkgZnJvbSB0aGUgdmF1bHQuXG4gKlxuICogQHBhcmFtIGFwcCAtIFRoZSBPYnNpZGlhbiBhcHBsaWNhdGlvbiBpbnN0YW5jZS5cbiAqIEBwYXJhbSBwYXRoT3JGaWxlIC0gVGhlIHBhdGggb3IgYWJzdHJhY3QgZmlsZSB0byBkZWxldGUuXG4gKiBAcGFyYW0gZGVsZXRlZE5vdGVQYXRoIC0gT3B0aW9uYWwuIFRoZSBwYXRoIG9mIHRoZSBub3RlIHRoYXQgdHJpZ2dlcmVkIHRoZSByZW1vdmFsLlxuICogQHBhcmFtIHNob3VsZFJlcG9ydFVzZWRBdHRhY2htZW50cyAtIE9wdGlvbmFsLiBJZiBgdHJ1ZWAsIGEgbm90aWNlIHdpbGwgYmUgc2hvd24gZm9yIGVhY2ggYXR0YWNobWVudCB0aGF0IGlzIHN0aWxsIHVzZWQgYnkgb3RoZXIgbm90ZXMuXG4gKiBAcGFyYW0gc2hvdWxkRGVsZXRlRW1wdHlGb2xkZXJzIC0gT3B0aW9uYWwuIElmIGB0cnVlYCwgZW1wdHkgZm9sZGVycyB3aWxsIGJlIGRlbGV0ZWQuXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB0byBhIGJvb2xlYW4gaW5kaWNhdGluZyB3aGV0aGVyIHRoZSByZW1vdmFsIHdhcyBzdWNjZXNzZnVsLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVsZXRlU2FmZShcbiAgYXBwOiBBcHAsXG4gIHBhdGhPckZpbGU6IFBhdGhPckFic3RyYWN0RmlsZSxcbiAgZGVsZXRlZE5vdGVQYXRoPzogc3RyaW5nLFxuICBzaG91bGRSZXBvcnRVc2VkQXR0YWNobWVudHM/OiBib29sZWFuLFxuICBzaG91bGREZWxldGVFbXB0eUZvbGRlcnM/OiBib29sZWFuXG4pOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgY29uc3QgZmlsZSA9IGdldEFic3RyYWN0RmlsZU9yTnVsbChhcHAsIHBhdGhPckZpbGUpO1xuXG4gIGlmICghZmlsZSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGxldCBjYW5EZWxldGUgPSBpc0ZpbGUoZmlsZSkgfHwgKHNob3VsZERlbGV0ZUVtcHR5Rm9sZGVycyA/PyB0cnVlKTtcblxuICBpZiAoaXNGaWxlKGZpbGUpKSB7XG4gICAgY29uc3QgYmFja2xpbmtzID0gYXdhaXQgZ2V0QmFja2xpbmtzRm9yRmlsZVNhZmUoYXBwLCBmaWxlKTtcbiAgICBpZiAoZGVsZXRlZE5vdGVQYXRoKSB7XG4gICAgICBiYWNrbGlua3MuY2xlYXIoZGVsZXRlZE5vdGVQYXRoKTtcbiAgICB9XG4gICAgaWYgKGJhY2tsaW5rcy5jb3VudCgpICE9PSAwKSB7XG4gICAgICBpZiAoc2hvdWxkUmVwb3J0VXNlZEF0dGFjaG1lbnRzKSB7XG4gICAgICAgIG5ldyBOb3RpY2UoYEF0dGFjaG1lbnQgJHtmaWxlLnBhdGh9IGlzIHN0aWxsIHVzZWQgYnkgb3RoZXIgbm90ZXMuIEl0IHdpbGwgbm90IGJlIGRlbGV0ZWQuYCk7XG4gICAgICB9XG4gICAgICBjYW5EZWxldGUgPSBmYWxzZTtcbiAgICB9XG4gIH0gZWxzZSBpZiAoaXNGb2xkZXIoZmlsZSkpIHtcbiAgICBjb25zdCBsaXN0ZWRGaWxlcyA9IGF3YWl0IGxpc3RTYWZlKGFwcCwgZmlsZSk7XG4gICAgZm9yIChjb25zdCBjaGlsZCBvZiBbLi4ubGlzdGVkRmlsZXMuZmlsZXMsIC4uLmxpc3RlZEZpbGVzLmZvbGRlcnNdKSB7XG4gICAgICBjYW5EZWxldGUgJiY9IGF3YWl0IGRlbGV0ZVNhZmUoYXBwLCBjaGlsZCwgZGVsZXRlZE5vdGVQYXRoLCBzaG91bGRSZXBvcnRVc2VkQXR0YWNobWVudHMpO1xuICAgIH1cblxuICAgIGNhbkRlbGV0ZSAmJj0gYXdhaXQgaXNFbXB0eUZvbGRlcihhcHAsIGZpbGUpO1xuICB9XG5cbiAgaWYgKGNhbkRlbGV0ZSkge1xuICAgIHRyeSB7XG4gICAgICBhd2FpdCBhcHAuZmlsZU1hbmFnZXIudHJhc2hGaWxlKGZpbGUpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGlmIChhd2FpdCBhcHAudmF1bHQuZXhpc3RzKGZpbGUucGF0aCkpIHtcbiAgICAgICAgcHJpbnRFcnJvcihuZXcgRXJyb3IoYEZhaWxlZCB0byBkZWxldGUgJHtmaWxlLnBhdGh9YCwgeyBjYXVzZTogZSB9KSk7XG4gICAgICAgIGNhbkRlbGV0ZSA9IGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBjYW5EZWxldGU7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBY0EsU0FBUyxrQkFBa0I7QUFDM0I7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsT0FDSztBQUNQLFNBQVMsK0JBQStCO0FBQ3hDO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBU1AsZUFBc0IsMkJBQTJCLEtBQVUsY0FBa0Q7QUFDM0csTUFBSSxTQUFTLGdCQUFnQixLQUFLLFlBQVk7QUFFOUMsU0FBTyxRQUFRO0FBQ2IsUUFBSSxDQUFDLE1BQU0sY0FBYyxLQUFLLE1BQU0sR0FBRztBQUNyQztBQUFBLElBQ0Y7QUFDQSxVQUFNLFNBQVMsT0FBTztBQUN0QixVQUFNLFdBQVcsS0FBSyxPQUFPLElBQUk7QUFDakMsYUFBUztBQUFBLEVBQ1g7QUFDRjtBQVlBLGVBQXNCLFdBQ3BCLEtBQ0EsWUFDQSxpQkFDQSw2QkFDQSwwQkFDa0I7QUFDbEIsUUFBTSxPQUFPLHNCQUFzQixLQUFLLFVBQVU7QUFFbEQsTUFBSSxDQUFDLE1BQU07QUFDVCxXQUFPO0FBQUEsRUFDVDtBQUVBLE1BQUksWUFBWSxPQUFPLElBQUksTUFBTSw0QkFBNEI7QUFFN0QsTUFBSSxPQUFPLElBQUksR0FBRztBQUNoQixVQUFNLFlBQVksTUFBTSx3QkFBd0IsS0FBSyxJQUFJO0FBQ3pELFFBQUksaUJBQWlCO0FBQ25CLGdCQUFVLE1BQU0sZUFBZTtBQUFBLElBQ2pDO0FBQ0EsUUFBSSxVQUFVLE1BQU0sTUFBTSxHQUFHO0FBQzNCLFVBQUksNkJBQTZCO0FBQy9CLFlBQUksT0FBTyxjQUFjLEtBQUssSUFBSSx3REFBd0Q7QUFBQSxNQUM1RjtBQUNBLGtCQUFZO0FBQUEsSUFDZDtBQUFBLEVBQ0YsV0FBVyxTQUFTLElBQUksR0FBRztBQUN6QixVQUFNLGNBQWMsTUFBTSxTQUFTLEtBQUssSUFBSTtBQUM1QyxlQUFXLFNBQVMsQ0FBQyxHQUFHLFlBQVksT0FBTyxHQUFHLFlBQVksT0FBTyxHQUFHO0FBQ2xFLG9CQUFjLE1BQU0sV0FBVyxLQUFLLE9BQU8saUJBQWlCLDJCQUEyQjtBQUFBLElBQ3pGO0FBRUEsa0JBQWMsTUFBTSxjQUFjLEtBQUssSUFBSTtBQUFBLEVBQzdDO0FBRUEsTUFBSSxXQUFXO0FBQ2IsUUFBSTtBQUNGLFlBQU0sSUFBSSxZQUFZLFVBQVUsSUFBSTtBQUFBLElBQ3RDLFNBQVMsR0FBRztBQUNWLFVBQUksTUFBTSxJQUFJLE1BQU0sT0FBTyxLQUFLLElBQUksR0FBRztBQUNyQyxtQkFBVyxJQUFJLE1BQU0sb0JBQW9CLEtBQUssSUFBSSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQztBQUNuRSxvQkFBWTtBQUFBLE1BQ2Q7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUVBLFNBQU87QUFDVDsiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,68 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ (function init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){const module=originalRequire(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})()
7
+
8
+ import * as App from "./App.mjs";
9
+ import * as AttachmentPath from "./AttachmentPath.mjs";
10
+ import * as Backlink from "./Backlink.mjs";
11
+ import * as Callout from "./Callout.mjs";
12
+ import * as Components from "./Components/index.mjs";
13
+ import * as Dataview from "./Dataview.mjs";
14
+ import * as DataviewLink from "./DataviewLink.mjs";
15
+ import * as FileChange from "./FileChange.mjs";
16
+ import * as FileManager from "./FileManager.mjs";
17
+ import * as FileSystem from "./FileSystem.mjs";
18
+ import * as Frontmatter from "./Frontmatter.mjs";
19
+ import * as Link from "./Link.mjs";
20
+ import * as Logger from "./Logger.mjs";
21
+ import * as Loop from "./Loop.mjs";
22
+ import * as Markdown from "./Markdown.mjs";
23
+ import * as MarkdownCodeBlockProcessor from "./MarkdownCodeBlockProcessor.mjs";
24
+ import * as MarkdownView from "./MarkdownView.mjs";
25
+ import * as MetadataCache from "./MetadataCache.mjs";
26
+ import * as Modals from "./Modals/index.mjs";
27
+ import * as ObsidianSettings from "./ObsidianSettings.mjs";
28
+ import * as Pdf from "./Pdf.mjs";
29
+ import * as Plugin from "./Plugin/index.mjs";
30
+ import * as Queue from "./Queue.mjs";
31
+ import * as Reference from "./Reference.mjs";
32
+ import * as RenameDeleteHandler from "./RenameDeleteHandler.mjs";
33
+ import * as ResourceUrl from "./ResourceUrl.mjs";
34
+ import * as SettingEx from "./SettingEx.mjs";
35
+ import * as Vault from "./Vault.mjs";
36
+ import * as VaultEx from "./VaultEx.mjs";
37
+ export {
38
+ App,
39
+ AttachmentPath,
40
+ Backlink,
41
+ Callout,
42
+ Components,
43
+ Dataview,
44
+ DataviewLink,
45
+ FileChange,
46
+ FileManager,
47
+ FileSystem,
48
+ Frontmatter,
49
+ Link,
50
+ Logger,
51
+ Loop,
52
+ Markdown,
53
+ MarkdownCodeBlockProcessor,
54
+ MarkdownView,
55
+ MetadataCache,
56
+ Modals,
57
+ ObsidianSettings,
58
+ Pdf,
59
+ Plugin,
60
+ Queue,
61
+ Reference,
62
+ RenameDeleteHandler,
63
+ ResourceUrl,
64
+ SettingEx,
65
+ Vault,
66
+ VaultEx
67
+ };
68
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgQXBwIGZyb20gJy4vQXBwLnRzJztcbmV4cG9ydCAqIGFzIEF0dGFjaG1lbnRQYXRoIGZyb20gJy4vQXR0YWNobWVudFBhdGgudHMnO1xuZXhwb3J0ICogYXMgQmFja2xpbmsgZnJvbSAnLi9CYWNrbGluay50cyc7XG5leHBvcnQgKiBhcyBDYWxsb3V0IGZyb20gJy4vQ2FsbG91dC50cyc7XG5leHBvcnQgKiBhcyBDb21wb25lbnRzIGZyb20gJy4vQ29tcG9uZW50cy9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBEYXRhdmlldyBmcm9tICcuL0RhdGF2aWV3LnRzJztcbmV4cG9ydCAqIGFzIERhdGF2aWV3TGluayBmcm9tICcuL0RhdGF2aWV3TGluay50cyc7XG5leHBvcnQgKiBhcyBGaWxlQ2hhbmdlIGZyb20gJy4vRmlsZUNoYW5nZS50cyc7XG5leHBvcnQgKiBhcyBGaWxlTWFuYWdlciBmcm9tICcuL0ZpbGVNYW5hZ2VyLnRzJztcbmV4cG9ydCAqIGFzIEZpbGVTeXN0ZW0gZnJvbSAnLi9GaWxlU3lzdGVtLnRzJztcbmV4cG9ydCAqIGFzIEZyb250bWF0dGVyIGZyb20gJy4vRnJvbnRtYXR0ZXIudHMnO1xuZXhwb3J0ICogYXMgTGluayBmcm9tICcuL0xpbmsudHMnO1xuZXhwb3J0ICogYXMgTG9nZ2VyIGZyb20gJy4vTG9nZ2VyLnRzJztcbmV4cG9ydCAqIGFzIExvb3AgZnJvbSAnLi9Mb29wLnRzJztcbmV4cG9ydCAqIGFzIE1hcmtkb3duIGZyb20gJy4vTWFya2Rvd24udHMnO1xuZXhwb3J0ICogYXMgTWFya2Rvd25Db2RlQmxvY2tQcm9jZXNzb3IgZnJvbSAnLi9NYXJrZG93bkNvZGVCbG9ja1Byb2Nlc3Nvci50cyc7XG5leHBvcnQgKiBhcyBNYXJrZG93blZpZXcgZnJvbSAnLi9NYXJrZG93blZpZXcudHMnO1xuZXhwb3J0ICogYXMgTWV0YWRhdGFDYWNoZSBmcm9tICcuL01ldGFkYXRhQ2FjaGUudHMnO1xuZXhwb3J0ICogYXMgTW9kYWxzIGZyb20gJy4vTW9kYWxzL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIE9ic2lkaWFuU2V0dGluZ3MgZnJvbSAnLi9PYnNpZGlhblNldHRpbmdzLnRzJztcbmV4cG9ydCAqIGFzIFBkZiBmcm9tICcuL1BkZi50cyc7XG5leHBvcnQgKiBhcyBQbHVnaW4gZnJvbSAnLi9QbHVnaW4vaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgUXVldWUgZnJvbSAnLi9RdWV1ZS50cyc7XG5leHBvcnQgKiBhcyBSZWZlcmVuY2UgZnJvbSAnLi9SZWZlcmVuY2UudHMnO1xuZXhwb3J0ICogYXMgUmVuYW1lRGVsZXRlSGFuZGxlciBmcm9tICcuL1JlbmFtZURlbGV0ZUhhbmRsZXIudHMnO1xuZXhwb3J0ICogYXMgUmVzb3VyY2VVcmwgZnJvbSAnLi9SZXNvdXJjZVVybC50cyc7XG5leHBvcnQgKiBhcyBTZXR0aW5nRXggZnJvbSAnLi9TZXR0aW5nRXgudHMnO1xuZXhwb3J0ICogYXMgVmF1bHQgZnJvbSAnLi9WYXVsdC50cyc7XG5leHBvcnQgKiBhcyBWYXVsdEV4IGZyb20gJy4vVmF1bHRFeC50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBRUEsWUFBWSxTQUFTO0FBQ3JCLFlBQVksb0JBQW9CO0FBQ2hDLFlBQVksY0FBYztBQUMxQixZQUFZLGFBQWE7QUFDekIsWUFBWSxnQkFBZ0I7QUFDNUIsWUFBWSxjQUFjO0FBQzFCLFlBQVksa0JBQWtCO0FBQzlCLFlBQVksZ0JBQWdCO0FBQzVCLFlBQVksaUJBQWlCO0FBQzdCLFlBQVksZ0JBQWdCO0FBQzVCLFlBQVksaUJBQWlCO0FBQzdCLFlBQVksVUFBVTtBQUN0QixZQUFZLFlBQVk7QUFDeEIsWUFBWSxVQUFVO0FBQ3RCLFlBQVksY0FBYztBQUMxQixZQUFZLGdDQUFnQztBQUM1QyxZQUFZLGtCQUFrQjtBQUM5QixZQUFZLG1CQUFtQjtBQUMvQixZQUFZLFlBQVk7QUFDeEIsWUFBWSxzQkFBc0I7QUFDbEMsWUFBWSxTQUFTO0FBQ3JCLFlBQVksWUFBWTtBQUN4QixZQUFZLFdBQVc7QUFDdkIsWUFBWSxlQUFlO0FBQzNCLFlBQVkseUJBQXlCO0FBQ3JDLFlBQVksaUJBQWlCO0FBQzdCLFlBQVksZUFBZTtBQUMzQixZQUFZLFdBQVc7QUFDdkIsWUFBWSxhQUFhOyIsCiAgIm5hbWVzIjogW10KfQo=