obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
131 lines (127 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 initEsm() {
if (globalThis.process) {
return;
}
const browserProcess = {
browser: true,
cwd() {
return '/';
},
env: {},
platform: 'android'
};
globalThis.process = browserProcess;
})();
import { AsyncEvents } from "./AsyncEvents.mjs";
const ASYNC_ERROR_EVENT = "asyncError";
const asyncErrorEventEmitter = new AsyncEvents();
asyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handleAsyncError);
const ASYNC_WRAPPER_ERROR_MESSAGE = "An unhandled error occurred executing async operation";
const STACK_TRACE_PREFIX = " at";
class CustomStackTraceError extends Error {
/**
* Creates a new CustomStackTraceError.
*
* @param message - The message of the error.
* @param stackTrace - The stack trace of the error.
* @param cause - The cause of the error.
*/
constructor(message, stackTrace, cause) {
super(message, { cause });
this.name = "CustomStackTraceError";
Error.captureStackTrace?.(this, CustomStackTraceError);
let rootCause = cause;
const parentCauses = /* @__PURE__ */ new Set();
while (rootCause instanceof CustomStackTraceError) {
if (parentCauses.has(rootCause)) {
throw new Error("Circular cause detected");
}
parentCauses.add(rootCause);
rootCause = rootCause.cause;
}
const originalStackLines = (this.stack ?? "").split("\n");
const stackLines = stackTrace.split("\n");
const ERROR_HEADER_REG_EXP = /^\w*Error(?:: |$)/;
if (ERROR_HEADER_REG_EXP.test(stackLines[0] ?? "")) {
stackLines.splice(0, 1);
}
originalStackLines.splice(1, originalStackLines.length - 1, ...stackLines);
this.stack = originalStackLines.join("\n");
}
}
class SilentError extends Error {
/**
* Creates a new SilentError.
*
* @param message - The message of the error.
*/
constructor(message) {
super(message);
this.name = "SilentError";
Error.captureStackTrace?.(this, SilentError);
}
}
function emitAsyncErrorEvent(asyncError) {
asyncErrorEventEmitter.trigger(ASYNC_ERROR_EVENT, asyncError);
}
function errorToString(error) {
if (!(error instanceof Error)) {
return String(error);
}
let message = error.stack ?? `${error.name}: ${error.message}`;
if (error.cause !== void 0) {
const causeStrLines = errorToString(error.cause).split("\n");
message += `
${generateStackTraceLine("Caused by:")}`;
for (const line of causeStrLines) {
if (!line.trim()) {
continue;
}
message += line.startsWith(STACK_TRACE_PREFIX) ? `
${line}` : `
${generateStackTraceLine(line)}`;
}
}
return message;
}
function getStackTrace(framesToSkip = 0) {
const ADDITIONAL_FRAMES_TO_SKIP = 2;
const stack = new Error().stack ?? "";
const lines = stack.split("\n");
return lines.slice(framesToSkip + ADDITIONAL_FRAMES_TO_SKIP).join("\n");
}
function printError(error, console) {
console ??= globalThis.console;
console.error(errorToString(error));
}
function registerAsyncErrorEventHandler(handler) {
const eventRef = asyncErrorEventEmitter.on(ASYNC_ERROR_EVENT, handler);
return () => {
asyncErrorEventEmitter.offref(eventRef);
};
}
function throwExpression(error) {
throw error;
}
function generateStackTraceLine(title) {
return `${STACK_TRACE_PREFIX} --- ${title} --- (0)`;
}
function handleAsyncError(asyncError) {
printError(asyncError);
}
export {
ASYNC_WRAPPER_ERROR_MESSAGE,
CustomStackTraceError,
SilentError,
emitAsyncErrorEvent,
errorToString,
getStackTrace,
printError,
registerAsyncErrorEventHandler,
throwExpression
};
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL0Vycm9yLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIENvbnRhaW5zIHV0aWxpdHkgZnVuY3Rpb25zIGZvciBlcnJvciBoYW5kbGluZy5cbiAqL1xuXG5pbXBvcnQgeyBBc3luY0V2ZW50cyB9IGZyb20gJy4vQXN5bmNFdmVudHMudHMnO1xuXG5jb25zdCBBU1lOQ19FUlJPUl9FVkVOVCA9ICdhc3luY0Vycm9yJztcblxuY29uc3QgYXN5bmNFcnJvckV2ZW50RW1pdHRlciA9IG5ldyBBc3luY0V2ZW50cygpO1xuYXN5bmNFcnJvckV2ZW50RW1pdHRlci5vbihBU1lOQ19FUlJPUl9FVkVOVCwgaGFuZGxlQXN5bmNFcnJvcik7XG5cbi8qKlxuICogQSBtZXNzYWdlIG9mIHRoZSBBc3luY1dyYXBwZXJFcnJvci5cbiAqL1xuZXhwb3J0IGNvbnN0IEFTWU5DX1dSQVBQRVJfRVJST1JfTUVTU0FHRSA9ICdBbiB1bmhhbmRsZWQgZXJyb3Igb2NjdXJyZWQgZXhlY3V0aW5nIGFzeW5jIG9wZXJhdGlvbic7XG5cbmNvbnN0IFNUQUNLX1RSQUNFX1BSRUZJWCA9ICcgICAgYXQnO1xuXG4vKipcbiAqIEFuIGVycm9yIHRoYXQgd3JhcHMgYW4gZXJyb3Igd2l0aCBhIGN1c3RvbSBzdGFjayB0cmFjZS5cbiAqL1xuZXhwb3J0IGNsYXNzIEN1c3RvbVN0YWNrVHJhY2VFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBuZXcgQ3VzdG9tU3RhY2tUcmFjZUVycm9yLlxuICAgKlxuICAgKiBAcGFyYW0gbWVzc2FnZSAtIFRoZSBtZXNzYWdlIG9mIHRoZSBlcnJvci5cbiAgICogQHBhcmFtIHN0YWNrVHJhY2UgLSBUaGUgc3RhY2sgdHJhY2Ugb2YgdGhlIGVycm9yLlxuICAgKiBAcGFyYW0gY2F1c2UgLSBUaGUgY2F1c2Ugb2YgdGhlIGVycm9yLlxuICAgKi9cbiAgcHVibGljIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZywgc3RhY2tUcmFjZTogc3RyaW5nLCBjYXVzZTogdW5rbm93bikge1xuICAgIHN1cGVyKG1lc3NhZ2UsIHsgY2F1c2UgfSk7XG4gICAgdGhpcy5uYW1lID0gJ0N1c3RvbVN0YWNrVHJhY2VFcnJvcic7XG5cbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVubmVjZXNzYXJ5LWNvbmRpdGlvbiAtLSBgPy5gIGlzIHVzZWQgdG8gc3VwcG9ydCBpT1MgYmVmb3JlIDE3LjJcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZT8uKHRoaXMsIEN1c3RvbVN0YWNrVHJhY2VFcnJvcik7XG5cbiAgICBsZXQgcm9vdENhdXNlID0gY2F1c2U7XG4gICAgY29uc3QgcGFyZW50Q2F1c2VzID0gbmV3IFNldDxDdXN0b21TdGFja1RyYWNlRXJyb3I+KCk7XG4gICAgd2hpbGUgKHJvb3RDYXVzZSBpbnN0YW5jZW9mIEN1c3RvbVN0YWNrVHJhY2VFcnJvcikge1xuICAgICAgaWYgKHBhcmVudENhdXNlcy5oYXMocm9vdENhdXNlKSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0NpcmN1bGFyIGNhdXNlIGRldGVjdGVkJyk7XG4gICAgICB9XG4gICAgICBwYXJlbnRDYXVzZXMuYWRkKHJvb3RDYXVzZSk7XG4gICAgICByb290Q2F1c2UgPSByb290Q2F1c2UuY2F1c2U7XG4gICAgfVxuXG4gICAgY29uc3Qgb3JpZ2luYWxTdGFja0xpbmVzID0gKHRoaXMuc3RhY2sgPz8gJycpLnNwbGl0KCdcXG4nKTtcbiAgICBjb25zdCBzdGFja0xpbmVzID0gc3RhY2tUcmFjZS5zcGxpdCgnXFxuJyk7XG4gICAgY29uc3QgRVJST1JfSEVBREVSX1JFR19FWFAgPSAvXlxcdypFcnJvcig/OjogfCQpLztcbiAgICBpZiAoRVJST1JfSEVBREVSX1JFR19FWFAudGVzdChzdGFja0xpbmVzWzBdID8/ICcnKSkge1xuICAgICAgc3RhY2tMaW5lcy5zcGxpY2UoMCwgMSk7XG4gICAgfVxuICAgIG9yaWdpbmFsU3RhY2tMaW5lcy5zcGxpY2UoMSwgb3JpZ2luYWxTdGFja0xpbmVzLmxlbmd0aCAtIDEsIC4uLnN0YWNrTGluZXMpO1xuICAgIHRoaXMuc3RhY2sgPSBvcmlnaW5hbFN0YWNrTGluZXMuam9pbignXFxuJyk7XG4gIH1cbn1cblxuLyoqXG4gKiBBbiBlcnJvciB0aGF0IGlzIG5vdCBwcmludGVkIHRvIHRoZSBjb25zb2xlLlxuICovXG5leHBvcnQgY2xhc3MgU2lsZW50RXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IFNpbGVudEVycm9yLlxuICAgKlxuICAgKiBAcGFyYW0gbWVzc2FnZSAtIFRoZSBtZXNzYWdlIG9mIHRoZSBlcnJvci5cbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnU2lsZW50RXJyb3InO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bm5lY2Vzc2FyeS1jb25kaXRpb24gLS0gYD8uYCBpcyB1c2VkIHRvIHN1cHBvcnQgaU9TIGJlZm9yZSAxNy4yXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2U/Lih0aGlzLCBTaWxlbnRFcnJvcik7XG4gIH1cbn1cblxuLyoqXG4gKiBFbWl0cyBhbiBhc3luY2hyb25vdXMgZXJyb3IgZXZlbnQuXG4gKlxuICogQHBhcmFtIGFzeW5jRXJyb3IgLSBUaGUgZXJyb3IgdG8gZW1pdCBhcyBhbiBhc3luY2hyb25vdXMgZXJyb3IgZXZlbnQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBlbWl0QXN5bmNFcnJvckV2ZW50KGFzeW5jRXJyb3I6IHVua25vd24pOiB2b2lkIHtcbiAgYXN5bmNFcnJvckV2ZW50RW1pdHRlci50cmlnZ2VyKEFTWU5DX0VSUk9SX0VWRU5ULCBhc3luY0Vycm9yKTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0cyBhbiBlcnJvciB0byBhIHN0cmluZyByZXByZXNlbnRhdGlvbiwgaW5jbHVkaW5nIG5lc3RlZCBjYXVzZXMgd2l0aCBpbmRlbnRhdGlvbi5cbiAqXG4gKiBAcGFyYW0gZXJyb3IgLSBUaGUgZXJyb3IgdG8gY29udmVydCB0byBhIHN0cmluZy5cbiAqIEByZXR1cm5zIFRoZSBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgdGhlIGVycm9yLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZXJyb3JUb1N0cmluZyhlcnJvcjogdW5rbm93bik6IHN0cmluZyB7XG4gIGlmICghKGVycm9yIGluc3RhbmNlb2YgRXJyb3IpKSB7XG4gICAgcmV0dXJuIFN0cmluZyhlcnJvcik7XG4gIH1cblxuICBsZXQgbWVzc2FnZSA9IGVycm9yLnN0YWNrID8/IGAke2Vycm9yLm5hbWV9OiAke2Vycm9yLm1lc3NhZ2V9YDtcbiAgaWYgKGVycm9yLmNhdXNlICE9PSB1bmRlZmluZWQpIHtcbiAgICBjb25zdCBjYXVzZVN0ckxpbmVzID0gZXJyb3JUb1N0cmluZyhlcnJvci5jYXVzZSkuc3BsaXQoJ1xcbicpO1xuICAgIG1lc3NhZ2UgKz0gYFxcbiR7Z2VuZXJhdGVTdGFja1RyYWNlTGluZSgnQ2F1c2VkIGJ5OicpfWA7XG4gICAgZm9yIChjb25zdCBsaW5lIG9mIGNhdXNlU3RyTGluZXMpIHtcbiAgICAgIGlmICghbGluZS50cmltKCkpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG4gICAgICBtZXNzYWdlICs9IGxpbmUuc3RhcnRzV2l0aChTVEFDS19UUkFDRV9QUkVGSVgpXG4gICAgICAgID8gYFxcbiR7bGluZX1gXG4gICAgICAgIDogYFxcbiR7Z2VuZXJhdGVTdGFja1RyYWNlTGluZShsaW5lKX1gO1xuICAgIH1cbiAgfVxuICByZXR1cm4gbWVzc2FnZTtcbn1cblxuLyoqXG4gKiBHZXRzIHRoZSBjdXJyZW50IHN0YWNrIHRyYWNlIGFzIGEgc3RyaW5nLCBleGNsdWRpbmcgdGhlIGN1cnJlbnQgZnVuY3Rpb24gY2FsbC5cbiAqXG4gKiBAcGFyYW0gZnJhbWVzVG9Ta2lwIC0gVGhlIG51bWJlciBvZiBmcmFtZXMgdG8gc2tpcCBpbiB0aGUgc3RhY2sgdHJhY2UuXG4gKiBAcmV0dXJucyBBIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgY3VycmVudCBzdGFjayB0cmFjZSwgZXhjbHVkaW5nIHRoZSBjdXJyZW50IGZ1bmN0aW9uIGNhbGwuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRTdGFja1RyYWNlKGZyYW1lc1RvU2tpcCA9IDApOiBzdHJpbmcge1xuICAvLyBTa2lwcGluZyBFcnJvciBwcmVmaXggYW5kIGBnZXRTdGFja1RyYWNlYCBmdW5jdGlvbiBjYWxsXG4gIGNvbnN0IEFERElUSU9OQUxfRlJBTUVTX1RPX1NLSVAgPSAyO1xuICBjb25zdCBzdGFjayA9IG5ldyBFcnJvcigpLnN0YWNrID8/ICcnO1xuICBjb25zdCBsaW5lcyA9IHN0YWNrLnNwbGl0KCdcXG4nKTtcbiAgcmV0dXJuIGxpbmVzLnNsaWNlKGZyYW1lc1RvU2tpcCArIEFERElUSU9OQUxfRlJBTUVTX1RPX1NLSVApLmpvaW4oJ1xcbicpO1xufVxuXG4vKipcbiAqIFByaW50cyBhbiBlcnJvciB0byB0aGUgY29uc29sZSwgaW5jbHVkaW5nIG5lc3RlZCBjYXVzZXMgYW5kIG9wdGlvbmFsIEFOU0kgc2VxdWVuY2UgY2xlYXJpbmcuXG4gKlxuICogQHBhcmFtIGVycm9yIC0gVGhlIGVycm9yIHRvIHByaW50LlxuICogQHBhcmFtIGNvbnNvbGUgLSBUaGUgY29uc29sZSB0byBwcmludCB0byAoZGVmYXVsdDogYGdsb2JhbFRoaXMuY29uc29sZWApLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJpbnRFcnJvcihlcnJvcjogdW5rbm93biwgY29uc29sZT86IENvbnNvbGUpOiB2b2lkIHtcbiAgY29uc29sZSA/Pz0gZ2xvYmFsVGhpcy5jb25zb2xlO1xuICBjb25zb2xlLmVycm9yKGVycm9yVG9TdHJpbmcoZXJyb3IpKTtcbn1cblxuLyoqXG4gKiBSZWdpc3RlcnMgYW4gZXZlbnQgaGFuZGxlciBmb3IgYXN5bmNocm9ub3VzIGVycm9ycy5cbiAqXG4gKiBAcGFyYW0gaGFuZGxlciAtIFRoZSBoYW5kbGVyIGZ1bmN0aW9uIHRvIGJlIGNhbGxlZCB3aGVuIGFuIGFzeW5jaHJvbm91cyBlcnJvciBldmVudCBvY2N1cnMuXG4gKiBAcmV0dXJucyBBIGZ1bmN0aW9uIHRvIHVucmVnaXN0ZXIgdGhlIGhhbmRsZXIuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZWdpc3RlckFzeW5jRXJyb3JFdmVudEhhbmRsZXIoaGFuZGxlcjogKGFzeW5jRXJyb3I6IHVua25vd24pID0+IHZvaWQpOiAoKSA9PiB2b2lkIHtcbiAgY29uc3QgZXZlbnRSZWYgPSBhc3luY0Vycm9yRXZlbnRFbWl0dGVyLm9uKEFTWU5DX0VSUk9SX0VWRU5ULCBoYW5kbGVyKTtcbiAgcmV0dXJuICgpID0+IHtcbiAgICBhc3luY0Vycm9yRXZlbnRFbWl0dGVyLm9mZnJlZihldmVudFJlZik7XG4gIH07XG59XG5cbi8qKlxuICogVGhyb3dzIGFuIGVycm9yIHdpdGggdGhlIHNwZWNpZmllZCBtZXNzYWdlLlxuICpcbiAqIEBwYXJhbSBlcnJvciAtIFRoZSBlcnJvciB0byB0aHJvdy5cbiAqIEB0aHJvd3NcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRocm93RXhwcmVzc2lvbihlcnJvcjogdW5rbm93bik6IG5ldmVyIHtcbiAgdGhyb3cgZXJyb3I7XG59XG5cbmZ1bmN0aW9uIGdlbmVyYXRlU3RhY2tUcmFjZUxpbmUodGl0bGU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgJHtTVEFDS19UUkFDRV9QUkVGSVh9IC0tLSAke3RpdGxlfSAtLS0gKDApYDtcbn1cblxuLyoqXG4gKiBIYW5kbGVzIGFzeW5jaHJvbm91cyBlcnJvcnMgYnkgcHJpbnRpbmcgdGhlbS5cbiAqXG4gKiBAcGFyYW0gYXN5bmNFcnJvciAtIFRoZSBhc3luY2hyb25vdXMgZXJyb3IgdG8gaGFuZGxlLlxuICovXG5mdW5jdGlvbiBoYW5kbGVBc3luY0Vycm9yKGFzeW5jRXJyb3I6IHVua25vd24pOiB2b2lkIHtcbiAgcHJpbnRFcnJvcihhc3luY0Vycm9yKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQU1BLFNBQVMsbUJBQW1CO0FBRTVCLE1BQU0sb0JBQW9CO0FBRTFCLE1BQU0seUJBQXlCLElBQUksWUFBWTtBQUMvQyx1QkFBdUIsR0FBRyxtQkFBbUIsZ0JBQWdCO0FBS3RELE1BQU0sOEJBQThCO0FBRTNDLE1BQU0scUJBQXFCO0FBS3BCLE1BQU0sOEJBQThCLE1BQU07QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBUXhDLFlBQVksU0FBaUIsWUFBb0IsT0FBZ0I7QUFDdEUsVUFBTSxTQUFTLEVBQUUsTUFBTSxDQUFDO0FBQ3hCLFNBQUssT0FBTztBQUdaLFVBQU0sb0JBQW9CLE1BQU0scUJBQXFCO0FBRXJELFFBQUksWUFBWTtBQUNoQixVQUFNLGVBQWUsb0JBQUksSUFBMkI7QUFDcEQsV0FBTyxxQkFBcUIsdUJBQXVCO0FBQ2pELFVBQUksYUFBYSxJQUFJLFNBQVMsR0FBRztBQUMvQixjQUFNLElBQUksTUFBTSx5QkFBeUI7QUFBQSxNQUMzQztBQUNBLG1CQUFhLElBQUksU0FBUztBQUMxQixrQkFBWSxVQUFVO0FBQUEsSUFDeEI7QUFFQSxVQUFNLHNCQUFzQixLQUFLLFNBQVMsSUFBSSxNQUFNLElBQUk7QUFDeEQsVUFBTSxhQUFhLFdBQVcsTUFBTSxJQUFJO0FBQ3hDLFVBQU0sdUJBQXVCO0FBQzdCLFFBQUkscUJBQXFCLEtBQUssV0FBVyxDQUFDLEtBQUssRUFBRSxHQUFHO0FBQ2xELGlCQUFXLE9BQU8sR0FBRyxDQUFDO0FBQUEsSUFDeEI7QUFDQSx1QkFBbUIsT0FBTyxHQUFHLG1CQUFtQixTQUFTLEdBQUcsR0FBRyxVQUFVO0FBQ3pFLFNBQUssUUFBUSxtQkFBbUIsS0FBSyxJQUFJO0FBQUEsRUFDM0M7QUFDRjtBQUtPLE1BQU0sb0JBQW9CLE1BQU07QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFNOUIsWUFBWSxTQUFpQjtBQUNsQyxVQUFNLE9BQU87QUFDYixTQUFLLE9BQU87QUFHWixVQUFNLG9CQUFvQixNQUFNLFdBQVc7QUFBQSxFQUM3QztBQUNGO0FBT08sU0FBUyxvQkFBb0IsWUFBMkI7QUFDN0QseUJBQXVCLFFBQVEsbUJBQW1CLFVBQVU7QUFDOUQ7QUFRTyxTQUFTLGNBQWMsT0FBd0I7QUFDcEQsTUFBSSxFQUFFLGlCQUFpQixRQUFRO0FBQzdCLFdBQU8sT0FBTyxLQUFLO0FBQUEsRUFDckI7QUFFQSxNQUFJLFVBQVUsTUFBTSxTQUFTLEdBQUcsTUFBTSxJQUFJLEtBQUssTUFBTSxPQUFPO0FBQzVELE1BQUksTUFBTSxVQUFVLFFBQVc7QUFDN0IsVUFBTSxnQkFBZ0IsY0FBYyxNQUFNLEtBQUssRUFBRSxNQUFNLElBQUk7QUFDM0QsZUFBVztBQUFBLEVBQUssdUJBQXVCLFlBQVksQ0FBQztBQUNwRCxlQUFXLFFBQVEsZUFBZTtBQUNoQyxVQUFJLENBQUMsS0FBSyxLQUFLLEdBQUc7QUFDaEI7QUFBQSxNQUNGO0FBQ0EsaUJBQVcsS0FBSyxXQUFXLGtCQUFrQixJQUN6QztBQUFBLEVBQUssSUFBSSxLQUNUO0FBQUEsRUFBSyx1QkFBdUIsSUFBSSxDQUFDO0FBQUEsSUFDdkM7QUFBQSxFQUNGO0FBQ0EsU0FBTztBQUNUO0FBUU8sU0FBUyxjQUFjLGVBQWUsR0FBVztBQUV0RCxRQUFNLDRCQUE0QjtBQUNsQyxRQUFNLFFBQVEsSUFBSSxNQUFNLEVBQUUsU0FBUztBQUNuQyxRQUFNLFFBQVEsTUFBTSxNQUFNLElBQUk7QUFDOUIsU0FBTyxNQUFNLE1BQU0sZUFBZSx5QkFBeUIsRUFBRSxLQUFLLElBQUk7QUFDeEU7QUFRTyxTQUFTLFdBQVcsT0FBZ0IsU0FBeUI7QUFDbEUsY0FBWSxXQUFXO0FBQ3ZCLFVBQVEsTUFBTSxjQUFjLEtBQUssQ0FBQztBQUNwQztBQVFPLFNBQVMsK0JBQStCLFNBQW9EO0FBQ2pHLFFBQU0sV0FBVyx1QkFBdUIsR0FBRyxtQkFBbUIsT0FBTztBQUNyRSxTQUFPLE1BQU07QUFDWCwyQkFBdUIsT0FBTyxRQUFRO0FBQUEsRUFDeEM7QUFDRjtBQVFPLFNBQVMsZ0JBQWdCLE9BQXVCO0FBQ3JELFFBQU07QUFDUjtBQUVBLFNBQVMsdUJBQXVCLE9BQXVCO0FBQ3JELFNBQU8sR0FBRyxrQkFBa0IsUUFBUSxLQUFLO0FBQzNDO0FBT0EsU0FBUyxpQkFBaUIsWUFBMkI7QUFDbkQsYUFBVyxVQUFVO0FBQ3ZCOyIsCiAgIm5hbWVzIjogW10KfQo=