UNPKG

obsidian-dev-utils

Version:

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

276 lines (262 loc) 24.3 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 __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; 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 __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var ObsidianPluginBuilder_exports = {}; __export(ObsidianPluginBuilder_exports, { BuildMode: () => BuildMode, banner: () => banner, buildObsidianPlugin: () => buildObsidianPlugin, invokeEsbuild: () => invokeEsbuild }); module.exports = __toCommonJS(ObsidianPluginBuilder_exports); var import_esbuild = require('esbuild'); var import_esbuild_sass_plugin = __toESM(__extractDefault(require('esbuild-sass-plugin')), 1); var import_Error = require('../../Error.cjs'); var import_ObjectUtils = require('../../ObjectUtils.cjs'); var import_ObsidianPluginRepoPaths = require('../../obsidian/Plugin/ObsidianPluginRepoPaths.cjs'); var import_Path = require('../../Path.cjs'); var import_build = require('../build.cjs'); var import_CliUtils = require('../CliUtils.cjs'); var import_NodeModules = require('../NodeModules.cjs'); var import_Npm = require('../Npm.cjs'); var import_Root = require('../Root.cjs'); var import_copyToObsidianPluginsFolderPlugin = require('./copyToObsidianPluginsFolderPlugin.cjs'); var import_customEsbuildOptionsPlugin = require('./customEsbuildOptionsPlugin.cjs'); var import_fixEsmPlugin = require('./fixEsmPlugin.cjs'); var import_fixSourceMapsPlugin = require('./fixSourceMapsPlugin.cjs'); var import_preprocessPlugin = require('./preprocessPlugin.cjs'); var import_renameCssPlugin = require('./renameCssPlugin.cjs'); var import_svelteWrapperPlugin = require('./svelteWrapperPlugin.cjs'); const sassPlugin = (0, import_ObjectUtils.extractDefaultExportInterop)(import_esbuild_sass_plugin.default); var BuildMode = /* @__PURE__ */ ((BuildMode2) => { BuildMode2[BuildMode2["Development"] = 0] = "Development"; BuildMode2[BuildMode2["Production"] = 1] = "Production"; return BuildMode2; })(BuildMode || {}); const banner = `/* THIS IS A GENERATED/BUNDLED FILE BY ESBUILD if you want to view the source, please visit the github repository of this plugin */ `; async function buildObsidianPlugin(options) { await (0, import_build.buildCompile)(); const envPath = (0, import_Root.resolvePathFromRoot)(".env"); if (envPath && (0, import_NodeModules.existsSync)(envPath)) { (0, import_NodeModules.loadEnvFile)(envPath); } const obsidianPluginBuilderEnv = import_NodeModules.process.env; const obsidianConfigFolder = options.obsidianConfigFolder ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_FOLDER ?? ""; const isProductionBuild = options.mode === 1 /* Production */; const distFolder = (0, import_Root.resolvePathFromRoot)(isProductionBuild ? import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.DistBuild : import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.DistDev); if (!distFolder) { throw new Error("Could not determine the dist folder"); } if ((0, import_NodeModules.existsSync)(distFolder)) { await (0, import_NodeModules.rm)(distFolder, { recursive: true }); } await (0, import_NodeModules.mkdir)(distFolder, { recursive: true }); const distFileNames = [ import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson ]; if (!isProductionBuild) { await (0, import_NodeModules.writeFile)((0, import_Path.join)(distFolder, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.HotReload), "", "utf-8"); } for (const fileName of distFileNames) { const localFile = (0, import_Root.resolvePathFromRoot)(fileName); if (!localFile) { throw new Error(`Could not determine the local file for ${fileName}`); } const distFile = (0, import_Path.join)(distFolder, fileName); if ((0, import_NodeModules.existsSync)(localFile)) { await (0, import_NodeModules.cp)(localFile, distFile); } } const distPath = (0, import_Path.join)(distFolder, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.MainJs); const cssPath = (0, import_Path.join)(distFolder, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.StylesCss); const packageJson = await (0, import_Npm.readPackageJson)(); const pluginName = packageJson.name ?? "(unknown)"; const buildOptions = { banner: { js: banner }, bundle: true, conditions: ["browser"], entryPoints: [ (0, import_Root.resolvePathFromRoot)((0, import_Path.join)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.Src, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.MainTs)) ?? (0, import_Error.throwExpression)(new Error("Could not determine the entry point for the plugin")) ], external: [ "obsidian", "electron", "@codemirror/autocomplete", "@codemirror/collab", "@codemirror/commands", "@codemirror/language", "@codemirror/lint", "@codemirror/search", "@codemirror/state", "@codemirror/view", "@lezer/common", "@lezer/highlight", "@lezer/lr", "esbuild", "eslint", ...import_NodeModules.builtinModules ], format: "cjs", keepNames: true, logLevel: "info", minify: isProductionBuild, outfile: distPath, platform: "node", plugins: [ (0, import_customEsbuildOptionsPlugin.customEsbuildOptionsPlugin)(options.customizeEsbuildOptions?.bind(options)), (0, import_svelteWrapperPlugin.svelteWrapperPlugin)(isProductionBuild), sassPlugin({ sourceMap: !isProductionBuild }), (0, import_renameCssPlugin.renameCssPlugin)(distFolder), (0, import_preprocessPlugin.preprocessPlugin)(), (0, import_fixEsmPlugin.fixEsmPlugin)(), (0, import_fixSourceMapsPlugin.fixSourceMapsPlugin)(isProductionBuild, [distPath, cssPath], pluginName), ...options.customEsbuildPlugins ?? [], (0, import_copyToObsidianPluginsFolderPlugin.copyToObsidianPluginsFolderPlugin)(isProductionBuild, distFolder, obsidianConfigFolder, pluginName) ], sourcemap: isProductionBuild ? false : "inline", target: "esnext", treeShaking: true }; const buildContext = await (0, import_esbuild.context)(buildOptions); return await invokeEsbuild(buildContext, isProductionBuild); } async function invokeEsbuild(buildContext, isProductionBuild) { if (isProductionBuild) { const result = await buildContext.rebuild(); const isSuccess = result.errors.length === 0 && result.warnings.length === 0; return import_CliUtils.CliTaskResult.Success(isSuccess); } await buildContext.watch(); return import_CliUtils.CliTaskResult.DoNotExit(); } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { BuildMode, banner, buildObsidianPlugin, invokeEsbuild }); //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL1NjcmlwdFV0aWxzL2VzYnVpbGQvT2JzaWRpYW5QbHVnaW5CdWlsZGVyLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIGZ1bmN0aW9uYWxpdHkgdG8gYnVpbGQgYW5kIGJ1bmRsZSBhbiBPYnNpZGlhbiBwbHVnaW4gdXNpbmcgZXNidWlsZC5cbiAqIEl0IGluY2x1ZGVzIGZ1bmN0aW9ucyB0byBoYW5kbGUgdGhlIGJ1aWxkIHByb2Nlc3MgYmFzZWQgb24gZGlmZmVyZW50IGJ1aWxkIG1vZGVzIChkZXZlbG9wbWVudCBvciBwcm9kdWN0aW9uKSxcbiAqIGFuZCBpdCBzZXRzIHVwIHZhcmlvdXMgZXNidWlsZCBwbHVnaW5zIHRvIHByZXByb2Nlc3MsIGxpbnQsIGZpeCBzb3VyY2UgbWFwcywgYW5kIGNvcHkgZmlsZXMgdG8gdGhlIE9ic2lkaWFuIHBsdWdpbnMgZm9sZGVyLlxuICovXG5cbmltcG9ydCB0eXBlIHtcbiAgQnVpbGRDb250ZXh0LFxuICBCdWlsZE9wdGlvbnMsXG4gIFBsdWdpblxufSBmcm9tICdlc2J1aWxkJztcblxuaW1wb3J0IHsgY29udGV4dCB9IGZyb20gJ2VzYnVpbGQnO1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC14L25vLXJlbmFtZS1kZWZhdWx0IC0tIFdlIG5lZWQgYSB0ZW1wIHZhcmlhYmxlIHRvIGFwcGx5IGBleHRyYWN0RGVmYXVsdEV4cG9ydEludGVyb3AoKWAgZml4IGJlbG93LlxuaW1wb3J0IHNhc3NQbHVnaW5fIGZyb20gJ2VzYnVpbGQtc2Fzcy1wbHVnaW4nO1xuXG5pbXBvcnQgeyB0aHJvd0V4cHJlc3Npb24gfSBmcm9tICcuLi8uLi9FcnJvci50cyc7XG5pbXBvcnQgeyBleHRyYWN0RGVmYXVsdEV4cG9ydEludGVyb3AgfSBmcm9tICcuLi8uLi9PYmplY3RVdGlscy50cyc7XG5pbXBvcnQgeyBPYnNpZGlhblBsdWdpblJlcG9QYXRocyB9IGZyb20gJy4uLy4uL29ic2lkaWFuL1BsdWdpbi9PYnNpZGlhblBsdWdpblJlcG9QYXRocy50cyc7XG5pbXBvcnQgeyBqb2luIH0gZnJvbSAnLi4vLi4vUGF0aC50cyc7XG5pbXBvcnQgeyBidWlsZENvbXBpbGUgfSBmcm9tICcuLi9idWlsZC50cyc7XG5pbXBvcnQgeyBDbGlUYXNrUmVzdWx0IH0gZnJvbSAnLi4vQ2xpVXRpbHMudHMnO1xuaW1wb3J0IHtcbiAgYnVpbHRpbk1vZHVsZXMsXG4gIGNwLFxuICBleGlzdHNTeW5jLFxuICBsb2FkRW52RmlsZSxcbiAgbWtkaXIsXG4gIHByb2Nlc3MsXG4gIHJtLFxuICB3cml0ZUZpbGVcbn0gZnJvbSAnLi4vTm9kZU1vZHVsZXMudHMnO1xuaW1wb3J0IHsgcmVhZFBhY2thZ2VKc29uIH0gZnJvbSAnLi4vTnBtLnRzJztcbmltcG9ydCB7IHJlc29sdmVQYXRoRnJvbVJvb3QgfSBmcm9tICcuLi9Sb290LnRzJztcbmltcG9ydCB7IGNvcHlUb09ic2lkaWFuUGx1Z2luc0ZvbGRlclBsdWdpbiB9IGZyb20gJy4vY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luLnRzJztcbmltcG9ydCB7IGN1c3RvbUVzYnVpbGRPcHRpb25zUGx1Z2luIH0gZnJvbSAnLi9jdXN0b21Fc2J1aWxkT3B0aW9uc1BsdWdpbi50cyc7XG5pbXBvcnQgeyBmaXhFc21QbHVnaW4gfSBmcm9tICcuL2ZpeEVzbVBsdWdpbi50cyc7XG5pbXBvcnQgeyBmaXhTb3VyY2VNYXBzUGx1Z2luIH0gZnJvbSAnLi9maXhTb3VyY2VNYXBzUGx1Z2luLnRzJztcbmltcG9ydCB7IHByZXByb2Nlc3NQbHVnaW4gfSBmcm9tICcuL3ByZXByb2Nlc3NQbHVnaW4udHMnO1xuaW1wb3J0IHsgcmVuYW1lQ3NzUGx1Z2luIH0gZnJvbSAnLi9yZW5hbWVDc3NQbHVnaW4udHMnO1xuaW1wb3J0IHsgc3ZlbHRlV3JhcHBlclBsdWdpbiB9IGZyb20gJy4vc3ZlbHRlV3JhcHBlclBsdWdpbi50cyc7XG5cbmNvbnN0IHNhc3NQbHVnaW4gPSBleHRyYWN0RGVmYXVsdEV4cG9ydEludGVyb3Aoc2Fzc1BsdWdpbl8pO1xuXG4vKipcbiAqIEVudW1lcmF0aW9uIHJlcHJlc2VudGluZyB0aGUgYnVpbGQgbW9kZXMuXG4gKi9cbmV4cG9ydCBlbnVtIEJ1aWxkTW9kZSB7XG4gIC8qKiBEZXZlbG9wbWVudCBtb2RlIGZvciBidWlsZGluZyB0aGUgcGx1Z2luICovXG4gIERldmVsb3BtZW50LFxuICAvKiogUHJvZHVjdGlvbiBtb2RlIGZvciBidWlsZGluZyB0aGUgcGx1Z2luICovXG4gIFByb2R1Y3Rpb25cbn1cblxuLyoqXG4gKiBCYW5uZXIgdGV4dCB0byBiZSBpbmNsdWRlZCBhdCB0aGUgdG9wIG9mIHRoZSBnZW5lcmF0ZWQgZmlsZXMuXG4gKi9cbmV4cG9ydCBjb25zdCBiYW5uZXIgPSBgLypcblRISVMgSVMgQSBHRU5FUkFURUQvQlVORExFRCBGSUxFIEJZIEVTQlVJTERcbmlmIHlvdSB3YW50IHRvIHZpZXcgdGhlIHNvdXJjZSwgcGxlYXNlIHZpc2l0IHRoZSBnaXRodWIgcmVwb3NpdG9yeSBvZiB0aGlzIHBsdWdpblxuKi9cbmA7XG5cbi8qKlxuICogT3B0aW9ucyBmb3Ige0BsaW5rIGJ1aWxkT2JzaWRpYW5QbHVnaW59LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkT2JzaWRpYW5QbHVnaW5PcHRpb25zIHtcbiAgLyoqXG4gICAqIEN1c3RvbSBlc2J1aWxkIHBsdWdpbnMgdG8gYmUgdXNlZCBkdXJpbmcgdGhlIGJ1aWxkIHByb2Nlc3MuXG4gICAqL1xuICBjdXN0b21Fc2J1aWxkUGx1Z2lucz86IFBsdWdpbltdO1xuXG4gIC8qKlxuICAgKiBDdXN0b21pemVzIHRoZSBgZXNidWlsZGAgb3B0aW9ucy5cbiAgICovXG4gIGN1c3RvbWl6ZUVzYnVpbGRPcHRpb25zPyhvcHRpb25zOiBCdWlsZE9wdGlvbnMpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBBIGJ1aWxkIG1vZGUsIGVpdGhlciBgRGV2ZWxvcG1lbnRgIG9yIGBQcm9kdWN0aW9uYFxuICAgKi9cbiAgbW9kZTogQnVpbGRNb2RlO1xuXG4gIC8qKlxuICAgKiBBIGZvbGRlciBmb3IgT2JzaWRpYW4gY29uZmlndXJhdGlvbi4gRGVmYXVsdHMgdG8gdGhlIGBPQlNJRElBTl9DT05GSUdfRk9MREVSYCBlbnZpcm9ubWVudCB2YXJpYWJsZS5cbiAgICovXG4gIG9ic2lkaWFuQ29uZmlnRm9sZGVyPzogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgT2JzaWRpYW5QbHVnaW5CdWlsZGVyRW52IHtcbiAgT0JTSURJQU5fQ09ORklHX0ZPTERFUjogc3RyaW5nO1xufVxuXG4vKipcbiAqIEJ1aWxkcyB0aGUgT2JzaWRpYW4gcGx1Z2luIGJhc2VkIG9uIHRoZSBzcGVjaWZpZWQgbW9kZSBhbmQgY29uZmlndXJhdGlvbiBmb2xkZXIuXG4gKlxuICogQHBhcmFtIG9wdGlvbnMgLSBUaGUgcGFyYW1ldGVycyBmb3IgYnVpbGRpbmcgdGhlIHBsdWdpbi5cbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgdG8gYSB7QGxpbmsgQ2xpVGFza1Jlc3VsdH0gaW5kaWNhdGluZyB0aGUgc3VjY2VzcyBvciBmYWlsdXJlIG9mIHRoZSBidWlsZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkT2JzaWRpYW5QbHVnaW4ob3B0aW9uczogQnVpbGRPYnNpZGlhblBsdWdpbk9wdGlvbnMpOiBQcm9taXNlPENsaVRhc2tSZXN1bHQ+IHtcbiAgYXdhaXQgYnVpbGRDb21waWxlKCk7XG4gIGNvbnN0IGVudlBhdGggPSByZXNvbHZlUGF0aEZyb21Sb290KCcuZW52Jyk7XG4gIGlmIChlbnZQYXRoICYmIGV4aXN0c1N5bmMoZW52UGF0aCkpIHtcbiAgICBsb2FkRW52RmlsZShlbnZQYXRoKTtcbiAgfVxuICBjb25zdCBvYnNpZGlhblBsdWdpbkJ1aWxkZXJFbnYgPSBwcm9jZXNzLmVudiBhcyBQYXJ0aWFsPE9ic2lkaWFuUGx1Z2luQnVpbGRlckVudj47XG5cbiAgY29uc3Qgb2JzaWRpYW5Db25maWdGb2xkZXIgPSBvcHRpb25zLm9ic2lkaWFuQ29uZmlnRm9sZGVyID8/IG9ic2lkaWFuUGx1Z2luQnVpbGRlckVudi5PQlNJRElBTl9DT05GSUdfRk9MREVSID8/ICcnO1xuICBjb25zdCBpc1Byb2R1Y3Rpb25CdWlsZCA9IG9wdGlvbnMubW9kZSA9PT0gQnVpbGRNb2RlLlByb2R1Y3Rpb247XG5cbiAgY29uc3QgZGlzdEZvbGRlciA9IHJlc29sdmVQYXRoRnJvbVJvb3QoaXNQcm9kdWN0aW9uQnVpbGQgPyBPYnNpZGlhblBsdWdpblJlcG9QYXRocy5EaXN0QnVpbGQgOiBPYnNpZGlhblBsdWdpblJlcG9QYXRocy5EaXN0RGV2KTtcbiAgaWYgKCFkaXN0Rm9sZGVyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdDb3VsZCBub3QgZGV0ZXJtaW5lIHRoZSBkaXN0IGZvbGRlcicpO1xuICB9XG5cbiAgaWYgKGV4aXN0c1N5bmMoZGlzdEZvbGRlcikpIHtcbiAgICBhd2FpdCBybShkaXN0Rm9sZGVyLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbiAgfVxuICBhd2FpdCBta2RpcihkaXN0Rm9sZGVyLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcblxuICBjb25zdCBkaXN0RmlsZU5hbWVzID0gW1xuICAgIE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzLk1hbmlmZXN0SnNvblxuICBdO1xuICBpZiAoIWlzUHJvZHVjdGlvbkJ1aWxkKSB7XG4gICAgYXdhaXQgd3JpdGVGaWxlKGpvaW4oZGlzdEZvbGRlciwgT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMuSG90UmVsb2FkKSwgJycsICd1dGYtOCcpO1xuICB9XG5cbiAgZm9yIChjb25zdCBmaWxlTmFtZSBvZiBkaXN0RmlsZU5hbWVzKSB7XG4gICAgY29uc3QgbG9jYWxGaWxlID0gcmVzb2x2ZVBhdGhGcm9tUm9vdChmaWxlTmFtZSk7XG4gICAgaWYgKCFsb2NhbEZpbGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgQ291bGQgbm90IGRldGVybWluZSB0aGUgbG9jYWwgZmlsZSBmb3IgJHtmaWxlTmFtZX1gKTtcbiAgICB9XG4gICAgY29uc3QgZGlzdEZpbGUgPSBqb2luKGRpc3RGb2xkZXIsIGZpbGVOYW1lKTtcblxuICAgIGlmIChleGlzdHNTeW5jKGxvY2FsRmlsZSkpIHtcbiAgICAgIGF3YWl0IGNwKGxvY2FsRmlsZSwgZGlzdEZpbGUpO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGRpc3RQYXRoID0gam9pbihkaXN0Rm9sZGVyLCBPYnNpZGlhblBsdWdpblJlcG9QYXRocy5NYWluSnMpO1xuICBjb25zdCBjc3NQYXRoID0gam9pbihkaXN0Rm9sZGVyLCBPYnNpZGlhblBsdWdpblJlcG9QYXRocy5TdHlsZXNDc3MpO1xuXG4gIGNvbnN0IHBhY2thZ2VKc29uID0gYXdhaXQgcmVhZFBhY2thZ2VKc29uKCk7XG4gIGNvbnN0IHBsdWdpbk5hbWUgPSBwYWNrYWdlSnNvbi5uYW1lID8/ICcodW5rbm93biknO1xuXG4gIGNvbnN0IGJ1aWxkT3B0aW9uczogQnVpbGRPcHRpb25zID0ge1xuICAgIGJhbm5lcjoge1xuICAgICAganM6IGJhbm5lclxuICAgIH0sXG4gICAgYnVuZGxlOiB0cnVlLFxuICAgIGNvbmRpdGlvbnM6IFsnYnJvd3NlciddLFxuICAgIGVudHJ5UG9pbnRzOiBbXG4gICAgICByZXNvbHZlUGF0aEZyb21Sb290KGpvaW4oT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMuU3JjLCBPYnNpZGlhblBsdWdpblJlcG9QYXRocy5NYWluVHMpKVxuICAgICAgICA/PyB0aHJvd0V4cHJlc3Npb24obmV3IEVycm9yKCdDb3VsZCBub3QgZGV0ZXJtaW5lIHRoZSBlbnRyeSBwb2ludCBmb3IgdGhlIHBsdWdpbicpKVxuICAgIF0sXG4gICAgZXh0ZXJuYWw6IFtcbiAgICAgICdvYnNpZGlhbicsXG4gICAgICAnZWxlY3Ryb24nLFxuICAgICAgJ0Bjb2RlbWlycm9yL2F1dG9jb21wbGV0ZScsXG4gICAgICAnQGNvZGVtaXJyb3IvY29sbGFiJyxcbiAgICAgICdAY29kZW1pcnJvci9jb21tYW5kcycsXG4gICAgICAnQGNvZGVtaXJyb3IvbGFuZ3VhZ2UnLFxuICAgICAgJ0Bjb2RlbWlycm9yL2xpbnQnLFxuICAgICAgJ0Bjb2RlbWlycm9yL3NlYXJjaCcsXG4gICAgICAnQGNvZGVtaXJyb3Ivc3RhdGUnLFxuICAgICAgJ0Bjb2RlbWlycm9yL3ZpZXcnLFxuICAgICAgJ0BsZXplci9jb21tb24nLFxuICAgICAgJ0BsZXplci9oaWdobGlnaHQnLFxuICAgICAgJ0BsZXplci9scicsXG4gICAgICAnZXNidWlsZCcsXG4gICAgICAnZXNsaW50JyxcbiAgICAgIC4uLmJ1aWx0aW5Nb2R1bGVzXG4gICAgXSxcbiAgICBmb3JtYXQ6ICdjanMnLFxuICAgIGtlZXBOYW1lczogdHJ1ZSxcbiAgICBsb2dMZXZlbDogJ2luZm8nLFxuICAgIG1pbmlmeTogaXNQcm9kdWN0aW9uQnVpbGQsXG4gICAgb3V0ZmlsZTogZGlzdFBhdGgsXG4gICAgcGxhdGZvcm06ICdub2RlJyxcbiAgICBwbHVnaW5zOiBbXG4gICAgICBjdXN0b21Fc2J1aWxkT3B0aW9uc1BsdWdpbihvcHRpb25zLmN1c3RvbWl6ZUVzYnVpbGRPcHRpb25zPy5iaW5kKG9wdGlvbnMpKSxcbiAgICAgIHN2ZWx0ZVdyYXBwZXJQbHVnaW4oaXNQcm9kdWN0aW9uQnVpbGQpLFxuICAgICAgc2Fzc1BsdWdpbih7XG4gICAgICAgIHNvdXJjZU1hcDogIWlzUHJvZHVjdGlvbkJ1aWxkXG4gICAgICB9KSxcbiAgICAgIHJlbmFtZUNzc1BsdWdpbihkaXN0Rm9sZGVyKSxcbiAgICAgIHByZXByb2Nlc3NQbHVnaW4oKSxcbiAgICAgIGZpeEVzbVBsdWdpbigpLFxuICAgICAgZml4U291cmNlTWFwc1BsdWdpbihpc1Byb2R1Y3Rpb25CdWlsZCwgW2Rpc3RQYXRoLCBjc3NQYXRoXSwgcGx1Z2luTmFtZSksXG4gICAgICAuLi5vcHRpb25zLmN1c3RvbUVzYnVpbGRQbHVnaW5zID8/IFtdLFxuICAgICAgY29weVRvT2JzaWRpYW5QbHVnaW5zRm9sZGVyUGx1Z2luKGlzUHJvZHVjdGlvbkJ1aWxkLCBkaXN0Rm9sZGVyLCBvYnNpZGlhbkNvbmZpZ0ZvbGRlciwgcGx1Z2luTmFtZSlcbiAgICBdLFxuICAgIHNvdXJjZW1hcDogaXNQcm9kdWN0aW9uQnVpbGQgPyBmYWxzZSA6ICdpbmxpbmUnLFxuICAgIHRhcmdldDogJ2VzbmV4dCcsXG4gICAgdHJlZVNoYWtpbmc6IHRydWVcbiAgfTtcblxuICBjb25zdCBidWlsZENvbnRleHQgPSBhd2FpdCBjb250ZXh0KGJ1aWxkT3B0aW9ucyk7XG4gIHJldHVybiBhd2FpdCBpbnZva2VFc2J1aWxkKGJ1aWxkQ29udGV4dCwgaXNQcm9kdWN0aW9uQnVpbGQpO1xufVxuXG4vKipcbiAqIEludm9rZXMgdGhlIGJ1aWxkIHByb2Nlc3Mgd2l0aCB0aGUgcHJvdmlkZWQgYnVpbGQgY29udGV4dC5cbiAqXG4gKiBAcGFyYW0gYnVpbGRDb250ZXh0IC0gVGhlIGJ1aWxkIGNvbnRleHQgZ2VuZXJhdGVkIGJ5IGVzYnVpbGQuXG4gKiBAcGFyYW0gaXNQcm9kdWN0aW9uQnVpbGQgLSBBIGJvb2xlYW4gaW5kaWNhdGluZyB3aGV0aGVyIHRoZSBidWlsZCBpcyBhIHByb2R1Y3Rpb24gYnVpbGQuXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHRvIGEge0BsaW5rIENsaVRhc2tSZXN1bHR9IGluZGljYXRpbmcgdGhlIHN1Y2Nlc3Mgb3IgZmFpbHVyZSBvZiB0aGUgYnVpbGQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBpbnZva2VFc2J1aWxkKGJ1aWxkQ29udGV4dDogQnVpbGRDb250ZXh0LCBpc1Byb2R1Y3Rpb25CdWlsZDogYm9vbGVhbik6IFByb21pc2U8Q2xpVGFza1Jlc3VsdD4ge1xuICBpZiAoaXNQcm9kdWN0aW9uQnVpbGQpIHtcbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBidWlsZENvbnRleHQucmVidWlsZCgpO1xuICAgIGNvbnN0IGlzU3VjY2VzcyA9IHJlc3VsdC5lcnJvcnMubGVuZ3RoID09PSAwICYmIHJlc3VsdC53YXJuaW5ncy5sZW5ndGggPT09IDA7XG4gICAgcmV0dXJuIENsaVRhc2tSZXN1bHQuU3VjY2Vzcyhpc1N1Y2Nlc3MpO1xuICB9XG4gIGF3YWl0IGJ1aWxkQ29udGV4dC53YXRjaCgpO1xuICByZXR1cm4gQ2xpVGFza1Jlc3VsdC5Eb05vdEV4aXQoKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQWNBLHFCQUF3QjtBQUV4QixpQ0FBd0I7QUFFeEIsbUJBQWdDO0FBQ2hDLHlCQUE0QztBQUM1QyxxQ0FBd0M7QUFDeEMsa0JBQXFCO0FBQ3JCLG1CQUE2QjtBQUM3QixzQkFBOEI7QUFDOUIseUJBU087QUFDUCxpQkFBZ0M7QUFDaEMsa0JBQW9DO0FBQ3BDLCtDQUFrRDtBQUNsRCx3Q0FBMkM7QUFDM0MsMEJBQTZCO0FBQzdCLGlDQUFvQztBQUNwQyw4QkFBaUM7QUFDakMsNkJBQWdDO0FBQ2hDLGlDQUFvQztBQUVwQyxNQUFNLGlCQUFhLGdEQUE0QiwyQkFBQUEsT0FBVztBQUtuRCxJQUFLLFlBQUwsa0JBQUtDLGVBQUw7QUFFTCxFQUFBQSxzQkFBQTtBQUVBLEVBQUFBLHNCQUFBO0FBSlUsU0FBQUE7QUFBQSxHQUFBO0FBVUwsTUFBTSxTQUFTO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUF5Q3RCLGVBQXNCLG9CQUFvQixTQUE2RDtBQUNyRyxZQUFNLDJCQUFhO0FBQ25CLFFBQU0sY0FBVSxpQ0FBb0IsTUFBTTtBQUMxQyxNQUFJLGVBQVcsK0JBQVcsT0FBTyxHQUFHO0FBQ2xDLHdDQUFZLE9BQU87QUFBQSxFQUNyQjtBQUNBLFFBQU0sMkJBQTJCLDJCQUFRO0FBRXpDLFFBQU0sdUJBQXVCLFFBQVEsd0JBQXdCLHlCQUF5QiwwQkFBMEI7QUFDaEgsUUFBTSxvQkFBb0IsUUFBUSxTQUFTO0FBRTNDLFFBQU0saUJBQWEsaUNBQW9CLG9CQUFvQix1REFBd0IsWUFBWSx1REFBd0IsT0FBTztBQUM5SCxNQUFJLENBQUMsWUFBWTtBQUNmLFVBQU0sSUFBSSxNQUFNLHFDQUFxQztBQUFBLEVBQ3ZEO0FBRUEsVUFBSSwrQkFBVyxVQUFVLEdBQUc7QUFDMUIsY0FBTSx1QkFBRyxZQUFZLEVBQUUsV0FBVyxLQUFLLENBQUM7QUFBQSxFQUMxQztBQUNBLFlBQU0sMEJBQU0sWUFBWSxFQUFFLFdBQVcsS0FBSyxDQUFDO0FBRTNDLFFBQU0sZ0JBQWdCO0FBQUEsSUFDcEIsdURBQXdCO0FBQUEsRUFDMUI7QUFDQSxNQUFJLENBQUMsbUJBQW1CO0FBQ3RCLGNBQU0sa0NBQVUsa0JBQUssWUFBWSx1REFBd0IsU0FBUyxHQUFHLElBQUksT0FBTztBQUFBLEVBQ2xGO0FBRUEsYUFBVyxZQUFZLGVBQWU7QUFDcEMsVUFBTSxnQkFBWSxpQ0FBb0IsUUFBUTtBQUM5QyxRQUFJLENBQUMsV0FBVztBQUNkLFlBQU0sSUFBSSxNQUFNLDBDQUEwQyxRQUFRLEVBQUU7QUFBQSxJQUN0RTtBQUNBLFVBQU0sZUFBVyxrQkFBSyxZQUFZLFFBQVE7QUFFMUMsWUFBSSwrQkFBVyxTQUFTLEdBQUc7QUFDekIsZ0JBQU0sdUJBQUcsV0FBVyxRQUFRO0FBQUEsSUFDOUI7QUFBQSxFQUNGO0FBRUEsUUFBTSxlQUFXLGtCQUFLLFlBQVksdURBQXdCLE1BQU07QUFDaEUsUUFBTSxjQUFVLGtCQUFLLFlBQVksdURBQXdCLFNBQVM7QUFFbEUsUUFBTSxjQUFjLFVBQU0sNEJBQWdCO0FBQzFDLFFBQU0sYUFBYSxZQUFZLFFBQVE7QUFFdkMsUUFBTSxlQUE2QjtBQUFBLElBQ2pDLFFBQVE7QUFBQSxNQUNOLElBQUk7QUFBQSxJQUNOO0FBQUEsSUFDQSxRQUFRO0FBQUEsSUFDUixZQUFZLENBQUMsU0FBUztBQUFBLElBQ3RCLGFBQWE7QUFBQSxVQUNYLHFDQUFvQixrQkFBSyx1REFBd0IsS0FBSyx1REFBd0IsTUFBTSxDQUFDLFNBQ2hGLDhCQUFnQixJQUFJLE1BQU0sb0RBQW9ELENBQUM7QUFBQSxJQUN0RjtBQUFBLElBQ0EsVUFBVTtBQUFBLE1BQ1I7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLE1BQ0E7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLE1BQ0E7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLE1BQ0E7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLE1BQ0E7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLE1BQ0EsR0FBRztBQUFBLElBQ0w7QUFBQSxJQUNBLFFBQVE7QUFBQSxJQUNSLFdBQVc7QUFBQSxJQUNYLFVBQVU7QUFBQSxJQUNWLFFBQVE7QUFBQSxJQUNSLFNBQVM7QUFBQSxJQUNULFVBQVU7QUFBQSxJQUNWLFNBQVM7QUFBQSxVQUNQLDhEQUEyQixRQUFRLHlCQUF5QixLQUFLLE9BQU8sQ0FBQztBQUFBLFVBQ3pFLGdEQUFvQixpQkFBaUI7QUFBQSxNQUNyQyxXQUFXO0FBQUEsUUFDVCxXQUFXLENBQUM7QUFBQSxNQUNkLENBQUM7QUFBQSxVQUNELHdDQUFnQixVQUFVO0FBQUEsVUFDMUIsMENBQWlCO0FBQUEsVUFDakIsa0NBQWE7QUFBQSxVQUNiLGdEQUFvQixtQkFBbUIsQ0FBQyxVQUFVLE9BQU8sR0FBRyxVQUFVO0FBQUEsTUFDdEUsR0FBRyxRQUFRLHdCQUF3QixDQUFDO0FBQUEsVUFDcEMsNEVBQWtDLG1CQUFtQixZQUFZLHNCQUFzQixVQUFVO0FBQUEsSUFDbkc7QUFBQSxJQUNBLFdBQVcsb0JBQW9CLFFBQVE7QUFBQSxJQUN2QyxRQUFRO0FBQUEsSUFDUixhQUFhO0FBQUEsRUFDZjtBQUVBLFFBQU0sZUFBZSxVQUFNLHdCQUFRLFlBQVk7QUFDL0MsU0FBTyxNQUFNLGNBQWMsY0FBYyxpQkFBaUI7QUFDNUQ7QUFTQSxlQUFzQixjQUFjLGNBQTRCLG1CQUFvRDtBQUNsSCxNQUFJLG1CQUFtQjtBQUNyQixVQUFNLFNBQVMsTUFBTSxhQUFhLFFBQVE7QUFDMUMsVUFBTSxZQUFZLE9BQU8sT0FBTyxXQUFXLEtBQUssT0FBTyxTQUFTLFdBQVc7QUFDM0UsV0FBTyw4QkFBYyxRQUFRLFNBQVM7QUFBQSxFQUN4QztBQUNBLFFBQU0sYUFBYSxNQUFNO0FBQ3pCLFNBQU8sOEJBQWMsVUFBVTtBQUNqQzsiLAogICJuYW1lcyI6IFsic2Fzc1BsdWdpbl8iLCAiQnVpbGRNb2RlIl0KfQo=