obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
67 lines (64 loc) • 10.8 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 {
dirname,
join,
relative,
resolve,
toPosixPath
} from "../Path.mjs";
import { exec } from "./Exec.mjs";
import { existsSync } from "./NodeModules.mjs";
import { ObsidianDevUtilsRepoPaths } from "./ObsidianDevUtilsRepoPaths.mjs";
function execFromRoot(command, options = {}) {
let root = getRootFolder(options.cwd);
if (!root) {
if (options.shouldFailIfCalledFromOutsideRoot ?? true) {
throw new Error("Could not find root folder");
}
root = options.cwd ?? process.cwd();
}
if (options.shouldIncludeDetails) {
return exec(command, { ...options, cwd: root, shouldIncludeDetails: true });
}
return exec(command, { ...options, cwd: root, shouldIncludeDetails: false });
}
function getRootFolder(cwd) {
let currentFolder = toPosixPath(cwd ?? process.cwd());
while (currentFolder !== ObsidianDevUtilsRepoPaths.CurrentFolder && currentFolder !== ObsidianDevUtilsRepoPaths.RootFolder) {
if (existsSync(join(currentFolder, ObsidianDevUtilsRepoPaths.PackageJson))) {
return toPosixPath(currentFolder);
}
currentFolder = dirname(currentFolder);
}
return null;
}
function resolvePathFromRoot(path, cwd) {
const rootFolder = getRootFolder(cwd);
if (!rootFolder) {
return null;
}
return resolve(rootFolder, path);
}
function resolvePathFromRootSafe(path, cwd) {
return resolvePathFromRoot(path, cwd) ?? path;
}
function toRelativeFromRoot(path, cwd) {
const rootFolder = getRootFolder(cwd);
if (!rootFolder) {
return null;
}
path = toPosixPath(path);
return relative(rootFolder, path);
}
export {
execFromRoot,
getRootFolder,
resolvePathFromRoot,
resolvePathFromRootSafe,
toRelativeFromRoot
};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/ScriptUtils/Root.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for executing commands from the root folder of a project,\n * resolving paths relative to the root.\n */\n\nimport type {\n  ExecOption,\n  ExecResult\n} from './Exec.ts';\n\nimport {\n  dirname,\n  join,\n  relative,\n  resolve,\n  toPosixPath\n} from '../Path.ts';\nimport { exec } from './Exec.ts';\nimport { existsSync } from './NodeModules.ts';\nimport { ObsidianDevUtilsRepoPaths } from './ObsidianDevUtilsRepoPaths.ts';\n\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport async function execFromRoot(command: string | string[], options?: { withDetails?: false } & ExecOption): Promise<string>;\n\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: { withDetails: true } & ExecOption): Promise<ExecResult>;\n\n/**\n * Executes a command from the root folder of the project.\n *\n * @param command - The command to execute. It can be a string or an array of strings.\n * @param options - The options for the execution.\n * @returns A {@link Promise} that resolves with the output of the command or an ExecResult object.\n *          The ExecResult object contains the exit code, exit signal, stderr, and stdout.\n * @throws If the command fails with a non-zero exit code and ignoreExitCode is false.\n *         The error message includes the exit code and stderr.\n *         If an error occurs during the execution and ignoreExitCode is true,\n *         the error is resolved with the stdout and stderr.\n */\nexport function execFromRoot(command: string | string[], options: ExecOption = {}): Promise<ExecResult | string> {\n  let root = getRootFolder(options.cwd);\n\n  if (!root) {\n    if (options.shouldFailIfCalledFromOutsideRoot ?? true) {\n      throw new Error('Could not find root folder');\n    }\n\n    root = options.cwd ?? process.cwd();\n  }\n\n  if (options.shouldIncludeDetails) {\n    return exec(command, { ...options, cwd: root, shouldIncludeDetails: true });\n  }\n\n  return exec(command, { ...options, cwd: root, shouldIncludeDetails: false });\n}\n\n/**\n * Retrieves the root folder of the project.\n *\n * @param cwd - The current working folder to resolve from.\n * @returns The path to the root folder.\n * @throws If the root folder cannot be found.\n */\nexport function getRootFolder(cwd?: string): null | string {\n  let currentFolder = toPosixPath(cwd ?? process.cwd());\n  while (currentFolder !== ObsidianDevUtilsRepoPaths.CurrentFolder as string && currentFolder !== ObsidianDevUtilsRepoPaths.RootFolder as string) {\n    if (existsSync(join(currentFolder, ObsidianDevUtilsRepoPaths.PackageJson))) {\n      return toPosixPath(currentFolder);\n    }\n    currentFolder = dirname(currentFolder);\n  }\n\n  return null;\n}\n\n/**\n * Resolves a path relative to the root folder of the project.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working folder to resolve from.\n * @returns The resolved absolute path.\n */\nexport function resolvePathFromRoot(path: string, cwd?: string): null | string {\n  const rootFolder = getRootFolder(cwd);\n  if (!rootFolder) {\n    return null;\n  }\n\n  return resolve(rootFolder, path);\n}\n\n/**\n * Resolves a path relative to the root folder, returning the resolved path or the original path if it does not exist.\n *\n * @param path - The path to resolve.\n * @param cwd - The current working folder to resolve from.\n * @returns The resolved path or the original path if it does not exist.\n */\nexport function resolvePathFromRootSafe(path: string, cwd?: string): string {\n  return resolvePathFromRoot(path, cwd) ?? path;\n}\n\n/**\n * Converts an absolute path to a relative path from the root folder of the project.\n *\n * @param path - The absolute path to convert.\n * @param cwd - The current working folder to resolve from.\n * @returns The relative path from the root folder.\n */\nexport function toRelativeFromRoot(path: string, cwd?: string): null | string {\n  const rootFolder = getRootFolder(cwd);\n  if (!rootFolder) {\n    return null;\n  }\n\n  path = toPosixPath(path);\n  return relative(rootFolder, path);\n}\n"],
  "mappings": ";;;;;;;AAYA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,YAAY;AACrB,SAAS,kBAAkB;AAC3B,SAAS,iCAAiC;AAyCnC,SAAS,aAAa,SAA4B,UAAsB,CAAC,GAAiC;AAC/G,MAAI,OAAO,cAAc,QAAQ,GAAG;AAEpC,MAAI,CAAC,MAAM;AACT,QAAI,QAAQ,qCAAqC,MAAM;AACrD,YAAM,IAAI,MAAM,4BAA4B;AAAA,IAC9C;AAEA,WAAO,QAAQ,OAAO,QAAQ,IAAI;AAAA,EACpC;AAEA,MAAI,QAAQ,sBAAsB;AAChC,WAAO,KAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,KAAK,CAAC;AAAA,EAC5E;AAEA,SAAO,KAAK,SAAS,EAAE,GAAG,SAAS,KAAK,MAAM,sBAAsB,MAAM,CAAC;AAC7E;AASO,SAAS,cAAc,KAA6B;AACzD,MAAI,gBAAgB,YAAY,OAAO,QAAQ,IAAI,CAAC;AACpD,SAAO,kBAAkB,0BAA0B,iBAA2B,kBAAkB,0BAA0B,YAAsB;AAC9I,QAAI,WAAW,KAAK,eAAe,0BAA0B,WAAW,CAAC,GAAG;AAC1E,aAAO,YAAY,aAAa;AAAA,IAClC;AACA,oBAAgB,QAAQ,aAAa;AAAA,EACvC;AAEA,SAAO;AACT;AASO,SAAS,oBAAoB,MAAc,KAA6B;AAC7E,QAAM,aAAa,cAAc,GAAG;AACpC,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,EACT;AAEA,SAAO,QAAQ,YAAY,IAAI;AACjC;AASO,SAAS,wBAAwB,MAAc,KAAsB;AAC1E,SAAO,oBAAoB,MAAM,GAAG,KAAK;AAC3C;AASO,SAAS,mBAAmB,MAAc,KAA6B;AAC5E,QAAM,aAAa,cAAc,GAAG;AACpC,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,EACT;AAEA,SAAO,YAAY,IAAI;AACvB,SAAO,SAAS,YAAY,IAAI;AAClC;",
  "names": []
}
