obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
163 lines (149 loc) • 15.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) {
// 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 {};
}
})();
;
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 Type_exports = {};
__export(Type_exports, {
assertAllTypeKeys: () => assertAllTypeKeys,
assertAllUnionMembers: () => assertAllUnionMembers,
typeToDummyParam: () => typeToDummyParam
});
module.exports = __toCommonJS(Type_exports);
const DUMMY_PROXY = new Proxy(dummyThrow, {
apply: dummyThrow,
construct: dummyThrow,
defineProperty: dummyThrow,
deleteProperty: dummyThrow,
get: dummyThrow,
getOwnPropertyDescriptor: dummyThrow,
getPrototypeOf: dummyThrow,
has: dummyThrow,
isExtensible: dummyThrow,
ownKeys: dummyThrow,
preventExtensions: dummyThrow,
set: dummyThrow,
setPrototypeOf: dummyThrow
});
function assertAllTypeKeys(_type, keys) {
return Object.freeze(keys.slice());
}
function assertAllUnionMembers(_type, keys) {
return Object.freeze(keys.slice());
}
function typeToDummyParam() {
return DUMMY_PROXY;
}
function dummyThrow() {
throw new Error("Dummy parameter should not be accessed directly.");
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
assertAllTypeKeys,
assertAllUnionMembers,
typeToDummyParam
});
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/Type.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Type utilities.\n */\n\n/**\n * A type that represents the keys of an object as strings and asserts that all keys are present in a list of keys.\n *\n * @typeParam Type - The type of the object.\n * @typeParam Keys - The list of keys to assert.\n */\nexport type ExactKeys<Type extends object, Keys extends readonly string[]> = ExactMembers<StringKeys<Type>, Keys>;\n\n/**\n * A type that represents a return value that may be `void`.\n *\n * @typeParam T - The type of the value that may be returned.\n */\n// eslint-disable-next-line @typescript-eslint/no-invalid-void-type -- We need to use the `void` return type.\nexport type MaybeReturn<T> = T | void;\n\n/**\n * A type that represents the values of an object.\n *\n * @typeParam T - The type of the object.\n */\nexport type PropertyValues<T extends object> = T[StringKeys<T>];\n\n/**\n * A type that represents the keys of an object as strings.\n *\n * @typeParam T - The type of the object.\n */\nexport type StringKeys<T extends object> = Extract<keyof T, string>;\n\ntype LastInUnion<Union> = UnionToIntersection<Union extends unknown ? () => Union : never> extends () => infer Last ? Last : never;\ntype UnionToIntersection<Union> = (Union extends unknown ? (key: Union) => void : never) extends (key: infer Intersection) => void ? Intersection : never;\ntype UnionToTuple<Union, Last = LastInUnion<Union>> = [Union] extends [never] ? [] : [...UnionToTuple<Exclude<Union, Last>>, Last];\n\nconst DUMMY_PROXY = new Proxy(dummyThrow, {\n  apply: dummyThrow,\n  construct: dummyThrow,\n  defineProperty: dummyThrow,\n  deleteProperty: dummyThrow,\n  get: dummyThrow,\n  getOwnPropertyDescriptor: dummyThrow,\n  getPrototypeOf: dummyThrow,\n  has: dummyThrow,\n  isExtensible: dummyThrow,\n  ownKeys: dummyThrow,\n  preventExtensions: dummyThrow,\n  set: dummyThrow,\n  setPrototypeOf: dummyThrow\n});\n\n/**\n * A type that represents the members of a type.\n *\n * @typeParam Type - The type to assert the members of.\n * @typeParam Keys - The list of members to assert.\n */\nexport type ExactMembers<\n  Type extends LiteralKey,\n  Keys extends readonly LiteralKey[]\n> = Exclude<Keys[number], Type> extends never ? Exclude<Type, Keys[number]> extends never ? Duplicates<Keys> extends [] ? Keys\n    : `ERROR: Duplicate members: ${TupleToCSV<Duplicates<Keys>>}`\n  : `ERROR: Missing members: ${TupleToCSV<UnionToTuple<Exclude<Type, Keys[number]>>>}`\n  : `ERROR: Invalid members: ${TupleToCSV<UnionToTuple<Exclude<Keys[number], Type>>>}`;\n\ntype Duplicates<\n  T extends readonly unknown[],\n  Seen extends readonly unknown[] = [],\n  Added extends readonly unknown[] = [],\n  Out extends readonly unknown[] = []\n> = T extends readonly [infer First, ...infer Rest]\n  ? Includes<Seen, First> extends true ? Includes<Added, First> extends true ? Duplicates<Rest, Seen, Added, Out>\n    : Duplicates<Rest, Seen, [...Added, First], [...Out, First]>\n  : Duplicates<Rest, [...Seen, First], Added, Out>\n  : Out;\n\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters,no-magic-numbers -- We need to use the dummy parameter to get type inference.\ntype Equal<X, Y> = (<T>() => T extends X ? 1 : 2) extends (<T>() => T extends Y ? 1 : 2) ? true : false;\n\ntype Includes<Type extends readonly unknown[], Member> = Type extends readonly [infer First, ...infer Rest]\n  ? Equal<First, Member> extends true ? true : Includes<Rest, Member>\n  : false;\n\ntype LiteralKey = number | string;\n\ntype ToString<T> = T extends number | string ? `${T}` : never;\n\ntype TupleToCSV<Tuple extends readonly unknown[]> = Tuple extends readonly [infer First, ...infer Rest]\n  ? First extends LiteralKey ? Rest extends readonly unknown[] ? Rest['length'] extends 0 ? ToString<First> : `${ToString<First>},${TupleToCSV<Rest>}`\n    : never\n  : never\n  : '';\n\n/**\n * Asserts that all keys of a type are present in a list of keys.\n *\n * @typeParam Type - The type to assert the keys of.\n * @typeParam Keys - The list of keys to assert.\n * @param _type - The type to assert the keys of.\n * @param keys - The list of keys to assert.\n * @returns The list of keys.\n *\n * @remarks If the incorrect keys are provided, the function has a compile-time error.\n *\n * @example\n * ```ts\n * type A = { a: 1, b: 2, c: 3 };\n * assertAllTypeKeys<A>(typeToDummyParam<A>(), ['a', 'b', 'c']); // OK\n * assertAllTypeKeys<A>(typeToDummyParam<A>(), ['c', 'a', 'b']); // OK, order is ignored\n * assertAllTypeKeys<A>(typeToDummyParam<A>(), ['a', 'b', 'c', 'd']); // Error: Invalid members: d\n * assertAllTypeKeys<A>(typeToDummyParam<A>(), ['a', 'b']); // Error: Missing members: c\n * assertAllTypeKeys<A>(typeToDummyParam<A>(), ['a', 'a', 'b', 'c', 'c']); // Error: Duplicate members: a,c\n * ```\n */\nexport function assertAllTypeKeys<\n  Type extends object,\n  const Keys extends readonly string[]\n>(_type: Type, keys: ExactMembers<StringKeys<Type>, Keys>): readonly (keyof Type)[] {\n  return Object.freeze(keys.slice() as (keyof Type)[]);\n}\n\n/**\n * Asserts that all members of a union are present in a list of members.\n *\n * @typeParam Type - The type to assert the members of.\n * @typeParam Keys - The list of members to assert.\n * @param _type - The type to assert the members of.\n * @param keys - The list of members to assert.\n * @returns The list of members.\n *\n * @remarks If the incorrect members are provided, the function has a compile-time error.\n *\n * @example\n * ```ts\n * type A = 1 | 2 | 3 | 'a';\n *\n * assertAllUnionMembers(typeToDummyParam<A>(), [1, 2, 3, 'a']); // OK\n * assertAllUnionMembers(typeToDummyParam<A>(), [3, 2, 1, 'a']); // OK, order is ignored\n * assertAllUnionMembers(typeToDummyParam<A>(), [1, 2, 3, 'a', 4]); // Error: Invalid members: 4\n * assertAllUnionMembers(typeToDummyParam<A>(), [1, 2, 3,]); // Error: Missing members: a\n * assertAllUnionMembers(typeToDummyParam<A>(), [1, 2, 3, 'a', 'a']); // Error: Duplicate members: 1,a\n * ```\n */\nexport function assertAllUnionMembers<\n  const Type extends LiteralKey,\n  const Keys extends readonly LiteralKey[]\n>(_type: Type, keys: ExactMembers<Type, Keys>): readonly Type[] {\n  return Object.freeze(keys.slice() as Type[]);\n}\n\n/**\n * Converts a type to a dummy parameter.\n *\n * This helper function is useful when we need to get type inference when we cannot use generic type parameters.\n *\n * An example below shows such a scenario.\n *\n * @typeParam T - The type to convert.\n * @returns A dummy parameter of the type.\n *\n * @remarks The result should be used only for type inference. The value should not be used directly.\n *\n * @example\n * ```ts\n * type A = { c: number; };\n * type B = { d: string; }\n *\n * function g<T, U>(u: U) {}\n *\n * // We cannot have partial type inference.\n * g<A>({ d: 'foo' }); // Error: Expected 2 type arguments, but got 1. ts(2558)\n *\n * // We have to call instead\n * g<A, B>({ d: 'foo' }); // OK, but we could not use type inference for `U=B`.\n *\n * function g2<T, U>(_type: T, u: U) {}\n * g2(typeToDummyParam<A>(), { d: 'foo' }); // We could use type inference for `T=A` and `U=B`.\n * ```\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters -- We need to use the dummy parameter to get type inference.\nexport function typeToDummyParam<T>(): T {\n  return DUMMY_PROXY as unknown as T;\n}\n\nfunction dummyThrow(): never {\n  throw new Error('Dummy parameter should not be accessed directly.');\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAwCA,MAAM,cAAc,IAAI,MAAM,YAAY;AAAA,EACxC,OAAO;AAAA,EACP,WAAW;AAAA,EACX,gBAAgB;AAAA,EAChB,gBAAgB;AAAA,EAChB,KAAK;AAAA,EACL,0BAA0B;AAAA,EAC1B,gBAAgB;AAAA,EAChB,KAAK;AAAA,EACL,cAAc;AAAA,EACd,SAAS;AAAA,EACT,mBAAmB;AAAA,EACnB,KAAK;AAAA,EACL,gBAAgB;AAClB,CAAC;AAiEM,SAAS,kBAGd,OAAa,MAAqE;AAClF,SAAO,OAAO,OAAO,KAAK,MAAM,CAAmB;AACrD;AAwBO,SAAS,sBAGd,OAAa,MAAiD;AAC9D,SAAO,OAAO,OAAO,KAAK,MAAM,CAAW;AAC7C;AAgCO,SAAS,mBAAyB;AACvC,SAAO;AACT;AAEA,SAAS,aAAoB;AAC3B,QAAM,IAAI,MAAM,kDAAkD;AACpE;",
  "names": []
}
