UNPKG

obsidian-dev-utils

Version:

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

286 lines (272 loc) 22.5 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) { // 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 {}; } })(); "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 preprocessPlugin_exports = {}; __export(preprocessPlugin_exports, { preprocessPlugin: () => preprocessPlugin }); module.exports = __toCommonJS(preprocessPlugin_exports); var import_ObjectUtils = require('../../ObjectUtils.cjs'); var import_String = require('../../String.cjs'); var import_NodeModules = require('../NodeModules.cjs'); function preprocessPlugin(isEsm) { const replacements = isEsm ? {} : { [(0, import_String.replaceAll)("import(dot)meta(dot)url", "(dot)", ".")]: () => { if (typeof __filename === "string") { const localRequire = require; const url = localRequire("node:url"); if (typeof url.pathToFileURL === "function") { return url.pathToFileURL(__filename).href; } } if (typeof window !== "undefined") { return window.location.href; } return ""; } }; return { name: "preprocess", setup(build) { build.initialOptions.define ??= {}; for (const key of Object.keys(replacements)) { build.initialOptions.define[key] = `__${(0, import_String.makeValidVariableName)(key)}`; } build.initialOptions.banner ??= {}; build.initialOptions.banner["js"] ??= ""; build.initialOptions.banner["js"] += ` (${String(isEsm ? initEsm : initCjs)})(); `; build.onLoad({ filter: /\.(?:js|ts|cjs|mjs|cts|mts)$/ }, async (args) => { let contents = await (0, import_NodeModules.readFile)(args.path, "utf-8"); for (const [key, value] of Object.entries(replacements)) { const variable = `__${(0, import_String.makeValidVariableName)(key)}`; if (!contents.includes(key)) { continue; } const valueStr = typeof value === "function" ? `(${String(value)})()` : (0, import_ObjectUtils.toJson)(value, { functionHandlingMode: import_ObjectUtils.FunctionHandlingMode.Full }); if (contents.includes(`var ${variable}`)) { continue; } contents = `var ${variable} = globalThis['${key}'] ?? ${valueStr}; ${contents}`; } contents = (0, import_String.replaceAll)(contents, /`\r?\n\/\/# sourceMappingURL/g, "`\n//#${''} sourceMappingURL"); return { contents, loader: "ts" }; }); } }; } 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; } function extractDefault(module2) { return module2 && module2.__esModule && "default" in module2 ? module2.default : module2; } 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); } 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 module2 = originalRequire?.(id); if (module2) { return extractDefault(module2); } } console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Empty object is returned instead.`); return {}; } } function initEsm() { if (globalThis.process) { return; } const browserProcess = { browser: true, cwd() { return "/"; }, env: {}, platform: "android" }; globalThis.process = browserProcess; } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { preprocessPlugin }); //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2VzYnVpbGQvcHJlcHJvY2Vzc1BsdWdpbi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqXG4gKiBUaGlzIG1vZHVsZSBkZWZpbmVzIGEgY3VzdG9tIGVzYnVpbGQgcGx1Z2luIHRoYXQgcHJlcHJvY2Vzc2VzIEphdmFTY3JpcHQgYW5kIFR5cGVTY3JpcHQgZmlsZXMuXG4gKlxuICogQHJlbWFya3NcbiAqIFdlIGNhbm5vdCB1c2UgYC5gIGluc3RlYWQgb2YgYChkb3QpYCBpbiB0aGUgYWJvdmUgZGVzY3JpcHRpb24gYmVjYXVzZSB0aGUgZmlsZSBpdHNlbGYgaXMgcHJlcHJvY2Vzc2VkIHdpdGggdGhlIHNhbWUgcnVsZS5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gJ2VzYnVpbGQnO1xuXG5pbXBvcnQgdHlwZSB7IEdlbmVyaWNPYmplY3QgfSBmcm9tICcuLi8uLi9PYmplY3RVdGlscy50cyc7XG5cbmltcG9ydCB7XG4gIEZ1bmN0aW9uSGFuZGxpbmdNb2RlLFxuICB0b0pzb25cbn0gZnJvbSAnLi4vLi4vT2JqZWN0VXRpbHMudHMnO1xuaW1wb3J0IHtcbiAgbWFrZVZhbGlkVmFyaWFibGVOYW1lLFxuICByZXBsYWNlQWxsXG59IGZyb20gJy4uLy4uL1N0cmluZy50cyc7XG5pbXBvcnQgeyByZWFkRmlsZSB9IGZyb20gJy4uL05vZGVNb2R1bGVzLnRzJztcblxuaW50ZXJmYWNlIEJyb3dzZXJQcm9jZXNzIGV4dGVuZHMgUGFydGlhbDxOb2RlSlMuUHJvY2Vzcz4ge1xuICBicm93c2VyOiBib29sZWFuO1xufVxuXG5pbnRlcmZhY2UgRXNtTW9kdWxlIHtcbiAgX19lc01vZHVsZTogYm9vbGVhbjtcbiAgZGVmYXVsdDogdW5rbm93bjtcbn1cblxuaW50ZXJmYWNlIFJlcXVpcmVQYXRjaGVkIGV4dGVuZHMgTm9kZUpTLlJlcXVpcmUge1xuICBfX2lzUGF0Y2hlZDogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVzYnVpbGQgcGx1Z2luIHRoYXQgcHJlcHJvY2Vzc2VzIEphdmFTY3JpcHQgYW5kIFR5cGVTY3JpcHQgZmlsZXMuXG4gKlxuICogVGhpcyBwbHVnaW4gcGVyZm9ybXMgdGhlIGZvbGxvd2luZyB0YXNrczpcbiAqIC0gUmVwbGFjZXMgaW5zdGFuY2VzIG9mIGBpbXBvcnQoZG90KW1ldGEoZG90KXVybGAgd2l0aCBhIE5vZGUuanMtY29tcGF0aWJsZSBgX19maWxlbmFtZWAgYWx0ZXJuYXRpdmUuXG4gKiAtIE1vZGlmaWVzIHRoZSBgc291cmNlTWFwcGluZ1VSTGAgY29tbWVudCB0byBlbnN1cmUgY29tcGF0aWJpbGl0eSB3aXRoIE9ic2lkaWFuJ3MgcGx1Z2luIHN5c3RlbS5cbiAqIC0gQWRkcyBhIGJhc2ljIGBwcm9jZXNzYCBvYmplY3QgdG8gdGhlIGdsb2JhbCBzY29wZSBpZiBgcHJvY2Vzc2AgaXMgcmVmZXJlbmNlZCBidXQgbm90IGRlZmluZWQuXG4gKlxuICogQHBhcmFtIGlzRXNtIC0gV2hldGhlciB0aGUgYnVpbGQgaXMgZm9yIGFuIEVTTSBmb3JtYXQuXG4gKiBAcmV0dXJucyBBbiBlc2J1aWxkIGBQbHVnaW5gIG9iamVjdCB0aGF0IGhhbmRsZXMgdGhlIHByZXByb2Nlc3NpbmcuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcmVwcm9jZXNzUGx1Z2luKGlzRXNtPzogYm9vbGVhbik6IFBsdWdpbiB7XG4gIGNvbnN0IHJlcGxhY2VtZW50cyA9IGlzRXNtXG4gICAgPyB7fVxuICAgIDoge1xuICAgICAgW3JlcGxhY2VBbGwoJ2ltcG9ydChkb3QpbWV0YShkb3QpdXJsJywgJyhkb3QpJywgJy4nKV06ICgpOiBzdHJpbmcgPT4ge1xuICAgICAgICBpZiAodHlwZW9mIF9fZmlsZW5hbWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgY29uc3QgbG9jYWxSZXF1aXJlID0gcmVxdWlyZTtcbiAgICAgICAgICBjb25zdCB1cmwgPSBsb2NhbFJlcXVpcmUoJ25vZGU6dXJsJykgYXMgdHlwZW9mIGltcG9ydCgnbm9kZTp1cmwnKTtcbiAgICAgICAgICBpZiAodHlwZW9mIHVybC5wYXRoVG9GaWxlVVJMID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICByZXR1cm4gdXJsLnBhdGhUb0ZpbGVVUkwoX19maWxlbmFtZSkuaHJlZjtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgICByZXR1cm4gd2luZG93LmxvY2F0aW9uLmhyZWY7XG4gICAgICAgIH1cblxuICAgICAgICAvLyBGYWxsYmFjayB0byBhbiBlbXB0eSBzdHJpbmcgaWYgdGhlIGVudmlyb25tZW50IGlzIHVua25vd25cbiAgICAgICAgcmV0dXJuICcnO1xuICAgICAgfVxuICAgIH07XG5cbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAncHJlcHJvY2VzcycsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLmluaXRpYWxPcHRpb25zLmRlZmluZSA/Pz0ge307XG5cbiAgICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHJlcGxhY2VtZW50cykpIHtcbiAgICAgICAgYnVpbGQuaW5pdGlhbE9wdGlvbnMuZGVmaW5lW2tleV0gPSBgX18ke21ha2VWYWxpZFZhcmlhYmxlTmFtZShrZXkpfWA7XG4gICAgICB9XG5cbiAgICAgIGJ1aWxkLmluaXRpYWxPcHRpb25zLmJhbm5lciA/Pz0ge307XG4gICAgICBidWlsZC5pbml0aWFsT3B0aW9ucy5iYW5uZXJbJ2pzJ10gPz89ICcnO1xuICAgICAgYnVpbGQuaW5pdGlhbE9wdGlvbnMuYmFubmVyWydqcyddICs9IGBcXG4oJHtTdHJpbmcoaXNFc20gPyBpbml0RXNtIDogaW5pdENqcyl9KSgpO1xcbmA7XG5cbiAgICAgIGJ1aWxkLm9uTG9hZCh7IGZpbHRlcjogL1xcLig/OmpzfHRzfGNqc3xtanN8Y3RzfG10cykkLyB9LCBhc3luYyAoYXJncykgPT4ge1xuICAgICAgICBsZXQgY29udGVudHMgPSBhd2FpdCByZWFkRmlsZShhcmdzLnBhdGgsICd1dGYtOCcpO1xuXG4gICAgICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIE9iamVjdC5lbnRyaWVzKHJlcGxhY2VtZW50cykpIHtcbiAgICAgICAgICBjb25zdCB2YXJpYWJsZSA9IGBfXyR7bWFrZVZhbGlkVmFyaWFibGVOYW1lKGtleSl9YDtcbiAgICAgICAgICBpZiAoIWNvbnRlbnRzLmluY2x1ZGVzKGtleSkpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICAgIH1cbiAgICAgICAgICBjb25zdCB2YWx1ZVN0ciA9IHR5cGVvZiB2YWx1ZSA9PT0gJ2Z1bmN0aW9uJyA/IGAoJHtTdHJpbmcodmFsdWUpfSkoKWAgOiB0b0pzb24odmFsdWUsIHsgZnVuY3Rpb25IYW5kbGluZ01vZGU6IEZ1bmN0aW9uSGFuZGxpbmdNb2RlLkZ1bGwgfSk7XG4gICAgICAgICAgaWYgKGNvbnRlbnRzLmluY2x1ZGVzKGB2YXIgJHt2YXJpYWJsZX1gKSkge1xuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgfVxuICAgICAgICAgIGNvbnRlbnRzID0gYHZhciAke3ZhcmlhYmxlfSA9IGdsb2JhbFRoaXNbJyR7a2V5fSddID8/ICR7dmFsdWVTdHJ9O1xcbiR7Y29udGVudHN9YDtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEhBQ0s6IFRoZSAkeycnfSBwYXJ0IGlzIHVzZWQgdG8gZW5zdXJlIE9ic2lkaWFuIGxvYWRzIHRoZSBwbHVnaW4gcHJvcGVybHksXG4gICAgICAgIC8vIE90aGVyd2lzZSwgaXQgc3RvcHMgbG9hZGluZyBhZnRlciB0aGUgZmlyc3QgbGluZSBvZiB0aGUgc291cmNlTWFwcGluZ1VSTCBjb21tZW50LlxuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdGVtcGxhdGUtY3VybHktaW4tc3RyaW5nIC0tIEl0IGlzIGludGVudGlvbmFsLCB0aGUgc3RyaW5nIGxvb2tzIGxpa2UgYSB0ZW1wbGF0ZSBsaXRlcmFsLCBidXQgaXQgaXMgbm90LlxuICAgICAgICBjb250ZW50cyA9IHJlcGxhY2VBbGwoY29udGVudHMsIC9gXFxyP1xcblxcL1xcLyMgc291cmNlTWFwcGluZ1VSTC9nLCAnYFxcbi8vIyR7XFwnXFwnfSBzb3VyY2VNYXBwaW5nVVJMJyk7XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBjb250ZW50cyxcbiAgICAgICAgICBsb2FkZXI6ICd0cydcbiAgICAgICAgfTtcbiAgICAgIH0pO1xuICAgIH1cbiAgfTtcbn1cblxuZnVuY3Rpb24gaW5pdENqcygpOiB2b2lkIHtcbiAgY29uc3QgZ2xvYmFsVGhpc1JlY29yZCA9IGdsb2JhbFRoaXMgYXMgdW5rbm93biBhcyBHZW5lcmljT2JqZWN0O1xuICBnbG9iYWxUaGlzUmVjb3JkWydfX25hbWUnXSA/Pz0gbmFtZTtcbiAgY29uc3Qgb3JpZ2luYWxSZXF1aXJlID0gcmVxdWlyZSBhcyAoTm9kZUpTLlJlcXVpcmUgJiBQYXJ0aWFsPFJlcXVpcmVQYXRjaGVkPiB8IHVuZGVmaW5lZCk7XG4gIGlmIChvcmlnaW5hbFJlcXVpcmUgJiYgIW9yaWdpbmFsUmVxdWlyZS5fX2lzUGF0Y2hlZCkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1nbG9iYWwtYXNzaWduLCBuby1pbXBsaWNpdC1nbG9iYWxzIC0tIFdlIG5lZWQgdG8gcGF0Y2ggdGhlIGByZXF1aXJlKClgIGZ1bmN0aW9uLlxuICAgIHJlcXVpcmUgPSBPYmplY3QuYXNzaWduKFxuICAgICAgKGlkOiBzdHJpbmcpID0+IHJlcXVpcmVQYXRjaGVkKGlkKSxcbiAgICAgIG9yaWdpbmFsUmVxdWlyZSxcbiAgICAgIHtcbiAgICAgICAgX19pc1BhdGNoZWQ6IHRydWVcbiAgICAgIH1cbiAgICApIGFzIFJlcXVpcmVQYXRjaGVkO1xuICB9XG5cbiAgY29uc3QgbmV3RnVuY3M6IFJlY29yZDxzdHJpbmcsICgpID0+IHVua25vd24+ID0ge1xuICAgIF9fZXh0cmFjdERlZmF1bHQoKSB7XG4gICAgICByZXR1cm4gZXh0cmFjdERlZmF1bHQ7XG4gICAgfSxcbiAgICBwcm9jZXNzKCkge1xuICAgICAgY29uc3QgYnJvd3NlclByb2Nlc3M6IEJyb3dzZXJQcm9jZXNzID0ge1xuICAgICAgICBicm93c2VyOiB0cnVlLFxuICAgICAgICBjd2QoKSB7XG4gICAgICAgICAgcmV0dXJuICcvJztcbiAgICAgICAgfSxcbiAgICAgICAgZW52OiB7fSxcbiAgICAgICAgcGxhdGZvcm06ICdhbmRyb2lkJ1xuICAgICAgfTtcbiAgICAgIHJldHVybiBicm93c2VyUHJvY2VzcztcbiAgICB9XG4gIH07XG5cbiAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMobmV3RnVuY3MpKSB7XG4gICAgZ2xvYmFsVGhpc1JlY29yZFtrZXldID8/PSBuZXdGdW5jc1trZXldPy4oKTtcbiAgfVxuXG4gIGZ1bmN0aW9uIG5hbWUob2JqOiB1bmtub3duKTogdW5rbm93biB7XG4gICAgcmV0dXJuIG9iajtcbiAgfVxuXG4gIGZ1bmN0aW9uIGV4dHJhY3REZWZhdWx0KG1vZHVsZTogUGFydGlhbDxFc21Nb2R1bGU+IHwgdW5kZWZpbmVkKTogdW5rbm93biB7XG4gICAgcmV0dXJuIG1vZHVsZSAmJiBtb2R1bGUuX19lc01vZHVsZSAmJiAnZGVmYXVsdCcgaW4gbW9kdWxlID8gbW9kdWxlLmRlZmF1bHQgOiBtb2R1bGU7XG4gIH1cblxuICBjb25zdCBPQlNJRElBTl9CVUlMVF9JTl9NT0RVTEVfTkFNRVMgPSBbXG4gICAgJ29ic2lkaWFuJyxcbiAgICAnQGNvZGVtaXJyb3IvYXV0b2NvbXBsZXRlJyxcbiAgICAnQGNvZGVtaXJyb3IvY29sbGFiJyxcbiAgICAnQGNvZGVtaXJyb3IvY29tbWFuZHMnLFxuICAgICdAY29kZW1pcnJvci9sYW5ndWFnZScsXG4gICAgJ0Bjb2RlbWlycm9yL2xpbnQnLFxuICAgICdAY29kZW1pcnJvci9zZWFyY2gnLFxuICAgICdAY29kZW1pcnJvci9zdGF0ZScsXG4gICAgJ0Bjb2RlbWlycm9yL3RleHQnLFxuICAgICdAY29kZW1pcnJvci92aWV3JyxcbiAgICAnQGxlemVyL2NvbW1vbicsXG4gICAgJ0BsZXplci9scicsXG4gICAgJ0BsZXplci9oaWdobGlnaHQnXG4gIF07XG5cbiAgY29uc3QgREVQUkVDQVRFRF9PQlNJRElBTl9CVUlMVF9JTl9NT0RVTEVfTkFNRVMgPSBbXG4gICAgJ0Bjb2RlbWlycm9yL2Nsb3NlYnJhY2tldHMnLFxuICAgICdAY29kZW1pcnJvci9jb21tZW50JyxcbiAgICAnQGNvZGVtaXJyb3IvZm9sZCcsXG4gICAgJ0Bjb2RlbWlycm9yL2d1dHRlcicsXG4gICAgJ0Bjb2RlbWlycm9yL2hpZ2hsaWdodCcsXG4gICAgJ0Bjb2RlbWlycm9yL2hpc3RvcnknLFxuICAgICdAY29kZW1pcnJvci9tYXRjaGJyYWNrZXRzJyxcbiAgICAnQGNvZGVtaXJyb3IvcGFuZWwnLFxuICAgICdAY29kZW1pcnJvci9yYW5nZXNldCcsXG4gICAgJ0Bjb2RlbWlycm9yL3JlY3Rhbmd1bGFyLXNlbGVjdGlvbicsXG4gICAgJ0Bjb2RlbWlycm9yL3N0cmVhbS1wYXJzZXInLFxuICAgICdAY29kZW1pcnJvci90b29sdGlwJ1xuICBdO1xuXG4gIGZ1bmN0aW9uIHJlcXVpcmVQYXRjaGVkKGlkOiBzdHJpbmcpOiB1bmtub3duIHtcbiAgICBpZiAoT0JTSURJQU5fQlVJTFRfSU5fTU9EVUxFX05BTUVTLmluY2x1ZGVzKGlkKSB8fCBERVBSRUNBVEVEX09CU0lESUFOX0JVSUxUX0lOX01PRFVMRV9OQU1FUy5pbmNsdWRlcyhpZCkpIHtcbiAgICAgIHJldHVybiBvcmlnaW5hbFJlcXVpcmU/LihpZCk7XG4gICAgfVxuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1kZXByZWNhdGVkLCBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5uZWNlc3NhcnktY29uZGl0aW9uIC0tIFdlIG5lZWQgYWNjZXNzIHRvIGFwcCBoZXJlIHdoaWNoIG1pZ2h0IG5vdCBiZSBhdmFpbGFibGUgeWV0LlxuICAgIGlmIChnbG9iYWxUaGlzPy5hcHA/LmlzTW9iaWxlKSB7XG4gICAgICBpZiAoaWQgPT09ICdwcm9jZXNzJyB8fCBpZCA9PT0gJ25vZGU6cHJvY2VzcycpIHtcbiAgICAgICAgY29uc29sZS5kZWJ1ZyhgVGhlIG1vc3QgbGlrZWx5IHlvdSBjYW4gc2FmZWx5IGlnbm9yZSB0aGlzIGVycm9yLiBNb2R1bGUgbm90IGZvdW5kOiAke2lkfS4gRmFrZSBwcm9jZXNzIG9iamVjdCBpcyByZXR1cm5lZCBpbnN0ZWFkLmApO1xuICAgICAgICByZXR1cm4gZ2xvYmFsVGhpcy5wcm9jZXNzO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBtb2R1bGUgPSBvcmlnaW5hbFJlcXVpcmU/LihpZCkgYXMgKFBhcnRpYWw8RXNtTW9kdWxlPiB8IHVuZGVmaW5lZCk7XG4gICAgICBpZiAobW9kdWxlKSB7XG4gICAgICAgIHJldHVybiBleHRyYWN0RGVmYXVsdChtb2R1bGUpO1xuICAgICAgfVxuICAgIH1cblxuICAgIGNvbnNvbGUuZGVidWcoYFRoZSBtb3N0IGxpa2VseSB5b3UgY2FuIHNhZmVseSBpZ25vcmUgdGhpcyBlcnJvci4gTW9kdWxlIG5vdCBmb3VuZDogJHtpZH0uIEVtcHR5IG9iamVjdCBpcyByZXR1cm5lZCBpbnN0ZWFkLmApO1xuICAgIHJldHVybiB7fTtcbiAgfVxufVxuXG5mdW5jdGlvbiBpbml0RXNtKCk6IHZvaWQge1xuICBpZiAoKGdsb2JhbFRoaXMucHJvY2VzcyBhcyBOb2RlSlMuUHJvY2VzcyB8IHVuZGVmaW5lZCkpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBicm93c2VyUHJvY2VzczogQnJvd3NlclByb2Nlc3MgPSB7XG4gICAgYnJvd3NlcjogdHJ1ZSxcbiAgICBjd2QoKSB7XG4gICAgICByZXR1cm4gJy8nO1xuICAgIH0sXG4gICAgZW52OiB7fSxcbiAgICBwbGF0Zm9ybTogJ2FuZHJvaWQnXG4gIH07XG4gIGdsb2JhbFRoaXMucHJvY2VzcyA9IGJyb3dzZXJQcm9jZXNzIGFzIE5vZGVKUy5Qcm9jZXNzO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFhQSx5QkFHTztBQUNQLG9CQUdPO0FBQ1AseUJBQXlCO0FBMEJsQixTQUFTLGlCQUFpQixPQUF5QjtBQUN4RCxRQUFNLGVBQWUsUUFDakIsQ0FBQyxJQUNEO0FBQUEsSUFDQSxLQUFDLDBCQUFXLDJCQUEyQixTQUFTLEdBQUcsQ0FBQyxHQUFHLE1BQWM7QUFDbkUsVUFBSSxPQUFPLGVBQWUsVUFBVTtBQUNsQyxjQUFNLGVBQWU7QUFDckIsY0FBTSxNQUFNLGFBQWEsVUFBVTtBQUNuQyxZQUFJLE9BQU8sSUFBSSxrQkFBa0IsWUFBWTtBQUMzQyxpQkFBTyxJQUFJLGNBQWMsVUFBVSxFQUFFO0FBQUEsUUFDdkM7QUFBQSxNQUNGO0FBRUEsVUFBSSxPQUFPLFdBQVcsYUFBYTtBQUNqQyxlQUFPLE9BQU8sU0FBUztBQUFBLE1BQ3pCO0FBR0EsYUFBTztBQUFBLElBQ1Q7QUFBQSxFQUNGO0FBRUYsU0FBTztBQUFBLElBQ0wsTUFBTTtBQUFBLElBQ04sTUFBTSxPQUFhO0FBQ2pCLFlBQU0sZUFBZSxXQUFXLENBQUM7QUFFakMsaUJBQVcsT0FBTyxPQUFPLEtBQUssWUFBWSxHQUFHO0FBQzNDLGNBQU0sZUFBZSxPQUFPLEdBQUcsSUFBSSxTQUFLLHFDQUFzQixHQUFHLENBQUM7QUFBQSxNQUNwRTtBQUVBLFlBQU0sZUFBZSxXQUFXLENBQUM7QUFDakMsWUFBTSxlQUFlLE9BQU8s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