obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
158 lines (155 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 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 RegExp_exports = {};
__export(RegExp_exports, {
ALWAYS_MATCH_REG_EXP: () => ALWAYS_MATCH_REG_EXP,
NEVER_MATCH_REG_EXP: () => NEVER_MATCH_REG_EXP,
RegExpMergeFlagsConflictStrategy: () => RegExpMergeFlagsConflictStrategy,
escapeRegExp: () => escapeRegExp,
isValidRegExp: () => isValidRegExp,
oneOf: () => oneOf
});
module.exports = __toCommonJS(RegExp_exports);
var RegExpMergeFlagsConflictStrategy = /* @__PURE__ */ ((RegExpMergeFlagsConflictStrategy2) => {
RegExpMergeFlagsConflictStrategy2["Intersect"] = "Intersect";
RegExpMergeFlagsConflictStrategy2["Throw"] = "Throw";
RegExpMergeFlagsConflictStrategy2["Union"] = "Union";
return RegExpMergeFlagsConflictStrategy2;
})(RegExpMergeFlagsConflictStrategy || {});
function escapeRegExp(str) {
return str.replaceAll(/[.*+?^${}()|[\]\\]/g, "\\$&");
}
function isValidRegExp(str) {
try {
new RegExp(str);
return true;
} catch {
return false;
}
}
function hasFlag(regExp, flag) {
return regExp.flags.includes(flag);
}
function shouldPickFlag(regExps, flag, strategy) {
const count = regExps.filter((regExp) => hasFlag(regExp, flag)).length;
switch (strategy) {
case "Intersect" /* Intersect */:
return count === regExps.length;
case "Throw" /* Throw */:
break;
case "Union" /* Union */:
return count > 0;
default:
throw new Error(`Invalid strategy: ${strategy}`);
}
const allSame = count === 0 || count === regExps.length;
if (!allSame) {
throw new Error(`Conflicting flag '${flag}' across patterns.`);
}
return count === regExps.length;
}
const ALWAYS_MATCH_REG_EXP = /(?:)/;
const NEVER_MATCH_REG_EXP = /.^/;
function oneOf(regExps, strategy = "Throw" /* Throw */) {
if (regExps.length === 0) {
return ALWAYS_MATCH_REG_EXP;
}
if (regExps.length === 1 && regExps[0] !== void 0) {
return regExps[0];
}
const source = regExps.map((regExp) => `(?:${regExp.source})`).join("|");
const finalFlags = /* @__PURE__ */ new Set();
addSemanticFlags(finalFlags, regExps, strategy);
addUnicodeFlags(finalFlags, regExps, strategy);
addMetaFlags(finalFlags, regExps);
return new RegExp(source, [...finalFlags].join(""));
}
function addMetaFlags(finalFlags, regExps) {
const META_FLAGS = ["g", "d"];
for (const flag of META_FLAGS) {
if (regExps.some((regExp) => hasFlag(regExp, flag))) {
finalFlags.add(flag);
}
}
}
function addSemanticFlags(finalFlags, regExps, strategy) {
const SEMANTIC_FLAGS = ["i", "m", "s", "y"];
for (const flag of SEMANTIC_FLAGS) {
if (shouldPickFlag(regExps, flag, strategy)) {
finalFlags.add(flag);
}
}
}
function addUnicodeFlags(finalFlags, regExps, strategy) {
const countU = regExps.filter((regExp) => hasFlag(regExp, "u")).length;
const countV = regExps.filter((regExp) => hasFlag(regExp, "v")).length;
let shouldUseUFlag;
let shouldUseVFlag;
switch (strategy) {
case "Intersect" /* Intersect */:
shouldUseUFlag = countU === regExps.length;
shouldUseVFlag = countV === regExps.length;
break;
case "Throw" /* Throw */: {
const allU = countU === regExps.length;
const noneU = countU === 0;
const allV = countV === regExps.length;
const noneV = countV === 0;
if (!(allU || noneU) || !(allV || noneV)) {
throw new Error("Conflicting 'u'/'v' flags across patterns.");
}
shouldUseUFlag = allU;
shouldUseVFlag = allV;
break;
}
case "Union" /* Union */:
shouldUseUFlag = countU > 0;
shouldUseVFlag = countV > 0;
break;
default:
throw new Error(`Invalid strategy: ${strategy}`);
}
if (shouldUseUFlag && shouldUseVFlag) {
if (strategy === "Throw" /* Throw */) {
throw new Error("Cannot combine both 'u'/'v' flags in one RegExp.");
}
shouldUseUFlag = false;
}
if (shouldUseUFlag) {
finalFlags.add("u");
}
if (shouldUseVFlag) {
finalFlags.add("v");
}
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
ALWAYS_MATCH_REG_EXP,
NEVER_MATCH_REG_EXP,
RegExpMergeFlagsConflictStrategy,
escapeRegExp,
isValidRegExp,
oneOf
});
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL1JlZ0V4cC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgcmVndWxhciBleHByZXNzaW9ucy5cbiAqL1xuXG4vKipcbiAqIEEgc3RyYXRlZ3kgdG8gdXNlIHdoZW4gbWVyZ2luZyBtdWx0aXBsZSByZWdleCBmbGFncyBpbnRvIG9uZSBhbHRlcm5hdGlvbi5cbiAqL1xuZXhwb3J0IGVudW0gUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kge1xuICAvKipcbiAgICogS2VlcCBvbmx5IHRoZSBmbGFncyBwcmVzZW50IGluIGFsbCByZWdleGVzLlxuICAgKi9cbiAgSW50ZXJzZWN0ID0gJ0ludGVyc2VjdCcsXG4gIC8qKlxuICAgKiBUaHJvdyBhbiBlcnJvciBpZiB0aGUgcmVnZXhlcyBoYXZlIGNvbmZsaWN0aW5nIGZsYWdzLlxuICAgKi9cbiAgVGhyb3cgPSAnVGhyb3cnLFxuICAvKipcbiAgICogS2VlcCBvbmx5IHRoZSBmbGFncyBwcmVzZW50IGluIGFueSByZWdleC5cbiAgICovXG4gIFVuaW9uID0gJ1VuaW9uJ1xufVxuXG4vKipcbiAqIEVzY2FwZXMgc3BlY2lhbCBjaGFyYWN0ZXJzIGluIGEgc3RyaW5nIHRvIHNhZmVseSB1c2UgaXQgd2l0aGluIGEgcmVndWxhciBleHByZXNzaW9uLlxuICpcbiAqIEBwYXJhbSBzdHIgLSBUaGUgc3RyaW5nIHRvIGVzY2FwZS5cbiAqIEByZXR1cm5zIFRoZSBlc2NhcGVkIHN0cmluZyB3aXRoIHNwZWNpYWwgY2hhcmFjdGVycyBwcmVmaXhlZCB3aXRoIGEgYmFja3NsYXNoLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZXNjYXBlUmVnRXhwKHN0cjogc3RyaW5nKTogc3RyaW5nIHtcbiAgLy8gTk9URTogV2UgY2FuJ3QgdXNlIGByZXBsYWNlQWxsKClgIGZyb20gYFN0cmluZy50c2AgaGVyZSBiZWNhdXNlIGl0IGludHJvZHVjZXMgYSBjaXJjdWxhciBkZXBlbmRlbmN5LlxuICByZXR1cm4gc3RyLnJlcGxhY2VBbGwoL1suKis/XiR7fSgpfFtcXF1cXFxcXS9nLCAnXFxcXCQmJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIGlmIGEgc3RyaW5nIGlzIGEgdmFsaWQgcmVndWxhciBleHByZXNzaW9uLlxuICpcbiAqIEBwYXJhbSBzdHIgLSBUaGUgc3RyaW5nIHRvIGNoZWNrLlxuICogQHJldHVybnMgYHRydWVgIGlmIHRoZSBzdHJpbmcgaXMgYSB2YWxpZCByZWd1bGFyIGV4cHJlc3Npb24sIGBmYWxzZWAgb3RoZXJ3aXNlLlxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNWYWxpZFJlZ0V4cChzdHI6IHN0cmluZyk6IGJvb2xlYW4ge1xuICB0cnkge1xuICAgIG5ldyBSZWdFeHAoc3RyKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbmZ1bmN0aW9uIGhhc0ZsYWcocmVnRXhwOiBSZWdFeHAsIGZsYWc6IHN0cmluZyk6IGJvb2xlYW4ge1xuICByZXR1cm4gcmVnRXhwLmZsYWdzLmluY2x1ZGVzKGZsYWcpO1xufVxuXG5mdW5jdGlvbiBzaG91bGRQaWNrRmxhZyhyZWdFeHBzOiBSZWdFeHBbXSwgZmxhZzogc3RyaW5nLCBzdHJhdGVneTogUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kpOiBib29sZWFuIHtcbiAgY29uc3QgY291bnQgPSByZWdFeHBzLmZpbHRlcigocmVnRXhwKSA9PiBoYXNGbGFnKHJlZ0V4cCwgZmxhZykpLmxlbmd0aDtcbiAgc3dpdGNoIChzdHJhdGVneSkge1xuICAgIGNhc2UgUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kuSW50ZXJzZWN0OlxuICAgICAgcmV0dXJuIGNvdW50ID09PSByZWdFeHBzLmxlbmd0aDtcbiAgICBjYXNlIFJlZ0V4cE1lcmdlRmxhZ3NDb25mbGljdFN0cmF0ZWd5LlRocm93OlxuICAgICAgYnJlYWs7XG4gICAgY2FzZSBSZWdFeHBNZXJnZUZsYWdzQ29uZmxpY3RTdHJhdGVneS5VbmlvbjpcbiAgICAgIHJldHVybiBjb3VudCA+IDA7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBzdHJhdGVneTogJHtzdHJhdGVneSBhcyBzdHJpbmd9YCk7XG4gIH1cblxuICBjb25zdCBhbGxTYW1lID0gY291bnQgPT09IDAgfHwgY291bnQgPT09IHJlZ0V4cHMubGVuZ3RoO1xuICBpZiAoIWFsbFNhbWUpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYENvbmZsaWN0aW5nIGZsYWcgJyR7ZmxhZ30nIGFjcm9zcyBwYXR0ZXJucy5gKTtcbiAgfVxuICByZXR1cm4gY291bnQgPT09IHJlZ0V4cHMubGVuZ3RoO1xufVxuXG4vKipcbiAqIEEgcmVndWxhciBleHByZXNzaW9uIHRoYXQgYWx3YXlzIG1hdGNoZXMuXG4gKi9cbmV4cG9ydCBjb25zdCBBTFdBWVNfTUFUQ0hfUkVHX0VYUCA9IC8oPzopLztcblxuLyoqXG4gKiBBIHJlZ3VsYXIgZXhwcmVzc2lvbiB0aGF0IG5ldmVyIG1hdGNoZXMuXG4gKi9cbmV4cG9ydCBjb25zdCBORVZFUl9NQVRDSF9SRUdfRVhQID0gLy5eLztcblxuLyoqXG4gKiBDb21iaW5lIG11bHRpcGxlIHJlZ2V4ZXMgaW50byBvbmUgYWx0ZXJuYXRpb24sIGhhbmRsaW5nIGZsYWdzLlxuICpcbiAqIEBwYXJhbSByZWdFeHBzIC0gVGhlIHJlZ2V4ZXMgdG8gY29tYmluZS5cbiAqIEBwYXJhbSBzdHJhdGVneSAtIFRoZSBzdHJhdGVneSB0byB1c2Ugd2hlbiBtZXJnaW5nIGZsYWdzIChkZWZhdWx0OiBgUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kuVGhyb3dgKS5cbiAqIEByZXR1cm5zIFRoZSBjb21iaW5lZCByZWdleC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG9uZU9mKFxuICByZWdFeHBzOiBSZWdFeHBbXSxcbiAgc3RyYXRlZ3k6IFJlZ0V4cE1lcmdlRmxhZ3NDb25mbGljdFN0cmF0ZWd5ID0gUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kuVGhyb3dcbik6IFJlZ0V4cCB7XG4gIGlmIChyZWdFeHBzLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBBTFdBWVNfTUFUQ0hfUkVHX0VYUDtcbiAgfVxuXG4gIGlmIChyZWdFeHBzLmxlbmd0aCA9PT0gMSAmJiByZWdFeHBzWzBdICE9PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gcmVnRXhwc1swXTtcbiAgfVxuXG4gIGNvbnN0IHNvdXJjZSA9IHJlZ0V4cHMubWFwKChyZWdFeHApID0+IGAoPzoke3JlZ0V4cC5zb3VyY2V9KWApLmpvaW4oJ3wnKTtcblxuICBjb25zdCBmaW5hbEZsYWdzID0gbmV3IFNldDxzdHJpbmc+KCk7XG4gIGFkZFNlbWFudGljRmxhZ3MoZmluYWxGbGFncywgcmVnRXhwcywgc3RyYXRlZ3kpO1xuICBhZGRVbmljb2RlRmxhZ3MoZmluYWxGbGFncywgcmVnRXhwcywgc3RyYXRlZ3kpO1xuICBhZGRNZXRhRmxhZ3MoZmluYWxGbGFncywgcmVnRXhwcyk7XG5cbiAgcmV0dXJuIG5ldyBSZWdFeHAoc291cmNlLCBbLi4uZmluYWxGbGFnc10uam9pbignJykpO1xufVxuXG5mdW5jdGlvbiBhZGRNZXRhRmxhZ3MoZmluYWxGbGFnczogU2V0PHN0cmluZz4sIHJlZ0V4cHM6IFJlZ0V4cFtdKTogdm9pZCB7XG4gIGNvbnN0IE1FVEFfRkxBR1MgPSBbJ2cnLCAnZCddO1xuICBmb3IgKGNvbnN0IGZsYWcgb2YgTUVUQV9GTEFHUykge1xuICAgIGlmIChyZWdFeHBzLnNvbWUoKHJlZ0V4cCkgPT4gaGFzRmxhZyhyZWdFeHAsIGZsYWcpKSkge1xuICAgICAgZmluYWxGbGFncy5hZGQoZmxhZyk7XG4gICAgfVxuICB9XG59XG5cbmZ1bmN0aW9uIGFkZFNlbWFudGljRmxhZ3MoXG4gIGZpbmFsRmxhZ3M6IFNldDxzdHJpbmc+LFxuICByZWdFeHBzOiBSZWdFeHBbXSxcbiAgc3RyYXRlZ3k6IFJlZ0V4cE1lcmdlRmxhZ3NDb25mbGljdFN0cmF0ZWd5XG4pOiB2b2lkIHtcbiAgY29uc3QgU0VNQU5USUNfRkxBR1MgPSBbJ2knLCAnbScsICdzJywgJ3knXTtcbiAgZm9yIChjb25zdCBmbGFnIG9mIFNFTUFOVElDX0ZMQUdTKSB7XG4gICAgaWYgKHNob3VsZFBpY2tGbGFnKHJlZ0V4cHMsIGZsYWcsIHN0cmF0ZWd5KSkge1xuICAgICAgZmluYWxGbGFncy5hZGQoZmxhZyk7XG4gICAgfVxuICB9XG59XG5cbmZ1bmN0aW9uIGFkZFVuaWNvZGVGbGFncyhcbiAgZmluYWxGbGFnczogU2V0PHN0cmluZz4sXG4gIHJlZ0V4cHM6IFJlZ0V4cFtdLFxuICBzdHJhdGVneTogUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3lcbik6IHZvaWQge1xuICBjb25zdCBjb3VudFUgPSByZWdFeHBzLmZpbHRlcigocmVnRXhwKSA9PiBoYXNGbGFnKHJlZ0V4cCwgJ3UnKSkubGVuZ3RoO1xuICBjb25zdCBjb3VudFYgPSByZWdFeHBzLmZpbHRlcigocmVnRXhwKSA9PiBoYXNGbGFnKHJlZ0V4cCwgJ3YnKSkubGVuZ3RoO1xuXG4gIGxldCBzaG91bGRVc2VVRmxhZzogYm9vbGVhbjtcbiAgbGV0IHNob3VsZFVzZVZGbGFnOiBib29sZWFuO1xuXG4gIHN3aXRjaCAoc3RyYXRlZ3kpIHtcbiAgICBjYXNlIFJlZ0V4cE1lcmdlRmxhZ3NDb25mbGljdFN0cmF0ZWd5LkludGVyc2VjdDpcbiAgICAgIHNob3VsZFVzZVVGbGFnID0gY291bnRVID09PSByZWdFeHBzLmxlbmd0aDtcbiAgICAgIHNob3VsZFVzZVZGbGFnID0gY291bnRWID09PSByZWdFeHBzLmxlbmd0aDtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kuVGhyb3c6IHtcbiAgICAgIGNvbnN0IGFsbFUgPSBjb3VudFUgPT09IHJlZ0V4cHMubGVuZ3RoO1xuICAgICAgY29uc3Qgbm9uZVUgPSBjb3VudFUgPT09IDA7XG4gICAgICBjb25zdCBhbGxWID0gY291bnRWID09PSByZWdFeHBzLmxlbmd0aDtcbiAgICAgIGNvbnN0IG5vbmVWID0gY291bnRWID09PSAwO1xuXG4gICAgICBpZiAoIShhbGxVIHx8IG5vbmVVKSB8fCAhKGFsbFYgfHwgbm9uZVYpKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignQ29uZmxpY3RpbmcgXFwndVxcJy9cXCd2XFwnIGZsYWdzIGFjcm9zcyBwYXR0ZXJucy4nKTtcbiAgICAgIH1cblxuICAgICAgc2hvdWxkVXNlVUZsYWcgPSBhbGxVO1xuICAgICAgc2hvdWxkVXNlVkZsYWcgPSBhbGxWO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kuVW5pb246XG4gICAgICBzaG91bGRVc2VVRmxhZyA9IGNvdW50VSA+IDA7XG4gICAgICBzaG91bGRVc2VWRmxhZyA9IGNvdW50ViA+IDA7XG4gICAgICBicmVhaztcbiAgICBkZWZhdWx0OlxuICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIHN0cmF0ZWd5OiAke3N0cmF0ZWd5IGFzIHN0cmluZ31gKTtcbiAgfVxuXG4gIGlmIChzaG91bGRVc2VVRmxhZyAmJiBzaG91bGRVc2VWRmxhZykge1xuICAgIGlmIChzdHJhdGVneSA9PT0gUmVnRXhwTWVyZ2VGbGFnc0NvbmZsaWN0U3RyYXRlZ3kuVGhyb3cpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IGNvbWJpbmUgYm90aCBcXCd1XFwnL1xcJ3ZcXCcgZmxhZ3MgaW4gb25lIFJlZ0V4cC4nKTtcbiAgICB9XG4gICAgc2hvdWxkVXNlVUZsYWcgPSBmYWxzZTtcbiAgfVxuXG4gIGlmIChzaG91bGRVc2VVRmxhZykge1xuICAgIGZpbmFsRmxhZ3MuYWRkKCd1Jyk7XG4gIH1cbiAgaWYgKHNob3VsZFVzZVZG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