UNPKG

obsidian-dev-utils

Version:

This is the collection of useful functions that you can use for your Obsidian plugin development

271 lines (257 loc) 21.8 kB
/* 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 {}; } })(); "use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; 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 __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var Debug_exports = {}; __export(Debug_exports, { enableLibraryDebuggers: () => enableLibraryDebuggers, getDebugController: () => getDebugController, getDebugger: () => getDebugger, getLibDebugger: () => getLibDebugger, printWithStackTrace: () => printWithStackTrace, showInitialDebugMessage: () => showInitialDebugMessage }); module.exports = __toCommonJS(Debug_exports); var import_debug = __toESM(__extractDefault(require('debug')), 1); var import_Error = require('./Error.cjs'); var import_Library = require('./Library.cjs'); var import_App = require('./obsidian/App.cjs'); var import_PluginId = require('./obsidian/Plugin/PluginId.cjs'); const NAMESPACE_SEPARATOR = ","; const NEGATED_NAMESPACE_PREFIX = "-"; function enableLibraryDebuggers() { enableNamespaces([import_Library.LIBRARY_NAME, `${import_Library.LIBRARY_NAME}:*`]); } function getDebugController() { return { disable: disableNamespaces, enable: enableNamespaces, get: getNamespaces, set: setNamespaces }; } function getDebugger(namespace, framesToSkip = 0) { const key = `${namespace}:${String(framesToSkip)}`; const debuggersMap = (0, import_App.getObsidianDevUtilsState)(null, "debuggers", /* @__PURE__ */ new Map()).value; let debuggerEx = debuggersMap.get(key); if (!debuggerEx) { debuggerEx = getSharedDebugLibInstance()(namespace); debuggerEx.log = (message, ...args) => { logWithCaller(namespace, framesToSkip, message, ...args); }; debuggersMap.set(key, debuggerEx); } return debuggerEx; } function getLibDebugger(namespace) { const pluginId = (0, import_PluginId.getPluginId)(); const prefix = pluginId === import_PluginId.NO_PLUGIN_ID_INITIALIZED ? "" : `${pluginId}:`; return getDebugger(`${prefix}${import_Library.LIBRARY_NAME}:${namespace}`); } function printWithStackTrace(debuggerInstance, stackTrace, message, ...args) { if (!isInObsidian()) { debuggerInstance(message, ...args); return; } debuggerInstance(message, ...args, "\n\n---\nContext stack trace:\n", makeStackTraceError(stackTrace)); } function showInitialDebugMessage(pluginId) { const isEnabled = getSharedDebugLibInstance().enabled(pluginId); const state = isEnabled ? "enabled" : "disabled"; const changeAction = isEnabled ? "disable" : "enable"; const namespaces = getNamespaces(); setNamespaces(pluginId); getDebugger(pluginId)( `Debug messages for plugin ${pluginId} are ${state}. See https://github.com/mnaoumov/obsidian-dev-utils/blob/main/docs/debugging.md how to ${changeAction} them.` ); setNamespaces(namespaces); } function disableNamespaces(namespaces) { const set = new Set(getNamespaces()); for (const namespace of toArray(namespaces)) { if (namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) { continue; } const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace; if (set.has(namespace)) { set.delete(namespace); } set.add(negatedNamespace); } setNamespaces(Array.from(set)); } function enableNamespaces(namespaces) { const set = new Set(getNamespaces()); for (const namespace of toArray(namespaces)) { if (!namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) { const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace; if (set.has(negatedNamespace)) { set.delete(negatedNamespace); } } set.add(namespace); } setNamespaces(Array.from(set)); } function getNamespaces() { return toArray(getSharedDebugLibInstance().load() ?? ""); } function getSharedDebugLibInstance() { if (typeof window === "undefined") { return import_debug.default; } return (0, import_App.getObsidianDevUtilsState)(null, "debug", import_debug.default).value; } function isInObsidian() { return typeof window !== "undefined"; } function logWithCaller(namespace, framesToSkip, message, ...args) { if (!getSharedDebugLibInstance().enabled(namespace)) { return; } if (!isInObsidian()) { console.debug(message, ...args); return; } const CALLER_LINE_INDEX = 4; const stackLines = new Error().stack?.split("\n") ?? []; stackLines.splice(0, CALLER_LINE_INDEX + framesToSkip); console.debug(message, ...args, "\n\n---\nLogger stack trace:\n", makeStackTraceError(stackLines.join("\n"))); } function makeStackTraceError(stackTrace) { return new import_Error.CustomStackTraceError( "Debug mode: intentional placeholder error. See https://github.com/mnaoumov/obsidian-dev-utils/blob/main/docs/debugging.md.", stackTrace, void 0 ); } function setNamespaces(namespaces) { getSharedDebugLibInstance().enable(toArray(namespaces).join(NAMESPACE_SEPARATOR)); } function toArray(namespaces) { return typeof namespaces === "string" ? namespaces.split(NAMESPACE_SEPARATOR).filter(Boolean) : namespaces.flatMap(toArray); } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { enableLibraryDebuggers, getDebugController, getDebugger, getLibDebugger, printWithStackTrace, showInitialDebugMessage }); //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Debug.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Contains utility functions for debugging.\n */\n\nimport type { Debugger } from 'debug';\n\nimport debug from 'debug';\n\nimport type { DebugController } from './DebugController.ts';\n\nimport { CustomStackTraceError } from './Error.ts';\nimport { LIBRARY_NAME } from './Library.ts';\nimport { getObsidianDevUtilsState } from './obsidian/App.ts';\nimport {\n  getPluginId,\n  NO_PLUGIN_ID_INITIALIZED\n} from './obsidian/Plugin/PluginId.ts';\n\nconst NAMESPACE_SEPARATOR = ',';\nconst NEGATED_NAMESPACE_PREFIX = '-';\n\n/**\n * Enables the debuggers for the `obsidian-dev-utils` library.\n */\nexport function enableLibraryDebuggers(): void {\n  enableNamespaces([LIBRARY_NAME, `${LIBRARY_NAME}:*`]);\n}\n\n/**\n * Returns a debug controller.\n *\n * @returns A debug controller.\n */\nexport function getDebugController(): DebugController {\n  return {\n    disable: disableNamespaces,\n    enable: enableNamespaces,\n    get: getNamespaces,\n    set: setNamespaces\n  };\n}\n\n/**\n * Returns a debugger instance with a log function that includes the caller's file name and line number.\n *\n * @param namespace - The namespace for the debugger instance.\n * @param framesToSkip - The number of frames to skip in the stack trace.\n * @returns A debugger instance with a log function that includes the caller's file name and line number.\n */\nexport function getDebugger(namespace: string, framesToSkip = 0): Debugger {\n  const key = `${namespace}:${String(framesToSkip)}`;\n  const debuggersMap = getObsidianDevUtilsState(null, 'debuggers', new Map<string, Debugger>()).value;\n  let debuggerEx = debuggersMap.get(key);\n  if (!debuggerEx) {\n    debuggerEx = getSharedDebugLibInstance()(namespace);\n    debuggerEx.log = (message: string, ...args: unknown[]): void => {\n      logWithCaller(namespace, framesToSkip, message, ...args);\n    };\n\n    debuggersMap.set(key, debuggerEx);\n  }\n\n  return debuggerEx;\n}\n\n/**\n * Returns a debugger instance for the `obsidian-dev-utils` library.\n *\n * @param namespace - The namespace for the debugger instance.\n * @returns A debugger instance for the `obsidian-dev-utils` library.\n */\nexport function getLibDebugger(namespace: string): Debugger {\n  const pluginId = getPluginId();\n  const prefix = pluginId === NO_PLUGIN_ID_INITIALIZED ? '' : `${pluginId}:`;\n  return getDebugger(`${prefix}${LIBRARY_NAME}:${namespace}`);\n}\n\n/**\n * Prints a message with a stack trace.\n *\n * @param debuggerInstance - The debugger instance.\n * @param stackTrace - The stack trace to print.\n * @param message - The message to print.\n * @param args - The arguments to print.\n */\nexport function printWithStackTrace(debuggerInstance: Debugger, stackTrace: string, message: string, ...args: unknown[]): void {\n  if (!isInObsidian()) {\n    debuggerInstance(message, ...args);\n    return;\n  }\n\n  debuggerInstance(message, ...args, '\\n\\n---\\nContext stack trace:\\n', makeStackTraceError(stackTrace));\n}\n\n/**\n * Shows an initial debug message.\n *\n * @param pluginId - The plugin ID.\n */\nexport function showInitialDebugMessage(pluginId: string): void {\n  const isEnabled = getSharedDebugLibInstance().enabled(pluginId);\n  const state = isEnabled ? 'enabled' : 'disabled';\n  const changeAction = isEnabled ? 'disable' : 'enable';\n  const namespaces = getNamespaces();\n  setNamespaces(pluginId);\n  getDebugger(pluginId)(\n    `Debug messages for plugin ${pluginId} are ${state}. See https://github.com/mnaoumov/obsidian-dev-utils/blob/main/docs/debugging.md how to ${changeAction} them.`\n  );\n  setNamespaces(namespaces);\n}\n\nfunction disableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      continue;\n    }\n    const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n    if (set.has(namespace)) {\n      set.delete(namespace);\n    }\n    set.add(negatedNamespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\nfunction enableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (!namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n      if (set.has(negatedNamespace)) {\n        set.delete(negatedNamespace);\n      }\n    }\n    set.add(namespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\nfunction getNamespaces(): string[] {\n  return toArray(getSharedDebugLibInstance().load() ?? '');\n}\n\nfunction getSharedDebugLibInstance(): typeof debug {\n  if (typeof window === 'undefined') {\n    return debug;\n  }\n  return getObsidianDevUtilsState(null, 'debug', debug).value;\n}\n\nfunction isInObsidian(): boolean {\n  return typeof window !== 'undefined';\n}\n\nfunction logWithCaller(namespace: string, framesToSkip: number, message: string, ...args: unknown[]): void {\n  if (!getSharedDebugLibInstance().enabled(namespace)) {\n    return;\n  }\n\n  if (!isInObsidian()) {\n    console.debug(message, ...args);\n    return;\n  }\n\n  /**\n   * A caller line index is 4 because the call stack is as follows:\n   *\n   * 0: Error\n   * 1:     at logWithCaller (?:?:?)\n   * 2:     at debugInstance.log (?:?:?)\n   * 3:     at debug (?:?:?)\n   * 4:     at functionName (path/to/caller.js:?:?)\n   */\n  const CALLER_LINE_INDEX = 4;\n\n  const stackLines = new Error().stack?.split('\\n') ?? [];\n  stackLines.splice(0, CALLER_LINE_INDEX + framesToSkip);\n\n  console.debug(message, ...args, '\\n\\n---\\nLogger stack trace:\\n', makeStackTraceError(stackLines.join('\\n')));\n}\n\nfunction makeStackTraceError(stackTrace: string): CustomStackTraceError {\n  return new CustomStackTraceError(\n    'Debug mode: intentional placeholder error. See https://github.com/mnaoumov/obsidian-dev-utils/blob/main/docs/debugging.md.',\n    stackTrace,\n    undefined\n  );\n}\n\n/**\n * Sets the namespaces to enable.\n *\n * @param namespaces - The namespaces to enable.\n */\nfunction setNamespaces(namespaces: string | string[]): void {\n  getSharedDebugLibInstance().enable(toArray(namespaces).join(NAMESPACE_SEPARATOR));\n}\n\nfunction toArray(namespaces: string | string[]): string[] {\n  return typeof namespaces === 'string' ? namespaces.split(NAMESPACE_SEPARATOR).filter(Boolean) : namespaces.flatMap(toArray);\n}\n"],
  "mappings": "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",
  "names": ["debug"]
}
