obsidian-dev-utils 4.10.0 → 4.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/dist/lib/@types/compare-versions.d.ts +1 -0
  3. package/dist/lib/Async.cjs +50 -35
  4. package/dist/lib/Async.d.ts +66 -66
  5. package/dist/lib/Blob.cjs +11 -11
  6. package/dist/lib/Blob.d.ts +7 -7
  7. package/dist/lib/Error.cjs +17 -17
  8. package/dist/lib/Error.d.ts +14 -14
  9. package/dist/lib/Function.cjs +8 -8
  10. package/dist/lib/Function.d.ts +12 -12
  11. package/dist/lib/Object.cjs +36 -36
  12. package/dist/lib/Object.d.ts +55 -55
  13. package/dist/lib/Path.cjs +16 -16
  14. package/dist/lib/Path.d.ts +28 -28
  15. package/dist/lib/String.cjs +35 -35
  16. package/dist/lib/String.d.ts +55 -55
  17. package/dist/lib/ValueProvider.cjs +4 -4
  18. package/dist/lib/obsidian/App.cjs +6 -6
  19. package/dist/lib/obsidian/App.d.ts +7 -7
  20. package/dist/lib/obsidian/AttachmentPath.cjs +9 -9
  21. package/dist/lib/obsidian/AttachmentPath.d.ts +8 -8
  22. package/dist/lib/obsidian/Backlink.cjs +28 -28
  23. package/dist/lib/obsidian/Backlink.d.ts +22 -22
  24. package/dist/lib/obsidian/Callout.cjs +13 -13
  25. package/dist/lib/obsidian/Dataview.cjs +40 -40
  26. package/dist/lib/obsidian/Dataview.d.ts +69 -69
  27. package/dist/lib/obsidian/FileChange.cjs +7 -7
  28. package/dist/lib/obsidian/FileChange.d.ts +22 -22
  29. package/dist/lib/obsidian/FileManager.cjs +18 -18
  30. package/dist/lib/obsidian/FileManager.d.ts +11 -11
  31. package/dist/lib/obsidian/FileSystem.cjs +31 -31
  32. package/dist/lib/obsidian/FileSystem.d.ts +41 -41
  33. package/dist/lib/obsidian/FrontMatter.cjs +1 -1
  34. package/dist/lib/obsidian/FrontMatter.d.ts +6 -6
  35. package/dist/lib/obsidian/Link.cjs +154 -154
  36. package/dist/lib/obsidian/Link.d.ts +163 -163
  37. package/dist/lib/obsidian/MetadataCache.cjs +61 -61
  38. package/dist/lib/obsidian/MetadataCache.d.ts +28 -28
  39. package/dist/lib/obsidian/Modal/Alert.cjs +7 -7
  40. package/dist/lib/obsidian/Modal/Confirm.cjs +7 -7
  41. package/dist/lib/obsidian/Modal/Prompt.cjs +15 -15
  42. package/dist/lib/obsidian/Modal/SelectItem.cjs +7 -7
  43. package/dist/lib/obsidian/ObsidianSettings.cjs +4 -4
  44. package/dist/lib/obsidian/ObsidianSettings.d.ts +6 -6
  45. package/dist/lib/obsidian/Plugin/Plugin.cjs +6 -6
  46. package/dist/lib/obsidian/Plugin/Plugin.d.ts +7 -7
  47. package/dist/lib/obsidian/Plugin/PluginBase.cjs +52 -52
  48. package/dist/lib/obsidian/Plugin/PluginBase.d.ts +29 -29
  49. package/dist/lib/obsidian/Plugin/PluginSettings.cjs +4 -4
  50. package/dist/lib/obsidian/Plugin/PluginSettings.d.ts +8 -8
  51. package/dist/lib/obsidian/Plugin/ValueComponent.cjs +1 -1
  52. package/dist/lib/obsidian/Plugin/ValueComponent.d.ts +51 -51
  53. package/dist/lib/obsidian/Queue.cjs +76 -0
  54. package/dist/lib/obsidian/Queue.d.ts +28 -0
  55. package/dist/lib/obsidian/Reference.cjs +12 -12
  56. package/dist/lib/obsidian/Reference.d.ts +7 -7
  57. package/dist/lib/obsidian/RenameDeleteHandler.cjs +130 -130
  58. package/dist/lib/obsidian/Vault.cjs +116 -116
  59. package/dist/lib/obsidian/Vault.d.ts +70 -70
  60. package/dist/lib/obsidian/index.cjs +4 -4
  61. package/dist/lib/obsidian/index.d.ts +1 -1
  62. package/dist/lib/scripts/CliUtils.cjs +30 -30
  63. package/dist/lib/scripts/CliUtils.d.ts +11 -11
  64. package/dist/lib/scripts/ESLint/@types/@guardian__eslint-plugin-tsdoc-required.d.ts +2 -0
  65. package/dist/lib/scripts/ESLint/@types/eslint-plugin-modules-newlines.d.ts +2 -0
  66. package/dist/lib/scripts/ESLint/@types/eslint-plugin-verify-tsdoc.d.ts +2 -0
  67. package/dist/lib/scripts/ESLint/eslint.config.cjs +2 -1
  68. package/dist/lib/scripts/Exec.cjs +1 -1
  69. package/dist/lib/scripts/Exec.d.ts +21 -21
  70. package/dist/lib/scripts/Fs.cjs +11 -11
  71. package/dist/lib/scripts/Fs.d.ts +13 -13
  72. package/dist/lib/scripts/JSON.cjs +7 -7
  73. package/dist/lib/scripts/JSON.d.ts +16 -16
  74. package/dist/lib/scripts/Npm.cjs +13 -13
  75. package/dist/lib/scripts/Npm.d.ts +43 -43
  76. package/dist/lib/scripts/Root.cjs +4 -4
  77. package/dist/lib/scripts/Root.d.ts +8 -8
  78. package/dist/lib/scripts/build.cjs +4 -4
  79. package/dist/lib/scripts/build.d.ts +8 -8
  80. package/dist/lib/scripts/cli.cjs +1 -1
  81. package/dist/lib/scripts/esbuild/Dependency.cjs +21 -21
  82. package/dist/lib/scripts/esbuild/Dependency.d.ts +6 -6
  83. package/dist/lib/scripts/esbuild/fixSourceMapsPlugin.cjs +5 -5
  84. package/dist/lib/scripts/version.cjs +134 -134
  85. package/dist/lib/scripts/version.d.ts +70 -70
  86. package/package.json +11 -11
  87. package/dist/lib/obsidian/ChainedPromise.cjs +0 -59
  88. package/dist/lib/obsidian/ChainedPromise.d.ts +0 -26
@@ -76,52 +76,32 @@ var VersionUpdateType = /* @__PURE__ */ ((VersionUpdateType2) => {
76
76
  VersionUpdateType2["Patch"] = "patch";
77
77
  return VersionUpdateType2;
78
78
  })(VersionUpdateType || {});
79
- async function updateVersion(versionUpdateType) {
80
- if (!versionUpdateType) {
81
- const npmOldVersion = __process.env["npm_old_version"];
82
- const npmNewVersion = __process.env["npm_new_version"];
83
- if (npmOldVersion && npmNewVersion) {
84
- await updateVersionInFiles(npmOldVersion, false);
85
- await updateVersion(npmNewVersion);
86
- return;
87
- }
88
- }
89
- const isObsidianPlugin = (0, import_NodeModules.existsSync)((0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson));
90
- validate(versionUpdateType);
91
- await checkGitInstalled();
92
- await checkGitRepoClean();
93
- await checkGitHubCliInstalled();
94
- await (0, import_Root.execFromRoot)("npm run spellcheck");
95
- await (0, import_Root.execFromRoot)("npm run build");
96
- await (0, import_Root.execFromRoot)("npm run lint");
97
- const newVersion = await getNewVersion(versionUpdateType);
98
- await updateVersionInFiles(newVersion, isObsidianPlugin);
99
- await updateChangelog(newVersion);
100
- await addUpdatedFilesToGit(newVersion);
101
- await addGitTag(newVersion);
102
- await gitPush();
103
- if (isObsidianPlugin) {
104
- await copyUpdatedManifest();
105
- }
106
- await publishGitHubRelease(newVersion, isObsidianPlugin);
79
+ async function addGitTag(newVersion) {
80
+ await (0, import_Root.execFromRoot)(`git tag -a ${newVersion} -m ${newVersion} --force`, { quiet: true });
107
81
  }
108
- function validate(versionUpdateType) {
109
- if (getVersionUpdateType(versionUpdateType) === "invalid" /* Invalid */) {
110
- throw new Error("Invalid version update type. Please use 'major', 'minor', 'patch', or 'x.y.z[-suffix]' format.");
111
- }
82
+ async function addUpdatedFilesToGit(newVersion) {
83
+ const files = [
84
+ import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson,
85
+ import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.PackageJson,
86
+ import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.PackageLockJson,
87
+ import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.VersionsJson,
88
+ import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ChangelogMd
89
+ ].filter((file) => (0, import_NodeModules.existsSync)((0, import_Root.resolvePathFromRoot)(file)));
90
+ await (0, import_Root.execFromRoot)(["git", "add", ...files], { quiet: true });
91
+ await (0, import_Root.execFromRoot)(`git commit -m ${newVersion} --allow-empty`, { quiet: true });
112
92
  }
113
- async function checkGitInstalled() {
93
+ async function checkGitHubCliInstalled() {
114
94
  try {
115
- await (0, import_Root.execFromRoot)("git --version", { quiet: true });
95
+ await (0, import_Root.execFromRoot)("gh --version", { quiet: true });
116
96
  } catch {
117
- throw new Error("Git is not installed. Please install it from https://git-scm.com/");
97
+ throw new Error("GitHub CLI is not installed. Please install it from https://cli.github.com/");
118
98
  }
119
99
  }
120
- async function checkGitHubCliInstalled() {
100
+ async function checkGitInstalled() {
121
101
  try {
122
- await (0, import_Root.execFromRoot)("gh --version", { quiet: true });
102
+ await (0, import_Root.execFromRoot)("git --version", { quiet: true });
123
103
  } catch {
124
- throw new Error("GitHub CLI is not installed. Please install it from https://cli.github.com/");
104
+ throw new Error("Git is not installed. Please install it from https://git-scm.com/");
125
105
  }
126
106
  }
127
107
  async function checkGitRepoClean() {
@@ -134,42 +114,8 @@ async function checkGitRepoClean() {
134
114
  throw new Error("Git repository is not clean. Please commit or stash your changes before releasing a new version.");
135
115
  }
136
116
  }
137
- function getVersionUpdateType(versionUpdateType) {
138
- const versionUpdateTypeEnum = versionUpdateType;
139
- switch (versionUpdateTypeEnum) {
140
- case "beta" /* Beta */:
141
- case "major" /* Major */:
142
- case "minor" /* Minor */:
143
- case "patch" /* Patch */:
144
- return versionUpdateTypeEnum;
145
- default:
146
- if (/^\d+\.\d+\.\d+(-[\w\d.-]+)?$/.test(versionUpdateType)) {
147
- return "manual" /* Manual */;
148
- }
149
- return "invalid" /* Invalid */;
150
- }
151
- }
152
- async function updateVersionInFiles(newVersion, isObsidianPlugin) {
153
- await (0, import_Npm.editNpmPackage)((npmPackage) => {
154
- npmPackage.version = newVersion;
155
- });
156
- await (0, import_Npm.editNpmPackageLock)((npmPackageLock) => {
157
- npmPackageLock.version = newVersion;
158
- const defaultPackage = npmPackageLock.packages?.[""];
159
- if (defaultPackage) {
160
- defaultPackage.version = newVersion;
161
- }
162
- }, { skipIfMissing: true });
163
- if (isObsidianPlugin) {
164
- const latestObsidianVersion = await getLatestObsidianVersion();
165
- await (0, import_JSON.editJson)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson, (manifest) => {
166
- manifest.minAppVersion = latestObsidianVersion;
167
- manifest.version = newVersion;
168
- });
169
- await (0, import_JSON.editJson)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.VersionsJson, (versions) => {
170
- versions[newVersion] = latestObsidianVersion;
171
- });
172
- }
117
+ async function copyUpdatedManifest() {
118
+ await (0, import_NodeModules.cp)((0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson), (0, import_Root.resolvePathFromRoot)((0, import_Path.join)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.DistBuild, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson)), { force: true });
173
119
  }
174
120
  async function getNewVersion(versionUpdateType) {
175
121
  const versionType = getVersionUpdateType(versionUpdateType);
@@ -211,65 +157,6 @@ async function getNewVersion(versionUpdateType) {
211
157
  }
212
158
  return `${major.toString()}.${minor.toString()}.${patch.toString()}${beta > 0 ? `-beta.${beta.toString()}` : ""}`;
213
159
  }
214
- async function getLatestObsidianVersion() {
215
- const response = await fetch("https://api.github.com/repos/obsidianmd/obsidian-releases/releases/latest");
216
- const obsidianReleasesJson = await response.json();
217
- return obsidianReleasesJson.name;
218
- }
219
- async function updateChangelog(newVersion) {
220
- const changelogPath = (0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ChangelogMd);
221
- let previousChangelogLines;
222
- if (!(0, import_NodeModules.existsSync)(changelogPath)) {
223
- previousChangelogLines = [];
224
- } else {
225
- const content = await (0, import_NodeModules.readFile)(changelogPath, "utf-8");
226
- previousChangelogLines = content.split("\n").slice(2);
227
- if (previousChangelogLines.at(-1) === "") {
228
- previousChangelogLines.pop();
229
- }
230
- }
231
- const lastTag = previousChangelogLines[0]?.replace("## ", "");
232
- const commitRange = lastTag ? `${lastTag}..HEAD` : "HEAD";
233
- const commitMessages = (await (0, import_Root.execFromRoot)(`git log ${commitRange} --format=%s --first-parent`, { quiet: true })).split(/\r?\n/);
234
- let newChangeLog = `# CHANGELOG
235
-
236
- ## ${newVersion}
237
-
238
- `;
239
- for (const message of commitMessages) {
240
- newChangeLog += `- ${message}
241
- `;
242
- }
243
- if (previousChangelogLines.length > 0) {
244
- newChangeLog += "\n";
245
- for (const line of previousChangelogLines) {
246
- newChangeLog += `${line}
247
- `;
248
- }
249
- }
250
- await (0, import_NodeModules.writeFile)(changelogPath, newChangeLog, "utf-8");
251
- await (0, import_NodeModules.createInterface)(__process.stdin, __process.stdout).question(`Please update the ${import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ChangelogMd} file. Press Enter when you are done...`);
252
- }
253
- async function addUpdatedFilesToGit(newVersion) {
254
- const files = [
255
- import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson,
256
- import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.PackageJson,
257
- import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.PackageLockJson,
258
- import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.VersionsJson,
259
- import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ChangelogMd
260
- ].filter((file) => (0, import_NodeModules.existsSync)((0, import_Root.resolvePathFromRoot)(file)));
261
- await (0, import_Root.execFromRoot)(["git", "add", ...files], { quiet: true });
262
- await (0, import_Root.execFromRoot)(`git commit -m ${newVersion} --allow-empty`, { quiet: true });
263
- }
264
- async function addGitTag(newVersion) {
265
- await (0, import_Root.execFromRoot)(`git tag -a ${newVersion} -m ${newVersion} --force`, { quiet: true });
266
- }
267
- async function gitPush() {
268
- await (0, import_Root.execFromRoot)("git push --follow-tags --force", { quiet: true });
269
- }
270
- async function copyUpdatedManifest() {
271
- await (0, import_NodeModules.cp)((0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson), (0, import_Root.resolvePathFromRoot)((0, import_Path.join)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.DistBuild, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson)), { force: true });
272
- }
273
160
  async function getReleaseNotes(newVersion) {
274
161
  const changelogPath = (0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ChangelogMd);
275
162
  const content = await (0, import_NodeModules.readFile)(changelogPath, "utf-8");
@@ -294,6 +181,24 @@ async function getReleaseNotes(newVersion) {
294
181
  releaseNotes += `**Full Changelog**: ${changesUrl}`;
295
182
  return releaseNotes;
296
183
  }
184
+ function getVersionUpdateType(versionUpdateType) {
185
+ const versionUpdateTypeEnum = versionUpdateType;
186
+ switch (versionUpdateTypeEnum) {
187
+ case "beta" /* Beta */:
188
+ case "major" /* Major */:
189
+ case "minor" /* Minor */:
190
+ case "patch" /* Patch */:
191
+ return versionUpdateTypeEnum;
192
+ default:
193
+ if (/^\d+\.\d+\.\d+(-[\w\d.-]+)?$/.test(versionUpdateType)) {
194
+ return "manual" /* Manual */;
195
+ }
196
+ return "invalid" /* Invalid */;
197
+ }
198
+ }
199
+ async function gitPush() {
200
+ await (0, import_Root.execFromRoot)("git push --follow-tags --force", { quiet: true });
201
+ }
297
202
  async function publishGitHubRelease(newVersion, isObsidianPlugin) {
298
203
  let filePaths;
299
204
  if (isObsidianPlugin) {
@@ -322,6 +227,101 @@ async function publishGitHubRelease(newVersion, isObsidianPlugin) {
322
227
  stdin: await getReleaseNotes(newVersion)
323
228
  });
324
229
  }
230
+ async function updateChangelog(newVersion) {
231
+ const changelogPath = (0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ChangelogMd);
232
+ let previousChangelogLines;
233
+ if (!(0, import_NodeModules.existsSync)(changelogPath)) {
234
+ previousChangelogLines = [];
235
+ } else {
236
+ const content = await (0, import_NodeModules.readFile)(changelogPath, "utf-8");
237
+ previousChangelogLines = content.split("\n").slice(2);
238
+ if (previousChangelogLines.at(-1) === "") {
239
+ previousChangelogLines.pop();
240
+ }
241
+ }
242
+ const lastTag = previousChangelogLines[0]?.replace("## ", "");
243
+ const commitRange = lastTag ? `${lastTag}..HEAD` : "HEAD";
244
+ const commitMessages = (await (0, import_Root.execFromRoot)(`git log ${commitRange} --format=%s --first-parent`, { quiet: true })).split(/\r?\n/);
245
+ let newChangeLog = `# CHANGELOG
246
+
247
+ ## ${newVersion}
248
+
249
+ `;
250
+ for (const message of commitMessages) {
251
+ newChangeLog += `- ${message}
252
+ `;
253
+ }
254
+ if (previousChangelogLines.length > 0) {
255
+ newChangeLog += "\n";
256
+ for (const line of previousChangelogLines) {
257
+ newChangeLog += `${line}
258
+ `;
259
+ }
260
+ }
261
+ await (0, import_NodeModules.writeFile)(changelogPath, newChangeLog, "utf-8");
262
+ await (0, import_NodeModules.createInterface)(__process.stdin, __process.stdout).question(`Please update the ${import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ChangelogMd} file. Press Enter when you are done...`);
263
+ }
264
+ async function updateVersion(versionUpdateType) {
265
+ if (!versionUpdateType) {
266
+ const npmOldVersion = __process.env["npm_old_version"];
267
+ const npmNewVersion = __process.env["npm_new_version"];
268
+ if (npmOldVersion && npmNewVersion) {
269
+ await updateVersionInFiles(npmOldVersion, false);
270
+ await updateVersion(npmNewVersion);
271
+ return;
272
+ }
273
+ }
274
+ const isObsidianPlugin = (0, import_NodeModules.existsSync)((0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson));
275
+ validate(versionUpdateType);
276
+ await checkGitInstalled();
277
+ await checkGitRepoClean();
278
+ await checkGitHubCliInstalled();
279
+ await (0, import_Root.execFromRoot)("npm run spellcheck");
280
+ await (0, import_Root.execFromRoot)("npm run build");
281
+ await (0, import_Root.execFromRoot)("npm run lint");
282
+ const newVersion = await getNewVersion(versionUpdateType);
283
+ await updateVersionInFiles(newVersion, isObsidianPlugin);
284
+ await updateChangelog(newVersion);
285
+ await addUpdatedFilesToGit(newVersion);
286
+ await addGitTag(newVersion);
287
+ await gitPush();
288
+ if (isObsidianPlugin) {
289
+ await copyUpdatedManifest();
290
+ }
291
+ await publishGitHubRelease(newVersion, isObsidianPlugin);
292
+ }
293
+ async function updateVersionInFiles(newVersion, isObsidianPlugin) {
294
+ await (0, import_Npm.editNpmPackage)((npmPackage) => {
295
+ npmPackage.version = newVersion;
296
+ });
297
+ await (0, import_Npm.editNpmPackageLock)((npmPackageLock) => {
298
+ npmPackageLock.version = newVersion;
299
+ const defaultPackage = npmPackageLock.packages?.[""];
300
+ if (defaultPackage) {
301
+ defaultPackage.version = newVersion;
302
+ }
303
+ }, { skipIfMissing: true });
304
+ if (isObsidianPlugin) {
305
+ const latestObsidianVersion = await getLatestObsidianVersion();
306
+ await (0, import_JSON.editJson)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson, (manifest) => {
307
+ manifest.minAppVersion = latestObsidianVersion;
308
+ manifest.version = newVersion;
309
+ });
310
+ await (0, import_JSON.editJson)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.VersionsJson, (versions) => {
311
+ versions[newVersion] = latestObsidianVersion;
312
+ });
313
+ }
314
+ }
315
+ function validate(versionUpdateType) {
316
+ if (getVersionUpdateType(versionUpdateType) === "invalid" /* Invalid */) {
317
+ throw new Error("Invalid version update type. Please use 'major', 'minor', 'patch', or 'x.y.z[-suffix]' format.");
318
+ }
319
+ }
320
+ async function getLatestObsidianVersion() {
321
+ const response = await fetch("https://api.github.com/repos/obsidianmd/obsidian-releases/releases/latest");
322
+ const obsidianReleasesJson = await response.json();
323
+ return obsidianReleasesJson.name;
324
+ }
325
325
  // Annotate the CommonJS export names for ESM import in node:
326
326
  0 && (module.exports = {
327
327
  VersionUpdateType,
@@ -341,4 +341,4 @@ async function publishGitHubRelease(newVersion, isObsidianPlugin) {
341
341
  updateVersionInFiles,
342
342
  validate
343
343
  });
344
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/version.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation version\n * This module provides functions for managing version updates in a project.\n * It includes tasks such as validating version update types, checking the state\n * of Git and GitHub CLI, updating version numbers in files, and performing\n * Git operations such as tagging and pushing.\n *\n * The main function, `updateVersion`, coordinates these tasks to ensure that\n * version updates are handled consistently and correctly. It also integrates\n * with Obsidian plugins, if applicable, by updating relevant files and releasing\n * new versions on GitHub.\n */\n\nimport AdmZip from 'adm-zip';\n\nimport { ObsidianPluginRepoPaths } from '../obsidian/Plugin/ObsidianPluginRepoPaths.ts';\nimport { join } from '../Path.ts';\nimport { readdirPosix } from './Fs.ts';\nimport { editJson } from './JSON.ts';\nimport {\n  cp,\n  createInterface,\n  existsSync,\n  readFile,\n  writeFile\n} from './NodeModules.ts';\nimport {\n  editNpmPackage,\n  editNpmPackageLock,\n  readNpmPackage\n} from './Npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\nimport {\n  execFromRoot,\n  resolvePathFromRoot\n} from './Root.ts';\n\n/**\n * Enum representing different types of version updates.\n */\nexport enum VersionUpdateType {\n  Beta = 'beta',\n  Invalid = 'invalid',\n  Major = 'major',\n  Manual = 'manual',\n  Minor = 'minor',\n  Patch = 'patch'\n}\n\n/**\n * Type representing the manifest file format for Obsidian plugins.\n */\nexport interface Manifest {\n  /**\n   * The minimum Obsidian version required for the plugin.\n   */\n  minAppVersion: string;\n\n  /**\n   * The version of the plugin.\n   */\n  version: string;\n}\n\n/**\n * Type representing the structure of Obsidian releases JSON.\n */\nexport interface ObsidianReleasesJson {\n  /**\n   * The name of the Obsidian release.\n   */\n  name: string;\n}\n\n/**\n * Updates the version of the project based on the specified update type.\n *\n * This function performs a series of tasks to handle version updates:\n * 1. Validates the version update type.\n * 2. Checks if Git and GitHub CLI are installed.\n * 3. Verifies that the Git repository is clean.\n * 4. Runs spellcheck and linting.\n * 5. Builds the project.\n * 6. Updates version in files and changelog.\n * 7. Adds updated files to Git, tags the commit, and pushes to the repository.\n * 8. If an Obsidian plugin, copies the updated manifest and publishes a GitHub release.\n *\n * @param versionUpdateType - The type of version update to perform (major, minor, patch, beta, or x.y.z[-beta:u]).\n * @returns A promise that resolves when the version update is complete.\n */\nexport async function updateVersion(versionUpdateType: string): Promise<void> {\n  if (!versionUpdateType) {\n    const npmOldVersion = process.env['npm_old_version'];\n    const npmNewVersion = process.env['npm_new_version'];\n\n    if (npmOldVersion && npmNewVersion) {\n      await updateVersionInFiles(npmOldVersion, false);\n      await updateVersion(npmNewVersion);\n      return;\n    }\n  }\n\n  const isObsidianPlugin = existsSync(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson));\n  validate(versionUpdateType);\n  await checkGitInstalled();\n  await checkGitRepoClean();\n  await checkGitHubCliInstalled();\n  await execFromRoot('npm run spellcheck');\n  await execFromRoot('npm run build');\n  await execFromRoot('npm run lint');\n\n  const newVersion = await getNewVersion(versionUpdateType);\n  await updateVersionInFiles(newVersion, isObsidianPlugin);\n  await updateChangelog(newVersion);\n  await addUpdatedFilesToGit(newVersion);\n  await addGitTag(newVersion);\n  await gitPush();\n  if (isObsidianPlugin) {\n    await copyUpdatedManifest();\n  }\n  await publishGitHubRelease(newVersion, isObsidianPlugin);\n}\n\n/**\n * Validates the version update type to ensure it is either a recognized type\n * or a valid manual version string.\n *\n * @param versionUpdateType - The version update type to validate.\n * @throws Error if the version update type is invalid.\n */\nexport function validate(versionUpdateType: string): void {\n  if (getVersionUpdateType(versionUpdateType) === VersionUpdateType.Invalid) {\n    throw new Error('Invalid version update type. Please use \\'major\\', \\'minor\\', \\'patch\\', or \\'x.y.z[-suffix]\\' format.');\n  }\n}\n\n/**\n * Checks if Git is installed on the system.\n *\n * Throws an error if Git is not installed.\n *\n * @throws Error if Git is not installed.\n */\nexport async function checkGitInstalled(): Promise<void> {\n  try {\n    await execFromRoot('git --version', { quiet: true });\n  } catch {\n    throw new Error('Git is not installed. Please install it from https://git-scm.com/');\n  }\n}\n\n/**\n * Checks if the GitHub CLI is installed on the system.\n *\n * Throws an error if the GitHub CLI is not installed.\n *\n * @throws Error if the GitHub CLI is not installed.\n */\nexport async function checkGitHubCliInstalled(): Promise<void> {\n  try {\n    await execFromRoot('gh --version', { quiet: true });\n  } catch {\n    throw new Error('GitHub CLI is not installed. Please install it from https://cli.github.com/');\n  }\n}\n\n/**\n * Checks if the Git repository is clean, meaning there are no uncommitted changes.\n *\n * Throws an error if the Git repository is not clean.\n *\n * @throws Error if the Git repository is not clean.\n */\nexport async function checkGitRepoClean(): Promise<void> {\n  try {\n    const stdout = await execFromRoot('git status --porcelain --untracked-files=all', { quiet: true });\n    if (stdout) {\n      throw new Error();\n    }\n  } catch {\n    throw new Error('Git repository is not clean. Please commit or stash your changes before releasing a new version.');\n  }\n}\n\n/**\n * Determines the type of version update based on the input string.\n *\n * @param versionUpdateType - The input string representing the version update type.\n * @returns The corresponding `VersionUpdateType`.\n */\nexport function getVersionUpdateType(versionUpdateType: string): VersionUpdateType {\n  const versionUpdateTypeEnum = versionUpdateType as VersionUpdateType;\n  switch (versionUpdateTypeEnum) {\n    case VersionUpdateType.Beta:\n    case VersionUpdateType.Major:\n    case VersionUpdateType.Minor:\n    case VersionUpdateType.Patch:\n      return versionUpdateTypeEnum;\n\n    default:\n      if (/^\\d+\\.\\d+\\.\\d+(-[\\w\\d.-]+)?$/.test(versionUpdateType)) {\n        return VersionUpdateType.Manual;\n      }\n\n      return VersionUpdateType.Invalid;\n  }\n}\n\n/**\n * Updates the version in various files, including `package.json`, `package-lock.json`,\n * and Obsidian plugin manifests if applicable.\n *\n * @param newVersion - The new version string to update in the files.\n * @param isObsidianPlugin - Whether the project is an Obsidian plugin.\n * @returns A `Promise` that resolves when the update is complete.\n */\nexport async function updateVersionInFiles(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  await editNpmPackage((npmPackage) => {\n    npmPackage.version = newVersion;\n  });\n\n  await editNpmPackageLock((npmPackageLock) => {\n    npmPackageLock.version = newVersion;\n    const defaultPackage = npmPackageLock.packages?.[''];\n    if (defaultPackage) {\n      defaultPackage.version = newVersion;\n    }\n  }, { skipIfMissing: true });\n\n  if (isObsidianPlugin) {\n    const latestObsidianVersion = await getLatestObsidianVersion();\n\n    await editJson<Manifest>(ObsidianPluginRepoPaths.ManifestJson, (manifest) => {\n      manifest.minAppVersion = latestObsidianVersion;\n      manifest.version = newVersion;\n    });\n\n    await editJson<Record<string, string>>(ObsidianPluginRepoPaths.VersionsJson, (versions) => {\n      versions[newVersion] = latestObsidianVersion;\n    });\n  }\n}\n\n/**\n * Generates a new version string based on the current version and the specified update type.\n *\n * @param versionUpdateType - The type of version update (major, minor, patch, beta, or manual).\n * @returns A `Promise` that resolves to the new version string.\n * @throws Error if the current version format is invalid.\n */\nexport async function getNewVersion(versionUpdateType: string): Promise<string> {\n  const versionType = getVersionUpdateType(versionUpdateType);\n  if (versionType === VersionUpdateType.Manual) {\n    return versionUpdateType;\n  }\n\n  const npmPackage = await readNpmPackage();\n  const currentVersion = npmPackage.version;\n\n  const match = /^(\\d+)\\.(\\d+)\\.(\\d+)(-beta.(\\d+))?/.exec(currentVersion);\n  if (!match) {\n    throw new Error(`Invalid current version format: ${currentVersion}`);\n  }\n\n  let major = Number(match[1]);\n  let minor = Number(match[2]);\n  let patch = Number(match[3]);\n  let beta = match[5] ? Number(match[5]) : 0;\n\n  switch (versionType) {\n    case VersionUpdateType.Beta:\n      if (beta === 0) {\n        patch++;\n      }\n      beta++;\n      break;\n    case VersionUpdateType.Major:\n      major++;\n      minor = 0;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Minor:\n      minor++;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Patch:\n      patch++;\n      beta = 0;\n      break;\n  }\n\n  return `${major.toString()}.${minor.toString()}.${patch.toString()}${beta > 0 ? `-beta.${beta.toString()}` : ''}`;\n}\n\n/**\n * Fetches the latest version of Obsidian from the GitHub releases API.\n *\n * @returns A promise that resolves to the latest version of Obsidian.\n */\nasync function getLatestObsidianVersion(): Promise<string> {\n  const response = await fetch('https://api.github.com/repos/obsidianmd/obsidian-releases/releases/latest');\n  const obsidianReleasesJson = await response.json() as ObsidianReleasesJson;\n  return obsidianReleasesJson.name;\n}\n\n/**\n * Updates the changelog file with new version information and commit messages.\n *\n * This function reads the current changelog, appends new entries for the latest version,\n * and prompts the user to review the changes.\n *\n * @param newVersion - The new version number to be added to the changelog.\n * @returns A promise that resolves when the changelog update is complete.\n */\nexport async function updateChangelog(newVersion: string): Promise<void> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  let previousChangelogLines: string[];\n  if (!existsSync(changelogPath)) {\n    previousChangelogLines = [];\n  } else {\n    const content = await readFile(changelogPath, 'utf-8');\n    previousChangelogLines = content.split('\\n').slice(2);\n    if (previousChangelogLines.at(-1) === '') {\n      previousChangelogLines.pop();\n    }\n  }\n\n  const lastTag = previousChangelogLines[0]?.replace('## ', '');\n  const commitRange = lastTag ? `${lastTag}..HEAD` : 'HEAD';\n  const commitMessages = (await execFromRoot(`git log ${commitRange} --format=%s --first-parent`, { quiet: true })).split(/\\r?\\n/);\n\n  let newChangeLog = `# CHANGELOG\\n\\n## ${newVersion}\\n\\n`;\n\n  for (const message of commitMessages) {\n    newChangeLog += `- ${message}\\n`;\n  }\n\n  if (previousChangelogLines.length > 0) {\n    newChangeLog += '\\n';\n    for (const line of previousChangelogLines) {\n      newChangeLog += `${line}\\n`;\n    }\n  }\n\n  await writeFile(changelogPath, newChangeLog, 'utf-8');\n\n  await createInterface(process.stdin, process.stdout).question(`Please update the ${ObsidianPluginRepoPaths.ChangelogMd} file. Press Enter when you are done...`);\n}\n\n/**\n * Adds updated files to the Git staging area and commits them with the new version message.\n *\n * @param newVersion - The new version number used as the commit message.\n * @returns A promise that resolves when the files have been added and committed.\n */\nexport async function addUpdatedFilesToGit(newVersion: string): Promise<void> {\n  const files = [\n    ObsidianPluginRepoPaths.ManifestJson,\n    ObsidianPluginRepoPaths.PackageJson,\n    ObsidianPluginRepoPaths.PackageLockJson,\n    ObsidianPluginRepoPaths.VersionsJson,\n    ObsidianPluginRepoPaths.ChangelogMd\n  ].filter((file) => existsSync(resolvePathFromRoot(file)));\n  await execFromRoot(['git', 'add', ...files], { quiet: true });\n  await execFromRoot(`git commit -m ${newVersion} --allow-empty`, { quiet: true });\n}\n\n/**\n * Creates a Git tag for the new version.\n *\n * @param newVersion - The new version number to use for the tag.\n * @returns A promise that resolves when the tag has been created.\n */\nexport async function addGitTag(newVersion: string): Promise<void> {\n  await execFromRoot(`git tag -a ${newVersion} -m ${newVersion} --force`, { quiet: true });\n}\n\n/**\n * Pushes commits and tags to the remote Git repository.\n *\n * @returns A promise that resolves when the push operation is complete.\n */\nexport async function gitPush(): Promise<void> {\n  await execFromRoot('git push --follow-tags --force', { quiet: true });\n}\n\n/**\n * Copies the updated manifest file to the distribution build directory.\n *\n * @returns A promise that resolves when the copy operation is complete.\n */\nexport async function copyUpdatedManifest(): Promise<void> {\n  await cp(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson), resolvePathFromRoot(join(ObsidianPluginRepoPaths.DistBuild, ObsidianPluginRepoPaths.ManifestJson)), { force: true });\n}\n\n/**\n * Retrieves the release notes for a specific version from the changelog.\n *\n * @param newVersion - The new version number for which to get the release notes.\n * @returns A promise that resolves to the release notes for the specified version.\n */\nexport async function getReleaseNotes(newVersion: string): Promise<string> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  const content = await readFile(changelogPath, 'utf-8');\n  const newVersionEscaped = newVersion.replaceAll('.', '\\\\.');\n  const match = new RegExp(`\\n## ${newVersionEscaped}\\n\\n((.|\\n)+?)\\n\\n##`).exec(content);\n  let releaseNotes = match?.[1] ? match[1] + '\\n\\n' : '';\n\n  const tags = (await execFromRoot('git tag --sort=-creatordate', { quiet: true })).split(/\\r?\\n/);\n  const previousVersion = tags[1];\n  let changesUrl = '';\n\n  const repoUrl = await execFromRoot('gh repo view --json url -q .url', { quiet: true });\n\n  if (previousVersion) {\n    changesUrl = `${repoUrl}/compare/${previousVersion}...${newVersion}`;\n  } else {\n    changesUrl = `${repoUrl}/commits/${newVersion}`;\n  }\n\n  releaseNotes += `**Full Changelog**: ${changesUrl}`;\n  return releaseNotes;\n}\n\n/**\n * Publishes a GitHub release for the new version.\n *\n * Handles the creation of a release and uploading files for either an Obsidian plugin or another project.\n *\n * @param newVersion - The new version number for the release.\n * @param isObsidianPlugin - A boolean indicating if the project is an Obsidian plugin.\n * @returns A promise that resolves when the release has been published.\n */\nexport async function publishGitHubRelease(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  let filePaths: string[];\n\n  if (isObsidianPlugin) {\n    const buildDir = resolvePathFromRoot(ObsidianPluginRepoPaths.DistBuild);\n    const fileNames = await readdirPosix(buildDir);\n    filePaths = fileNames.map((fileName) => join(buildDir, fileName));\n  } else {\n    const zip = new AdmZip();\n    zip.addLocalFolder(resolvePathFromRoot(ObsidianDevUtilsRepoPaths.Dist), ObsidianDevUtilsRepoPaths.Dist, (filename) => !filename.endsWith('.zip'));\n\n    const files = [\n      ObsidianDevUtilsRepoPaths.ChangelogMd,\n      ObsidianDevUtilsRepoPaths.License,\n      ObsidianDevUtilsRepoPaths.ReadmeMd,\n      ObsidianDevUtilsRepoPaths.PackageJson\n    ];\n\n    for (const file of files) {\n      zip.addLocalFile(resolvePathFromRoot(file));\n    }\n\n    const npmPackage = await readNpmPackage();\n    const distZipPath = resolvePathFromRoot(join(ObsidianDevUtilsRepoPaths.Dist, `${npmPackage.name}-${newVersion}.zip`));\n    zip.writeZip(distZipPath);\n    filePaths = [distZipPath];\n  }\n\n  await execFromRoot(['gh', 'release', 'create', newVersion, ...filePaths, '--title', `v${newVersion}`, '--notes-file', '-'], {\n    quiet: true,\n    stdin: await getReleaseNotes(newVersion)\n  });\n}\n"],
  "mappings": "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",
  "names": ["VersionUpdateType", "AdmZip"]
}

344
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/version.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation version\n * This module provides functions for managing version updates in a project.\n * It includes tasks such as validating version update types, checking the state\n * of Git and GitHub CLI, updating version numbers in files, and performing\n * Git operations such as tagging and pushing.\n *\n * The main function, `updateVersion`, coordinates these tasks to ensure that\n * version updates are handled consistently and correctly. It also integrates\n * with Obsidian plugins, if applicable, by updating relevant files and releasing\n * new versions on GitHub.\n */\n\nimport AdmZip from 'adm-zip';\n\nimport { ObsidianPluginRepoPaths } from '../obsidian/Plugin/ObsidianPluginRepoPaths.ts';\nimport { join } from '../Path.ts';\nimport { readdirPosix } from './Fs.ts';\nimport { editJson } from './JSON.ts';\nimport {\n  cp,\n  createInterface,\n  existsSync,\n  readFile,\n  writeFile\n} from './NodeModules.ts';\nimport {\n  editNpmPackage,\n  editNpmPackageLock,\n  readNpmPackage\n} from './Npm.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\nimport {\n  execFromRoot,\n  resolvePathFromRoot\n} from './Root.ts';\n\n/**\n * Enum representing different types of version updates.\n */\nexport enum VersionUpdateType {\n  Beta = 'beta',\n  Invalid = 'invalid',\n  Major = 'major',\n  Manual = 'manual',\n  Minor = 'minor',\n  Patch = 'patch'\n}\n\n/**\n * Type representing the manifest file format for Obsidian plugins.\n */\nexport interface Manifest {\n  /**\n   * The minimum Obsidian version required for the plugin.\n   */\n  minAppVersion: string;\n\n  /**\n   * The version of the plugin.\n   */\n  version: string;\n}\n\n/**\n * Type representing the structure of Obsidian releases JSON.\n */\nexport interface ObsidianReleasesJson {\n  /**\n   * The name of the Obsidian release.\n   */\n  name: string;\n}\n\n/**\n * Creates a Git tag for the new version.\n *\n * @param newVersion - The new version number to use for the tag.\n * @returns A promise that resolves when the tag has been created.\n */\nexport async function addGitTag(newVersion: string): Promise<void> {\n  await execFromRoot(`git tag -a ${newVersion} -m ${newVersion} --force`, { quiet: true });\n}\n\n/**\n * Adds updated files to the Git staging area and commits them with the new version message.\n *\n * @param newVersion - The new version number used as the commit message.\n * @returns A promise that resolves when the files have been added and committed.\n */\nexport async function addUpdatedFilesToGit(newVersion: string): Promise<void> {\n  const files = [\n    ObsidianPluginRepoPaths.ManifestJson,\n    ObsidianPluginRepoPaths.PackageJson,\n    ObsidianPluginRepoPaths.PackageLockJson,\n    ObsidianPluginRepoPaths.VersionsJson,\n    ObsidianPluginRepoPaths.ChangelogMd\n  ].filter((file) => existsSync(resolvePathFromRoot(file)));\n  await execFromRoot(['git', 'add', ...files], { quiet: true });\n  await execFromRoot(`git commit -m ${newVersion} --allow-empty`, { quiet: true });\n}\n\n/**\n * Checks if the GitHub CLI is installed on the system.\n *\n * Throws an error if the GitHub CLI is not installed.\n *\n * @throws Error if the GitHub CLI is not installed.\n */\nexport async function checkGitHubCliInstalled(): Promise<void> {\n  try {\n    await execFromRoot('gh --version', { quiet: true });\n  } catch {\n    throw new Error('GitHub CLI is not installed. Please install it from https://cli.github.com/');\n  }\n}\n\n/**\n * Checks if Git is installed on the system.\n *\n * Throws an error if Git is not installed.\n *\n * @throws Error if Git is not installed.\n */\nexport async function checkGitInstalled(): Promise<void> {\n  try {\n    await execFromRoot('git --version', { quiet: true });\n  } catch {\n    throw new Error('Git is not installed. Please install it from https://git-scm.com/');\n  }\n}\n\n/**\n * Checks if the Git repository is clean, meaning there are no uncommitted changes.\n *\n * Throws an error if the Git repository is not clean.\n *\n * @throws Error if the Git repository is not clean.\n */\nexport async function checkGitRepoClean(): Promise<void> {\n  try {\n    const stdout = await execFromRoot('git status --porcelain --untracked-files=all', { quiet: true });\n    if (stdout) {\n      throw new Error();\n    }\n  } catch {\n    throw new Error('Git repository is not clean. Please commit or stash your changes before releasing a new version.');\n  }\n}\n\n/**\n * Copies the updated manifest file to the distribution build directory.\n *\n * @returns A promise that resolves when the copy operation is complete.\n */\nexport async function copyUpdatedManifest(): Promise<void> {\n  await cp(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson), resolvePathFromRoot(join(ObsidianPluginRepoPaths.DistBuild, ObsidianPluginRepoPaths.ManifestJson)), { force: true });\n}\n\n/**\n * Generates a new version string based on the current version and the specified update type.\n *\n * @param versionUpdateType - The type of version update (major, minor, patch, beta, or manual).\n * @returns A `Promise` that resolves to the new version string.\n * @throws Error if the current version format is invalid.\n */\nexport async function getNewVersion(versionUpdateType: string): Promise<string> {\n  const versionType = getVersionUpdateType(versionUpdateType);\n  if (versionType === VersionUpdateType.Manual) {\n    return versionUpdateType;\n  }\n\n  const npmPackage = await readNpmPackage();\n  const currentVersion = npmPackage.version;\n\n  const match = /^(\\d+)\\.(\\d+)\\.(\\d+)(-beta.(\\d+))?/.exec(currentVersion);\n  if (!match) {\n    throw new Error(`Invalid current version format: ${currentVersion}`);\n  }\n\n  let major = Number(match[1]);\n  let minor = Number(match[2]);\n  let patch = Number(match[3]);\n  let beta = match[5] ? Number(match[5]) : 0;\n\n  switch (versionType) {\n    case VersionUpdateType.Beta:\n      if (beta === 0) {\n        patch++;\n      }\n      beta++;\n      break;\n    case VersionUpdateType.Major:\n      major++;\n      minor = 0;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Minor:\n      minor++;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Patch:\n      patch++;\n      beta = 0;\n      break;\n  }\n\n  return `${major.toString()}.${minor.toString()}.${patch.toString()}${beta > 0 ? `-beta.${beta.toString()}` : ''}`;\n}\n\n/**\n * Retrieves the release notes for a specific version from the changelog.\n *\n * @param newVersion - The new version number for which to get the release notes.\n * @returns A promise that resolves to the release notes for the specified version.\n */\nexport async function getReleaseNotes(newVersion: string): Promise<string> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  const content = await readFile(changelogPath, 'utf-8');\n  const newVersionEscaped = newVersion.replaceAll('.', '\\\\.');\n  const match = new RegExp(`\\n## ${newVersionEscaped}\\n\\n((.|\\n)+?)\\n\\n##`).exec(content);\n  let releaseNotes = match?.[1] ? match[1] + '\\n\\n' : '';\n\n  const tags = (await execFromRoot('git tag --sort=-creatordate', { quiet: true })).split(/\\r?\\n/);\n  const previousVersion = tags[1];\n  let changesUrl = '';\n\n  const repoUrl = await execFromRoot('gh repo view --json url -q .url', { quiet: true });\n\n  if (previousVersion) {\n    changesUrl = `${repoUrl}/compare/${previousVersion}...${newVersion}`;\n  } else {\n    changesUrl = `${repoUrl}/commits/${newVersion}`;\n  }\n\n  releaseNotes += `**Full Changelog**: ${changesUrl}`;\n  return releaseNotes;\n}\n\n/**\n * Determines the type of version update based on the input string.\n *\n * @param versionUpdateType - The input string representing the version update type.\n * @returns The corresponding `VersionUpdateType`.\n */\nexport function getVersionUpdateType(versionUpdateType: string): VersionUpdateType {\n  const versionUpdateTypeEnum = versionUpdateType as VersionUpdateType;\n  switch (versionUpdateTypeEnum) {\n    case VersionUpdateType.Beta:\n    case VersionUpdateType.Major:\n    case VersionUpdateType.Minor:\n    case VersionUpdateType.Patch:\n      return versionUpdateTypeEnum;\n\n    default:\n      if (/^\\d+\\.\\d+\\.\\d+(-[\\w\\d.-]+)?$/.test(versionUpdateType)) {\n        return VersionUpdateType.Manual;\n      }\n\n      return VersionUpdateType.Invalid;\n  }\n}\n\n/**\n * Pushes commits and tags to the remote Git repository.\n *\n * @returns A promise that resolves when the push operation is complete.\n */\nexport async function gitPush(): Promise<void> {\n  await execFromRoot('git push --follow-tags --force', { quiet: true });\n}\n\n/**\n * Publishes a GitHub release for the new version.\n *\n * Handles the creation of a release and uploading files for either an Obsidian plugin or another project.\n *\n * @param newVersion - The new version number for the release.\n * @param isObsidianPlugin - A boolean indicating if the project is an Obsidian plugin.\n * @returns A promise that resolves when the release has been published.\n */\nexport async function publishGitHubRelease(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  let filePaths: string[];\n\n  if (isObsidianPlugin) {\n    const buildDir = resolvePathFromRoot(ObsidianPluginRepoPaths.DistBuild);\n    const fileNames = await readdirPosix(buildDir);\n    filePaths = fileNames.map((fileName) => join(buildDir, fileName));\n  } else {\n    const zip = new AdmZip();\n    zip.addLocalFolder(resolvePathFromRoot(ObsidianDevUtilsRepoPaths.Dist), ObsidianDevUtilsRepoPaths.Dist, (filename) => !filename.endsWith('.zip'));\n\n    const files = [\n      ObsidianDevUtilsRepoPaths.ChangelogMd,\n      ObsidianDevUtilsRepoPaths.License,\n      ObsidianDevUtilsRepoPaths.ReadmeMd,\n      ObsidianDevUtilsRepoPaths.PackageJson\n    ];\n\n    for (const file of files) {\n      zip.addLocalFile(resolvePathFromRoot(file));\n    }\n\n    const npmPackage = await readNpmPackage();\n    const distZipPath = resolvePathFromRoot(join(ObsidianDevUtilsRepoPaths.Dist, `${npmPackage.name}-${newVersion}.zip`));\n    zip.writeZip(distZipPath);\n    filePaths = [distZipPath];\n  }\n\n  await execFromRoot(['gh', 'release', 'create', newVersion, ...filePaths, '--title', `v${newVersion}`, '--notes-file', '-'], {\n    quiet: true,\n    stdin: await getReleaseNotes(newVersion)\n  });\n}\n\n/**\n * Updates the changelog file with new version information and commit messages.\n *\n * This function reads the current changelog, appends new entries for the latest version,\n * and prompts the user to review the changes.\n *\n * @param newVersion - The new version number to be added to the changelog.\n * @returns A promise that resolves when the changelog update is complete.\n */\nexport async function updateChangelog(newVersion: string): Promise<void> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  let previousChangelogLines: string[];\n  if (!existsSync(changelogPath)) {\n    previousChangelogLines = [];\n  } else {\n    const content = await readFile(changelogPath, 'utf-8');\n    previousChangelogLines = content.split('\\n').slice(2);\n    if (previousChangelogLines.at(-1) === '') {\n      previousChangelogLines.pop();\n    }\n  }\n\n  const lastTag = previousChangelogLines[0]?.replace('## ', '');\n  const commitRange = lastTag ? `${lastTag}..HEAD` : 'HEAD';\n  const commitMessages = (await execFromRoot(`git log ${commitRange} --format=%s --first-parent`, { quiet: true })).split(/\\r?\\n/);\n\n  let newChangeLog = `# CHANGELOG\\n\\n## ${newVersion}\\n\\n`;\n\n  for (const message of commitMessages) {\n    newChangeLog += `- ${message}\\n`;\n  }\n\n  if (previousChangelogLines.length > 0) {\n    newChangeLog += '\\n';\n    for (const line of previousChangelogLines) {\n      newChangeLog += `${line}\\n`;\n    }\n  }\n\n  await writeFile(changelogPath, newChangeLog, 'utf-8');\n\n  await createInterface(process.stdin, process.stdout).question(`Please update the ${ObsidianPluginRepoPaths.ChangelogMd} file. Press Enter when you are done...`);\n}\n\n/**\n * Updates the version of the project based on the specified update type.\n *\n * This function performs a series of tasks to handle version updates:\n * 1. Validates the version update type.\n * 2. Checks if Git and GitHub CLI are installed.\n * 3. Verifies that the Git repository is clean.\n * 4. Runs spellcheck and linting.\n * 5. Builds the project.\n * 6. Updates version in files and changelog.\n * 7. Adds updated files to Git, tags the commit, and pushes to the repository.\n * 8. If an Obsidian plugin, copies the updated manifest and publishes a GitHub release.\n *\n * @param versionUpdateType - The type of version update to perform (major, minor, patch, beta, or x.y.z[-beta:u]).\n * @returns A promise that resolves when the version update is complete.\n */\nexport async function updateVersion(versionUpdateType: string): Promise<void> {\n  if (!versionUpdateType) {\n    const npmOldVersion = process.env['npm_old_version'];\n    const npmNewVersion = process.env['npm_new_version'];\n\n    if (npmOldVersion && npmNewVersion) {\n      await updateVersionInFiles(npmOldVersion, false);\n      await updateVersion(npmNewVersion);\n      return;\n    }\n  }\n\n  const isObsidianPlugin = existsSync(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson));\n  validate(versionUpdateType);\n  await checkGitInstalled();\n  await checkGitRepoClean();\n  await checkGitHubCliInstalled();\n  await execFromRoot('npm run spellcheck');\n  await execFromRoot('npm run build');\n  await execFromRoot('npm run lint');\n\n  const newVersion = await getNewVersion(versionUpdateType);\n  await updateVersionInFiles(newVersion, isObsidianPlugin);\n  await updateChangelog(newVersion);\n  await addUpdatedFilesToGit(newVersion);\n  await addGitTag(newVersion);\n  await gitPush();\n  if (isObsidianPlugin) {\n    await copyUpdatedManifest();\n  }\n  await publishGitHubRelease(newVersion, isObsidianPlugin);\n}\n\n/**\n * Updates the version in various files, including `package.json`, `package-lock.json`,\n * and Obsidian plugin manifests if applicable.\n *\n * @param newVersion - The new version string to update in the files.\n * @param isObsidianPlugin - Whether the project is an Obsidian plugin.\n * @returns A `Promise` that resolves when the update is complete.\n */\nexport async function updateVersionInFiles(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  await editNpmPackage((npmPackage) => {\n    npmPackage.version = newVersion;\n  });\n\n  await editNpmPackageLock((npmPackageLock) => {\n    npmPackageLock.version = newVersion;\n    const defaultPackage = npmPackageLock.packages?.[''];\n    if (defaultPackage) {\n      defaultPackage.version = newVersion;\n    }\n  }, { skipIfMissing: true });\n\n  if (isObsidianPlugin) {\n    const latestObsidianVersion = await getLatestObsidianVersion();\n\n    await editJson<Manifest>(ObsidianPluginRepoPaths.ManifestJson, (manifest) => {\n      manifest.minAppVersion = latestObsidianVersion;\n      manifest.version = newVersion;\n    });\n\n    await editJson<Record<string, string>>(ObsidianPluginRepoPaths.VersionsJson, (versions) => {\n      versions[newVersion] = latestObsidianVersion;\n    });\n  }\n}\n\n/**\n * Validates the version update type to ensure it is either a recognized type\n * or a valid manual version string.\n *\n * @param versionUpdateType - The version update type to validate.\n * @throws Error if the version update type is invalid.\n */\nexport function validate(versionUpdateType: string): void {\n  if (getVersionUpdateType(versionUpdateType) === VersionUpdateType.Invalid) {\n    throw new Error('Invalid version update type. Please use \\'major\\', \\'minor\\', \\'patch\\', or \\'x.y.z[-suffix]\\' format.');\n  }\n}\n\n/**\n * Fetches the latest version of Obsidian from the GitHub releases API.\n *\n * @returns A promise that resolves to the latest version of Obsidian.\n */\nasync function getLatestObsidianVersion(): Promise<string> {\n  const response = await fetch('https://api.github.com/repos/obsidianmd/obsidian-releases/releases/latest');\n  const obsidianReleasesJson = await response.json() as ObsidianReleasesJson;\n  return obsidianReleasesJson.name;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkBA,qBAAmB;AAEnB,qCAAwC;AACxC,kBAAqB;AACrB,gBAA6B;AAC7B,kBAAyB;AACzB,yBAMO;AACP,iBAIO;AACP,uCAA0C;AAC1C,kBAGO;AAxCP,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAyCO,IAAK,oBAAL,kBAAKA,uBAAL;AACL,EAAAA,mBAAA,UAAO;AACP,EAAAA,mBAAA,aAAU;AACV,EAAAA,mBAAA,WAAQ;AACR,EAAAA,mBAAA,YAAS;AACT,EAAAA,mBAAA,WAAQ;AACR,EAAAA,mBAAA,WAAQ;AANE,SAAAA;AAAA,GAAA;AAwCZ,eAAsB,UAAU,YAAmC;AACjE,YAAM,0BAAa,cAAc,UAAU,OAAO,UAAU,YAAY,EAAE,OAAO,KAAK,CAAC;AACzF;AAQA,eAAsB,qBAAqB,YAAmC;AAC5E,QAAM,QAAQ;AAAA,IACZ,uDAAwB;AAAA,IACxB,uDAAwB;AAAA,IACxB,uDAAwB;AAAA,IACxB,uDAAwB;AAAA,IACxB,uDAAwB;AAAA,EAC1B,EAAE,OAAO,CAAC,aAAS,mCAAW,iCAAoB,IAAI,CAAC,CAAC;AACxD,YAAM,0BAAa,CAAC,OAAO,OAAO,GAAG,KAAK,GAAG,EAAE,OAAO,KAAK,CAAC;AAC5D,YAAM,0BAAa,iBAAiB,UAAU,kBAAkB,EAAE,OAAO,KAAK,CAAC;AACjF;AASA,eAAsB,0BAAyC;AAC7D,MAAI;AACF,cAAM,0BAAa,gBAAgB,EAAE,OAAO,KAAK,CAAC;AAAA,EACpD,QAAQ;AACN,UAAM,IAAI,MAAM,6EAA6E;AAAA,EAC/F;AACF;AASA,eAAsB,oBAAmC;AACvD,MAAI;AACF,cAAM,0BAAa,iBAAiB,EAAE,OAAO,KAAK,CAAC;AAAA,EACrD,QAAQ;AACN,UAAM,IAAI,MAAM,mEAAmE;AAAA,EACrF;AACF;AASA,eAAsB,oBAAmC;AACvD,MAAI;AACF,UAAM,SAAS,UAAM,0BAAa,gDAAgD,EAAE,OAAO,KAAK,CAAC;AACjG,QAAI,QAAQ;AACV,YAAM,IAAI,MAAM;AAAA,IAClB;AAAA,EACF,QAAQ;AACN,UAAM,IAAI,MAAM,kGAAkG;AAAA,EACpH;AACF;AAOA,eAAsB,sBAAqC;AACzD,YAAM,2BAAG,iCAAoB,uDAAwB,YAAY,OAAG,qCAAoB,kBAAK,uDAAwB,WAAW,uDAAwB,YAAY,CAAC,GAAG,EAAE,OAAO,KAAK,CAAC;AACzL;AASA,eAAsB,cAAc,mBAA4C;AAC9E,QAAM,cAAc,qBAAqB,iBAAiB;AAC1D,MAAI,gBAAgB,uBAA0B;AAC5C,WAAO;AAAA,EACT;AAEA,QAAM,aAAa,UAAM,2BAAe;AACxC,QAAM,iBAAiB,WAAW;AAElC,QAAM,QAAQ,qCAAqC,KAAK,cAAc;AACtE,MAAI,CAAC,OAAO;AACV,UAAM,IAAI,MAAM,mCAAmC,cAAc,EAAE;AAAA,EACrE;AAEA,MAAI,QAAQ,OAAO,MAAM,CAAC,CAAC;AAC3B,MAAI,QAAQ,OAAO,MAAM,CAAC,CAAC;AAC3B,MAAI,QAAQ,OAAO,MAAM,CAAC,CAAC;AAC3B,MAAI,OAAO,MAAM,CAAC,IAAI,OAAO,MAAM,CAAC,CAAC,IAAI;AAEzC,UAAQ,aAAa;AAAA,IACnB,KAAK;AACH,UAAI,SAAS,GAAG;AACd;AAAA,MACF;AACA;AACA;AAAA,IACF,KAAK;AACH;AACA,cAAQ;AACR,cAAQ;AACR,aAAO;AACP;AAAA,IACF,KAAK;AACH;AACA,cAAQ;AACR,aAAO;AACP;AAAA,IACF,KAAK;AACH;AACA,aAAO;AACP;AAAA,EACJ;AAEA,SAAO,GAAG,MAAM,SAAS,CAAC,IAAI,MAAM,SAAS,CAAC,IAAI,MAAM,SAAS,CAAC,GAAG,OAAO,IAAI,SAAS,KAAK,SAAS,CAAC,KAAK,EAAE;AACjH;AAQA,eAAsB,gBAAgB,YAAqC;AACzE,QAAM,oBAAgB,iCAAoB,uDAAwB,WAAW;AAC7E,QAAM,UAAU,UAAM,6BAAS,eAAe,OAAO;AACrD,QAAM,oBAAoB,WAAW,WAAW,KAAK,KAAK;AAC1D,QAAM,QAAQ,IAAI,OAAO;AAAA,KAAQ,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA,GAAsB,EAAE,KAAK,OAAO;AACtF,MAAI,eAAe,QAAQ,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS;AAEpD,QAAM,QAAQ,UAAM,0BAAa,+BAA+B,EAAE,OAAO,KAAK,CAAC,GAAG,MAAM,OAAO;AAC/F,QAAM,kBAAkB,KAAK,CAAC;AAC9B,MAAI,aAAa;AAEjB,QAAM,UAAU,UAAM,0BAAa,mCAAmC,EAAE,OAAO,KAAK,CAAC;AAErF,MAAI,iBAAiB;AACnB,iBAAa,GAAG,OAAO,YAAY,eAAe,MAAM,UAAU;AAAA,EACpE,OAAO;AACL,iBAAa,GAAG,OAAO,YAAY,UAAU;AAAA,EAC/C;AAEA,kBAAgB,uBAAuB,UAAU;AACjD,SAAO;AACT;AAQO,SAAS,qBAAqB,mBAA8C;AACjF,QAAM,wBAAwB;AAC9B,UAAQ,uBAAuB;AAAA,IAC7B,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACH,aAAO;AAAA,IAET;AACE,UAAI,+BAA+B,KAAK,iBAAiB,GAAG;AAC1D,eAAO;AAAA,MACT;AAEA,aAAO;AAAA,EACX;AACF;AAOA,eAAsB,UAAyB;AAC7C,YAAM,0BAAa,kCAAkC,EAAE,OAAO,KAAK,CAAC;AACtE;AAWA,eAAsB,qBAAqB,YAAoB,kBAA0C;AACvG,MAAI;AAEJ,MAAI,kBAAkB;AACpB,UAAM,eAAW,iCAAoB,uDAAwB,SAAS;AACtE,UAAM,YAAY,UAAM,wBAAa,QAAQ;AAC7C,gBAAY,UAAU,IAAI,CAAC,iBAAa,kBAAK,UAAU,QAAQ,CAAC;AAAA,EAClE,OAAO;AACL,UAAM,MAAM,IAAI,eAAAC,QAAO;AACvB,QAAI,mBAAe,iCAAoB,2DAA0B,IAAI,GAAG,2DAA0B,MAAM,CAAC,aAAa,CAAC,SAAS,SAAS,MAAM,CAAC;AAEhJ,UAAM,QAAQ;AAAA,MACZ,2DAA0B;AAAA,MAC1B,2DAA0B;AAAA,MAC1B,2DAA0B;AAAA,MAC1B,2DAA0B;AAAA,IAC5B;AAEA,eAAW,QAAQ,OAAO;AACxB,UAAI,iBAAa,iCAAoB,IAAI,CAAC;AAAA,IAC5C;AAEA,UAAM,aAAa,UAAM,2BAAe;AACxC,UAAM,kBAAc,qCAAoB,kBAAK,2DAA0B,MAAM,GAAG,WAAW,IAAI,IAAI,UAAU,MAAM,CAAC;AACpH,QAAI,SAAS,WAAW;AACxB,gBAAY,CAAC,WAAW;AAAA,EAC1B;AAEA,YAAM,0BAAa,CAAC,MAAM,WAAW,UAAU,YAAY,GAAG,WAAW,WAAW,IAAI,UAAU,IAAI,gBAAgB,GAAG,GAAG;AAAA,IAC1H,OAAO;AAAA,IACP,OAAO,MAAM,gBAAgB,UAAU;AAAA,EACzC,CAAC;AACH;AAWA,eAAsB,gBAAgB,YAAmC;AACvE,QAAM,oBAAgB,iCAAoB,uDAAwB,WAAW;AAC7E,MAAI;AACJ,MAAI,KAAC,+BAAW,aAAa,GAAG;AAC9B,6BAAyB,CAAC;AAAA,EAC5B,OAAO;AACL,UAAM,UAAU,UAAM,6BAAS,eAAe,OAAO;AACrD,6BAAyB,QAAQ,MAAM,IAAI,EAAE,MAAM,CAAC;AACpD,QAAI,uBAAuB,GAAG,EAAE,MAAM,IAAI;AACxC,6BAAuB,IAAI;AAAA,IAC7B;AAAA,EACF;AAEA,QAAM,UAAU,uBAAuB,CAAC,GAAG,QAAQ,OAAO,EAAE;AAC5D,QAAM,cAAc,UAAU,GAAG,OAAO,WAAW;AACnD,QAAM,kBAAkB,UAAM,0BAAa,WAAW,WAAW,+BAA+B,EAAE,OAAO,KAAK,CAAC,GAAG,MAAM,OAAO;AAE/H,MAAI,eAAe;AAAA;AAAA,KAAqB,UAAU;AAAA;AAAA;AAElD,aAAW,WAAW,gBAAgB;AACpC,oBAAgB,KAAK,OAAO;AAAA;AAAA,EAC9B;AAEA,MAAI,uBAAuB,SAAS,GAAG;AACrC,oBAAgB;AAChB,eAAW,QAAQ,wBAAwB;AACzC,sBAAgB,GAAG,IAAI;AAAA;AAAA,IACzB;AAAA,EACF;AAEA,YAAM,8BAAU,eAAe,cAAc,OAAO;AAEpD,YAAM,oCAAgB,UAAQ,OAAO,UAAQ,MAAM,EAAE,SAAS,qBAAqB,uDAAwB,WAAW,yCAAyC;AACjK;AAkBA,eAAsB,cAAc,mBAA0C;AAC5E,MAAI,CAAC,mBAAmB;AACtB,UAAM,gBAAgB,UAAQ,IAAI,iBAAiB;AACnD,UAAM,gBAAgB,UAAQ,IAAI,iBAAiB;AAEnD,QAAI,iBAAiB,eAAe;AAClC,YAAM,qBAAqB,eAAe,KAAK;AAC/C,YAAM,cAAc,aAAa;AACjC;AAAA,IACF;AAAA,EACF;AAEA,QAAM,uBAAmB,mCAAW,iCAAoB,uDAAwB,YAAY,CAAC;AAC7F,WAAS,iBAAiB;AAC1B,QAAM,kBAAkB;AACxB,QAAM,kBAAkB;AACxB,QAAM,wBAAwB;AAC9B,YAAM,0BAAa,oBAAoB;AACvC,YAAM,0BAAa,eAAe;AAClC,YAAM,0BAAa,cAAc;AAEjC,QAAM,aAAa,MAAM,cAAc,iBAAiB;AACxD,QAAM,qBAAqB,YAAY,gBAAgB;AACvD,QAAM,gBAAgB,UAAU;AAChC,QAAM,qBAAqB,UAAU;AACrC,QAAM,UAAU,UAAU;AAC1B,QAAM,QAAQ;AACd,MAAI,kBAAkB;AACpB,UAAM,oBAAoB;AAAA,EAC5B;AACA,QAAM,qBAAqB,YAAY,gBAAgB;AACzD;AAUA,eAAsB,qBAAqB,YAAoB,kBAA0C;AACvG,YAAM,2BAAe,CAAC,eAAe;AACnC,eAAW,UAAU;AAAA,EACvB,CAAC;AAED,YAAM,+BAAmB,CAAC,mBAAmB;AAC3C,mBAAe,UAAU;AACzB,UAAM,iBAAiB,eAAe,WAAW,EAAE;AACnD,QAAI,gBAAgB;AAClB,qBAAe,UAAU;AAAA,IAC3B;AAAA,EACF,GAAG,EAAE,eAAe,KAAK,CAAC;AAE1B,MAAI,kBAAkB;AACpB,UAAM,wBAAwB,MAAM,yBAAyB;AAE7D,cAAM,sBAAmB,uDAAwB,cAAc,CAAC,aAAa;AAC3E,eAAS,gBAAgB;AACzB,eAAS,UAAU;AAAA,IACrB,CAAC;AAED,cAAM,sBAAiC,uDAAwB,cAAc,CAAC,aAAa;AACzF,eAAS,UAAU,IAAI;AAAA,IACzB,CAAC;AAAA,EACH;AACF;AASO,SAAS,SAAS,mBAAiC;AACxD,MAAI,qBAAqB,iBAAiB,MAAM,yBAA2B;AACzE,UAAM,IAAI,MAAM,gGAAwG;AAAA,EAC1H;AACF;AAOA,eAAe,2BAA4C;AACzD,QAAM,WAAW,MAAM,MAAM,2EAA2E;AACxG,QAAM,uBAAuB,MAAM,SAAS,KAAK;AACjD,SAAO,qBAAqB;AAC9B;",
  "names": ["VersionUpdateType", "AdmZip"]
}

@@ -44,30 +44,27 @@ export interface ObsidianReleasesJson {
44
44
  name: string;
45
45
  }
46
46
  /**
47
- * Updates the version of the project based on the specified update type.
47
+ * Creates a Git tag for the new version.
48
48
  *
49
- * This function performs a series of tasks to handle version updates:
50
- * 1. Validates the version update type.
51
- * 2. Checks if Git and GitHub CLI are installed.
52
- * 3. Verifies that the Git repository is clean.
53
- * 4. Runs spellcheck and linting.
54
- * 5. Builds the project.
55
- * 6. Updates version in files and changelog.
56
- * 7. Adds updated files to Git, tags the commit, and pushes to the repository.
57
- * 8. If an Obsidian plugin, copies the updated manifest and publishes a GitHub release.
49
+ * @param newVersion - The new version number to use for the tag.
50
+ * @returns A promise that resolves when the tag has been created.
51
+ */
52
+ export declare function addGitTag(newVersion: string): Promise<void>;
53
+ /**
54
+ * Adds updated files to the Git staging area and commits them with the new version message.
58
55
  *
59
- * @param versionUpdateType - The type of version update to perform (major, minor, patch, beta, or x.y.z[-beta:u]).
60
- * @returns A promise that resolves when the version update is complete.
56
+ * @param newVersion - The new version number used as the commit message.
57
+ * @returns A promise that resolves when the files have been added and committed.
61
58
  */
62
- export declare function updateVersion(versionUpdateType: string): Promise<void>;
59
+ export declare function addUpdatedFilesToGit(newVersion: string): Promise<void>;
63
60
  /**
64
- * Validates the version update type to ensure it is either a recognized type
65
- * or a valid manual version string.
61
+ * Checks if the GitHub CLI is installed on the system.
66
62
  *
67
- * @param versionUpdateType - The version update type to validate.
68
- * @throws Error if the version update type is invalid.
63
+ * Throws an error if the GitHub CLI is not installed.
64
+ *
65
+ * @throws Error if the GitHub CLI is not installed.
69
66
  */
70
- export declare function validate(versionUpdateType: string): void;
67
+ export declare function checkGitHubCliInstalled(): Promise<void>;
71
68
  /**
72
69
  * Checks if Git is installed on the system.
73
70
  *
@@ -76,14 +73,6 @@ export declare function validate(versionUpdateType: string): void;
76
73
  * @throws Error if Git is not installed.
77
74
  */
78
75
  export declare function checkGitInstalled(): Promise<void>;
79
- /**
80
- * Checks if the GitHub CLI is installed on the system.
81
- *
82
- * Throws an error if the GitHub CLI is not installed.
83
- *
84
- * @throws Error if the GitHub CLI is not installed.
85
- */
86
- export declare function checkGitHubCliInstalled(): Promise<void>;
87
76
  /**
88
77
  * Checks if the Git repository is clean, meaning there are no uncommitted changes.
89
78
  *
@@ -93,21 +82,11 @@ export declare function checkGitHubCliInstalled(): Promise<void>;
93
82
  */
94
83
  export declare function checkGitRepoClean(): Promise<void>;
95
84
  /**
96
- * Determines the type of version update based on the input string.
97
- *
98
- * @param versionUpdateType - The input string representing the version update type.
99
- * @returns The corresponding `VersionUpdateType`.
100
- */
101
- export declare function getVersionUpdateType(versionUpdateType: string): VersionUpdateType;
102
- /**
103
- * Updates the version in various files, including `package.json`, `package-lock.json`,
104
- * and Obsidian plugin manifests if applicable.
85
+ * Copies the updated manifest file to the distribution build directory.
105
86
  *
106
- * @param newVersion - The new version string to update in the files.
107
- * @param isObsidianPlugin - Whether the project is an Obsidian plugin.
108
- * @returns A `Promise` that resolves when the update is complete.
87
+ * @returns A promise that resolves when the copy operation is complete.
109
88
  */
110
- export declare function updateVersionInFiles(newVersion: string, isObsidianPlugin: boolean): Promise<void>;
89
+ export declare function copyUpdatedManifest(): Promise<void>;
111
90
  /**
112
91
  * Generates a new version string based on the current version and the specified update type.
113
92
  *
@@ -117,48 +96,25 @@ export declare function updateVersionInFiles(newVersion: string, isObsidianPlugi
117
96
  */
118
97
  export declare function getNewVersion(versionUpdateType: string): Promise<string>;
119
98
  /**
120
- * Updates the changelog file with new version information and commit messages.
121
- *
122
- * This function reads the current changelog, appends new entries for the latest version,
123
- * and prompts the user to review the changes.
124
- *
125
- * @param newVersion - The new version number to be added to the changelog.
126
- * @returns A promise that resolves when the changelog update is complete.
127
- */
128
- export declare function updateChangelog(newVersion: string): Promise<void>;
129
- /**
130
- * Adds updated files to the Git staging area and commits them with the new version message.
99
+ * Retrieves the release notes for a specific version from the changelog.
131
100
  *
132
- * @param newVersion - The new version number used as the commit message.
133
- * @returns A promise that resolves when the files have been added and committed.
101
+ * @param newVersion - The new version number for which to get the release notes.
102
+ * @returns A promise that resolves to the release notes for the specified version.
134
103
  */
135
- export declare function addUpdatedFilesToGit(newVersion: string): Promise<void>;
104
+ export declare function getReleaseNotes(newVersion: string): Promise<string>;
136
105
  /**
137
- * Creates a Git tag for the new version.
106
+ * Determines the type of version update based on the input string.
138
107
  *
139
- * @param newVersion - The new version number to use for the tag.
140
- * @returns A promise that resolves when the tag has been created.
108
+ * @param versionUpdateType - The input string representing the version update type.
109
+ * @returns The corresponding `VersionUpdateType`.
141
110
  */
142
- export declare function addGitTag(newVersion: string): Promise<void>;
111
+ export declare function getVersionUpdateType(versionUpdateType: string): VersionUpdateType;
143
112
  /**
144
113
  * Pushes commits and tags to the remote Git repository.
145
114
  *
146
115
  * @returns A promise that resolves when the push operation is complete.
147
116
  */
148
117
  export declare function gitPush(): Promise<void>;
149
- /**
150
- * Copies the updated manifest file to the distribution build directory.
151
- *
152
- * @returns A promise that resolves when the copy operation is complete.
153
- */
154
- export declare function copyUpdatedManifest(): Promise<void>;
155
- /**
156
- * Retrieves the release notes for a specific version from the changelog.
157
- *
158
- * @param newVersion - The new version number for which to get the release notes.
159
- * @returns A promise that resolves to the release notes for the specified version.
160
- */
161
- export declare function getReleaseNotes(newVersion: string): Promise<string>;
162
118
  /**
163
119
  * Publishes a GitHub release for the new version.
164
120
  *
@@ -169,3 +125,47 @@ export declare function getReleaseNotes(newVersion: string): Promise<string>;
169
125
  * @returns A promise that resolves when the release has been published.
170
126
  */
171
127
  export declare function publishGitHubRelease(newVersion: string, isObsidianPlugin: boolean): Promise<void>;
128
+ /**
129
+ * Updates the changelog file with new version information and commit messages.
130
+ *
131
+ * This function reads the current changelog, appends new entries for the latest version,
132
+ * and prompts the user to review the changes.
133
+ *
134
+ * @param newVersion - The new version number to be added to the changelog.
135
+ * @returns A promise that resolves when the changelog update is complete.
136
+ */
137
+ export declare function updateChangelog(newVersion: string): Promise<void>;
138
+ /**
139
+ * Updates the version of the project based on the specified update type.
140
+ *
141
+ * This function performs a series of tasks to handle version updates:
142
+ * 1. Validates the version update type.
143
+ * 2. Checks if Git and GitHub CLI are installed.
144
+ * 3. Verifies that the Git repository is clean.
145
+ * 4. Runs spellcheck and linting.
146
+ * 5. Builds the project.
147
+ * 6. Updates version in files and changelog.
148
+ * 7. Adds updated files to Git, tags the commit, and pushes to the repository.
149
+ * 8. If an Obsidian plugin, copies the updated manifest and publishes a GitHub release.
150
+ *
151
+ * @param versionUpdateType - The type of version update to perform (major, minor, patch, beta, or x.y.z[-beta:u]).
152
+ * @returns A promise that resolves when the version update is complete.
153
+ */
154
+ export declare function updateVersion(versionUpdateType: string): Promise<void>;
155
+ /**
156
+ * Updates the version in various files, including `package.json`, `package-lock.json`,
157
+ * and Obsidian plugin manifests if applicable.
158
+ *
159
+ * @param newVersion - The new version string to update in the files.
160
+ * @param isObsidianPlugin - Whether the project is an Obsidian plugin.
161
+ * @returns A `Promise` that resolves when the update is complete.
162
+ */
163
+ export declare function updateVersionInFiles(newVersion: string, isObsidianPlugin: boolean): Promise<void>;
164
+ /**
165
+ * Validates the version update type to ensure it is either a recognized type
166
+ * or a valid manual version string.
167
+ *
168
+ * @param versionUpdateType - The version update type to validate.
169
+ * @throws Error if the version update type is invalid.
170
+ */
171
+ export declare function validate(versionUpdateType: string): void;