obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
106 lines (103 loc) • 19.5 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 initCjs(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;const originalRequire=require;if(originalRequire&&!originalRequire.__isPatched){require=Object.assign(id=>requirePatched(id),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>{const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};return browserProcess},"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&"default"in module?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id){const module=originalRequire?.(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})();
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var cli_exports = {};
__export(cli_exports, {
cli: () => cli
});
module.exports = __toCommonJS(cli_exports);
var import_commander = require('commander');
var import_api = require('tsx/esm/api');
var import_Async = require('../Async.cjs');
var import_Path = require('../Path.cjs');
var import_build = require('./build.cjs');
var import_CliUtils = require('./CliUtils.cjs');
var import_ObsidianPluginBuilder = require('./esbuild/ObsidianPluginBuilder.cjs');
var import_ESLint = require('./ESLint/ESLint.cjs');
var import_format = require('./format.cjs');
var import_NodeModules = require('./NodeModules.cjs');
var import_Npm = require('./Npm.cjs');
var import_NpmPublish = require('./NpmPublish.cjs');
var import_ObsidianDevUtilsRepoPaths = require('./ObsidianDevUtilsRepoPaths.cjs');
var import_Root = require('./Root.cjs');
var import_spellcheck = require('./spellcheck.cjs');
var import_version = require('./version.cjs');
var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
if (typeof __filename === "string") {
const localRequire = require;
const url = localRequire("node:url");
return url.pathToFileURL(__filename).href;
}
if (typeof window !== "undefined") {
return window.location.href;
}
return "";
})();
const NODE_SCRIPT_ARGV_SKIP_COUNT = 2;
function cli(argv = import_NodeModules.process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)) {
(0, import_Async.invokeAsyncSafely)(
() => (0, import_CliUtils.wrapCliTask)(async () => {
const packageJson = await (0, import_Npm.readPackageJson)((0, import_Path.getFolderName)(__import_meta_url));
const program = new import_commander.Command();
program.name(packageJson.name ?? "(unknown)").description("CLI for Obsidian plugin development utilities").version(packageJson.version ?? "(unknown)");
addCommand(program, "build" /* Build */, "Build the plugin", () => (0, import_ObsidianPluginBuilder.buildObsidianPlugin)({ mode: import_ObsidianPluginBuilder.BuildMode.Production }));
addCommand(program, "build:clean" /* BuildClean */, "Clean the dist folder", () => (0, import_build.buildClean)());
addCommand(program, "build:compile" /* BuildCompile */, "Check if code compiles", () => (0, import_build.buildCompile)());
addCommand(program, "build:compile:svelte" /* BuildCompileSvelte */, "Check if Svelte code compiles", () => (0, import_build.buildCompileSvelte)());
addCommand(program, "build:compile:typescript" /* BuildCompileTypeScript */, "Check if TypeScript code compiles", () => (0, import_build.buildCompileTypeScript)());
addCommand(program, "build:static" /* BuildStatic */, "Copy static content to dist", () => (0, import_build.buildStatic)());
addCommand(program, "dev" /* Dev */, "Build the plugin in development mode", () => (0, import_ObsidianPluginBuilder.buildObsidianPlugin)({ mode: import_ObsidianPluginBuilder.BuildMode.Development }));
addCommand(program, "format" /* Format */, "Format the source code", () => (0, import_format.format)());
addCommand(program, "format:check" /* FormatCheck */, "Check if the source code is formatted", () => (0, import_format.format)(false));
addCommand(program, "lint" /* Lint */, "Lint the source code", () => (0, import_ESLint.lint)());
addCommand(program, "lint:fix" /* LintFix */, "Lint the source code and apply automatic fixes", () => (0, import_ESLint.lint)(true));
addCommand(program, "publish" /* Publish */, "Publish to NPM", (isBeta) => (0, import_NpmPublish.publish)(isBeta)).argument("[isBeta]", "Publish to NPM beta");
addCommand(program, "spellcheck" /* Spellcheck */, "Spellcheck the source code", () => (0, import_spellcheck.spellcheck)());
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]");
await program.parseAsync(argv, { from: "user" });
return import_CliUtils.CliTaskResult.DoNotExit();
})
);
}
function addCommand(program, name, description, taskFn) {
return program.command(name).description(description).action(
(...args) => (0, import_CliUtils.wrapCliTask)(async () => {
const scriptPath = (0, import_Root.resolvePathFromRootSafe)((0, import_Path.join)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.Scripts, `${name.replace(":", "-")}.ts`));
if ((0, import_NodeModules.existsSync)(scriptPath)) {
const folder = (0, import_Path.getFolderName)(__import_meta_url);
const relativeScriptPath = (0, import_Path.relative)(folder, scriptPath);
const module2 = await (0, import_api.tsImport)(relativeScriptPath, { parentURL: __import_meta_url });
if (typeof module2.invoke !== "function") {
throw new Error(`${relativeScriptPath} does not export an invoke function`);
}
return module2.invoke(...args);
}
return await taskFn(...args);
})
);
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
cli
});
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const localRequire=require;const url=localRequire(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\n/**\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 { tsImport } from 'tsx/esm/api';\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 {\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\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\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.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\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 tsImport(relativeScriptPath, { parentURL: import.meta.url }) as Partial<OverrideModule<Args>>;\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": ["module"]
}
