UNPKG

obsidian-dev-utils

Version:

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

117 lines (114 loc) 13.4 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){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}__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")})(); "use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; 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 __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var AbortController_exports = {}; __export(AbortController_exports, { INFINITE_TIMEOUT: () => INFINITE_TIMEOUT, abortSignalAny: () => abortSignalAny, abortSignalNever: () => abortSignalNever, abortSignalTimeout: () => abortSignalTimeout, onAbort: () => onAbort, waitForAbort: () => waitForAbort }); module.exports = __toCommonJS(AbortController_exports); var import_Function = require('./Function.cjs'); const INFINITE_TIMEOUT = Number.POSITIVE_INFINITY; function abortSignalAny(...maybeAbortSignals) { const abortSignals = maybeAbortSignals.filter((abortSignal) => !!abortSignal); if (typeof AbortSignal.any === "function") { return AbortSignal.any(abortSignals); } if (abortSignals.length === 0) { return abortSignalNever(); } if (abortSignals.length === 1 && abortSignals[0]) { return abortSignals[0]; } const abortController = new AbortController(); for (const abortSignal of abortSignals) { if (abortSignal.aborted) { return abortSignal; } } const abortHandlerRemovers = []; for (const abortSignal of abortSignals) { abortHandlerRemovers.push(onAbort(abortSignal, handleAbort)); } return abortController.signal; function handleAbort(abortSignal) { for (const abortHandlerRemover of abortHandlerRemovers) { abortHandlerRemover(); } abortController.abort(abortSignal.reason); } } function abortSignalNever() { return new AbortController().signal; } function abortSignalTimeout(timeoutInMilliseconds) { if (timeoutInMilliseconds === INFINITE_TIMEOUT) { return abortSignalNever(); } if (typeof AbortSignal.timeout === "function") { return AbortSignal.timeout(timeoutInMilliseconds); } const abortController = new AbortController(); window.setTimeout(() => { abortController.abort(new Error(`Timed out in ${String(timeoutInMilliseconds)} milliseconds`)); }, timeoutInMilliseconds); return abortController.signal; } function onAbort(abortSignal, callback) { if (abortSignal.aborted) { callback(abortSignal); return import_Function.noop; } abortSignal.addEventListener("abort", wrappedCallback, { once: true }); return () => { abortSignal.removeEventListener("abort", wrappedCallback); }; function wrappedCallback(evt) { callback(evt.target); } } function waitForAbort(abortSignal, shouldRejectOnAbort) { return new Promise((resolve, reject) => { onAbort(abortSignal, () => { if (shouldRejectOnAbort) { reject(abortSignal.reason); } else { resolve(abortSignal.reason); } }); }); } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { INFINITE_TIMEOUT, abortSignalAny, abortSignalNever, abortSignalTimeout, onAbort, waitForAbort }); //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/AbortController.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * AbortController utilities.\n */\n\nimport { noop } from './Function.ts';\n\n/**\n * A constant representing an infinite timeout.\n */\nexport const INFINITE_TIMEOUT = Number.POSITIVE_INFINITY;\n\n/**\n * An abort signal that aborts when any of the given abort signals abort.\n *\n * @param maybeAbortSignals - The abort signals to abort when any of them abort.\n * @returns The abort signal that aborts when any of the given abort signals abort.\n */\nexport function abortSignalAny(...maybeAbortSignals: (AbortSignal | undefined)[]): AbortSignal {\n  const abortSignals = maybeAbortSignals.filter((abortSignal) => !!abortSignal);\n\n  if (typeof AbortSignal.any === 'function') {\n    return AbortSignal.any(abortSignals);\n  }\n\n  if (abortSignals.length === 0) {\n    return abortSignalNever();\n  }\n\n  if (abortSignals.length === 1 && abortSignals[0]) {\n    return abortSignals[0];\n  }\n\n  const abortController = new AbortController();\n\n  for (const abortSignal of abortSignals) {\n    if (abortSignal.aborted) {\n      return abortSignal;\n    }\n  }\n\n  const abortHandlerRemovers: (() => void)[] = [];\n\n  for (const abortSignal of abortSignals) {\n    abortHandlerRemovers.push(onAbort(abortSignal, handleAbort));\n  }\n\n  return abortController.signal;\n\n  function handleAbort(abortSignal: AbortSignal): void {\n    for (const abortHandlerRemover of abortHandlerRemovers) {\n      abortHandlerRemover();\n    }\n\n    abortController.abort(abortSignal.reason);\n  }\n}\n\n/**\n * An abort signal that never aborts.\n *\n * @returns The abort signal that never aborts.\n */\nexport function abortSignalNever(): AbortSignal {\n  return new AbortController().signal;\n}\n\n/**\n * An abort signal that aborts after a timeout.\n *\n * @param timeoutInMilliseconds - The timeout in milliseconds.\n * @returns The abort signal that aborts after a timeout.\n */\nexport function abortSignalTimeout(timeoutInMilliseconds: number): AbortSignal {\n  if (timeoutInMilliseconds === INFINITE_TIMEOUT) {\n    return abortSignalNever();\n  }\n\n  if (typeof AbortSignal.timeout === 'function') {\n    return AbortSignal.timeout(timeoutInMilliseconds);\n  }\n\n  const abortController = new AbortController();\n  window.setTimeout(() => {\n    abortController.abort(new Error(`Timed out in ${String(timeoutInMilliseconds)} milliseconds`));\n  }, timeoutInMilliseconds);\n  return abortController.signal;\n}\n\n/**\n * Adds an abort listener to an abort signal and calls the callback if the abort signal is already aborted.\n *\n * @param abortSignal - The abort signal to add the listener to.\n * @param callback - The callback to call when the abort signal aborts.\n * @returns A function to remove the abort listener.\n */\nexport function onAbort(abortSignal: AbortSignal, callback: (abortSignal: AbortSignal) => void): () => void {\n  if (abortSignal.aborted) {\n    callback(abortSignal);\n    return noop;\n  }\n\n  abortSignal.addEventListener('abort', wrappedCallback, { once: true });\n  return () => {\n    abortSignal.removeEventListener('abort', wrappedCallback);\n  };\n\n  function wrappedCallback(evt: Event): void {\n    callback(evt.target as AbortSignal);\n  }\n}\n\n/**\n * Waits for an abort signal to abort and resolves with its reason.\n *\n * @typeParam T - Expected type of `abortSignal.reason`.\n * @param abortSignal - The abort signal to wait for.\n * @returns A {@link Promise} that resolves with the reason of the abort signal.\n */\nexport function waitForAbort<T = unknown>(abortSignal: AbortSignal): Promise<T>;\n\n/**\n * Waits for an abort signal to abort and rejects with its reason.\n *\n * @param abortSignal - The abort signal to wait for.\n * @param shouldRejectOnAbort - Whether to reject the promise if the abort signal is aborted.\n * @returns A {@link Promise} that rejects with the reason of the abort signal.\n */\nexport function waitForAbort(abortSignal: AbortSignal, shouldRejectOnAbort: true): Promise<never>;\n\n/**\n * Waits for an abort signal to abort and resolves with its reason.\n *\n * @typeParam T - Expected type of `abortSignal.reason`.\n * @param abortSignal - The abort signal to wait for.\n * @param shouldRejectOnAbort - Whether to reject the promise if the abort signal is aborted.\n * @returns A {@link Promise} that resolves with the reason of the abort signal.\n */\nexport function waitForAbort<T = unknown>(abortSignal: AbortSignal, shouldRejectOnAbort?: boolean): Promise<T> {\n  return new Promise<T>((resolve, reject) => {\n    onAbort(abortSignal, () => {\n      if (shouldRejectOnAbort) {\n        reject(abortSignal.reason as Error);\n      } else {\n        resolve(abortSignal.reason as T);\n      }\n    });\n  });\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,sBAAqB;AAKd,MAAM,mBAAmB,OAAO;AAQhC,SAAS,kBAAkB,mBAA6D;AAC7F,QAAM,eAAe,kBAAkB,OAAO,CAAC,gBAAgB,CAAC,CAAC,WAAW;AAE5E,MAAI,OAAO,YAAY,QAAQ,YAAY;AACzC,WAAO,YAAY,IAAI,YAAY;AAAA,EACrC;AAEA,MAAI,aAAa,WAAW,GAAG;AAC7B,WAAO,iBAAiB;AAAA,EAC1B;AAEA,MAAI,aAAa,WAAW,KAAK,aAAa,CAAC,GAAG;AAChD,WAAO,aAAa,CAAC;AAAA,EACvB;AAEA,QAAM,kBAAkB,IAAI,gBAAgB;AAE5C,aAAW,eAAe,cAAc;AACtC,QAAI,YAAY,SAAS;AACvB,aAAO;AAAA,IACT;AAAA,EACF;AAEA,QAAM,uBAAuC,CAAC;AAE9C,aAAW,eAAe,cAAc;AACtC,yBAAqB,KAAK,QAAQ,aAAa,WAAW,CAAC;AAAA,EAC7D;AAEA,SAAO,gBAAgB;AAEvB,WAAS,YAAY,aAAgC;AACnD,eAAW,uBAAuB,sBAAsB;AACtD,0BAAoB;AAAA,IACtB;AAEA,oBAAgB,MAAM,YAAY,MAAM;AAAA,EAC1C;AACF;AAOO,SAAS,mBAAgC;AAC9C,SAAO,IAAI,gBAAgB,EAAE;AAC/B;AAQO,SAAS,mBAAmB,uBAA4C;AAC7E,MAAI,0BAA0B,kBAAkB;AAC9C,WAAO,iBAAiB;AAAA,EAC1B;AAEA,MAAI,OAAO,YAAY,YAAY,YAAY;AAC7C,WAAO,YAAY,QAAQ,qBAAqB;AAAA,EAClD;AAEA,QAAM,kBAAkB,IAAI,gBAAgB;AAC5C,SAAO,WAAW,MAAM;AACtB,oBAAgB,MAAM,IAAI,MAAM,gBAAgB,OAAO,qBAAqB,CAAC,eAAe,CAAC;AAAA,EAC/F,GAAG,qBAAqB;AACxB,SAAO,gBAAgB;AACzB;AASO,SAAS,QAAQ,aAA0B,UAA0D;AAC1G,MAAI,YAAY,SAAS;AACvB,aAAS,WAAW;AACpB,WAAO;AAAA,EACT;AAEA,cAAY,iBAAiB,SAAS,iBAAiB,EAAE,MAAM,KAAK,CAAC;AACrE,SAAO,MAAM;AACX,gBAAY,oBAAoB,SAAS,eAAe;AAAA,EAC1D;AAEA,WAAS,gBAAgB,KAAkB;AACzC,aAAS,IAAI,MAAqB;AAAA,EACpC;AACF;AA4BO,SAAS,aAA0B,aAA0B,qBAA2C;AAC7G,SAAO,IAAI,QAAW,CAAC,SAAS,WAAW;AACzC,YAAQ,aAAa,MAAM;AACzB,UAAI,qBAAqB;AACvB,eAAO,YAAY,MAAe;AAAA,MACpC,OAAO;AACL,gBAAQ,YAAY,MAAW;AAAA,MACjC;AAAA,IACF,CAAC;AAAA,EACH,CAAC;AACH;",
  "names": []
}
