obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
108 lines (104 loc) • 17.3 kB
JavaScript
/*
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
if you want to view the source, please visit the github repository of this plugin
*/
(function initEsm() {
if (globalThis.process) {
return;
}
const browserProcess = {
browser: true,
cwd() {
return '/';
},
env: {},
platform: 'android'
};
globalThis.process = browserProcess;
})();
import { Command } from "commander";
import { createJiti } from "jiti";
import { invokeAsyncSafely } from "../Async.mjs";
import {
getFolderName,
join,
relative
} from "../Path.mjs";
import {
buildClean,
buildCompile,
buildCompileSvelte,
buildCompileTypeScript,
buildStatic
} from "./build.mjs";
import {
CliTaskResult,
wrapCliTask
} from "./CliUtils.mjs";
import {
BuildMode,
buildObsidianPlugin
} from "./esbuild/ObsidianPluginBuilder.mjs";
import { lint } from "./ESLint/ESLint.mjs";
import { format } from "./format.mjs";
import { lintMarkdown } from "./markdownlint/markdownlint.mjs";
import {
existsSync,
process
} from "./NodeModules.mjs";
import { readPackageJson } from "./Npm.mjs";
import { publish } from "./NpmPublish.mjs";
import { ObsidianDevUtilsRepoPaths } from "./ObsidianDevUtilsRepoPaths.mjs";
import { resolvePathFromRootSafe } from "./Root.mjs";
import { spellcheck } from "./spellcheck.mjs";
import { updateVersion } from "./version.mjs";
const jiti = createJiti(import.meta.url);
const NODE_SCRIPT_ARGV_SKIP_COUNT = 2;
function cli(argv = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)) {
invokeAsyncSafely(
() => wrapCliTask(async () => {
const packageJson = await readPackageJson(getFolderName(import.meta.url));
const program = new Command();
program.name(packageJson.name ?? "(unknown)").description("CLI for Obsidian plugin development utilities").version(packageJson.version ?? "(unknown)");
addCommand(program, "build" /* Build */, "Build the plugin", () => buildObsidianPlugin({ mode: BuildMode.Production }));
addCommand(program, "build:clean" /* BuildClean */, "Clean the dist folder", () => buildClean());
addCommand(program, "build:compile" /* BuildCompile */, "Check if code compiles", () => buildCompile());
addCommand(program, "build:compile:svelte" /* BuildCompileSvelte */, "Check if Svelte code compiles", () => buildCompileSvelte());
addCommand(program, "build:compile:typescript" /* BuildCompileTypeScript */, "Check if TypeScript code compiles", () => buildCompileTypeScript());
addCommand(program, "build:static" /* BuildStatic */, "Copy static content to dist", () => buildStatic());
addCommand(program, "dev" /* Dev */, "Build the plugin in development mode", () => buildObsidianPlugin({ mode: BuildMode.Development }));
addCommand(program, "format" /* Format */, "Format the source code", () => format());
addCommand(program, "format:check" /* FormatCheck */, "Check if the source code is formatted", () => format(false));
addCommand(program, "lint" /* Lint */, "Lint the source code", () => lint());
addCommand(program, "lint:fix" /* LintFix */, "Lint the source code and apply automatic fixes", () => lint(true));
addCommand(program, "lint:md" /* LintMarkdown */, "Lint the markdown documentation", () => lintMarkdown());
addCommand(program, "lint:md:fix" /* LintMarkdownFix */, "Lint the markdown documentation and apply automatic fixes", () => lintMarkdown(true));
addCommand(program, "publish" /* Publish */, "Publish to NPM", (isBeta) => publish(isBeta)).argument("[isBeta]", "Publish to NPM beta");
addCommand(program, "spellcheck" /* Spellcheck */, "Spellcheck the source code", () => spellcheck());
addCommand(program, "version" /* Version */, "Release a new version", (versionUpdateType) => updateVersion(versionUpdateType)).argument("[versionUpdateType]", "Version update type: major, minor, patch, beta, or x.y.z[-suffix]");
await program.parseAsync(argv, { from: "user" });
return CliTaskResult.DoNotExit();
})
);
}
function addCommand(program, name, description, taskFn) {
return program.command(name).description(description).action(
(...args) => wrapCliTask(async () => {
const scriptPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(":", "-")}.ts`));
if (existsSync(scriptPath)) {
const folder = getFolderName(import.meta.url);
const relativeScriptPath = relative(folder, scriptPath);
const module = await jiti.import(relativeScriptPath);
if (typeof module.invoke !== "function") {
throw new Error(`${relativeScriptPath} does not export an invoke function`);
}
return module.invoke(...args);
}
return await taskFn(...args);
})
);
}
export {
cli
};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/cli.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\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 type { Promisable } from 'type-fest';\n\nimport { Command } from 'commander';\nimport { createJiti } from 'jiti';\n\nimport type { MaybeReturn } from '../Type.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport {\n  getFolderName,\n  join,\n  relative\n} from '../Path.ts';\nimport {\n  buildClean,\n  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport { lintMarkdown } from './markdownlint/markdownlint.ts';\nimport {\n  existsSync,\n  process\n} from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\nimport { resolvePathFromRootSafe } from './Root.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n\nconst jiti = createJiti(import.meta.url);\n\n/**\n * A number of leading arguments to skip when parsing command-line arguments.\n * First two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  LintMarkdown = 'lint:md',\n  LintMarkdownFix = 'lint:md:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\ninterface OverrideModule<Args extends unknown[]> {\n  invoke(...args: Args): Promise<MaybeReturn<CliTaskResult>>;\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getFolderName(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.LintMarkdown, 'Lint the markdown documentation', () => lintMarkdown());\n      addCommand(program, CommandNames.LintMarkdownFix, 'Lint the markdown documentation and apply automatic fixes', () => lintMarkdown(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a {@link CliTaskResult} or `void`.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters -- We need to use the dummy parameter to get type inference.\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  taskFn: (...args: Args) => Promisable<MaybeReturn<CliTaskResult>>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) =>\n      wrapCliTask(async () => {\n        const scriptPath = resolvePathFromRootSafe(join(ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(':', '-')}.ts`));\n        if (existsSync(scriptPath)) {\n          const folder = getFolderName(import.meta.url);\n          const relativeScriptPath = relative(folder, scriptPath);\n          const module = await jiti.import<Partial<OverrideModule<Args>>>(relativeScriptPath);\n          if (typeof module.invoke !== 'function') {\n            throw new Error(`${relativeScriptPath} does not export an invoke function`);\n          }\n          return module.invoke(...args);\n        }\n\n        return await taskFn(...args);\n      })\n    );\n}\n"],
  "mappings": "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",
  "names": []
}
