obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
208 lines (194 loc) • 22.7 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) {
// eslint-disable-next-line no-global-assign, no-implicit-globals -- We need to patch the `require()` function.
require = Object.assign(
(id) => requirePatched(id),
originalRequire,
{
__isPatched: true
}
);
}
const newFuncs = {
__extractDefault() {
return extractDefault;
},
process() {
const browserProcess = {
browser: true,
cwd() {
return '/';
},
env: {},
platform: 'android'
};
return browserProcess;
}
};
for (const key of Object.keys(newFuncs)) {
globalThisRecord[key] ??= newFuncs[key]?.();
}
function name(obj) {
return obj;
}
function extractDefault(module) {
return module && module.__esModule && 'default' in module ? module.default : module;
}
const OBSIDIAN_BUILT_IN_MODULE_NAMES = [
'obsidian',
'@codemirror/autocomplete',
'@codemirror/collab',
'@codemirror/commands',
'@codemirror/language',
'@codemirror/lint',
'@codemirror/search',
'@codemirror/state',
'@codemirror/text',
'@codemirror/view',
'@lezer/common',
'@lezer/lr',
'@lezer/highlight'];
const DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES = [
'@codemirror/closebrackets',
'@codemirror/comment',
'@codemirror/fold',
'@codemirror/gutter',
'@codemirror/highlight',
'@codemirror/history',
'@codemirror/matchbrackets',
'@codemirror/panel',
'@codemirror/rangeset',
'@codemirror/rectangular-selection',
'@codemirror/stream-parser',
'@codemirror/tooltip'];
function requirePatched(id) {
if (OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id) || DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id)) {
return originalRequire?.(id);
}
// eslint-disable-next-line @typescript-eslint/no-deprecated, @typescript-eslint/no-unnecessary-condition -- We need access to app here which might not be available yet.
if (globalThis?.app?.isMobile) {
if (id === 'process' || id === 'node:process') {
console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Fake process object is returned instead.`);
return globalThis.process;
}
} else {
const module = originalRequire?.(id);
if (module) {
return extractDefault(module);
}
}
console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Empty object is returned instead.`);
return {};
}
})();
;
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_jiti = require('jiti');
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_markdownlint = require('./markdownlint/markdownlint.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");
if (typeof url.pathToFileURL === "function") {
return url.pathToFileURL(__filename).href;
}
}
if (typeof window !== "undefined") {
return window.location.href;
}
return "";
})();
const jiti = (0, import_jiti.createJiti)(__import_meta_url);
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, "lint:md" /* LintMarkdown */, "Lint the markdown documentation", () => (0, import_markdownlint.lintMarkdown)());
addCommand(program, "lint:md:fix" /* LintMarkdownFix */, "Lint the markdown documentation and apply automatic fixes", () => (0, import_markdownlint.lintMarkdown)(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 jiti.import(relativeScriptPath);
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'] ?? (() => {\n      if (typeof __filename === 'string') {\n        const localRequire = require;\n        const url = localRequire('node:url');\n        if (typeof url.pathToFileURL === 'function') {\n          return url.pathToFileURL(__filename).href;\n        }\n      }\n\n      if (typeof window !== 'undefined') {\n        return window.location.href;\n      }\n\n      // Fallback to an empty string if the environment is unknown\n      return '';\n    })();\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 { 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": ["module"]
}
