obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
67 lines (64 loc) • 13.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(){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")})();
;
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\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\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\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": []
}
