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.
- package/CHANGELOG.md +16 -0
- package/README.md +4 -2
- package/dist/lib/Async.mjs +154 -0
- package/dist/lib/Blob.mjs +81 -0
- package/dist/lib/CssClass.mjs +32 -0
- package/dist/lib/Debug.mjs +137 -0
- package/dist/lib/DebugController.mjs +8 -0
- package/dist/lib/Enum.mjs +26 -0
- package/dist/lib/Error.mjs +82 -0
- package/dist/lib/Function.mjs +28 -0
- package/dist/lib/HTMLElement.mjs +65 -0
- package/dist/lib/Library.cjs +2 -2
- package/dist/lib/Library.mjs +16 -0
- package/dist/lib/Object.cjs +1 -1
- package/dist/lib/Object.d.ts +16 -0
- package/dist/lib/Object.mjs +273 -0
- package/dist/lib/Path.mjs +76 -0
- package/dist/lib/RegExp.mjs +23 -0
- package/dist/lib/String.mjs +119 -0
- package/dist/lib/Transformers/DateTransformer.cjs +71 -0
- package/dist/lib/Transformers/DateTransformer.d.ts +35 -0
- package/dist/lib/Transformers/DateTransformer.mjs +47 -0
- package/dist/lib/Transformers/GroupTransformer.cjs +118 -0
- package/dist/lib/Transformers/GroupTransformer.d.ts +65 -0
- package/dist/lib/Transformers/GroupTransformer.mjs +94 -0
- package/dist/lib/Transformers/SkipPrivatePropertyTransformer.cjs +69 -0
- package/dist/lib/Transformers/SkipPrivatePropertyTransformer.d.ts +32 -0
- package/dist/lib/Transformers/SkipPrivatePropertyTransformer.mjs +45 -0
- package/dist/lib/Transformers/Transformer.cjs +107 -0
- package/dist/lib/Transformers/Transformer.d.ts +67 -0
- package/dist/lib/Transformers/Transformer.mjs +83 -0
- package/dist/lib/Transformers/TypedTransformer.cjs +38 -0
- package/dist/lib/Transformers/TypedTransformer.d.ts +37 -0
- package/dist/lib/Transformers/TypedTransformer.mjs +14 -0
- package/dist/lib/Transformers/index.cjs +58 -0
- package/dist/lib/Transformers/index.d.ts +5 -0
- package/dist/lib/Transformers/index.mjs +20 -0
- package/dist/lib/ValueProvider.mjs +20 -0
- package/dist/lib/codemirror/StateFieldSpec.mjs +8 -0
- package/dist/lib/codemirror/index.mjs +12 -0
- package/dist/lib/index.cjs +4 -4
- package/dist/lib/index.d.ts +1 -1
- package/dist/lib/index.mjs +50 -0
- package/dist/lib/obsidian/App.mjs +33 -0
- package/dist/lib/obsidian/AttachmentPath.mjs +82 -0
- package/dist/lib/obsidian/Backlink.mjs +88 -0
- package/dist/lib/obsidian/Callout.mjs +71 -0
- package/dist/lib/obsidian/Components/DateComponent.mjs +43 -0
- package/dist/lib/obsidian/Components/DateTimeComponent.mjs +43 -0
- package/dist/lib/obsidian/Components/EmailComponent.mjs +32 -0
- package/dist/lib/obsidian/Components/FileComponent.mjs +48 -0
- package/dist/lib/obsidian/Components/MonthComponent.mjs +51 -0
- package/dist/lib/obsidian/Components/MultipleDropdownComponent.mjs +88 -0
- package/dist/lib/obsidian/Components/MultipleEmailComponent.mjs +42 -0
- package/dist/lib/obsidian/Components/MultipleFileComponent.mjs +49 -0
- package/dist/lib/obsidian/Components/NumberComponent.mjs +32 -0
- package/dist/lib/obsidian/Components/TimeComponent.mjs +53 -0
- package/dist/lib/obsidian/Components/TypedRangeTextComponent.mjs +44 -0
- package/dist/lib/obsidian/Components/TypedTextComponent.mjs +107 -0
- package/dist/lib/obsidian/Components/UrlComponent.mjs +32 -0
- package/dist/lib/obsidian/Components/ValidatorComponent.mjs +52 -0
- package/dist/lib/obsidian/Components/ValueComponentWithChangeTracking.mjs +9 -0
- package/dist/lib/obsidian/Components/WeekComponent.mjs +51 -0
- package/dist/lib/obsidian/Components/index.mjs +42 -0
- package/dist/lib/obsidian/Dataview.mjs +232 -0
- package/dist/lib/obsidian/DataviewLink.mjs +27 -0
- package/dist/lib/obsidian/FileChange.mjs +123 -0
- package/dist/lib/obsidian/FileManager.mjs +66 -0
- package/dist/lib/obsidian/FileSystem.mjs +197 -0
- package/dist/lib/obsidian/Frontmatter.mjs +32 -0
- package/dist/lib/obsidian/Link.mjs +415 -0
- package/dist/lib/obsidian/Logger.mjs +45 -0
- package/dist/lib/obsidian/Loop.mjs +39 -0
- package/dist/lib/obsidian/Markdown.mjs +40 -0
- package/dist/lib/obsidian/MarkdownCodeBlockProcessor.mjs +44 -0
- package/dist/lib/obsidian/MarkdownView.mjs +21 -0
- package/dist/lib/obsidian/MetadataCache.mjs +219 -0
- package/dist/lib/obsidian/Modals/Alert.mjs +52 -0
- package/dist/lib/obsidian/Modals/Confirm.mjs +65 -0
- package/dist/lib/obsidian/Modals/Prompt.mjs +98 -0
- package/dist/lib/obsidian/Modals/SelectItem.mjs +51 -0
- package/dist/lib/obsidian/Modals/index.mjs +18 -0
- package/dist/lib/obsidian/ObsidianSettings.mjs +18 -0
- package/dist/lib/obsidian/Pdf.mjs +42 -0
- package/dist/lib/obsidian/Plugin/EmptySettings.mjs +14 -0
- package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.mjs +35 -0
- package/dist/lib/obsidian/Plugin/Plugin.mjs +28 -0
- package/dist/lib/obsidian/Plugin/PluginBase.mjs +148 -0
- package/dist/lib/obsidian/Plugin/PluginContext.mjs +45 -0
- package/dist/lib/obsidian/Plugin/PluginId.mjs +23 -0
- package/dist/lib/obsidian/Plugin/PluginSettingsBase.cjs +13 -9
- package/dist/lib/obsidian/Plugin/PluginSettingsBase.mjs +63 -0
- package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.cjs +1 -1
- package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.d.ts +1 -1
- package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.mjs +101 -0
- package/dist/lib/obsidian/Plugin/index.mjs +26 -0
- package/dist/lib/obsidian/Queue.mjs +50 -0
- package/dist/lib/obsidian/Reference.mjs +45 -0
- package/dist/lib/obsidian/RenameDeleteHandler.mjs +436 -0
- package/dist/lib/obsidian/ResourceUrl.mjs +19 -0
- package/dist/lib/obsidian/SettingEx.mjs +148 -0
- package/dist/lib/obsidian/Vault.mjs +248 -0
- package/dist/lib/obsidian/VaultEx.mjs +71 -0
- package/dist/lib/obsidian/index.mjs +68 -0
- package/dist/lib/scripts/CliUtils.mjs +135 -0
- package/dist/lib/scripts/CodeGenerator.mjs +19 -0
- package/dist/lib/scripts/ESLint/ESLint.cjs +2 -2
- package/dist/lib/scripts/ESLint/ESLint.mjs +68 -0
- package/dist/lib/scripts/ESLint/eslint.config.mjs +287 -0
- package/dist/lib/scripts/ESLint/index.mjs +14 -0
- package/dist/lib/scripts/Exec.mjs +98 -0
- package/dist/lib/scripts/Fs.mjs +64 -0
- package/dist/lib/scripts/JSON.mjs +60 -0
- package/dist/lib/scripts/NodeModules.mjs +62 -0
- package/dist/lib/scripts/Npm.mjs +106 -0
- package/dist/lib/scripts/NpmPublish.mjs +21 -0
- package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.cjs +5 -1
- package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.d.ts +8 -0
- package/dist/lib/scripts/ObsidianDevUtilsRepoPaths.mjs +44 -0
- package/dist/lib/scripts/Root.mjs +66 -0
- package/dist/lib/scripts/build.mjs +60 -0
- package/dist/lib/scripts/cli.cjs +2 -2
- package/dist/lib/scripts/cli.mjs +65 -0
- package/dist/lib/scripts/esbuild/Dependency.cjs +2 -2
- package/dist/lib/scripts/esbuild/Dependency.mjs +95 -0
- package/dist/lib/scripts/esbuild/ObsidianPluginBuilder.mjs +149 -0
- package/dist/lib/scripts/esbuild/changeExtensionPlugin.cjs +67 -0
- package/dist/lib/scripts/esbuild/changeExtensionPlugin.d.ts +12 -0
- package/dist/lib/scripts/esbuild/changeExtensionPlugin.mjs +43 -0
- package/dist/lib/scripts/esbuild/copyToObsidianPluginsFolderPlugin.mjs +50 -0
- package/dist/lib/scripts/esbuild/fixEsmPlugin.mjs +25 -0
- package/dist/lib/scripts/esbuild/fixSourceMapsPlugin.mjs +55 -0
- package/dist/lib/scripts/esbuild/index.cjs +4 -4
- package/dist/lib/scripts/esbuild/index.d.ts +1 -1
- package/dist/lib/scripts/esbuild/index.mjs +28 -0
- package/dist/lib/scripts/esbuild/preprocessPlugin.cjs +4 -4
- package/dist/lib/scripts/esbuild/preprocessPlugin.d.ts +2 -1
- package/dist/lib/scripts/esbuild/preprocessPlugin.mjs +112 -0
- package/dist/lib/scripts/esbuild/renameCssPlugin.mjs +31 -0
- package/dist/lib/scripts/esbuild/svelteWrapperPlugin.mjs +41 -0
- package/dist/lib/scripts/format.cjs +2 -2
- package/dist/lib/scripts/format.mjs +41 -0
- package/dist/lib/scripts/index.mjs +44 -0
- package/dist/lib/scripts/spellcheck.mjs +15 -0
- package/dist/lib/scripts/version.mjs +361 -0
- package/dist/lib/url.mjs +25 -0
- package/dist/styles.css +19 -56
- package/package.json +161 -173
- package/dist/lib/@types.cjs +0 -24
- package/dist/lib/@types.d.ts +0 -20
- package/dist/lib/scripts/esbuild/renameToCjsPlugin.cjs +0 -60
- package/dist/lib/scripts/esbuild/renameToCjsPlugin.d.ts +0 -14
@@ -0,0 +1,44 @@
|
|
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
|
+
var ObsidianDevUtilsRepoPaths = /* @__PURE__ */ ((ObsidianDevUtilsRepoPaths2) => {
|
9
|
+
ObsidianDevUtilsRepoPaths2["Any"] = "*";
|
10
|
+
ObsidianDevUtilsRepoPaths2["AnyCjs"] = "*.cjs";
|
11
|
+
ObsidianDevUtilsRepoPaths2["AnyDts"] = "*.d.ts";
|
12
|
+
ObsidianDevUtilsRepoPaths2["AnyMjs"] = "*.mjs";
|
13
|
+
ObsidianDevUtilsRepoPaths2["AnyPath"] = "**";
|
14
|
+
ObsidianDevUtilsRepoPaths2["AnyTs"] = "*.ts";
|
15
|
+
ObsidianDevUtilsRepoPaths2["ChangelogMd"] = "CHANGELOG.md";
|
16
|
+
ObsidianDevUtilsRepoPaths2["CjsExtension"] = ".cjs";
|
17
|
+
ObsidianDevUtilsRepoPaths2["Dist"] = "dist";
|
18
|
+
ObsidianDevUtilsRepoPaths2["DistEslintConfigEmptyCjs"] = "dist/eslint.config.empty.cjs";
|
19
|
+
ObsidianDevUtilsRepoPaths2["DistLib"] = "dist/lib";
|
20
|
+
ObsidianDevUtilsRepoPaths2["DistLibDependenciesCjs"] = "./dist/lib/_dependencies.cjs";
|
21
|
+
ObsidianDevUtilsRepoPaths2["DprintJson"] = "dprint.json";
|
22
|
+
ObsidianDevUtilsRepoPaths2["DtsExtension"] = ".d.ts";
|
23
|
+
ObsidianDevUtilsRepoPaths2["IndexCjs"] = "index.cjs";
|
24
|
+
ObsidianDevUtilsRepoPaths2["IndexDts"] = "index.d.ts";
|
25
|
+
ObsidianDevUtilsRepoPaths2["IndexMjs"] = "index.mjs";
|
26
|
+
ObsidianDevUtilsRepoPaths2["IndexTs"] = "index.ts";
|
27
|
+
ObsidianDevUtilsRepoPaths2["License"] = "LICENSE";
|
28
|
+
ObsidianDevUtilsRepoPaths2["MjsExtension"] = ".mjs";
|
29
|
+
ObsidianDevUtilsRepoPaths2["NodeModules"] = "node_modules";
|
30
|
+
ObsidianDevUtilsRepoPaths2["PackageJson"] = "package.json";
|
31
|
+
ObsidianDevUtilsRepoPaths2["ReadmeMd"] = "README.md";
|
32
|
+
ObsidianDevUtilsRepoPaths2["Scripts"] = "scripts";
|
33
|
+
ObsidianDevUtilsRepoPaths2["Src"] = "src";
|
34
|
+
ObsidianDevUtilsRepoPaths2["SrcDependenciesTs"] = "./src/_dependencies.ts";
|
35
|
+
ObsidianDevUtilsRepoPaths2["SrcObsidianTypesDataview"] = "src/obsidian/@types/Dataview";
|
36
|
+
ObsidianDevUtilsRepoPaths2["Static"] = "static";
|
37
|
+
ObsidianDevUtilsRepoPaths2["TsConfigJson"] = "tsconfig.json";
|
38
|
+
ObsidianDevUtilsRepoPaths2["Types"] = "@types";
|
39
|
+
return ObsidianDevUtilsRepoPaths2;
|
40
|
+
})(ObsidianDevUtilsRepoPaths || {});
|
41
|
+
export {
|
42
|
+
ObsidianDevUtilsRepoPaths
|
43
|
+
};
|
44
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRoc1xuICogVGhpcyBtb2R1bGUgZGVmaW5lcyBhbiBlbnVtZXJhdGlvbiBvZiBjb21tb24gZmlsZSBwYXRocyBhbmQgcGF0dGVybnMgdXNlZCBpbiB0aGUgT2JzaWRpYW4gZGV2ZWxvcG1lbnQgdXRpbGl0aWVzIHJlcG9zaXRvcnkuXG4gKiBUaGVzZSBwYXRocyBhcmUgdXNlZCB0aHJvdWdob3V0IHRoZSBidWlsZCBwcm9jZXNzIGFuZCBvdGhlciB1dGlsaXRpZXMsIGVuc3VyaW5nIGNvbnNpc3RlbmN5IGFuZCByZWR1Y2luZyB0aGUgbGlrZWxpaG9vZFxuICogb2YgZXJyb3JzIGR1ZSB0byBoYXJkY29kZWQgc3RyaW5ncy5cbiAqL1xuXG5leHBvcnQgZW51bSBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIHtcbiAgLyoqIE1hdGNoZXMgYW55IGZpbGUgb3IgZGlyZWN0b3J5IChgKmApLiAqL1xuICBBbnkgPSAnKicsXG5cbiAgLyoqIE1hdGNoZXMgYW55IGAuY2pzYCBmaWxlIChgKi5janNgKS4gKi9cbiAgQW55Q2pzID0gJyouY2pzJyxcblxuICAvKiogTWF0Y2hlcyBhbnkgVHlwZVNjcmlwdCBkZWNsYXJhdGlvbiBmaWxlIChgKi5kLnRzYCkuICovXG4gIEFueUR0cyA9ICcqLmQudHMnLFxuXG4gIC8qKiBNYXRjaGVzIGFueSBgLm1qc2AgZmlsZSAoYCoubWpzYCkuICovXG4gIEFueU1qcyA9ICcqLm1qcycsXG5cbiAgLyoqIE1hdGNoZXMgYW55IHBhdGggcmVjdXJzaXZlbHkgKGAqKmApLiAqL1xuICBBbnlQYXRoID0gJyoqJyxcblxuICAvKiogTWF0Y2hlcyBhbnkgVHlwZVNjcmlwdCBmaWxlIChgKi50c2ApLiAqL1xuICBBbnlUcyA9ICcqLnRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBDSEFOR0VMT0cubWRgIGZpbGUuICovXG4gIENoYW5nZWxvZ01kID0gJ0NIQU5HRUxPRy5tZCcsXG5cbiAgLyoqIFRoZSBgLmNqc2AgZmlsZSBleHRlbnNpb24uICovXG4gIENqc0V4dGVuc2lvbiA9ICcuY2pzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGRpc3RyaWJ1dGlvbiAoYGRpc3RgKSBkaXJlY3RvcnkuICovXG4gIERpc3QgPSAnZGlzdCcsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBlbXB0eSBFU0xpbnQgY29uZmlnIGluIENvbW1vbkpTIGZvcm1hdCB3aXRoaW4gdGhlIGBkaXN0YCBkaXJlY3RvcnkuICovXG4gIERpc3RFc2xpbnRDb25maWdFbXB0eUNqcyA9ICdkaXN0L2VzbGludC5jb25maWcuZW1wdHkuY2pzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBsaWJgIGRpcmVjdG9yeSB3aXRoaW4gdGhlIGBkaXN0YCBkaXJlY3RvcnkuICovXG4gIERpc3RMaWIgPSAnZGlzdC9saWInLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYF9kZXBlbmRlbmNpZXMuY2pzYCBmaWxlIHdpdGhpbiB0aGUgYGxpYmAgZGlyZWN0b3J5IGluIHRoZSBgZGlzdGAgZGlyZWN0b3J5LiAqL1xuICBEaXN0TGliRGVwZW5kZW5jaWVzQ2pzID0gJy4vZGlzdC9saWIvX2RlcGVuZGVuY2llcy5janMnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYGRwcmludC5qc29uYCBmaWxlLiAqL1xuICBEcHJpbnRKc29uID0gJ2RwcmludC5qc29uJyxcblxuICAvKiogVGhlIGAuZC50c2AgZmlsZSBleHRlbnNpb24uICovXG4gIER0c0V4dGVuc2lvbiA9ICcuZC50cycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgaW5kZXguY2pzYCBmaWxlLiAqL1xuICBJbmRleENqcyA9ICdpbmRleC5janMnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYGluZGV4LmQudHNgIGZpbGUuICovXG4gIEluZGV4RHRzID0gJ2luZGV4LmQudHMnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYGluZGV4Lm1qc2AgZmlsZS4gKi9cbiAgSW5kZXhNanMgPSAnaW5kZXgubWpzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBpbmRleC50c2AgZmlsZS4gKi9cbiAgSW5kZXhUcyA9ICdpbmRleC50cycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgTElDRU5TRWAgZmlsZS4gKi9cbiAgTGljZW5zZSA9ICdMSUNFTlNFJyxcblxuICAvKiogVGhlIGAubWpzYCBmaWxlIGV4dGVuc2lvbi4gKi9cbiAgTWpzRXh0ZW5zaW9uID0gJy5tanMnLFxuXG4gIC8qKlxuICAgKiBUaGUgcGF0aCB0byB0aGUgYG5vZGVfbW9kdWxlc2AgZGlyZWN0b3J5LlxuICAgKi9cbiAgTm9kZU1vZHVsZXMgPSAnbm9kZV9tb2R1bGVzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBwYWNrYWdlLmpzb25gIGZpbGUuICovXG4gIFBhY2thZ2VKc29uID0gJ3BhY2thZ2UuanNvbicsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgUkVBRE1FLm1kYCBmaWxlLiAqL1xuICBSZWFkbWVNZCA9ICdSRUFETUUubWQnLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYHNjcmlwdHNgIGRpcmVjdG9yeS4gKi9cbiAgU2NyaXB0cyA9ICdzY3JpcHRzJyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBzcmNgIGRpcmVjdG9yeS4gKi9cbiAgU3JjID0gJ3NyYycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgX2RlcGVuZGVuY2llcy50c2AgZmlsZSB3aXRoaW4gdGhlIGBzcmNgIGRpcmVjdG9yeS4gKi9cbiAgU3JjRGVwZW5kZW5jaWVzVHMgPSAnLi9zcmMvX2RlcGVuZGVuY2llcy50cycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgc3JjYCBkaXJlY3RvcnkuICovXG4gIFNyY09ic2lkaWFuVHlwZXNEYXRhdmlldyA9ICdzcmMvb2JzaWRpYW4vQHR5cGVzL0RhdGF2aWV3JyxcblxuICAvKiogVGhlIHBhdGggdG8gdGhlIGBzdGF0aWNgIGRpcmVjdG9yeS4gKi9cbiAgU3RhdGljID0gJ3N0YXRpYycsXG5cbiAgLyoqIFRoZSBwYXRoIHRvIHRoZSBgdHNjb25maWcuanNvbmAgZmlsZS4gKi9cbiAgVHNDb25maWdKc29uID0gJ3RzY29uZmlnLmpzb24nLFxuXG4gIC8qKiBUaGUgcGF0aCB0byB0aGUgYEB0eXBlc2AgZGlyZWN0b3J5LCB0eXBpY2FsbHkgdXNlZCBmb3IgVHlwZVNjcmlwdCB0eXBlIGRlY2xhcmF0aW9ucy4gKi9cbiAgVHlwZXMgPSAnQHR5cGVzJ1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7OztBQU9PLElBQUssNEJBQUwsa0JBQUtBLCtCQUFMO0FBRUwsRUFBQUEsMkJBQUEsU0FBTTtBQUdOLEVBQUFBLDJCQUFBLFlBQVM7QUFHVCxFQUFBQSwyQkFBQSxZQUFTO0FBR1QsRUFBQUEsMkJBQUEsWUFBUztBQUdULEVBQUFBLDJCQUFBLGFBQVU7QUFHVixFQUFBQSwyQkFBQSxXQUFRO0FBR1IsRUFBQUEsMkJBQUEsaUJBQWM7QUFHZCxFQUFBQSwyQkFBQSxrQkFBZTtBQUdmLEVBQUFBLDJCQUFBLFVBQU87QUFHUCxFQUFBQSwyQkFBQSw4QkFBMkI7QUFHM0IsRUFBQUEsMkJBQUEsYUFBVTtBQUdWLEVBQUFBLDJCQUFBLDRCQUF5QjtBQUd6QixFQUFBQSwyQkFBQSxnQkFBYTtBQUdiLEVBQUFBLDJCQUFBLGtCQUFlO0FBR2YsRUFBQUEsMkJBQUEsY0FBVztBQUdYLEVBQUFBLDJCQUFBLGNBQVc7QUFHWCxFQUFBQSwyQkFBQSxjQUFXO0FBR1gsRUFBQUEsMkJBQUEsYUFBVTtBQUdWLEVBQUFBLDJCQUFBLGFBQVU7QUFHVixFQUFBQSwyQkFBQSxrQkFBZTtBQUtmLEVBQUFBLDJCQUFBLGlCQUFjO0FBR2QsRUFBQUEsMkJBQUEsaUJBQWM7QUFHZCxFQUFBQSwyQkFBQSxjQUFXO0FBR1gsRUFBQUEsMkJBQUEsYUFBVTtBQUdWLEVBQUFBLDJCQUFBLFNBQU07QUFHTixFQUFBQSwyQkFBQSx1QkFBb0I7QUFHcEIsRUFBQUEsMkJBQUEsOEJBQTJCO0FBRzNCLEVBQUFBLDJCQUFBLFlBQVM7QUFHVCxFQUFBQSwyQkFBQSxrQkFBZTtBQUdmLEVBQUFBLDJCQUFBLFdBQVE7QUEzRkUsU0FBQUE7QUFBQSxHQUFBOyIsCiAgIm5hbWVzIjogWyJPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzIl0KfQo=
|
@@ -0,0 +1,66 @@
|
|
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
|
+
dirname,
|
10
|
+
join,
|
11
|
+
relative,
|
12
|
+
resolve,
|
13
|
+
toPosixPath
|
14
|
+
} from "../Path.mjs";
|
15
|
+
import { exec } from "./Exec.mjs";
|
16
|
+
import { existsSync } from "./NodeModules.mjs";
|
17
|
+
import { ObsidianDevUtilsRepoPaths } from "./ObsidianDevUtilsRepoPaths.mjs";
|
18
|
+
function execFromRoot(command, options = {}) {
|
19
|
+
let root = getRootDir(options.cwd);
|
20
|
+
if (!root) {
|
21
|
+
if (options.shouldFailIfCalledFromOutsideRoot ?? true) {
|
22
|
+
throw new Error("Could not find root directory");
|
23
|
+
}
|
24
|
+
root = options.cwd ?? process.cwd();
|
25
|
+
}
|
26
|
+
if (options.shouldIncludeDetails) {
|
27
|
+
return exec(command, { ...options, cwd: root, shouldIncludeDetails: true });
|
28
|
+
}
|
29
|
+
return exec(command, { ...options, cwd: root, shouldIncludeDetails: false });
|
30
|
+
}
|
31
|
+
function getRootDir(cwd) {
|
32
|
+
let currentDir = toPosixPath(cwd ?? process.cwd());
|
33
|
+
while (currentDir !== "." && currentDir !== "/") {
|
34
|
+
if (existsSync(join(currentDir, ObsidianDevUtilsRepoPaths.PackageJson))) {
|
35
|
+
return toPosixPath(currentDir);
|
36
|
+
}
|
37
|
+
currentDir = dirname(currentDir);
|
38
|
+
}
|
39
|
+
return null;
|
40
|
+
}
|
41
|
+
function resolvePathFromRoot(path, cwd) {
|
42
|
+
const rootDir = getRootDir(cwd);
|
43
|
+
if (!rootDir) {
|
44
|
+
return null;
|
45
|
+
}
|
46
|
+
return resolve(rootDir, path);
|
47
|
+
}
|
48
|
+
function resolvePathFromRootSafe(path, cwd) {
|
49
|
+
return resolvePathFromRoot(path, cwd) ?? path;
|
50
|
+
}
|
51
|
+
function toRelativeFromRoot(path, cwd) {
|
52
|
+
const rootDir = getRootDir(cwd);
|
53
|
+
if (!rootDir) {
|
54
|
+
return null;
|
55
|
+
}
|
56
|
+
path = toPosixPath(path);
|
57
|
+
return relative(rootDir, path);
|
58
|
+
}
|
59
|
+
export {
|
60
|
+
execFromRoot,
|
61
|
+
getRootDir,
|
62
|
+
resolvePathFromRoot,
|
63
|
+
resolvePathFromRootSafe,
|
64
|
+
toRelativeFromRoot
|
65
|
+
};
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/Root.ts"],
  "sourcesContent": ["/**\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 * Resolves a path relative to the root directory, returning the resolved path or the original path if it does not exist.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working directory to resolve from.\n * @returns The resolved path or the original path if it does not exist.\n */\nexport function resolvePathFromRootSafe(path: string, cwd?: string): string {\n  return resolvePathFromRoot(path, cwd) ?? 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": ";;;;;;;AAWA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,YAAY;AACrB,SAAS,kBAAkB;AAC3B,SAAS,iCAAiC;AAyCnC,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,QAAQ,IAAI;AAAA,EACpC;AAEA,MAAI,QAAQ,sBAAsB;AAChC,WAAO,KAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,KAAK,CAAC;AAAA,EAC5E;AAEA,SAAO,KAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,MAAM,CAAC;AAC7E;AASO,SAAS,WAAW,KAA6B;AACtD,MAAI,aAAa,YAAY,OAAO,QAAQ,IAAI,CAAC;AACjD,SAAO,eAAe,OAAO,eAAe,KAAK;AAC/C,QAAI,WAAW,KAAK,YAAY,0BAA0B,WAAW,CAAC,GAAG;AACvE,aAAO,YAAY,UAAU;AAAA,IAC/B;AACA,iBAAa,QAAQ,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,SAAO,QAAQ,SAAS,IAAI;AAC9B;AASO,SAAS,wBAAwB,MAAc,KAAsB;AAC1E,SAAO,oBAAoB,MAAM,GAAG,KAAK;AAC3C;AASO,SAAS,mBAAmB,MAAc,KAA6B;AAC5E,QAAM,UAAU,WAAW,GAAG;AAC9B,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AAEA,SAAO,YAAY,IAAI;AACvB,SAAO,SAAS,SAAS,IAAI;AAC/B;",
  "names": []
}

|
@@ -0,0 +1,60 @@
|
|
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 { glob } from "glob";
|
9
|
+
import { getLibDebugger } from "../Debug.mjs";
|
10
|
+
import { join } from "../Path.mjs";
|
11
|
+
import { trimStart } from "../String.mjs";
|
12
|
+
import { readdirPosix } from "./Fs.mjs";
|
13
|
+
import { readJson } from "./JSON.mjs";
|
14
|
+
import {
|
15
|
+
cp,
|
16
|
+
rm
|
17
|
+
} from "./NodeModules.mjs";
|
18
|
+
import { ObsidianDevUtilsRepoPaths } from "./ObsidianDevUtilsRepoPaths.mjs";
|
19
|
+
import {
|
20
|
+
execFromRoot,
|
21
|
+
resolvePathFromRootSafe
|
22
|
+
} from "./Root.mjs";
|
23
|
+
async function buildClean() {
|
24
|
+
await rm(ObsidianDevUtilsRepoPaths.Dist, { force: true, recursive: true });
|
25
|
+
}
|
26
|
+
async function buildCompile() {
|
27
|
+
await buildCompileSvelte();
|
28
|
+
await buildCompileTypeScript();
|
29
|
+
}
|
30
|
+
async function buildCompileSvelte() {
|
31
|
+
const tsConfigPath = resolvePathFromRootSafe(ObsidianDevUtilsRepoPaths.TsConfigJson);
|
32
|
+
const tsConfig = await readJson(tsConfigPath);
|
33
|
+
const allFiles = await glob(tsConfig.include ?? [], { ignore: tsConfig.exclude ?? [] });
|
34
|
+
const svelteFiles = allFiles.filter((file) => file.endsWith(".svelte") || file.endsWith(".svelte.js") || file.endsWith(".svelte.ts"));
|
35
|
+
if (svelteFiles.length === 0) {
|
36
|
+
getLibDebugger("build:buildCompileSvelte")("No Svelte files found in the project, skipping Svelte compilation");
|
37
|
+
return;
|
38
|
+
}
|
39
|
+
await execFromRoot(["svelte-check", "--tsconfig", ObsidianDevUtilsRepoPaths.TsConfigJson]);
|
40
|
+
}
|
41
|
+
async function buildCompileTypeScript() {
|
42
|
+
await execFromRoot(["tsc", "--build", "--force"]);
|
43
|
+
}
|
44
|
+
async function buildStatic() {
|
45
|
+
for (const dirent of await readdirPosix(ObsidianDevUtilsRepoPaths.Static, { recursive: true, withFileTypes: true })) {
|
46
|
+
if (!dirent.isFile()) {
|
47
|
+
continue;
|
48
|
+
}
|
49
|
+
const path = trimStart(join(dirent.parentPath, dirent.name), `${ObsidianDevUtilsRepoPaths.Static}/`);
|
50
|
+
await cp(join(ObsidianDevUtilsRepoPaths.Static, path), join(ObsidianDevUtilsRepoPaths.Dist, path));
|
51
|
+
}
|
52
|
+
}
|
53
|
+
export {
|
54
|
+
buildClean,
|
55
|
+
buildCompile,
|
56
|
+
buildCompileSvelte,
|
57
|
+
buildCompileTypeScript,
|
58
|
+
buildStatic
|
59
|
+
};
|
60
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvYnVpbGQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIGJ1aWxkXG4gKiBUaGlzIG1vZHVsZSBwcm92aWRlcyB1dGlsaXR5IGZ1bmN0aW9ucyB0byBoYW5kbGUgdGhlIGJ1aWxkIHByb2Nlc3MgZm9yIHN0YXRpYyBhc3NldHMgYW5kIGNsZWFuaW5nXG4gKiB0aGUgYnVpbGQgb3V0cHV0IGRpcmVjdG9yeS4gSXQgaW5jbHVkZXMgZnVuY3Rpb25zIHRvIGNvcHkgc3RhdGljIGZpbGVzIHRvIHRoZSBkaXN0cmlidXRpb24gZGlyZWN0b3J5XG4gKiBhbmQgdG8gcmVtb3ZlIHRoZSBleGlzdGluZyBidWlsZCBvdXRwdXQuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBUc0NvbmZpZ0pzb24gfSBmcm9tICd0eXBlLWZlc3QnO1xuXG5pbXBvcnQgeyBnbG9iIH0gZnJvbSAnZ2xvYic7XG5cbmltcG9ydCB7IGdldExpYkRlYnVnZ2VyIH0gZnJvbSAnLi4vRGVidWcudHMnO1xuaW1wb3J0IHsgam9pbiB9IGZyb20gJy4uL1BhdGgudHMnO1xuaW1wb3J0IHsgdHJpbVN0YXJ0IH0gZnJvbSAnLi4vU3RyaW5nLnRzJztcbmltcG9ydCB7IHJlYWRkaXJQb3NpeCB9IGZyb20gJy4vRnMudHMnO1xuaW1wb3J0IHsgcmVhZEpzb24gfSBmcm9tICcuL0pTT04udHMnO1xuaW1wb3J0IHtcbiAgY3AsXG4gIHJtXG59IGZyb20gJy4vTm9kZU1vZHVsZXMudHMnO1xuaW1wb3J0IHsgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocyB9IGZyb20gJy4vT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy50cyc7XG5pbXBvcnQge1xuICBleGVjRnJvbVJvb3QsXG4gIHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlXG59IGZyb20gJy4vUm9vdC50cyc7XG5cbi8qKlxuICogUmVtb3ZlcyB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeSBhbmQgaXRzIGNvbnRlbnRzLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gZGVsZXRlcyB0aGUgZW50aXJlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkgdG8gZW5zdXJlIGEgY2xlYW4gYnVpbGQgZW52aXJvbm1lbnQuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgZGlyZWN0b3J5IGhhcyBiZWVuIHJlbW92ZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENsZWFuKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBybShPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRpc3QsIHsgZm9yY2U6IHRydWUsIHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgY29kZS5cbiAqXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZSgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgYnVpbGRDb21waWxlU3ZlbHRlKCk7XG4gIGF3YWl0IGJ1aWxkQ29tcGlsZVR5cGVTY3JpcHQoKTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgU3ZlbHRlIGNvZGUuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENvbXBpbGVTdmVsdGUoKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHRzQ29uZmlnUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuVHNDb25maWdKc29uKTtcbiAgY29uc3QgdHNDb25maWcgPSBhd2FpdCByZWFkSnNvbjxUc0NvbmZpZ0pzb24+KHRzQ29uZmlnUGF0aCk7XG4gIGNvbnN0IGFsbEZpbGVzID0gYXdhaXQgZ2xvYih0c0NvbmZpZy5pbmNsdWRlID8/IFtdLCB7IGlnbm9yZTogdHNDb25maWcuZXhjbHVkZSA/PyBbXSB9KTtcbiAgY29uc3Qgc3ZlbHRlRmlsZXMgPSBhbGxGaWxlcy5maWx0ZXIoKGZpbGUpID0+IGZpbGUuZW5kc1dpdGgoJy5zdmVsdGUnKSB8fCBmaWxlLmVuZHNXaXRoKCcuc3ZlbHRlLmpzJykgfHwgZmlsZS5lbmRzV2l0aCgnLnN2ZWx0ZS50cycpKTtcblxuICBpZiAoc3ZlbHRlRmlsZXMubGVuZ3RoID09PSAwKSB7XG4gICAgZ2V0TGliRGVidWdnZXIoJ2J1aWxkOmJ1aWxkQ29tcGlsZVN2ZWx0ZScpKCdObyBTdmVsdGUgZmlsZXMgZm91bmQgaW4gdGhlIHByb2plY3QsIHNraXBwaW5nIFN2ZWx0ZSBjb21waWxhdGlvbicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ3N2ZWx0ZS1jaGVjaycsICctLXRzY29uZmlnJywgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5Uc0NvbmZpZ0pzb25dKTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgVHlwZVNjcmlwdCBjb2RlLlxuICpcbiAqIEByZXR1cm5zIEEgcHJvbWlzZSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGNvZGUgY29tcGlsZXMgc3VjY2Vzc2Z1bGx5LlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDb21waWxlVHlwZVNjcmlwdCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsndHNjJywgJy0tYnVpbGQnLCAnLS1mb3JjZSddKTtcbn1cblxuLyoqXG4gKiBDb3BpZXMgYWxsIHN0YXRpYyBmaWxlcyBmcm9tIHRoZSBzdGF0aWMgYXNzZXRzIGRpcmVjdG9yeSB0byB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHJlY3Vyc2l2ZWx5IHJlYWRzIHRoZSBjb250ZW50cyBvZiB0aGUgc3RhdGljIGFzc2V0cyBkaXJlY3RvcnkgYW5kIGNvcGllc1xuICogZWFjaCBmaWxlIHRvIHRoZSBjb3JyZXNwb25kaW5nIHBhdGggaW4gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiBhbGwgZmlsZXMgaGF2ZSBiZWVuIGNvcGllZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkU3RhdGljKCk6IFByb21pc2U8dm9pZD4ge1xuICBmb3IgKGNvbnN0IGRpcmVudCBvZiBhd2FpdCByZWFkZGlyUG9zaXgoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWMsIHsgcmVjdXJzaXZlOiB0cnVlLCB3aXRoRmlsZVR5cGVzOiB0cnVlIH0pKSB7XG4gICAgaWYgKCFkaXJlbnQuaXNGaWxlKCkpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IHBhdGggPSB0cmltU3RhcnQoam9pbihkaXJlbnQucGFyZW50UGF0aCwgZGlyZW50Lm5hbWUpLCBgJHtPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpY30vYCk7XG4gICAgYXdhaXQgY3Aoam9pbihPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYywgcGF0aCksIGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBwYXRoKSk7XG4gIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7QUFTQSxTQUFTLFlBQVk7QUFFckIsU0FBUyxzQkFBc0I7QUFDL0IsU0FBUyxZQUFZO0FBQ3JCLFNBQVMsaUJBQWlCO0FBQzFCLFNBQVMsb0JBQW9CO0FBQzdCLFNBQVMsZ0JBQWdCO0FBQ3pCO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBQ1AsU0FBUyxpQ0FBaUM7QUFDMUM7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLE9BQ0s7QUFTUCxlQUFzQixhQUE0QjtBQUNoRCxRQUFNLEdBQUcsMEJBQTBCLE1BQU0sRUFBRSxPQUFPLE1BQU0sV0FBVyxLQUFLLENBQUM7QUFDM0U7QUFPQSxlQUFzQixlQUE4QjtBQUNsRCxRQUFNLG1CQUFtQjtBQUN6QixRQUFNLHVCQUF1QjtBQUMvQjtBQU9BLGVBQXNCLHFCQUFvQztBQUN4RCxRQUFNLGVBQWUsd0JBQXdCLDBCQUEwQixZQUFZO0FBQ25GLFFBQU0sV0FBVyxNQUFNLFNBQXVCLFlBQVk7QUFDMUQsUUFBTSxXQUFXLE1BQU0sS0FBSyxTQUFTLFdBQVcsQ0FBQyxHQUFHLEVBQUUsUUFBUSxTQUFTLFdBQVcsQ0FBQyxFQUFFLENBQUM7QUFDdEYsUUFBTSxjQUFjLFNBQVMsT0FBTyxDQUFDLFNBQVMsS0FBSyxTQUFTLFNBQVMsS0FBSyxLQUFLLFNBQVMsWUFBWSxLQUFLLEtBQUssU0FBUyxZQUFZLENBQUM7QUFFcEksTUFBSSxZQUFZLFdBQVcsR0FBRztBQUM1QixtQkFBZSwwQkFBMEIsRUFBRSxtRUFBbUU7QUFDOUc7QUFBQSxFQUNGO0FBRUEsUUFBTSxhQUFhLENBQUMsZ0JBQWdCLGNBQWMsMEJBQTBCLFlBQVksQ0FBQztBQUMzRjtBQU9BLGVBQXNCLHlCQUF3QztBQUM1RCxRQUFNLGFBQWEsQ0FBQyxPQUFPLFdBQVcsU0FBUyxDQUFDO0FBQ2xEO0FBVUEsZUFBc0IsY0FBNkI7QUFDakQsYUFBVyxVQUFVLE1BQU0sYUFBYSwwQkFBMEIsUUFBUSxFQUFFLFdBQVcsTUFBTSxlQUFlLEtBQUssQ0FBQyxHQUFHO0FBQ25ILFFBQUksQ0FBQyxPQUFPLE9BQU8sR0FBRztBQUNwQjtBQUFBLElBQ0Y7QUFFQSxVQUFNLE9BQU8sVUFBVSxLQUFLLE9BQU8sWUFBWSxPQUFPLElBQUksR0FBRyxHQUFHLDBCQUEwQixNQUFNLEdBQUc7QUFDbkcsVUFBTSxHQUFHLEtBQUssMEJBQTBCLFFBQVEsSUFBSSxHQUFHLEtBQUssMEJBQTBCLE1BQU0sSUFBSSxDQUFDO0FBQUEsRUFDbkc7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/lib/scripts/cli.cjs
CHANGED
@@ -43,7 +43,7 @@ var import_spellcheck = require('./spellcheck.cjs');
|
|
43
43
|
var import_version = require('./version.cjs');
|
44
44
|
var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
|
45
45
|
if (typeof __filename === "string") {
|
46
|
-
const url = require('node:url');
|
46
|
+
const url = globalThis.require('node:url');
|
47
47
|
return url.pathToFileURL(__filename).href;
|
48
48
|
}
|
49
49
|
if (typeof window !== "undefined") {
|
@@ -84,4 +84,4 @@ function addCommand(program, name, description, taskFn) {
|
|
84
84
|
0 && (module.exports = {
|
85
85
|
cli
|
86
86
|
});
|
87
|
-
//# 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\"\"})();\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  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport { 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 * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,uBAAwB;AAIxB,mBAAkC;AAClC,kBAA2B;AAC3B,mBAMO;AACP,sBAGO;AACP,mCAGO;AACP,oBAAqB;AACrB,oBAAuB;AACvB,yBAAwB;AACxB,iBAAgC;AAChC,wBAAwB;AACxB,wBAA2B;AAC3B,qBAA8B;AApC9B,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;AA0C/O,MAAM,8BAA8B;AA4B7B,SAAS,IAAI,OAAiB,2BAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F;AAAA,IAAkB,UAChB,6BAAY,YAAY;AACtB,YAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,YAAM,UAAU,IAAI,yBAAQ;AAE5B,cACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,iBAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,iBAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,iBAAW,SAAS,oCAA2B,0BAA0B,UAAM,2BAAa,CAAC;AAC7F,iBAAW,SAAS,iDAAiC,iCAAiC,UAAM,iCAAmB,CAAC;AAChH,iBAAW,SAAS,yDAAqC,qCAAqC,UAAM,qCAAuB,CAAC;AAC5H,iBAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,iBAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,iBAAW,SAAS,uBAAqB,0BAA0B,UAAM,sBAAO,CAAC;AACjF,iBAAW,SAAS,kCAA0B,yCAAyC,UAAM,sBAAO,KAAK,CAAC;AAC1G,iBAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,iBAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,iBAAW,SAAS,yBAAsB,kBAAkB,CAAC,eAAoB,2BAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,iBAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,iBAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,YAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,aAAO,8BAAc,UAAU;AAAA,IACjC,CAAC;AAAA,EACH;AACF;AAYA,SAAS,WACP,SACA,MACA,aAEA,QACS;AACT,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,aAAe,6BAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

|
87
|
+
//# 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=globalThis.require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\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  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport { 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 * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,uBAAwB;AAIxB,mBAAkC;AAClC,kBAA2B;AAC3B,mBAMO;AACP,sBAGO;AACP,mCAGO;AACP,oBAAqB;AACrB,oBAAuB;AACvB,yBAAwB;AACxB,iBAAgC;AAChC,wBAAwB;AACxB,wBAA2B;AAC3B,qBAA8B;AApC9B,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,WAAW,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;AA0C1P,MAAM,8BAA8B;AA4B7B,SAAS,IAAI,OAAiB,2BAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F;AAAA,IAAkB,UAChB,6BAAY,YAAY;AACtB,YAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,YAAM,UAAU,IAAI,yBAAQ;AAE5B,cACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,iBAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,iBAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,iBAAW,SAAS,oCAA2B,0BAA0B,UAAM,2BAAa,CAAC;AAC7F,iBAAW,SAAS,iDAAiC,iCAAiC,UAAM,iCAAmB,CAAC;AAChH,iBAAW,SAAS,yDAAqC,qCAAqC,UAAM,qCAAuB,CAAC;AAC5H,iBAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,iBAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,iBAAW,SAAS,uBAAqB,0BAA0B,UAAM,sBAAO,CAAC;AACjF,iBAAW,SAAS,kCAA0B,yCAAyC,UAAM,sBAAO,KAAK,CAAC;AAC1G,iBAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,iBAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,iBAAW,SAAS,yBAAsB,kBAAkB,CAAC,eAAoB,2BAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,iBAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,iBAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,YAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,aAAO,8BAAc,UAAU;AAAA,IACjC,CAAC;AAAA,EACH;AACF;AAYA,SAAS,WACP,SACA,MACA,aAEA,QACS;AACT,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,aAAe,6BAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

|
@@ -0,0 +1,65 @@
|
|
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 { Command } from "commander";
|
9
|
+
import { invokeAsyncSafely } from "../Async.mjs";
|
10
|
+
import { getDirname } from "../Path.mjs";
|
11
|
+
import {
|
12
|
+
buildClean,
|
13
|
+
buildCompile,
|
14
|
+
buildCompileSvelte,
|
15
|
+
buildCompileTypeScript,
|
16
|
+
buildStatic
|
17
|
+
} from "./build.mjs";
|
18
|
+
import {
|
19
|
+
CliTaskResult,
|
20
|
+
wrapCliTask
|
21
|
+
} from "./CliUtils.mjs";
|
22
|
+
import {
|
23
|
+
BuildMode,
|
24
|
+
buildObsidianPlugin
|
25
|
+
} from "./esbuild/ObsidianPluginBuilder.mjs";
|
26
|
+
import { lint } from "./ESLint/ESLint.mjs";
|
27
|
+
import { format } from "./format.mjs";
|
28
|
+
import { process } from "./NodeModules.mjs";
|
29
|
+
import { readPackageJson } from "./Npm.mjs";
|
30
|
+
import { publish } from "./NpmPublish.mjs";
|
31
|
+
import { spellcheck } from "./spellcheck.mjs";
|
32
|
+
import { updateVersion } from "./version.mjs";
|
33
|
+
const NODE_SCRIPT_ARGV_SKIP_COUNT = 2;
|
34
|
+
function cli(argv = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)) {
|
35
|
+
invokeAsyncSafely(
|
36
|
+
() => wrapCliTask(async () => {
|
37
|
+
const packageJson = await readPackageJson(getDirname(import.meta.url));
|
38
|
+
const program = new Command();
|
39
|
+
program.name(packageJson.name ?? "(unknown)").description("CLI for Obsidian plugin development utilities").version(packageJson.version ?? "(unknown)");
|
40
|
+
addCommand(program, "build" /* Build */, "Build the plugin", () => buildObsidianPlugin({ mode: BuildMode.Production }));
|
41
|
+
addCommand(program, "build:clean" /* BuildClean */, "Clean the dist folder", () => buildClean());
|
42
|
+
addCommand(program, "build:compile" /* BuildCompile */, "Check if code compiles", () => buildCompile());
|
43
|
+
addCommand(program, "build:compile:svelte" /* BuildCompileSvelte */, "Check if Svelte code compiles", () => buildCompileSvelte());
|
44
|
+
addCommand(program, "build:compile:typescript" /* BuildCompileTypeScript */, "Check if TypeScript code compiles", () => buildCompileTypeScript());
|
45
|
+
addCommand(program, "build:static" /* BuildStatic */, "Copy static content to dist", () => buildStatic());
|
46
|
+
addCommand(program, "dev" /* Dev */, "Build the plugin in development mode", () => buildObsidianPlugin({ mode: BuildMode.Development }));
|
47
|
+
addCommand(program, "format" /* Format */, "Format the source code", () => format());
|
48
|
+
addCommand(program, "format:check" /* FormatCheck */, "Check if the source code is formatted", () => format(false));
|
49
|
+
addCommand(program, "lint" /* Lint */, "Lint the source code", () => lint());
|
50
|
+
addCommand(program, "lint:fix" /* LintFix */, "Lint the source code and apply automatic fixes", () => lint(true));
|
51
|
+
addCommand(program, "publish" /* Publish */, "Publish to NPM", (isBeta) => publish(isBeta)).argument("[isBeta]", "Publish to NPM beta");
|
52
|
+
addCommand(program, "spellcheck" /* Spellcheck */, "Spellcheck the source code", () => spellcheck());
|
53
|
+
addCommand(program, "version" /* Version */, "Release a new version", (versionUpdateType) => updateVersion(versionUpdateType)).argument("[versionUpdateType]", "Version update type: major, minor, patch, beta, or x.y.z[-suffix]");
|
54
|
+
await program.parseAsync(argv, { from: "user" });
|
55
|
+
return CliTaskResult.DoNotExit();
|
56
|
+
})
|
57
|
+
);
|
58
|
+
}
|
59
|
+
function addCommand(program, name, description, taskFn) {
|
60
|
+
return program.command(name).description(description).action((...args) => wrapCliTask(() => taskFn(...args)));
|
61
|
+
}
|
62
|
+
export {
|
63
|
+
cli
|
64
|
+
};
|
65
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/cli.ts"],
  "sourcesContent": ["/**\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  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport { 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 * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;AAQA,SAAS,eAAe;AAIxB,SAAS,yBAAyB;AAClC,SAAS,kBAAkB;AAC3B;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,YAAY;AACrB,SAAS,cAAc;AACvB,SAAS,eAAe;AACxB,SAAS,uBAAuB;AAChC,SAAS,eAAe;AACxB,SAAS,kBAAkB;AAC3B,SAAS,qBAAqB;AAM9B,MAAM,8BAA8B;AA4B7B,SAAS,IAAI,OAAiB,QAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F;AAAA,IAAkB,MAChB,YAAY,YAAY;AACtB,YAAM,cAAc,MAAM,gBAAgB,WAAW,YAAY,GAAG,CAAC;AACrE,YAAM,UAAU,IAAI,QAAQ;AAE5B,cACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,iBAAW,SAAS,qBAAoB,oBAAoB,MAAM,oBAAoB,EAAE,MAAM,UAAU,WAAW,CAAC,CAAC;AACrH,iBAAW,SAAS,gCAAyB,yBAAyB,MAAM,WAAW,CAAC;AACxF,iBAAW,SAAS,oCAA2B,0BAA0B,MAAM,aAAa,CAAC;AAC7F,iBAAW,SAAS,iDAAiC,iCAAiC,MAAM,mBAAmB,CAAC;AAChH,iBAAW,SAAS,yDAAqC,qCAAqC,MAAM,uBAAuB,CAAC;AAC5H,iBAAW,SAAS,kCAA0B,+BAA+B,MAAM,YAAY,CAAC;AAChG,iBAAW,SAAS,iBAAkB,wCAAwC,MAAM,oBAAoB,EAAE,MAAM,UAAU,YAAY,CAAC,CAAC;AACxI,iBAAW,SAAS,uBAAqB,0BAA0B,MAAM,OAAO,CAAC;AACjF,iBAAW,SAAS,kCAA0B,yCAAyC,MAAM,OAAO,KAAK,CAAC;AAC1G,iBAAW,SAAS,mBAAmB,wBAAwB,MAAM,KAAK,CAAC;AAC3E,iBAAW,SAAS,0BAAsB,kDAAkD,MAAM,KAAK,IAAI,CAAC;AAC5G,iBAAW,SAAS,yBAAsB,kBAAkB,CAAC,WAAoB,QAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,iBAAW,SAAS,+BAAyB,8BAA8B,MAAM,WAAW,CAAC;AAC7F,iBAAW,SAAS,yBAAsB,yBAAyB,CAAC,sBAA8B,cAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,YAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,aAAO,cAAc,UAAU;AAAA,IACjC,CAAC;AAAA,EACH;AACF;AAYA,SAAS,WACP,SACA,MACA,aAEA,QACS;AACT,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,SAAe,YAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

|
@@ -40,7 +40,7 @@ var import_ObsidianPluginBuilder = require('./ObsidianPluginBuilder.cjs');
|
|
40
40
|
var import_preprocessPlugin = require('./preprocessPlugin.cjs');
|
41
41
|
var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
|
42
42
|
if (typeof __filename === "string") {
|
43
|
-
const url = require('node:url');
|
43
|
+
const url = globalThis.require('node:url');
|
44
44
|
return url.pathToFileURL(__filename).href;
|
45
45
|
}
|
46
46
|
if (typeof window !== "undefined") {
|
@@ -118,4 +118,4 @@ function extractDependenciesToBundlePlugin(dependenciesToSkip, dependenciesToBun
|
|
118
118
|
getDependenciesToBundle,
|
119
119
|
getDependenciesToSkip
|
120
120
|
});
|
121
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC9EZXBlbmRlbmN5LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ2YXIgX19pbXBvcnRfbWV0YV91cmwgPSBnbG9iYWxUaGlzWydpbXBvcnQubWV0YS51cmwnXSA/
|
121
|
+
//# 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=globalThis.require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\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;AAaA,qBAAwB;AAExB,mBAAgC;AAChC,kBAGO;AACP,oBAA0B;AAC1B,yBAGO;AACP,iBAAgC;AAChC,uCAA0C;AAC1C,mCAGO;AACP,8BAAiC;AA/BjC,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,WAAW,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;AAiC1P,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"]
}

|
@@ -0,0 +1,95 @@
|
|
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 { context } from "esbuild";
|
9
|
+
import { throwExpression } from "../../Error.mjs";
|
10
|
+
import {
|
11
|
+
getDirname,
|
12
|
+
join
|
13
|
+
} from "../../Path.mjs";
|
14
|
+
import { trimStart } from "../../String.mjs";
|
15
|
+
import {
|
16
|
+
builtinModules,
|
17
|
+
createRequire
|
18
|
+
} from "../NodeModules.mjs";
|
19
|
+
import { readPackageJson } from "../Npm.mjs";
|
20
|
+
import { ObsidianDevUtilsRepoPaths } from "../ObsidianDevUtilsRepoPaths.mjs";
|
21
|
+
import {
|
22
|
+
banner,
|
23
|
+
invokeEsbuild
|
24
|
+
} from "./ObsidianPluginBuilder.mjs";
|
25
|
+
import { preprocessPlugin } from "./preprocessPlugin.mjs";
|
26
|
+
const esmRequire = createRequire(import.meta.url);
|
27
|
+
async function getDependenciesToBundle() {
|
28
|
+
const dependenciesToSkip = await getDependenciesToSkip();
|
29
|
+
const dependenciesToBundle = /* @__PURE__ */ new Set();
|
30
|
+
const buildOptions = {
|
31
|
+
banner: {
|
32
|
+
js: banner
|
33
|
+
},
|
34
|
+
bundle: true,
|
35
|
+
entryPoints: [join(ObsidianDevUtilsRepoPaths.Src, ObsidianDevUtilsRepoPaths.AnyPath, ObsidianDevUtilsRepoPaths.AnyTs)],
|
36
|
+
format: "cjs",
|
37
|
+
logLevel: "info",
|
38
|
+
outdir: "nothing-will-be-written-on-disk-so-this-does-not-matter",
|
39
|
+
platform: "node",
|
40
|
+
plugins: [
|
41
|
+
preprocessPlugin(),
|
42
|
+
extractDependenciesToBundlePlugin(dependenciesToSkip, dependenciesToBundle)
|
43
|
+
],
|
44
|
+
sourcemap: "inline",
|
45
|
+
target: "ESNext",
|
46
|
+
treeShaking: true,
|
47
|
+
write: false
|
48
|
+
};
|
49
|
+
const buildContext = await context(buildOptions);
|
50
|
+
await invokeEsbuild(buildContext, true);
|
51
|
+
return Array.from(dependenciesToBundle).sort();
|
52
|
+
}
|
53
|
+
async function getDependenciesToSkip() {
|
54
|
+
const packageJson = await readPackageJson(getDirname(import.meta.url));
|
55
|
+
const dependenciesToSkip = /* @__PURE__ */ new Set([...builtinModules, ...Object.keys(packageJson.dependencies ?? {}).filter(canSkipFromBundling)]);
|
56
|
+
return dependenciesToSkip;
|
57
|
+
}
|
58
|
+
function canSkipFromBundling(moduleName) {
|
59
|
+
if (moduleName.startsWith("@types/")) {
|
60
|
+
return true;
|
61
|
+
}
|
62
|
+
if (moduleName.startsWith("obsidian")) {
|
63
|
+
return true;
|
64
|
+
}
|
65
|
+
if (moduleName === "esbuild") {
|
66
|
+
return true;
|
67
|
+
}
|
68
|
+
try {
|
69
|
+
const module = esmRequire(moduleName);
|
70
|
+
return !module.default;
|
71
|
+
} catch {
|
72
|
+
return false;
|
73
|
+
}
|
74
|
+
}
|
75
|
+
function extractDependenciesToBundlePlugin(dependenciesToSkip, dependenciesToBundle) {
|
76
|
+
return {
|
77
|
+
name: "test",
|
78
|
+
setup(build) {
|
79
|
+
build.onResolve({ filter: /^[^./]/ }, (args) => {
|
80
|
+
if (!args.importer.endsWith(".d.ts")) {
|
81
|
+
const moduleName = trimStart(args.path.split("/")[0] ?? throwExpression(new Error("Wrong path")), "node:");
|
82
|
+
if (!dependenciesToSkip.has(args.path) && !dependenciesToSkip.has(moduleName)) {
|
83
|
+
dependenciesToBundle.add(args.path);
|
84
|
+
}
|
85
|
+
}
|
86
|
+
return { external: true, path: args.path };
|
87
|
+
});
|
88
|
+
}
|
89
|
+
};
|
90
|
+
}
|
91
|
+
export {
|
92
|
+
getDependenciesToBundle,
|
93
|
+
getDependenciesToSkip
|
94
|
+
};
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/Dependency.ts"],
  "sourcesContent": ["/**\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": ";;;;;;;AAYA,SAAS,eAAe;AAExB,SAAS,uBAAuB;AAChC;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,iBAAiB;AAC1B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,uBAAuB;AAChC,SAAS,iCAAiC;AAC1C;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,wBAAwB;AAEjC,MAAM,aAAa,cAAc,YAAY,GAAG;AAWhD,eAAsB,0BAA6C;AACjE,QAAM,qBAAqB,MAAM,sBAAsB;AACvD,QAAM,uBAAuB,oBAAI,IAAY;AAE7C,QAAM,eAA6B;AAAA,IACjC,QAAQ;AAAA,MACN,IAAI;AAAA,IACN;AAAA,IACA,QAAQ;AAAA,IACR,aAAa,CAAC,KAAK,0BAA0B,KAAK,0BAA0B,SAAS,0BAA0B,KAAK,CAAC;AAAA,IACrH,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,SAAS;AAAA,MACP,iBAAiB;AAAA,MACjB,kCAAkC,oBAAoB,oBAAoB;AAAA,IAC5E;AAAA,IACA,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,aAAa;AAAA,IACb,OAAO;AAAA,EACT;AAEA,QAAM,eAAe,MAAM,QAAQ,YAAY;AAC/C,QAAM,cAAc,cAAc,IAAI;AACtC,SAAO,MAAM,KAAK,oBAAoB,EAAE,KAAK;AAC/C;AAOA,eAAsB,wBAA8C;AAClE,QAAM,cAAc,MAAM,gBAAgB,WAAW,YAAY,GAAG,CAAC;AACrE,QAAM,qBAAqB,oBAAI,IAAY,CAAC,GAAG,gBAAgB,GAAG,OAAO,KAAK,YAAY,gBAAgB,CAAC,CAAC,EAAE,OAAO,mBAAmB,CAAC,CAAC;AAC1I,SAAO;AACT;AAQA,SAAS,oBAAoB,YAA6B;AACxD,MAAI,WAAW,WAAW,SAAS,GAAG;AACpC,WAAO;AAAA,EACT;AAEA,MAAI,WAAW,WAAW,UAAU,GAAG;AACrC,WAAO;AAAA,EACT;AAEA,MAAI,eAAe,WAAW;AAC5B,WAAO;AAAA,EACT;AAEA,MAAI;AACF,UAAM,SAAS,WAAW,UAAU;AACpC,WAAO,CAAC,OAAO;AAAA,EACjB,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AASA,SAAS,kCAAkC,oBAAiC,sBAA2C;AACrH,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM,OAAa;AACjB,YAAM,UAAU,EAAE,QAAQ,SAAS,GAAG,CAAC,SAAS;AAC9C,YAAI,CAAC,KAAK,SAAS,SAAS,OAAO,GAAG;AACpC,gBAAM,aAAa,UAAU,KAAK,KAAK,MAAM,GAAG,EAAE,CAAC,KAAK,gBAAgB,IAAI,MAAM,YAAY,CAAC,GAAG,OAAO;AACzG,cAAI,CAAC,mBAAmB,IAAI,KAAK,IAAI,KAAK,CAAC,mBAAmB,IAAI,UAAU,GAAG;AAC7E,iCAAqB,IAAI,KAAK,IAAI;AAAA,UACpC;AAAA,QACF;AACA,eAAO,EAAE,UAAU,MAAM,MAAM,KAAK,KAAK;AAAA,MAC3C,CAAC;AAAA,IACH;AAAA,EACF;AACF;",
  "names": []
}

|