@datagrok/sequence-translator 0.0.8 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,2444 @@
1
+ var sequencetranslator_test;
2
+ /******/ (() => { // webpackBootstrap
3
+ /******/ "use strict";
4
+ /******/ var __webpack_modules__ = ({
5
+
6
+ /***/ "./node_modules/@datagrok-libraries/utils/src/test.js":
7
+ /*!************************************************************!*\
8
+ !*** ./node_modules/@datagrok-libraries/utils/src/test.js ***!
9
+ \************************************************************/
10
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
11
+
12
+ __webpack_require__.r(__webpack_exports__);
13
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
14
+ /* harmony export */ "tests": () => (/* binding */ tests),
15
+ /* harmony export */ "currentCategory": () => (/* binding */ currentCategory),
16
+ /* harmony export */ "assure": () => (/* binding */ assure),
17
+ /* harmony export */ "Test": () => (/* binding */ Test),
18
+ /* harmony export */ "test": () => (/* binding */ test),
19
+ /* harmony export */ "assertNoError": () => (/* binding */ assertNoError),
20
+ /* harmony export */ "expect": () => (/* binding */ expect),
21
+ /* harmony export */ "expectFloat": () => (/* binding */ expectFloat),
22
+ /* harmony export */ "category": () => (/* binding */ category),
23
+ /* harmony export */ "before": () => (/* binding */ before),
24
+ /* harmony export */ "after": () => (/* binding */ after),
25
+ /* harmony export */ "runTests": () => (/* binding */ runTests),
26
+ /* harmony export */ "delay": () => (/* binding */ delay)
27
+ /* harmony export */ });
28
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
29
+ /* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
30
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
31
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
32
+ return new (P || (P = Promise))(function (resolve, reject) {
33
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
34
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
35
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
36
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
37
+ });
38
+ };
39
+
40
+ let tests = {};
41
+ let currentCategory;
42
+ var assure;
43
+ (function (assure) {
44
+ function notNull(value, name) {
45
+ if (value == null)
46
+ throw `${name == null ? 'Value' : name} not defined`;
47
+ }
48
+ assure.notNull = notNull;
49
+ })(assure || (assure = {}));
50
+ class Test {
51
+ constructor(category, name, test, options) {
52
+ var _a, _b;
53
+ this.category = category;
54
+ this.name = name;
55
+ options !== null && options !== void 0 ? options : (options = {});
56
+ (_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);
57
+ (_b = options.unhandledExceptionTimeout) !== null && _b !== void 0 ? _b : (options.unhandledExceptionTimeout = 2000);
58
+ this.options = options;
59
+ this.test = () => __awaiter(this, void 0, void 0, function* () {
60
+ return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
61
+ let result = '';
62
+ try {
63
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError = '';
64
+ result = yield test();
65
+ }
66
+ catch (e) {
67
+ reject(e);
68
+ }
69
+ if (!(yield assertNoError(options.unhandledExceptionTimeout)))
70
+ reject(`Unhandled exception during test: ${datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError}`);
71
+ resolve(result);
72
+ }));
73
+ });
74
+ }
75
+ }
76
+ function test(name, test, options) {
77
+ if (tests[currentCategory] == undefined)
78
+ tests[currentCategory] = {};
79
+ if (tests[currentCategory].tests == undefined)
80
+ tests[currentCategory].tests = [];
81
+ tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));
82
+ }
83
+ /** Awaits for a while checking the error status of the platform */
84
+ function assertNoError(ms) {
85
+ return __awaiter(this, void 0, void 0, function* () {
86
+ for (let i = 0; i < ms / 500; ++i) {
87
+ yield delay(500);
88
+ if (datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError.length !== 0)
89
+ return false;
90
+ }
91
+ return true;
92
+ });
93
+ }
94
+ /** Tests two objects for equality, throws an exception if they are not equal. */
95
+ function expect(actual, expected) {
96
+ if (actual !== expected)
97
+ throw `Expected "${expected}", got "${actual}"`;
98
+ }
99
+ function expectFloat(actual, expected, tolerance = 0.001) {
100
+ const areEqual = Math.abs(actual - expected) < 0.001;
101
+ if (!areEqual)
102
+ throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;
103
+ }
104
+ /** Defines a test suite. */
105
+ function category(category, tests) {
106
+ currentCategory = category;
107
+ tests();
108
+ }
109
+ /** Defines a function to be executed before the tests in this category are executed. */
110
+ function before(before) {
111
+ if (tests[currentCategory] == undefined)
112
+ tests[currentCategory] = {};
113
+ tests[currentCategory].before = before;
114
+ }
115
+ /** Defines a function to be executed after the tests in this category are executed. */
116
+ function after(after) {
117
+ if (tests[currentCategory] == undefined)
118
+ tests[currentCategory] = {};
119
+ tests[currentCategory].after = after;
120
+ }
121
+ function runTests(options) {
122
+ var _a;
123
+ return __awaiter(this, void 0, void 0, function* () {
124
+ let results = [];
125
+ for (const [key, value] of Object.entries(tests)) {
126
+ if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {
127
+ if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))
128
+ continue;
129
+ }
130
+ try {
131
+ if (value.before)
132
+ yield value.before();
133
+ }
134
+ catch (x) {
135
+ value.beforeStatus = x.toString();
136
+ }
137
+ let t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];
138
+ let res = [];
139
+ for (let i = 0; i < t.length; i++) {
140
+ res.push(yield execTest(t[i], options === null || options === void 0 ? void 0 : options.test));
141
+ }
142
+ let data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');
143
+ try {
144
+ if (value.after)
145
+ yield value.after();
146
+ }
147
+ catch (x) {
148
+ value.afterStatus = x.toString();
149
+ }
150
+ if (value.afterStatus)
151
+ data.push({ category: key, name: 'init', result: value.afterStatus, success: false });
152
+ if (value.beforeStatus)
153
+ data.push({ category: key, name: 'init', result: value.beforeStatus, success: false });
154
+ results.push(...data);
155
+ }
156
+ return results;
157
+ });
158
+ }
159
+ function execTest(t, predicate) {
160
+ var _a;
161
+ return __awaiter(this, void 0, void 0, function* () {
162
+ let r;
163
+ try {
164
+ if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))
165
+ r = { success: true, result: 'skipped' };
166
+ else
167
+ r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK' };
168
+ }
169
+ catch (x) {
170
+ r = { success: false, result: x.toString() };
171
+ }
172
+ r.category = t.category;
173
+ r.name = t.name;
174
+ return r;
175
+ });
176
+ }
177
+ function delay(ms) {
178
+ return __awaiter(this, void 0, void 0, function* () {
179
+ yield new Promise(r => setTimeout(r, ms));
180
+ });
181
+ }
182
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsT0FBTyxLQUFLLElBQUksTUFBTSxtQkFBbUIsQ0FBQztBQUUxQyxNQUFNLENBQUMsSUFBSSxLQUFLLEdBQThJLEVBQUUsQ0FBQztBQUVqSyxNQUFNLENBQUMsSUFBSSxlQUF1QixDQUFDO0FBRW5DLE1BQU0sS0FBVyxNQUFNLENBTXRCO0FBTkQsV0FBaUIsTUFBTTtJQUVyQixTQUFnQixPQUFPLENBQUMsS0FBVSxFQUFFLElBQWE7UUFDL0MsSUFBSSxLQUFLLElBQUksSUFBSTtZQUNmLE1BQU0sR0FBRyxJQUFJLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksY0FBYyxDQUFDO0lBQ3pELENBQUM7SUFIZSxjQUFPLFVBR3RCLENBQUE7QUFDSCxDQUFDLEVBTmdCLE1BQU0sS0FBTixNQUFNLFFBTXRCO0FBT0QsTUFBTSxPQUFPLElBQUk7SUFNZixZQUFZLFFBQWdCLEVBQUUsSUFBWSxFQUFFLElBQXdCLEVBQUUsT0FBcUI7O1FBQ3pGLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLE9BQU8sYUFBUCxPQUFPLGNBQVAsT0FBTyxJQUFQLE9BQU8sR0FBSyxFQUFFLEVBQUM7UUFDZixNQUFBLE9BQU8sQ0FBQyxPQUFPLG9DQUFmLE9BQU8sQ0FBQyxPQUFPLEdBQUssS0FBSyxFQUFDO1FBQzFCLE1BQUEsT0FBTyxDQUFDLHlCQUF5QixvQ0FBakMsT0FBTyxDQUFDLHlCQUF5QixHQUFLLElBQUksRUFBQztRQUMzQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsSUFBSSxHQUFHLEdBQXVCLEVBQUU7WUFDbkMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFPLE9BQU8s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QUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUMsQ0FBQzs7Z0JBRXZDLENBQUMsR0FBRyxFQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE1BQUEsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLG1DQUFJLElBQUksRUFBQyxDQUFDO1NBQ3ZEO1FBQUMsT0FBTyxDQUFNLEVBQUU7WUFDZixDQUFDLEdBQUcsRUFBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUMsQ0FBQztTQUM1QztRQUNELENBQUMsQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQztRQUN4QixDQUFDLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFDaEIsT0FBTyxDQUFDLENBQUM7O0NBQ1Y7QUFFRCxNQUFNLFVBQWdCLEtBQUssQ0FBQyxFQUFVOztRQUNwQyxNQUFPLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzdDLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGdyb2sgZnJvbSBcImRhdGFncm9rLWFwaS9ncm9rXCI7XG5cbmV4cG9ydCBsZXQgdGVzdHM6IHtba2V5OiBzdHJpbmddOiB7dGVzdHM/OiBUZXN0W10sIGJlZm9yZT86ICgpID0+IFByb21pc2U8dm9pZD4sIGFmdGVyPzogKCkgPT4gUHJvbWlzZTx2b2lkPiwgYmVmb3JlU3RhdHVzPzogc3RyaW5nLCBhZnRlclN0YXR1cz86IHN0cmluZ319ID0ge307XG5cbmV4cG9ydCBsZXQgY3VycmVudENhdGVnb3J5OiBzdHJpbmc7XG5cbmV4cG9ydCBuYW1lc3BhY2UgYXNzdXJlIHtcblxuICBleHBvcnQgZnVuY3Rpb24gbm90TnVsbCh2YWx1ZTogYW55LCBuYW1lPzogc3RyaW5nKSB7XG4gICAgaWYgKHZhbHVlID09IG51bGwpXG4gICAgICB0aHJvdyBgJHtuYW1lID09IG51bGwgPyAnVmFsdWUnIDogbmFtZX0gbm90IGRlZmluZWRgO1xuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGVzdE9wdGlvbnMge1xuICB0aW1lb3V0PyA6IG51bWJlcjtcbiAgdW5oYW5kbGVkRXhjZXB0aW9uVGltZW91dD8gOiBudW1iZXI7XG59XG5cbmV4cG9ydCBjbGFzcyBUZXN0IHtcbiAgdGVzdDogKCkgPT4gUHJvbWlzZTxhbnk+O1xuICBuYW1lOiBzdHJpbmc7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIG9wdGlvbnM/OiBUZXN0T3B0aW9ucztcblxuICBjb25zdHJ1Y3RvcihjYXRlZ29yeTogc3RyaW5nLCBuYW1lOiBzdHJpbmcsIHRlc3Q6ICgpID0+IFByb21pc2U8YW55Piwgb3B0aW9ucz86IFRlc3RPcHRpb25zKSB7XG4gICAgdGhpcy5jYXRlZ29yeSA9IGNhdGVnb3J5O1xuICAgIHRoaXMubmFtZSA9IG5hbWU7XG4gICAgb3B0aW9ucyA/Pz0ge307XG4gICAgb3B0aW9ucy50aW1lb3V0ID8/PSAzMDAwMDtcbiAgICBvcHRpb25zLnVuaGFuZGxlZEV4Y2VwdGlvblRpbWVvdXQgPz89IDIwMDA7XG4gICAgdGhpcy5vcHRpb25zID0gb3B0aW9ucztcbiAgICB0aGlzLnRlc3QgPSBhc3luYyAoKTogUHJvbWlzZTxhbnk+ID0+IHtcbiAgICAgIHJldHVybiBuZXcgUHJvbWlzZShhc3luYyAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICAgIGxldCByZXN1bHQgPSAnJztcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBncm9rLnNoZWxsLmxhc3RFcnJvciA9ICcnO1xuICAgICAgICAgIHJlc3VsdCA9IGF3YWl0IHRlc3QoKTtcbiAgICAgICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICAgICAgcmVqZWN0KGUpO1xuICAgICAgICB9XG4gICAgICAgIGlmICghKGF3YWl0IGFzc2VydE5vRXJyb3Iob3B0aW9ucyEudW5oYW5kbGVkRXhjZXB0aW9uVGltZW91dCEpKSlcbiAgICAgICAgICByZWplY3QoYFVuaGFuZGxlZCBleGNlcHRpb24gZHVyaW5nIHRlc3Q6ICR7Z3Jvay5zaGVsbC5sYXN0RXJyb3J9YCk7XG4gICAgICAgIHJlc29sdmUocmVzdWx0KTtcbiAgICAgIH0pO1xuICAgIH07XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRlc3QobmFtZTogc3RyaW5nLCB0ZXN0OiAoKSA9PiBQcm9taXNlPGFueT4sIG9wdGlvbnM/OiBUZXN0T3B0aW9ucyk6IHZvaWQge1xuICBpZiAodGVzdHNbY3VycmVudENhdGVnb3J5XSA9PSB1bmRlZmluZWQpXG4gICAgdGVzdHNbY3VycmVudENhdGVnb3J5XSA9IHt9O1xuICBpZiAodGVzdHNbY3VycmVudENhdGVnb3J5XS50ZXN0cyA9PSB1bmRlZmluZWQpXG4gICAgdGVzdHNbY3VycmVudENhdGVnb3J5XS50ZXN0cyA9IFtdO1xuICB0ZXN0c1tjdXJyZW50Q2F0ZWdvcnldLnRlc3RzIS5wdXNoKG5ldyBUZXN0KGN1cnJlbnRDYXRlZ29yeSwgbmFtZSwgdGVzdCwgb3B0aW9ucykpO1xufVxuXG4vKiogQXdhaXRzIGZvciBhIHdoaWxlIGNoZWNraW5nIHRoZSBlcnJvciBzdGF0dXMgb2YgdGhlIHBsYXRmb3JtICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYXNzZXJ0Tm9FcnJvcihtczogbnVtYmVyKTogUHJvbWlzZTxib29sZWFuPiB7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgbXMgLyA1MDA7ICsraSkge1xuICAgIGF3YWl0IGRlbGF5KDUwMCk7XG4gICAgaWYgKGdyb2suc2hlbGwubGFzdEVycm9yLmxlbmd0aCAhPT0gMClcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuLyoqIFRlc3RzIHR3byBvYmplY3RzIGZvciBlcXVhbGl0eSwgdGhyb3dzIGFuIGV4Y2VwdGlvbiBpZiB0aGV5IGFyZSBub3QgZXF1YWwuICovXG5leHBvcnQgZnVuY3Rpb24gZXhwZWN0KGFjdHVhbDogYW55LCBleHBlY3RlZDogYW55KTogdm9pZCB7XG4gIGlmIChhY3R1YWwgIT09IGV4cGVjdGVkKVxuICAgIHRocm93IGBFeHBlY3RlZCBcIiR7ZXhwZWN0ZWR9XCIsIGdvdCBcIiR7YWN0dWFsfVwiYDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGV4cGVjdEZsb2F0KGFjdHVhbDogbnVtYmVyLCBleHBlY3RlZDogbnVtYmVyLCB0b2xlcmFuY2UgPSAwLjAwMSk6IHZvaWQge1xuICBjb25zdCBhcmVFcXVhbCA9IE1hdGguYWJzKGFjdHVhbCAtIGV4cGVjdGVkKSA8IDAuMDAxO1xuICBpZiAoIWFyZUVxdWFsKVxuICAgIHRocm93IGBFeHBlY3RlZCAke2V4cGVjdGVkfSwgZ290ICR7YWN0dWFsfSAodG9sZXJhbmNlID0gJHt0b2xlcmFuY2V9KWA7XG59XG5cbi8qKiBEZWZpbmVzIGEgdGVzdCBzdWl0ZS4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjYXRlZ29yeShjYXRlZ29yeTogc3RyaW5nLCB0ZXN0czogKCkgPT4gdm9pZCk6IHZvaWQge1xuICBjdXJyZW50Q2F0ZWdvcnkgPSBjYXRlZ29yeTtcbiAgdGVzdHMoKTtcbn1cblxuLyoqIERlZmluZXMgYSBmdW5jdGlvbiB0byBiZSBleGVjdXRlZCBiZWZvcmUgdGhlIHRlc3RzIGluIHRoaXMgY2F0ZWdvcnkgYXJlIGV4ZWN1dGVkLiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGJlZm9yZShiZWZvcmU6ICgpID0+IFByb21pc2U8dm9pZD4pOiB2b2lkIHtcbiAgaWYgKHRlc3RzW2N1cnJlbnRDYXRlZ29yeV0gPT0gdW5kZWZpbmVkKVxuICAgIHRlc3RzW2N1cnJlbnRDYXRlZ29yeV0gPSB7fTtcbiAgdGVzdHNbY3VycmVudENhdGVnb3J5XS5iZWZvcmUgPSBiZWZvcmU7XG59XG5cbi8qKiBEZWZpbmVzIGEgZnVuY3Rpb24gdG8gYmUgZXhlY3V0ZWQgYWZ0ZXIgdGhlIHRlc3RzIGluIHRoaXMgY2F0ZWdvcnkgYXJlIGV4ZWN1dGVkLiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGFmdGVyKGFmdGVyOiAoKSA9PiBQcm9taXNlPHZvaWQ+KTogdm9pZCB7XG4gIGlmICh0ZXN0c1tjdXJyZW50Q2F0ZWdvcnldID09IHVuZGVmaW5lZClcbiAgICB0ZXN0c1tjdXJyZW50Q2F0ZWdvcnldID0ge307XG4gIHRlc3RzW2N1cnJlbnRDYXRlZ29yeV0uYWZ0ZXIgPSBhZnRlcjtcbn1cblxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcnVuVGVzdHMob3B0aW9ucz86IHtjYXRlZ29yeT86IHN0cmluZywgdGVzdD86IHN0cmluZ30pIHtcbiAgbGV0IHJlc3VsdHM6IHsgY2F0ZWdvcnk/OiBzdHJpbmcsIG5hbWU/OiBzdHJpbmcsIHN1Y2Nlc3M6IGJvb2xlYW4sIHJlc3VsdDogc3RyaW5nfVtdID0gW107XG5cbiAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXModGVzdHMpKSB7XG4gICAgaWYgKG9wdGlvbnM/LmNhdGVnb3J5ICE9IHVuZGVmaW5lZCkge1xuICAgICAgaWYgKCFrZXkudG9Mb3dlckNhc2UoKS5zdGFydHNXaXRoKG9wdGlvbnM/LmNhdGVnb3J5LnRvTG93ZXJDYXNlKCkpKVxuICAgICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgdHJ5IHtcbiAgICAgIGlmICh2YWx1ZS5iZWZvcmUpXG4gICAgICAgIGF3YWl0IHZhbHVlLmJlZm9yZSgpO1xuICAgIH0gY2F0Y2ggKHg6IGFueSkge1xuICAgICAgdmFsdWUuYmVmb3JlU3RhdHVzID0geC50b1N0cmluZygpO1xuICAgIH1cbiAgICBsZXQgdCA9IHZhbHVlLnRlc3RzID8/IFtdO1xuICAgIGxldCByZXMgPSBbXTtcbiAgICBmb3IobGV0IGkgPSAwOyBpIDwgdC5sZW5ndGg7IGkrKykge1xuICAgICAgcmVzLnB1c2goYXdhaXQgZXhlY1Rlc3QodFtpXSwgb3B0aW9ucz8udGVzdCkpO1xuICAgIH1cblxuICAgIGxldCBkYXRhID0gKGF3YWl0IFByb21pc2UuYWxsKHJlcykpLmZpbHRlcigoZCkgPT4gZC5yZXN1bHQgIT0gJ3NraXBwZWQnKTtcbiAgICB0cnkge1xuICAgICAgaWYgKHZhbHVlLmFmdGVyKVxuICAgICAgICBhd2FpdCB2YWx1ZS5hZnRlcigpO1xuICAgIH0gY2F0Y2ggKHg6IGFueSkge1xuICAgICAgdmFsdWUuYWZ0ZXJTdGF0dXMgPSB4LnRvU3RyaW5nKCk7XG4gICAgfVxuICAgIGlmICh2YWx1ZS5hZnRlclN0YXR1cylcbiAgICAgIGRhdGEucHVzaCh7Y2F0ZWdvcnk6IGtleSwgbmFtZTogJ2luaXQnLCByZXN1bHQ6IHZhbHVlLmFmdGVyU3RhdHVzLCBzdWNjZXNzOiBmYWxzZX0pO1xuICAgIGlmICh2YWx1ZS5iZWZvcmVTdGF0dXMpXG4gICAgICBkYXRhLnB1c2goe2NhdGVnb3J5OiBrZXksIG5hbWU6ICdpbml0JywgcmVzdWx0OiB2YWx1ZS5iZWZvcmVTdGF0dXMsIHN1Y2Nlc3M6IGZhbHNlfSk7XG4gICAgcmVzdWx0cy5wdXNoKC4uLmRhdGEpO1xuICB9XG5cbiAgcmV0dXJuIHJlc3VsdHM7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIGV4ZWNUZXN0KHQ6IFRlc3QsIHByZWRpY2F0ZTogc3RyaW5nIHwgdW5kZWZpbmVkKSB7XG4gIGxldCByOiB7IGNhdGVnb3J5Pzogc3RyaW5nLCBuYW1lPzogc3RyaW5nLCBzdWNjZXNzOiBib29sZWFuLCByZXN1bHQ6IHN0cmluZyB9O1xuICB0cnkge1xuICAgIGlmIChwcmVkaWNhdGUgIT0gdW5kZWZpbmVkICYmICghdC5uYW1lLnRvTG93ZXJDYXNlKCkuc3RhcnRzV2l0aChwcmVkaWNhdGUudG9Mb3dlckNhc2UoKSkpKVxuICAgICAgciA9IHtzdWNjZXNzOiB0cnVlLCByZXN1bHQ6ICdza2lwcGVkJ307XG4gICAgZWxzZVxuICAgICAgciA9IHtzdWNjZXNzOiB0cnVlLCByZXN1bHQ6IGF3YWl0IHQudGVzdCgpID8/ICdPSyd9O1xuICB9IGNhdGNoICh4OiBhbnkpIHtcbiAgICByID0ge3N1Y2Nlc3M6IGZhbHNlLCByZXN1bHQ6IHgudG9TdHJpbmcoKX07XG4gIH1cbiAgci5jYXRlZ29yeSA9IHQuY2F0ZWdvcnk7XG4gIHIubmFtZSA9IHQubmFtZTtcbiAgcmV0dXJuIHI7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBkZWxheShtczogbnVtYmVyKSB7XG4gIGF3YWl0ICBuZXcgUHJvbWlzZShyID0+IHNldFRpbWVvdXQociwgbXMpKTtcbn1cbiJdfQ==
183
+
184
+ /***/ }),
185
+
186
+ /***/ "./src/structures-works/converters.ts":
187
+ /*!********************************************!*\
188
+ !*** ./src/structures-works/converters.ts ***!
189
+ \********************************************/
190
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
191
+
192
+ __webpack_require__.r(__webpack_exports__);
193
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
194
+ /* harmony export */ "asoGapmersNucleotidesToBioSpring": () => (/* binding */ asoGapmersNucleotidesToBioSpring),
195
+ /* harmony export */ "asoGapmersNucleotidesToGcrs": () => (/* binding */ asoGapmersNucleotidesToGcrs),
196
+ /* harmony export */ "asoGapmersBioSpringToNucleotides": () => (/* binding */ asoGapmersBioSpringToNucleotides),
197
+ /* harmony export */ "asoGapmersBioSpringToGcrs": () => (/* binding */ asoGapmersBioSpringToGcrs),
198
+ /* harmony export */ "asoGapmersGcrsToBioSpring": () => (/* binding */ asoGapmersGcrsToBioSpring),
199
+ /* harmony export */ "asoGapmersGcrsToNucleotides": () => (/* binding */ asoGapmersGcrsToNucleotides),
200
+ /* harmony export */ "siRnaBioSpringToNucleotides": () => (/* binding */ siRnaBioSpringToNucleotides),
201
+ /* harmony export */ "siRnaBioSpringToAxolabs": () => (/* binding */ siRnaBioSpringToAxolabs),
202
+ /* harmony export */ "siRnaBioSpringToGcrs": () => (/* binding */ siRnaBioSpringToGcrs),
203
+ /* harmony export */ "siRnaAxolabsToGcrs": () => (/* binding */ siRnaAxolabsToGcrs),
204
+ /* harmony export */ "siRnaAxolabsToBioSpring": () => (/* binding */ siRnaAxolabsToBioSpring),
205
+ /* harmony export */ "siRnaAxolabsToNucleotides": () => (/* binding */ siRnaAxolabsToNucleotides),
206
+ /* harmony export */ "siRnaGcrsToNucleotides": () => (/* binding */ siRnaGcrsToNucleotides),
207
+ /* harmony export */ "siRnaGcrsToBioSpring": () => (/* binding */ siRnaGcrsToBioSpring),
208
+ /* harmony export */ "siRnaGcrsToAxolabs": () => (/* binding */ siRnaGcrsToAxolabs),
209
+ /* harmony export */ "siRnaNucleotideToBioSpringSenseStrand": () => (/* binding */ siRnaNucleotideToBioSpringSenseStrand),
210
+ /* harmony export */ "siRnaNucleotidesToGcrs": () => (/* binding */ siRnaNucleotidesToGcrs),
211
+ /* harmony export */ "siRnaNucleotideToAxolabsSenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsSenseStrand),
212
+ /* harmony export */ "siRnaNucleotideToAxolabsAntisenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsAntisenseStrand),
213
+ /* harmony export */ "gcrsToNucleotides": () => (/* binding */ gcrsToNucleotides),
214
+ /* harmony export */ "gcrsToMermade12": () => (/* binding */ gcrsToMermade12)
215
+ /* harmony export */ });
216
+ //name: asoGapmersNucleotidesToBioSpring
217
+ //input: string nucleotides {semType: DNA nucleotides}
218
+ //output: string result {semType: BioSpring / Gapmers}
219
+ function asoGapmersNucleotidesToBioSpring(nucleotides) {
220
+ let count = -1;
221
+ const objForEdges = {
222
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'
223
+ };
224
+ const objForCenter = {
225
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'
226
+ };
227
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
228
+ count++;
229
+ return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];
230
+ }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
231
+ nucleotides.length : 2 * count + 1);
232
+ }
233
+ //name: asoGapmersNucleotidesToGcrs
234
+ //input: string nucleotides {semType: DNA nucleotides}
235
+ //output: string result {semType: GCRS / Gapmers}
236
+ function asoGapmersNucleotidesToGcrs(nucleotides) {
237
+ let count = -1;
238
+ const objForEdges = {
239
+ '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',
240
+ 'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'
241
+ };
242
+ const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
243
+ 'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };
244
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
245
+ count++;
246
+ if (count < 5)
247
+ return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];
248
+ if (count < 15)
249
+ return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];
250
+ return objForEdges[x];
251
+ }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
252
+ nucleotides.length : -3);
253
+ }
254
+ //name: asoGapmersBioSpringToNucleotides
255
+ //input: string nucleotides {semType: BioSpring / Gapmers}
256
+ //output: string result {semType: DNA nucleotides}
257
+ function asoGapmersBioSpringToNucleotides(nucleotides) {
258
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
259
+ '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };
260
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|\*|5|6|7|8|9)/g, function (x) { return obj[x]; });
261
+ }
262
+ //name: asoGapmersBioSpringToGcrs
263
+ //input: string nucleotides {semType: BioSpring / Gapmers}
264
+ //output: string result {semType: GCRS / Gapmers}
265
+ function asoGapmersBioSpringToGcrs(nucleotides) {
266
+ let count = -1;
267
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
268
+ '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',
269
+ 'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',
270
+ };
271
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|5\*|6\*|7\*|8\*|9\*|A\*|T\*|G\*|C\*|5|6|7|8)/g, function (x) {
272
+ count++;
273
+ return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];
274
+ });
275
+ }
276
+ //name: asoGapmersGcrsToBioSpring
277
+ //input: string nucleotides {semType: GCRS / Gapmers}
278
+ //output: string result {semType: BioSpring / Gapmers}
279
+ function asoGapmersGcrsToBioSpring(nucleotides) {
280
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
281
+ 'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',
282
+ };
283
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });
284
+ }
285
+ //name: asoGapmersGcrsToNucleotides
286
+ //input: string nucleotides {semType: GCRS / Gapmers}
287
+ //output: string result {semType: DNA nucleotides}
288
+ function asoGapmersGcrsToNucleotides(nucleotides) {
289
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
290
+ 'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };
291
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });
292
+ }
293
+ //name: siRnaBioSpringToNucleotides
294
+ //input: string nucleotides {semType: BioSpring / siRNA}
295
+ //output: string result {semType: RNA nucleotides}
296
+ function siRnaBioSpringToNucleotides(nucleotides) {
297
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
298
+ '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };
299
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
300
+ }
301
+ //name: siRnaBioSpringToAxolabs
302
+ //input: string nucleotides {semType: BioSpring / siRNA}
303
+ //output: string result {semType: Axolabs / siRNA}
304
+ function siRnaBioSpringToAxolabs(nucleotides) {
305
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
306
+ '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };
307
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
308
+ }
309
+ //name: siRnaBioSpringToGcrs
310
+ //input: string nucleotides {semType: BioSpring / siRNA}
311
+ //output: string result {semType: GCRS}
312
+ function siRnaBioSpringToGcrs(nucleotides) {
313
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
314
+ '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };
315
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
316
+ }
317
+ //name: siRnaAxolabsToGcrs
318
+ //input: string nucleotides {semType: Axolabs / siRNA}
319
+ //output: string result {semType: GCRS}
320
+ function siRnaAxolabsToGcrs(nucleotides) {
321
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
322
+ 'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',
323
+ };
324
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
325
+ }
326
+ //name: siRnaAxolabsToBioSpring
327
+ //input: string nucleotides {semType: Axolabs / siRNA}
328
+ //output: string result {semType: BioSpring / siRNA}
329
+ function siRnaAxolabsToBioSpring(nucleotides) {
330
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
331
+ 'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',
332
+ };
333
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
334
+ }
335
+ //name: siRnaAxolabsToNucleotides
336
+ //input: string nucleotides {semType: Axolabs / siRNA}
337
+ //output: string result {semType: RNA nucleotides}
338
+ function siRnaAxolabsToNucleotides(nucleotides) {
339
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
340
+ 'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',
341
+ };
342
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
343
+ }
344
+ //name: siRnaGcrsToNucleotides
345
+ //input: string nucleotides {semType: GCRS}
346
+ //output: string result {semType: RNA nucleotides}
347
+ function siRnaGcrsToNucleotides(nucleotides) {
348
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
349
+ 'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',
350
+ };
351
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
352
+ }
353
+ //name: siRnaGcrsToBioSpring
354
+ //input: string nucleotides {semType: GCRS}
355
+ //output: string result {semType: BioSpring / siRNA}
356
+ function siRnaGcrsToBioSpring(nucleotides) {
357
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
358
+ 'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',
359
+ };
360
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
361
+ }
362
+ //name: siRnaGcrsToAxolabs
363
+ //input: string nucleotides {semType: GCRS}
364
+ //output: string result {semType: Axolabs / siRNA}
365
+ function siRnaGcrsToAxolabs(nucleotides) {
366
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
367
+ 'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',
368
+ };
369
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
370
+ }
371
+ //name: siRnaNucleotideToBioSpringSenseStrand
372
+ //input: string nucleotides {semType: RNA nucleotides}
373
+ //output: string result {semType: BioSpring / siRNA}
374
+ function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {
375
+ let count = -1;
376
+ const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
377
+ 'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };
378
+ const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
379
+ 'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };
380
+ const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
381
+ 'A': '6', 'U': '5', 'G': '8', 'C': '7' };
382
+ const objForEvenIndices = { '(invabasic)': '(invabasic)',
383
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };
384
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
385
+ count++;
386
+ if (count < 2)
387
+ return objForLeftEdge[x];
388
+ if (count > nucleotides.length - 3)
389
+ return objForRightEdge[x];
390
+ return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];
391
+ });
392
+ }
393
+ //name: siRnaNucleotidesToGcrs
394
+ //input: string nucleotides {semType: RNA nucleotides}
395
+ //output: string result {semType: GCRS}
396
+ function siRnaNucleotidesToGcrs(nucleotides) {
397
+ let count = -1;
398
+ const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
399
+ 'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };
400
+ const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
401
+ 'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };
402
+ const objForEvenIndices = { '(invabasic)': '(invabasic)',
403
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };
404
+ const objForOddIndices = { '(invabasic)': '(invabasic)',
405
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };
406
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
407
+ count++;
408
+ if (count < 2)
409
+ return objForLeftEdge[x];
410
+ if (count > nucleotides.length - 3)
411
+ return objForRightEdge[x];
412
+ return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];
413
+ });
414
+ }
415
+ //name: siRnaNucleotideToAxolabsSenseStrand
416
+ //input: string nucleotides {semType: RNA nucleotides}
417
+ //output: string result {semType: Axolabs}
418
+ function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {
419
+ let count = -1;
420
+ const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
421
+ 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };
422
+ const objForSomeIndices = { '(invabasic)': '(invabasic)',
423
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };
424
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
425
+ 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };
426
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
427
+ count++;
428
+ if (count < 2)
429
+ return objForLeftEdge[x];
430
+ if (count == 6 || (count > 7 && count < 11))
431
+ return objForSomeIndices[x];
432
+ if (count == nucleotides.length - 1)
433
+ return 'a';
434
+ return obj[x];
435
+ });
436
+ }
437
+ //name: siRnaNucleotideToAxolabsAntisenseStrand
438
+ //input: string nucleotides {semType: RNA nucleotides}
439
+ //output: string result {semType: Axolabs}
440
+ function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {
441
+ let count = -1;
442
+ const objForSmallLinkages = { '(invabasic)': '(invabasic)',
443
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };
444
+ const objForBigLinkages = { '(invabasic)': '(invabasic)',
445
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };
446
+ const objForSomeIndices = { '(invabasic)': '(invabasic)',
447
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };
448
+ const obj = { '(invabasic)': '(invabasic)',
449
+ '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };
450
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
451
+ count++;
452
+ if (count > 19 && count < 22)
453
+ return objForSmallLinkages[x];
454
+ if (count == 0)
455
+ return 'us';
456
+ if (count == 1)
457
+ return objForBigLinkages[x];
458
+ return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];
459
+ });
460
+ }
461
+ //name: gcrsToNucleotides
462
+ //input: string nucleotides {semType: GCRS}
463
+ //output: string result {semType: RNA nucleotides}
464
+ function gcrsToNucleotides(nucleotides) {
465
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
466
+ 'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',
467
+ 'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',
468
+ };
469
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });
470
+ }
471
+ //name: gcrsToMermade12
472
+ //input: string nucleotides {semType: GCRS}
473
+ //output: string result {semType: Mermade 12 / siRNA}
474
+ function gcrsToMermade12(nucleotides) {
475
+ const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
476
+ 'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',
477
+ 'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',
478
+ };
479
+ return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });
480
+ }
481
+
482
+
483
+ /***/ }),
484
+
485
+ /***/ "./src/structures-works/from-monomers.ts":
486
+ /*!***********************************************!*\
487
+ !*** ./src/structures-works/from-monomers.ts ***!
488
+ \***********************************************/
489
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
490
+
491
+ __webpack_require__.r(__webpack_exports__);
492
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
493
+ /* harmony export */ "sequenceToMolV3000": () => (/* binding */ sequenceToMolV3000),
494
+ /* harmony export */ "sequenceToSmiles": () => (/* binding */ sequenceToSmiles)
495
+ /* harmony export */ });
496
+ /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
497
+ /* harmony import */ var _sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
498
+ /* harmony import */ var _mol_transformations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./mol-transformations */ "./src/structures-works/mol-transformations.ts");
499
+
500
+
501
+
502
+ function sequenceToMolV3000(sequence, inverted = false, oclRender = false, format) {
503
+ const obj = getObjectWithCodesAndSmiles(sequence, format);
504
+ let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));
505
+ let i = 0;
506
+ const smilesCodes = [];
507
+ const codesList = [];
508
+ const links = ['s', 'ps', '*'];
509
+ const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
510
+ const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
511
+ codes = codes.concat(dropdowns);
512
+ while (i < sequence.length) {
513
+ const code = codes.find((s) => s == sequence.slice(i, i + s.length));
514
+ i += code.length;
515
+ inverted ? codesList.unshift(code) : codesList.push(code);
516
+ }
517
+ for (let i = 0; i < codesList.length; i++) {
518
+ if (dropdowns.includes(codesList[i])) {
519
+ smilesCodes.push((i >= codesList.length / 2) ?
520
+ _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].right : _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].left);
521
+ smilesCodes.push(_map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles);
522
+ }
523
+ else {
524
+ if (links.includes(codesList[i]) ||
525
+ includesStandardLinkAlready.includes(codesList[i]) ||
526
+ (i < codesList.length - 1 && links.includes(codesList[i + 1])))
527
+ smilesCodes.push(obj[codesList[i]]);
528
+ else {
529
+ smilesCodes.push(obj[codesList[i]]);
530
+ smilesCodes.push(_map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles);
531
+ }
532
+ }
533
+ }
534
+ return (0,_mol_transformations__WEBPACK_IMPORTED_MODULE_2__.getNucleotidesMol)(smilesCodes, oclRender);
535
+ }
536
+ function sequenceToSmiles(sequence, inverted = false, format) {
537
+ const obj = getObjectWithCodesAndSmiles(sequence, format);
538
+ let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));
539
+ let i = 0;
540
+ let smiles = '';
541
+ const codesList = [];
542
+ const links = ['s', 'ps', '*'];
543
+ const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
544
+ const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
545
+ codes = codes.concat(dropdowns);
546
+ while (i < sequence.length) {
547
+ const code = codes.find((s) => s == sequence.slice(i, i + s.length));
548
+ i += code.length;
549
+ inverted ? codesList.unshift(code) : codesList.push(code);
550
+ }
551
+ for (let i = 0; i < codesList.length; i++) {
552
+ if (dropdowns.includes(codesList[i])) {
553
+ smiles += (i >= codesList.length / 2) ?
554
+ _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].right + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles :
555
+ _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].left + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles;
556
+ }
557
+ else {
558
+ if (links.includes(codesList[i]) ||
559
+ includesStandardLinkAlready.includes(codesList[i]) ||
560
+ (i < codesList.length - 1 && links.includes(codesList[i + 1])))
561
+ smiles += obj[codesList[i]];
562
+ else
563
+ smiles += obj[codesList[i]] + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles;
564
+ }
565
+ }
566
+ smiles = smiles.replace(/OO/g, 'O');
567
+ return ((links.includes(codesList[codesList.length - 1]) &&
568
+ codesList.length > 1 &&
569
+ !includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||
570
+ dropdowns.includes(codesList[codesList.length - 1]) ||
571
+ includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?
572
+ smiles :
573
+ smiles.slice(0, smiles.length - _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles.length + 1);
574
+ }
575
+ function getObjectWithCodesAndSmiles(sequence, format) {
576
+ const obj = {};
577
+ if (format == null) {
578
+ for (const synthesizer of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map)) {
579
+ for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer])) {
580
+ for (const code of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology]))
581
+ obj[code] = _map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology][code].SMILES;
582
+ }
583
+ }
584
+ }
585
+ else {
586
+ for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[format])) {
587
+ for (const code of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[format][technology]))
588
+ obj[code] = _map__WEBPACK_IMPORTED_MODULE_0__.map[format][technology][code].SMILES;
589
+ }
590
+ }
591
+ // TODO: create object based from synthesizer type to avoid key(codes) duplicates
592
+ const output = (0,_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__.isValidSequence)(sequence, format);
593
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12))
594
+ obj['g'] = _map__WEBPACK_IMPORTED_MODULE_0__.map[_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12][_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA]['g'].SMILES;
595
+ else if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS))
596
+ obj['g'] = _map__WEBPACK_IMPORTED_MODULE_0__.map[_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS][_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA]['g'].SMILES;
597
+ return obj;
598
+ }
599
+ function sortByStringLengthInDescendingOrder(array) {
600
+ return array.sort(function (a, b) { return b.length - a.length; });
601
+ }
602
+
603
+
604
+ /***/ }),
605
+
606
+ /***/ "./src/structures-works/map.ts":
607
+ /*!*************************************!*\
608
+ !*** ./src/structures-works/map.ts ***!
609
+ \*************************************/
610
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
611
+
612
+ __webpack_require__.r(__webpack_exports__);
613
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
614
+ /* harmony export */ "SYNTHESIZERS": () => (/* binding */ SYNTHESIZERS),
615
+ /* harmony export */ "TECHNOLOGIES": () => (/* binding */ TECHNOLOGIES),
616
+ /* harmony export */ "COL_NAMES": () => (/* binding */ COL_NAMES),
617
+ /* harmony export */ "MODIFICATIONS": () => (/* binding */ MODIFICATIONS),
618
+ /* harmony export */ "stadardPhosphateLinkSmiles": () => (/* binding */ stadardPhosphateLinkSmiles),
619
+ /* harmony export */ "map": () => (/* binding */ map)
620
+ /* harmony export */ });
621
+ const SYNTHESIZERS = {
622
+ RAW_NUCLEOTIDES: 'Raw Nucleotides',
623
+ BIOSPRING: 'BioSpring Codes',
624
+ GCRS: 'Janssen GCRS Codes',
625
+ AXOLABS: 'Axolabs Codes',
626
+ MERMADE_12: 'Mermade 12',
627
+ };
628
+ const TECHNOLOGIES = {
629
+ DNA: 'DNA',
630
+ RNA: 'RNA',
631
+ ASO_GAPMERS: 'For ASO Gapmers',
632
+ SI_RNA: 'For 2\'-OMe and 2\'-F modified siRNA',
633
+ };
634
+ const COL_NAMES = {
635
+ CHEMISTRY: 'Chemistry',
636
+ NUMBER: 'Number',
637
+ TYPE: 'Type',
638
+ CHEMISTRY_NAME: 'Chemistry Name',
639
+ INTERNAL_COMPOUND_ID: 'Internal compound ID',
640
+ IDP: 'IDP',
641
+ SEQUENCE: 'Sequence',
642
+ COMPOUND_NAME: 'Compound Name',
643
+ COMPOUND_COMMENTS: 'Compound Comments',
644
+ SALT: 'Salt',
645
+ EQUIVALENTS: 'Equivalents',
646
+ PURITY: 'Purity',
647
+ CPD_MW: 'Cpd MW',
648
+ SALT_MASS: 'Salt mass',
649
+ BATCH_MW: 'Batch MW',
650
+ SOURCE: 'Source',
651
+ ICD: 'ICD',
652
+ OWNER: 'Owner',
653
+ };
654
+ // interface CODES {
655
+ // }
656
+ const MODIFICATIONS = {
657
+ '(invabasic)': {
658
+ molecularWeight: 118.13,
659
+ left: 'O[C@@H]1C[C@@H]O[C@H]1CO',
660
+ right: 'O[C@@H]1C[C@@H]O[C@H]1CO',
661
+ },
662
+ '(GalNAc-2-JNJ)': {
663
+ molecularWeight: 1273.3,
664
+ left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
665
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
666
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',
667
+ right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
668
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
669
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',
670
+ },
671
+ };
672
+ const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';
673
+ const map = {
674
+ 'Raw Nucleotides': {
675
+ 'DNA': {
676
+ 'A': {
677
+ 'name': 'Adenine',
678
+ 'weight': 313.21,
679
+ 'normalized': 'dA',
680
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
681
+ },
682
+ 'T': {
683
+ 'name': 'Tyrosine',
684
+ 'weight': 304.2,
685
+ 'normalized': 'dT',
686
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
687
+ },
688
+ 'G': {
689
+ 'name': 'Guanine',
690
+ 'weight': 329.21,
691
+ 'normalized': 'dG',
692
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
693
+ },
694
+ 'C': {
695
+ 'name': 'Cytosine',
696
+ 'weight': 289.18,
697
+ 'normalized': 'dC',
698
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
699
+ },
700
+ },
701
+ 'RNA': {
702
+ 'A': {
703
+ 'name': 'Adenine',
704
+ 'weight': 313.21,
705
+ 'normalized': 'dA',
706
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
707
+ },
708
+ 'U': {
709
+ 'name': 'Uracil',
710
+ 'weight': 306.17,
711
+ 'normalized': 'rU',
712
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',
713
+ },
714
+ 'G': {
715
+ 'name': 'Guanine',
716
+ 'weight': 329.21,
717
+ 'normalized': 'dG',
718
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
719
+ },
720
+ 'C': {
721
+ 'name': 'Cytosine',
722
+ 'weight': 289.18,
723
+ 'normalized': 'dC',
724
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
725
+ },
726
+ },
727
+ },
728
+ 'BioSpring Codes': {
729
+ 'For ASO Gapmers': {
730
+ '5': {
731
+ 'name': '2\'MOE-5Me-rU',
732
+ 'weight': 378.27,
733
+ 'normalized': 'rU',
734
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',
735
+ },
736
+ '6': {
737
+ 'name': '2\'MOE-rA',
738
+ 'weight': 387.29,
739
+ 'normalized': 'rA',
740
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
741
+ },
742
+ '7': {
743
+ 'name': '2\'MOE-5Me-rC',
744
+ 'weight': 377.29,
745
+ 'normalized': 'rC',
746
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
747
+ },
748
+ '8': {
749
+ 'name': '2\'MOE-rG',
750
+ 'weight': 403.28,
751
+ 'normalized': 'rG',
752
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
753
+ },
754
+ '9': {
755
+ 'name': '5-Methyl-dC',
756
+ 'weight': 303.21,
757
+ 'normalized': 'dC',
758
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
759
+ },
760
+ '*': {
761
+ 'name': 'ps linkage',
762
+ 'weight': 16.07,
763
+ 'normalized': '',
764
+ 'SMILES': 'OP(=O)(S)O',
765
+ },
766
+ 'A': {
767
+ 'name': 'Adenine',
768
+ 'weight': 313.21,
769
+ 'normalized': 'dA',
770
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
771
+ },
772
+ 'C': {
773
+ 'name': 'Cytosine',
774
+ 'weight': 289.18,
775
+ 'normalized': 'dC',
776
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
777
+ },
778
+ 'G': {
779
+ 'name': 'Guanine',
780
+ 'weight': 329.21,
781
+ 'normalized': 'dG',
782
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
783
+ },
784
+ 'T': {
785
+ 'name': 'Tyrosine',
786
+ 'weight': 304.2,
787
+ 'normalized': 'dT',
788
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
789
+ },
790
+ },
791
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
792
+ '1': {
793
+ 'name': '2\'-fluoro-U',
794
+ 'weight': 308.16,
795
+ 'normalized': 'rU',
796
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
797
+ },
798
+ '2': {
799
+ 'name': '2\'-fluoro-A',
800
+ 'weight': 331.2,
801
+ 'normalized': 'rA',
802
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
803
+ },
804
+ '3': {
805
+ 'name': '2\'-fluoro-C',
806
+ 'weight': 307.18,
807
+ 'normalized': 'rC',
808
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
809
+ },
810
+ '4': {
811
+ 'name': '2\'-fluoro-G',
812
+ 'weight': 347.19,
813
+ 'normalized': 'rG',
814
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
815
+ },
816
+ '5': {
817
+ 'name': '2\'OMe-rU',
818
+ 'weight': 320.2,
819
+ 'normalized': 'rU',
820
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
821
+ },
822
+ '6': {
823
+ 'name': '2\'OMe-rA',
824
+ 'weight': 343.24,
825
+ 'normalized': 'rA',
826
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
827
+ },
828
+ '7': {
829
+ 'name': '2\'OMe-rC',
830
+ 'weight': 319.21,
831
+ 'normalized': 'rC',
832
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
833
+ },
834
+ '8': {
835
+ 'name': '2\'OMe-rG',
836
+ 'weight': 359.24,
837
+ 'normalized': 'rG',
838
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
839
+ },
840
+ '*': {
841
+ 'name': 'ps linkage',
842
+ 'weight': 16.07,
843
+ 'normalized': '',
844
+ 'SMILES': 'OP(=O)(S)O',
845
+ },
846
+ },
847
+ },
848
+ 'Axolabs Codes': {
849
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
850
+ 'Uf': {
851
+ 'name': '2\'-fluoro-U',
852
+ 'weight': 308.16,
853
+ 'normalized': 'rU',
854
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
855
+ },
856
+ 'Af': {
857
+ 'name': '2\'-fluoro-A',
858
+ 'weight': 331.2,
859
+ 'normalized': 'rA',
860
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
861
+ },
862
+ 'Cf': {
863
+ 'name': '2\'-fluoro-C',
864
+ 'weight': 307.18,
865
+ 'normalized': 'rC',
866
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
867
+ },
868
+ 'Gf': {
869
+ 'name': '2\'-fluoro-G',
870
+ 'weight': 347.19,
871
+ 'normalized': 'rG',
872
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
873
+ },
874
+ 'u': {
875
+ 'name': '2\'OMe-rU',
876
+ 'weight': 320.2,
877
+ 'normalized': 'rU',
878
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
879
+ },
880
+ 'a': {
881
+ 'name': '2\'OMe-rA',
882
+ 'weight': 343.24,
883
+ 'normalized': 'rA',
884
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
885
+ },
886
+ 'c': {
887
+ 'name': '2\'OMe-rC',
888
+ 'weight': 319.21,
889
+ 'normalized': 'rC',
890
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
891
+ },
892
+ 'g': {
893
+ 'name': '2\'OMe-rG',
894
+ 'weight': 359.,
895
+ 'normalized': 'rG',
896
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
897
+ },
898
+ 's': {
899
+ 'name': 'ps linkage',
900
+ 'weight': 16.07,
901
+ 'normalized': '',
902
+ 'SMILES': 'OP(=O)(S)O',
903
+ },
904
+ },
905
+ },
906
+ 'Janssen GCRS Codes': {
907
+ 'For ASO Gapmers': {
908
+ 'moeT': {
909
+ 'name': '2\'MOE-5Me-rU',
910
+ 'weight': 378.27,
911
+ 'normalized': 'rU',
912
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',
913
+ },
914
+ 'moeA': {
915
+ 'name': '2\'MOE-rA',
916
+ 'weight': 387.29,
917
+ 'normalized': 'rA',
918
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
919
+ },
920
+ 'moe5mC': {
921
+ 'name': '2\'MOE-5Me-rC',
922
+ 'weight': 377.29,
923
+ 'normalized': 'rC',
924
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
925
+ },
926
+ '(5m)moeC': {
927
+ 'name': '2\'MOE-5Me-rC',
928
+ 'weight': 377.29,
929
+ 'normalized': 'rC',
930
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
931
+ },
932
+ 'moeG': {
933
+ 'name': '2\'MOE-rG',
934
+ 'weight': 403.28,
935
+ 'normalized': 'rG',
936
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
937
+ },
938
+ '5mC': {
939
+ 'name': '5-Methyl-dC',
940
+ 'weight': 303.28,
941
+ 'normalized': 'dC',
942
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
943
+ },
944
+ '(5m)C': {
945
+ 'name': '5-Methyl-dC',
946
+ 'weight': 303.28,
947
+ 'normalized': 'dC',
948
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
949
+ },
950
+ 'ps': {
951
+ 'name': 'ps linkage',
952
+ 'weight': 16.07,
953
+ 'normalized': '',
954
+ 'SMILES': 'OP(=O)(S)O',
955
+ },
956
+ 'A': {
957
+ 'name': 'Adenine',
958
+ 'weight': 313.21,
959
+ 'normalized': 'dA',
960
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
961
+ },
962
+ 'dA': {
963
+ 'name': 'Adenine',
964
+ 'weight': 313.21,
965
+ 'normalized': 'dA',
966
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
967
+ },
968
+ 'C': {
969
+ 'name': 'Cytosine',
970
+ 'weight': 289.18,
971
+ 'normalized': 'dC',
972
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
973
+ },
974
+ 'dC': {
975
+ 'name': 'Cytosine',
976
+ 'weight': 289.18,
977
+ 'normalized': 'dC',
978
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
979
+ },
980
+ 'G': {
981
+ 'name': 'Guanine',
982
+ 'weight': 329.21,
983
+ 'normalized': 'dG',
984
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
985
+ },
986
+ 'dG': {
987
+ 'name': 'Guanine',
988
+ 'weight': 329.21,
989
+ 'normalized': 'dG',
990
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
991
+ },
992
+ 'T': {
993
+ 'name': 'Tyrosine',
994
+ 'weight': 304.2,
995
+ 'normalized': 'dT',
996
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
997
+ },
998
+ 'dT': {
999
+ 'name': 'Tyrosine',
1000
+ 'weight': 304.2,
1001
+ 'normalized': 'dT',
1002
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
1003
+ },
1004
+ 'rA': {
1005
+ 'name': 'Adenine',
1006
+ 'weight': 329.21,
1007
+ 'normalized': 'rA',
1008
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',
1009
+ },
1010
+ 'rC': {
1011
+ 'name': 'Cytosine',
1012
+ 'weight': 305.18,
1013
+ 'normalized': 'rC',
1014
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',
1015
+ },
1016
+ 'rG': {
1017
+ 'name': 'Guanine',
1018
+ 'weight': 345.21,
1019
+ 'normalized': 'rG',
1020
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',
1021
+ },
1022
+ 'rU': {
1023
+ 'name': 'Uracil',
1024
+ 'weight': 306.17,
1025
+ 'normalized': 'rU',
1026
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',
1027
+ },
1028
+ },
1029
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
1030
+ 'fU': {
1031
+ 'name': '2\'-fluoro-U',
1032
+ 'weight': 308.16,
1033
+ 'normalized': 'rU',
1034
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
1035
+ },
1036
+ 'fA': {
1037
+ 'name': '2\'-fluoro-A',
1038
+ 'weight': 331.2,
1039
+ 'normalized': 'rA',
1040
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
1041
+ },
1042
+ 'fC': {
1043
+ 'name': '2\'-fluoro-C',
1044
+ 'weight': 307.18,
1045
+ 'normalized': 'rC',
1046
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
1047
+ },
1048
+ 'fG': {
1049
+ 'name': '2\'-fluoro-G',
1050
+ 'weight': 347.19,
1051
+ 'normalized': 'rG',
1052
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
1053
+ },
1054
+ 'mU': {
1055
+ 'name': '2\'OMe-rU',
1056
+ 'weight': 320.2,
1057
+ 'normalized': 'rU',
1058
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
1059
+ },
1060
+ 'mA': {
1061
+ 'name': '2\'OMe-rA',
1062
+ 'weight': 343.24,
1063
+ 'normalized': 'rA',
1064
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
1065
+ },
1066
+ 'mC': {
1067
+ 'name': '2\'OMe-rC',
1068
+ 'weight': 319.21,
1069
+ 'normalized': 'rC',
1070
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
1071
+ },
1072
+ 'mG': {
1073
+ 'name': '2\'OMe-rG',
1074
+ 'weight': 359.24,
1075
+ 'normalized': 'rG',
1076
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
1077
+ },
1078
+ },
1079
+ },
1080
+ 'Mermade 12': {
1081
+ 'For 2\'-OMe and 2\'-F modified siRNA': {
1082
+ 'e': {
1083
+ 'name': '2\'OMe-rA-ps',
1084
+ 'weight': 359.31,
1085
+ 'normalized': 'rA',
1086
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',
1087
+ },
1088
+ 'h': {
1089
+ 'name': '2\'OMe-rU-ps',
1090
+ 'weight': 336.27,
1091
+ 'normalized': 'rU',
1092
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',
1093
+ },
1094
+ 'g': {
1095
+ 'name': '2\'OMe-rG-ps',
1096
+ 'weight': 375.31,
1097
+ 'normalized': 'rG',
1098
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',
1099
+ },
1100
+ 'f': {
1101
+ 'name': '2\'OMe-rC-ps',
1102
+ 'weight': 335.28,
1103
+ 'normalized': 'rC',
1104
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',
1105
+ },
1106
+ 'i': {
1107
+ 'name': '2\'-fluoro-A-ps',
1108
+ 'weight': 347.27,
1109
+ 'normalized': 'rA',
1110
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',
1111
+ },
1112
+ 'l': {
1113
+ 'name': '2\'-fluoro-U-ps',
1114
+ 'weight': 324.23,
1115
+ 'normalized': 'rU',
1116
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',
1117
+ },
1118
+ 'k': {
1119
+ 'name': '2\'-fluoro-G-ps',
1120
+ 'weight': 363.26,
1121
+ 'normalized': 'rG',
1122
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',
1123
+ },
1124
+ 'j': {
1125
+ 'name': '2\'-fluoro-C-ps',
1126
+ 'weight': 323.25,
1127
+ 'normalized': 'rC',
1128
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',
1129
+ },
1130
+ 'L': {
1131
+ 'name': '2\'-fluoro-U',
1132
+ 'weight': 308.16,
1133
+ 'normalized': 'rU',
1134
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
1135
+ },
1136
+ 'I': {
1137
+ 'name': '2\'-fluoro-A',
1138
+ 'weight': 331.2,
1139
+ 'normalized': 'rA',
1140
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
1141
+ },
1142
+ 'J': {
1143
+ 'name': '2\'-fluoro-C',
1144
+ 'weight': 307.18,
1145
+ 'normalized': 'rC',
1146
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
1147
+ },
1148
+ 'K': {
1149
+ 'name': '2\'-fluoro-G',
1150
+ 'weight': 347.19,
1151
+ 'normalized': 'rG',
1152
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
1153
+ },
1154
+ 'H': {
1155
+ 'name': '2\'OMe-rU',
1156
+ 'weight': 320.2,
1157
+ 'normalized': 'rU',
1158
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
1159
+ },
1160
+ 'E': {
1161
+ 'name': '2\'OMe-rA',
1162
+ 'weight': 343.24,
1163
+ 'normalized': 'rA',
1164
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
1165
+ },
1166
+ 'F': {
1167
+ 'name': '2\'OMe-rC',
1168
+ 'weight': 319.21,
1169
+ 'normalized': 'rC',
1170
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
1171
+ },
1172
+ 'G': {
1173
+ 'name': '2\'OMe-rG',
1174
+ 'weight': 359.24,
1175
+ 'normalized': 'rG',
1176
+ 'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
1177
+ },
1178
+ },
1179
+ },
1180
+ };
1181
+
1182
+
1183
+ /***/ }),
1184
+
1185
+ /***/ "./src/structures-works/mol-transformations.ts":
1186
+ /*!*****************************************************!*\
1187
+ !*** ./src/structures-works/mol-transformations.ts ***!
1188
+ \*****************************************************/
1189
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1190
+
1191
+ __webpack_require__.r(__webpack_exports__);
1192
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1193
+ /* harmony export */ "getNucleotidesMol": () => (/* binding */ getNucleotidesMol),
1194
+ /* harmony export */ "linkV3000": () => (/* binding */ linkV3000)
1195
+ /* harmony export */ });
1196
+ /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! openchemlib/full.js */ "openchemlib/full.js");
1197
+ /* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__);
1198
+
1199
+ const PHOSHATE = `
1200
+ Datagrok monomer library Nucleotides
1201
+
1202
+ 0 0 0 0 0 0 0 V3000
1203
+ M V30 BEGIN CTAB
1204
+ M V30 COUNTS 5 4 0 0 0
1205
+ M V30 BEGIN ATOM
1206
+ M V30 1 O -1.5 0 0 0
1207
+ M V30 2 P 0 0 0 0
1208
+ M V30 3 O 0 1 0 0
1209
+ M V30 4 O 0 -1 0 0
1210
+ M V30 5 O 1.5 0 0 0
1211
+ M V30 END ATOM
1212
+ M V30 BEGIN BOND
1213
+ M V30 1 1 1 2
1214
+ M V30 2 2 2 3
1215
+ M V30 3 1 2 4
1216
+ M V30 4 1 2 5
1217
+ M V30 END BOND
1218
+ M V30 END CTAB
1219
+ M V30 BEGIN COLLECTION
1220
+ M V30 END COLLECTION
1221
+ M END`;
1222
+ const THIOPHOSHATE = `
1223
+ Datagrok monomer library Nucleotides
1224
+
1225
+ 0 0 0 0 0 0 0 V3000
1226
+ M V30 BEGIN CTAB
1227
+ M V30 COUNTS 5 4 0 0 0
1228
+ M V30 BEGIN ATOM
1229
+ M V30 1 O -1.5 0 0 0
1230
+ M V30 2 P 0 0 0 0
1231
+ M V30 3 O 0 1 0 0
1232
+ M V30 4 S 0 -1 0 0
1233
+ M V30 5 O 1.5 0 0 0
1234
+ M V30 END ATOM
1235
+ M V30 BEGIN BOND
1236
+ M V30 1 1 1 2
1237
+ M V30 2 2 2 3
1238
+ M V30 3 1 2 4
1239
+ M V30 4 1 2 5
1240
+ M V30 END BOND
1241
+ M V30 END CTAB
1242
+ M V30 BEGIN COLLECTION
1243
+ M V30 END COLLECTION
1244
+ M END`;
1245
+ const INVABASIC = `
1246
+ Datagrok monomer library Nucleotides
1247
+
1248
+ 0 0 0 0 0 0 0 V3000
1249
+ M V30 BEGIN CTAB
1250
+ M V30 COUNTS 8 8 0 0 0
1251
+ M V30 BEGIN ATOM
1252
+ M V30 1 O 1.0934 -2.1636 0 0
1253
+ M V30 2 C 1.8365 -1.4945 0 0 CFG=2
1254
+ M V30 3 C 2.8147 -1.7024 0 0
1255
+ M V30 4 C 3.3147 -0.8364 0 0 VAL=3
1256
+ M V30 5 O 2.6455 -0.0932 0 0
1257
+ M V30 6 C 1.732 -0.5 0 0 CFG=1
1258
+ M V30 7 C 0.866 0 0 0
1259
+ M V30 8 O 0.866 1 0 0
1260
+ M V30 END ATOM
1261
+ M V30 BEGIN BOND
1262
+ M V30 1 1 2 1 CFG=1
1263
+ M V30 2 1 2 3
1264
+ M V30 3 1 3 4
1265
+ M V30 4 1 4 5
1266
+ M V30 5 1 6 5
1267
+ M V30 6 1 2 6
1268
+ M V30 7 1 6 7 CFG=3
1269
+ M V30 8 1 7 8
1270
+ M V30 END BOND
1271
+ M V30 BEGIN COLLECTION
1272
+ M V30 MDLV30/STEABS ATOMS=(2 2 6)
1273
+ M V30 END COLLECTION
1274
+ M V30 END CTAB
1275
+ M END`;
1276
+ function getNucleotidesMol(smilesCodes, oclRender = false) {
1277
+ const molBlocks = [];
1278
+ for (let i = 0; i < smilesCodes.length - 1; i++) {
1279
+ smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :
1280
+ smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :
1281
+ smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :
1282
+ molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));
1283
+ }
1284
+ return linkV3000(molBlocks, false, oclRender);
1285
+ }
1286
+ function linkV3000(molBlocks, twoMolecules = false, oclRender = false) {
1287
+ let macroMolBlock = '\nDatagrok macromolecule handler\n\n';
1288
+ macroMolBlock += ' 0 0 0 0 0 0 999 V3000\n';
1289
+ macroMolBlock += 'M V30 BEGIN CTAB\n';
1290
+ let atomBlock = '';
1291
+ let bondBlock = '';
1292
+ let collectionBlock = '';
1293
+ const collection = [];
1294
+ let natom = 0;
1295
+ let nbond = 0;
1296
+ let sequenceShift = 0;
1297
+ let xShift = 0;
1298
+ if (twoMolecules && molBlocks.length > 1)
1299
+ molBlocks[1] = invertNucleotidesV3000(molBlocks[1]);
1300
+ for (let i = 0; i < molBlocks.length; i++) {
1301
+ molBlocks[i] = molBlocks[i].replaceAll('(-\nM V30 ', '(')
1302
+ .replaceAll('-\nM V30 ', '').replaceAll(' )', ')');
1303
+ const numbers = extractAtomsBondsNumbersV3000(molBlocks[i]);
1304
+ const coordinates = extractAtomDataV3000(molBlocks[i]);
1305
+ let indexAtoms = molBlocks[i].indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1306
+ indexAtoms = molBlocks[i].indexOf('\n', indexAtoms);
1307
+ let index = indexAtoms;
1308
+ let indexEnd = indexAtoms;
1309
+ for (let j = 0; j < numbers.natom; j++) {
1310
+ if (coordinates.atomIndex[j] != 1 || i == 0 || twoMolecules) {
1311
+ //rewrite atom number
1312
+ index = molBlocks[i].indexOf('V30', index) + 4;
1313
+ indexEnd = molBlocks[i].indexOf(' ', index);
1314
+ const atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
1315
+ molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
1316
+ //rewrite coordinates
1317
+ index = molBlocks[i].indexOf(' ', index) + 1;
1318
+ index = molBlocks[i].indexOf(' ', index) + 1;
1319
+ indexEnd = molBlocks[i].indexOf(' ', index);
1320
+ const totalShift = xShift - coordinates.x[0];
1321
+ let coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + totalShift)) / 10000;
1322
+ molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);
1323
+ index = molBlocks[i].indexOf(' ', index) + 1;
1324
+ indexEnd = molBlocks[i].indexOf(' ', index);
1325
+ coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + sequenceShift)) / 10000;
1326
+ molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);
1327
+ index = molBlocks[i].indexOf('\n', index) + 1;
1328
+ }
1329
+ else {
1330
+ index = molBlocks[i].indexOf('M V30', index) - 1;
1331
+ indexEnd = molBlocks[i].indexOf('\n', index + 1);
1332
+ molBlocks[i] = molBlocks[i].slice(0, index) + molBlocks[i].slice(indexEnd);
1333
+ }
1334
+ }
1335
+ const indexAtomsEnd = molBlocks[i].indexOf('M V30 END ATOM');
1336
+ atomBlock += molBlocks[i].substring(indexAtoms + 1, indexAtomsEnd);
1337
+ let indexBonds = molBlocks[i].indexOf('M V30 BEGIN BOND'); // V3000 index for bonds
1338
+ indexBonds = molBlocks[i].indexOf('\n', indexBonds);
1339
+ index = indexBonds;
1340
+ indexEnd = indexBonds;
1341
+ for (let j = 0; j < numbers.nbond; j++) {
1342
+ //rewrite bond number
1343
+ index = molBlocks[i].indexOf('V30', index) + 4;
1344
+ indexEnd = molBlocks[i].indexOf(' ', index);
1345
+ const bondNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + nbond;
1346
+ molBlocks[i] = molBlocks[i].slice(0, index) + bondNumber + molBlocks[i].slice(indexEnd);
1347
+ //rewrite atom pair in bond
1348
+ index = molBlocks[i].indexOf(' ', index) + 1;
1349
+ index = molBlocks[i].indexOf(' ', index) + 1;
1350
+ indexEnd = molBlocks[i].indexOf(' ', index);
1351
+ let atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
1352
+ molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
1353
+ index = molBlocks[i].indexOf(' ', index) + 1;
1354
+ indexEnd = Math.min(molBlocks[i].indexOf('\n', index), molBlocks[i].indexOf(' ', index));
1355
+ atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
1356
+ molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
1357
+ index = molBlocks[i].indexOf('\n', index) + 1;
1358
+ }
1359
+ const indexBondEnd = molBlocks[i].indexOf('M V30 END BOND');
1360
+ bondBlock += molBlocks[i].substring(indexBonds + 1, indexBondEnd);
1361
+ let indexCollection = molBlocks[i].indexOf('M V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections
1362
+ while (indexCollection != -1) {
1363
+ indexCollection += 28;
1364
+ const collectionEnd = molBlocks[i].indexOf(')', indexCollection);
1365
+ const collectionEntries = molBlocks[i].substring(indexCollection, collectionEnd).split(' ').slice(1);
1366
+ collectionEntries.forEach((e) => {
1367
+ collection.push(parseInt(e) + natom);
1368
+ });
1369
+ indexCollection = collectionEnd;
1370
+ indexCollection = molBlocks[i].indexOf('M V30 MDLV30/STEABS ATOMS=(', indexCollection);
1371
+ }
1372
+ natom += twoMolecules ? numbers.natom : numbers.natom - 1;
1373
+ nbond += numbers.nbond;
1374
+ xShift += twoMolecules ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[0];
1375
+ sequenceShift += twoMolecules ? -7 : 0;
1376
+ }
1377
+ const entries = 4;
1378
+ const collNumber = Math.ceil(collection.length / entries);
1379
+ if (oclRender) {
1380
+ collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length;
1381
+ for (let j = 0; j < collection.length; j++)
1382
+ collectionBlock += ' ' + collection[j];
1383
+ collectionBlock += ')\n';
1384
+ }
1385
+ else {
1386
+ collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\n';
1387
+ for (let i = 0; i < collNumber; i++) {
1388
+ collectionBlock += 'M V30 ';
1389
+ const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;
1390
+ for (let j = 0; j < entriesCurrent; j++) {
1391
+ collectionBlock += (j + 1 == entriesCurrent) ?
1392
+ (i == collNumber - 1 ? collection[entries * i + j] + ')\n' : collection[entries * i + j] + ' -\n') :
1393
+ collection[entries * i + j] + ' ';
1394
+ }
1395
+ }
1396
+ }
1397
+ //generate file
1398
+ twoMolecules ? natom : natom++;
1399
+ macroMolBlock += 'M V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\n';
1400
+ macroMolBlock += 'M V30 BEGIN ATOM\n';
1401
+ macroMolBlock += atomBlock;
1402
+ macroMolBlock += 'M V30 END ATOM\n';
1403
+ macroMolBlock += 'M V30 BEGIN BOND\n';
1404
+ macroMolBlock += bondBlock;
1405
+ macroMolBlock += 'M V30 END BOND\n';
1406
+ macroMolBlock += 'M V30 BEGIN COLLECTION\n';
1407
+ macroMolBlock += collectionBlock;
1408
+ macroMolBlock += 'M V30 END COLLECTION\n';
1409
+ macroMolBlock += 'M V30 END CTAB\n';
1410
+ macroMolBlock += 'M END\n';
1411
+ return macroMolBlock;
1412
+ }
1413
+ function rotateNucleotidesV3000(molecule) {
1414
+ let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
1415
+ const coordinates = extractAtomDataV3000(molBlock);
1416
+ const natom = coordinates.atomIndex.length;
1417
+ const indexFivePrime = coordinates.atomIndex.indexOf(1);
1418
+ const indexThreePrime = coordinates.atomIndex.indexOf(natom);
1419
+ //fix 5 prime if inadequate
1420
+ if (natom > 8)
1421
+ fix5Prime(coordinates, indexFivePrime, indexThreePrime);
1422
+ const xCenter = (coordinates.x[indexThreePrime] + coordinates.x[indexFivePrime]) / 2;
1423
+ const yCenter = (coordinates.y[indexThreePrime] + coordinates.y[indexFivePrime]) / 2;
1424
+ //place to center
1425
+ for (let i = 0; i < natom; i++) {
1426
+ coordinates.x[i] -= xCenter;
1427
+ coordinates.y[i] -= yCenter;
1428
+ }
1429
+ let angle = 0;
1430
+ if (coordinates.x[indexFivePrime] == 0)
1431
+ angle = coordinates.y[indexFivePrime] > coordinates.y[indexThreePrime] ? Math.PI / 2 : 3 * Math.PI / 2;
1432
+ else if (coordinates.y[indexFivePrime] == 0)
1433
+ angle = coordinates.x[indexFivePrime] > coordinates.x[indexThreePrime] ? Math.PI : 0;
1434
+ else {
1435
+ const derivative = coordinates.y[indexFivePrime] / coordinates.x[indexFivePrime];
1436
+ angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);
1437
+ }
1438
+ const cos = Math.cos(angle);
1439
+ const sin = Math.sin(angle);
1440
+ for (let i = 0; i < natom; i++) {
1441
+ const xAdd = coordinates.x[i];
1442
+ coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;
1443
+ coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;
1444
+ }
1445
+ //place to right
1446
+ const xShift = coordinates.x[indexFivePrime];
1447
+ for (let i = 0; i < natom; i++)
1448
+ coordinates.x[i] -= xShift;
1449
+ //rewrite molBlock
1450
+ let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1451
+ index = molBlock.indexOf('\n', index);
1452
+ let indexEnd = index;
1453
+ for (let i = 0; i < natom; i++) {
1454
+ index = molBlock.indexOf('V30', index) + 4;
1455
+ index = molBlock.indexOf(' ', index) + 1;
1456
+ index = molBlock.indexOf(' ', index) + 1;
1457
+ indexEnd = molBlock.indexOf(' ', index) + 1;
1458
+ indexEnd = molBlock.indexOf(' ', indexEnd);
1459
+ molBlock = molBlock.slice(0, index) +
1460
+ coordinates.x[i] + ' ' + coordinates.y[i] +
1461
+ molBlock.slice(indexEnd);
1462
+ index = molBlock.indexOf('\n', index) + 1;
1463
+ }
1464
+ return molBlock;
1465
+ }
1466
+ function invertNucleotidesV3000(molecule) {
1467
+ let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
1468
+ const coordinates = extractAtomDataV3000(molBlock);
1469
+ const natom = coordinates.atomIndex.length;
1470
+ const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;
1471
+ const yCenter = (Math.max(...coordinates.y) + Math.min(...coordinates.y)) / 2;
1472
+ //place to center
1473
+ for (let i = 0; i < natom; i++) {
1474
+ coordinates.x[i] -= xCenter;
1475
+ coordinates.y[i] -= yCenter;
1476
+ }
1477
+ const angle = Math.PI;
1478
+ const cos = Math.cos(angle);
1479
+ const sin = Math.sin(angle);
1480
+ for (let i = 0; i < natom; i++) {
1481
+ const xAdd = coordinates.x[i];
1482
+ coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;
1483
+ coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;
1484
+ }
1485
+ //place back
1486
+ const yShift = Math.max(...coordinates.y);
1487
+ for (let i = 0; i < natom; i++) {
1488
+ coordinates.x[i] += xCenter;
1489
+ coordinates.y[i] -= yShift;
1490
+ }
1491
+ //rewrite molBlock
1492
+ let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1493
+ index = molBlock.indexOf('\n', index);
1494
+ let indexEnd = index;
1495
+ for (let i = 0; i < natom; i++) {
1496
+ index = molBlock.indexOf('V30', index) + 4;
1497
+ index = molBlock.indexOf(' ', index) + 1;
1498
+ index = molBlock.indexOf(' ', index) + 1;
1499
+ indexEnd = molBlock.indexOf(' ', index) + 1;
1500
+ indexEnd = molBlock.indexOf(' ', indexEnd);
1501
+ molBlock = molBlock.slice(0, index) +
1502
+ coordinates.x[i] + ' ' + coordinates.y[i] +
1503
+ molBlock.slice(indexEnd);
1504
+ index = molBlock.indexOf('\n', index) + 1;
1505
+ }
1506
+ return molBlock;
1507
+ }
1508
+ function fix5Prime(coordinates, indexFivePrime, indexThreePrime) {
1509
+ const indexFivePrimeNeighbour = indexFivePrime + 1;
1510
+ const xShift = coordinates.x[indexFivePrimeNeighbour];
1511
+ const yShift = coordinates.y[indexFivePrimeNeighbour];
1512
+ const base3PrimeX = coordinates.x[indexThreePrime] - xShift;
1513
+ const base3PrimeY = coordinates.y[indexThreePrime] - yShift;
1514
+ const base5PrimeX = coordinates.x[indexFivePrime] - xShift;
1515
+ const base5PrimeY = coordinates.y[indexFivePrime] - yShift;
1516
+ const rotated5PrimeX = base5PrimeX * Math.cos(Math.PI * 2 / 3) - base5PrimeY * Math.sin(Math.PI * 2 / 3);
1517
+ const rotated5PrimeY = base5PrimeX * Math.sin(Math.PI * 2 / 3) + base5PrimeY * Math.cos(Math.PI * 2 / 3);
1518
+ const dx = base5PrimeX - base3PrimeX;
1519
+ const dy = base5PrimeY - base3PrimeY;
1520
+ const dxRotated = rotated5PrimeX - base3PrimeX;
1521
+ const dyRotated = rotated5PrimeY - base3PrimeY;
1522
+ if (Math.sqrt(dyRotated * dyRotated + dxRotated * dxRotated) >= Math.sqrt(dy * dy + dx * dx)) {
1523
+ coordinates.x[indexFivePrime] = rotated5PrimeX + xShift;
1524
+ coordinates.y[indexFivePrime] = rotated5PrimeY + yShift;
1525
+ }
1526
+ }
1527
+ function extractAtomsBondsNumbersV3000(molBlock) {
1528
+ molBlock = molBlock.replaceAll('\r', ''); //equalize old and new sdf standards
1529
+ let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number
1530
+ let indexEnd = molBlock.indexOf(' ', index);
1531
+ const atomsNumber = parseInt(molBlock.substring(index, indexEnd));
1532
+ index = indexEnd + 1;
1533
+ indexEnd = molBlock.indexOf(' ', index);
1534
+ const bondsNumber = parseInt(molBlock.substring(index, indexEnd));
1535
+ return { natom: atomsNumber, nbond: bondsNumber };
1536
+ }
1537
+ function extractAtomDataV3000(molBlock) {
1538
+ const numbers = extractAtomsBondsNumbersV3000(molBlock);
1539
+ let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
1540
+ index = molBlock.indexOf('\n', index);
1541
+ let indexEnd = index;
1542
+ const indexes = Array(numbers.natom);
1543
+ const types = Array(numbers.natom);
1544
+ const x = Array(numbers.natom);
1545
+ const y = Array(numbers.natom);
1546
+ for (let i = 0; i < numbers.natom; i++) {
1547
+ index = molBlock.indexOf('V30', index) + 4;
1548
+ indexEnd = molBlock.indexOf(' ', index);
1549
+ indexes[i] = parseInt(molBlock.substring(index, indexEnd));
1550
+ index = indexEnd + 1;
1551
+ indexEnd = molBlock.indexOf(' ', index);
1552
+ types[i] = molBlock.substring(index, indexEnd);
1553
+ index = indexEnd + 1;
1554
+ indexEnd = molBlock.indexOf(' ', index);
1555
+ x[i] = parseFloat(molBlock.substring(index, indexEnd));
1556
+ index = indexEnd + 1;
1557
+ indexEnd = molBlock.indexOf(' ', index);
1558
+ y[i] = parseFloat(molBlock.substring(index, indexEnd));
1559
+ index = molBlock.indexOf('\n', index) + 1;
1560
+ }
1561
+ return { atomIndex: indexes, atomType: types, x: x, y: y };
1562
+ }
1563
+
1564
+
1565
+ /***/ }),
1566
+
1567
+ /***/ "./src/structures-works/sequence-codes-tools.ts":
1568
+ /*!******************************************************!*\
1569
+ !*** ./src/structures-works/sequence-codes-tools.ts ***!
1570
+ \******************************************************/
1571
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1572
+
1573
+ __webpack_require__.r(__webpack_exports__);
1574
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1575
+ /* harmony export */ "undefinedInputSequence": () => (/* binding */ undefinedInputSequence),
1576
+ /* harmony export */ "getFormat": () => (/* binding */ getFormat),
1577
+ /* harmony export */ "isValidSequence": () => (/* binding */ isValidSequence),
1578
+ /* harmony export */ "convertSequence": () => (/* binding */ convertSequence)
1579
+ /* harmony export */ });
1580
+ /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
1581
+ /* harmony import */ var _converters__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./converters */ "./src/structures-works/converters.ts");
1582
+ // import * as grok from 'datagrok-api/grok';
1583
+ // import * as ui from 'datagrok-api/ui';
1584
+ // import * as DG from 'datagrok-api/dg';
1585
+
1586
+
1587
+ const noTranslationTableAvailable = 'No translation table available';
1588
+ const undefinedInputSequence = 'Type of input sequence is undefined';
1589
+ function getFormat(sequence) {
1590
+ const possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);
1591
+ if (possibleSynthesizers.length == 0)
1592
+ return null;
1593
+ let outputIndex = 0;
1594
+ const firstUniqueCharacters = ['r', 'd'];
1595
+ const nucleotides = ['A', 'U', 'T', 'C', 'G'];
1596
+ possibleSynthesizers.forEach((synthesizer) => {
1597
+ const codes = getAllCodesOfSynthesizer(synthesizer);
1598
+ while (outputIndex < sequence.length) {
1599
+ const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
1600
+ if (matchedCode == null)
1601
+ break;
1602
+ if ( // for mistake pattern 'rAA'
1603
+ outputIndex > 1 &&
1604
+ nucleotides.includes(sequence[outputIndex]) &&
1605
+ firstUniqueCharacters.includes(sequence[outputIndex - 2]))
1606
+ break;
1607
+ if ( // for mistake pattern 'ArA'
1608
+ firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
1609
+ nucleotides.includes(sequence[outputIndex])) {
1610
+ outputIndex++;
1611
+ break;
1612
+ }
1613
+ outputIndex += matchedCode.length;
1614
+ }
1615
+ });
1616
+ const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;
1617
+ if (indexOfFirstNotValidChar != -1)
1618
+ return possibleSynthesizers[0];
1619
+ const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);
1620
+ if (possibleTechnologies.length == 0)
1621
+ return null;
1622
+ outputIndex = 0;
1623
+ possibleTechnologies.forEach((technology) => {
1624
+ const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[possibleSynthesizers[0]][technology]);
1625
+ while (outputIndex < sequence.length) {
1626
+ const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
1627
+ if (matchedCode == null)
1628
+ break;
1629
+ if ( // for mistake pattern 'rAA'
1630
+ outputIndex > 1 &&
1631
+ nucleotides.includes(sequence[outputIndex]) &&
1632
+ firstUniqueCharacters.includes(sequence[outputIndex - 2]))
1633
+ break;
1634
+ if ( // for mistake pattern 'ArA'
1635
+ firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
1636
+ nucleotides.includes(sequence[outputIndex])) {
1637
+ outputIndex++;
1638
+ break;
1639
+ }
1640
+ outputIndex += matchedCode.length;
1641
+ }
1642
+ });
1643
+ return possibleSynthesizers[0];
1644
+ }
1645
+ function isValidSequence(sequence, format) {
1646
+ const possibleSynthesizers = format == null ?
1647
+ getListOfPossibleSynthesizersByFirstMatchedCode(sequence) :
1648
+ [format];
1649
+ // if (possibleSynthesizers.length > 1) {
1650
+ // const synthesizer = ui.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0],
1651
+ // possibleSynthesizers);
1652
+ // ui.dialog('Choose Synthesizer')
1653
+ // .add(ui.panel([synthesizer.root], {style: {fontWeight: 'bold'}}))
1654
+ // .onOK(() => possibleSynthesizers = [synthesizer.value])
1655
+ // .onCancel(() => {
1656
+ // possibleSynthesizers = [possibleSynthesizers[0]];
1657
+ // grok.shell.warning('Input sequence is expected to be in format ' + possibleSynthesizers[0]);
1658
+ // })
1659
+ // .show();
1660
+ // } else if (possibleSynthesizers.length == 0)
1661
+ if (possibleSynthesizers.length == 0)
1662
+ return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };
1663
+ let outputIndex = 0;
1664
+ const firstUniqueCharacters = ['r', 'd'];
1665
+ const nucleotides = ['A', 'U', 'T', 'C', 'G'];
1666
+ possibleSynthesizers.forEach((synthesizer) => {
1667
+ const codes = getAllCodesOfSynthesizer(synthesizer);
1668
+ while (outputIndex < sequence.length) {
1669
+ const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
1670
+ if (matchedCode == null)
1671
+ break;
1672
+ if ( // for mistake pattern 'rAA'
1673
+ outputIndex > 1 &&
1674
+ nucleotides.includes(sequence[outputIndex]) &&
1675
+ firstUniqueCharacters.includes(sequence[outputIndex - 2]))
1676
+ break;
1677
+ if ( // for mistake pattern 'ArA'
1678
+ firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
1679
+ nucleotides.includes(sequence[outputIndex])) {
1680
+ outputIndex++;
1681
+ break;
1682
+ }
1683
+ outputIndex += matchedCode.length;
1684
+ }
1685
+ });
1686
+ const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;
1687
+ if (indexOfFirstNotValidChar != -1) {
1688
+ return {
1689
+ indexOfFirstNotValidChar: indexOfFirstNotValidChar,
1690
+ synthesizer: possibleSynthesizers,
1691
+ technology: null,
1692
+ };
1693
+ }
1694
+ const possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);
1695
+ // if (possibleTechnologies.length > 1) {
1696
+ // const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0],
1697
+ // possibleTechnologies);
1698
+ // ui.dialog('Choose Technology')
1699
+ // .add(ui.panel([technology.root], {style: {fontWeight: 'bold'}}))
1700
+ // .onOK(() => possibleTechnologies = [technology.value])
1701
+ // .onCancel(() => {
1702
+ // possibleTechnologies = [possibleTechnologies[0]];
1703
+ // grok.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);
1704
+ // })
1705
+ // .show();
1706
+ // } else if (possibleTechnologies.length == 0)
1707
+ if (possibleTechnologies.length == 0)
1708
+ return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };
1709
+ outputIndex = 0;
1710
+ possibleTechnologies.forEach((technology) => {
1711
+ const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[possibleSynthesizers[0]][technology]);
1712
+ while (outputIndex < sequence.length) {
1713
+ const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
1714
+ if (matchedCode == null)
1715
+ break;
1716
+ if ( // for mistake pattern 'rAA'
1717
+ outputIndex > 1 &&
1718
+ nucleotides.includes(sequence[outputIndex]) &&
1719
+ firstUniqueCharacters.includes(sequence[outputIndex - 2]))
1720
+ break;
1721
+ if ( // for mistake pattern 'ArA'
1722
+ firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
1723
+ nucleotides.includes(sequence[outputIndex])) {
1724
+ outputIndex++;
1725
+ break;
1726
+ }
1727
+ outputIndex += matchedCode.length;
1728
+ }
1729
+ });
1730
+ return {
1731
+ indexOfFirstNotValidChar: indexOfFirstNotValidChar,
1732
+ synthesizer: possibleSynthesizers,
1733
+ technology: [possibleTechnologies[outputIndex]],
1734
+ };
1735
+ }
1736
+ function getAllCodesOfSynthesizer(synthesizer) {
1737
+ let codes = [];
1738
+ for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer]))
1739
+ codes = codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology]));
1740
+ return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS));
1741
+ }
1742
+ function getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {
1743
+ const synthesizers = [];
1744
+ Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map).forEach((synthesizer) => {
1745
+ const codes = getAllCodesOfSynthesizer(synthesizer);
1746
+ //TODO: get first non-dropdown code when there are two modifications
1747
+ let start = 0;
1748
+ for (let i = 0; i < sequence.length; i++) {
1749
+ if (sequence[i] == ')' && i != sequence.length - 1) {
1750
+ start = i + 1;
1751
+ break;
1752
+ }
1753
+ }
1754
+ if (codes.some((s) => s == sequence.slice(start, start + s.length)))
1755
+ synthesizers.push(synthesizer);
1756
+ });
1757
+ return synthesizers;
1758
+ }
1759
+ function getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {
1760
+ const technologies = [];
1761
+ Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer]).forEach((technology) => {
1762
+ const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology]).concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS));
1763
+ if (codes.some((s) => s == sequence.slice(0, s.length)))
1764
+ technologies.push(technology);
1765
+ });
1766
+ return technologies;
1767
+ }
1768
+ function convertSequence(sequence, output) {
1769
+ if (output.indexOfFirstNotValidChar != -1) {
1770
+ return {
1771
+ // type: '',
1772
+ indexOfFirstNotValidChar: JSON.stringify(output),
1773
+ Error: undefinedInputSequence,
1774
+ };
1775
+ }
1776
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.RAW_NUCLEOTIDES)) { //&& output.technology!.includes(TECHNOLOGIES.DNA)) {
1777
+ return {
1778
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.RAW_NUCLEOTIDES,
1779
+ Nucleotides: sequence,
1780
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.asoGapmersNucleotidesToBioSpring)(sequence),
1781
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.asoGapmersNucleotidesToGcrs)(sequence),
1782
+ };
1783
+ }
1784
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.BIOSPRING) && output.technology.includes(_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.ASO_GAPMERS)) {
1785
+ return {
1786
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.BIOSPRING + ' ' + _map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.ASO_GAPMERS,
1787
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.asoGapmersBioSpringToNucleotides)(sequence),
1788
+ BioSpring: sequence,
1789
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.asoGapmersBioSpringToGcrs)(sequence),
1790
+ };
1791
+ }
1792
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.GCRS) && output.technology.includes(_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.ASO_GAPMERS)) {
1793
+ return {
1794
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.GCRS + ' ' + _map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.ASO_GAPMERS,
1795
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.asoGapmersGcrsToNucleotides)(sequence),
1796
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.asoGapmersGcrsToBioSpring)(sequence),
1797
+ Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToMermade12)(sequence),
1798
+ GCRS: sequence,
1799
+ };
1800
+ }
1801
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.RAW_NUCLEOTIDES) && output.technology.includes(_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.RNA)) {
1802
+ return {
1803
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + _map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.RNA,
1804
+ Nucleotides: sequence,
1805
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaNucleotideToBioSpringSenseStrand)(sequence),
1806
+ Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaNucleotideToAxolabsSenseStrand)(sequence),
1807
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaNucleotidesToGcrs)(sequence),
1808
+ };
1809
+ }
1810
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.BIOSPRING) && output.technology.includes(_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA)) {
1811
+ return {
1812
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.BIOSPRING + ' ' + _map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA,
1813
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaBioSpringToNucleotides)(sequence),
1814
+ BioSpring: sequence,
1815
+ Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaBioSpringToAxolabs)(sequence),
1816
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaBioSpringToGcrs)(sequence),
1817
+ };
1818
+ }
1819
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS)) {
1820
+ return {
1821
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS + ' ' + _map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA,
1822
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaAxolabsToNucleotides)(sequence),
1823
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaAxolabsToBioSpring)(sequence),
1824
+ Axolabs: sequence,
1825
+ GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaAxolabsToGcrs)(sequence),
1826
+ };
1827
+ }
1828
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.GCRS) && output.technology.includes(_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA)) {
1829
+ return {
1830
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.GCRS + ' ' + _map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA,
1831
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaGcrsToNucleotides)(sequence),
1832
+ BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaGcrsToBioSpring)(sequence),
1833
+ Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.siRnaGcrsToAxolabs)(sequence),
1834
+ MM12: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToMermade12)(sequence),
1835
+ GCRS: sequence,
1836
+ };
1837
+ }
1838
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.GCRS)) {
1839
+ return {
1840
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.GCRS,
1841
+ Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToNucleotides)(sequence),
1842
+ GCRS: sequence,
1843
+ Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_1__.gcrsToMermade12)(sequence),
1844
+ };
1845
+ }
1846
+ if (output.synthesizer.includes(_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12)) {
1847
+ return {
1848
+ type: _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12,
1849
+ Nucleotides: noTranslationTableAvailable,
1850
+ GCRS: noTranslationTableAvailable,
1851
+ Mermade12: sequence,
1852
+ };
1853
+ }
1854
+ return {
1855
+ type: undefinedInputSequence,
1856
+ Nucleotides: undefinedInputSequence,
1857
+ };
1858
+ }
1859
+
1860
+
1861
+ /***/ }),
1862
+
1863
+ /***/ "./src/tests/smiles-tests.ts":
1864
+ /*!***********************************!*\
1865
+ !*** ./src/tests/smiles-tests.ts ***!
1866
+ \***********************************/
1867
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1868
+
1869
+ __webpack_require__.r(__webpack_exports__);
1870
+ /* harmony import */ var _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @datagrok-libraries/utils/src/test */ "./node_modules/@datagrok-libraries/utils/src/test.js");
1871
+ /* harmony import */ var _structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../structures-works/from-monomers */ "./src/structures-works/from-monomers.ts");
1872
+ /* harmony import */ var _structures_works_map__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../structures-works/map */ "./src/structures-works/map.ts");
1873
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
1874
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1875
+ return new (P || (P = Promise))(function (resolve, reject) {
1876
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
1877
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
1878
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
1879
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
1880
+ });
1881
+ };
1882
+
1883
+
1884
+
1885
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.category)('sequence-translator', () => {
1886
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('AGGTCCTCTTGACTTAGGCC', () => __awaiter(void 0, void 0, void 0, function* () {
1887
+ const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
1888
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1889
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1890
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1891
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1892
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1893
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1894
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1895
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1896
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1897
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1898
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
1899
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
1900
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1901
+ 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
1902
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
1903
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1904
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1905
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O';
1906
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('AGGTCCTCTTGACTTAGGCC', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES), expected);
1907
+ }));
1908
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac1', () => __awaiter(void 0, void 0, void 0, function* () {
1909
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1910
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1911
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1912
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
1913
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1914
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1915
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1916
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgg(invabasic)(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1917
+ }));
1918
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac2', () => __awaiter(void 0, void 0, void 0, function* () {
1919
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1920
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1921
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1922
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
1923
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1924
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1925
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1926
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgsg(invabasic)(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1927
+ }));
1928
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac3', () => __awaiter(void 0, void 0, void 0, function* () {
1929
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1930
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1931
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1932
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
1933
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1934
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1935
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1936
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sggs(invabasic)(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1937
+ }));
1938
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac4', () => __awaiter(void 0, void 0, void 0, function* () {
1939
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1940
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1941
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1942
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
1943
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1944
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
1945
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
1946
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgg(invabasic)s(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1947
+ }));
1948
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('usCfCfUfGfAf', () => __awaiter(void 0, void 0, void 0, function* () {
1949
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1950
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1951
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1952
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1953
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1954
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O';
1955
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('usCfCfUfGfAf', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1956
+ }));
1957
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('usAfsusgsgsg', () => __awaiter(void 0, void 0, void 0, function* () {
1958
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1959
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
1960
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1961
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1962
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1963
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
1964
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('usAfsusgsgsg', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1965
+ }));
1966
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('UfUfUfsCfsuacg', () => __awaiter(void 0, void 0, void 0, function* () {
1967
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1968
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1969
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
1970
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
1971
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1972
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1973
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1974
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
1975
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('UfUfUfsCfsuacg', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1976
+ }));
1977
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('susususauasu', () => __awaiter(void 0, void 0, void 0, function* () {
1978
+ const expected = 'OP(=O)(S)OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1979
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1980
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
1981
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1982
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1983
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
1984
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';
1985
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('susususauasu', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1986
+ }));
1987
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('CfGfCfsGfsCf', () => __awaiter(void 0, void 0, void 0, function* () {
1988
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
1989
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
1990
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
1991
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
1992
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O';
1993
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('CfGfCfsGfsCf', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
1994
+ }));
1995
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('acacacsacsac', () => __awaiter(void 0, void 0, void 0, function* () {
1996
+ const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1997
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
1998
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
1999
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2000
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2001
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2002
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2003
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2004
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2005
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';
2006
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('acacacsacsac', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2007
+ }));
2008
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('cccgggusug', () => __awaiter(void 0, void 0, void 0, function* () {
2009
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2010
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2011
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2012
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2013
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2014
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2015
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2016
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2017
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
2018
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('cccgggusug', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2019
+ }));
2020
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('UfAfCfGfGfCfAfUf', () => __awaiter(void 0, void 0, void 0, function* () {
2021
+ const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2022
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2023
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2024
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2025
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2026
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2027
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2028
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
2029
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('UfAfCfGfGfCfAfUf', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2030
+ }));
2031
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sucuCfuUf', () => __awaiter(void 0, void 0, void 0, function* () {
2032
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2033
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2034
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2035
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2036
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2037
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2038
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
2039
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sucuCfuUf', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2040
+ }));
2041
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sAfgcugUf', () => __awaiter(void 0, void 0, void 0, function* () {
2042
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2043
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2044
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2045
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2046
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2047
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2048
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
2049
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sAfgcugUf', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2050
+ }));
2051
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)cuCfuUfsc', () => __awaiter(void 0, void 0, void 0, function* () {
2052
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2053
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2054
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2055
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2056
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2057
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
2058
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';
2059
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)cuCfuUfsc', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2060
+ }));
2061
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scususu(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2062
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2063
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2064
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2065
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2066
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2067
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2068
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2069
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2070
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scususu(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2071
+ }));
2072
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu', () => __awaiter(void 0, void 0, void 0, function* () {
2073
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2074
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2075
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
2076
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2077
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2078
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2079
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2080
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2081
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2082
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2083
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2084
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2085
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2086
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2087
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2088
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2089
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2090
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2091
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2092
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2093
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2094
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';
2095
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2096
+ }));
2097
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)asacgGfuGfCfAfacucuauuca', () => __awaiter(void 0, void 0, void 0, function* () {
2098
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2099
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2100
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2101
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2102
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2103
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2104
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2105
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2106
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2107
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2108
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2109
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2110
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2111
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2112
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2113
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2114
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2115
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2116
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2117
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2118
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)asacgGfuGfCfAfacucuauuca', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2119
+ }));
2120
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsgguGfcAfAfCfucuauucuga', () => __awaiter(void 0, void 0, void 0, function* () {
2121
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2122
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2123
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2124
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2125
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2126
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2127
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2128
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2129
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2130
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2131
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2132
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2133
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2134
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2135
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2136
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2137
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2138
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2139
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2140
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2141
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsgguGfcAfAfCfucuauucuga', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2142
+ }));
2143
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsaacUfcUfAfUfucuggacuua', () => __awaiter(void 0, void 0, void 0, function* () {
2144
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2145
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2146
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2147
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2148
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2149
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2150
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2151
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2152
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2153
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2154
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2155
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2156
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2157
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2158
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2159
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2160
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2161
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2162
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2163
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2164
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsaacUfcUfAfUfucuggacuua', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2165
+ }));
2166
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasacuCfuAfUfUfcuggacuuua', () => __awaiter(void 0, void 0, void 0, function* () {
2167
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2168
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2169
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2170
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2171
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2172
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2173
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2174
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2175
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2176
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2177
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2178
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2179
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2180
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2181
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2182
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2183
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2184
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2185
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2186
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
2187
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasacuCfuAfUfUfcuggacuuua', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2188
+ }));
2189
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2190
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2191
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2192
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
2193
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2194
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2195
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2196
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2197
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2198
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2199
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2200
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2201
+ }));
2202
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2203
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2204
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2205
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2206
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2207
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2208
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2209
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2210
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2211
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2212
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2213
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2214
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2215
+ }));
2216
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2217
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2218
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
2219
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2220
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2221
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2222
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2223
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2224
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2225
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2226
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2227
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2228
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2229
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2230
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2231
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2232
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2233
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2234
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2235
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2236
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2237
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2238
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2239
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2240
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2241
+ }));
2242
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2243
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2244
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2245
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2246
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2247
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2248
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2249
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2250
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2251
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2252
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2253
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
2254
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2255
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2256
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2257
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2258
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2259
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2260
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2261
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2262
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2263
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2264
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2265
+ 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
2266
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2267
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2268
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2269
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2270
+ }));
2271
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
2272
+ const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
2273
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
2274
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2275
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2276
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2277
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2278
+ 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2279
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2280
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2281
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
2282
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2283
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2284
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2285
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2286
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2287
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2288
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2289
+ 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2290
+ 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
2291
+ 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
2292
+ 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2293
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
2294
+ '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
2295
+ (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', false, _structures_works_map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS), expected);
2296
+ }));
2297
+ });
2298
+
2299
+
2300
+ /***/ }),
2301
+
2302
+ /***/ "datagrok-api/dg":
2303
+ /*!*********************!*\
2304
+ !*** external "DG" ***!
2305
+ \*********************/
2306
+ /***/ ((module) => {
2307
+
2308
+ module.exports = DG;
2309
+
2310
+ /***/ }),
2311
+
2312
+ /***/ "openchemlib/full.js":
2313
+ /*!**********************!*\
2314
+ !*** external "OCL" ***!
2315
+ \**********************/
2316
+ /***/ ((module) => {
2317
+
2318
+ module.exports = OCL;
2319
+
2320
+ /***/ }),
2321
+
2322
+ /***/ "datagrok-api/grok":
2323
+ /*!***********************!*\
2324
+ !*** external "grok" ***!
2325
+ \***********************/
2326
+ /***/ ((module) => {
2327
+
2328
+ module.exports = grok;
2329
+
2330
+ /***/ })
2331
+
2332
+ /******/ });
2333
+ /************************************************************************/
2334
+ /******/ // The module cache
2335
+ /******/ var __webpack_module_cache__ = {};
2336
+ /******/
2337
+ /******/ // The require function
2338
+ /******/ function __webpack_require__(moduleId) {
2339
+ /******/ // Check if module is in cache
2340
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
2341
+ /******/ if (cachedModule !== undefined) {
2342
+ /******/ return cachedModule.exports;
2343
+ /******/ }
2344
+ /******/ // Create a new module (and put it into the cache)
2345
+ /******/ var module = __webpack_module_cache__[moduleId] = {
2346
+ /******/ // no module.id needed
2347
+ /******/ // no module.loaded needed
2348
+ /******/ exports: {}
2349
+ /******/ };
2350
+ /******/
2351
+ /******/ // Execute the module function
2352
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
2353
+ /******/
2354
+ /******/ // Return the exports of the module
2355
+ /******/ return module.exports;
2356
+ /******/ }
2357
+ /******/
2358
+ /************************************************************************/
2359
+ /******/ /* webpack/runtime/compat get default export */
2360
+ /******/ (() => {
2361
+ /******/ // getDefaultExport function for compatibility with non-harmony modules
2362
+ /******/ __webpack_require__.n = (module) => {
2363
+ /******/ var getter = module && module.__esModule ?
2364
+ /******/ () => (module['default']) :
2365
+ /******/ () => (module);
2366
+ /******/ __webpack_require__.d(getter, { a: getter });
2367
+ /******/ return getter;
2368
+ /******/ };
2369
+ /******/ })();
2370
+ /******/
2371
+ /******/ /* webpack/runtime/define property getters */
2372
+ /******/ (() => {
2373
+ /******/ // define getter functions for harmony exports
2374
+ /******/ __webpack_require__.d = (exports, definition) => {
2375
+ /******/ for(var key in definition) {
2376
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
2377
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
2378
+ /******/ }
2379
+ /******/ }
2380
+ /******/ };
2381
+ /******/ })();
2382
+ /******/
2383
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
2384
+ /******/ (() => {
2385
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
2386
+ /******/ })();
2387
+ /******/
2388
+ /******/ /* webpack/runtime/make namespace object */
2389
+ /******/ (() => {
2390
+ /******/ // define __esModule on exports
2391
+ /******/ __webpack_require__.r = (exports) => {
2392
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
2393
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2394
+ /******/ }
2395
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
2396
+ /******/ };
2397
+ /******/ })();
2398
+ /******/
2399
+ /************************************************************************/
2400
+ var __webpack_exports__ = {};
2401
+ // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
2402
+ (() => {
2403
+ /*!*****************************!*\
2404
+ !*** ./src/package-test.ts ***!
2405
+ \*****************************/
2406
+ __webpack_require__.r(__webpack_exports__);
2407
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
2408
+ /* harmony export */ "_package": () => (/* binding */ _package),
2409
+ /* harmony export */ "tests": () => (/* reexport safe */ _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__.tests),
2410
+ /* harmony export */ "test": () => (/* binding */ test)
2411
+ /* harmony export */ });
2412
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
2413
+ /* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__);
2414
+ /* harmony import */ var _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @datagrok-libraries/utils/src/test */ "./node_modules/@datagrok-libraries/utils/src/test.js");
2415
+ /* harmony import */ var _tests_smiles_tests__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tests/smiles-tests */ "./src/tests/smiles-tests.ts");
2416
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
2417
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
2418
+ return new (P || (P = Promise))(function (resolve, reject) {
2419
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
2420
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
2421
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
2422
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
2423
+ });
2424
+ };
2425
+
2426
+
2427
+
2428
+ const _package = new datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.Package();
2429
+
2430
+ //name: test
2431
+ //output: dataframe result
2432
+ function test() {
2433
+ return __awaiter(this, void 0, void 0, function* () {
2434
+ const data = yield (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__.runTests)();
2435
+ return datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.DataFrame.fromObjects(data);
2436
+ });
2437
+ }
2438
+
2439
+ })();
2440
+
2441
+ sequencetranslator_test = __webpack_exports__;
2442
+ /******/ })()
2443
+ ;
2444
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,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O0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDTztBQUNQO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDTztBQUNBO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2IsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYixTQUFTO0FBQ1QsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiLFNBQVM7QUFDVCxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiLFNBQVM7QUFDVCxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYixTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2IsU0FBUztBQUNULEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYixTQUFTO0FBQ1QsS0FBSztBQUNMOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUMvaUIyQztBQUMzQztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ087QUFDUDtBQUNBLG9CQUFv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V0FDQSx5Q0FBeUMsd0NBQXdDO1dBQ2pGO1dBQ0E7V0FDQTs7Ozs7V0NQQTs7Ozs7V0NBQTtXQUNBO1dBQ0E7V0FDQSx1REFBdUQsaUJBQWlCO1dBQ3hFO1dBQ0EsZ0RBQWdELGFBQWE7V0FDN0Q7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FDTkEsaUJBQWlCLFNBQUksSUFBSSxTQUFJO0FBQzdCLDRCQUE0QiwrREFBK0QsaUJBQWlCO0FBQzVHO0FBQ0Esb0NBQW9DLE1BQU0sK0JBQStCLFlBQVk7QUFDckYsbUNBQW1DLE1BQU0sbUNBQW1DLFlBQVk7QUFDeEYsZ0NBQWdDO0FBQ2hDO0FBQ0EsS0FBSztBQUNMO0FBQ3NDO0FBQytCO0FBQ3ZDO0FBQ3ZCLHFCQUFxQixvREFBVTtBQUNyQjtBQUNqQjtBQUNBO0FBQ087QUFDUDtBQUNBLDJCQUEyQiw0RUFBUTtBQUNuQyxlQUFlLGtFQUF3QjtBQUN2QyxLQUFLO0FBQ0wiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9zZXF1ZW5jZXRyYW5zbGF0b3IvLi9ub2RlX21vZHVsZXMvQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvdGVzdC5qcyIsIndlYnBhY2s6Ly9zZXF1ZW5jZXRyYW5zbGF0b3IvLi9zcmMvc3RydWN0dXJlcy13b3Jrcy9jb252ZXJ0ZXJzLnRzIiwid2VicGFjazovL3NlcXVlbmNldHJhbnNsYXRvci8uL3NyYy9zdHJ1Y3R1cmVzLXdvcmtzL2Zyb20tbW9ub21lcnMudHMiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yLy4vc3JjL3N0cnVjdHVyZXMtd29ya3MvbWFwLnRzIiwid2VicGFjazovL3NlcXVlbmNldHJhbnNsYXRvci8uL3NyYy9zdHJ1Y3R1cmVzLXdvcmtzL21vbC10cmFuc2Zvcm1hdGlvbnMudHMiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yLy4vc3JjL3N0cnVjdHVyZXMtd29ya3Mvc2VxdWVuY2UtY29kZXMtdG9vbHMudHMiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yLy4vc3JjL3Rlc3RzL3NtaWxlcy10ZXN0cy50cyIsIndlYnBhY2s6Ly9zZXF1ZW5jZXRyYW5zbGF0b3IvZXh0ZXJuYWwgdmFyIFwiREdcIiIsIndlYnBhY2s6Ly9zZXF1ZW5jZXRyYW5zbGF0b3IvZXh0ZXJuYWwgdmFyIFwiT0NMXCIiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yL2V4dGVybmFsIHZhciBcImdyb2tcIiIsIndlYnBhY2s6Ly9zZXF1ZW5jZXRyYW5zbGF0b3Ivd2VicGFjay9ib290c3RyYXAiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yL3dlYnBhY2svcnVudGltZS9jb21wYXQgZ2V0IGRlZmF1bHQgZXhwb3J0Iiwid2VicGFjazovL3NlcXVlbmNldHJhbnNsYXRvci93ZWJwYWNrL3J1bnRpbWUvZGVmaW5lIHByb3BlcnR5IGdldHRlcnMiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yL3dlYnBhY2svcnVudGltZS9oYXNPd25Qcm9wZXJ0eSBzaG9ydGhhbmQiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yL3dlYnBhY2svcnVudGltZS9tYWtlIG5hbWVzcGFjZSBvYmplY3QiLCJ3ZWJwYWNrOi8vc2VxdWVuY2V0cmFuc2xhdG9yLy4vc3JjL3BhY2thZ2UtdGVzdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgX19hd2FpdGVyID0gKHRoaXMgJiYgdGhpcy5fX2F3YWl0ZXIpIHx8IGZ1bmN0aW9uICh0aGlzQXJnLCBfYXJndW1lbnRzLCBQLCBnZW5lcmF0b3IpIHtcbiAgICBmdW5jdGlvbiBhZG9wdCh2YWx1ZSkgeyByZXR1cm4gdmFsdWUgaW5zdGFuY2VvZiBQID8gdmFsdWUgOiBuZXcgUChmdW5jdGlvbiAocmVzb2x2ZSkgeyByZXNvbHZlKHZhbHVlKTsgfSk7IH1cbiAgICByZXR1cm4gbmV3IChQIHx8IChQID0gUHJvbWlzZSkpKGZ1bmN0aW9uIChyZXNvbHZlLCByZWplY3QpIHtcbiAgICAgICAgZnVuY3Rpb24gZnVsZmlsbGVkKHZhbHVlKSB7IHRyeSB7IHN0ZXAoZ2VuZXJhdG9yLm5leHQodmFsdWUpKTsgfSBjYXRjaCAoZSkgeyByZWplY3QoZSk7IH0gfVxuICAgICAgICBmdW5jdGlvbiByZWplY3RlZCh2YWx1ZSkgeyB0cnkgeyBzdGVwKGdlbmVyYXRvcltcInRocm93XCJdKHZhbHVlKSk7IH0gY2F0Y2ggKGUpIHsgcmVqZWN0KGUpOyB9IH1cbiAgICAgICAgZnVuY3Rpb24gc3RlcChyZXN1bHQpIHsgcmVzdWx0LmRvbmUgPyByZXNvbHZlKHJlc3VsdC52YWx1ZSkgOiBhZG9wdChyZXN1bHQudmFsdWUpLnRoZW4oZnVsZmlsbGVkLCByZWplY3RlZCk7IH1cbiAgICAgICAgc3RlcCgoZ2VuZXJhdG9yID0gZ2VuZXJhdG9yLmFwcGx5KHRoaXNBcmcsIF9hcmd1bWVudHMgfHwgW10pKS5uZXh0KCkpO1xuICAgIH0pO1xufTtcbmltcG9ydCAqIGFzIGdyb2sgZnJvbSBcImRhdGFncm9rLWFwaS9ncm9rXCI7XG5leHBvcnQgbGV0IHRlc3RzID0ge307XG5leHBvcnQgbGV0IGN1cnJlbnRDYXRlZ29yeTtcbmV4cG9ydCB2YXIgYXNzdXJlO1xuKGZ1bmN0aW9uIChhc3N1cmUpIHtcbiAgICBmdW5jdGlvbiBub3ROdWxsKHZhbHVlLCBuYW1lKSB7XG4gICAgICAgIGlmICh2YWx1ZSA9PSBudWxsKVxuICAgICAgICAgICAgdGhyb3cgYCR7bmFtZSA9PSBudWxsID8gJ1ZhbHVlJyA6IG5hbWV9IG5vdCBkZWZpbmVkYDtcbiAgICB9XG4gICAgYXNzdXJlLm5vdE51bGwgPSBub3ROdWxsO1xufSkoYXNzdXJlIHx8IChhc3N1cmUgPSB7fSkpO1xuZXhwb3J0IGNsYXNzIFRlc3Qge1xuICAgIGNvbnN0cnVjdG9yKGNhdGVnb3J5LCBuYW1lLCB0ZXN0LCBvcHRpb25zKSB7XG4gICAgICAgIHZhciBfYSwgX2I7XG4gICAgICAgIHRoaXMuY2F0ZWdvcnkgPSBjYXRlZ29yeTtcbiAgICAgICAgdGhpcy5uYW1lID0gbmFtZTtcbiAgICAgICAgb3B0aW9ucyAhPT0gbnVsbCAmJiBvcHRpb25zICE9PSB2b2lkIDAgPyBvcHRpb25zIDogKG9wdGlvbnMgPSB7fSk7XG4gICAgICAgIChfYSA9IG9wdGlvbnMudGltZW91dCkgIT09IG51bGwgJiYgX2EgIT09IHZvaWQgMCA/IF9hIDogKG9wdGlvbnMudGltZW91dCA9IDMwMDAwKTtcbiAgICAgICAgKF9iID0gb3B0aW9ucy51bmhhbmRsZWRFeGNlcHRpb25UaW1lb3V0KSAhPT0gbnVsbCAmJiBfYiAhPT0gdm9pZCAwID8gX2IgOiAob3B0aW9ucy51bmhhbmRsZWRFeGNlcHRpb25UaW1lb3V0ID0gMjAwMCk7XG4gICAgICAgIHRoaXMub3B0aW9ucyA9IG9wdGlvbnM7XG4gICAgICAgIHRoaXMudGVzdCA9ICgpID0+IF9fYXdhaXRlcih0aGlzLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiBfX2F3YWl0ZXIodGhpcywgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgICAgICAgICAgbGV0IHJlc3VsdCA9ICcnO1xuICAgICAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgICAgIGdyb2suc2hlbGwubGFzdEVycm9yID0gJyc7XG4gICAgICAgICAgICAgICAgICAgIHJlc3VsdCA9IHlpZWxkIHRlc3QoKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgICAgICAgICAgcmVqZWN0KGUpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBpZiAoISh5aWVsZCBhc3NlcnROb0Vycm9yKG9wdGlvbnMudW5oYW5kbGVkRXhjZXB0aW9uVGltZW91dCkpKVxuICAgICAgICAgICAgICAgICAgICByZWplY3QoYFVuaGFuZGxlZCBleGNlcHRpb24gZHVyaW5nIHRlc3Q6ICR7Z3Jvay5zaGVsbC5sYXN0RXJyb3J9YCk7XG4gICAgICAgICAgICAgICAgcmVzb2x2ZShyZXN1bHQpO1xuICAgICAgICAgICAgfSkpO1xuICAgICAgICB9KTtcbiAgICB9XG59XG5leHBvcnQgZnVuY3Rpb24gdGVzdChuYW1lLCB0ZXN0LCBvcHRpb25zKSB7XG4gICAgaWYgKHRlc3RzW2N1cnJlbnRDYXRlZ29yeV0gPT0gdW5kZWZpbmVkKVxuICAgICAgICB0ZXN0c1tjdXJyZW50Q2F0ZWdvcnldID0ge307XG4gICAgaWYgKHRlc3RzW2N1cnJlbnRDYXRlZ29yeV0udGVzdHMgPT0gdW5kZWZpbmVkKVxuICAgICAgICB0ZXN0c1tjdXJyZW50Q2F0ZWdvcnldLnRlc3RzID0gW107XG4gICAgdGVzdHNbY3VycmVudENhdGVnb3J5XS50ZXN0cy5wdXNoKG5ldyBUZXN0KGN1cnJlbnRDYXRlZ29yeSwgbmFtZSwgdGVzdCwgb3B0aW9ucykpO1xufVxuLyoqIEF3YWl0cyBmb3IgYSB3aGlsZSBjaGVja2luZyB0aGUgZXJyb3Igc3RhdHVzIG9mIHRoZSBwbGF0Zm9ybSAqL1xuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydE5vRXJyb3IobXMpIHtcbiAgICByZXR1cm4gX19hd2FpdGVyKHRoaXMsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IG1zIC8gNTAwOyArK2kpIHtcbiAgICAgICAgICAgIHlpZWxkIGRlbGF5KDUwMCk7XG4gICAgICAgICAgICBpZiAoZ3Jvay5zaGVsbC5sYXN0RXJyb3IubGVuZ3RoICE9PSAwKVxuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9KTtcbn1cbi8qKiBUZXN0cyB0d28gb2JqZWN0cyBmb3IgZXF1YWxpdHksIHRocm93cyBhbiBleGNlcHRpb24gaWYgdGhleSBhcmUgbm90IGVxdWFsLiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGV4cGVjdChhY3R1YWwsIGV4cGVjdGVkKSB7XG4gICAgaWYgKGFjdHVhbCAhPT0gZXhwZWN0ZWQpXG4gICAgICAgIHRocm93IGBFeHBlY3RlZCBcIiR7ZXhwZWN0ZWR9XCIsIGdvdCBcIiR7YWN0dWFsfVwiYDtcbn1cbmV4cG9ydCBmdW5jdGlvbiBleHBlY3RGbG9hdChhY3R1YWwsIGV4cGVjdGVkLCB0b2xlcmFuY2UgPSAwLjAwMSkge1xuICAgIGNvbnN0IGFyZUVxdWFsID0gTWF0aC5hYnMoYWN0dWFsIC0gZXhwZWN0ZWQpIDwgMC4wMDE7XG4gICAgaWYgKCFhcmVFcXVhbClcbiAgICAgICAgdGhyb3cgYEV4cGVjdGVkICR7ZXhwZWN0ZWR9LCBnb3QgJHthY3R1YWx9ICh0b2xlcmFuY2UgPSAke3RvbGVyYW5jZX0pYDtcbn1cbi8qKiBEZWZpbmVzIGEgdGVzdCBzdWl0ZS4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjYXRlZ29yeShjYXRlZ29yeSwgdGVzdHMpIHtcbiAgICBjdXJyZW50Q2F0ZWdvcnkgPSBjYXRlZ29yeTtcbiAgICB0ZXN0cygpO1xufVxuLyoqIERlZmluZXMgYSBmdW5jdGlvbiB0byBiZSBleGVjdXRlZCBiZWZvcmUgdGhlIHRlc3RzIGluIHRoaXMgY2F0ZWdvcnkgYXJlIGV4ZWN1dGVkLiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGJlZm9yZShiZWZvcmUpIHtcbiAgICBpZiAodGVzdHNbY3VycmVudENhdGVnb3J5XSA9PSB1bmRlZmluZWQpXG4gICAgICAgIHRlc3RzW2N1cnJlbnRDYXRlZ29yeV0gPSB7fTtcbiAgICB0ZXN0c1tjdXJyZW50Q2F0ZWdvcnldLmJlZm9yZSA9IGJlZm9yZTtcbn1cbi8qKiBEZWZpbmVzIGEgZnVuY3Rpb24gdG8gYmUgZXhlY3V0ZWQgYWZ0ZXIgdGhlIHRlc3RzIGluIHRoaXMgY2F0ZWdvcnkgYXJlIGV4ZWN1dGVkLiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGFmdGVyKGFmdGVyKSB7XG4gICAgaWYgKHRlc3RzW2N1cnJlbnRDYXRlZ29yeV0gPT0gdW5kZWZpbmVkKVxuICAgICAgICB0ZXN0c1tjdXJyZW50Q2F0ZWdvcnldID0ge307XG4gICAgdGVzdHNbY3VycmVudENhdGVnb3J5XS5hZnRlciA9IGFmdGVyO1xufVxuZXhwb3J0IGZ1bmN0aW9uIHJ1blRlc3RzKG9wdGlvbnMpIHtcbiAgICB2YXIgX2E7XG4gICAgcmV0dXJuIF9fYXdhaXRlcih0aGlzLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgbGV0IHJlc3VsdHMgPSBbXTtcbiAgICAgICAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXModGVzdHMpKSB7XG4gICAgICAgICAgICBpZiAoKG9wdGlvbnMgPT09IG51bGwgfHwgb3B0aW9ucyA9PT0gdm9pZCAwID8gdm9pZCAwIDogb3B0aW9ucy5jYXRlZ29yeSkgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgICAgaWYgKCFrZXkudG9Mb3dlckNhc2UoKS5zdGFydHNXaXRoKG9wdGlvbnMgPT09IG51bGwgfHwgb3B0aW9ucyA9PT0gdm9pZCAwID8gdm9pZCAwIDogb3B0aW9ucy5jYXRlZ29yeS50b0xvd2VyQ2FzZSgpKSlcbiAgICAgICAgICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgIGlmICh2YWx1ZS5iZWZvcmUpXG4gICAgICAgICAgICAgICAgICAgIHlpZWxkIHZhbHVlLmJlZm9yZSgpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgY2F0Y2ggKHgpIHtcbiAgICAgICAgICAgICAgICB2YWx1ZS5iZWZvcmVTdGF0dXMgPSB4LnRvU3RyaW5nKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBsZXQgdCA9IChfYSA9IHZhbHVlLnRlc3RzKSAhPT0gbnVsbCAmJiBfYSAhPT0gdm9pZCAwID8gX2EgOiBbXTtcbiAgICAgICAgICAgIGxldCByZXMgPSBbXTtcbiAgICAgICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdC5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgICAgIHJlcy5wdXNoKHlpZWxkIGV4ZWNUZXN0KHRbaV0sIG9wdGlvbnMgPT09IG51bGwgfHwgb3B0aW9ucyA9PT0gdm9pZCAwID8gdm9pZCAwIDogb3B0aW9ucy50ZXN0KSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBsZXQgZGF0YSA9ICh5aWVsZCBQcm9taXNlLmFsbChyZXMpKS5maWx0ZXIoKGQpID0+IGQucmVzdWx0ICE9ICdza2lwcGVkJyk7XG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgIGlmICh2YWx1ZS5hZnRlcilcbiAgICAgICAgICAgICAgICAgICAgeWllbGQgdmFsdWUuYWZ0ZXIoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGNhdGNoICh4KSB7XG4gICAgICAgICAgICAgICAgdmFsdWUuYWZ0ZXJTdGF0dXMgPSB4LnRvU3RyaW5nKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAodmFsdWUuYWZ0ZXJTdGF0dXMpXG4gICAgICAgICAgICAgICAgZGF0YS5wdXNoKHsgY2F0ZWdvcnk6IGtleSwgbmFtZTogJ2luaXQnLCByZXN1bHQ6IHZhbHVlLmFmdGVyU3RhdHVzLCBzdWNjZXNzOiBmYWxzZSB9KTtcbiAgICAgICAgICAgIGlmICh2YWx1ZS5iZWZvcmVTdGF0dXMpXG4gICAgICAgICAgICAgICAgZGF0YS5wdXNoKHsgY2F0ZWdvcnk6IGtleSwgbmFtZTogJ2luaXQnLCByZXN1bHQ6IHZhbHVlLmJlZm9yZVN0YXR1cywgc3VjY2VzczogZmFsc2UgfSk7XG4gICAgICAgICAgICByZXN1bHRzLnB1c2goLi4uZGF0YSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHJlc3VsdHM7XG4gICAgfSk7XG59XG5mdW5jdGlvbiBleGVjVGVzdCh0LCBwcmVkaWNhdGUpIHtcbiAgICB2YXIgX2E7XG4gICAgcmV0dXJuIF9fYXdhaXRlcih0aGlzLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgbGV0IHI7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBpZiAocHJlZGljYXRlICE9IHVuZGVmaW5lZCAmJiAoIXQubmFtZS50b0xvd2VyQ2FzZSgpLnN0YXJ0c1dpdGgocHJlZGljYXRlLnRvTG93ZXJDYXNlKCkpKSlcbiAgICAgICAgICAgICAgICByID0geyBzdWNjZXNzOiB0cnVlLCByZXN1bHQ6ICdza2lwcGVkJyB9O1xuICAgICAgICAgICAgZWxzZVxuICAgICAgICAgICAgICAgIHIgPSB7IHN1Y2Nlc3M6IHRydWUsIHJlc3VsdDogKF9hID0geWllbGQgdC50ZXN0KCkpICE9PSBudWxsICYmIF9hICE9PSB2b2lkIDAgPyBfYSA6ICdPSycgfTtcbiAgICAgICAgfVxuICAgICAgICBjYXRjaCAoeCkge1xuICAgICAgICAgICAgciA9IHsgc3VjY2VzczogZmFsc2UsIHJlc3VsdDogeC50b1N0cmluZygpIH07XG4gICAgICAgIH1cbiAgICAgICAgci5jYXRlZ29yeSA9IHQuY2F0ZWdvcnk7XG4gICAgICAgIHIubmFtZSA9IHQubmFtZTtcbiAgICAgICAgcmV0dXJuIHI7XG4gICAgfSk7XG59XG5leHBvcnQgZnVuY3Rpb24gZGVsYXkobXMpIHtcbiAgICByZXR1cm4gX19hd2FpdGVyKHRoaXMsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICB5aWVsZCBuZXcgUHJvbWlzZShyID0+IHNldFRpbWVvdXQociwgbXMpKTtcbiAgICB9KTtcbn1cbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRhdGE6YXBwbGljYXRpb24vanNvbjtiYXNlNjQsZXlKMlpYSnphVzl1SWpvekxDSm1hV3hsSWpvaWRHVnpkQzVxY3lJc0luTnZkWEpqWlZKdmIzUWlPaUlpTENKemIzVnlZMlZ6SWpwYkluUmxjM1F1ZEhNaVhTd2libUZ0WlhNaU9sdGRMQ0p0WVhCd2FXNW5jeUk2SWpzN096czdPenM3TzBGQlFVRXNUMEZCVHl4TFFVRkxMRWxCUVVrc1RVRkJUU3h0UWtGQmJVSXNRMEZCUXp0QlFVVXhReXhOUVVGTkxFTkJRVU1zU1VGQlNTeExRVUZMTEVkQlFUaEpMRVZCUVVVc1EwRkJRenRCUVVWcVN5eE5RVUZOTEVOQlFVTXNTVUZCU1N4bFFVRjFRaXhEUVVGRE8wRkJSVzVETEUxQlFVMHNTMEZCVnl4TlFVRk5MRU5CVFhSQ08wRkJUa1FzVjBGQmFVSXNUVUZCVFR0SlFVVnlRaXhUUVVGblFpeFBRVUZQTEVOQlFVTXNTMEZCVlN4RlFVRkZMRWxCUVdFN1VVRkRMME1zU1VGQlNTeExRVUZMTEVsQlFVa3NTVUZCU1R0WlFVTm1MRTFCUVUwc1IwRkJSeXhKUVVGSkxFbEJRVWtzU1VGQlNTeERRVUZETEVOQlFVTXNRMEZCUXl4UFFVRlBMRU5CUVVNc1EwRkJReXhEUVVGRExFbEJRVWtzWTBGQll5eERRVUZETzBsQlEzcEVMRU5CUVVNN1NVRklaU3hqUVVGUExGVkJSM1JDTEVOQlFVRTdRVUZEU0N4RFFVRkRMRVZCVG1kQ0xFMUJRVTBzUzBGQlRpeE5RVUZOTEZGQlRYUkNPMEZCVDBRc1RVRkJUU3hQUVVGUExFbEJRVWs3U1VGTlppeFpRVUZaTEZGQlFXZENMRVZCUVVVc1NVRkJXU3hGUVVGRkxFbEJRWGRDTEVWQlFVVXNUMEZCY1VJN08xRkJRM3BHTEVsQlFVa3NRMEZCUXl4UlFVRlJMRWRCUVVjc1VVRkJVU3hEUVVGRE8xRkJRM3BDTEVsQlFVa3NRMEZCUXl4SlFVRkpMRWRCUVVjc1NVRkJTU3hEUVVGRE8xRkJRMnBDTEU5QlFVOHNZVUZCVUN4UFFVRlBMR05CUVZBc1QwRkJUeXhKUVVGUUxFOUJRVThzUjBGQlN5eEZRVUZGTEVWQlFVTTdVVUZEWml4TlFVRkJMRTlCUVU4c1EwRkJReXhQUVVGUExHOURRVUZtTEU5QlFVOHNRMEZCUXl4UFFVRlBMRWRCUVVzc1MwRkJTeXhGUVVGRE8xRkJRekZDTEUxQlFVRXNUMEZCVHl4RFFVRkRMSGxDUVVGNVFpeHZRMEZCYWtNc1QwRkJUeXhEUVVGRExIbENRVUY1UWl4SFFVRkxMRWxCUVVrc1JVRkJRenRSUVVNelF5eEpRVUZKTEVOQlFVTXNUMEZCVHl4SFFVRkhMRTlCUVU4c1EwRkJRenRSUVVOMlFpeEpRVUZKTEVOQlFVTXNTVUZCU1N4SFFVRkhMRWRCUVhWQ0xFVkJRVVU3V1VGRGJrTXNUMEZCVHl4SlFVRkpMRTlCUVU4c1EwRkJReXhEUVVGUExFOUJRVThzUlVGQlJTeE5RVUZOTEVWQlFVVXNSVUZCUlR0blFrRkRNME1zU1VGQlNTeE5RVUZOTEVkQlFVY3NSVUZCUlN4RFFVRkRPMmRDUVVOb1FpeEpRVUZKTzI5Q1FVTkdMRWxCUVVrc1EwRkJReXhMUVVGTExFTkJRVU1zVTBGQlV5eEhRVUZITEVWQlFVVXNRMEZCUXp0dlFrRkRNVUlzVFVGQlRTeEhRVUZITEUxQlFVMHNTVUZCU1N4RlFVRkZMRU5CUVVNN2FVSkJRM1pDTzJkQ1FVRkRMRTlCUVU4c1EwRkJUU3hGUVVGRk8yOUNRVU5tTEUxQlFVMHNRMEZCUXl4RFFVRkRMRU5CUVVNc1EwRkJRenRwUWtGRFdEdG5Ra0ZEUkN4SlFVRkpMRU5CUVVNc1EwRkJReXhOUVVGTkxHRkJRV0VzUTBGQlF5eFBRVUZSTEVOQlFVTXNlVUpCUVRCQ0xFTkJRVU1zUTBGQlF6dHZRa0ZETjBRc1RVRkJUU3hEUVVGRExHOURRVUZ2UXl4SlFVRkpMRU5CUVVNc1MwRkJTeXhEUVVGRExGTkJRVk1zUlVGQlJTeERRVUZETEVOQlFVTTdaMEpCUTNKRkxFOUJRVThzUTBGQlF5eE5RVUZOTEVOQlFVTXNRMEZCUXp0WlFVTnNRaXhEUVVGRExFTkJRVUVzUTBGQlF5eERRVUZETzFGQlEwd3NRMEZCUXl4RFFVRkJMRU5CUVVNN1NVRkRTaXhEUVVGRE8wTkJRMFk3UVVGRlJDeE5RVUZOTEZWQlFWVXNTVUZCU1N4RFFVRkRMRWxCUVZrc1JVRkJSU3hKUVVGM1FpeEZRVUZGTEU5QlFYRkNPMGxCUTJoR0xFbEJRVWtzUzBGQlN5eERRVUZETEdWQlFXVXNRMEZCUXl4SlFVRkpMRk5CUVZNN1VVRkRja01zUzBGQlN5eERRVUZETEdWQlFXVXNRMEZCUXl4SFFVRkhMRVZCUVVVc1EwRkJRenRKUVVNNVFpeEpRVUZKTEV0QlFVc3NRMEZCUXl4bFFVRmxMRU5CUVVNc1EwRkJReXhMUVVGTExFbEJRVWtzVTBGQlV6dFJRVU16UXl4TFFVRkxMRU5CUVVNc1pVRkJaU3hEUVVGRExFTkJRVU1zUzBGQlN5eEhRVUZITEVWQlFVVXNRMEZCUXp0SlFVTndReXhMUVVGTExFTkJRVU1zWlVGQlpTeERRVUZETEVOQlFVTXNTMEZCVFN4RFFVRkRMRWxCUVVrc1EwRkJReXhKUVVGSkxFbEJRVWtzUTBGQlF5eGxRVUZsTEVWQlFVVXNTVUZCU1N4RlFVRkZMRWxCUVVrc1JVRkJSU3hQUVVGUExFTkJRVU1zUTBGQlF5eERRVUZETzBGQlEzSkdMRU5CUVVNN1FVRkZSQ3h0UlVGQmJVVTdRVUZEYmtVc1RVRkJUU3hWUVVGblFpeGhRVUZoTEVOQlFVTXNSVUZCVlRzN1VVRkROVU1zUzBGQlN5eEpRVUZKTEVOQlFVTXNSMEZCUnl4RFFVRkRMRVZCUVVVc1EwRkJReXhIUVVGSExFVkJRVVVzUjBGQlJ5eEhRVUZITEVWQlFVVXNSVUZCUlN4RFFVRkRMRVZCUVVVN1dVRkRha01zVFVGQlRTeExRVUZMTEVOQlFVTXNSMEZCUnl4RFFVRkRMRU5CUVVNN1dVRkRha0lzU1VGQlNTeEpRVUZKTEVOQlFVTXNTMEZCU3l4RFFVRkRMRk5CUVZNc1EwRkJReXhOUVVGTkxFdEJRVXNzUTBGQlF6dG5Ra0ZEYmtNc1QwRkJUeXhMUVVGTExFTkJRVU03VTBGRGFFSTdVVUZEUkN4UFFVRlBMRWxCUVVrc1EwRkJRenRKUVVOa0xFTkJRVU03UTBGQlFUdEJRVVZFTEdsR1FVRnBSanRCUVVOcVJpeE5RVUZOTEZWQlFWVXNUVUZCVFN4RFFVRkRMRTFCUVZjc1JVRkJSU3hSUVVGaE8wbEJReTlETEVsQlFVa3NUVUZCVFN4TFFVRkxMRkZCUVZFN1VVRkRja0lzVFVGQlRTeGhRVUZoTEZGQlFWRXNWMEZCVnl4TlFVRk5MRWRCUVVjc1EwRkJRenRCUVVOd1JDeERRVUZETzBGQlJVUXNUVUZCVFN4VlFVRlZMRmRCUVZjc1EwRkJReXhOUVVGakxFVkJRVVVzVVVGQlowSXNSVUZCUlN4VFFVRlRMRWRCUVVjc1MwRkJTenRKUVVNM1JTeE5RVUZOTEZGQlFWRXNSMEZCUnl4SlFVRkpMRU5CUVVNc1IwRkJSeXhEUVVGRExFMUJRVTBzUjBGQlJ5eFJRVUZSTEVOQlFVTXNSMEZCUnl4TFFVRkxMRU5CUVVNN1NVRkRja1FzU1VGQlNTeERRVUZETEZGQlFWRTdVVUZEV0N4TlFVRk5MRmxCUVZrc1VVRkJVU3hUUVVGVExFMUJRVTBzYVVKQlFXbENMRk5CUVZNc1IwRkJSeXhEUVVGRE8wRkJRek5GTEVOQlFVTTdRVUZGUkN3MFFrRkJORUk3UVVGRE5VSXNUVUZCVFN4VlFVRlZMRkZCUVZFc1EwRkJReXhSUVVGblFpeEZRVUZGTEV0QlFXbENPMGxCUXpGRUxHVkJRV1VzUjBGQlJ5eFJRVUZSTEVOQlFVTTdTVUZETTBJc1MwRkJTeXhGUVVGRkxFTkJRVU03UVVGRFZpeERRVUZETzBGQlJVUXNkMFpCUVhkR08wRkJRM2hHTEUxQlFVMHNWVUZCVlN4TlFVRk5MRU5CUVVNc1RVRkJNa0k3U1VGRGFFUXNTVUZCU1N4TFFVRkxMRU5CUVVNc1pVRkJaU3hEUVVGRExFbEJRVWtzVTBGQlV6dFJRVU55UXl4TFFVRkxMRU5CUVVNc1pVRkJaU3hEUVVGRExFZEJRVWNzUlVGQlJTeERRVUZETzBsQlF6bENMRXRCUVVzc1EwRkJReXhsUVVGbExFTkJRVU1zUTBGQlF5eE5RVUZOTEVkQlFVY3NUVUZCVFN4RFFVRkRPMEZCUTNwRExFTkJRVU03UVVGRlJDeDFSa0ZCZFVZN1FVRkRka1lzVFVGQlRTeFZRVUZWTEV0QlFVc3NRMEZCUXl4TFFVRXdRanRKUVVNNVF5eEpRVUZKTEV0QlFVc3NRMEZCUXl4bFFVRmxMRU5CUVVNc1NVRkJTU3hUUVVGVE8xRkJRM0pETEV0QlFVc3NRMEZCUXl4bFFVRmxMRU5CUVVNc1IwRkJSeXhGUVVGRkxFTkJRVU03U1VGRE9VSXNTMEZCU3l4RFFVRkRMR1ZCUVdVc1EwRkJReXhEUVVGRExFdEJRVXNzUjBGQlJ5eExRVUZMTEVOQlFVTTdRVUZEZGtNc1EwRkJRenRCUVVkRUxFMUJRVTBzVlVGQlowSXNVVUZCVVN4RFFVRkRMRTlCUVRSRE96czdVVUZEZWtVc1NVRkJTU3hQUVVGUExFZEJRVFJGTEVWQlFVVXNRMEZCUXp0UlFVVXhSaXhMUVVGTExFMUJRVTBzUTBGQlF5eEhRVUZITEVWQlFVVXNTMEZCU3l4RFFVRkRMRWxCUVVrc1RVRkJUU3hEUVVGRExFOUJRVThzUTBGQlF5eExRVUZMTEVOQlFVTXNSVUZCUlR0WlFVTm9SQ3hKUVVGSkxFTkJRVUVzVDBGQlR5eGhRVUZRTEU5QlFVOHNkVUpCUVZBc1QwRkJUeXhEUVVGRkxGRkJRVkVzUzBGQlNTeFRRVUZUTEVWQlFVVTdaMEpCUTJ4RExFbEJRVWtzUTBGQlF5eEhRVUZITEVOQlFVTXNWMEZCVnl4RlFVRkZMRU5CUVVNc1ZVRkJWU3hEUVVGRExFOUJRVThzWVVGQlVDeFBRVUZQTEhWQ1FVRlFMRTlCUVU4c1EwRkJSU3hSUVVGUkxFTkJRVU1zVjBGQlZ5eEZRVUZGTEVOQlFVTTdiMEpCUTJoRkxGTkJRVk03WVVGRFdqdFpRVU5FTEVsQlFVazdaMEpCUTBZc1NVRkJTU3hMUVVGTExFTkJRVU1zVFVGQlRUdHZRa0ZEWkN4TlFVRk5MRXRCUVVzc1EwRkJReXhOUVVGTkxFVkJRVVVzUTBGQlF6dGhRVU40UWp0WlFVRkRMRTlCUVU4c1EwRkJUU3hGUVVGRk8yZENRVU5tTEV0QlFVc3NRMEZCUXl4WlFVRlpMRWRCUVVjc1EwRkJReXhEUVVGRExGRkJRVkVzUlVGQlJTeERRVUZETzJGQlEyNURPMWxCUTBRc1NVRkJTU3hEUVVGRExFZEJRVWNzVFVGQlFTeExRVUZMTEVOQlFVTXNTMEZCU3l4dFEwRkJTU3hGUVVGRkxFTkJRVU03V1VGRE1VSXNTVUZCU1N4SFFVRkhMRWRCUVVjc1JVRkJSU3hEUVVGRE8xbEJRMklzUzBGQlNTeEpRVUZKTEVOQlFVTXNSMEZCUnl4RFFVRkRMRVZCUVVVc1EwRkJReXhIUVVGSExFTkJRVU1zUTBGQlF5eE5RVUZOTEVWQlFVVXNRMEZCUXl4RlFVRkZMRVZCUVVVN1owSkJRMmhETEVkQlFVY3NRMEZCUXl4SlFVRkpMRU5CUVVNc1RVRkJUU3hSUVVGUkxFTkJRVU1zUTBGQlF5eERRVUZETEVOQlFVTXNRMEZCUXl4RlFVRkZMRTlCUVU4c1lVRkJVQ3hQUVVGUExIVkNRVUZRTEU5QlFVOHNRMEZCUlN4SlFVRkpMRU5CUVVNc1EwRkJReXhEUVVGRE8yRkJReTlETzFsQlJVUXNTVUZCU1N4SlFVRkpMRWRCUVVjc1EwRkJReXhOUVVGTkxFOUJRVThzUTBGQlF5eEhRVUZITEVOQlFVTXNSMEZCUnl4RFFVRkRMRU5CUVVNc1EwRkJReXhOUVVGTkxFTkJRVU1zUTBGQlF5eERRVUZETEVWQlFVVXNSVUZCUlN4RFFVRkRMRU5CUVVNc1EwRkJReXhOUVVGTkxFbEJRVWtzVTBGQlV5eERRVUZETEVOQlFVTTdXVUZEZWtVc1NVRkJTVHRuUWtGRFJpeEpRVUZKTEV0QlFVc3NRMEZCUXl4TFFVRkxPMjlDUVVOaUxFMUJRVTBzUzBGQlN5eERRVUZETEV0QlFVc3NSVUZCUlN4RFFVRkRPMkZCUTNaQ08xbEJRVU1zVDBGQlR5eERRVUZOTEVWQlFVVTdaMEpCUTJZc1MwRkJTeXhEUVVGRExGZEJRVmNzUjBGQlJ5eERRVUZETEVOQlFVTXNVVUZCVVN4RlFVRkZMRU5CUVVNN1lVRkRiRU03V1VGRFJDeEpRVUZKTEV0QlFVc3NRMEZCUXl4WFFVRlhPMmRDUVVOdVFpeEpRVUZKTEVOQlFVTXNTVUZCU1N4RFFVRkRMRVZCUVVNc1VVRkJVU3hGUVVGRkxFZEJRVWNzUlVGQlJTeEpRVUZKTEVWQlFVVXNUVUZCVFN4RlFVRkZMRTFCUVUwc1JVRkJSU3hMUVVGTExFTkJRVU1zVjBGQlZ5eEZRVUZGTEU5QlFVOHNSVUZCUlN4TFFVRkxMRVZCUVVNc1EwRkJReXhEUVVGRE8xbEJRM1JHTEVsQlFVa3NTMEZCU3l4RFFVRkRMRmxCUVZrN1owSkJRM0JDTEVsQlFVa3NRMEZCUXl4SlFVRkpMRU5CUVVNc1JVRkJReXhSUVVGUkxFVkJRVVVzUjBGQlJ5eEZRVUZGTEVsQlFVa3NSVUZCUlN4TlFVRk5MRVZCUVVVc1RVRkJUU3hGUVVGRkxFdEJRVXNzUTBGQlF5eFpRVUZaTEVWQlFVVXNUMEZCVHl4RlFVRkZMRXRCUVVzc1JVRkJReXhEUVVGRExFTkJRVU03V1VGRGRrWXNUMEZCVHl4RFFVRkRMRWxCUVVrc1EwRkJReXhIUVVGSExFbEJRVWtzUTBGQlF5eERRVUZETzFOQlEzWkNPMUZCUlVRc1QwRkJUeXhQUVVGUExFTkJRVU03TzBOQlEyaENPMEZCUlVRc1UwRkJaU3hSUVVGUkxFTkJRVU1zUTBGQlR5eEZRVUZGTEZOQlFUWkNPenM3VVVGRE5VUXNTVUZCU1N4RFFVRjVSU3hEUVVGRE8xRkJRemxGTEVsQlFVazdXVUZEUml4SlFVRkpMRk5CUVZNc1NVRkJTU3hUUVVGVExFbEJRVWtzUTBGQlF5eERRVUZETEVOQlFVTXNRMEZCUXl4SlFVRkpMRU5CUVVNc1YwRkJWeXhGUVVGRkxFTkJRVU1zVlVGQlZTeERRVUZETEZOQlFWTXNRMEZCUXl4WFFVRlhMRVZCUVVVc1EwRkJReXhEUVVGRE8yZENRVU4yUml4RFFVRkRMRWRCUVVjc1JVRkJReXhQUVVGUExFVkJRVVVzU1VGQlNTeEZRVUZGTEUxQlFVMHNSVUZCUlN4VFFVRlRMRVZCUVVNc1EwRkJRenM3WjBKQlJYWkRMRU5CUVVNc1IwRkJSeXhGUVVGRExFOUJRVThzUlVGQlJTeEpRVUZKTEVWQlFVVXNUVUZCVFN4RlFVRkZMRTFCUVVFc1RVRkJUU3hEUVVGRExFTkJRVU1zU1VGQlNTeEZRVUZGTEcxRFFVRkpMRWxCUVVrc1JVRkJReXhEUVVGRE8xTkJRM1pFTzFGQlFVTXNUMEZCVHl4RFFVRk5MRVZCUVVVN1dVRkRaaXhEUVVGRExFZEJRVWNzUlVGQlF5eFBRVUZQTEVWQlFVVXNTMEZCU3l4RlFVRkZMRTFCUVUwc1JVRkJSU3hEUVVGRExFTkJRVU1zVVVGQlVTeEZRVUZGTEVWQlFVTXNRMEZCUXp0VFFVTTFRenRSUVVORUxFTkJRVU1zUTBGQlF5eFJRVUZSTEVkQlFVY3NRMEZCUXl4RFFVRkRMRkZCUVZFc1EwRkJRenRSUVVONFFpeERRVUZETEVOQlFVTXNTVUZCU1N4SFFVRkhMRU5CUVVNc1EwRkJReXhKUVVGSkxFTkJRVU03VVVGRGFFSXNUMEZCVHl4RFFVRkRMRU5CUVVNN08wTkJRMVk3UVVGRlJDeE5RVUZOTEZWQlFXZENMRXRCUVVzc1EwRkJReXhGUVVGVk96dFJRVU53UXl4TlFVRlBMRWxCUVVrc1QwRkJUeXhEUVVGRExFTkJRVU1zUTBGQlF5eEZRVUZGTEVOQlFVTXNWVUZCVlN4RFFVRkRMRU5CUVVNc1JVRkJSU3hGUVVGRkxFTkJRVU1zUTBGQlF5eERRVUZETzBsQlF6ZERMRU5CUVVNN1EwRkJRU0lzSW5OdmRYSmpaWE5EYjI1MFpXNTBJanBiSW1sdGNHOXlkQ0FxSUdGeklHZHliMnNnWm5KdmJTQmNJbVJoZEdGbmNtOXJMV0Z3YVM5bmNtOXJYQ0k3WEc1Y2JtVjRjRzl5ZENCc1pYUWdkR1Z6ZEhNNklIdGJhMlY1T2lCemRISnBibWRkT2lCN2RHVnpkSE0vT2lCVVpYTjBXMTBzSUdKbFptOXlaVDg2SUNncElEMCtJRkJ5YjIxcGMyVThkbTlwWkQ0c0lHRm1kR1Z5UHpvZ0tDa2dQVDRnVUhKdmJXbHpaVHgyYjJsa1Bpd2dZbVZtYjNKbFUzUmhkSFZ6UHpvZ2MzUnlhVzVuTENCaFpuUmxjbE4wWVhSMWN6ODZJSE4wY21sdVozMTlJRDBnZTMwN1hHNWNibVY0Y0c5eWRDQnNaWFFnWTNWeWNtVnVkRU5oZEdWbmIzSjVPaUJ6ZEhKcGJtYzdYRzVjYm1WNGNHOXlkQ0J1WVcxbGMzQmhZMlVnWVhOemRYSmxJSHRjYmx4dUlDQmxlSEJ2Y25RZ1puVnVZM1JwYjI0Z2JtOTBUblZzYkNoMllXeDFaVG9nWVc1NUxDQnVZVzFsUHpvZ2MzUnlhVzVuS1NCN1hHNGdJQ0FnYVdZZ0tIWmhiSFZsSUQwOUlHNTFiR3dwWEc0Z0lDQWdJQ0IwYUhKdmR5QmdKSHR1WVcxbElEMDlJRzUxYkd3Z1B5QW5WbUZzZFdVbklEb2dibUZ0WlgwZ2JtOTBJR1JsWm1sdVpXUmdPMXh1SUNCOVhHNTlYRzVjYm1WNGNHOXlkQ0JwYm5SbGNtWmhZMlVnVkdWemRFOXdkR2x2Ym5NZ2UxeHVJQ0IwYVcxbGIzVjBQeUE2SUc1MWJXSmxjanRjYmlBZ2RXNW9ZVzVrYkdWa1JYaGpaWEIwYVc5dVZHbHRaVzkxZEQ4Z09pQnVkVzFpWlhJN1hHNTlYRzVjYm1WNGNHOXlkQ0JqYkdGemN5QlVaWE4wSUh0Y2JpQWdkR1Z6ZERvZ0tDa2dQVDRnVUhKdmJXbHpaVHhoYm5rK08xeHVJQ0J1WVcxbE9pQnpkSEpwYm1jN1hHNGdJR05oZEdWbmIzSjVPaUJ6ZEhKcGJtYzdYRzRnSUc5d2RHbHZibk0vT2lCVVpYTjBUM0IwYVc5dWN6dGNibHh1SUNCamIyNXpkSEoxWTNSdmNpaGpZWFJsWjI5eWVUb2djM1J5YVc1bkxDQnVZVzFsT2lCemRISnBibWNzSUhSbGMzUTZJQ2dwSUQwK0lGQnliMjFwYzJVOFlXNTVQaXdnYjNCMGFXOXVjejg2SUZSbGMzUlBjSFJwYjI1ektTQjdYRzRnSUNBZ2RHaHBjeTVqWVhSbFoyOXllU0E5SUdOaGRHVm5iM0o1TzF4dUlDQWdJSFJvYVhNdWJtRnRaU0E5SUc1aGJXVTdYRzRnSUNBZ2IzQjBhVzl1Y3lBL1B6MGdlMzA3WEc0Z0lDQWdiM0IwYVc5dWN5NTBhVzFsYjNWMElEOC9QU0F6TURBd01EdGNiaUFnSUNCdmNIUnBiMjV6TG5WdWFHRnVaR3hsWkVWNFkyVndkR2x2YmxScGJXVnZkWFFnUHo4OUlESXdNREE3WEc0Z0lDQWdkR2hwY3k1dmNIUnBiMjV6SUQwZ2IzQjBhVzl1Y3p0Y2JpQWdJQ0IwYUdsekxuUmxjM1FnUFNCaGMzbHVZeUFvS1RvZ1VISnZiV2x6WlR4aGJuaytJRDArSUh0Y2JpQWdJQ0FnSUhKbGRIVnliaUJ1WlhjZ1VISnZiV2x6WlNoaGMzbHVZeUFvY21WemIyeDJaU3dnY21WcVpXTjBLU0E5UGlCN1hHNGdJQ0FnSUNBZ0lHeGxkQ0J5WlhOMWJIUWdQU0FuSnp0Y2JpQWdJQ0FnSUNBZ2RISjVJSHRjYmlBZ0lDQWdJQ0FnSUNCbmNtOXJMbk5vWld4c0xteGhjM1JGY25KdmNpQTlJQ2NuTzF4dUlDQWdJQ0FnSUNBZ0lISmxjM1ZzZENBOUlHRjNZV2wwSUhSbGMzUW9LVHRjYmlBZ0lDQWdJQ0FnZlNCallYUmphQ0FvWlRvZ1lXNTVLU0I3WEc0Z0lDQWdJQ0FnSUNBZ2NtVnFaV04wS0dVcE8xeHVJQ0FnSUNBZ0lDQjlYRzRnSUNBZ0lDQWdJR2xtSUNnaEtHRjNZV2wwSUdGemMyVnlkRTV2UlhKeWIzSW9iM0IwYVc5dWN5RXVkVzVvWVc1a2JHVmtSWGhqWlhCMGFXOXVWR2x0Wlc5MWRDRXBLU2xjYmlBZ0lDQWdJQ0FnSUNCeVpXcGxZM1FvWUZWdWFHRnVaR3hsWkNCbGVHTmxjSFJwYjI0Z1pIVnlhVzVuSUhSbGMzUTZJQ1I3WjNKdmF5NXphR1ZzYkM1c1lYTjBSWEp5YjNKOVlDazdYRzRnSUNBZ0lDQWdJSEpsYzI5c2RtVW9jbVZ6ZFd4MEtUdGNiaUFnSUNBZ0lIMHBPMXh1SUNBZ0lIMDdYRzRnSUgxY2JuMWNibHh1Wlhod2IzSjBJR1oxYm1OMGFXOXVJSFJsYzNRb2JtRnRaVG9nYzNSeWFXNW5MQ0IwWlhOME9pQW9LU0E5UGlCUWNtOXRhWE5sUEdGdWVUNHNJRzl3ZEdsdmJuTS9PaUJVWlhOMFQzQjBhVzl1Y3lrNklIWnZhV1FnZTF4dUlDQnBaaUFvZEdWemRITmJZM1Z5Y21WdWRFTmhkR1ZuYjNKNVhTQTlQU0IxYm1SbFptbHVaV1FwWEc0Z0lDQWdkR1Z6ZEhOYlkzVnljbVZ1ZEVOaGRHVm5iM0o1WFNBOUlIdDlPMXh1SUNCcFppQW9kR1Z6ZEhOYlkzVnljbVZ1ZEVOaGRHVm5iM0o1WFM1MFpYTjBjeUE5UFNCMWJtUmxabWx1WldRcFhHNGdJQ0FnZEdWemRITmJZM1Z5Y21WdWRFTmhkR1ZuYjNKNVhTNTBaWE4wY3lBOUlGdGRPMXh1SUNCMFpYTjBjMXRqZFhKeVpXNTBRMkYwWldkdmNubGRMblJsYzNSeklTNXdkWE5vS0c1bGR5QlVaWE4wS0dOMWNuSmxiblJEWVhSbFoyOXllU3dnYm1GdFpTd2dkR1Z6ZEN3Z2IzQjBhVzl1Y3lrcE8xeHVmVnh1WEc0dktpb2dRWGRoYVhSeklHWnZjaUJoSUhkb2FXeGxJR05vWldOcmFXNW5JSFJvWlNCbGNuSnZjaUJ6ZEdGMGRYTWdiMllnZEdobElIQnNZWFJtYjNKdElDb3ZYRzVsZUhCdmNuUWdZWE41Ym1NZ1puVnVZM1JwYjI0Z1lYTnpaWEowVG05RmNuSnZjaWh0Y3pvZ2JuVnRZbVZ5S1RvZ1VISnZiV2x6WlR4aWIyOXNaV0Z1UGlCN1hHNGdJR1p2Y2lBb2JHVjBJR2tnUFNBd095QnBJRHdnYlhNZ0x5QTFNREE3SUNzcmFTa2dlMXh1SUNBZ0lHRjNZV2wwSUdSbGJHRjVLRFV3TUNrN1hHNGdJQ0FnYVdZZ0tHZHliMnN1YzJobGJHd3ViR0Z6ZEVWeWNtOXlMbXhsYm1kMGFDQWhQVDBnTUNsY2JpQWdJQ0FnSUhKbGRIVnliaUJtWVd4elpUdGNiaUFnZlZ4dUlDQnlaWFIxY200Z2RISjFaVHRjYm4xY2JseHVMeW9xSUZSbGMzUnpJSFIzYnlCdlltcGxZM1J6SUdadmNpQmxjWFZoYkdsMGVTd2dkR2h5YjNkeklHRnVJR1Y0WTJWd2RHbHZiaUJwWmlCMGFHVjVJR0Z5WlNCdWIzUWdaWEYxWVd3dUlDb3ZYRzVsZUhCdmNuUWdablZ1WTNScGIyNGdaWGh3WldOMEtHRmpkSFZoYkRvZ1lXNTVMQ0JsZUhCbFkzUmxaRG9nWVc1NUtUb2dkbTlwWkNCN1hHNGdJR2xtSUNoaFkzUjFZV3dnSVQwOUlHVjRjR1ZqZEdWa0tWeHVJQ0FnSUhSb2NtOTNJR0JGZUhCbFkzUmxaQ0JjSWlSN1pYaHdaV04wWldSOVhDSXNJR2R2ZENCY0lpUjdZV04wZFdGc2ZWd2lZRHRjYm4xY2JseHVaWGh3YjNKMElHWjFibU4wYVc5dUlHVjRjR1ZqZEVac2IyRjBLR0ZqZEhWaGJEb2diblZ0WW1WeUxDQmxlSEJsWTNSbFpEb2diblZ0WW1WeUxDQjBiMnhsY21GdVkyVWdQU0F3TGpBd01TazZJSFp2YVdRZ2UxeHVJQ0JqYjI1emRDQmhjbVZGY1hWaGJDQTlJRTFoZEdndVlXSnpLR0ZqZEhWaGJDQXRJR1Y0Y0dWamRHVmtLU0E4SURBdU1EQXhPMXh1SUNCcFppQW9JV0Z5WlVWeGRXRnNLVnh1SUNBZ0lIUm9jbTkzSUdCRmVIQmxZM1JsWkNBa2UyVjRjR1ZqZEdWa2ZTd2daMjkwSUNSN1lXTjBkV0ZzZlNBb2RHOXNaWEpoYm1ObElEMGdKSHQwYjJ4bGNtRnVZMlY5S1dBN1hHNTlYRzVjYmk4cUtpQkVaV1pwYm1WeklHRWdkR1Z6ZENCemRXbDBaUzRnS2k5Y2JtVjRjRzl5ZENCbWRXNWpkR2x2YmlCallYUmxaMjl5ZVNoallYUmxaMjl5ZVRvZ2MzUnlhVzVuTENCMFpYTjBjem9nS0NrZ1BUNGdkbTlwWkNrNklIWnZhV1FnZTF4dUlDQmpkWEp5Wlc1MFEyRjBaV2R2Y25rZ1BTQmpZWFJsWjI5eWVUdGNiaUFnZEdWemRITW9LVHRjYm4xY2JseHVMeW9xSUVSbFptbHVaWE1nWVNCbWRXNWpkR2x2YmlCMGJ5QmlaU0JsZUdWamRYUmxaQ0JpWldadmNtVWdkR2hsSUhSbGMzUnpJR2x1SUhSb2FYTWdZMkYwWldkdmNua2dZWEpsSUdWNFpXTjFkR1ZrTGlBcUwxeHVaWGh3YjNKMElHWjFibU4wYVc5dUlHSmxabTl5WlNoaVpXWnZjbVU2SUNncElEMCtJRkJ5YjIxcGMyVThkbTlwWkQ0cE9pQjJiMmxrSUh0Y2JpQWdhV1lnS0hSbGMzUnpXMk4xY25KbGJuUkRZWFJsWjI5eWVWMGdQVDBnZFc1a1pXWnBibVZrS1Z4dUlDQWdJSFJsYzNSelcyTjFjbkpsYm5SRFlYUmxaMjl5ZVYwZ1BTQjdmVHRjYmlBZ2RHVnpkSE5iWTNWeWNtVnVkRU5oZEdWbmIzSjVYUzVpWldadmNtVWdQU0JpWldadmNtVTdYRzU5WEc1Y2JpOHFLaUJFWldacGJtVnpJR0VnWm5WdVkzUnBiMjRnZEc4Z1ltVWdaWGhsWTNWMFpXUWdZV1owWlhJZ2RHaGxJSFJsYzNSeklHbHVJSFJvYVhNZ1kyRjBaV2R2Y25rZ1lYSmxJR1Y0WldOMWRHVmtMaUFxTDF4dVpYaHdiM0owSUdaMWJtTjBhVzl1SUdGbWRHVnlLR0ZtZEdWeU9pQW9LU0E5UGlCUWNtOXRhWE5sUEhadmFXUStLVG9nZG05cFpDQjdYRzRnSUdsbUlDaDBaWE4wYzF0amRYSnlaVzUwUTJGMFpXZHZjbmxkSUQwOUlIVnVaR1ZtYVc1bFpDbGNiaUFnSUNCMFpYTjBjMXRqZFhKeVpXNTBRMkYwWldkdmNubGRJRDBnZTMwN1hHNGdJSFJsYzNSelcyTjFjbkpsYm5SRFlYUmxaMjl5ZVYwdVlXWjBaWElnUFNCaFpuUmxjanRjYm4xY2JseHVYRzVsZUhCdmNuUWdZWE41Ym1NZ1puVnVZM1JwYjI0Z2NuVnVWR1Z6ZEhNb2IzQjBhVzl1Y3o4NklIdGpZWFJsWjI5eWVUODZJSE4wY21sdVp5d2dkR1Z6ZEQ4NklITjBjbWx1WjMwcElIdGNiaUFnYkdWMElISmxjM1ZzZEhNNklIc2dZMkYwWldkdmNuay9PaUJ6ZEhKcGJtY3NJRzVoYldVL09pQnpkSEpwYm1jc0lITjFZMk5sYzNNNklHSnZiMnhsWVc0c0lISmxjM1ZzZERvZ2MzUnlhVzVuZlZ0ZElEMGdXMTA3WEc1Y2JpQWdabTl5SUNoamIyNXpkQ0JiYTJWNUxDQjJZV3gxWlYwZ2IyWWdUMkpxWldOMExtVnVkSEpwWlhNb2RHVnpkSE1wS1NCN1hHNGdJQ0FnYVdZZ0tHOXdkR2x2Ym5NL0xtTmhkR1ZuYjNKNUlDRTlJSFZ1WkdWbWFXNWxaQ2tnZTF4dUlDQWdJQ0FnYVdZZ0tDRnJaWGt1ZEc5TWIzZGxja05oYzJVb0tTNXpkR0Z5ZEhOWGFYUm9LRzl3ZEdsdmJuTS9MbU5oZEdWbmIzSjVMblJ2VEc5M1pYSkRZWE5sS0NrcEtWeHVJQ0FnSUNBZ0lDQmpiMjUwYVc1MVpUdGNiaUFnSUNCOVhHNGdJQ0FnZEhKNUlIdGNiaUFnSUNBZ0lHbG1JQ2gyWVd4MVpTNWlaV1p2Y21VcFhHNGdJQ0FnSUNBZ0lHRjNZV2wwSUhaaGJIVmxMbUpsWm05eVpTZ3BPMXh1SUNBZ0lIMGdZMkYwWTJnZ0tIZzZJR0Z1ZVNrZ2UxeHVJQ0FnSUNBZ2RtRnNkV1V1WW1WbWIzSmxVM1JoZEhWeklEMGdlQzUwYjFOMGNtbHVaeWdwTzF4dUlDQWdJSDFjYmlBZ0lDQnNaWFFnZENBOUlIWmhiSFZsTG5SbGMzUnpJRDgvSUZ0ZE8xeHVJQ0FnSUd4bGRDQnlaWE1nUFNCYlhUdGNiaUFnSUNCbWIzSW9iR1YwSUdrZ1BTQXdPeUJwSUR3Z2RDNXNaVzVuZEdnN0lHa3JLeWtnZTF4dUlDQWdJQ0FnY21WekxuQjFjMmdvWVhkaGFYUWdaWGhsWTFSbGMzUW9kRnRwWFN3Z2IzQjBhVzl1Y3o4dWRHVnpkQ2twTzF4dUlDQWdJSDFjYmx4dUlDQWdJR3hsZENCa1lYUmhJRDBnS0dGM1lXbDBJRkJ5YjIxcGMyVXVZV3hzS0hKbGN5a3BMbVpwYkhSbGNpZ29aQ2tnUFQ0Z1pDNXlaWE4xYkhRZ0lUMGdKM05yYVhCd1pXUW5LVHRjYmlBZ0lDQjBjbmtnZTF4dUlDQWdJQ0FnYVdZZ0tIWmhiSFZsTG1GbWRHVnlLVnh1SUNBZ0lDQWdJQ0JoZDJGcGRDQjJZV3gxWlM1aFpuUmxjaWdwTzF4dUlDQWdJSDBnWTJGMFkyZ2dLSGc2SUdGdWVTa2dlMXh1SUNBZ0lDQWdkbUZzZFdVdVlXWjBaWEpUZEdGMGRYTWdQU0I0TG5SdlUzUnlhVzVuS0NrN1hHNGdJQ0FnZlZ4dUlDQWdJR2xtSUNoMllXeDFaUzVoWm5SbGNsTjBZWFIxY3lsY2JpQWdJQ0FnSUdSaGRHRXVjSFZ6YUNoN1kyRjBaV2R2Y25rNklHdGxlU3dnYm1GdFpUb2dKMmx1YVhRbkxDQnlaWE4xYkhRNklIWmhiSFZsTG1GbWRHVnlVM1JoZEhWekxDQnpkV05qWlhOek9pQm1ZV3h6WlgwcE8xeHVJQ0FnSUdsbUlDaDJZV3gxWlM1aVpXWnZjbVZUZEdGMGRYTXBYRzRnSUNBZ0lDQmtZWFJoTG5CMWMyZ29lMk5oZEdWbmIzSjVPaUJyWlhrc0lHNWhiV1U2SUNkcGJtbDBKeXdnY21WemRXeDBPaUIyWVd4MVpTNWlaV1p2Y21WVGRHRjBkWE1zSUhOMVkyTmxjM002SUdaaGJITmxmU2s3WEc0Z0lDQWdjbVZ6ZFd4MGN5NXdkWE5vS0M0dUxtUmhkR0VwTzF4dUlDQjlYRzVjYmlBZ2NtVjBkWEp1SUhKbGMzVnNkSE03WEc1OVhHNWNibUZ6ZVc1aklHWjFibU4wYVc5dUlHVjRaV05VWlhOMEtIUTZJRlJsYzNRc0lIQnlaV1JwWTJGMFpUb2djM1J5YVc1bklId2dkVzVrWldacGJtVmtLU0I3WEc0Z0lHeGxkQ0J5T2lCN0lHTmhkR1ZuYjNKNVB6b2djM1J5YVc1bkxDQnVZVzFsUHpvZ2MzUnlhVzVuTENCemRXTmpaWE56T2lCaWIyOXNaV0Z1TENCeVpYTjFiSFE2SUhOMGNtbHVaeUI5TzF4dUlDQjBjbmtnZTF4dUlDQWdJR2xtSUNod2NtVmthV05oZEdVZ0lUMGdkVzVrWldacGJtVmtJQ1ltSUNnaGRDNXVZVzFsTG5SdlRHOTNaWEpEWVhObEtDa3VjM1JoY25SelYybDBhQ2h3Y21Wa2FXTmhkR1V1ZEc5TWIzZGxja05oYzJVb0tTa3BLVnh1SUNBZ0lDQWdjaUE5SUh0emRXTmpaWE56T2lCMGNuVmxMQ0J5WlhOMWJIUTZJQ2R6YTJsd2NHVmtKMzA3WEc0Z0lDQWdaV3h6WlZ4dUlDQWdJQ0FnY2lBOUlIdHpkV05qWlhOek9pQjBjblZsTENCeVpYTjFiSFE2SUdGM1lXbDBJSFF1ZEdWemRDZ3BJRDgvSUNkUFN5ZDlPMXh1SUNCOUlHTmhkR05vSUNoNE9pQmhibmtwSUh0Y2JpQWdJQ0J5SUQwZ2UzTjFZMk5sYzNNNklHWmhiSE5sTENCeVpYTjFiSFE2SUhndWRHOVRkSEpwYm1jb0tYMDdYRzRnSUgxY2JpQWdjaTVqWVhSbFoyOXllU0E5SUhRdVkyRjBaV2R2Y25rN1hHNGdJSEl1Ym1GdFpTQTlJSFF1Ym1GdFpUdGNiaUFnY21WMGRYSnVJSEk3WEc1OVhHNWNibVY0Y0c5eWRDQmhjM2x1WXlCbWRXNWpkR2x2YmlCa1pXeGhlU2h0Y3pvZ2JuVnRZbVZ5S1NCN1hHNGdJR0YzWVdsMElDQnVaWGNnVUhKdmJXbHpaU2h5SUQwK0lITmxkRlJwYldWdmRYUW9jaXdnYlhNcEtUdGNibjFjYmlKZGZRPT0iLCIvL25hbWU6IGFzb0dhcG1lcnNOdWNsZW90aWRlc1RvQmlvU3ByaW5nXG4vL2lucHV0OiBzdHJpbmcgbnVjbGVvdGlkZXMge3NlbVR5cGU6IEROQSBudWNsZW90aWRlc31cbi8vb3V0cHV0OiBzdHJpbmcgcmVzdWx0IHtzZW1UeXBlOiBCaW9TcHJpbmcgLyBHYXBtZXJzfVxuZXhwb3J0IGZ1bmN0aW9uIGFzb0dhcG1lcnNOdWNsZW90aWRlc1RvQmlvU3ByaW5nKG51Y2xlb3RpZGVzKSB7XG4gICAgbGV0IGNvdW50ID0gLTE7XG4gICAgY29uc3Qgb2JqRm9yRWRnZXMgPSB7XG4gICAgICAgICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsICdUJzogJzUqJywgJ0EnOiAnNionLCAnQyc6ICc3KicsICdHJzogJzgqJ1xuICAgIH07XG4gICAgY29uc3Qgb2JqRm9yQ2VudGVyID0ge1xuICAgICAgICAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLCAnVCc6ICdUKicsICdBJzogJ0EqJywgJ0MnOiAnOSonLCAnRyc6ICdHKidcbiAgICB9O1xuICAgIHJldHVybiBudWNsZW90aWRlcy5yZXBsYWNlKC8oXFwoaW52YWJhc2ljXFwpfFxcKEdhbE5BYy0yLUpOSlxcKXxBfFR8Q3xHKS9nLCBmdW5jdGlvbiAoeCkge1xuICAgICAgICBjb3VudCsrO1xuICAgICAgICByZXR1cm4gKGNvdW50ID4gNCAmJiBjb3VudCA8IDE1KSA/IG9iakZvckNlbnRlclt4XSA6IG9iakZvckVkZ2VzW3hdO1xuICAgIH0pLnNsaWNlKDAsIChudWNsZW90aWRlcy5lbmRzV2l0aCgnKGludmFiYXNpYyknKSB8fCBudWNsZW90aWRlcy5lbmRzV2l0aCgnKEdhbE5BYy0yLUpOSiknKSkgP1xuICAgICAgICBudWNsZW90aWRlcy5sZW5ndGggOiAyICogY291bnQgKyAxKTtcbn1cbi8vbmFtZTogYXNvR2FwbWVyc051Y2xlb3RpZGVzVG9HY3JzXG4vL2lucHV0OiBzdHJpbmcgbnVjbGVvdGlkZXMge3NlbVR5cGU6IEROQSBudWNsZW90aWRlc31cbi8vb3V0cHV0OiBzdHJpbmcgcmVzdWx0IHtzZW1UeXBlOiBHQ1JTIC8gR2FwbWVyc31cbmV4cG9ydCBmdW5jdGlvbiBhc29HYXBtZXJzTnVjbGVvdGlkZXNUb0djcnMobnVjbGVvdGlkZXMpIHtcbiAgICBsZXQgY291bnQgPSAtMTtcbiAgICBjb25zdCBvYmpGb3JFZGdlcyA9IHtcbiAgICAgICAgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJywgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJywgJ1QnOiAnbW9lVW5wcycsXG4gICAgICAgICdBJzogJ21vZUFucHMnLCAnQyc6ICdtb2U1bUNucHMnLCAnRyc6ICdtb2VHbnBzJ1xuICAgIH07XG4gICAgY29uc3Qgb2JqRm9yQ2VudGVyID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnQyc6ICc1bUNwcycsICdBJzogJ0FwcycsICdUJzogJ1RwcycsICdHJzogJ0dwcycgfTtcbiAgICByZXR1cm4gbnVjbGVvdGlkZXMucmVwbGFjZSgvKFxcKGludmFiYXNpY1xcKXxcXChHYWxOQWMtMi1KTkpcXCl8QXxUfEN8RykvZywgZnVuY3Rpb24gKHgpIHtcbiAgICAgICAgY291bnQrKztcbiAgICAgICAgaWYgKGNvdW50IDwgNSlcbiAgICAgICAgICAgIHJldHVybiAoY291bnQgPT0gNCkgPyBvYmpGb3JFZGdlc1t4XS5zbGljZSgwLCAtMykgKyAncHMnIDogb2JqRm9yRWRnZXNbeF07XG4gICAgICAgIGlmIChjb3VudCA8IDE1KVxuICAgICAgICAgICAgcmV0dXJuIChjb3VudCA9PSAxNCkgPyBvYmpGb3JDZW50ZXJbeF0uc2xpY2UoMCwgLTIpICsgJ25wcycgOiBvYmpGb3JDZW50ZXJbeF07XG4gICAgICAgIHJldHVybiBvYmpGb3JFZGdlc1t4XTtcbiAgICB9KS5zbGljZSgwLCAobnVjbGVvdGlkZXMuZW5kc1dpdGgoJyhpbnZhYmFzaWMpJykgfHwgbnVjbGVvdGlkZXMuZW5kc1dpdGgoJyhHYWxOQWMtMi1KTkopJykpID9cbiAgICAgICAgbnVjbGVvdGlkZXMubGVuZ3RoIDogLTMpO1xufVxuLy9uYW1lOiBhc29HYXBtZXJzQmlvU3ByaW5nVG9OdWNsZW90aWRlc1xuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBCaW9TcHJpbmcgLyBHYXBtZXJzfVxuLy9vdXRwdXQ6IHN0cmluZyByZXN1bHQge3NlbVR5cGU6IEROQSBudWNsZW90aWRlc31cbmV4cG9ydCBmdW5jdGlvbiBhc29HYXBtZXJzQmlvU3ByaW5nVG9OdWNsZW90aWRlcyhudWNsZW90aWRlcykge1xuICAgIGNvbnN0IG9iaiA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJywgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJyxcbiAgICAgICAgJyonOiAnJywgJzUnOiAnVCcsICc2JzogJ0EnLCAnNyc6ICdDJywgJzgnOiAnRycsICc5JzogJ0MnIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfFxcKnw1fDZ8N3w4fDkpL2csIGZ1bmN0aW9uICh4KSB7IHJldHVybiBvYmpbeF07IH0pO1xufVxuLy9uYW1lOiBhc29HYXBtZXJzQmlvU3ByaW5nVG9HY3JzXG4vL2lucHV0OiBzdHJpbmcgbnVjbGVvdGlkZXMge3NlbVR5cGU6IEJpb1NwcmluZyAvIEdhcG1lcnN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogR0NSUyAvIEdhcG1lcnN9XG5leHBvcnQgZnVuY3Rpb24gYXNvR2FwbWVyc0Jpb1NwcmluZ1RvR2NycyhudWNsZW90aWRlcykge1xuICAgIGxldCBjb3VudCA9IC0xO1xuICAgIGNvbnN0IG9iaiA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJywgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJyxcbiAgICAgICAgJzUqJzogJ21vZVVucHMnLCAnNionOiAnbW9lQW5wcycsICc3Kic6ICdtb2U1bUNucHMnLCAnOConOiAnbW9lR25wcycsICc5Kic6ICc1bUNwcycsICdBKic6ICdBcHMnLCAnVConOiAnVHBzJyxcbiAgICAgICAgJ0cqJzogJ0dwcycsICdDKic6ICdDcHMnLCAnNSc6ICdtb2VVJywgJzYnOiAnbW9lQScsICc3JzogJ21vZTVtQycsICc4JzogJ21vZUcnLFxuICAgIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfDVcXCp8NlxcKnw3XFwqfDhcXCp8OVxcKnxBXFwqfFRcXCp8R1xcKnxDXFwqfDV8Nnw3fDgpL2csIGZ1bmN0aW9uICh4KSB7XG4gICAgICAgIGNvdW50Kys7XG4gICAgICAgIHJldHVybiAoY291bnQgPT0gNCkgPyBvYmpbeF0uc2xpY2UoMCwgLTMpICsgJ3BzJyA6IChjb3VudCA9PSAxNCkgPyBvYmpbeF0uc2xpY2UoMCwgLTIpICsgJ25wcycgOiBvYmpbeF07XG4gICAgfSk7XG59XG4vL25hbWU6IGFzb0dhcG1lcnNHY3JzVG9CaW9TcHJpbmdcbi8vaW5wdXQ6IHN0cmluZyBudWNsZW90aWRlcyB7c2VtVHlwZTogR0NSUyAvIEdhcG1lcnN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogQmlvU3ByaW5nIC8gR2FwbWVyc31cbmV4cG9ydCBmdW5jdGlvbiBhc29HYXBtZXJzR2Nyc1RvQmlvU3ByaW5nKG51Y2xlb3RpZGVzKSB7XG4gICAgY29uc3Qgb2JqID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnbW9lVCc6ICc1JywgJ21vZUEnOiAnNicsICdtb2U1bUMnOiAnNycsICdtb2VHJzogJzgnLCAnbW9lVSc6ICc1JywgJzVtQyc6ICc5JywgJ25wcyc6ICcqJywgJ3BzJzogJyonLCAnVSc6ICdUJyxcbiAgICB9O1xuICAgIHJldHVybiBudWNsZW90aWRlcy5yZXBsYWNlKC8oXFwoaW52YWJhc2ljXFwpfFxcKEdhbE5BYy0yLUpOSlxcKXxtb2VUfG1vZUF8bW9lNW1DfG1vZUd8bW9lVXw1bUN8bnBzfHBzfFUpL2csIGZ1bmN0aW9uICh4KSB7IHJldHVybiBvYmpbeF07IH0pO1xufVxuLy9uYW1lOiBhc29HYXBtZXJzR2Nyc1RvTnVjbGVvdGlkZXNcbi8vaW5wdXQ6IHN0cmluZyBudWNsZW90aWRlcyB7c2VtVHlwZTogR0NSUyAvIEdhcG1lcnN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogRE5BIG51Y2xlb3RpZGVzfVxuZXhwb3J0IGZ1bmN0aW9uIGFzb0dhcG1lcnNHY3JzVG9OdWNsZW90aWRlcyhudWNsZW90aWRlcykge1xuICAgIGNvbnN0IG9iaiA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJywgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJyxcbiAgICAgICAgJ21vZSc6ICcnLCAnNW0nOiAnJywgJ24nOiAnJywgJ3BzJzogJycsICdVJzogJ1QnIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfG1vZXw1bXxufHBzfFUpL2csIGZ1bmN0aW9uICh4KSB7IHJldHVybiBvYmpbeF07IH0pO1xufVxuLy9uYW1lOiBzaVJuYUJpb1NwcmluZ1RvTnVjbGVvdGlkZXNcbi8vaW5wdXQ6IHN0cmluZyBudWNsZW90aWRlcyB7c2VtVHlwZTogQmlvU3ByaW5nIC8gc2lSTkF9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogUk5BIG51Y2xlb3RpZGVzfVxuZXhwb3J0IGZ1bmN0aW9uIHNpUm5hQmlvU3ByaW5nVG9OdWNsZW90aWRlcyhudWNsZW90aWRlcykge1xuICAgIGNvbnN0IG9iaiA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJywgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJyxcbiAgICAgICAgJzEnOiAnVScsICcyJzogJ0EnLCAnMyc6ICdDJywgJzQnOiAnRycsICc1JzogJ1UnLCAnNic6ICdBJywgJzcnOiAnQycsICc4JzogJ0cnLCAnKic6ICcnIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfDF8MnwzfDR8NXw2fDd8OHxcXCopL2csIGZ1bmN0aW9uICh4KSB7IHJldHVybiBvYmpbeF07IH0pO1xufVxuLy9uYW1lOiBzaVJuYUJpb1NwcmluZ1RvQXhvbGFic1xuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBCaW9TcHJpbmcgLyBzaVJOQX1cbi8vb3V0cHV0OiBzdHJpbmcgcmVzdWx0IHtzZW1UeXBlOiBBeG9sYWJzIC8gc2lSTkF9XG5leHBvcnQgZnVuY3Rpb24gc2lSbmFCaW9TcHJpbmdUb0F4b2xhYnMobnVjbGVvdGlkZXMpIHtcbiAgICBjb25zdCBvYmogPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsXG4gICAgICAgICcxJzogJ1VmJywgJzInOiAnQWYnLCAnMyc6ICdDZicsICc0JzogJ0dmJywgJzUnOiAndScsICc2JzogJ2EnLCAnNyc6ICdjJywgJzgnOiAnZycsICcqJzogJ3MnIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfDF8MnwzfDR8NXw2fDd8OHxcXCopL2csIGZ1bmN0aW9uICh4KSB7IHJldHVybiBvYmpbeF07IH0pO1xufVxuLy9uYW1lOiBzaVJuYUJpb1NwcmluZ1RvR2Nyc1xuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBCaW9TcHJpbmcgLyBzaVJOQX1cbi8vb3V0cHV0OiBzdHJpbmcgcmVzdWx0IHtzZW1UeXBlOiBHQ1JTfVxuZXhwb3J0IGZ1bmN0aW9uIHNpUm5hQmlvU3ByaW5nVG9HY3JzKG51Y2xlb3RpZGVzKSB7XG4gICAgY29uc3Qgb2JqID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnMSc6ICdmVScsICcyJzogJ2ZBJywgJzMnOiAnZkMnLCAnNCc6ICdmRycsICc1JzogJ21VJywgJzYnOiAnbUEnLCAnNyc6ICdtQycsICc4JzogJ21HJywgJyonOiAncHMnIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfDF8MnwzfDR8NXw2fDd8OHxcXCopL2csIGZ1bmN0aW9uICh4KSB7IHJldHVybiBvYmpbeF07IH0pO1xufVxuLy9uYW1lOiBzaVJuYUF4b2xhYnNUb0djcnNcbi8vaW5wdXQ6IHN0cmluZyBudWNsZW90aWRlcyB7c2VtVHlwZTogQXhvbGFicyAvIHNpUk5BfVxuLy9vdXRwdXQ6IHN0cmluZyByZXN1bHQge3NlbVR5cGU6IEdDUlN9XG5leHBvcnQgZnVuY3Rpb24gc2lSbmFBeG9sYWJzVG9HY3JzKG51Y2xlb3RpZGVzKSB7XG4gICAgY29uc3Qgb2JqID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnVWYnOiAnZlUnLCAnQWYnOiAnZkEnLCAnQ2YnOiAnZkMnLCAnR2YnOiAnZkcnLCAndSc6ICdtVScsICdhJzogJ21BJywgJ2MnOiAnbUMnLCAnZyc6ICdtRycsICdzJzogJ3BzJyxcbiAgICB9O1xuICAgIHJldHVybiBudWNsZW90aWRlcy5yZXBsYWNlKC8oXFwoaW52YWJhc2ljXFwpfFxcKEdhbE5BYy0yLUpOSlxcKXxVZnxBZnxDZnxHZnx1fGF8Y3xnfHMpL2csIGZ1bmN0aW9uICh4KSB7IHJldHVybiBvYmpbeF07IH0pO1xufVxuLy9uYW1lOiBzaVJuYUF4b2xhYnNUb0Jpb1NwcmluZ1xuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBBeG9sYWJzIC8gc2lSTkF9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogQmlvU3ByaW5nIC8gc2lSTkF9XG5leHBvcnQgZnVuY3Rpb24gc2lSbmFBeG9sYWJzVG9CaW9TcHJpbmcobnVjbGVvdGlkZXMpIHtcbiAgICBjb25zdCBvYmogPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsXG4gICAgICAgICdVZic6ICcxJywgJ0FmJzogJzInLCAnQ2YnOiAnMycsICdHZic6ICc0JywgJ3UnOiAnNScsICdhJzogJzYnLCAnYyc6ICc3JywgJ2cnOiAnOCcsICdzJzogJyonLFxuICAgIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfFVmfEFmfENmfEdmfHV8YXxjfGd8cykvZywgZnVuY3Rpb24gKHgpIHsgcmV0dXJuIG9ialt4XTsgfSk7XG59XG4vL25hbWU6IHNpUm5hQXhvbGFic1RvTnVjbGVvdGlkZXNcbi8vaW5wdXQ6IHN0cmluZyBudWNsZW90aWRlcyB7c2VtVHlwZTogQXhvbGFicyAvIHNpUk5BfVxuLy9vdXRwdXQ6IHN0cmluZyByZXN1bHQge3NlbVR5cGU6IFJOQSBudWNsZW90aWRlc31cbmV4cG9ydCBmdW5jdGlvbiBzaVJuYUF4b2xhYnNUb051Y2xlb3RpZGVzKG51Y2xlb3RpZGVzKSB7XG4gICAgY29uc3Qgb2JqID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnVWYnOiAnVScsICdBZic6ICdBJywgJ0NmJzogJ0MnLCAnR2YnOiAnRycsICd1JzogJ1UnLCAnYSc6ICdBJywgJ2MnOiAnQycsICdnJzogJ0cnLCAncyc6ICcnLFxuICAgIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfFVmfEFmfENmfEdmfHV8YXxjfGd8cykvZywgZnVuY3Rpb24gKHgpIHsgcmV0dXJuIG9ialt4XTsgfSk7XG59XG4vL25hbWU6IHNpUm5hR2Nyc1RvTnVjbGVvdGlkZXNcbi8vaW5wdXQ6IHN0cmluZyBudWNsZW90aWRlcyB7c2VtVHlwZTogR0NSU31cbi8vb3V0cHV0OiBzdHJpbmcgcmVzdWx0IHtzZW1UeXBlOiBSTkEgbnVjbGVvdGlkZXN9XG5leHBvcnQgZnVuY3Rpb24gc2lSbmFHY3JzVG9OdWNsZW90aWRlcyhudWNsZW90aWRlcykge1xuICAgIGNvbnN0IG9iaiA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJywgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJyxcbiAgICAgICAgJ2ZVJzogJ1UnLCAnZkEnOiAnQScsICdmQyc6ICdDJywgJ2ZHJzogJ0cnLCAnbVUnOiAnVScsICdtQSc6ICdBJywgJ21DJzogJ0MnLCAnbUcnOiAnRycsICdwcyc6ICcnLFxuICAgIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfGZVfGZBfGZDfGZHfG1VfG1BfG1DfG1HfHBzKS9nLCBmdW5jdGlvbiAoeCkgeyByZXR1cm4gb2JqW3hdOyB9KTtcbn1cbi8vbmFtZTogc2lSbmFHY3JzVG9CaW9TcHJpbmdcbi8vaW5wdXQ6IHN0cmluZyBudWNsZW90aWRlcyB7c2VtVHlwZTogR0NSU31cbi8vb3V0cHV0OiBzdHJpbmcgcmVzdWx0IHtzZW1UeXBlOiBCaW9TcHJpbmcgLyBzaVJOQX1cbmV4cG9ydCBmdW5jdGlvbiBzaVJuYUdjcnNUb0Jpb1NwcmluZyhudWNsZW90aWRlcykge1xuICAgIGNvbnN0IG9iaiA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJywgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJyxcbiAgICAgICAgJ2ZVJzogJzEnLCAnZkEnOiAnMicsICdmQyc6ICczJywgJ2ZHJzogJzQnLCAnbVUnOiAnNScsICdtQSc6ICc2JywgJ21DJzogJzcnLCAnbUcnOiAnOCcsICdwcyc6ICcqJyxcbiAgICB9O1xuICAgIHJldHVybiBudWNsZW90aWRlcy5yZXBsYWNlKC8oXFwoaW52YWJhc2ljXFwpfFxcKEdhbE5BYy0yLUpOSlxcKXxmVXxmQXxmQ3xmR3xtVXxtQXxtQ3xtR3xwcykvZywgZnVuY3Rpb24gKHgpIHsgcmV0dXJuIG9ialt4XTsgfSk7XG59XG4vL25hbWU6IHNpUm5hR2Nyc1RvQXhvbGFic1xuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBHQ1JTfVxuLy9vdXRwdXQ6IHN0cmluZyByZXN1bHQge3NlbVR5cGU6IEF4b2xhYnMgLyBzaVJOQX1cbmV4cG9ydCBmdW5jdGlvbiBzaVJuYUdjcnNUb0F4b2xhYnMobnVjbGVvdGlkZXMpIHtcbiAgICBjb25zdCBvYmogPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsXG4gICAgICAgICdmVSc6ICdVZicsICdmQSc6ICdBZicsICdmQyc6ICdDZicsICdmRyc6ICdHZicsICdtVSc6ICd1JywgJ21BJzogJ2EnLCAnbUMnOiAnYycsICdtRyc6ICdnJywgJ3BzJzogJ3MnLFxuICAgIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfGZVfGZBfGZDfGZHfG1VfG1BfG1DfG1HfHBzKS9nLCBmdW5jdGlvbiAoeCkgeyByZXR1cm4gb2JqW3hdOyB9KTtcbn1cbi8vbmFtZTogc2lSbmFOdWNsZW90aWRlVG9CaW9TcHJpbmdTZW5zZVN0cmFuZFxuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBSTkEgbnVjbGVvdGlkZXN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogQmlvU3ByaW5nIC8gc2lSTkF9XG5leHBvcnQgZnVuY3Rpb24gc2lSbmFOdWNsZW90aWRlVG9CaW9TcHJpbmdTZW5zZVN0cmFuZChudWNsZW90aWRlcykge1xuICAgIGxldCBjb3VudCA9IC0xO1xuICAgIGNvbnN0IG9iakZvckxlZnRFZGdlID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnQSc6ICc2KicsICdVJzogJzUqJywgJ0cnOiAnOConLCAnQyc6ICc3KicgfTtcbiAgICBjb25zdCBvYmpGb3JSaWdodEVkZ2UgPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsXG4gICAgICAgICdBJzogJyo2JywgJ1UnOiAnKjUnLCAnRyc6ICcqOCcsICdDJzogJyo3JyB9O1xuICAgIGNvbnN0IG9iakZvck9kZEluZGljZXMgPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsXG4gICAgICAgICdBJzogJzYnLCAnVSc6ICc1JywgJ0cnOiAnOCcsICdDJzogJzcnIH07XG4gICAgY29uc3Qgb2JqRm9yRXZlbkluZGljZXMgPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsXG4gICAgICAgICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsICdBJzogJzInLCAnVSc6ICcxJywgJ0cnOiAnNCcsICdDJzogJzMnIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfEF8VXxHfEMpL2csIGZ1bmN0aW9uICh4KSB7XG4gICAgICAgIGNvdW50Kys7XG4gICAgICAgIGlmIChjb3VudCA8IDIpXG4gICAgICAgICAgICByZXR1cm4gb2JqRm9yTGVmdEVkZ2VbeF07XG4gICAgICAgIGlmIChjb3VudCA+IG51Y2xlb3RpZGVzLmxlbmd0aCAtIDMpXG4gICAgICAgICAgICByZXR1cm4gb2JqRm9yUmlnaHRFZGdlW3hdO1xuICAgICAgICByZXR1cm4gKGNvdW50ICUgMiA9PSAwKSA/IG9iakZvckV2ZW5JbmRpY2VzW3hdIDogb2JqRm9yT2RkSW5kaWNlc1t4XTtcbiAgICB9KTtcbn1cbi8vbmFtZTogc2lSbmFOdWNsZW90aWRlc1RvR2Nyc1xuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBSTkEgbnVjbGVvdGlkZXN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogR0NSU31cbmV4cG9ydCBmdW5jdGlvbiBzaVJuYU51Y2xlb3RpZGVzVG9HY3JzKG51Y2xlb3RpZGVzKSB7XG4gICAgbGV0IGNvdW50ID0gLTE7XG4gICAgY29uc3Qgb2JqRm9yTGVmdEVkZ2UgPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsXG4gICAgICAgICdBJzogJ21BcHMnLCAnVSc6ICdtVXBzJywgJ0cnOiAnbUdwcycsICdDJzogJ21DcHMnIH07XG4gICAgY29uc3Qgb2JqRm9yUmlnaHRFZGdlID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnQSc6ICdwc21BJywgJ1UnOiAncHNtVScsICdHJzogJ3BzbUcnLCAnQyc6ICdwc21DJyB9O1xuICAgIGNvbnN0IG9iakZvckV2ZW5JbmRpY2VzID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLFxuICAgICAgICAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLCAnQSc6ICdmQScsICdVJzogJ2ZVJywgJ0cnOiAnZkcnLCAnQyc6ICdmQycgfTtcbiAgICBjb25zdCBvYmpGb3JPZGRJbmRpY2VzID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLFxuICAgICAgICAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLCAnQSc6ICdtQScsICdVJzogJ21VJywgJ0cnOiAnbUcnLCAnQyc6ICdtQycgfTtcbiAgICByZXR1cm4gbnVjbGVvdGlkZXMucmVwbGFjZSgvKFxcKGludmFiYXNpY1xcKXxcXChHYWxOQWMtMi1KTkpcXCl8QXxVfEd8QykvZywgZnVuY3Rpb24gKHgpIHtcbiAgICAgICAgY291bnQrKztcbiAgICAgICAgaWYgKGNvdW50IDwgMilcbiAgICAgICAgICAgIHJldHVybiBvYmpGb3JMZWZ0RWRnZVt4XTtcbiAgICAgICAgaWYgKGNvdW50ID4gbnVjbGVvdGlkZXMubGVuZ3RoIC0gMylcbiAgICAgICAgICAgIHJldHVybiBvYmpGb3JSaWdodEVkZ2VbeF07XG4gICAgICAgIHJldHVybiAoY291bnQgJSAyID09IDApID8gb2JqRm9yRXZlbkluZGljZXNbeF0gOiBvYmpGb3JPZGRJbmRpY2VzW3hdO1xuICAgIH0pO1xufVxuLy9uYW1lOiBzaVJuYU51Y2xlb3RpZGVUb0F4b2xhYnNTZW5zZVN0cmFuZFxuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBSTkEgbnVjbGVvdGlkZXN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogQXhvbGFic31cbmV4cG9ydCBmdW5jdGlvbiBzaVJuYU51Y2xlb3RpZGVUb0F4b2xhYnNTZW5zZVN0cmFuZChudWNsZW90aWRlcykge1xuICAgIGxldCBjb3VudCA9IC0xO1xuICAgIGNvbnN0IG9iakZvckxlZnRFZGdlID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnQSc6ICdhcycsICdVJzogJ3VzJywgJ0cnOiAnZ3MnLCAnQyc6ICdjcycgfTtcbiAgICBjb25zdCBvYmpGb3JTb21lSW5kaWNlcyA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJyxcbiAgICAgICAgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJywgJ0EnOiAnQWYnLCAnVSc6ICdVZicsICdHJzogJ0dmJywgJ0MnOiAnQ2YnIH07XG4gICAgY29uc3Qgb2JqID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnQSc6ICdhJywgJ1UnOiAndScsICdHJzogJ2cnLCAnQyc6ICdjJyB9O1xuICAgIHJldHVybiBudWNsZW90aWRlcy5yZXBsYWNlKC8oXFwoaW52YWJhc2ljXFwpfFxcKEdhbE5BYy0yLUpOSlxcKXxBfFV8R3xDKS9nLCBmdW5jdGlvbiAoeCkge1xuICAgICAgICBjb3VudCsrO1xuICAgICAgICBpZiAoY291bnQgPCAyKVxuICAgICAgICAgICAgcmV0dXJuIG9iakZvckxlZnRFZGdlW3hdO1xuICAgICAgICBpZiAoY291bnQgPT0gNiB8fCAoY291bnQgPiA3ICYmIGNvdW50IDwgMTEpKVxuICAgICAgICAgICAgcmV0dXJuIG9iakZvclNvbWVJbmRpY2VzW3hdO1xuICAgICAgICBpZiAoY291bnQgPT0gbnVjbGVvdGlkZXMubGVuZ3RoIC0gMSlcbiAgICAgICAgICAgIHJldHVybiAnYSc7XG4gICAgICAgIHJldHVybiBvYmpbeF07XG4gICAgfSk7XG59XG4vL25hbWU6IHNpUm5hTnVjbGVvdGlkZVRvQXhvbGFic0FudGlzZW5zZVN0cmFuZFxuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBSTkEgbnVjbGVvdGlkZXN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogQXhvbGFic31cbmV4cG9ydCBmdW5jdGlvbiBzaVJuYU51Y2xlb3RpZGVUb0F4b2xhYnNBbnRpc2Vuc2VTdHJhbmQobnVjbGVvdGlkZXMpIHtcbiAgICBsZXQgY291bnQgPSAtMTtcbiAgICBjb25zdCBvYmpGb3JTbWFsbExpbmthZ2VzID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLFxuICAgICAgICAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLCAnQSc6ICdhcycsICdVJzogJ3VzJywgJ0cnOiAnZ3MnLCAnQyc6ICdjcycgfTtcbiAgICBjb25zdCBvYmpGb3JCaWdMaW5rYWdlcyA9IHsgJyhpbnZhYmFzaWMpJzogJyhpbnZhYmFzaWMpJyxcbiAgICAgICAgJyhHYWxOQWMtMi1KTkopJzogJyhHYWxOQWMtMi1KTkopJywgJ0EnOiAnQWZzJywgJ1UnOiAnVWZzJywgJ0cnOiAnR2ZzJywgJ0MnOiAnQ2ZzJyB9O1xuICAgIGNvbnN0IG9iakZvclNvbWVJbmRpY2VzID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLFxuICAgICAgICAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLCAnQSc6ICdBZicsICdVJzogJ1VmJywgJ0cnOiAnR2YnLCAnQyc6ICdDZicgfTtcbiAgICBjb25zdCBvYmogPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsXG4gICAgICAgICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsICdBJzogJ2EnLCAnVSc6ICd1JywgJ0cnOiAnZycsICdDJzogJ2MnIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfEF8VXxHfEMpL2csIGZ1bmN0aW9uICh4KSB7XG4gICAgICAgIGNvdW50Kys7XG4gICAgICAgIGlmIChjb3VudCA+IDE5ICYmIGNvdW50IDwgMjIpXG4gICAgICAgICAgICByZXR1cm4gb2JqRm9yU21hbGxMaW5rYWdlc1t4XTtcbiAgICAgICAgaWYgKGNvdW50ID09IDApXG4gICAgICAgICAgICByZXR1cm4gJ3VzJztcbiAgICAgICAgaWYgKGNvdW50ID09IDEpXG4gICAgICAgICAgICByZXR1cm4gb2JqRm9yQmlnTGlua2FnZXNbeF07XG4gICAgICAgIHJldHVybiAoY291bnQgPT0gNSB8fCBjb3VudCA9PSA3IHx8IGNvdW50ID09IDggfHwgY291bnQgPT0gMTMgfHwgY291bnQgPT0gMTUpID8gb2JqRm9yU29tZUluZGljZXNbeF0gOiBvYmpbeF07XG4gICAgfSk7XG59XG4vL25hbWU6IGdjcnNUb051Y2xlb3RpZGVzXG4vL2lucHV0OiBzdHJpbmcgbnVjbGVvdGlkZXMge3NlbVR5cGU6IEdDUlN9XG4vL291dHB1dDogc3RyaW5nIHJlc3VsdCB7c2VtVHlwZTogUk5BIG51Y2xlb3RpZGVzfVxuZXhwb3J0IGZ1bmN0aW9uIGdjcnNUb051Y2xlb3RpZGVzKG51Y2xlb3RpZGVzKSB7XG4gICAgY29uc3Qgb2JqID0geyAnKGludmFiYXNpYyknOiAnKGludmFiYXNpYyknLCAnKEdhbE5BYy0yLUpOSiknOiAnKEdhbE5BYy0yLUpOSiknLFxuICAgICAgICAnbUFwcyc6ICdBJywgJ21VcHMnOiAnVScsICdtR3BzJzogJ0cnLCAnbUNwcyc6ICdDJywgJ2ZBcHMnOiAnQScsICdmVXBzJzogJ1UnLCAnZkdwcyc6ICdHJywgJ2ZDcHMnOiAnQycsXG4gICAgICAgICdmVSc6ICdVJywgJ2ZBJzogJ0EnLCAnZkMnOiAnQycsICdmRyc6ICdHJywgJ21VJzogJ1UnLCAnbUEnOiAnQScsICdtQyc6ICdDJywgJ21HJzogJ0cnLFxuICAgIH07XG4gICAgcmV0dXJuIG51Y2xlb3RpZGVzLnJlcGxhY2UoLyhcXChpbnZhYmFzaWNcXCl8XFwoR2FsTkFjLTItSk5KXFwpfG1BcHN8bVVwc3xtR3BzfG1DcHN8ZkFwc3xmVXBzfGZHcHN8ZkNwc3xmVXxmQXxmQ3xmR3xtVXxtQXxtQ3xtRykvZywgZnVuY3Rpb24gKHgpIHsgcmV0dXJuIG9ialt4XTsgfSk7XG59XG4vL25hbWU6IGdjcnNUb01lcm1hZGUxMlxuLy9pbnB1dDogc3RyaW5nIG51Y2xlb3RpZGVzIHtzZW1UeXBlOiBHQ1JTfVxuLy9vdXRwdXQ6IHN0cmluZyByZXN1bHQge3NlbVR5cGU6IE1lcm1hZGUgMTIgLyBzaVJOQX1cbmV4cG9ydCBmdW5jdGlvbiBnY3JzVG9NZXJtYWRlMTIobnVjbGVvdGlkZXMpIHtcbiAgICBjb25zdCBvYmogPSB7ICcoaW52YWJhc2ljKSc6ICcoaW52YWJhc2ljKScsICcoR2FsTkFjLTItSk5KKSc6ICcoR2FsTkFjLTItSk5KKScsXG4gICAgICAgICdtQXBzJzogJ2UnLCAnbVVwcyc6ICdoJywgJ21HcHMnOiAnZycsICdtQ3BzJzogJ2YnLCAnZkFwcyc6ICdpJywgJ2ZVcHMnOiAnbCcsICdmR3BzJzogJ2snLCAnZkNwcyc6ICdqJywgJ2ZVJzogJ0wnLFxuICAgICAgICAnZkEnOiAnSScsICdmQyc6ICdKJywgJ2ZHJzogJ0snLCAnbVUnOiAnSCcsICdtQSc6ICdFJywgJ21DJzogJ0YnLCAnbUcnOiAnRycsXG4gICAgfTtcbiAgICByZXR1cm4gbnVjbGVvdGlkZXMucmVwbGFjZSgvKFxcKGludmFiYXNpY1xcKXxcXChHYWxOQWMtMi1KTkpcXCl8bUFwc3xtVXBzfG1HcHN8bUNwc3xmQXBzfGZVcHN8Zkdwc3xmQ3BzfGZVfGZBfGZDfGZHfG1VfG1BfG1DfG1HKS9nLCBmdW5jdGlvbiAoeCkgeyByZXR1cm4gb2JqW3hdOyB9KTtcbn1cbiIsImltcG9ydCB7IG1hcCwgc3RhZGFyZFBob3NwaGF0ZUxpbmtTbWlsZXMsIFNZTlRIRVNJWkVSUywgVEVDSE5PTE9HSUVTLCBNT0RJRklDQVRJT05TIH0gZnJvbSAnLi9tYXAnO1xuaW1wb3J0IHsgaXNWYWxpZFNlcXVlbmNlIH0gZnJvbSAnLi9zZXF1ZW5jZS1jb2Rlcy10b29scyc7XG5pbXBvcnQgeyBnZXROdWNsZW90aWRlc01vbCB9IGZyb20gJy4vbW9sLXRyYW5zZm9ybWF0aW9ucyc7XG5leHBvcnQgZnVuY3Rpb24gc2VxdWVuY2VUb01vbFYzMDAwKHNlcXVlbmNlLCBpbnZlcnRlZCA9IGZhbHNlLCBvY2xSZW5kZXIgPSBmYWxzZSwgZm9ybWF0KSB7XG4gICAgY29uc3Qgb2JqID0gZ2V0T2JqZWN0V2l0aENvZGVzQW5kU21pbGVzKHNlcXVlbmNlLCBmb3JtYXQpO1xuICAgIGxldCBjb2RlcyA9IHNvcnRCeVN0cmluZ0xlbmd0aEluRGVzY2VuZGluZ09yZGVyKE9iamVjdC5rZXlzKG9iaikpO1xuICAgIGxldCBpID0gMDtcbiAgICBjb25zdCBzbWlsZXNDb2RlcyA9IFtdO1xuICAgIGNvbnN0IGNvZGVzTGlzdCA9IFtdO1xuICAgIGNvbnN0IGxpbmtzID0gWydzJywgJ3BzJywgJyonXTtcbiAgICBjb25zdCBpbmNsdWRlc1N0YW5kYXJkTGlua0FscmVhZHkgPSBbJ2UnLCAnaCcsIC8qJ2cnLCovICdmJywgJ2knLCAnbCcsICdrJywgJ2onXTtcbiAgICBjb25zdCBkcm9wZG93bnMgPSBPYmplY3Qua2V5cyhNT0RJRklDQVRJT05TKTtcbiAgICBjb2RlcyA9IGNvZGVzLmNvbmNhdChkcm9wZG93bnMpO1xuICAgIHdoaWxlIChpIDwgc2VxdWVuY2UubGVuZ3RoKSB7XG4gICAgICAgIGNvbnN0IGNvZGUgPSBjb2Rlcy5maW5kKChzKSA9PiBzID09IHNlcXVlbmNlLnNsaWNlKGksIGkgKyBzLmxlbmd0aCkpO1xuICAgICAgICBpICs9IGNvZGUubGVuZ3RoO1xuICAgICAgICBpbnZlcnRlZCA/IGNvZGVzTGlzdC51bnNoaWZ0KGNvZGUpIDogY29kZXNMaXN0LnB1c2goY29kZSk7XG4gICAgfVxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgY29kZXNMaXN0Lmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIGlmIChkcm9wZG93bnMuaW5jbHVkZXMoY29kZXNMaXN0W2ldKSkge1xuICAgICAgICAgICAgc21pbGVzQ29kZXMucHVzaCgoaSA+PSBjb2Rlc0xpc3QubGVuZ3RoIC8gMikgP1xuICAgICAgICAgICAgICAgIE1PRElGSUNBVElPTlNbY29kZXNMaXN0W2ldXS5yaWdodCA6IE1PRElGSUNBVElPTlNbY29kZXNMaXN0W2ldXS5sZWZ0KTtcbiAgICAgICAgICAgIHNtaWxlc0NvZGVzLnB1c2goc3RhZGFyZFBob3NwaGF0ZUxpbmtTbWlsZXMpO1xuICAgICAgICB9XG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgaWYgKGxpbmtzLmluY2x1ZGVzKGNvZGVzTGlzdFtpXSkgfHxcbiAgICAgICAgICAgICAgICBpbmNsdWRlc1N0YW5kYXJkTGlua0FscmVhZHkuaW5jbHVkZXMoY29kZXNMaXN0W2ldKSB8fFxuICAgICAgICAgICAgICAgIChpIDwgY29kZXNMaXN0Lmxlbmd0aCAtIDEgJiYgbGlua3MuaW5jbHVkZXMoY29kZXNMaXN0W2kgKyAxXSkpKVxuICAgICAgICAgICAgICAgIHNtaWxlc0NvZGVzLnB1c2gob2JqW2NvZGVzTGlzdFtpXV0pO1xuICAgICAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICAgICAgc21pbGVzQ29kZXMucHVzaChvYmpbY29kZXNMaXN0W2ldXSk7XG4gICAgICAgICAgICAgICAgc21pbGVzQ29kZXMucHVzaChzdGFkYXJkUGhvc3BoYXRlTGlua1NtaWxlcyk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGdldE51Y2xlb3RpZGVzTW9sKHNtaWxlc0NvZGVzLCBvY2xSZW5kZXIpO1xufVxuZXhwb3J0IGZ1bmN0aW9uIHNlcXVlbmNlVG9TbWlsZXMoc2VxdWVuY2UsIGludmVydGVkID0gZmFsc2UsIGZvcm1hdCkge1xuICAgIGNvbnN0IG9iaiA9IGdldE9iamVjdFdpdGhDb2Rlc0FuZFNtaWxlcyhzZXF1ZW5jZSwgZm9ybWF0KTtcbiAgICBsZXQgY29kZXMgPSBzb3J0QnlTdHJpbmdMZW5ndGhJbkRlc2NlbmRpbmdPcmRlcihPYmplY3Qua2V5cyhvYmopKTtcbiAgICBsZXQgaSA9IDA7XG4gICAgbGV0IHNtaWxlcyA9ICcnO1xuICAgIGNvbnN0IGNvZGVzTGlzdCA9IFtdO1xuICAgIGNvbnN0IGxpbmtzID0gWydzJywgJ3BzJywgJyonXTtcbiAgICBjb25zdCBpbmNsdWRlc1N0YW5kYXJkTGlua0FscmVhZHkgPSBbJ2UnLCAnaCcsIC8qJ2cnLCovICdmJywgJ2knLCAnbCcsICdrJywgJ2onXTtcbiAgICBjb25zdCBkcm9wZG93bnMgPSBPYmplY3Qua2V5cyhNT0RJRklDQVRJT05TKTtcbiAgICBjb2RlcyA9IGNvZGVzLmNvbmNhdChkcm9wZG93bnMpO1xuICAgIHdoaWxlIChpIDwgc2VxdWVuY2UubGVuZ3RoKSB7XG4gICAgICAgIGNvbnN0IGNvZGUgPSBjb2Rlcy5maW5kKChzKSA9PiBzID09IHNlcXVlbmNlLnNsaWNlKGksIGkgKyBzLmxlbmd0aCkpO1xuICAgICAgICBpICs9IGNvZGUubGVuZ3RoO1xuICAgICAgICBpbnZlcnRlZCA/IGNvZGVzTGlzdC51bnNoaWZ0KGNvZGUpIDogY29kZXNMaXN0LnB1c2goY29kZSk7XG4gICAgfVxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgY29kZXNMaXN0Lmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIGlmIChkcm9wZG93bnMuaW5jbHVkZXMoY29kZXNMaXN0W2ldKSkge1xuICAgICAgICAgICAgc21pbGVzICs9IChpID49IGNvZGVzTGlzdC5sZW5ndGggLyAyKSA/XG4gICAgICAgICAgICAgICAgTU9ESUZJQ0FUSU9OU1tjb2Rlc0xpc3RbaV1dLnJpZ2h0ICsgc3RhZGFyZFBob3NwaGF0ZUxpbmtTbWlsZXMgOlxuICAgICAgICAgICAgICAgIE1PRElGSUNBVElPTlNbY29kZXNMaXN0W2ldXS5sZWZ0ICsgc3RhZGFyZFBob3NwaGF0ZUxpbmtTbWlsZXM7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICBpZiAobGlua3MuaW5jbHVkZXMoY29kZXNMaXN0W2ldKSB8fFxuICAgICAgICAgICAgICAgIGluY2x1ZGVzU3RhbmRhcmRMaW5rQWxyZWFkeS5pbmNsdWRlcyhjb2Rlc0xpc3RbaV0pIHx8XG4gICAgICAgICAgICAgICAgKGkgPCBjb2Rlc0xpc3QubGVuZ3RoIC0gMSAmJiBsaW5rcy5pbmNsdWRlcyhjb2Rlc0xpc3RbaSArIDFdKSkpXG4gICAgICAgICAgICAgICAgc21pbGVzICs9IG9ialtjb2Rlc0xpc3RbaV1dO1xuICAgICAgICAgICAgZWxzZVxuICAgICAgICAgICAgICAgIHNtaWxlcyArPSBvYmpbY29kZXNMaXN0W2ldXSArIHN0YWRhcmRQaG9zcGhhdGVMaW5rU21pbGVzO1xuICAgICAgICB9XG4gICAgfVxuICAgIHNtaWxlcyA9IHNtaWxlcy5yZXBsYWNlKC9PTy9nLCAnTycpO1xuICAgIHJldHVybiAoKGxpbmtzLmluY2x1ZGVzKGNvZGVzTGlzdFtjb2Rlc0xpc3QubGVuZ3RoIC0gMV0pICYmXG4gICAgICAgIGNvZGVzTGlzdC5sZW5ndGggPiAxICYmXG4gICAgICAgICFpbmNsdWRlc1N0YW5kYXJkTGlua0FscmVhZHkuaW5jbHVkZXMoY29kZXNMaXN0W2NvZGVzTGlzdC5sZW5ndGggLSAyXSkpIHx8XG4gICAgICAgIGRyb3Bkb3ducy5pbmNsdWRlcyhjb2Rlc0xpc3RbY29kZXNMaXN0Lmxlbmd0aCAtIDFdKSB8fFxuICAgICAgICBpbmNsdWRlc1N0YW5kYXJkTGlua0FscmVhZHkuaW5jbHVkZXMoY29kZXNMaXN0W2NvZGVzTGlzdC5sZW5ndGggLSAxXSkpID9cbiAgICAgICAgc21pbGVzIDpcbiAgICAgICAgc21pbGVzLnNsaWNlKDAsIHNtaWxlcy5sZW5ndGggLSBzdGFkYXJkUGhvc3BoYXRlTGlua1NtaWxlcy5sZW5ndGggKyAxKTtcbn1cbmZ1bmN0aW9uIGdldE9iamVjdFdpdGhDb2Rlc0FuZFNtaWxlcyhzZXF1ZW5jZSwgZm9ybWF0KSB7XG4gICAgY29uc3Qgb2JqID0ge307XG4gICAgaWYgKGZvcm1hdCA9PSBudWxsKSB7XG4gICAgICAgIGZvciAoY29uc3Qgc3ludGhlc2l6ZXIgb2YgT2JqZWN0LmtleXMobWFwKSkge1xuICAgICAgICAgICAgZm9yIChjb25zdCB0ZWNobm9sb2d5IG9mIE9iamVjdC5rZXlzKG1hcFtzeW50aGVzaXplcl0pKSB7XG4gICAgICAgICAgICAgICAgZm9yIChjb25zdCBjb2RlIG9mIE9iamVjdC5rZXlzKG1hcFtzeW50aGVzaXplcl1bdGVjaG5vbG9neV0pKVxuICAgICAgICAgICAgICAgICAgICBvYmpbY29kZV0gPSBtYXBbc3ludGhlc2l6ZXJdW3RlY2hub2xvZ3ldW2NvZGVdLlNNSUxFUztcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cbiAgICBlbHNlIHtcbiAgICAgICAgZm9yIChjb25zdCB0ZWNobm9sb2d5IG9mIE9iamVjdC5rZXlzKG1hcFtmb3JtYXRdKSkge1xuICAgICAgICAgICAgZm9yIChjb25zdCBjb2RlIG9mIE9iamVjdC5rZXlzKG1hcFtmb3JtYXRdW3RlY2hub2xvZ3ldKSlcbiAgICAgICAgICAgICAgICBvYmpbY29kZV0gPSBtYXBbZm9ybWF0XVt0ZWNobm9sb2d5XVtjb2RlXS5TTUlMRVM7XG4gICAgICAgIH1cbiAgICB9XG4gICAgLy8gVE9ETzogY3JlYXRlIG9iamVjdCBiYXNlZCBmcm9tIHN5bnRoZXNpemVyIHR5cGUgdG8gYXZvaWQga2V5KGNvZGVzKSBkdXBsaWNhdGVzXG4gICAgY29uc3Qgb3V0cHV0ID0gaXNWYWxpZFNlcXVlbmNlKHNlcXVlbmNlLCBmb3JtYXQpO1xuICAgIGlmIChvdXRwdXQuc3ludGhlc2l6ZXIuaW5jbHVkZXMoU1lOVEhFU0laRVJTLk1FUk1BREVfMTIpKVxuICAgICAgICBvYmpbJ2cnXSA9IG1hcFtTWU5USEVTSVpFUlMuTUVSTUFERV8xMl1bVEVDSE5PTE9HSUVTLlNJX1JOQV1bJ2cnXS5TTUlMRVM7XG4gICAgZWxzZSBpZiAob3V0cHV0LnN5bnRoZXNpemVyLmluY2x1ZGVzKFNZTlRIRVNJWkVSUy5BWE9MQUJTKSlcbiAgICAgICAgb2JqWydnJ10gPSBtYXBbU1lOVEhFU0laRVJTLkFYT0xBQlNdW1RFQ0hOT0xPR0lFUy5TSV9STkFdWydnJ10uU01JTEVTO1xuICAgIHJldHVybiBvYmo7XG59XG5mdW5jdGlvbiBzb3J0QnlTdHJpbmdMZW5ndGhJbkRlc2NlbmRpbmdPcmRlcihhcnJheSkge1xuICAgIHJldHVybiBhcnJheS5zb3J0KGZ1bmN0aW9uIChhLCBiKSB7IHJldHVybiBiLmxlbmd0aCAtIGEubGVuZ3RoOyB9KTtcbn1cbiIsImV4cG9ydCBjb25zdCBTWU5USEVTSVpFUlMgPSB7XG4gICAgUkFXX05VQ0xFT1RJREVTOiAnUmF3IE51Y2xlb3RpZGVzJyxcbiAgICBCSU9TUFJJTkc6ICdCaW9TcHJpbmcgQ29kZXMnLFxuICAgIEdDUlM6ICdKYW5zc2VuIEdDUlMgQ29kZXMnLFxuICAgIEFYT0xBQlM6ICdBeG9sYWJzIENvZGVzJyxcbiAgICBNRVJNQURFXzEyOiAnTWVybWFkZSAxMicsXG59O1xuZXhwb3J0IGNvbnN0IFRFQ0hOT0xPR0lFUyA9IHtcbiAgICBETkE6ICdETkEnLFxuICAgIFJOQTogJ1JOQScsXG4gICAgQVNPX0dBUE1FUlM6ICdGb3IgQVNPIEdhcG1lcnMnLFxuICAgIFNJX1JOQTogJ0ZvciAyXFwnLU9NZSBhbmQgMlxcJy1GIG1vZGlmaWVkIHNpUk5BJyxcbn07XG5leHBvcnQgY29uc3QgQ09MX05BTUVTID0ge1xuICAgIENIRU1JU1RSWTogJ0NoZW1pc3RyeScsXG4gICAgTlVNQkVSOiAnTnVtYmVyJyxcbiAgICBUWVBFOiAnVHlwZScsXG4gICAgQ0hFTUlTVFJZX05BTUU6ICdDaGVtaXN0cnkgTmFtZScsXG4gICAgSU5URVJOQUxfQ09NUE9VTkRfSUQ6ICdJbnRlcm5hbCBjb21wb3VuZCBJRCcsXG4gICAgSURQOiAnSURQJyxcbiAgICBTRVFVRU5DRTogJ1NlcXVlbmNlJyxcbiAgICBDT01QT1VORF9OQU1FOiAnQ29tcG91bmQgTmFtZScsXG4gICAgQ09NUE9VTkRfQ09NTUVOVFM6ICdDb21wb3VuZCBDb21tZW50cycsXG4gICAgU0FMVDogJ1NhbHQnLFxuICAgIEVRVUlWQUxFTlRTOiAnRXF1aXZhbGVudHMnLFxuICAgIFBVUklUWTogJ1B1cml0eScsXG4gICAgQ1BEX01XOiAnQ3BkIE1XJyxcbiAgICBTQUxUX01BU1M6ICdTYWx0IG1hc3MnLFxuICAgIEJBVENIX01XOiAnQmF0Y2ggTVcnLFxuICAgIFNPVVJDRTogJ1NvdXJjZScsXG4gICAgSUNEOiAnSUNEJyxcbiAgICBPV05FUjogJ093bmVyJyxcbn07XG4vLyBpbnRlcmZhY2UgQ09ERVMge1xuLy8gfVxuZXhwb3J0IGNvbnN0IE1PRElGSUNBVElPTlMgPSB7XG4gICAgJyhpbnZhYmFzaWMpJzoge1xuICAgICAgICBtb2xlY3VsYXJXZWlnaHQ6IDExOC4xMyxcbiAgICAgICAgbGVmdDogJ09bQ0BASF0xQ1tDQEBIXU9bQ0BIXTFDTycsXG4gICAgICAgIHJpZ2h0OiAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPJyxcbiAgICB9LFxuICAgICcoR2FsTkFjLTItSk5KKSc6IHtcbiAgICAgICAgbW9sZWN1bGFyV2VpZ2h0OiAxMjczLjMsXG4gICAgICAgIGxlZnQ6ICdDKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpTkMoPU8pQ0NDQyg9TylOQ0MoTylDTycsXG4gICAgICAgIHJpZ2h0OiAnT0NDKE8pQ05DKD1PKUNDQ0MoPU8pTkMoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknICtcbiAgICAgICAgICAgICcoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknICtcbiAgICAgICAgICAgICcoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknLFxuICAgIH0sXG59O1xuZXhwb3J0IGNvbnN0IHN0YWRhcmRQaG9zcGhhdGVMaW5rU21pbGVzID0gJ09QKD1PKShPKU8nO1xuZXhwb3J0IGNvbnN0IG1hcCA9IHtcbiAgICAnUmF3IE51Y2xlb3RpZGVzJzoge1xuICAgICAgICAnRE5BJzoge1xuICAgICAgICAgICAgJ0EnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnQWRlbmluZScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMxMy4yMSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdkQScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpQ1tDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnVCc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICdUeXJvc2luZScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMwNC4yLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ2RUJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoPU8pTkMyKD1PKSlDW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdHJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0d1YW5pbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMjkuMjEsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ0MnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnQ3l0b3NpbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAyODkuMTgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICAnUk5BJzoge1xuICAgICAgICAgICAgJ0EnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnQWRlbmluZScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMxMy4yMSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdkQScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpQ1tDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnVSc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICdVcmFjaWwnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMDYuMTcsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnclUnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE8pW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdHJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0d1YW5pbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMjkuMjEsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ0MnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnQ3l0b3NpbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAyODkuMTgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgIH0sXG4gICAgJ0Jpb1NwcmluZyBDb2Rlcyc6IHtcbiAgICAgICAgJ0ZvciBBU08gR2FwbWVycyc6IHtcbiAgICAgICAgICAgICc1Jzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdNT0UtNU1lLXJVJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzc4LjI3LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JVJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoPU8pTkMyKD1PKSlbQ0BIXShPQ0NPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJzYnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ01PRS1yQScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDM4Ny4yOSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyQScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0NDT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICc3Jzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdNT0UtNU1lLXJDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzc3LjI5LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoTik9TkMyKD1PKSlbQ0BIXShPQ0NPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJzgnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ01PRS1yRycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDQwMy4yOCxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyRycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0NDT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICc5Jzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzUtTWV0aHlsLWRDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzAzLjIxLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ2RDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoTik9TkMyKD1PKSlDW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICcqJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ3BzIGxpbmthZ2UnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAxNi4wNyxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT1AoPU8pKFMpTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ0EnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnQWRlbmluZScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMxMy4yMSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdkQScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpQ1tDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnQyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICdDeXRvc2luZScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDI4OS4xOCxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdkQycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpQ1tDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnRyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICdHdWFuaW5lJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzI5LjIxLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ2RHJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilDW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdUJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ1R5cm9zaW5lJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzA0LjIsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZFQnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DKEMpQyg9TylOQzIoPU8pKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICAnRm9yIDJcXCctT01lIGFuZCAyXFwnLUYgbW9kaWZpZWQgc2lSTkEnOiB7XG4gICAgICAgICAgICAnMSc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1VJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzA4LjE2LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JVJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnMic6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1BJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzMxLjIsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICczJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCctZmx1b3JvLUMnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMDcuMTgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICc0Jzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCctZmx1b3JvLUcnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNDcuMTksXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICc1Jzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtclUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMjAuMixcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyVScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICc2Jzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtckEnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNDMuMjQsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnNyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnT01lLXJDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzE5LjIxLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJzgnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ09NZS1yRycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDM1OS4yNCxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyRycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICcqJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ3BzIGxpbmthZ2UnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAxNi4wNyxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT1AoPU8pKFMpTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgIH0sXG4gICAgJ0F4b2xhYnMgQ29kZXMnOiB7XG4gICAgICAgICdGb3IgMlxcJy1PTWUgYW5kIDJcXCctRiBtb2RpZmllZCBzaVJOQSc6IHtcbiAgICAgICAgICAgICdVZic6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1VJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzA4LjE2LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JVJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnQWYnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJy1mbHVvcm8tQScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMzMS4yLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JBJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnQ2YnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJy1mbHVvcm8tQycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMwNy4xOCxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyQycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ0dmJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCctZmx1b3JvLUcnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNDcuMTksXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICd1Jzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtclUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMjAuMixcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyVScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdhJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtckEnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNDMuMjQsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnYyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnT01lLXJDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzE5LjIxLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ2cnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ09NZS1yRycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDM1OS4sXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAncyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICdwcyBsaW5rYWdlJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMTYuMDcsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09QKD1PKShTKU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICB9LFxuICAgICdKYW5zc2VuIEdDUlMgQ29kZXMnOiB7XG4gICAgICAgICdGb3IgQVNPIEdhcG1lcnMnOiB7XG4gICAgICAgICAgICAnbW9lVCc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnTU9FLTVNZS1yVScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDM3OC4yNyxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyVScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUMoQylDKD1PKU5DMig9TykpW0NASF0oT0NDT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdtb2VBJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdNT0UtckEnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzODcuMjksXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DQ09DKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnbW9lNW1DJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdNT0UtNU1lLXJDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzc3LjI5LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoTik9TkMyKD1PKSlbQ0BIXShPQ0NPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJyg1bSltb2VDJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdNT0UtNU1lLXJDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzc3LjI5LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoTik9TkMyKD1PKSlbQ0BIXShPQ0NPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ21vZUcnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ01PRS1yRycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDQwMy4yOCxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyRycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0NDT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICc1bUMnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnNS1NZXRoeWwtZEMnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMDMuMjgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DKEMpQyhOKT1OQzIoPU8pKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJyg1bSlDJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzUtTWV0aHlsLWRDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzAzLjI4LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ2RDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoTik9TkMyKD1PKSlDW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdwcyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICdwcyBsaW5rYWdlJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMTYuMDcsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09QKD1PKShTKU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdBJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0FkZW5pbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMTMuMjEsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ2RBJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0FkZW5pbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMTMuMjEsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ0MnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnQ3l0b3NpbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAyODkuMTgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ2RDJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0N5dG9zaW5lJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMjg5LjE4LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ2RDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlDW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdHJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0d1YW5pbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMjkuMjEsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ2RHJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0d1YW5pbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMjkuMjEsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnZEcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKUNbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ1QnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnVHlyb3NpbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMDQuMixcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdkVCcsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUMoQylDKD1PKU5DMig9TykpQ1tDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnZFQnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnVHlyb3NpbmUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMDQuMixcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdkVCcsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUMoQylDKD1PKU5DMig9TykpQ1tDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnckEnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnQWRlbmluZScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMyOS4yMSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyQScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oTylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ3JDJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ0N5dG9zaW5lJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzA1LjE4LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnckcnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnR3VhbmluZScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDM0NS4yMSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyRycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oTylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ3JVJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJ1VyYWNpbCcsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMwNi4xNyxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyVScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oTylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICAnRm9yIDJcXCctT01lIGFuZCAyXFwnLUYgbW9kaWZpZWQgc2lSTkEnOiB7XG4gICAgICAgICAgICAnZlUnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJy1mbHVvcm8tVScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMwOC4xNixcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyVScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ2ZBJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCctZmx1b3JvLUEnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMzEuMixcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyQScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oRilbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ2ZDJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCctZmx1b3JvLUMnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMDcuMTgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdmRyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1HJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzQ3LjE5LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JHJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnbVUnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ09NZS1yVScsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMyMC4yLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JVJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ21BJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtckEnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNDMuMjQsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnbUMnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ09NZS1yQycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDMxOS4yMSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyQycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdtRyc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnT01lLXJHJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzU5LjI0LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JHJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgIH0sXG4gICAgJ01lcm1hZGUgMTInOiB7XG4gICAgICAgICdGb3IgMlxcJy1PTWUgYW5kIDJcXCctRiBtb2RpZmllZCBzaVJOQSc6IHtcbiAgICAgICAgICAgICdlJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtckEtcHMnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNTkuMzEsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUylPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnaCc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnT01lLXJVLXBzJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzM2LjI3LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JVJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ2cnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ09NZS1yRy1wcycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDM3NS4zMSxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyRycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdmJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtckMtcHMnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMzUuMjgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUylPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnaSc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1BLXBzJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzQ3LjI3LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JBJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoUylPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnbCc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1VLXBzJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzI0LjIzLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JVJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoUylPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnayc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1HLXBzJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzYzLjI2LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JHJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoUylPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnaic6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1DLXBzJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzIzLjI1LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoUylPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnTCc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1VJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzA4LjE2LFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JVJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnSSc6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnLWZsdW9yby1BJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzMxLjIsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdKJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCctZmx1b3JvLUMnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMDcuMTgsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckMnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdLJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCctZmx1b3JvLUcnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNDcuMTksXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckcnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdIJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtclUnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzMjAuMixcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyVScsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICdFJzoge1xuICAgICAgICAgICAgICAgICduYW1lJzogJzJcXCdPTWUtckEnLFxuICAgICAgICAgICAgICAgICd3ZWlnaHQnOiAzNDMuMjQsXG4gICAgICAgICAgICAgICAgJ25vcm1hbGl6ZWQnOiAnckEnLFxuICAgICAgICAgICAgICAgICdTTUlMRVMnOiAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAnRic6IHtcbiAgICAgICAgICAgICAgICAnbmFtZSc6ICcyXFwnT01lLXJDJyxcbiAgICAgICAgICAgICAgICAnd2VpZ2h0JzogMzE5LjIxLFxuICAgICAgICAgICAgICAgICdub3JtYWxpemVkJzogJ3JDJyxcbiAgICAgICAgICAgICAgICAnU01JTEVTJzogJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xTycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgJ0cnOiB7XG4gICAgICAgICAgICAgICAgJ25hbWUnOiAnMlxcJ09NZS1yRycsXG4gICAgICAgICAgICAgICAgJ3dlaWdodCc6IDM1OS4yNCxcbiAgICAgICAgICAgICAgICAnbm9ybWFsaXplZCc6ICdyRycsXG4gICAgICAgICAgICAgICAgJ1NNSUxFUyc6ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU8nLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICB9LFxufTtcbiIsImltcG9ydCAqIGFzIE9DTCBmcm9tICdvcGVuY2hlbWxpYi9mdWxsLmpzJztcbmNvbnN0IFBIT1NIQVRFID0gYFxuRGF0YWdyb2sgbW9ub21lciBsaWJyYXJ5IE51Y2xlb3RpZGVzXG5cbiAgMCAgMCAgMCAgMCAgMCAgMCAgICAgICAgICAgICAgMCBWMzAwMFxuTSAgVjMwIEJFR0lOIENUQUJcbk0gIFYzMCBDT1VOVFMgNSA0IDAgMCAwXG5NICBWMzAgQkVHSU4gQVRPTVxuTSAgVjMwIDEgTyAtMS41IDAgMCAwXG5NICBWMzAgMiBQIDAgMCAwIDBcbk0gIFYzMCAzIE8gMCAxIDAgMFxuTSAgVjMwIDQgTyAwIC0xIDAgMFxuTSAgVjMwIDUgTyAxLjUgMCAwIDBcbk0gIFYzMCBFTkQgQVRPTVxuTSAgVjMwIEJFR0lOIEJPTkRcbk0gIFYzMCAxIDEgMSAyXG5NICBWMzAgMiAyIDIgM1xuTSAgVjMwIDMgMSAyIDRcbk0gIFYzMCA0IDEgMiA1XG5NICBWMzAgRU5EIEJPTkRcbk0gIFYzMCBFTkQgQ1RBQlxuTSAgVjMwIEJFR0lOIENPTExFQ1RJT05cbk0gIFYzMCBFTkQgQ09MTEVDVElPTlxuTSAgRU5EYDtcbmNvbnN0IFRISU9QSE9TSEFURSA9IGBcbkRhdGFncm9rIG1vbm9tZXIgbGlicmFyeSBOdWNsZW90aWRlc1xuXG4gIDAgIDAgIDAgIDAgIDAgIDAgICAgICAgICAgICAgIDAgVjMwMDBcbk0gIFYzMCBCRUdJTiBDVEFCXG5NICBWMzAgQ09VTlRTIDUgNCAwIDAgMFxuTSAgVjMwIEJFR0lOIEFUT01cbk0gIFYzMCAxIE8gLTEuNSAwIDAgMFxuTSAgVjMwIDIgUCAwIDAgMCAwXG5NICBWMzAgMyBPIDAgMSAwIDBcbk0gIFYzMCA0IFMgMCAtMSAwIDBcbk0gIFYzMCA1IE8gMS41IDAgMCAwXG5NICBWMzAgRU5EIEFUT01cbk0gIFYzMCBCRUdJTiBCT05EXG5NICBWMzAgMSAxIDEgMlxuTSAgVjMwIDIgMiAyIDNcbk0gIFYzMCAzIDEgMiA0XG5NICBWMzAgNCAxIDIgNVxuTSAgVjMwIEVORCBCT05EXG5NICBWMzAgRU5EIENUQUJcbk0gIFYzMCBCRUdJTiBDT0xMRUNUSU9OXG5NICBWMzAgRU5EIENPTExFQ1RJT05cbk0gIEVORGA7XG5jb25zdCBJTlZBQkFTSUMgPSBgXG5EYXRhZ3JvayBtb25vbWVyIGxpYnJhcnkgTnVjbGVvdGlkZXNcblxuICAwICAwICAwICAwICAwICAwICAgICAgICAgICAgICAwIFYzMDAwXG5NICBWMzAgQkVHSU4gQ1RBQlxuTSAgVjMwIENPVU5UUyA4IDggMCAwIDBcbk0gIFYzMCBCRUdJTiBBVE9NXG5NICBWMzAgMSBPIDEuMDkzNCAtMi4xNjM2IDAgMFxuTSAgVjMwIDIgQyAxLjgzNjUgLTEuNDk0NSAwIDAgQ0ZHPTJcbk0gIFYzMCAzIEMgMi44MTQ3IC0xLjcwMjQgMCAwXG5NICBWMzAgNCBDIDMuMzE0NyAtMC44MzY0IDAgMCBWQUw9M1xuTSAgVjMwIDUgTyAyLjY0NTUgLTAuMDkzMiAwIDBcbk0gIFYzMCA2IEMgMS43MzIgLTAuNSAwIDAgQ0ZHPTFcbk0gIFYzMCA3IEMgMC44NjYgMCAwIDBcbk0gIFYzMCA4IE8gMC44NjYgMSAwIDBcbk0gIFYzMCBFTkQgQVRPTVxuTSAgVjMwIEJFR0lOIEJPTkRcbk0gIFYzMCAxIDEgMiAxIENGRz0xXG5NICBWMzAgMiAxIDIgM1xuTSAgVjMwIDMgMSAzIDRcbk0gIFYzMCA0IDEgNCA1XG5NICBWMzAgNSAxIDYgNVxuTSAgVjMwIDYgMSAyIDZcbk0gIFYzMCA3IDEgNiA3IENGRz0zXG5NICBWMzAgOCAxIDcgOFxuTSAgVjMwIEVORCBCT05EXG5NICBWMzAgQkVHSU4gQ09MTEVDVElPTlxuTSAgVjMwIE1ETFYzMC9TVEVBQlMgQVRPTVM9KDIgMiA2KVxuTSAgVjMwIEVORCBDT0xMRUNUSU9OXG5NICBWMzAgRU5EIENUQUJcbk0gIEVORGA7XG5leHBvcnQgZnVuY3Rpb24gZ2V0TnVjbGVvdGlkZXNNb2woc21pbGVzQ29kZXMsIG9jbFJlbmRlciA9IGZhbHNlKSB7XG4gICAgY29uc3QgbW9sQmxvY2tzID0gW107XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBzbWlsZXNDb2Rlcy5sZW5ndGggLSAxOyBpKyspIHtcbiAgICAgICAgc21pbGVzQ29kZXNbaV0gPT0gJ09QKD1PKShPKU8nID8gbW9sQmxvY2tzLnB1c2goUEhPU0hBVEUpIDpcbiAgICAgICAgICAgIHNtaWxlc0NvZGVzW2ldID09ICdPUCg9TykoUylPJyA/IG1vbEJsb2Nrcy5wdXNoKFRISU9QSE9TSEFURSkgOlxuICAgICAgICAgICAgICAgIHNtaWxlc0NvZGVzW2ldID09ICdPW0NAQEhdMUNbQ0BASF1PW0NASF0xQ08nID8gbW9sQmxvY2tzLnB1c2gocm90YXRlTnVjbGVvdGlkZXNWMzAwMChJTlZBQkFTSUMpKSA6XG4gICAgICAgICAgICAgICAgICAgIG1vbEJsb2Nrcy5wdXNoKHJvdGF0ZU51Y2xlb3RpZGVzVjMwMDAoc21pbGVzQ29kZXNbaV0pKTtcbiAgICB9XG4gICAgcmV0dXJuIGxpbmtWMzAwMChtb2xCbG9ja3MsIGZhbHNlLCBvY2xSZW5kZXIpO1xufVxuZXhwb3J0IGZ1bmN0aW9uIGxpbmtWMzAwMChtb2xCbG9ja3MsIHR3b01vbGVjdWxlcyA9IGZhbHNlLCBvY2xSZW5kZXIgPSBmYWxzZSkge1xuICAgIGxldCBtYWNyb01vbEJsb2NrID0gJ1xcbkRhdGFncm9rIG1hY3JvbW9sZWN1bGUgaGFuZGxlclxcblxcbic7XG4gICAgbWFjcm9Nb2xCbG9jayArPSAnICAwICAwICAwICAwICAwICAwICAgICAgICAgICAgOTk5IFYzMDAwXFxuJztcbiAgICBtYWNyb01vbEJsb2NrICs9ICdNICBWMzAgQkVHSU4gQ1RBQlxcbic7XG4gICAgbGV0IGF0b21CbG9jayA9ICcnO1xuICAgIGxldCBib25kQmxvY2sgPSAnJztcbiAgICBsZXQgY29sbGVjdGlvbkJsb2NrID0gJyc7XG4gICAgY29uc3QgY29sbGVjdGlvbiA9IFtdO1xuICAgIGxldCBuYXRvbSA9IDA7XG4gICAgbGV0IG5ib25kID0gMDtcbiAgICBsZXQgc2VxdWVuY2VTaGlmdCA9IDA7XG4gICAgbGV0IHhTaGlmdCA9IDA7XG4gICAgaWYgKHR3b01vbGVjdWxlcyAmJiBtb2xCbG9ja3MubGVuZ3RoID4gMSlcbiAgICAgICAgbW9sQmxvY2tzWzFdID0gaW52ZXJ0TnVjbGVvdGlkZXNWMzAwMChtb2xCbG9ja3NbMV0pO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbW9sQmxvY2tzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIG1vbEJsb2Nrc1tpXSA9IG1vbEJsb2Nrc1tpXS5yZXBsYWNlQWxsKCcoLVxcbk0gIFYzMCAnLCAnKCcpXG4gICAgICAgICAgICAucmVwbGFjZUFsbCgnLVxcbk0gIFYzMCAnLCAnJykucmVwbGFjZUFsbCgnICknLCAnKScpO1xuICAgICAgICBjb25zdCBudW1iZXJzID0gZXh0cmFjdEF0b21zQm9uZHNOdW1iZXJzVjMwMDAobW9sQmxvY2tzW2ldKTtcbiAgICAgICAgY29uc3QgY29vcmRpbmF0ZXMgPSBleHRyYWN0QXRvbURhdGFWMzAwMChtb2xCbG9ja3NbaV0pO1xuICAgICAgICBsZXQgaW5kZXhBdG9tcyA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCdNICBWMzAgQkVHSU4gQVRPTScpOyAvLyBWMzAwMCBpbmRleCBmb3IgYXRvbXMgY29vcmRpbmF0ZXNcbiAgICAgICAgaW5kZXhBdG9tcyA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCdcXG4nLCBpbmRleEF0b21zKTtcbiAgICAgICAgbGV0IGluZGV4ID0gaW5kZXhBdG9tcztcbiAgICAgICAgbGV0IGluZGV4RW5kID0gaW5kZXhBdG9tcztcbiAgICAgICAgZm9yIChsZXQgaiA9IDA7IGogPCBudW1iZXJzLm5hdG9tOyBqKyspIHtcbiAgICAgICAgICAgIGlmIChjb29yZGluYXRlcy5hdG9tSW5kZXhbal0gIT0gMSB8fCBpID09IDAgfHwgdHdvTW9sZWN1bGVzKSB7XG4gICAgICAgICAgICAgICAgLy9yZXdyaXRlIGF0b20gbnVtYmVyXG4gICAgICAgICAgICAgICAgaW5kZXggPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignVjMwJywgaW5kZXgpICsgNDtcbiAgICAgICAgICAgICAgICBpbmRleEVuZCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCcgJywgaW5kZXgpO1xuICAgICAgICAgICAgICAgIGNvbnN0IGF0b21OdW1iZXIgPSBwYXJzZUludChtb2xCbG9ja3NbaV0uc3Vic3RyaW5nKGluZGV4LCBpbmRleEVuZCkpICsgbmF0b207XG4gICAgICAgICAgICAgICAgbW9sQmxvY2tzW2ldID0gbW9sQmxvY2tzW2ldLnNsaWNlKDAsIGluZGV4KSArIGF0b21OdW1iZXIgKyBtb2xCbG9ja3NbaV0uc2xpY2UoaW5kZXhFbmQpO1xuICAgICAgICAgICAgICAgIC8vcmV3cml0ZSBjb29yZGluYXRlc1xuICAgICAgICAgICAgICAgIGluZGV4ID0gbW9sQmxvY2tzW2ldLmluZGV4T2YoJyAnLCBpbmRleCkgKyAxO1xuICAgICAgICAgICAgICAgIGluZGV4ID0gbW9sQmxvY2tzW2ldLmluZGV4T2YoJyAnLCBpbmRleCkgKyAxO1xuICAgICAgICAgICAgICAgIGluZGV4RW5kID0gbW9sQmxvY2tzW2ldLmluZGV4T2YoJyAnLCBpbmRleCk7XG4gICAgICAgICAgICAgICAgY29uc3QgdG90YWxTaGlmdCA9IHhTaGlmdCAtIGNvb3JkaW5hdGVzLnhbMF07XG4gICAgICAgICAgICAgICAgbGV0IGNvb3JkaW5hdGUgPSBNYXRoLnJvdW5kKDEwMDAwICogKHBhcnNlRmxvYXQobW9sQmxvY2tzW2ldLnN1YnN0cmluZyhpbmRleCwgaW5kZXhFbmQpKSArIHRvdGFsU2hpZnQpKSAvIDEwMDAwO1xuICAgICAgICAgICAgICAgIG1vbEJsb2Nrc1tpXSA9IG1vbEJsb2Nrc1tpXS5zbGljZSgwLCBpbmRleCkgKyBjb29yZGluYXRlICsgbW9sQmxvY2tzW2ldLnNsaWNlKGluZGV4RW5kKTtcbiAgICAgICAgICAgICAgICBpbmRleCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCcgJywgaW5kZXgpICsgMTtcbiAgICAgICAgICAgICAgICBpbmRleEVuZCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCcgJywgaW5kZXgpO1xuICAgICAgICAgICAgICAgIGNvb3JkaW5hdGUgPSBNYXRoLnJvdW5kKDEwMDAwICogKHBhcnNlRmxvYXQobW9sQmxvY2tzW2ldLnN1YnN0cmluZyhpbmRleCwgaW5kZXhFbmQpKSArIHNlcXVlbmNlU2hpZnQpKSAvIDEwMDAwO1xuICAgICAgICAgICAgICAgIG1vbEJsb2Nrc1tpXSA9IG1vbEJsb2Nrc1tpXS5zbGljZSgwLCBpbmRleCkgKyBjb29yZGluYXRlICsgbW9sQmxvY2tzW2ldLnNsaWNlKGluZGV4RW5kKTtcbiAgICAgICAgICAgICAgICBpbmRleCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCdcXG4nLCBpbmRleCkgKyAxO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICAgICAgaW5kZXggPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignTSAgVjMwJywgaW5kZXgpIC0gMTtcbiAgICAgICAgICAgICAgICBpbmRleEVuZCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCdcXG4nLCBpbmRleCArIDEpO1xuICAgICAgICAgICAgICAgIG1vbEJsb2Nrc1tpXSA9IG1vbEJsb2Nrc1tpXS5zbGljZSgwLCBpbmRleCkgKyBtb2xCbG9ja3NbaV0uc2xpY2UoaW5kZXhFbmQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGluZGV4QXRvbXNFbmQgPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignTSAgVjMwIEVORCBBVE9NJyk7XG4gICAgICAgIGF0b21CbG9jayArPSBtb2xCbG9ja3NbaV0uc3Vic3RyaW5nKGluZGV4QXRvbXMgKyAxLCBpbmRleEF0b21zRW5kKTtcbiAgICAgICAgbGV0IGluZGV4Qm9uZHMgPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignTSAgVjMwIEJFR0lOIEJPTkQnKTsgLy8gVjMwMDAgaW5kZXggZm9yIGJvbmRzXG4gICAgICAgIGluZGV4Qm9uZHMgPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignXFxuJywgaW5kZXhCb25kcyk7XG4gICAgICAgIGluZGV4ID0gaW5kZXhCb25kcztcbiAgICAgICAgaW5kZXhFbmQgPSBpbmRleEJvbmRzO1xuICAgICAgICBmb3IgKGxldCBqID0gMDsgaiA8IG51bWJlcnMubmJvbmQ7IGorKykge1xuICAgICAgICAgICAgLy9yZXdyaXRlIGJvbmQgbnVtYmVyXG4gICAgICAgICAgICBpbmRleCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCdWMzAnLCBpbmRleCkgKyA0O1xuICAgICAgICAgICAgaW5kZXhFbmQgPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignICcsIGluZGV4KTtcbiAgICAgICAgICAgIGNvbnN0IGJvbmROdW1iZXIgPSBwYXJzZUludChtb2xCbG9ja3NbaV0uc3Vic3RyaW5nKGluZGV4LCBpbmRleEVuZCkpICsgbmJvbmQ7XG4gICAgICAgICAgICBtb2xCbG9ja3NbaV0gPSBtb2xCbG9ja3NbaV0uc2xpY2UoMCwgaW5kZXgpICsgYm9uZE51bWJlciArIG1vbEJsb2Nrc1tpXS5zbGljZShpbmRleEVuZCk7XG4gICAgICAgICAgICAvL3Jld3JpdGUgYXRvbSBwYWlyIGluIGJvbmRcbiAgICAgICAgICAgIGluZGV4ID0gbW9sQmxvY2tzW2ldLmluZGV4T2YoJyAnLCBpbmRleCkgKyAxO1xuICAgICAgICAgICAgaW5kZXggPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignICcsIGluZGV4KSArIDE7XG4gICAgICAgICAgICBpbmRleEVuZCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCcgJywgaW5kZXgpO1xuICAgICAgICAgICAgbGV0IGF0b21OdW1iZXIgPSBwYXJzZUludChtb2xCbG9ja3NbaV0uc3Vic3RyaW5nKGluZGV4LCBpbmRleEVuZCkpICsgbmF0b207XG4gICAgICAgICAgICBtb2xCbG9ja3NbaV0gPSBtb2xCbG9ja3NbaV0uc2xpY2UoMCwgaW5kZXgpICsgYXRvbU51bWJlciArIG1vbEJsb2Nrc1tpXS5zbGljZShpbmRleEVuZCk7XG4gICAgICAgICAgICBpbmRleCA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCcgJywgaW5kZXgpICsgMTtcbiAgICAgICAgICAgIGluZGV4RW5kID0gTWF0aC5taW4obW9sQmxvY2tzW2ldLmluZGV4T2YoJ1xcbicsIGluZGV4KSwgbW9sQmxvY2tzW2ldLmluZGV4T2YoJyAnLCBpbmRleCkpO1xuICAgICAgICAgICAgYXRvbU51bWJlciA9IHBhcnNlSW50KG1vbEJsb2Nrc1tpXS5zdWJzdHJpbmcoaW5kZXgsIGluZGV4RW5kKSkgKyBuYXRvbTtcbiAgICAgICAgICAgIG1vbEJsb2Nrc1tpXSA9IG1vbEJsb2Nrc1tpXS5zbGljZSgwLCBpbmRleCkgKyBhdG9tTnVtYmVyICsgbW9sQmxvY2tzW2ldLnNsaWNlKGluZGV4RW5kKTtcbiAgICAgICAgICAgIGluZGV4ID0gbW9sQmxvY2tzW2ldLmluZGV4T2YoJ1xcbicsIGluZGV4KSArIDE7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgaW5kZXhCb25kRW5kID0gbW9sQmxvY2tzW2ldLmluZGV4T2YoJ00gIFYzMCBFTkQgQk9ORCcpO1xuICAgICAgICBib25kQmxvY2sgKz0gbW9sQmxvY2tzW2ldLnN1YnN0cmluZyhpbmRleEJvbmRzICsgMSwgaW5kZXhCb25kRW5kKTtcbiAgICAgICAgbGV0IGluZGV4Q29sbGVjdGlvbiA9IG1vbEJsb2Nrc1tpXS5pbmRleE9mKCdNICBWMzAgTURMVjMwL1NURUFCUyBBVE9NUz0oJyk7IC8vIFYzMDAwIGluZGV4IGZvciBjb2xsZWN0aW9uc1xuICAgICAgICB3aGlsZSAoaW5kZXhDb2xsZWN0aW9uICE9IC0xKSB7XG4gICAgICAgICAgICBpbmRleENvbGxlY3Rpb24gKz0gMjg7XG4gICAgICAgICAgICBjb25zdCBjb2xsZWN0aW9uRW5kID0gbW9sQmxvY2tzW2ldLmluZGV4T2YoJyknLCBpbmRleENvbGxlY3Rpb24pO1xuICAgICAgICAgICAgY29uc3QgY29sbGVjdGlvbkVudHJpZXMgPSBtb2xCbG9ja3NbaV0uc3Vic3RyaW5nKGluZGV4Q29sbGVjdGlvbiwgY29sbGVjdGlvbkVuZCkuc3BsaXQoJyAnKS5zbGljZSgxKTtcbiAgICAgICAgICAgIGNvbGxlY3Rpb25FbnRyaWVzLmZvckVhY2goKGUpID0+IHtcbiAgICAgICAgICAgICAgICBjb2xsZWN0aW9uLnB1c2gocGFyc2VJbnQoZSkgKyBuYXRvbSk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIGluZGV4Q29sbGVjdGlvbiA9IGNvbGxlY3Rpb25FbmQ7XG4gICAgICAgICAgICBpbmRleENvbGxlY3Rpb24gPSBtb2xCbG9ja3NbaV0uaW5kZXhPZignTSAgVjMwIE1ETFYzMC9TVEVBQlMgQVRPTVM9KCcsIGluZGV4Q29sbGVjdGlvbik7XG4gICAgICAgIH1cbiAgICAgICAgbmF0b20gKz0gdHdvTW9sZWN1bGVzID8gbnVtYmVycy5uYXRvbSA6IG51bWJlcnMubmF0b20gLSAxO1xuICAgICAgICBuYm9uZCArPSBudW1iZXJzLm5ib25kO1xuICAgICAgICB4U2hpZnQgKz0gdHdvTW9sZWN1bGVzID8gMCA6IGNvb3JkaW5hdGVzLnhbbnVtYmVycy5uYXRvbSAtIDFdIC0gY29vcmRpbmF0ZXMueFswXTtcbiAgICAgICAgc2VxdWVuY2VTaGlmdCArPSB0d29Nb2xlY3VsZXMgPyAtNyA6IDA7XG4gICAgfVxuICAgIGNvbnN0IGVudHJpZXMgPSA0O1xuICAgIGNvbnN0IGNvbGxOdW1iZXIgPSBNYXRoLmNlaWwoY29sbGVjdGlvbi5sZW5ndGggLyBlbnRyaWVzKTtcbiAgICBpZiAob2NsUmVuZGVyKSB7XG4gICAgICAgIGNvbGxlY3Rpb25CbG9jayArPSAnTSAgVjMwIE1ETFYzMC9TVEVBQlMgQVRPTVM9KCcgKyBjb2xsZWN0aW9uLmxlbmd0aDtcbiAgICAgICAgZm9yIChsZXQgaiA9IDA7IGogPCBjb2xsZWN0aW9uLmxlbmd0aDsgaisrKVxuICAgICAgICAgICAgY29sbGVjdGlvbkJsb2NrICs9ICcgJyArIGNvbGxlY3Rpb25bal07XG4gICAgICAgIGNvbGxlY3Rpb25CbG9jayArPSAnKVxcbic7XG4gICAgfVxuICAgIGVsc2Uge1xuICAgICAgICBjb2xsZWN0aW9uQmxvY2sgKz0gJ00gIFYzMCBNRExWMzAvU1RFQUJTIEFUT01TPSgnICsgY29sbGVjdGlvbi5sZW5ndGggKyAnIC1cXG4nO1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IGNvbGxOdW1iZXI7IGkrKykge1xuICAgICAgICAgICAgY29sbGVjdGlvbkJsb2NrICs9ICdNICBWMzAgJztcbiAgICAgICAgICAgIGNvbnN0IGVudHJpZXNDdXJyZW50ID0gaSArIDEgPT0gY29sbE51bWJlciA/IGNvbGxlY3Rpb24ubGVuZ3RoIC0gKGNvbGxOdW1iZXIgLSAxKSAqIGVudHJpZXMgOiBlbnRyaWVzO1xuICAgICAgICAgICAgZm9yIChsZXQgaiA9IDA7IGogPCBlbnRyaWVzQ3VycmVudDsgaisrKSB7XG4gICAgICAgICAgICAgICAgY29sbGVjdGlvbkJsb2NrICs9IChqICsgMSA9PSBlbnRyaWVzQ3VycmVudCkgP1xuICAgICAgICAgICAgICAgICAgICAoaSA9PSBjb2xsTnVtYmVyIC0gMSA/IGNvbGxlY3Rpb25bZW50cmllcyAqIGkgKyBqXSArICcpXFxuJyA6IGNvbGxlY3Rpb25bZW50cmllcyAqIGkgKyBqXSArICcgLVxcbicpIDpcbiAgICAgICAgICAgICAgICAgICAgY29sbGVjdGlvbltlbnRyaWVzICogaSArIGpdICsgJyAnO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuICAgIC8vZ2VuZXJhdGUgZmlsZVxuICAgIHR3b01vbGVjdWxlcyA/IG5hdG9tIDogbmF0b20rKztcbiAgICBtYWNyb01vbEJsb2NrICs9ICdNICBWMzAgQ09VTlRTICcgKyBuYXRvbSArICcgJyArIG5ib25kICsgJyAwIDAgMFxcbic7XG4gICAgbWFjcm9Nb2xCbG9jayArPSAnTSAgVjMwIEJFR0lOIEFUT01cXG4nO1xuICAgIG1hY3JvTW9sQmxvY2sgKz0gYXRvbUJsb2NrO1xuICAgIG1hY3JvTW9sQmxvY2sgKz0gJ00gIFYzMCBFTkQgQVRPTVxcbic7XG4gICAgbWFjcm9Nb2xCbG9jayArPSAnTSAgVjMwIEJFR0lOIEJPTkRcXG4nO1xuICAgIG1hY3JvTW9sQmxvY2sgKz0gYm9uZEJsb2NrO1xuICAgIG1hY3JvTW9sQmxvY2sgKz0gJ00gIFYzMCBFTkQgQk9ORFxcbic7XG4gICAgbWFjcm9Nb2xCbG9jayArPSAnTSAgVjMwIEJFR0lOIENPTExFQ1RJT05cXG4nO1xuICAgIG1hY3JvTW9sQmxvY2sgKz0gY29sbGVjdGlvbkJsb2NrO1xuICAgIG1hY3JvTW9sQmxvY2sgKz0gJ00gIFYzMCBFTkQgQ09MTEVDVElPTlxcbic7XG4gICAgbWFjcm9Nb2xCbG9jayArPSAnTSAgVjMwIEVORCBDVEFCXFxuJztcbiAgICBtYWNyb01vbEJsb2NrICs9ICdNICBFTkRcXG4nO1xuICAgIHJldHVybiBtYWNyb01vbEJsb2NrO1xufVxuZnVuY3Rpb24gcm90YXRlTnVjbGVvdGlkZXNWMzAwMChtb2xlY3VsZSkge1xuICAgIGxldCBtb2xCbG9jayA9IG1vbGVjdWxlLmluY2x1ZGVzKCdNICBFTkQnKSA/IG1vbGVjdWxlIDogT0NMLk1vbGVjdWxlLmZyb21TbWlsZXMobW9sZWN1bGUpLnRvTW9sZmlsZVYzKCk7XG4gICAgY29uc3QgY29vcmRpbmF0ZXMgPSBleHRyYWN0QXRvbURhdGFWMzAwMChtb2xCbG9jayk7XG4gICAgY29uc3QgbmF0b20gPSBjb29yZGluYXRlcy5hdG9tSW5kZXgubGVuZ3RoO1xuICAgIGNvbnN0IGluZGV4Rml2ZVByaW1lID0gY29vcmRpbmF0ZXMuYXRvbUluZGV4LmluZGV4T2YoMSk7XG4gICAgY29uc3QgaW5kZXhUaHJlZVByaW1lID0gY29vcmRpbmF0ZXMuYXRvbUluZGV4LmluZGV4T2YobmF0b20pO1xuICAgIC8vZml4IDUgcHJpbWUgaWYgaW5hZGVxdWF0ZVxuICAgIGlmIChuYXRvbSA+IDgpXG4gICAgICAgIGZpeDVQcmltZShjb29yZGluYXRlcywgaW5kZXhGaXZlUHJpbWUsIGluZGV4VGhyZWVQcmltZSk7XG4gICAgY29uc3QgeENlbnRlciA9IChjb29yZGluYXRlcy54W2luZGV4VGhyZWVQcmltZV0gKyBjb29yZGluYXRlcy54W2luZGV4Rml2ZVByaW1lXSkgLyAyO1xuICAgIGNvbnN0IHlDZW50ZXIgPSAoY29vcmRpbmF0ZXMueVtpbmRleFRocmVlUHJpbWVdICsgY29vcmRpbmF0ZXMueVtpbmRleEZpdmVQcmltZV0pIC8gMjtcbiAgICAvL3BsYWNlIHRvIGNlbnRlclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbmF0b207IGkrKykge1xuICAgICAgICBjb29yZGluYXRlcy54W2ldIC09IHhDZW50ZXI7XG4gICAgICAgIGNvb3JkaW5hdGVzLnlbaV0gLT0geUNlbnRlcjtcbiAgICB9XG4gICAgbGV0IGFuZ2xlID0gMDtcbiAgICBpZiAoY29vcmRpbmF0ZXMueFtpbmRleEZpdmVQcmltZV0gPT0gMClcbiAgICAgICAgYW5nbGUgPSBjb29yZGluYXRlcy55W2luZGV4Rml2ZVByaW1lXSA+IGNvb3JkaW5hdGVzLnlbaW5kZXhUaHJlZVByaW1lXSA/IE1hdGguUEkgLyAyIDogMyAqIE1hdGguUEkgLyAyO1xuICAgIGVsc2UgaWYgKGNvb3JkaW5hdGVzLnlbaW5kZXhGaXZlUHJpbWVdID09IDApXG4gICAgICAgIGFuZ2xlID0gY29vcmRpbmF0ZXMueFtpbmRleEZpdmVQcmltZV0gPiBjb29yZGluYXRlcy54W2luZGV4VGhyZWVQcmltZV0gPyBNYXRoLlBJIDogMDtcbiAgICBlbHNlIHtcbiAgICAgICAgY29uc3QgZGVyaXZhdGl2ZSA9IGNvb3JkaW5hdGVzLnlbaW5kZXhGaXZlUHJpbWVdIC8gY29vcmRpbmF0ZXMueFtpbmRleEZpdmVQcmltZV07XG4gICAgICAgIGFuZ2xlID0gZGVyaXZhdGl2ZSA+IDAgPyBNYXRoLlBJIC0gTWF0aC5hdGFuKGRlcml2YXRpdmUpIDogTWF0aC5hdGFuKGRlcml2YXRpdmUpO1xuICAgIH1cbiAgICBjb25zdCBjb3MgPSBNYXRoLmNvcyhhbmdsZSk7XG4gICAgY29uc3Qgc2luID0gTWF0aC5zaW4oYW5nbGUpO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbmF0b207IGkrKykge1xuICAgICAgICBjb25zdCB4QWRkID0gY29vcmRpbmF0ZXMueFtpXTtcbiAgICAgICAgY29vcmRpbmF0ZXMueFtpXSA9IHhBZGQgKiBjb3MgLSBjb29yZGluYXRlcy55W2ldICogc2luO1xuICAgICAgICBjb29yZGluYXRlcy55W2ldID0geEFkZCAqIHNpbiArIGNvb3JkaW5hdGVzLnlbaV0gKiBjb3M7XG4gICAgfVxuICAgIC8vcGxhY2UgdG8gcmlnaHRcbiAgICBjb25zdCB4U2hpZnQgPSBjb29yZGluYXRlcy54W2luZGV4Rml2ZVByaW1lXTtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IG5hdG9tOyBpKyspXG4gICAgICAgIGNvb3JkaW5hdGVzLnhbaV0gLT0geFNoaWZ0O1xuICAgIC8vcmV3cml0ZSBtb2xCbG9ja1xuICAgIGxldCBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ00gIFYzMCBCRUdJTiBBVE9NJyk7IC8vIFYzMDAwIGluZGV4IGZvciBhdG9tcyBjb29yZGluYXRlc1xuICAgIGluZGV4ID0gbW9sQmxvY2suaW5kZXhPZignXFxuJywgaW5kZXgpO1xuICAgIGxldCBpbmRleEVuZCA9IGluZGV4O1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbmF0b207IGkrKykge1xuICAgICAgICBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ1YzMCcsIGluZGV4KSArIDQ7XG4gICAgICAgIGluZGV4ID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KSArIDE7XG4gICAgICAgIGluZGV4ID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KSArIDE7XG4gICAgICAgIGluZGV4RW5kID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KSArIDE7XG4gICAgICAgIGluZGV4RW5kID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4RW5kKTtcbiAgICAgICAgbW9sQmxvY2sgPSBtb2xCbG9jay5zbGljZSgwLCBpbmRleCkgK1xuICAgICAgICAgICAgY29vcmRpbmF0ZXMueFtpXSArICcgJyArIGNvb3JkaW5hdGVzLnlbaV0gK1xuICAgICAgICAgICAgbW9sQmxvY2suc2xpY2UoaW5kZXhFbmQpO1xuICAgICAgICBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ1xcbicsIGluZGV4KSArIDE7XG4gICAgfVxuICAgIHJldHVybiBtb2xCbG9jaztcbn1cbmZ1bmN0aW9uIGludmVydE51Y2xlb3RpZGVzVjMwMDAobW9sZWN1bGUpIHtcbiAgICBsZXQgbW9sQmxvY2sgPSBtb2xlY3VsZS5pbmNsdWRlcygnTSAgRU5EJykgPyBtb2xlY3VsZSA6IE9DTC5Nb2xlY3VsZS5mcm9tU21pbGVzKG1vbGVjdWxlKS50b01vbGZpbGVWMygpO1xuICAgIGNvbnN0IGNvb3JkaW5hdGVzID0gZXh0cmFjdEF0b21EYXRhVjMwMDAobW9sQmxvY2spO1xuICAgIGNvbnN0IG5hdG9tID0gY29vcmRpbmF0ZXMuYXRvbUluZGV4Lmxlbmd0aDtcbiAgICBjb25zdCB4Q2VudGVyID0gKE1hdGgubWF4KC4uLmNvb3JkaW5hdGVzLngpICsgTWF0aC5taW4oLi4uY29vcmRpbmF0ZXMueCkpIC8gMjtcbiAgICBjb25zdCB5Q2VudGVyID0gKE1hdGgubWF4KC4uLmNvb3JkaW5hdGVzLnkpICsgTWF0aC5taW4oLi4uY29vcmRpbmF0ZXMueSkpIC8gMjtcbiAgICAvL3BsYWNlIHRvIGNlbnRlclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbmF0b207IGkrKykge1xuICAgICAgICBjb29yZGluYXRlcy54W2ldIC09IHhDZW50ZXI7XG4gICAgICAgIGNvb3JkaW5hdGVzLnlbaV0gLT0geUNlbnRlcjtcbiAgICB9XG4gICAgY29uc3QgYW5nbGUgPSBNYXRoLlBJO1xuICAgIGNvbnN0IGNvcyA9IE1hdGguY29zKGFuZ2xlKTtcbiAgICBjb25zdCBzaW4gPSBNYXRoLnNpbihhbmdsZSk7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBuYXRvbTsgaSsrKSB7XG4gICAgICAgIGNvbnN0IHhBZGQgPSBjb29yZGluYXRlcy54W2ldO1xuICAgICAgICBjb29yZGluYXRlcy54W2ldID0geEFkZCAqIGNvcyAtIGNvb3JkaW5hdGVzLnlbaV0gKiBzaW47XG4gICAgICAgIGNvb3JkaW5hdGVzLnlbaV0gPSB4QWRkICogc2luICsgY29vcmRpbmF0ZXMueVtpXSAqIGNvcztcbiAgICB9XG4gICAgLy9wbGFjZSBiYWNrXG4gICAgY29uc3QgeVNoaWZ0ID0gTWF0aC5tYXgoLi4uY29vcmRpbmF0ZXMueSk7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBuYXRvbTsgaSsrKSB7XG4gICAgICAgIGNvb3JkaW5hdGVzLnhbaV0gKz0geENlbnRlcjtcbiAgICAgICAgY29vcmRpbmF0ZXMueVtpXSAtPSB5U2hpZnQ7XG4gICAgfVxuICAgIC8vcmV3cml0ZSBtb2xCbG9ja1xuICAgIGxldCBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ00gIFYzMCBCRUdJTiBBVE9NJyk7IC8vIFYzMDAwIGluZGV4IGZvciBhdG9tcyBjb29yZGluYXRlc1xuICAgIGluZGV4ID0gbW9sQmxvY2suaW5kZXhPZignXFxuJywgaW5kZXgpO1xuICAgIGxldCBpbmRleEVuZCA9IGluZGV4O1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbmF0b207IGkrKykge1xuICAgICAgICBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ1YzMCcsIGluZGV4KSArIDQ7XG4gICAgICAgIGluZGV4ID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KSArIDE7XG4gICAgICAgIGluZGV4ID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KSArIDE7XG4gICAgICAgIGluZGV4RW5kID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KSArIDE7XG4gICAgICAgIGluZGV4RW5kID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4RW5kKTtcbiAgICAgICAgbW9sQmxvY2sgPSBtb2xCbG9jay5zbGljZSgwLCBpbmRleCkgK1xuICAgICAgICAgICAgY29vcmRpbmF0ZXMueFtpXSArICcgJyArIGNvb3JkaW5hdGVzLnlbaV0gK1xuICAgICAgICAgICAgbW9sQmxvY2suc2xpY2UoaW5kZXhFbmQpO1xuICAgICAgICBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ1xcbicsIGluZGV4KSArIDE7XG4gICAgfVxuICAgIHJldHVybiBtb2xCbG9jaztcbn1cbmZ1bmN0aW9uIGZpeDVQcmltZShjb29yZGluYXRlcywgaW5kZXhGaXZlUHJpbWUsIGluZGV4VGhyZWVQcmltZSkge1xuICAgIGNvbnN0IGluZGV4Rml2ZVByaW1lTmVpZ2hib3VyID0gaW5kZXhGaXZlUHJpbWUgKyAxO1xuICAgIGNvbnN0IHhTaGlmdCA9IGNvb3JkaW5hdGVzLnhbaW5kZXhGaXZlUHJpbWVOZWlnaGJvdXJdO1xuICAgIGNvbnN0IHlTaGlmdCA9IGNvb3JkaW5hdGVzLnlbaW5kZXhGaXZlUHJpbWVOZWlnaGJvdXJdO1xuICAgIGNvbnN0IGJhc2UzUHJpbWVYID0gY29vcmRpbmF0ZXMueFtpbmRleFRocmVlUHJpbWVdIC0geFNoaWZ0O1xuICAgIGNvbnN0IGJhc2UzUHJpbWVZID0gY29vcmRpbmF0ZXMueVtpbmRleFRocmVlUHJpbWVdIC0geVNoaWZ0O1xuICAgIGNvbnN0IGJhc2U1UHJpbWVYID0gY29vcmRpbmF0ZXMueFtpbmRleEZpdmVQcmltZV0gLSB4U2hpZnQ7XG4gICAgY29uc3QgYmFzZTVQcmltZVkgPSBjb29yZGluYXRlcy55W2luZGV4Rml2ZVByaW1lXSAtIHlTaGlmdDtcbiAgICBjb25zdCByb3RhdGVkNVByaW1lWCA9IGJhc2U1UHJpbWVYICogTWF0aC5jb3MoTWF0aC5QSSAqIDIgLyAzKSAtIGJhc2U1UHJpbWVZICogTWF0aC5zaW4oTWF0aC5QSSAqIDIgLyAzKTtcbiAgICBjb25zdCByb3RhdGVkNVByaW1lWSA9IGJhc2U1UHJpbWVYICogTWF0aC5zaW4oTWF0aC5QSSAqIDIgLyAzKSArIGJhc2U1UHJpbWVZICogTWF0aC5jb3MoTWF0aC5QSSAqIDIgLyAzKTtcbiAgICBjb25zdCBkeCA9IGJhc2U1UHJpbWVYIC0gYmFzZTNQcmltZVg7XG4gICAgY29uc3QgZHkgPSBiYXNlNVByaW1lWSAtIGJhc2UzUHJpbWVZO1xuICAgIGNvbnN0IGR4Um90YXRlZCA9IHJvdGF0ZWQ1UHJpbWVYIC0gYmFzZTNQcmltZVg7XG4gICAgY29uc3QgZHlSb3RhdGVkID0gcm90YXRlZDVQcmltZVkgLSBiYXNlM1ByaW1lWTtcbiAgICBpZiAoTWF0aC5zcXJ0KGR5Um90YXRlZCAqIGR5Um90YXRlZCArIGR4Um90YXRlZCAqIGR4Um90YXRlZCkgPj0gTWF0aC5zcXJ0KGR5ICogZHkgKyBkeCAqIGR4KSkge1xuICAgICAgICBjb29yZGluYXRlcy54W2luZGV4Rml2ZVByaW1lXSA9IHJvdGF0ZWQ1UHJpbWVYICsgeFNoaWZ0O1xuICAgICAgICBjb29yZGluYXRlcy55W2luZGV4Rml2ZVByaW1lXSA9IHJvdGF0ZWQ1UHJpbWVZICsgeVNoaWZ0O1xuICAgIH1cbn1cbmZ1bmN0aW9uIGV4dHJhY3RBdG9tc0JvbmRzTnVtYmVyc1YzMDAwKG1vbEJsb2NrKSB7XG4gICAgbW9sQmxvY2sgPSBtb2xCbG9jay5yZXBsYWNlQWxsKCdcXHInLCAnJyk7IC8vZXF1YWxpemUgb2xkIGFuZCBuZXcgc2RmIHN0YW5kYXJkc1xuICAgIGxldCBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ0NPVU5UUycpICsgNzsgLy8gVjMwMDAgaW5kZXggZm9yIGF0b21zIGFuZCBib25kcyBudW1iZXJcbiAgICBsZXQgaW5kZXhFbmQgPSBtb2xCbG9jay5pbmRleE9mKCcgJywgaW5kZXgpO1xuICAgIGNvbnN0IGF0b21zTnVtYmVyID0gcGFyc2VJbnQobW9sQmxvY2suc3Vic3RyaW5nKGluZGV4LCBpbmRleEVuZCkpO1xuICAgIGluZGV4ID0gaW5kZXhFbmQgKyAxO1xuICAgIGluZGV4RW5kID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KTtcbiAgICBjb25zdCBib25kc051bWJlciA9IHBhcnNlSW50KG1vbEJsb2NrLnN1YnN0cmluZyhpbmRleCwgaW5kZXhFbmQpKTtcbiAgICByZXR1cm4geyBuYXRvbTogYXRvbXNOdW1iZXIsIG5ib25kOiBib25kc051bWJlciB9O1xufVxuZnVuY3Rpb24gZXh0cmFjdEF0b21EYXRhVjMwMDAobW9sQmxvY2spIHtcbiAgICBjb25zdCBudW1iZXJzID0gZXh0cmFjdEF0b21zQm9uZHNOdW1iZXJzVjMwMDAobW9sQmxvY2spO1xuICAgIGxldCBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ00gIFYzMCBCRUdJTiBBVE9NJyk7IC8vIFYzMDAwIGluZGV4IGZvciBhdG9tcyBjb29yZGluYXRlc1xuICAgIGluZGV4ID0gbW9sQmxvY2suaW5kZXhPZignXFxuJywgaW5kZXgpO1xuICAgIGxldCBpbmRleEVuZCA9IGluZGV4O1xuICAgIGNvbnN0IGluZGV4ZXMgPSBBcnJheShudW1iZXJzLm5hdG9tKTtcbiAgICBjb25zdCB0eXBlcyA9IEFycmF5KG51bWJlcnMubmF0b20pO1xuICAgIGNvbnN0IHggPSBBcnJheShudW1iZXJzLm5hdG9tKTtcbiAgICBjb25zdCB5ID0gQXJyYXkobnVtYmVycy5uYXRvbSk7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBudW1iZXJzLm5hdG9tOyBpKyspIHtcbiAgICAgICAgaW5kZXggPSBtb2xCbG9jay5pbmRleE9mKCdWMzAnLCBpbmRleCkgKyA0O1xuICAgICAgICBpbmRleEVuZCA9IG1vbEJsb2NrLmluZGV4T2YoJyAnLCBpbmRleCk7XG4gICAgICAgIGluZGV4ZXNbaV0gPSBwYXJzZUludChtb2xCbG9jay5zdWJzdHJpbmcoaW5kZXgsIGluZGV4RW5kKSk7XG4gICAgICAgIGluZGV4ID0gaW5kZXhFbmQgKyAxO1xuICAgICAgICBpbmRleEVuZCA9IG1vbEJsb2NrLmluZGV4T2YoJyAnLCBpbmRleCk7XG4gICAgICAgIHR5cGVzW2ldID0gbW9sQmxvY2suc3Vic3RyaW5nKGluZGV4LCBpbmRleEVuZCk7XG4gICAgICAgIGluZGV4ID0gaW5kZXhFbmQgKyAxO1xuICAgICAgICBpbmRleEVuZCA9IG1vbEJsb2NrLmluZGV4T2YoJyAnLCBpbmRleCk7XG4gICAgICAgIHhbaV0gPSBwYXJzZUZsb2F0KG1vbEJsb2NrLnN1YnN0cmluZyhpbmRleCwgaW5kZXhFbmQpKTtcbiAgICAgICAgaW5kZXggPSBpbmRleEVuZCArIDE7XG4gICAgICAgIGluZGV4RW5kID0gbW9sQmxvY2suaW5kZXhPZignICcsIGluZGV4KTtcbiAgICAgICAgeVtpXSA9IHBhcnNlRmxvYXQobW9sQmxvY2suc3Vic3RyaW5nKGluZGV4LCBpbmRleEVuZCkpO1xuICAgICAgICBpbmRleCA9IG1vbEJsb2NrLmluZGV4T2YoJ1xcbicsIGluZGV4KSArIDE7XG4gICAgfVxuICAgIHJldHVybiB7IGF0b21JbmRleDogaW5kZXhlcywgYXRvbVR5cGU6IHR5cGVzLCB4OiB4LCB5OiB5IH07XG59XG4iLCIvLyBpbXBvcnQgKiBhcyBncm9rIGZyb20gJ2RhdGFncm9rLWFwaS9ncm9rJztcbi8vIGltcG9ydCAqIGFzIHVpIGZyb20gJ2RhdGFncm9rLWFwaS91aSc7XG4vLyBpbXBvcnQgKiBhcyBERyBmcm9tICdkYXRhZ3Jvay1hcGkvZGcnO1xuaW1wb3J0IHsgbWFwLCBTWU5USEVTSVpFUlMsIFRFQ0hOT0xPR0lFUywgTU9ESUZJQ0FUSU9OUyB9IGZyb20gJy4vbWFwJztcbmltcG9ydCB7IGFzb0dhcG1lcnNOdWNsZW90aWRlc1RvQmlvU3ByaW5nLCBhc29HYXBtZXJzTnVjbGVvdGlkZXNUb0djcnMsIGFzb0dhcG1lcnNCaW9TcHJpbmdUb051Y2xlb3RpZGVzLCBhc29HYXBtZXJzQmlvU3ByaW5nVG9HY3JzLCBhc29HYXBtZXJzR2Nyc1RvTnVjbGVvdGlkZXMsIGFzb0dhcG1lcnNHY3JzVG9CaW9TcHJpbmcsIGdjcnNUb01lcm1hZGUxMiwgc2lSbmFOdWNsZW90aWRlVG9CaW9TcHJpbmdTZW5zZVN0cmFuZCwgc2lSbmFOdWNsZW90aWRlVG9BeG9sYWJzU2Vuc2VTdHJhbmQsIHNpUm5hTnVjbGVvdGlkZXNUb0djcnMsIHNpUm5hQmlvU3ByaW5nVG9OdWNsZW90aWRlcywgc2lSbmFCaW9TcHJpbmdUb0F4b2xhYnMsIHNpUm5hQmlvU3ByaW5nVG9HY3JzLCBzaVJuYUF4b2xhYnNUb051Y2xlb3RpZGVzLCBzaVJuYUF4b2xhYnNUb0Jpb1NwcmluZywgc2lSbmFBeG9sYWJzVG9HY3JzLCBzaVJuYUdjcnNUb051Y2xlb3RpZGVzLCBzaVJuYUdjcnNUb0Jpb1NwcmluZywgc2lSbmFHY3JzVG9BeG9sYWJzLCBnY3JzVG9OdWNsZW90aWRlcyB9IGZyb20gJy4vY29udmVydGVycyc7XG5jb25zdCBub1RyYW5zbGF0aW9uVGFibGVBdmFpbGFibGUgPSAnTm8gdHJhbnNsYXRpb24gdGFibGUgYXZhaWxhYmxlJztcbmV4cG9ydCBjb25zdCB1bmRlZmluZWRJbnB1dFNlcXVlbmNlID0gJ1R5cGUgb2YgaW5wdXQgc2VxdWVuY2UgaXMgdW5kZWZpbmVkJztcbmV4cG9ydCBmdW5jdGlvbiBnZXRGb3JtYXQoc2VxdWVuY2UpIHtcbiAgICBjb25zdCBwb3NzaWJsZVN5bnRoZXNpemVycyA9IGdldExpc3RPZlBvc3NpYmxlU3ludGhlc2l6ZXJzQnlGaXJzdE1hdGNoZWRDb2RlKHNlcXVlbmNlKTtcbiAgICBpZiAocG9zc2libGVTeW50aGVzaXplcnMubGVuZ3RoID09IDApXG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIGxldCBvdXRwdXRJbmRleCA9IDA7XG4gICAgY29uc3QgZmlyc3RVbmlxdWVDaGFyYWN0ZXJzID0gWydyJywgJ2QnXTtcbiAgICBjb25zdCBudWNsZW90aWRlcyA9IFsnQScsICdVJywgJ1QnLCAnQycsICdHJ107XG4gICAgcG9zc2libGVTeW50aGVzaXplcnMuZm9yRWFjaCgoc3ludGhlc2l6ZXIpID0+IHtcbiAgICAgICAgY29uc3QgY29kZXMgPSBnZXRBbGxDb2Rlc09mU3ludGhlc2l6ZXIoc3ludGhlc2l6ZXIpO1xuICAgICAgICB3aGlsZSAob3V0cHV0SW5kZXggPCBzZXF1ZW5jZS5sZW5ndGgpIHtcbiAgICAgICAgICAgIGNvbnN0IG1hdGNoZWRDb2RlID0gY29kZXMuZmluZCgoYykgPT4gYyA9PSBzZXF1ZW5jZS5zbGljZShvdXRwdXRJbmRleCwgb3V0cHV0SW5kZXggKyBjLmxlbmd0aCkpO1xuICAgICAgICAgICAgaWYgKG1hdGNoZWRDb2RlID09IG51bGwpXG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICBpZiAoIC8vIGZvciBtaXN0YWtlIHBhdHRlcm4gJ3JBQSdcbiAgICAgICAgICAgIG91dHB1dEluZGV4ID4gMSAmJlxuICAgICAgICAgICAgICAgIG51Y2xlb3RpZGVzLmluY2x1ZGVzKHNlcXVlbmNlW291dHB1dEluZGV4XSkgJiZcbiAgICAgICAgICAgICAgICBmaXJzdFVuaXF1ZUNoYXJhY3RlcnMuaW5jbHVkZXMoc2VxdWVuY2Vbb3V0cHV0SW5kZXggLSAyXSkpXG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICBpZiAoIC8vIGZvciBtaXN0YWtlIHBhdHRlcm4gJ0FyQSdcbiAgICAgICAgICAgIGZpcnN0VW5pcXVlQ2hhcmFjdGVycy5pbmNsdWRlcyhzZXF1ZW5jZVtvdXRwdXRJbmRleCArIDFdKSAmJlxuICAgICAgICAgICAgICAgIG51Y2xlb3RpZGVzLmluY2x1ZGVzKHNlcXVlbmNlW291dHB1dEluZGV4XSkpIHtcbiAgICAgICAgICAgICAgICBvdXRwdXRJbmRleCsrO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgb3V0cHV0SW5kZXggKz0gbWF0Y2hlZENvZGUubGVuZ3RoO1xuICAgICAgICB9XG4gICAgfSk7XG4gICAgY29uc3QgaW5kZXhPZkZpcnN0Tm90VmFsaWRDaGFyID0gKG91dHB1dEluZGV4ID09IHNlcXVlbmNlLmxlbmd0aCkgPyAtMSA6IG91dHB1dEluZGV4O1xuICAgIGlmIChpbmRleE9mRmlyc3ROb3RWYWxpZENoYXIgIT0gLTEpXG4gICAgICAgIHJldHVybiBwb3NzaWJsZVN5bnRoZXNpemVyc1swXTtcbiAgICBjb25zdCBwb3NzaWJsZVRlY2hub2xvZ2llcyA9IGdldExpc3RPZlBvc3NpYmxlVGVjaG5vbG9naWVzQnlGaXJzdE1hdGNoZWRDb2RlKHNlcXVlbmNlLCBwb3NzaWJsZVN5bnRoZXNpemVyc1swXSk7XG4gICAgaWYgKHBvc3NpYmxlVGVjaG5vbG9naWVzLmxlbmd0aCA9PSAwKVxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICBvdXRwdXRJbmRleCA9IDA7XG4gICAgcG9zc2libGVUZWNobm9sb2dpZXMuZm9yRWFjaCgodGVjaG5vbG9neSkgPT4ge1xuICAgICAgICBjb25zdCBjb2RlcyA9IE9iamVjdC5rZXlzKG1hcFtwb3NzaWJsZVN5bnRoZXNpemVyc1swXV1bdGVjaG5vbG9neV0pO1xuICAgICAgICB3aGlsZSAob3V0cHV0SW5kZXggPCBzZXF1ZW5jZS5sZW5ndGgpIHtcbiAgICAgICAgICAgIGNvbnN0IG1hdGNoZWRDb2RlID0gY29kZXMuZmluZCgoYykgPT4gYyA9PSBzZXF1ZW5jZS5zbGljZShvdXRwdXRJbmRleCwgb3V0cHV0SW5kZXggKyBjLmxlbmd0aCkpO1xuICAgICAgICAgICAgaWYgKG1hdGNoZWRDb2RlID09IG51bGwpXG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICBpZiAoIC8vIGZvciBtaXN0YWtlIHBhdHRlcm4gJ3JBQSdcbiAgICAgICAgICAgIG91dHB1dEluZGV4ID4gMSAmJlxuICAgICAgICAgICAgICAgIG51Y2xlb3RpZGVzLmluY2x1ZGVzKHNlcXVlbmNlW291dHB1dEluZGV4XSkgJiZcbiAgICAgICAgICAgICAgICBmaXJzdFVuaXF1ZUNoYXJhY3RlcnMuaW5jbHVkZXMoc2VxdWVuY2Vbb3V0cHV0SW5kZXggLSAyXSkpXG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICBpZiAoIC8vIGZvciBtaXN0YWtlIHBhdHRlcm4gJ0FyQSdcbiAgICAgICAgICAgIGZpcnN0VW5pcXVlQ2hhcmFjdGVycy5pbmNsdWRlcyhzZXF1ZW5jZVtvdXRwdXRJbmRleCArIDFdKSAmJlxuICAgICAgICAgICAgICAgIG51Y2xlb3RpZGVzLmluY2x1ZGVzKHNlcXVlbmNlW291dHB1dEluZGV4XSkpIHtcbiAgICAgICAgICAgICAgICBvdXRwdXRJbmRleCsrO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgb3V0cHV0SW5kZXggKz0gbWF0Y2hlZENvZGUubGVuZ3RoO1xuICAgICAgICB9XG4gICAgfSk7XG4gICAgcmV0dXJuIHBvc3NpYmxlU3ludGhlc2l6ZXJzWzBdO1xufVxuZXhwb3J0IGZ1bmN0aW9uIGlzVmFsaWRTZXF1ZW5jZShzZXF1ZW5jZSwgZm9ybWF0KSB7XG4gICAgY29uc3QgcG9zc2libGVTeW50aGVzaXplcnMgPSBmb3JtYXQgPT0gbnVsbCA/XG4gICAgICAgIGdldExpc3RPZlBvc3NpYmxlU3ludGhlc2l6ZXJzQnlGaXJzdE1hdGNoZWRDb2RlKHNlcXVlbmNlKSA6XG4gICAgICAgIFtmb3JtYXRdO1xuICAgIC8vIGlmIChwb3NzaWJsZVN5bnRoZXNpemVycy5sZW5ndGggPiAxKSB7XG4gICAgLy8gICBjb25zdCBzeW50aGVzaXplciA9IHVpLmNob2ljZUlucHV0KCdDaG9vc2Ugc3ludGhlc2l6ZXIgZnJvbSBsaXN0OiAnLCBwb3NzaWJsZVN5bnRoZXNpemVyc1swXSxcbiAgICAvLyAgcG9zc2libGVTeW50aGVzaXplcnMpO1xuICAgIC8vICAgdWkuZGlhbG9nKCdDaG9vc2UgU3ludGhlc2l6ZXInKVxuICAgIC8vICAgICAuYWRkKHVpLnBhbmVsKFtzeW50aGVzaXplci5yb290XSwge3N0eWxlOiB7Zm9udFdlaWdodDogJ2JvbGQnfX0pKVxuICAgIC8vICAgICAub25PSygoKSA9PiBwb3NzaWJsZVN5bnRoZXNpemVycyA9IFtzeW50aGVzaXplci52YWx1ZV0pXG4gICAgLy8gICAgIC5vbkNhbmNlbCgoKSA9PiB7XG4gICAgLy8gICAgICAgcG9zc2libGVTeW50aGVzaXplcnMgPSBbcG9zc2libGVTeW50aGVzaXplcnNbMF1dO1xuICAgIC8vICAgICAgIGdyb2suc2hlbGwud2FybmluZygnSW5wdXQgc2VxdWVuY2UgaXMgZXhwZWN0ZWQgdG8gYmUgaW4gZm9ybWF0ICcgKyBwb3NzaWJsZVN5bnRoZXNpemVyc1swXSk7XG4gICAgLy8gICAgIH0pXG4gICAgLy8gICAgIC5zaG93KCk7XG4gICAgLy8gfSBlbHNlIGlmIChwb3NzaWJsZVN5bnRoZXNpemVycy5sZW5ndGggPT0gMClcbiAgICBpZiAocG9zc2libGVTeW50aGVzaXplcnMubGVuZ3RoID09IDApXG4gICAgICAgIHJldHVybiB7IGluZGV4T2ZGaXJzdE5vdFZhbGlkQ2hhcjogMCwgc3ludGhlc2l6ZXI6IG51bGwsIHRlY2hub2xvZ3k6IG51bGwgfTtcbiAgICBsZXQgb3V0cHV0SW5kZXggPSAwO1xuICAgIGNvbnN0IGZpcnN0VW5pcXVlQ2hhcmFjdGVycyA9IFsncicsICdkJ107XG4gICAgY29uc3QgbnVjbGVvdGlkZXMgPSBbJ0EnLCAnVScsICdUJywgJ0MnLCAnRyddO1xuICAgIHBvc3NpYmxlU3ludGhlc2l6ZXJzLmZvckVhY2goKHN5bnRoZXNpemVyKSA9PiB7XG4gICAgICAgIGNvbnN0IGNvZGVzID0gZ2V0QWxsQ29kZXNPZlN5bnRoZXNpemVyKHN5bnRoZXNpemVyKTtcbiAgICAgICAgd2hpbGUgKG91dHB1dEluZGV4IDwgc2VxdWVuY2UubGVuZ3RoKSB7XG4gICAgICAgICAgICBjb25zdCBtYXRjaGVkQ29kZSA9IGNvZGVzLmZpbmQoKGMpID0+IGMgPT0gc2VxdWVuY2Uuc2xpY2Uob3V0cHV0SW5kZXgsIG91dHB1dEluZGV4ICsgYy5sZW5ndGgpKTtcbiAgICAgICAgICAgIGlmIChtYXRjaGVkQ29kZSA9PSBudWxsKVxuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgaWYgKCAvLyBmb3IgbWlzdGFrZSBwYXR0ZXJuICdyQUEnXG4gICAgICAgICAgICBvdXRwdXRJbmRleCA+IDEgJiZcbiAgICAgICAgICAgICAgICBudWNsZW90aWRlcy5pbmNsdWRlcyhzZXF1ZW5jZVtvdXRwdXRJbmRleF0pICYmXG4gICAgICAgICAgICAgICAgZmlyc3RVbmlxdWVDaGFyYWN0ZXJzLmluY2x1ZGVzKHNlcXVlbmNlW291dHB1dEluZGV4IC0gMl0pKVxuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgaWYgKCAvLyBmb3IgbWlzdGFrZSBwYXR0ZXJuICdBckEnXG4gICAgICAgICAgICBmaXJzdFVuaXF1ZUNoYXJhY3RlcnMuaW5jbHVkZXMoc2VxdWVuY2Vbb3V0cHV0SW5kZXggKyAxXSkgJiZcbiAgICAgICAgICAgICAgICBudWNsZW90aWRlcy5pbmNsdWRlcyhzZXF1ZW5jZVtvdXRwdXRJbmRleF0pKSB7XG4gICAgICAgICAgICAgICAgb3V0cHV0SW5kZXgrKztcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIG91dHB1dEluZGV4ICs9IG1hdGNoZWRDb2RlLmxlbmd0aDtcbiAgICAgICAgfVxuICAgIH0pO1xuICAgIGNvbnN0IGluZGV4T2ZGaXJzdE5vdFZhbGlkQ2hhciA9IChvdXRwdXRJbmRleCA9PSBzZXF1ZW5jZS5sZW5ndGgpID8gLTEgOiBvdXRwdXRJbmRleDtcbiAgICBpZiAoaW5kZXhPZkZpcnN0Tm90VmFsaWRDaGFyICE9IC0xKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBpbmRleE9mRmlyc3ROb3RWYWxpZENoYXI6IGluZGV4T2ZGaXJzdE5vdFZhbGlkQ2hhcixcbiAgICAgICAgICAgIHN5bnRoZXNpemVyOiBwb3NzaWJsZVN5bnRoZXNpemVycyxcbiAgICAgICAgICAgIHRlY2hub2xvZ3k6IG51bGwsXG4gICAgICAgIH07XG4gICAgfVxuICAgIGNvbnN0IHBvc3NpYmxlVGVjaG5vbG9naWVzID0gZ2V0TGlzdE9mUG9zc2libGVUZWNobm9sb2dpZXNCeUZpcnN0TWF0Y2hlZENvZGUoc2VxdWVuY2UsIHBvc3NpYmxlU3ludGhlc2l6ZXJzWzBdKTtcbiAgICAvLyBpZiAocG9zc2libGVUZWNobm9sb2dpZXMubGVuZ3RoID4gMSkge1xuICAgIC8vICAgY29uc3QgdGVjaG5vbG9neSA9IHVpLmNob2ljZUlucHV0KCdDaG9vc2UgdGVjaG5vbG9neSBmcm9tIGxpc3Q6ICcsIHBvc3NpYmxlVGVjaG5vbG9naWVzWzBdLFxuICAgIC8vIHBvc3NpYmxlVGVjaG5vbG9naWVzKTtcbiAgICAvLyAgIHVpLmRpYWxvZygnQ2hvb3NlIFRlY2hub2xvZ3knKVxuICAgIC8vICAgICAuYWRkKHVpLnBhbmVsKFt0ZWNobm9sb2d5LnJvb3RdLCB7c3R5bGU6IHtmb250V2VpZ2h0OiAnYm9sZCd9fSkpXG4gICAgLy8gICAgIC5vbk9LKCgpID0+IHBvc3NpYmxlVGVjaG5vbG9naWVzID0gW3RlY2hub2xvZ3kudmFsdWVdKVxuICAgIC8vICAgICAub25DYW5jZWwoKCkgPT4ge1xuICAgIC8vICAgICAgIHBvc3NpYmxlVGVjaG5vbG9naWVzID0gW3Bvc3NpYmxlVGVjaG5vbG9naWVzWzBdXTtcbiAgICAvLyAgICAgICBncm9rLnNoZWxsLndhcm5pbmcoJ0lucHV0IHNlcXVlbmNlIGlzIGV4cGVjdGVkIHRvIGJlIGluIGZvcm1hdCAnICsgcG9zc2libGVUZWNobm9sb2dpZXNbMF0pO1xuICAgIC8vICAgICB9KVxuICAgIC8vICAgICAuc2hvdygpO1xuICAgIC8vIH0gZWxzZSBpZiAocG9zc2libGVUZWNobm9sb2dpZXMubGVuZ3RoID09IDApXG4gICAgaWYgKHBvc3NpYmxlVGVjaG5vbG9naWVzLmxlbmd0aCA9PSAwKVxuICAgICAgICByZXR1cm4geyBpbmRleE9mRmlyc3ROb3RWYWxpZENoYXI6IDAsIHN5bnRoZXNpemVyOiBudWxsLCB0ZWNobm9sb2d5OiBudWxsIH07XG4gICAgb3V0cHV0SW5kZXggPSAwO1xuICAgIHBvc3NpYmxlVGVjaG5vbG9naWVzLmZvckVhY2goKHRlY2hub2xvZ3kpID0+IHtcbiAgICAgICAgY29uc3QgY29kZXMgPSBPYmplY3Qua2V5cyhtYXBbcG9zc2libGVTeW50aGVzaXplcnNbMF1dW3RlY2hub2xvZ3ldKTtcbiAgICAgICAgd2hpbGUgKG91dHB1dEluZGV4IDwgc2VxdWVuY2UubGVuZ3RoKSB7XG4gICAgICAgICAgICBjb25zdCBtYXRjaGVkQ29kZSA9IGNvZGVzLmZpbmQoKGMpID0+IGMgPT0gc2VxdWVuY2Uuc2xpY2Uob3V0cHV0SW5kZXgsIG91dHB1dEluZGV4ICsgYy5sZW5ndGgpKTtcbiAgICAgICAgICAgIGlmIChtYXRjaGVkQ29kZSA9PSBudWxsKVxuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgaWYgKCAvLyBmb3IgbWlzdGFrZSBwYXR0ZXJuICdyQUEnXG4gICAgICAgICAgICBvdXRwdXRJbmRleCA+IDEgJiZcbiAgICAgICAgICAgICAgICBudWNsZW90aWRlcy5pbmNsdWRlcyhzZXF1ZW5jZVtvdXRwdXRJbmRleF0pICYmXG4gICAgICAgICAgICAgICAgZmlyc3RVbmlxdWVDaGFyYWN0ZXJzLmluY2x1ZGVzKHNlcXVlbmNlW291dHB1dEluZGV4IC0gMl0pKVxuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgaWYgKCAvLyBmb3IgbWlzdGFrZSBwYXR0ZXJuICdBckEnXG4gICAgICAgICAgICBmaXJzdFVuaXF1ZUNoYXJhY3RlcnMuaW5jbHVkZXMoc2VxdWVuY2Vbb3V0cHV0SW5kZXggKyAxXSkgJiZcbiAgICAgICAgICAgICAgICBudWNsZW90aWRlcy5pbmNsdWRlcyhzZXF1ZW5jZVtvdXRwdXRJbmRleF0pKSB7XG4gICAgICAgICAgICAgICAgb3V0cHV0SW5kZXgrKztcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIG91dHB1dEluZGV4ICs9IG1hdGNoZWRDb2RlLmxlbmd0aDtcbiAgICAgICAgfVxuICAgIH0pO1xuICAgIHJldHVybiB7XG4gICAgICAgIGluZGV4T2ZGaXJzdE5vdFZhbGlkQ2hhcjogaW5kZXhPZkZpcnN0Tm90VmFsaWRDaGFyLFxuICAgICAgICBzeW50aGVzaXplcjogcG9zc2libGVTeW50aGVzaXplcnMsXG4gICAgICAgIHRlY2hub2xvZ3k6IFtwb3NzaWJsZVRlY2hub2xvZ2llc1tvdXRwdXRJbmRleF1dLFxuICAgIH07XG59XG5mdW5jdGlvbiBnZXRBbGxDb2Rlc09mU3ludGhlc2l6ZXIoc3ludGhlc2l6ZXIpIHtcbiAgICBsZXQgY29kZXMgPSBbXTtcbiAgICBmb3IgKGNvbnN0IHRlY2hub2xvZ3kgb2YgT2JqZWN0LmtleXMobWFwW3N5bnRoZXNpemVyXSkpXG4gICAgICAgIGNvZGVzID0gY29kZXMuY29uY2F0KE9iamVjdC5rZXlzKG1hcFtzeW50aGVzaXplcl1bdGVjaG5vbG9neV0pKTtcbiAgICByZXR1cm4gY29kZXMuY29uY2F0KE9iamVjdC5rZXlzKE1PRElGSUNBVElPTlMpKTtcbn1cbmZ1bmN0aW9uIGdldExpc3RPZlBvc3NpYmxlU3ludGhlc2l6ZXJzQnlGaXJzdE1hdGNoZWRDb2RlKHNlcXVlbmNlKSB7XG4gICAgY29uc3Qgc3ludGhlc2l6ZXJzID0gW107XG4gICAgT2JqZWN0LmtleXMobWFwKS5mb3JFYWNoKChzeW50aGVzaXplcikgPT4ge1xuICAgICAgICBjb25zdCBjb2RlcyA9IGdldEFsbENvZGVzT2ZTeW50aGVzaXplcihzeW50aGVzaXplcik7XG4gICAgICAgIC8vVE9ETzogZ2V0IGZpcnN0IG5vbi1kcm9wZG93biBjb2RlIHdoZW4gdGhlcmUgYXJlIHR3byBtb2RpZmljYXRpb25zXG4gICAgICAgIGxldCBzdGFydCA9IDA7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc2VxdWVuY2UubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICAgIGlmIChzZXF1ZW5jZVtpXSA9PSAnKScgJiYgaSAhPSBzZXF1ZW5jZS5sZW5ndGggLSAxKSB7XG4gICAgICAgICAgICAgICAgc3RhcnQgPSBpICsgMTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoY29kZXMuc29tZSgocykgPT4gcyA9PSBzZXF1ZW5jZS5zbGljZShzdGFydCwgc3RhcnQgKyBzLmxlbmd0aCkpKVxuICAgICAgICAgICAgc3ludGhlc2l6ZXJzLnB1c2goc3ludGhlc2l6ZXIpO1xuICAgIH0pO1xuICAgIHJldHVybiBzeW50aGVzaXplcnM7XG59XG5mdW5jdGlvbiBnZXRMaXN0T2ZQb3NzaWJsZVRlY2hub2xvZ2llc0J5Rmlyc3RNYXRjaGVkQ29kZShzZXF1ZW5jZSwgc3ludGhlc2l6ZXIpIHtcbiAgICBjb25zdCB0ZWNobm9sb2dpZXMgPSBbXTtcbiAgICBPYmplY3Qua2V5cyhtYXBbc3ludGhlc2l6ZXJdKS5mb3JFYWNoKCh0ZWNobm9sb2d5KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvZGVzID0gT2JqZWN0LmtleXMobWFwW3N5bnRoZXNpemVyXVt0ZWNobm9sb2d5XSkuY29uY2F0KE9iamVjdC5rZXlzKE1PRElGSUNBVElPTlMpKTtcbiAgICAgICAgaWYgKGNvZGVzLnNvbWUoKHMpID0+IHMgPT0gc2VxdWVuY2Uuc2xpY2UoMCwgcy5sZW5ndGgpKSlcbiAgICAgICAgICAgIHRlY2hub2xvZ2llcy5wdXNoKHRlY2hub2xvZ3kpO1xuICAgIH0pO1xuICAgIHJldHVybiB0ZWNobm9sb2dpZXM7XG59XG5leHBvcnQgZnVuY3Rpb24gY29udmVydFNlcXVlbmNlKHNlcXVlbmNlLCBvdXRwdXQpIHtcbiAgICBpZiAob3V0cHV0LmluZGV4T2ZGaXJzdE5vdFZhbGlkQ2hhciAhPSAtMSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgLy8gdHlwZTogJycsXG4gICAgICAgICAgICBpbmRleE9mRmlyc3ROb3RWYWxpZENoYXI6IEpTT04uc3RyaW5naWZ5KG91dHB1dCksXG4gICAgICAgICAgICBFcnJvcjogdW5kZWZpbmVkSW5wdXRTZXF1ZW5jZSxcbiAgICAgICAgfTtcbiAgICB9XG4gICAgaWYgKG91dHB1dC5zeW50aGVzaXplci5pbmNsdWRlcyhTWU5USEVTSVpFUlMuUkFXX05VQ0xFT1RJREVTKSkgeyAvLyYmIG91dHB1dC50ZWNobm9sb2d5IS5pbmNsdWRlcyhURUNITk9MT0dJRVMuRE5BKSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdHlwZTogU1lOVEhFU0laRVJTLlJBV19OVUNMRU9USURFUyxcbiAgICAgICAgICAgIE51Y2xlb3RpZGVzOiBzZXF1ZW5jZSxcbiAgICAgICAgICAgIEJpb1NwcmluZzogYXNvR2FwbWVyc051Y2xlb3RpZGVzVG9CaW9TcHJpbmcoc2VxdWVuY2UpLFxuICAgICAgICAgICAgR0NSUzogYXNvR2FwbWVyc051Y2xlb3RpZGVzVG9HY3JzKHNlcXVlbmNlKSxcbiAgICAgICAgfTtcbiAgICB9XG4gICAgaWYgKG91dHB1dC5zeW50aGVzaXplci5pbmNsdWRlcyhTWU5USEVTSVpFUlMuQklPU1BSSU5HKSAmJiBvdXRwdXQudGVjaG5vbG9neS5pbmNsdWRlcyhURUNITk9MT0dJRVMuQVNPX0dBUE1FUlMpKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBTWU5USEVTSVpFUlMuQklPU1BSSU5HICsgJyAnICsgVEVDSE5PTE9HSUVTLkFTT19HQVBNRVJTLFxuICAgICAgICAgICAgTnVjbGVvdGlkZXM6IGFzb0dhcG1lcnNCaW9TcHJpbmdUb051Y2xlb3RpZGVzKHNlcXVlbmNlKSxcbiAgICAgICAgICAgIEJpb1NwcmluZzogc2VxdWVuY2UsXG4gICAgICAgICAgICBHQ1JTOiBhc29HYXBtZXJzQmlvU3ByaW5nVG9HY3JzKHNlcXVlbmNlKSxcbiAgICAgICAgfTtcbiAgICB9XG4gICAgaWYgKG91dHB1dC5zeW50aGVzaXplci5pbmNsdWRlcyhTWU5USEVTSVpFUlMuR0NSUykgJiYgb3V0cHV0LnRlY2hub2xvZ3kuaW5jbHVkZXMoVEVDSE5PTE9HSUVTLkFTT19HQVBNRVJTKSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdHlwZTogU1lOVEhFU0laRVJTLkdDUlMgKyAnICcgKyBURUNITk9MT0dJRVMuQVNPX0dBUE1FUlMsXG4gICAgICAgICAgICBOdWNsZW90aWRlczogYXNvR2FwbWVyc0djcnNUb051Y2xlb3RpZGVzKHNlcXVlbmNlKSxcbiAgICAgICAgICAgIEJpb1NwcmluZzogYXNvR2FwbWVyc0djcnNUb0Jpb1NwcmluZyhzZXF1ZW5jZSksXG4gICAgICAgICAgICBNZXJtYWRlMTI6IGdjcnNUb01lcm1hZGUxMihzZXF1ZW5jZSksXG4gICAgICAgICAgICBHQ1JTOiBzZXF1ZW5jZSxcbiAgICAgICAgfTtcbiAgICB9XG4gICAgaWYgKG91dHB1dC5zeW50aGVzaXplci5pbmNsdWRlcyhTWU5USEVTSVpFUlMuUkFXX05VQ0xFT1RJREVTKSAmJiBvdXRwdXQudGVjaG5vbG9neS5pbmNsdWRlcyhURUNITk9MT0dJRVMuUk5BKSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdHlwZTogU1lOVEhFU0laRVJTLlJBV19OVUNMRU9USURFUyArICcgJyArIFRFQ0hOT0xPR0lFUy5STkEsXG4gICAgICAgICAgICBOdWNsZW90aWRlczogc2VxdWVuY2UsXG4gICAgICAgICAgICBCaW9TcHJpbmc6IHNpUm5hTnVjbGVvdGlkZVRvQmlvU3ByaW5nU2Vuc2VTdHJhbmQoc2VxdWVuY2UpLFxuICAgICAgICAgICAgQXhvbGFiczogc2lSbmFOdWNsZW90aWRlVG9BeG9sYWJzU2Vuc2VTdHJhbmQoc2VxdWVuY2UpLFxuICAgICAgICAgICAgR0NSUzogc2lSbmFOdWNsZW90aWRlc1RvR2NycyhzZXF1ZW5jZSksXG4gICAgICAgIH07XG4gICAgfVxuICAgIGlmIChvdXRwdXQuc3ludGhlc2l6ZXIuaW5jbHVkZXMoU1lOVEhFU0laRVJTLkJJT1NQUklORykgJiYgb3V0cHV0LnRlY2hub2xvZ3kuaW5jbHVkZXMoVEVDSE5PTE9HSUVTLlNJX1JOQSkpIHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHR5cGU6IFNZTlRIRVNJWkVSUy5CSU9TUFJJTkcgKyAnICcgKyBURUNITk9MT0dJRVMuU0lfUk5BLFxuICAgICAgICAgICAgTnVjbGVvdGlkZXM6IHNpUm5hQmlvU3ByaW5nVG9OdWNsZW90aWRlcyhzZXF1ZW5jZSksXG4gICAgICAgICAgICBCaW9TcHJpbmc6IHNlcXVlbmNlLFxuICAgICAgICAgICAgQXhvbGFiczogc2lSbmFCaW9TcHJpbmdUb0F4b2xhYnMoc2VxdWVuY2UpLFxuICAgICAgICAgICAgR0NSUzogc2lSbmFCaW9TcHJpbmdUb0djcnMoc2VxdWVuY2UpLFxuICAgICAgICB9O1xuICAgIH1cbiAgICBpZiAob3V0cHV0LnN5bnRoZXNpemVyLmluY2x1ZGVzKFNZTlRIRVNJWkVSUy5BWE9MQUJTKSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdHlwZTogU1lOVEhFU0laRVJTLkFYT0xBQlMgKyAnICcgKyBURUNITk9MT0dJRVMuU0lfUk5BLFxuICAgICAgICAgICAgTnVjbGVvdGlkZXM6IHNpUm5hQXhvbGFic1RvTnVjbGVvdGlkZXMoc2VxdWVuY2UpLFxuICAgICAgICAgICAgQmlvU3ByaW5nOiBzaVJuYUF4b2xhYnNUb0Jpb1NwcmluZyhzZXF1ZW5jZSksXG4gICAgICAgICAgICBBeG9sYWJzOiBzZXF1ZW5jZSxcbiAgICAgICAgICAgIEdDUlM6IHNpUm5hQXhvbGFic1RvR2NycyhzZXF1ZW5jZSksXG4gICAgICAgIH07XG4gICAgfVxuICAgIGlmIChvdXRwdXQuc3ludGhlc2l6ZXIuaW5jbHVkZXMoU1lOVEhFU0laRVJTLkdDUlMpICYmIG91dHB1dC50ZWNobm9sb2d5LmluY2x1ZGVzKFRFQ0hOT0xPR0lFUy5TSV9STkEpKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBTWU5USEVTSVpFUlMuR0NSUyArICcgJyArIFRFQ0hOT0xPR0lFUy5TSV9STkEsXG4gICAgICAgICAgICBOdWNsZW90aWRlczogc2lSbmFHY3JzVG9OdWNsZW90aWRlcyhzZXF1ZW5jZSksXG4gICAgICAgICAgICBCaW9TcHJpbmc6IHNpUm5hR2Nyc1RvQmlvU3ByaW5nKHNlcXVlbmNlKSxcbiAgICAgICAgICAgIEF4b2xhYnM6IHNpUm5hR2Nyc1RvQXhvbGFicyhzZXF1ZW5jZSksXG4gICAgICAgICAgICBNTTEyOiBnY3JzVG9NZXJtYWRlMTIoc2VxdWVuY2UpLFxuICAgICAgICAgICAgR0NSUzogc2VxdWVuY2UsXG4gICAgICAgIH07XG4gICAgfVxuICAgIGlmIChvdXRwdXQuc3ludGhlc2l6ZXIuaW5jbHVkZXMoU1lOVEhFU0laRVJTLkdDUlMpKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBTWU5USEVTSVpFUlMuR0NSUyxcbiAgICAgICAgICAgIE51Y2xlb3RpZGVzOiBnY3JzVG9OdWNsZW90aWRlcyhzZXF1ZW5jZSksXG4gICAgICAgICAgICBHQ1JTOiBzZXF1ZW5jZSxcbiAgICAgICAgICAgIE1lcm1hZGUxMjogZ2Nyc1RvTWVybWFkZTEyKHNlcXVlbmNlKSxcbiAgICAgICAgfTtcbiAgICB9XG4gICAgaWYgKG91dHB1dC5zeW50aGVzaXplci5pbmNsdWRlcyhTWU5USEVTSVpFUlMuTUVSTUFERV8xMikpIHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHR5cGU6IFNZTlRIRVNJWkVSUy5NRVJNQURFXzEyLFxuICAgICAgICAgICAgTnVjbGVvdGlkZXM6IG5vVHJhbnNsYXRpb25UYWJsZUF2YWlsYWJsZSxcbiAgICAgICAgICAgIEdDUlM6IG5vVHJhbnNsYXRpb25UYWJsZUF2YWlsYWJsZSxcbiAgICAgICAgICAgIE1lcm1hZGUxMjogc2VxdWVuY2UsXG4gICAgICAgIH07XG4gICAgfVxuICAgIHJldHVybiB7XG4gICAgICAgIHR5cGU6IHVuZGVmaW5lZElucHV0U2VxdWVuY2UsXG4gICAgICAgIE51Y2xlb3RpZGVzOiB1bmRlZmluZWRJbnB1dFNlcXVlbmNlLFxuICAgIH07XG59XG4iLCJ2YXIgX19hd2FpdGVyID0gKHRoaXMgJiYgdGhpcy5fX2F3YWl0ZXIpIHx8IGZ1bmN0aW9uICh0aGlzQXJnLCBfYXJndW1lbnRzLCBQLCBnZW5lcmF0b3IpIHtcbiAgICBmdW5jdGlvbiBhZG9wdCh2YWx1ZSkgeyByZXR1cm4gdmFsdWUgaW5zdGFuY2VvZiBQID8gdmFsdWUgOiBuZXcgUChmdW5jdGlvbiAocmVzb2x2ZSkgeyByZXNvbHZlKHZhbHVlKTsgfSk7IH1cbiAgICByZXR1cm4gbmV3IChQIHx8IChQID0gUHJvbWlzZSkpKGZ1bmN0aW9uIChyZXNvbHZlLCByZWplY3QpIHtcbiAgICAgICAgZnVuY3Rpb24gZnVsZmlsbGVkKHZhbHVlKSB7IHRyeSB7IHN0ZXAoZ2VuZXJhdG9yLm5leHQodmFsdWUpKTsgfSBjYXRjaCAoZSkgeyByZWplY3QoZSk7IH0gfVxuICAgICAgICBmdW5jdGlvbiByZWplY3RlZCh2YWx1ZSkgeyB0cnkgeyBzdGVwKGdlbmVyYXRvcltcInRocm93XCJdKHZhbHVlKSk7IH0gY2F0Y2ggKGUpIHsgcmVqZWN0KGUpOyB9IH1cbiAgICAgICAgZnVuY3Rpb24gc3RlcChyZXN1bHQpIHsgcmVzdWx0LmRvbmUgPyByZXNvbHZlKHJlc3VsdC52YWx1ZSkgOiBhZG9wdChyZXN1bHQudmFsdWUpLnRoZW4oZnVsZmlsbGVkLCByZWplY3RlZCk7IH1cbiAgICAgICAgc3RlcCgoZ2VuZXJhdG9yID0gZ2VuZXJhdG9yLmFwcGx5KHRoaXNBcmcsIF9hcmd1bWVudHMgfHwgW10pKS5uZXh0KCkpO1xuICAgIH0pO1xufTtcbmltcG9ydCB7IGNhdGVnb3J5LCBleHBlY3QsIHRlc3QgfSBmcm9tICdAZGF0YWdyb2stbGlicmFyaWVzL3V0aWxzL3NyYy90ZXN0JztcbmltcG9ydCB7IHNlcXVlbmNlVG9TbWlsZXMgfSBmcm9tICcuLi9zdHJ1Y3R1cmVzLXdvcmtzL2Zyb20tbW9ub21lcnMnO1xuaW1wb3J0IHsgU1lOVEhFU0laRVJTIH0gZnJvbSAnLi4vc3RydWN0dXJlcy13b3Jrcy9tYXAnO1xuY2F0ZWdvcnkoJ3NlcXVlbmNlLXRyYW5zbGF0b3InLCAoKSA9PiB7XG4gICAgdGVzdCgnQUdHVENDVENUVEdBQ1RUQUdHQ0MnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKUNbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoPU8pTkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoPU8pTkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoPU8pTkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9QyhDKUMoPU8pTkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKUNbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKUNbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DKEMpQyg9TylOQzIoPU8pKUNbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DKEMpQyg9TylOQzIoPU8pKUNbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKUNbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlDW0NAQEhdMU9QKD1PKShPKU9DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlDW0NAQEhdMU8nO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygnQUdHVENDVENUVEdBQ1RUQUdHQ0MnLCBmYWxzZSwgU1lOVEhFU0laRVJTLlJBV19OVUNMRU9USURFUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnaW52YWJhc2ljL2dhbG5hYzEnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ0MoTylDTkMoPU8pQ0NDQyg9TylOQyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKScgK1xuICAgICAgICAgICAgJyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKScgK1xuICAgICAgICAgICAgJyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKSc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKXNnZyhpbnZhYmFzaWMpKEdhbE5BYy0yLUpOSiknLCBmYWxzZSwgU1lOVEhFU0laRVJTLkFYT0xBQlMpLCBleHBlY3RlZCk7XG4gICAgfSkpO1xuICAgIHRlc3QoJ2ludmFiYXNpYy9nYWxuYWMyJywgKCkgPT4gX19hd2FpdGVyKHZvaWQgMCwgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgIGNvbnN0IGV4cGVjdGVkID0gJ09bQ0BASF0xQ1tDQEBIXU9bQ0BIXTFDT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09bQ0BASF0xQ1tDQEBIXU9bQ0BIXTFDT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NDKE8pQ05DKD1PKUNDQ0MoPU8pTkMoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknICtcbiAgICAgICAgICAgICcoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknICtcbiAgICAgICAgICAgICcoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygnKGludmFiYXNpYylzZ3NnKGludmFiYXNpYykoR2FsTkFjLTItSk5KKScsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnaW52YWJhc2ljL2dhbG5hYzMnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ0MoTylDTkMoPU8pQ0NDQyg9TylOQyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKScgK1xuICAgICAgICAgICAgJyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKScgK1xuICAgICAgICAgICAgJyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKSc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKXNnZ3MoaW52YWJhc2ljKShHYWxOQWMtMi1KTkopJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCdpbnZhYmFzaWMvZ2FsbmFjNCcsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPW0NAQEhdMUNbQ0BASF1PW0NASF0xQ09QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPW0NAQEhdMUNbQ0BASF1PW0NASF0xQ09QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DQyhPKUNOQyg9TylDQ0NDKD1PKU5DKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJyhpbnZhYmFzaWMpc2dnKGludmFiYXNpYylzKEdhbE5BYy0yLUpOSiknLCBmYWxzZSwgU1lOVEhFU0laRVJTLkFYT0xBQlMpLCBleHBlY3RlZCk7XG4gICAgfSkpO1xuICAgIHRlc3QoJ3VzQ2ZDZlVmR2ZBZicsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oRilbQ0BASF0xTyc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCd1c0NmQ2ZVZkdmQWYnLCBmYWxzZSwgU1lOVEhFU0laRVJTLkFYT0xBQlMpLCBleHBlY3RlZCk7XG4gICAgfSkpO1xuICAgIHRlc3QoJ3VzQWZzdXNnc2dzZycsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU8nO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygndXNBZnN1c2dzZ3NnJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCdVZlVmVWZzQ2ZzdWFjZycsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJ1VmVWZVZnNDZnN1YWNnJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCdzdXN1c3VzYXVhc3UnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1AoPU8pKFMpT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJ3N1c3VzdXNhdWFzdScsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnQ2ZHZkNmc0dmc0NmJywgKCkgPT4gX19hd2FpdGVyKHZvaWQgMCwgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgIGNvbnN0IGV4cGVjdGVkID0gJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xTyc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCdDZkdmQ2ZzR2ZzQ2YnLCBmYWxzZSwgU1lOVEhFU0laRVJTLkFYT0xBQlMpLCBleHBlY3RlZCk7XG4gICAgfSkpO1xuICAgIHRlc3QoJ2FjYWNhY3NhY3NhYycsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU8nO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygnYWNhY2Fjc2Fjc2FjJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCdjY2NnZ2d1c3VnJywgKCkgPT4gX19hd2FpdGVyKHZvaWQgMCwgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgIGNvbnN0IGV4cGVjdGVkID0gJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU8nO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygnY2NjZ2dndXN1ZycsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnVWZBZkNmR2ZHZkNmQWZVZicsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU8nO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygnVWZBZkNmR2ZHZkNmQWZVZicsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnKGludmFiYXNpYylzdWN1Q2Z1VWYnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xTyc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKXN1Y3VDZnVVZicsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnKGludmFiYXNpYylzQWZnY3VnVWYnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xTyc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKXNBZmdjdWdVZicsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnKGludmFiYXNpYyljdUNmdVVmc2MnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xTyc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKWN1Q2Z1VWZzYycsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnKGludmFiYXNpYylzY3VzdXN1KEdhbE5BYy0yLUpOSiknLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DQyhPKUNOQyg9TylDQ0NDKD1PKU5DKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJyhpbnZhYmFzaWMpc2N1c3VzdShHYWxOQWMtMi1KTkopJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCcoaW52YWJhc2ljKXVzQWZzdWN1Q2Z1VWZBZmdjdWdVZmdDZmFjdXN1c3UnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJyhpbnZhYmFzaWMpdXNBZnN1Y3VDZnVVZkFmZ2N1Z1VmZ0NmYWN1c3VzdScsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnKGludmFiYXNpYylhc2FjZ0dmdUdmQ2ZBZmFjdWN1YXV1Y2EnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xTyc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKWFzYWNnR2Z1R2ZDZkFmYWN1Y3VhdXVjYScsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnKGludmFiYXNpYylzY3NnZ3VHZmNBZkFmQ2Z1Y3VhdXVjdWdhJywgKCkgPT4gX19hd2FpdGVyKHZvaWQgMCwgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgIGNvbnN0IGV4cGVjdGVkID0gJ09bQ0BASF0xQ1tDQEBIXU9bQ0BIXTFDT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU8nO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygnKGludmFiYXNpYylzY3NnZ3VHZmNBZkFmQ2Z1Y3VhdXVjdWdhJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCcoaW52YWJhc2ljKXNjc2FhY1VmY1VmQWZVZnVjdWdnYWN1dWEnLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xTyc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKXNjc2FhY1VmY1VmQWZVZnVjdWdnYWN1dWEnLCBmYWxzZSwgU1lOVEhFU0laRVJTLkFYT0xBQlMpLCBleHBlY3RlZCk7XG4gICAgfSkpO1xuICAgIHRlc3QoJyhpbnZhYmFzaWMpc2FzYWN1Q2Z1QWZVZlVmY3VnZ2FjdXV1YScsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPW0NAQEhdMUNbQ0BASF1PW0NASF0xQ09QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJyhpbnZhYmFzaWMpc2FzYWN1Q2Z1QWZVZlVmY3VnZ2FjdXV1YScsIGZhbHNlLCBTWU5USEVTSVpFUlMuQVhPTEFCUyksIGV4cGVjdGVkKTtcbiAgICB9KSk7XG4gICAgdGVzdCgnKGludmFiYXNpYyl1c0Fmc2N1ZyhpbnZhYmFzaWMpKEdhbE5BYy0yLUpOSiknLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShGKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPW0NAQEhdMUNbQ0BASF1PW0NASF0xQ09QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DQyhPKUNOQyg9TylDQ0NDKD1PKU5DKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJyhpbnZhYmFzaWMpdXNBZnNjdWcoaW52YWJhc2ljKShHYWxOQWMtMi1KTkopJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCcoaW52YWJhc2ljKXNhc3VhYUNmY1VmKEdhbE5BYy0yLUpOSiknLCAoKSA9PiBfX2F3YWl0ZXIodm9pZCAwLCB2b2lkIDAsIHZvaWQgMCwgZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgZXhwZWN0ZWQgPSAnT1tDQEBIXTFDW0NAQEhdT1tDQEhdMUNPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ0MoTylDTkMoPU8pQ0NDQyg9TylOQyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKScgK1xuICAgICAgICAgICAgJyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKScgK1xuICAgICAgICAgICAgJyhDT0NDQyg9TylOQ0NDTkMoPU8pQ0NDQ09DMk9DKENPKUMoTylDKE8pQzJOQyg9TylDKSc7XG4gICAgICAgIGV4cGVjdChzZXF1ZW5jZVRvU21pbGVzKCcoaW52YWJhc2ljKXNhc3VhYUNmY1VmKEdhbE5BYy0yLUpOSiknLCBmYWxzZSwgU1lOVEhFU0laRVJTLkFYT0xBQlMpLCBleHBlY3RlZCk7XG4gICAgfSkpO1xuICAgIHRlc3QoJyhpbnZhYmFzaWMpc2FzdWFhQ2ZjVWZDZlVmdWd1YWd1dWF1YShHYWxOQWMtMi1KTkopJywgKCkgPT4gX19hd2FpdGVyKHZvaWQgMCwgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgIGNvbnN0IGV4cGVjdGVkID0gJ09bQ0BASF0xQ1tDQEBIXU9bQ0BIXTFDT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DTj1DKE4pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DQyhPKUNOQyg9TylDQ0NDKD1PKU5DKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJyhpbnZhYmFzaWMpc2FzdWFhQ2ZjVWZDZlVmdWd1YWd1dWF1YShHYWxOQWMtMi1KTkopJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbiAgICB0ZXN0KCcoaW52YWJhc2ljKXNjc2F1Y2FjZ3VVZkdmQ2ZhZ2NjZ3VjdXVhKGludmFiYXNpYykoR2FsTkFjLTItSk5KKScsICgpID0+IF9fYXdhaXRlcih2b2lkIDAsIHZvaWQgMCwgdm9pZCAwLCBmdW5jdGlvbiogKCkge1xuICAgICAgICBjb25zdCBleHBlY3RlZCA9ICdPW0NAQEhdMUNbQ0BASF1PW0NASF0xQ09QKD1PKShTKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkMzTj1DKE4pTkMoPU8pQz0zTj1DMilbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09bQ0BASF0xQ1tDQEBIXU9bQ0BIXTFDT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NDKE8pQ05DKD1PKUNDQ0MoPU8pTkMoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknICtcbiAgICAgICAgICAgICcoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknICtcbiAgICAgICAgICAgICcoQ09DQ0MoPU8pTkNDQ05DKD1PKUNDQ0NPQzJPQyhDTylDKE8pQyhPKUMyTkMoPU8pQyknO1xuICAgICAgICBleHBlY3Qoc2VxdWVuY2VUb1NtaWxlcygnKGludmFiYXNpYylzY3NhdWNhY2d1VWZHZkNmYWdjY2d1Y3V1YShpbnZhYmFzaWMpKEdhbE5BYy0yLUpOSiknLCBmYWxzZSwgU1lOVEhFU0laRVJTLkFYT0xBQlMpLCBleHBlY3RlZCk7XG4gICAgfSkpO1xuICAgIHRlc3QoJyhpbnZhYmFzaWMpc3VzZ3V1VWZnQ2ZDZlVmYWNhdWN1YWN1YShHYWxOQWMtMi1KTkopJywgKCkgPT4gX19hd2FpdGVyKHZvaWQgMCwgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgIGNvbnN0IGV4cGVjdGVkID0gJ09bQ0BASF0xQ1tDQEBIXU9bQ0BIXTFDT1AoPU8pKFMpJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoUyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049QyhOKU5DKD1PKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUMoTilOQyg9TylDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKE4pPU5DMig9TykpW0NASF0oRilbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyhOKT1OQzIoPU8pKVtDQEhdKEYpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoPU8pTkMyKD1PKSlbQ0BIXShGKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQzNOPUNOPUMoTilDPTNOPUMyKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDPUNDKD1PKU5DMig9TykpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DW0NASF0xT1tDQEBIXShOMkM9Q0MoTik9TkMyKD1PKSlbQ0BIXShPQylbQ0BASF0xT1AoPU8pKE8pJyArXG4gICAgICAgICAgICAnT0NbQ0BIXTFPW0NAQEhdKE4yQz1DQyg9TylOQzIoPU8pKVtDQEhdKE9DKVtDQEBIXTFPUCg9TykoTyknICtcbiAgICAgICAgICAgICdPQ1tDQEhdMU9bQ0BASF0oTjJDM049Q049QyhOKUM9M049QzIpW0NASF0oT0MpW0NAQEhdMU9QKD1PKShPKScgK1xuICAgICAgICAgICAgJ09DQyhPKUNOQyg9TylDQ0NDKD1PKU5DKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJyArXG4gICAgICAgICAgICAnKENPQ0NDKD1PKU5DQ0NOQyg9TylDQ0NDT0MyT0MoQ08pQyhPKUMoTylDMk5DKD1PKUMpJztcbiAgICAgICAgZXhwZWN0KHNlcXVlbmNlVG9TbWlsZXMoJyhpbnZhYmFzaWMpc3VzZ3V1VWZnQ2ZDZlVmYWNhdWN1YWN1YShHYWxOQWMtMi1KTkopJywgZmFsc2UsIFNZTlRIRVNJWkVSUy5BWE9MQUJTKSwgZXhwZWN0ZWQpO1xuICAgIH0pKTtcbn0pO1xuIiwibW9kdWxlLmV4cG9ydHMgPSBERzsiLCJtb2R1bGUuZXhwb3J0cyA9IE9DTDsiLCJtb2R1bGUuZXhwb3J0cyA9IGdyb2s7IiwiLy8gVGhlIG1vZHVsZSBjYWNoZVxudmFyIF9fd2VicGFja19tb2R1bGVfY2FjaGVfXyA9IHt9O1xuXG4vLyBUaGUgcmVxdWlyZSBmdW5jdGlvblxuZnVuY3Rpb24gX193ZWJwYWNrX3JlcXVpcmVfXyhtb2R1bGVJZCkge1xuXHQvLyBDaGVjayBpZiBtb2R1bGUgaXMgaW4gY2FjaGVcblx0dmFyIGNhY2hlZE1vZHVsZSA9IF9fd2VicGFja19tb2R1bGVfY2FjaGVfX1ttb2R1bGVJZF07XG5cdGlmIChjYWNoZWRNb2R1bGUgIT09IHVuZGVmaW5lZCkge1xuXHRcdHJldHVybiBjYWNoZWRNb2R1bGUuZXhwb3J0cztcblx0fVxuXHQvLyBDcmVhdGUgYSBuZXcgbW9kdWxlIChhbmQgcHV0IGl0IGludG8gdGhlIGNhY2hlKVxuXHR2YXIgbW9kdWxlID0gX193ZWJwYWNrX21vZHVsZV9jYWNoZV9fW21vZHVsZUlkXSA9IHtcblx0XHQvLyBubyBtb2R1bGUuaWQgbmVlZGVkXG5cdFx0Ly8gbm8gbW9kdWxlLmxvYWRlZCBuZWVkZWRcblx0XHRleHBvcnRzOiB7fVxuXHR9O1xuXG5cdC8vIEV4ZWN1dGUgdGhlIG1vZHVsZSBmdW5jdGlvblxuXHRfX3dlYnBhY2tfbW9kdWxlc19fW21vZHVsZUlkXShtb2R1bGUsIG1vZHVsZS5leHBvcnRzLCBfX3dlYnBhY2tfcmVxdWlyZV9fKTtcblxuXHQvLyBSZXR1cm4gdGhlIGV4cG9ydHMgb2YgdGhlIG1vZHVsZVxuXHRyZXR1cm4gbW9kdWxlLmV4cG9ydHM7XG59XG5cbiIsIi8vIGdldERlZmF1bHRFeHBvcnQgZnVuY3Rpb24gZm9yIGNvbXBhdGliaWxpdHkgd2l0aCBub24taGFybW9ueSBtb2R1bGVzXG5fX3dlYnBhY2tfcmVxdWlyZV9fLm4gPSAobW9kdWxlKSA9PiB7XG5cdHZhciBnZXR0ZXIgPSBtb2R1bGUgJiYgbW9kdWxlLl9fZXNNb2R1bGUgP1xuXHRcdCgpID0+IChtb2R1bGVbJ2RlZmF1bHQnXSkgOlxuXHRcdCgpID0+IChtb2R1bGUpO1xuXHRfX3dlYnBhY2tfcmVxdWlyZV9fLmQoZ2V0dGVyLCB7IGE6IGdldHRlciB9KTtcblx0cmV0dXJuIGdldHRlcjtcbn07IiwiLy8gZGVmaW5lIGdldHRlciBmdW5jdGlvbnMgZm9yIGhhcm1vbnkgZXhwb3J0c1xuX193ZWJwYWNrX3JlcXVpcmVfXy5kID0gKGV4cG9ydHMsIGRlZmluaXRpb24pID0+IHtcblx0Zm9yKHZhciBrZXkgaW4gZGVmaW5pdGlvbikge1xuXHRcdGlmKF9fd2VicGFja19yZXF1aXJlX18ubyhkZWZpbml0aW9uLCBrZXkpICYmICFfX3dlYnBhY2tfcmVxdWlyZV9fLm8oZXhwb3J0cywga2V5KSkge1xuXHRcdFx0T2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIGtleSwgeyBlbnVtZXJhYmxlOiB0cnVlLCBnZXQ6IGRlZmluaXRpb25ba2V5XSB9KTtcblx0XHR9XG5cdH1cbn07IiwiX193ZWJwYWNrX3JlcXVpcmVfXy5vID0gKG9iaiwgcHJvcCkgPT4gKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChvYmosIHByb3ApKSIsIi8vIGRlZmluZSBfX2VzTW9kdWxlIG9uIGV4cG9ydHNcbl9fd2VicGFja19yZXF1aXJlX18uciA9IChleHBvcnRzKSA9PiB7XG5cdGlmKHR5cGVvZiBTeW1ib2wgIT09ICd1bmRlZmluZWQnICYmIFN5bWJvbC50b1N0cmluZ1RhZykge1xuXHRcdE9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXHR9XG5cdE9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCAnX19lc01vZHVsZScsIHsgdmFsdWU6IHRydWUgfSk7XG59OyIsInZhciBfX2F3YWl0ZXIgPSAodGhpcyAmJiB0aGlzLl9fYXdhaXRlcikgfHwgZnVuY3Rpb24gKHRoaXNBcmcsIF9hcmd1bWVudHMsIFAsIGdlbmVyYXRvcikge1xuICAgIGZ1bmN0aW9uIGFkb3B0KHZhbHVlKSB7IHJldHVybiB2YWx1ZSBpbnN0YW5jZW9mIFAgPyB2YWx1ZSA6IG5ldyBQKGZ1bmN0aW9uIChyZXNvbHZlKSB7IHJlc29sdmUodmFsdWUpOyB9KTsgfVxuICAgIHJldHVybiBuZXcgKFAgfHwgKFAgPSBQcm9taXNlKSkoZnVuY3Rpb24gKHJlc29sdmUsIHJlamVjdCkge1xuICAgICAgICBmdW5jdGlvbiBmdWxmaWxsZWQodmFsdWUpIHsgdHJ5IHsgc3RlcChnZW5lcmF0b3IubmV4dCh2YWx1ZSkpOyB9IGNhdGNoIChlKSB7IHJlamVjdChlKTsgfSB9XG4gICAgICAgIGZ1bmN0aW9uIHJlamVjdGVkKHZhbHVlKSB7IHRyeSB7IHN0ZXAoZ2VuZXJhdG9yW1widGhyb3dcIl0odmFsdWUpKTsgfSBjYXRjaCAoZSkgeyByZWplY3QoZSk7IH0gfVxuICAgICAgICBmdW5jdGlvbiBzdGVwKHJlc3VsdCkgeyByZXN1bHQuZG9uZSA/IHJlc29sdmUocmVzdWx0LnZhbHVlKSA6IGFkb3B0KHJlc3VsdC52YWx1ZSkudGhlbihmdWxmaWxsZWQsIHJlamVjdGVkKTsgfVxuICAgICAgICBzdGVwKChnZW5lcmF0b3IgPSBnZW5lcmF0b3IuYXBwbHkodGhpc0FyZywgX2FyZ3VtZW50cyB8fCBbXSkpLm5leHQoKSk7XG4gICAgfSk7XG59O1xuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcbmltcG9ydCB7IHJ1blRlc3RzLCB0ZXN0cyB9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3Rlc3QnO1xuaW1wb3J0ICcuL3Rlc3RzL3NtaWxlcy10ZXN0cyc7XG5leHBvcnQgY29uc3QgX3BhY2thZ2UgPSBuZXcgREcuUGFja2FnZSgpO1xuZXhwb3J0IHsgdGVzdHMgfTtcbi8vbmFtZTogdGVzdFxuLy9vdXRwdXQ6IGRhdGFmcmFtZSByZXN1bHRcbmV4cG9ydCBmdW5jdGlvbiB0ZXN0KCkge1xuICAgIHJldHVybiBfX2F3YWl0ZXIodGhpcywgdm9pZCAwLCB2b2lkIDAsIGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgIGNvbnN0IGRhdGEgPSB5aWVsZCBydW5UZXN0cygpO1xuICAgICAgICByZXR1cm4gREcuRGF0YUZyYW1lLmZyb21PYmplY3RzKGRhdGEpO1xuICAgIH0pO1xufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9