obsidian-dev-utils 1.7.3 → 1.7.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,9 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## 1.7.4
4
+
5
+ - Don't exit on `npm run dev`
6
+
3
7
  ## 1.7.3
4
8
 
5
9
  - Switch to var as it what esbuild converts const to
@@ -70,6 +70,7 @@ function cli(argv = import_node_process.default.argv.slice(NODE_SCRIPT_ARGV_SKIP
70
70
  addCommand(program, "spellcheck" /* Spellcheck */, "Spellcheck the source code", () => (0, import_spellcheck.spellcheck)());
71
71
  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]");
72
72
  await program.parseAsync(argv, { from: "user" });
73
+ return import_TaskResult.TaskResult.DoNotExit();
73
74
  }));
74
75
  }
75
76
  function addCommand(program, name, description, taskFn) {
@@ -94,4 +95,4 @@ function toCommandLine(args) {
94
95
  toCommandLine,
95
96
  wrapCliTask
96
97
  });
97
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/bin/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @file\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport { Command } from \"commander\";\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from \"./esbuild/ObsidianPluginBuilder.ts\";\nimport process from \"node:process\";\nimport { lint } from \"./ESLint/ESLint.ts\";\nimport { spellcheck } from \"./spellcheck.ts\";\nimport { updateVersion } from \"./version.ts\";\nimport {\n  invokeAsyncSafely,\n  type MaybePromise\n} from \"../Async.ts\";\nimport {\n  getTaskResult,\n  TaskResult\n} from \"../TaskResult.ts\";\nimport { readNpmPackage } from \"../Npm.ts\";\nimport { getDirname } from \"../Path.ts\";\nimport {\n  buildClean,\n  buildStatic\n} from \"./build.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 * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(wrapCliTask(async () => {\n    const npmPackage = await readNpmPackage(getDirname(import.meta.url));\n    const program = new Command();\n\n    program\n      .name(npmPackage.name)\n      .description(\"CLI for Obsidian plugin development utilities\")\n      .version(npmPackage.version);\n\n    addCommand(program, CommandNames.Build, \"Build the plugin\", () => buildObsidianPlugin({ mode: BuildMode.Production }));\n    addCommand(program, CommandNames.BuildClean, \"Clean the dist folder\", () => buildClean());\n    addCommand(program, CommandNames.BuildStatic, \"Copy static content to dist\", () => buildStatic());\n    addCommand(program, CommandNames.Dev, \"Build the plugin in development mode\", () => buildObsidianPlugin({ mode: BuildMode.Development }));\n    addCommand(program, CommandNames.Lint, \"Lint the source code\", () => lint());\n    addCommand(program, CommandNames.LintFix, \"Lint the source code and apply automatic fixes\", () => lint(true));\n    addCommand(program, CommandNames.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  }));\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\nfunction addCommand<Args extends unknown[]>(program: Command, name: string, description: string, taskFn: (...args: Args) => MaybePromise<TaskResult | void>): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n\n/**\n * Wraps a CLI task function to ensure it runs safely and handles its `TaskResult`.\n *\n * @param taskFn - The task function to execute, which may return a `TaskResult` or void.\n * @returns A promise that resolves when the task is completed and exits with the appropriate status.\n */\nexport async function wrapCliTask(taskFn: () => MaybePromise<TaskResult | void>): Promise<void> {\n  const result = await getTaskResult(taskFn);\n  result.exit();\n}\n\n/**\n * Converts an array of command-line arguments into a single command-line string.\n * Handles escaping of special characters such as spaces, quotes, and newlines.\n *\n * @param args - The array of command-line arguments to convert.\n * @returns A string representing the command-line invocation.\n */\nexport function toCommandLine(args: string[]): string {\n  return args\n    .map(arg => {\n      if (/[\\s\"\\n]/.test(arg)) {\n        const escapedArg = arg.replace(/\"/g, \"\\\\\\\"\").replace(/\\n/g, \"\\\\n\");\n        return `\"${escapedArg}\"`;\n      }\n      return arg;\n    })\n    .join(\" \");\n}\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = \"build\",\n  BuildClean = \"build:clean\",\n  BuildStatic = \"build:static\",\n  Dev = \"dev\",\n  Lint = \"lint\",\n  LintFix = \"lint:fix\",\n  Spellcheck = \"spellcheck\",\n  Version = \"version\"\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,uBAAwB;AACxB,mCAGO;AACP,0BAAoB;AACpB,oBAAqB;AACrB,wBAA2B;AAC3B,qBAA8B;AAC9B,mBAGO;AACP,wBAGO;AACP,iBAA+B;AAC/B,kBAA2B;AAC3B,mBAGO;AApCP,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI,QAAQ,UAAU,EAAE,cAAc,UAAU,GAAG;AAC7G,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAsCA,MAAM,8BAA8B;AAQ7B,SAAS,IAAI,OAAiB,oBAAAA,QAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F,sCAAkB,YAAY,YAAY;AACxC,UAAM,aAAa,UAAM,+BAAe,wBAAW,iBAAe,CAAC;AACnE,UAAM,UAAU,IAAI,yBAAQ;AAE5B,YACG,KAAK,WAAW,IAAI,EACpB,YAAY,+CAA+C,EAC3D,QAAQ,WAAW,OAAO;AAE7B,eAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,eAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,eAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,eAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,eAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,eAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,eAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,eAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,UAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAAA,EACjD,CAAC,CAAC;AACJ;AAWA,SAAS,WAAmC,SAAkB,MAAc,aAAqB,QAAqE;AACpK,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,SAAe,YAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;AAQA,eAAsB,YAAY,QAA8D;AAC9F,QAAM,SAAS,UAAM,iCAAc,MAAM;AACzC,SAAO,KAAK;AACd;AASO,SAAS,cAAc,MAAwB;AACpD,SAAO,KACJ,IAAI,SAAO;AACV,QAAI,UAAU,KAAK,GAAG,GAAG;AACvB,YAAM,aAAa,IAAI,QAAQ,MAAM,KAAM,EAAE,QAAQ,OAAO,KAAK;AACjE,aAAO,IAAI,UAAU;AAAA,IACvB;AACA,WAAO;AAAA,EACT,CAAC,EACA,KAAK,GAAG;AACb;",
  "names": ["process"]
}

98
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/bin/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @file\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport { Command } from \"commander\";\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from \"./esbuild/ObsidianPluginBuilder.ts\";\nimport process from \"node:process\";\nimport { lint } from \"./ESLint/ESLint.ts\";\nimport { spellcheck } from \"./spellcheck.ts\";\nimport { updateVersion } from \"./version.ts\";\nimport {\n  invokeAsyncSafely,\n  type MaybePromise\n} from \"../Async.ts\";\nimport {\n  getTaskResult,\n  TaskResult\n} from \"../TaskResult.ts\";\nimport { readNpmPackage } from \"../Npm.ts\";\nimport { getDirname } from \"../Path.ts\";\nimport {\n  buildClean,\n  buildStatic\n} from \"./build.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 * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(wrapCliTask(async () => {\n    const npmPackage = await readNpmPackage(getDirname(import.meta.url));\n    const program = new Command();\n\n    program\n      .name(npmPackage.name)\n      .description(\"CLI for Obsidian plugin development utilities\")\n      .version(npmPackage.version);\n\n    addCommand(program, CommandNames.Build, \"Build the plugin\", () => buildObsidianPlugin({ mode: BuildMode.Production }));\n    addCommand(program, CommandNames.BuildClean, \"Clean the dist folder\", () => buildClean());\n    addCommand(program, CommandNames.BuildStatic, \"Copy static content to dist\", () => buildStatic());\n    addCommand(program, CommandNames.Dev, \"Build the plugin in development mode\", () => buildObsidianPlugin({ mode: BuildMode.Development }));\n    addCommand(program, CommandNames.Lint, \"Lint the source code\", () => lint());\n    addCommand(program, CommandNames.LintFix, \"Lint the source code and apply automatic fixes\", () => lint(true));\n    addCommand(program, CommandNames.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 TaskResult.DoNotExit();\n  }));\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\nfunction addCommand<Args extends unknown[]>(program: Command, name: string, description: string, taskFn: (...args: Args) => MaybePromise<TaskResult | void>): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n\n/**\n * Wraps a CLI task function to ensure it runs safely and handles its `TaskResult`.\n *\n * @param taskFn - The task function to execute, which may return a `TaskResult` or void.\n * @returns A promise that resolves when the task is completed and exits with the appropriate status.\n */\nexport async function wrapCliTask(taskFn: () => MaybePromise<TaskResult | void>): Promise<void> {\n  const result = await getTaskResult(taskFn);\n  result.exit();\n}\n\n/**\n * Converts an array of command-line arguments into a single command-line string.\n * Handles escaping of special characters such as spaces, quotes, and newlines.\n *\n * @param args - The array of command-line arguments to convert.\n * @returns A string representing the command-line invocation.\n */\nexport function toCommandLine(args: string[]): string {\n  return args\n    .map(arg => {\n      if (/[\\s\"\\n]/.test(arg)) {\n        const escapedArg = arg.replace(/\"/g, \"\\\\\\\"\").replace(/\\n/g, \"\\\\n\");\n        return `\"${escapedArg}\"`;\n      }\n      return arg;\n    })\n    .join(\" \");\n}\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = \"build\",\n  BuildClean = \"build:clean\",\n  BuildStatic = \"build:static\",\n  Dev = \"dev\",\n  Lint = \"lint\",\n  LintFix = \"lint:fix\",\n  Spellcheck = \"spellcheck\",\n  Version = \"version\"\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,uBAAwB;AACxB,mCAGO;AACP,0BAAoB;AACpB,oBAAqB;AACrB,wBAA2B;AAC3B,qBAA8B;AAC9B,mBAGO;AACP,wBAGO;AACP,iBAA+B;AAC/B,kBAA2B;AAC3B,mBAGO;AApCP,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI,QAAQ,UAAU,EAAE,cAAc,UAAU,GAAG;AAC7G,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAsCA,MAAM,8BAA8B;AAQ7B,SAAS,IAAI,OAAiB,oBAAAA,QAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F,sCAAkB,YAAY,YAAY;AACxC,UAAM,aAAa,UAAM,+BAAe,wBAAW,iBAAe,CAAC;AACnE,UAAM,UAAU,IAAI,yBAAQ;AAE5B,YACG,KAAK,WAAW,IAAI,EACpB,YAAY,+CAA+C,EAC3D,QAAQ,WAAW,OAAO;AAE7B,eAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,eAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,eAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,eAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,eAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,eAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,eAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,eAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,UAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,WAAO,6BAAW,UAAU;AAAA,EAC9B,CAAC,CAAC;AACJ;AAWA,SAAS,WAAmC,SAAkB,MAAc,aAAqB,QAAqE;AACpK,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,SAAe,YAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;AAQA,eAAsB,YAAY,QAA8D;AAC9F,QAAM,SAAS,UAAM,iCAAc,MAAM;AACzC,SAAO,KAAK;AACd;AASO,SAAS,cAAc,MAAwB;AACpD,SAAO,KACJ,IAAI,SAAO;AACV,QAAI,UAAU,KAAK,GAAG,GAAG;AACvB,YAAM,aAAa,IAAI,QAAQ,MAAM,KAAM,EAAE,QAAQ,OAAO,KAAK;AACjE,aAAO,IAAI,UAAU;AAAA,IACvB;AACA,WAAO;AAAA,EACT,CAAC,EACA,KAAK,GAAG;AACb;",
  "names": ["process"]
}

package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "obsidian-dev-utils",
3
- "version": "1.7.3",
3
+ "version": "1.7.4",
4
4
  "description": "This is the collection of useful functions that you can use for your Obsidian plugin development",
5
5
  "main": "./dist/lib/index.cjs",
6
6
  "types": "./dist/lib/index.d.ts",