obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
175 lines (172 loc) • 19.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 initCjs(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;const originalRequire=require;if(originalRequire&&!originalRequire.__isPatched){require=Object.assign(id=>requirePatched(id),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>{const browserProcess={browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"};return browserProcess},"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&"default"in module?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id){const module=originalRequire?.(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})();
;
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,
showInitialDebugMessage: () => showInitialDebugMessage
});
module.exports = __toCommonJS(Debug_exports);
var import_debug = __toESM(__extractDefault(require('debug')), 1);
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 _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 = (0, import_PluginId.getPluginId)();
const prefix = pluginId === import_PluginId.NO_PLUGIN_ID_INITIALIZED ? "" : `${pluginId}:`;
return getDebugger(`${prefix}${import_Library.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 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;
}
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);
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
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": ["debug"]
}
