obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
140 lines (137 loc) • 16.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:__name(()=>"/","cwd"),env:{},platform:"android"};globalThis.process=browserProcess})();
import debug from "debug";
import { LIBRARY_NAME } from "./Library.mjs";
import { getObsidianDevUtilsState } from "./obsidian/App.mjs";
import {
getPluginId,
NO_PLUGIN_ID_INITIALIZED
} from "./obsidian/Plugin/PluginId.mjs";
const NAMESPACE_SEPARATOR = ",";
const NEGATED_NAMESPACE_PREFIX = "-";
function enableLibraryDebuggers() {
enableNamespaces([LIBRARY_NAME, `${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 = getObsidianDevUtilsState(null, "debuggers", /* @__PURE__ */ new Map()).value;
let _debugger = debuggersMap.get(key);
if (!_debugger) {
_debugger = getSharedDebugLibInstance()(namespace);
_debugger.log = (message, ...args) => {
logWithCaller(namespace, framesToSkip, message, ...args);
};
_debugger.printStackTrace = (stackTrace, title) => {
printStackTrace(namespace, stackTrace, title);
};
debuggersMap.set(key, _debugger);
}
return _debugger;
}
function getLibDebugger(namespace) {
const pluginId = getPluginId();
const prefix = pluginId === NO_PLUGIN_ID_INITIALIZED ? "" : `${pluginId}:`;
return getDebugger(`${prefix}${LIBRARY_NAME}:${namespace}`);
}
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 debug;
}
return getObsidianDevUtilsState(null, "debug", debug).value;
}
function isInObsidian() {
return typeof window !== "undefined";
}
function logWithCaller(namespace, framesToSkip, message, ...args) {
if (!getSharedDebugLibInstance().enabled(namespace)) {
return;
}
const CALLER_LINE_INDEX = 4;
const stackLines = new Error().stack?.split("\n") ?? [];
const callerLine = stackLines[CALLER_LINE_INDEX + framesToSkip] ?? "";
console.debug(message, ...args);
if (isInObsidian()) {
printStackTrace(namespace, callerLine, "Debug message caller");
}
}
function printStackTrace(namespace, stackTrace, title) {
const _debugger = getSharedDebugLibInstance()(namespace);
if (!_debugger.enabled) {
return;
}
if (!stackTrace) {
stackTrace = "(unavailable)";
}
if (!(title ?? "")) {
title = "Caller stack trace";
}
_debugger(title);
const prefix = isInObsidian() ? "StackTraceFakeError\n" : "";
console.debug(`${prefix}${stackTrace}`);
}
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);
}
export {
enableLibraryDebuggers,
getDebugController,
getDebugger,
getLibDebugger,
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 { 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\ninterface DebuggerEx extends Debugger {\n  printStackTrace(stackTrace: string, title?: string): void;\n}\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): DebuggerEx {\n  const key = `${namespace}:${String(framesToSkip)}`;\n  const debuggersMap = getObsidianDevUtilsState(null, 'debuggers', new Map<string, DebuggerEx>()).value;\n  let _debugger = debuggersMap.get(key);\n  if (!_debugger) {\n    _debugger = getSharedDebugLibInstance()(namespace) as DebuggerEx;\n    _debugger.log = (message: string, ...args: unknown[]): void => {\n      logWithCaller(namespace, framesToSkip, message, ...args);\n    };\n    _debugger.printStackTrace = (stackTrace, title): void => {\n      printStackTrace(namespace, stackTrace, title);\n    };\n\n    debuggersMap.set(key, _debugger);\n  }\n\n  return _debugger;\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): DebuggerEx {\n  const pluginId = getPluginId();\n  const prefix = pluginId === NO_PLUGIN_ID_INITIALIZED ? '' : `${pluginId}:`;\n  return getDebugger(`${prefix}${LIBRARY_NAME}:${namespace}`);\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  /**\n   * The 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  const callerLine = stackLines[CALLER_LINE_INDEX + framesToSkip] ?? '';\n  // eslint-disable-next-line no-console\n  console.debug(message, ...args);\n  if (isInObsidian()) {\n    printStackTrace(namespace, callerLine, 'Debug message caller');\n  }\n}\n\nfunction printStackTrace(namespace: string, stackTrace: string, title?: string): void {\n  const _debugger = getSharedDebugLibInstance()(namespace);\n\n  if (!_debugger.enabled) {\n    return;\n  }\n\n  if (!stackTrace) {\n    stackTrace = '(unavailable)';\n  }\n  if (!(title ?? '')) {\n    title = 'Caller stack trace';\n  }\n\n  _debugger(title);\n  const prefix = isInObsidian() ? 'StackTraceFakeError\\n' : '';\n  // eslint-disable-next-line no-console\n  console.debug(`${prefix}${stackTrace}`);\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": []
}
