obsidian-dev-utils 8.0.1-beta.1 → 8.0.1-beta.10
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/README.md +10 -0
- package/dist/lib/Async.cjs +20 -6
- package/dist/lib/Async.d.ts +2 -0
- package/dist/lib/Debug.cjs +40 -0
- package/dist/lib/Debug.d.ts +10 -0
- package/dist/lib/index.cjs +4 -1
- package/dist/lib/index.d.ts +1 -0
- package/dist/lib/obsidian/Link.cjs +3 -3
- package/dist/lib/obsidian/Logger.cjs +5 -5
- package/dist/lib/obsidian/MetadataCache.cjs +6 -2
- package/dist/lib/obsidian/RenameDeleteHandler.cjs +8 -7
- package/dist/lib/obsidian/Vault.cjs +37 -76
- package/dist/lib/obsidian/Vault.d.ts +11 -20
- package/dist/lib/obsidian/VaultEx.cjs +90 -0
- package/dist/lib/obsidian/VaultEx.d.ts +27 -0
- package/dist/lib/obsidian/index.cjs +6 -3
- package/dist/lib/obsidian/index.d.ts +1 -0
- package/dist/lib/scripts/NpmPublish.cjs +52 -0
- package/dist/lib/scripts/NpmPublish.d.ts +9 -0
- package/dist/lib/scripts/cli.cjs +3 -1
- package/dist/lib/scripts/esbuild/ObsidianPluginBuilder.cjs +4 -4
- package/dist/lib/scripts/index.cjs +4 -1
- package/dist/lib/scripts/index.d.ts +1 -0
- package/dist/lib/scripts/version.cjs +2 -1
- package/dist/lib/scripts/version.d.ts +1 -1
- package/package.json +2 -2
@@ -6,7 +6,7 @@ import type { ListedFiles } from 'obsidian';
|
|
6
6
|
import { App, TFile } from 'obsidian';
|
7
7
|
import type { RetryOptions } from '../Async.ts';
|
8
8
|
import type { ValueProvider } from '../ValueProvider.ts';
|
9
|
-
import type {
|
9
|
+
import type { PathOrFile, PathOrFolder } from './FileSystem.ts';
|
10
10
|
/**
|
11
11
|
* Options for the `process` function.
|
12
12
|
*/
|
@@ -48,25 +48,6 @@ export declare function createTempFile(app: App, path: string): Promise<() => Pr
|
|
48
48
|
* @returns A promise that resolves to a function that can be called to delete the temporary folder and all its created parents.
|
49
49
|
*/
|
50
50
|
export declare function createTempFolder(app: App, path: string): Promise<() => Promise<void>>;
|
51
|
-
/**
|
52
|
-
* Removes empty folder hierarchy starting from the given folder.
|
53
|
-
*
|
54
|
-
* @param app - The application instance.
|
55
|
-
* @param pathOrFolder - The folder to start removing empty hierarchy from.
|
56
|
-
* @returns A promise that resolves when the empty hierarchy is deleted.
|
57
|
-
*/
|
58
|
-
export declare function deleteEmptyFolderHierarchy(app: App, pathOrFolder: null | PathOrFolder): Promise<void>;
|
59
|
-
/**
|
60
|
-
* Deletes abstract file safely from the vault.
|
61
|
-
*
|
62
|
-
* @param app - The Obsidian application instance.
|
63
|
-
* @param pathOrFile - The path or abstract file to delete.
|
64
|
-
* @param deletedNotePath - Optional. The path of the note that triggered the removal.
|
65
|
-
* @param shouldReportUsedAttachments - Optional. If `true`, a notice will be shown for each attachment that is still used by other notes.
|
66
|
-
* @param shouldDeleteEmptyFolders - Optional. If `true`, empty folders will be deleted.
|
67
|
-
* @returns A promise that resolves to a boolean indicating whether the removal was successful.
|
68
|
-
*/
|
69
|
-
export declare function deleteSafe(app: App, pathOrFile: PathOrAbstractFile, deletedNotePath?: string, shouldReportUsedAttachments?: boolean, shouldDeleteEmptyFolders?: boolean): Promise<boolean>;
|
70
51
|
/**
|
71
52
|
* Gets an available path for a file in the vault.
|
72
53
|
*
|
@@ -127,6 +108,16 @@ export declare function listSafe(app: App, pathOrFolder: PathOrFolder): Promise<
|
|
127
108
|
* @throws Will throw an error if the process fails after the specified number of retries or timeout.
|
128
109
|
*/
|
129
110
|
export declare function process(app: App, pathOrFile: PathOrFile, newContentProvider: ValueProvider<null | string, [string]>, options?: ProcessOptions): Promise<void>;
|
111
|
+
/**
|
112
|
+
* Reads the content of a file safely from the vault.
|
113
|
+
*
|
114
|
+
* It covers the case when the file was removed during the reading.
|
115
|
+
*
|
116
|
+
* @param app - The application instance.
|
117
|
+
* @param pathOrFile - The path or file to read.
|
118
|
+
* @returns A promise that resolves to the content of the file or `null` if the file is missing or deleted.
|
119
|
+
*/
|
120
|
+
export declare function readSafe(app: App, pathOrFile: PathOrFile): Promise<null | string>;
|
130
121
|
/**
|
131
122
|
* Renames a file safely in the vault.
|
132
123
|
* If the new path already exists, the file will be renamed to an available path.
|
@@ -0,0 +1,90 @@
|
|
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 __extractDefault(module2){return module2&&module2.__esModule&&module2.default?module2.default:module2}
|
7
|
+
|
8
|
+
(function patchRequireEsmDefault(){const __require=require;require=Object.assign(id=>{const module2=__require(id)??{};return __extractDefault(module2)},__require)})()
|
9
|
+
|
10
|
+
"use strict";
|
11
|
+
var __defProp = Object.defineProperty;
|
12
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
13
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
14
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
15
|
+
var __export = (target, all) => {
|
16
|
+
for (var name in all)
|
17
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
18
|
+
};
|
19
|
+
var __copyProps = (to, from, except, desc) => {
|
20
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
21
|
+
for (let key of __getOwnPropNames(from))
|
22
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
23
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
24
|
+
}
|
25
|
+
return to;
|
26
|
+
};
|
27
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
28
|
+
var VaultEx_exports = {};
|
29
|
+
__export(VaultEx_exports, {
|
30
|
+
deleteEmptyFolderHierarchy: () => deleteEmptyFolderHierarchy,
|
31
|
+
deleteSafe: () => deleteSafe
|
32
|
+
});
|
33
|
+
module.exports = __toCommonJS(VaultEx_exports);
|
34
|
+
var import_Error = require('../Error.cjs');
|
35
|
+
var import_FileSystem = require('./FileSystem.cjs');
|
36
|
+
var import_MetadataCache = require('./MetadataCache.cjs');
|
37
|
+
var import_Vault = require('./Vault.cjs');
|
38
|
+
async function deleteEmptyFolderHierarchy(app, pathOrFolder) {
|
39
|
+
let folder = (0, import_FileSystem.getFolderOrNull)(app, pathOrFolder);
|
40
|
+
while (folder) {
|
41
|
+
if (!await (0, import_Vault.isEmptyFolder)(app, folder)) {
|
42
|
+
return;
|
43
|
+
}
|
44
|
+
const parent = folder.parent;
|
45
|
+
await deleteSafe(app, folder.path);
|
46
|
+
folder = parent;
|
47
|
+
}
|
48
|
+
}
|
49
|
+
async function deleteSafe(app, pathOrFile, deletedNotePath, shouldReportUsedAttachments, shouldDeleteEmptyFolders) {
|
50
|
+
const file = (0, import_FileSystem.getAbstractFileOrNull)(app, pathOrFile);
|
51
|
+
if (!file) {
|
52
|
+
return false;
|
53
|
+
}
|
54
|
+
let canDelete = (0, import_FileSystem.isFile)(file) || (shouldDeleteEmptyFolders ?? true);
|
55
|
+
if ((0, import_FileSystem.isFile)(file)) {
|
56
|
+
const backlinks = await (0, import_MetadataCache.getBacklinksForFileSafe)(app, file);
|
57
|
+
if (deletedNotePath) {
|
58
|
+
backlinks.clear(deletedNotePath);
|
59
|
+
}
|
60
|
+
if (backlinks.count() !== 0) {
|
61
|
+
if (shouldReportUsedAttachments) {
|
62
|
+
new Notice(`Attachment ${file.path} is still used by other notes. It will not be deleted.`);
|
63
|
+
}
|
64
|
+
canDelete = false;
|
65
|
+
}
|
66
|
+
} else if ((0, import_FileSystem.isFolder)(file)) {
|
67
|
+
const listedFiles = await (0, import_Vault.listSafe)(app, file);
|
68
|
+
for (const child of [...listedFiles.files, ...listedFiles.folders]) {
|
69
|
+
canDelete &&= await deleteSafe(app, child, deletedNotePath, shouldReportUsedAttachments);
|
70
|
+
}
|
71
|
+
canDelete &&= await (0, import_Vault.isEmptyFolder)(app, file);
|
72
|
+
}
|
73
|
+
if (canDelete) {
|
74
|
+
try {
|
75
|
+
await app.fileManager.trashFile(file);
|
76
|
+
} catch (e) {
|
77
|
+
if (await app.vault.exists(file.path)) {
|
78
|
+
(0, import_Error.printError)(new Error(`Failed to delete ${file.path}`, { cause: e }));
|
79
|
+
canDelete = false;
|
80
|
+
}
|
81
|
+
}
|
82
|
+
}
|
83
|
+
return canDelete;
|
84
|
+
}
|
85
|
+
// Annotate the CommonJS export names for ESM import in node:
|
86
|
+
0 && (module.exports = {
|
87
|
+
deleteEmptyFolderHierarchy,
|
88
|
+
deleteSafe
|
89
|
+
});
|
90
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL1ZhdWx0RXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIFZhdWx0RXhcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIGFkZGl0aW9uYWwgdXRpbGl0aWVzIGZvciB3b3JraW5nIHdpdGggdGhlIE9ic2lkaWFuIFZhdWx0LlxuICpcbiAqIEl0IGhhcyB0byBiZSBleHRyYWN0ZWQgZnJvbSBgVmF1bHRgIGJlY2F1c2Ugb2YgY2lyY3VsYXIgZGVwZW5kZW5jaWVzLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQXBwIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgdHlwZSB7XG4gIFBhdGhPckFic3RyYWN0RmlsZSxcbiAgUGF0aE9yRm9sZGVyXG59IGZyb20gJy4vRmlsZVN5c3RlbS50cyc7XG5cbmltcG9ydCB7IHByaW50RXJyb3IgfSBmcm9tICcuLi9FcnJvci50cyc7XG5pbXBvcnQge1xuICBnZXRBYnN0cmFjdEZpbGVPck51bGwsXG4gIGdldEZvbGRlck9yTnVsbCxcbiAgaXNGaWxlLFxuICBpc0ZvbGRlclxufSBmcm9tICcuL0ZpbGVTeXN0ZW0udHMnO1xuaW1wb3J0IHsgZ2V0QmFja2xpbmtzRm9yRmlsZVNhZmUgfSBmcm9tICcuL01ldGFkYXRhQ2FjaGUudHMnO1xuaW1wb3J0IHtcbiAgaXNFbXB0eUZvbGRlcixcbiAgbGlzdFNhZmVcbn0gZnJvbSAnLi9WYXVsdC50cyc7XG5cbi8qKlxuICogUmVtb3ZlcyBlbXB0eSBmb2xkZXIgaGllcmFyY2h5IHN0YXJ0aW5nIGZyb20gdGhlIGdpdmVuIGZvbGRlci5cbiAqXG4gKiBAcGFyYW0gYXBwIC0gVGhlIGFwcGxpY2F0aW9uIGluc3RhbmNlLlxuICogQHBhcmFtIHBhdGhPckZvbGRlciAtIFRoZSBmb2xkZXIgdG8gc3RhcnQgcmVtb3ZpbmcgZW1wdHkgaGllcmFyY2h5IGZyb20uXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBlbXB0eSBoaWVyYXJjaHkgaXMgZGVsZXRlZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRlbGV0ZUVtcHR5Rm9sZGVySGllcmFyY2h5KGFwcDogQXBwLCBwYXRoT3JGb2xkZXI6IG51bGwgfCBQYXRoT3JGb2xkZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgbGV0IGZvbGRlciA9IGdldEZvbGRlck9yTnVsbChhcHAsIHBhdGhPckZvbGRlcik7XG5cbiAgd2hpbGUgKGZvbGRlcikge1xuICAgIGlmICghYXdhaXQgaXNFbXB0eUZvbGRlcihhcHAsIGZvbGRlcikpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgY29uc3QgcGFyZW50ID0gZm9sZGVyLnBhcmVudDtcbiAgICBhd2FpdCBkZWxldGVTYWZlKGFwcCwgZm9sZGVyLnBhdGgpO1xuICAgIGZvbGRlciA9IHBhcmVudDtcbiAgfVxufVxuXG4vKipcbiAqIERlbGV0ZXMgYWJzdHJhY3QgZmlsZSBzYWZlbHkgZnJvbSB0aGUgdmF1bHQuXG4gKlxuICogQHBhcmFtIGFwcCAtIFRoZSBPYnNpZGlhbiBhcHBsaWNhdGlvbiBpbnN0YW5jZS5cbiAqIEBwYXJhbSBwYXRoT3JGaWxlIC0gVGhlIHBhdGggb3IgYWJzdHJhY3QgZmlsZSB0byBkZWxldGUuXG4gKiBAcGFyYW0gZGVsZXRlZE5vdGVQYXRoIC0gT3B0aW9uYWwuIFRoZSBwYXRoIG9mIHRoZSBub3RlIHRoYXQgdHJpZ2dlcmVkIHRoZSByZW1vdmFsLlxuICogQHBhcmFtIHNob3VsZFJlcG9ydFVzZWRBdHRhY2htZW50cyAtIE9wdGlvbmFsLiBJZiBgdHJ1ZWAsIGEgbm90aWNlIHdpbGwgYmUgc2hvd24gZm9yIGVhY2ggYXR0YWNobWVudCB0aGF0IGlzIHN0aWxsIHVzZWQgYnkgb3RoZXIgbm90ZXMuXG4gKiBAcGFyYW0gc2hvdWxkRGVsZXRlRW1wdHlGb2xkZXJzIC0gT3B0aW9uYWwuIElmIGB0cnVlYCwgZW1wdHkgZm9sZGVycyB3aWxsIGJlIGRlbGV0ZWQuXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB0byBhIGJvb2xlYW4gaW5kaWNhdGluZyB3aGV0aGVyIHRoZSByZW1vdmFsIHdhcyBzdWNjZXNzZnVsLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVsZXRlU2FmZShhcHA6IEFwcCwgcGF0aE9yRmlsZTogUGF0aE9yQWJzdHJhY3RGaWxlLCBkZWxldGVkTm90ZVBhdGg/OiBzdHJpbmcsIHNob3VsZFJlcG9ydFVzZWRBdHRhY2htZW50cz86IGJvb2xlYW4sIHNob3VsZERlbGV0ZUVtcHR5Rm9sZGVycz86IGJvb2xlYW4pOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgY29uc3QgZmlsZSA9IGdldEFic3RyYWN0RmlsZU9yTnVsbChhcHAsIHBhdGhPckZpbGUpO1xuXG4gIGlmICghZmlsZSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGxldCBjYW5EZWxldGUgPSBpc0ZpbGUoZmlsZSkgfHwgKHNob3VsZERlbGV0ZUVtcHR5Rm9sZGVycyA/PyB0cnVlKTtcblxuICBpZiAoaXNGaWxlKGZpbGUpKSB7XG4gICAgY29uc3QgYmFja2xpbmtzID0gYXdhaXQgZ2V0QmFja2xpbmtzRm9yRmlsZVNhZmUoYXBwLCBmaWxlKTtcbiAgICBpZiAoZGVsZXRlZE5vdGVQYXRoKSB7XG4gICAgICBiYWNrbGlua3MuY2xlYXIoZGVsZXRlZE5vdGVQYXRoKTtcbiAgICB9XG4gICAgaWYgKGJhY2tsaW5rcy5jb3VudCgpICE9PSAwKSB7XG4gICAgICBpZiAoc2hvdWxkUmVwb3J0VXNlZEF0dGFjaG1lbnRzKSB7XG4gICAgICAgIG5ldyBOb3RpY2UoYEF0dGFjaG1lbnQgJHtmaWxlLnBhdGh9IGlzIHN0aWxsIHVzZWQgYnkgb3RoZXIgbm90ZXMuIEl0IHdpbGwgbm90IGJlIGRlbGV0ZWQuYCk7XG4gICAgICB9XG4gICAgICBjYW5EZWxldGUgPSBmYWxzZTtcbiAgICB9XG4gIH0gZWxzZSBpZiAoaXNGb2xkZXIoZmlsZSkpIHtcbiAgICBjb25zdCBsaXN0ZWRGaWxlcyA9IGF3YWl0IGxpc3RTYWZlKGFwcCwgZmlsZSk7XG4gICAgZm9yIChjb25zdCBjaGlsZCBvZiBbLi4ubGlzdGVkRmlsZXMuZmlsZXMsIC4uLmxpc3RlZEZpbGVzLmZvbGRlcnNdKSB7XG4gICAgICBjYW5EZWxldGUgJiY9IGF3YWl0IGRlbGV0ZVNhZmUoYXBwLCBjaGlsZCwgZGVsZXRlZE5vdGVQYXRoLCBzaG91bGRSZXBvcnRVc2VkQXR0YWNobWVudHMpO1xuICAgIH1cblxuICAgIGNhbkRlbGV0ZSAmJj0gYXdhaXQgaXNFbXB0eUZvbGRlcihhcHAsIGZpbGUpO1xuICB9XG5cbiAgaWYgKGNhbkRlbGV0ZSkge1xuICAgIHRyeSB7XG4gICAgICBhd2FpdCBhcHAuZmlsZU1hbmFnZXIudHJhc2hGaWxlKGZpbGUpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGlmIChhd2FpdCBhcHAudmF1bHQuZXhpc3RzKGZpbGUucGF0aCkpIHtcbiAgICAgICAgcHJpbnRFcnJvcihuZXcgRXJyb3IoYEZhaWxlZCB0byBkZWxldGUgJHtmaWxlLnBhdGh9YCwgeyBjYXVzZTogZSB9KSk7XG4gICAgICAgIGNhbkRlbGV0ZSA9IGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBjYW5EZWxldGU7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFjQSxtQkFBMkI7QUFDM0Isd0JBS087QUFDUCwyQkFBd0M7QUFDeEMsbUJBR087QUFTUCxlQUFzQiwyQkFBMkIsS0FBVSxjQUFrRDtBQUMzRyxNQUFJLGFBQVMsbUNBQWdCLEtBQUssWUFBWTtBQUU5QyxTQUFPLFFBQVE7QUFDYixRQUFJLENBQUMsVUFBTSw0QkFBYyxLQUFLLE1BQU0sR0FBRztBQUNyQztBQUFBLElBQ0Y7QUFDQSxVQUFNLFNBQVMsT0FBTztBQUN0QixVQUFNLFdBQVcsS0FBSyxPQUFPLElBQUk7QUFDakMsYUFBUztBQUFBLEVBQ1g7QUFDRjtBQVlBLGVBQXNCLFdBQVcsS0FBVSxZQUFnQyxpQkFBMEIsNkJBQXVDLDBCQUFzRDtBQUNoTSxRQUFNLFdBQU8seUNBQXNCLEtBQUssVUFBVTtBQUVsRCxNQUFJLENBQUMsTUFBTTtBQUNULFdBQU87QUFBQSxFQUNUO0FBRUEsTUFBSSxnQkFBWSwwQkFBTyxJQUFJLE1BQU0sNEJBQTRCO0FBRTdELFVBQUksMEJBQU8sSUFBSSxHQUFHO0FBQ2hCLFVBQU0sWUFBWSxVQUFNLDhDQUF3QixLQUFLLElBQUk7QUFDekQsUUFBSSxpQkFBaUI7QUFDbkIsZ0JBQVUsTUFBTSxlQUFlO0FBQUEsSUFDakM7QUFDQSxRQUFJLFVBQVUsTUFBTSxNQUFNLEdBQUc7QUFDM0IsVUFBSSw2QkFBNkI7QUFDL0IsWUFBSSxPQUFPLGNBQWMsS0FBSyxJQUFJLHdEQUF3RDtBQUFBLE1BQzVGO0FBQ0Esa0JBQVk7QUFBQSxJQUNkO0FBQUEsRUFDRixlQUFXLDRCQUFTLElBQUksR0FBRztBQUN6QixVQUFNLGNBQWMsVUFBTSx1QkFBUyxLQUFLLElBQUk7QUFDNUMsZUFBVyxTQUFTLENBQUMsR0FBRyxZQUFZLE9BQU8sR0FBRyxZQUFZLE9BQU8sR0FBRztBQUNsRSxvQkFBYyxNQUFNLFdBQVcsS0FBSyxPQUFPLGlCQUFpQiwyQkFBMkI7QUFBQSxJQUN6RjtBQUVBLGtCQUFjLFVBQU0sNEJBQWMsS0FBSyxJQUFJO0FBQUEsRUFDN0M7QUFFQSxNQUFJLFdBQVc7QUFDYixRQUFJO0FBQ0YsWUFBTSxJQUFJLFlBQVksVUFBVSxJQUFJO0FBQUEsSUFDdEMsU0FBUyxHQUFHO0FBQ1YsVUFBSSxNQUFNLElBQUksTUFBTSxPQUFPLEtBQUssSUFBSSxHQUFHO0FBQ3JDLHFDQUFXLElBQUksTUFBTSxvQkFBb0IsS0FBSyxJQUFJLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0FBQ25FLG9CQUFZO0FBQUEsTUFDZDtBQUFBLElBQ0Y7QUFBQSxFQUNGO0FBRUEsU0FBTztBQUNUOyIsCiAgIm5hbWVzIjogW10KfQo=
|
@@ -0,0 +1,27 @@
|
|
1
|
+
/**
|
2
|
+
* @packageDocumentation VaultEx
|
3
|
+
* This module provides additional utilities for working with the Obsidian Vault.
|
4
|
+
*
|
5
|
+
* It has to be extracted from `Vault` because of circular dependencies.
|
6
|
+
*/
|
7
|
+
import type { App } from 'obsidian';
|
8
|
+
import type { PathOrAbstractFile, PathOrFolder } from './FileSystem.ts';
|
9
|
+
/**
|
10
|
+
* Removes empty folder hierarchy starting from the given folder.
|
11
|
+
*
|
12
|
+
* @param app - The application instance.
|
13
|
+
* @param pathOrFolder - The folder to start removing empty hierarchy from.
|
14
|
+
* @returns A promise that resolves when the empty hierarchy is deleted.
|
15
|
+
*/
|
16
|
+
export declare function deleteEmptyFolderHierarchy(app: App, pathOrFolder: null | PathOrFolder): Promise<void>;
|
17
|
+
/**
|
18
|
+
* Deletes abstract file safely from the vault.
|
19
|
+
*
|
20
|
+
* @param app - The Obsidian application instance.
|
21
|
+
* @param pathOrFile - The path or abstract file to delete.
|
22
|
+
* @param deletedNotePath - Optional. The path of the note that triggered the removal.
|
23
|
+
* @param shouldReportUsedAttachments - Optional. If `true`, a notice will be shown for each attachment that is still used by other notes.
|
24
|
+
* @param shouldDeleteEmptyFolders - Optional. If `true`, empty folders will be deleted.
|
25
|
+
* @returns A promise that resolves to a boolean indicating whether the removal was successful.
|
26
|
+
*/
|
27
|
+
export declare function deleteSafe(app: App, pathOrFile: PathOrAbstractFile, deletedNotePath?: string, shouldReportUsedAttachments?: boolean, shouldDeleteEmptyFolders?: boolean): Promise<boolean>;
|
@@ -61,7 +61,8 @@ __export(obsidian_exports, {
|
|
61
61
|
Reference: () => Reference,
|
62
62
|
RenameDeleteHandler: () => RenameDeleteHandler,
|
63
63
|
ResourceUrl: () => ResourceUrl,
|
64
|
-
Vault: () => Vault
|
64
|
+
Vault: () => Vault,
|
65
|
+
VaultEx: () => VaultEx
|
65
66
|
});
|
66
67
|
module.exports = __toCommonJS(obsidian_exports);
|
67
68
|
var App = __toESM(__extractDefault(require('./App.cjs')), 1);
|
@@ -89,6 +90,7 @@ var Reference = __toESM(__extractDefault(require('./Reference.cjs')), 1);
|
|
89
90
|
var RenameDeleteHandler = __toESM(__extractDefault(require('./RenameDeleteHandler.cjs')), 1);
|
90
91
|
var ResourceUrl = __toESM(__extractDefault(require('./ResourceUrl.cjs')), 1);
|
91
92
|
var Vault = __toESM(__extractDefault(require('./Vault.cjs')), 1);
|
93
|
+
var VaultEx = __toESM(__extractDefault(require('./VaultEx.cjs')), 1);
|
92
94
|
// Annotate the CommonJS export names for ESM import in node:
|
93
95
|
0 && (module.exports = {
|
94
96
|
App,
|
@@ -115,6 +117,7 @@ var Vault = __toESM(__extractDefault(require('./Vault.cjs')), 1);
|
|
115
117
|
Reference,
|
116
118
|
RenameDeleteHandler,
|
117
119
|
ResourceUrl,
|
118
|
-
Vault
|
120
|
+
Vault,
|
121
|
+
VaultEx
|
119
122
|
});
|
120
|
-
//# sourceMappingURL=data:application/json;base64,
|
123
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgQXBwIGZyb20gJy4vQXBwLnRzJztcbmV4cG9ydCAqIGFzIEF0dGFjaG1lbnRQYXRoIGZyb20gJy4vQXR0YWNobWVudFBhdGgudHMnO1xuZXhwb3J0ICogYXMgQmFja2xpbmsgZnJvbSAnLi9CYWNrbGluay50cyc7XG5leHBvcnQgKiBhcyBDYWxsb3V0IGZyb20gJy4vQ2FsbG91dC50cyc7XG5leHBvcnQgKiBhcyBEYXRhdmlldyBmcm9tICcuL0RhdGF2aWV3LnRzJztcbmV4cG9ydCAqIGFzIERhdGF2aWV3TGluayBmcm9tICcuL0RhdGF2aWV3TGluay50cyc7XG5leHBvcnQgKiBhcyBGaWxlQ2hhbmdlIGZyb20gJy4vRmlsZUNoYW5nZS50cyc7XG5leHBvcnQgKiBhcyBGaWxlTWFuYWdlciBmcm9tICcuL0ZpbGVNYW5hZ2VyLnRzJztcbmV4cG9ydCAqIGFzIEZpbGVTeXN0ZW0gZnJvbSAnLi9GaWxlU3lzdGVtLnRzJztcbmV4cG9ydCAqIGFzIEZyb250bWF0dGVyIGZyb20gJy4vRnJvbnRtYXR0ZXIudHMnO1xuZXhwb3J0ICogYXMgTGluayBmcm9tICcuL0xpbmsudHMnO1xuZXhwb3J0ICogYXMgTG9nZ2VyIGZyb20gJy4vTG9nZ2VyLnRzJztcbmV4cG9ydCAqIGFzIExvb3AgZnJvbSAnLi9Mb29wLnRzJztcbmV4cG9ydCAqIGFzIE1hcmtkb3duIGZyb20gJy4vTWFya2Rvd24udHMnO1xuZXhwb3J0ICogYXMgTWFya2Rvd25Db2RlQmxvY2tQcm9jZXNzb3IgZnJvbSAnLi9NYXJrZG93bkNvZGVCbG9ja1Byb2Nlc3Nvci50cyc7XG5leHBvcnQgKiBhcyBNYXJrZG93blZpZXcgZnJvbSAnLi9NYXJrZG93blZpZXcudHMnO1xuZXhwb3J0ICogYXMgTWV0YWRhdGFDYWNoZSBmcm9tICcuL01ldGFkYXRhQ2FjaGUudHMnO1xuZXhwb3J0ICogYXMgTW9kYWwgZnJvbSAnLi9Nb2RhbC9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBPYnNpZGlhblNldHRpbmdzIGZyb20gJy4vT2JzaWRpYW5TZXR0aW5ncy50cyc7XG5leHBvcnQgKiBhcyBQbHVnaW4gZnJvbSAnLi9QbHVnaW4vaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgUXVldWUgZnJvbSAnLi9RdWV1ZS50cyc7XG5leHBvcnQgKiBhcyBSZWZlcmVuY2UgZnJvbSAnLi9SZWZlcmVuY2UudHMnO1xuZXhwb3J0ICogYXMgUmVuYW1lRGVsZXRlSGFuZGxlciBmcm9tICcuL1JlbmFtZURlbGV0ZUhhbmRsZXIudHMnO1xuZXhwb3J0ICogYXMgUmVzb3VyY2VVcmwgZnJvbSAnLi9SZXNvdXJjZVVybC50cyc7XG5leHBvcnQgKiBhcyBWYXVsdCBmcm9tICcuL1ZhdWx0LnRzJztcbmV4cG9ydCAqIGFzIFZhdWx0RXggZnJvbSAnLi9WYXVsdEV4LnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFFQSxVQUFxQjtBQUNyQixxQkFBZ0M7QUFDaEMsZUFBMEI7QUFDMUIsY0FBeUI7QUFDekIsZUFBMEI7QUFDMUIsbUJBQThCO0FBQzlCLGlCQUE0QjtBQUM1QixrQkFBNkI7QUFDN0IsaUJBQTRCO0FBQzVCLGtCQUE2QjtBQUM3QixXQUFzQjtBQUN0QixhQUF3QjtBQUN4QixXQUFzQjtBQUN0QixlQUEwQjtBQUMxQixpQ0FBNEM7QUFDNUMsbUJBQThCO0FBQzlCLG9CQUErQjtBQUMvQixZQUF1QjtBQUN2Qix1QkFBa0M7QUFDbEMsYUFBd0I7QUFDeEIsWUFBdUI7QUFDdkIsZ0JBQTJCO0FBQzNCLDBCQUFxQztBQUNyQyxrQkFBNkI7QUFDN0IsWUFBdUI7QUFDdkIsY0FBeUI7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
@@ -0,0 +1,52 @@
|
|
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 __extractDefault(module2){return module2&&module2.__esModule&&module2.default?module2.default:module2}
|
7
|
+
|
8
|
+
(function patchRequireEsmDefault(){const __require=require;require=Object.assign(id=>{const module2=__require(id)??{};return __extractDefault(module2)},__require)})()
|
9
|
+
|
10
|
+
"use strict";
|
11
|
+
var __defProp = Object.defineProperty;
|
12
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
13
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
14
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
15
|
+
var __export = (target, all) => {
|
16
|
+
for (var name in all)
|
17
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
18
|
+
};
|
19
|
+
var __copyProps = (to, from, except, desc) => {
|
20
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
21
|
+
for (let key of __getOwnPropNames(from))
|
22
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
23
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
24
|
+
}
|
25
|
+
return to;
|
26
|
+
};
|
27
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
28
|
+
var NpmPublish_exports = {};
|
29
|
+
__export(NpmPublish_exports, {
|
30
|
+
publish: () => publish
|
31
|
+
});
|
32
|
+
module.exports = __toCommonJS(NpmPublish_exports);
|
33
|
+
var import_dotenv = require('dotenv');
|
34
|
+
var import_NodeModules = require('./NodeModules.cjs');
|
35
|
+
var import_Root = require('./Root.cjs');
|
36
|
+
var __process = globalThis["process"] ?? {
|
37
|
+
"cwd": () => "/",
|
38
|
+
"env": {},
|
39
|
+
"platform": "android"
|
40
|
+
};
|
41
|
+
async function publish(isBeta) {
|
42
|
+
(0, import_dotenv.config)();
|
43
|
+
const npmEnv = import_NodeModules.process.env;
|
44
|
+
await (0, import_Root.execFromRoot)(["npm", "config", "set", `//registry.npmjs.org/:_authToken=${npmEnv.NPM_TOKEN ?? ""}`]);
|
45
|
+
const tag = isBeta ? "beta" : "latest";
|
46
|
+
await (0, import_Root.execFromRoot)(["npm", "publish", "--tag", tag]);
|
47
|
+
}
|
48
|
+
// Annotate the CommonJS export names for ESM import in node:
|
49
|
+
0 && (module.exports = {
|
50
|
+
publish
|
51
|
+
});
|
52
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvTnBtUHVibGlzaC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsidmFyIF9fcHJvY2VzcyA9IGdsb2JhbFRoaXNbJ3Byb2Nlc3MnXSA/PyB7XG4gIFwiY3dkXCI6ICgpPT5cIi9cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBOcG1QdWJsaXNoXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgTlBNIHB1Ymxpc2guXG4gKi9cblxuaW1wb3J0IHsgY29uZmlnIH0gZnJvbSAnZG90ZW52JztcblxuaW1wb3J0IHsgcHJvY2VzcyB9IGZyb20gJy4vTm9kZU1vZHVsZXMudHMnO1xuaW1wb3J0IHsgZXhlY0Zyb21Sb290IH0gZnJvbSAnLi9Sb290LnRzJztcblxuaW50ZXJmYWNlIE5wbUVudiB7XG4gIE5QTV9UT0tFTjogc3RyaW5nO1xufVxuXG4vKipcbiAqIFB1Ymxpc2ggdG8gTlBNLlxuICogQHBhcmFtIGlzQmV0YSAtIFdoZXRoZXIgdG8gcHVibGlzaCB0byB0aGUgYmV0YSBOUE0gcmVnaXN0cnkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwdWJsaXNoKGlzQmV0YT86IGJvb2xlYW4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uZmlnKCk7XG4gIGNvbnN0IG5wbUVudiA9IHByb2Nlc3MuZW52IGFzIFBhcnRpYWw8TnBtRW52PjtcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnBtJywgJ2NvbmZpZycsICdzZXQnLCBgLy9yZWdpc3RyeS5ucG1qcy5vcmcvOl9hdXRoVG9rZW49JHtucG1FbnYuTlBNX1RPS0VOID8/ICcnfWBdKTtcblxuICBjb25zdCB0YWcgPSBpc0JldGEgPyAnYmV0YScgOiAnbGF0ZXN0JztcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsnbnBtJywgJ3B1Ymxpc2gnLCAnLS10YWcnLCB0YWddKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFVQSxvQkFBdUI7QUFFdkIseUJBQXdCO0FBQ3hCLGtCQUE2QjtBQWI3QixJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxPQUFPLE1BQUk7QUFBQSxFQUNYLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBbUJBLGVBQXNCLFFBQVEsUUFBaUM7QUFDN0QsNEJBQU87QUFDUCxRQUFNLFNBQVMsMkJBQVE7QUFDdkIsWUFBTSwwQkFBYSxDQUFDLE9BQU8sVUFBVSxPQUFPLG9DQUFvQyxPQUFPLGFBQWEsRUFBRSxFQUFFLENBQUM7QUFFekcsUUFBTSxNQUFNLFNBQVMsU0FBUztBQUM5QixZQUFNLDBCQUFhLENBQUMsT0FBTyxXQUFXLFNBQVMsR0FBRyxDQUFDO0FBQ3JEOyIsCiAgIm5hbWVzIjogW10KfQo=
|
package/dist/lib/scripts/cli.cjs
CHANGED
@@ -39,6 +39,7 @@ var import_ObsidianPluginBuilder = require('./esbuild/ObsidianPluginBuilder.cjs'
|
|
39
39
|
var import_ESLint = require('./ESLint/ESLint.cjs');
|
40
40
|
var import_NodeModules = require('./NodeModules.cjs');
|
41
41
|
var import_Npm = require('./Npm.cjs');
|
42
|
+
var import_NpmPublish = require('./NpmPublish.cjs');
|
42
43
|
var import_spellcheck = require('./spellcheck.cjs');
|
43
44
|
var import_version = require('./version.cjs');
|
44
45
|
var __process = globalThis["process"] ?? {
|
@@ -69,6 +70,7 @@ function cli(argv = import_NodeModules.process.argv.slice(NODE_SCRIPT_ARGV_SKIP_
|
|
69
70
|
addCommand(program, "dev" /* Dev */, "Build the plugin in development mode", () => (0, import_ObsidianPluginBuilder.buildObsidianPlugin)({ mode: import_ObsidianPluginBuilder.BuildMode.Development }));
|
70
71
|
addCommand(program, "lint" /* Lint */, "Lint the source code", () => (0, import_ESLint.lint)());
|
71
72
|
addCommand(program, "lint:fix" /* LintFix */, "Lint the source code and apply automatic fixes", () => (0, import_ESLint.lint)(true));
|
73
|
+
addCommand(program, "publish" /* Publish */, "Publish to NPM", (isBeta) => (0, import_NpmPublish.publish)(isBeta)).argument("[isBeta]", "Publish to NPM beta");
|
72
74
|
addCommand(program, "spellcheck" /* Spellcheck */, "Spellcheck the source code", () => (0, import_spellcheck.spellcheck)());
|
73
75
|
addCommand(program, "version" /* Version */, "Release a new version", (versionUpdateType) => (0, import_version.updateVersion)(versionUpdateType)).argument("[versionUpdateType]", "Version update type: major, minor, patch, beta, or x.y.z[-suffix]");
|
74
76
|
await program.parseAsync(argv, { from: "user" });
|
@@ -82,4 +84,4 @@ function addCommand(program, name, description, taskFn) {
|
|
82
84
|
0 && (module.exports = {
|
83
85
|
cli
|
84
86
|
});
|
85
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvY2xpLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ2YXIgX19wcm9jZXNzID0gZ2xvYmFsVGhpc1sncHJvY2VzcyddID8/IHtcbiAgXCJjd2RcIjogKCk9PlwiL1wiLFxuICBcImVudlwiOiB7fSxcbiAgXCJwbGF0Zm9ybVwiOiBcImFuZHJvaWRcIlxufTtcbnZhciBfX2ltcG9ydF9tZXRhX3VybCA9IGdsb2JhbFRoaXNbJ2ltcG9ydC5tZXRhLnVybCddID8/ICgoKT0+
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/cli.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\nvar __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof module[\"exports\"]!==\"undefined\"){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  buildStatic,\n  buildValidate\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { process } from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildStatic = 'build:static',\n  BuildValidate = 'build:validate',\n  Dev = 'dev',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() => wrapCliTask(async () => {\n    const packageJson = await readPackageJson(getDirname(import.meta.url));\n    const program = new Command();\n\n    program\n      .name(packageJson.name ?? '(unknown)')\n      .description('CLI for Obsidian plugin development utilities')\n      .version(packageJson.version ?? '(unknown)');\n\n    addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n    addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n    addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n    addCommand(program, CommandNames.BuildValidate, 'Validates if TypeScript code compiles', () => buildValidate());\n    addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n    addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n    addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n    addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n      .argument('[isBeta]', 'Publish to NPM beta');\n    addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n    addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n      .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n    await program.parseAsync(argv, { from: 'user' });\n    return CliTaskResult.DoNotExit();\n  }));\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters, @typescript-eslint/no-invalid-void-type\nfunction addCommand<Args extends unknown[]>(program: Command, name: string, description: string, taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,uBAAwB;AAIxB,mBAAkC;AAClC,kBAA2B;AAC3B,mBAIO;AACP,sBAGO;AACP,mCAGO;AACP,oBAAqB;AACrB,yBAAwB;AACxB,iBAAgC;AAChC,wBAAwB;AACxB,wBAA2B;AAC3B,qBAA8B;AAtC9B,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AACA,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,OAAO,SAAS,MAAI,aAAY;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;AAwCzP,MAAM,8BAA8B;AAwB7B,SAAS,IAAI,OAAiB,2BAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F,sCAAkB,UAAM,6BAAY,YAAY;AAC9C,UAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,UAAM,UAAU,IAAI,yBAAQ;AAE5B,YACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,eAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,eAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,eAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,eAAW,SAAS,sCAA4B,yCAAyC,UAAM,4BAAc,CAAC;AAC9G,eAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,eAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,eAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,eAAW,SAAS,yBAAsB,kBAAkB,CAAC,eAAoB,2BAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,eAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,eAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,UAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,WAAO,8BAAc,UAAU;AAAA,EACjC,CAAC,CAAC;AACJ;AAYA,SAAS,WAAmC,SAAkB,MAAc,aAAqB,QAAwE;AACvK,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,aAAe,6BAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

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

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

|
@@ -45,6 +45,7 @@ __export(scripts_exports, {
|
|
45
45
|
JSON: () => JSON,
|
46
46
|
NodeModules: () => NodeModules,
|
47
47
|
Npm: () => Npm,
|
48
|
+
NpmPublish: () => NpmPublish,
|
48
49
|
ObsidianDevUtilsRepoPaths: () => ObsidianDevUtilsRepoPaths,
|
49
50
|
Root: () => Root,
|
50
51
|
build: () => build,
|
@@ -65,6 +66,7 @@ var Fs = __toESM(__extractDefault(require('./Fs.cjs')), 1);
|
|
65
66
|
var JSON = __toESM(__extractDefault(require('./JSON.cjs')), 1);
|
66
67
|
var NodeModules = __toESM(__extractDefault(require('./NodeModules.cjs')), 1);
|
67
68
|
var Npm = __toESM(__extractDefault(require('./Npm.cjs')), 1);
|
69
|
+
var NpmPublish = __toESM(__extractDefault(require('./NpmPublish.cjs')), 1);
|
68
70
|
var ObsidianDevUtilsRepoPaths = __toESM(__extractDefault(require('./ObsidianDevUtilsRepoPaths.cjs')), 1);
|
69
71
|
var Root = __toESM(__extractDefault(require('./Root.cjs')), 1);
|
70
72
|
var spellcheck = __toESM(__extractDefault(require('./spellcheck.cjs')), 1);
|
@@ -79,6 +81,7 @@ var version = __toESM(__extractDefault(require('./version.cjs')), 1);
|
|
79
81
|
JSON,
|
80
82
|
NodeModules,
|
81
83
|
Npm,
|
84
|
+
NpmPublish,
|
82
85
|
ObsidianDevUtilsRepoPaths,
|
83
86
|
Root,
|
84
87
|
build,
|
@@ -87,4 +90,4 @@ var version = __toESM(__extractDefault(require('./version.cjs')), 1);
|
|
87
90
|
spellcheck,
|
88
91
|
version
|
89
92
|
});
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
93
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qIFRISVMgSVMgQSBHRU5FUkFURUQvQlVORExFRCBGSUxFIEJZIEJVSUxEIFNDUklQVCAqL1xuXG5leHBvcnQgKiBhcyBidWlsZCBmcm9tICcuL2J1aWxkLnRzJztcbmV4cG9ydCAqIGFzIGNsaSBmcm9tICcuL2NsaS50cyc7XG5leHBvcnQgKiBhcyBDbGlVdGlscyBmcm9tICcuL0NsaVV0aWxzLnRzJztcbmV4cG9ydCAqIGFzIENvZGVHZW5lcmF0b3IgZnJvbSAnLi9Db2RlR2VuZXJhdG9yLnRzJztcbmV4cG9ydCAqIGFzIGVzYnVpbGQgZnJvbSAnLi9lc2J1aWxkL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIEVTTGludCBmcm9tICcuL0VTTGludC9pbmRleC50cyc7XG5leHBvcnQgKiBhcyBFeGVjIGZyb20gJy4vRXhlYy50cyc7XG5leHBvcnQgKiBhcyBGcyBmcm9tICcuL0ZzLnRzJztcbmV4cG9ydCAqIGFzIEpTT04gZnJvbSAnLi9KU09OLnRzJztcbmV4cG9ydCAqIGFzIE5vZGVNb2R1bGVzIGZyb20gJy4vTm9kZU1vZHVsZXMudHMnO1xuZXhwb3J0ICogYXMgTnBtIGZyb20gJy4vTnBtLnRzJztcbmV4cG9ydCAqIGFzIE5wbVB1Ymxpc2ggZnJvbSAnLi9OcG1QdWJsaXNoLnRzJztcbmV4cG9ydCAqIGFzIE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMgZnJvbSAnLi9PYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLnRzJztcbmV4cG9ydCAqIGFzIFJvb3QgZnJvbSAnLi9Sb290LnRzJztcbmV4cG9ydCAqIGFzIHNwZWxsY2hlY2sgZnJvbSAnLi9zcGVsbGNoZWNrLnRzJztcbmV4cG9ydCAqIGFzIHZlcnNpb24gZnJvbSAnLi92ZXJzaW9uLnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRUEsWUFBdUI7QUFDdkIsVUFBcUI7QUFDckIsZUFBMEI7QUFDMUIsb0JBQStCO0FBQy9CLGNBQXlCO0FBQ3pCLGFBQXdCO0FBQ3hCLFdBQXNCO0FBQ3RCLFNBQW9CO0FBQ3BCLFdBQXNCO0FBQ3RCLGtCQUE2QjtBQUM3QixVQUFxQjtBQUNyQixpQkFBNEI7QUFDNUIsZ0NBQTJDO0FBQzNDLFdBQXNCO0FBQ3RCLGlCQUE0QjtBQUM1QixjQUF5QjsiLAogICJuYW1lcyI6IFtdCn0K
|
@@ -9,6 +9,7 @@ export * as Fs from './Fs.ts';
|
|
9
9
|
export * as JSON from './JSON.ts';
|
10
10
|
export * as NodeModules from './NodeModules.ts';
|
11
11
|
export * as Npm from './Npm.ts';
|
12
|
+
export * as NpmPublish from './NpmPublish.ts';
|
12
13
|
export * as ObsidianDevUtilsRepoPaths from './ObsidianDevUtilsRepoPaths.ts';
|
13
14
|
export * as Root from './Root.ts';
|
14
15
|
export * as spellcheck from './spellcheck.ts';
|