jsii-diff 1.55.1 → 1.56.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.
- package/lib/version.d.ts +1 -1
- package/lib/version.js +3 -3
- package/package.json +9 -9
- package/test/diagnostics.test.js +15 -15
- package/test/util.d.ts +3 -3
- package/test/util.js +9 -11
package/lib/version.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/** The qualified version number for this JSII compiler. */
|
|
2
|
-
export declare const VERSION = "1.
|
|
2
|
+
export declare const VERSION = "1.56.0 (build 55e7d15)";
|
package/lib/version.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
// Generated at 2022-
|
|
2
|
+
// Generated at 2022-04-08T12:52:57Z by generate.sh
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
4
|
exports.VERSION = void 0;
|
|
5
5
|
/** The qualified version number for this JSII compiler. */
|
|
6
|
-
exports.VERSION = '1.
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
exports.VERSION = '1.56.0 (build 55e7d15)';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLG1EQUFtRDs7O0FBRW5ELDJEQUEyRDtBQUM5QyxRQUFBLE9BQU8sR0FBRyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEdlbmVyYXRlZCBhdCAyMDIyLTA0LTA4VDEyOjUyOjU3WiBieSBnZW5lcmF0ZS5zaFxuXG4vKiogVGhlIHF1YWxpZmllZCB2ZXJzaW9uIG51bWJlciBmb3IgdGhpcyBKU0lJIGNvbXBpbGVyLiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSAnMS41Ni4wIChidWlsZCA1NWU3ZDE1KSc7XG4iXX0=
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "jsii-diff",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.56.0",
|
|
4
4
|
"description": "Assembly comparison for jsii",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"author": {
|
|
@@ -33,11 +33,11 @@
|
|
|
33
33
|
"package": "package-js"
|
|
34
34
|
},
|
|
35
35
|
"dependencies": {
|
|
36
|
-
"@jsii/check-node": "1.
|
|
37
|
-
"@jsii/spec": "^1.
|
|
36
|
+
"@jsii/check-node": "1.56.0",
|
|
37
|
+
"@jsii/spec": "^1.56.0",
|
|
38
38
|
"fs-extra": "^9.1.0",
|
|
39
|
-
"jsii-reflect": "^1.
|
|
40
|
-
"log4js": "^6.4.
|
|
39
|
+
"jsii-reflect": "^1.56.0",
|
|
40
|
+
"log4js": "^6.4.4",
|
|
41
41
|
"typescript": "~3.9.10",
|
|
42
42
|
"yargs": "^16.2.0"
|
|
43
43
|
},
|
|
@@ -46,11 +46,11 @@
|
|
|
46
46
|
"@types/jest": "^27.4.1",
|
|
47
47
|
"@types/node": "^12.20.47",
|
|
48
48
|
"@types/tar-fs": "^2.0.1",
|
|
49
|
-
"eslint": "^8.
|
|
49
|
+
"eslint": "^8.12.0",
|
|
50
50
|
"jest": "^27.5.1",
|
|
51
51
|
"jest-expect-message": "^1.0.2",
|
|
52
|
-
"jsii": "^1.
|
|
53
|
-
"jsii-build-tools": "^1.
|
|
54
|
-
"prettier": "^2.
|
|
52
|
+
"jsii": "^1.56.0",
|
|
53
|
+
"jsii-build-tools": "^1.56.0",
|
|
54
|
+
"prettier": "^2.6.2"
|
|
55
55
|
}
|
|
56
56
|
}
|
package/test/diagnostics.test.js
CHANGED
|
@@ -3,8 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const diagnostics_1 = require("../lib/diagnostics");
|
|
4
4
|
const util_1 = require("./util");
|
|
5
5
|
// ----------------------------------------------------------------------
|
|
6
|
-
test('experimental elements lead to warnings',
|
|
7
|
-
const mms =
|
|
6
|
+
test('experimental elements lead to warnings', () => {
|
|
7
|
+
const mms = util_1.compare(`
|
|
8
8
|
/** @experimental */
|
|
9
9
|
export class Foo1 { }
|
|
10
10
|
`, `
|
|
@@ -16,8 +16,8 @@ test('experimental elements lead to warnings', async () => {
|
|
|
16
16
|
expect(diagnostics_1.hasErrors(diags)).toBeFalsy();
|
|
17
17
|
});
|
|
18
18
|
// ----------------------------------------------------------------------
|
|
19
|
-
test('external stability violations are reported as warnings',
|
|
20
|
-
const mms =
|
|
19
|
+
test('external stability violations are reported as warnings', () => {
|
|
20
|
+
const mms = util_1.compare(`
|
|
21
21
|
/** @stability external */
|
|
22
22
|
export class Foo1 { }
|
|
23
23
|
`, `
|
|
@@ -29,8 +29,8 @@ test('external stability violations are reported as warnings', async () => {
|
|
|
29
29
|
expect(diagnostics_1.hasErrors(diags)).toBeFalsy();
|
|
30
30
|
});
|
|
31
31
|
// ----------------------------------------------------------------------
|
|
32
|
-
test('warnings can be turned into errors',
|
|
33
|
-
const mms =
|
|
32
|
+
test('warnings can be turned into errors', () => {
|
|
33
|
+
const mms = util_1.compare(`
|
|
34
34
|
/** @experimental */
|
|
35
35
|
export class Foo1 { }
|
|
36
36
|
`, `
|
|
@@ -42,8 +42,8 @@ test('warnings can be turned into errors', async () => {
|
|
|
42
42
|
expect(diagnostics_1.hasErrors(diags)).toBeTruthy();
|
|
43
43
|
});
|
|
44
44
|
// ----------------------------------------------------------------------
|
|
45
|
-
test('external stability violations are never turned into errors',
|
|
46
|
-
const mms =
|
|
45
|
+
test('external stability violations are never turned into errors', () => {
|
|
46
|
+
const mms = util_1.compare(`
|
|
47
47
|
/** @stability external */
|
|
48
48
|
export class Foo1 { }
|
|
49
49
|
`, `
|
|
@@ -55,8 +55,8 @@ test('external stability violations are never turned into errors', async () => {
|
|
|
55
55
|
expect(diagnostics_1.hasErrors(diags)).toBeFalsy();
|
|
56
56
|
});
|
|
57
57
|
// ----------------------------------------------------------------------
|
|
58
|
-
test('errors can be skipped',
|
|
59
|
-
const mms =
|
|
58
|
+
test('errors can be skipped', () => {
|
|
59
|
+
const mms = util_1.compare(`
|
|
60
60
|
export class Foo1 { }
|
|
61
61
|
`, `
|
|
62
62
|
export class Foo2 { }
|
|
@@ -67,8 +67,8 @@ test('errors can be skipped', async () => {
|
|
|
67
67
|
expect(diagnostics_1.hasErrors(diags)).toBeFalsy();
|
|
68
68
|
});
|
|
69
69
|
// ----------------------------------------------------------------------
|
|
70
|
-
test('changing stable to experimental is breaking',
|
|
71
|
-
const mms =
|
|
70
|
+
test('changing stable to experimental is breaking', () => {
|
|
71
|
+
const mms = util_1.compare(`
|
|
72
72
|
/** @stable */
|
|
73
73
|
export class Foo1 { }
|
|
74
74
|
`, `
|
|
@@ -82,8 +82,8 @@ test('changing stable to experimental is breaking', async () => {
|
|
|
82
82
|
expect(diagnostics_1.hasErrors(diags)).toBeTruthy();
|
|
83
83
|
});
|
|
84
84
|
// ----------------------------------------------------------------------
|
|
85
|
-
test('can make fields optional in output struct if it is marked @external',
|
|
86
|
-
const mms =
|
|
85
|
+
test('can make fields optional in output struct if it is marked @external', () => {
|
|
86
|
+
const mms = util_1.compare(`
|
|
87
87
|
/** @stability external */
|
|
88
88
|
export interface TheStruct {
|
|
89
89
|
readonly fieldOne: string;
|
|
@@ -107,4 +107,4 @@ test('can make fields optional in output struct if it is marked @external', asyn
|
|
|
107
107
|
expect(diags.length).toBe(1);
|
|
108
108
|
expect(diagnostics_1.hasErrors(diags)).toBeFalsy();
|
|
109
109
|
});
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"diagnostics.test.js","sourceRoot":"","sources":["diagnostics.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { classifyDiagnostics, hasErrors } from '../lib/diagnostics';\nimport { compare } from './util';\n\n// ----------------------------------------------------------------------\ntest('experimental elements lead to warnings', () => {\n  const mms = compare(\n    `\n    /** @experimental */\n    export class Foo1 { }\n  `,\n    `\n    export class Foo2 { }\n  `,\n  );\n\n  const experimentalErrors = false;\n  const diags = classifyDiagnostics(mms, experimentalErrors, new Set());\n\n  expect(diags.length).toBe(1);\n  expect(hasErrors(diags)).toBeFalsy();\n});\n\n// ----------------------------------------------------------------------\ntest('external stability violations are reported as warnings', () => {\n  const mms = compare(\n    `\n    /** @stability external */\n    export class Foo1 { }\n  `,\n    `\n    export class Foo2 { }\n  `,\n  );\n\n  const experimentalErrors = false;\n  const diags = classifyDiagnostics(mms, experimentalErrors, new Set());\n\n  expect(diags.length).toBe(1);\n  expect(hasErrors(diags)).toBeFalsy();\n});\n\n// ----------------------------------------------------------------------\ntest('warnings can be turned into errors', () => {\n  const mms = compare(\n    `\n    /** @experimental */\n    export class Foo1 { }\n  `,\n    `\n    export class Foo2 { }\n  `,\n  );\n\n  const experimentalErrors = true;\n  const diags = classifyDiagnostics(mms, experimentalErrors, new Set());\n\n  expect(diags.length).toBe(1);\n  expect(hasErrors(diags)).toBeTruthy();\n});\n\n// ----------------------------------------------------------------------\ntest('external stability violations are never turned into errors', () => {\n  const mms = compare(\n    `\n    /** @stability external */\n    export class Foo1 { }\n  `,\n    `\n    export class Foo2 { }\n  `,\n  );\n\n  const experimentalErrors = true;\n  const diags = classifyDiagnostics(mms, experimentalErrors, new Set());\n\n  expect(diags.length).toBe(1);\n  expect(hasErrors(diags)).toBeFalsy();\n});\n\n// ----------------------------------------------------------------------\ntest('errors can be skipped', () => {\n  const mms = compare(\n    `\n    export class Foo1 { }\n  `,\n    `\n    export class Foo2 { }\n  `,\n  );\n\n  const experimentalErrors = true;\n  const diags = classifyDiagnostics(\n    mms,\n    experimentalErrors,\n    new Set([mms.mismatches[0].violationKey]),\n  );\n\n  expect(diags.length).toBe(1);\n  expect(hasErrors(diags)).toBeFalsy();\n});\n\n// ----------------------------------------------------------------------\ntest('changing stable to experimental is breaking', () => {\n  const mms = compare(\n    `\n    /** @stable */\n    export class Foo1 { }\n  `,\n    `\n    /** @experimental */\n    export class Foo1 { }\n  `,\n  );\n\n  const experimentalErrors = false;\n  const diags = classifyDiagnostics(mms, experimentalErrors, new Set());\n\n  expect(diags.length).toBeGreaterThan(0);\n  expect(\n    diags.some((d) =>\n      /stability not allowed to go from 'stable' to 'experimental'/.exec(\n        d.message,\n      ),\n    ),\n  ).toBeTruthy();\n  expect(hasErrors(diags)).toBeTruthy();\n});\n\n// ----------------------------------------------------------------------\n\ntest('can make fields optional in output struct if it is marked @external', () => {\n  const mms = compare(\n    `\n    /** @stability external */\n    export interface TheStruct {\n      readonly fieldOne: string;\n    }\n\n    export interface IConsumer {\n      foo(): TheStruct;\n    }\n    `,\n    `\n    /** @stability external */\n    export interface TheStruct {\n      readonly fieldOne?: string;\n    }\n\n    export interface IConsumer {\n      foo(): TheStruct;\n    }\n    `,\n  );\n\n  const experimentalErrors = true;\n  const diags = classifyDiagnostics(mms, experimentalErrors, new Set());\n\n  expect(diags.length).toBe(1);\n  expect(hasErrors(diags)).toBeFalsy();\n});\n"]}
|
package/test/util.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { Mismatches } from '../lib/types';
|
|
2
|
-
export declare function expectNoError(original: string, updated: string):
|
|
3
|
-
export declare function expectError(error: RegExp | undefined, original: string, updated: string):
|
|
4
|
-
export declare function compare(original: string, updated: string):
|
|
2
|
+
export declare function expectNoError(original: string, updated: string): void;
|
|
3
|
+
export declare function expectError(error: RegExp | undefined, original: string, updated: string): void;
|
|
4
|
+
export declare function compare(original: string, updated: string): Mismatches;
|
package/test/util.js
CHANGED
|
@@ -4,20 +4,20 @@ exports.compare = exports.expectError = exports.expectNoError = void 0;
|
|
|
4
4
|
const jsii_1 = require("jsii");
|
|
5
5
|
const reflect = require("jsii-reflect");
|
|
6
6
|
const lib_1 = require("../lib");
|
|
7
|
-
|
|
8
|
-
const mms =
|
|
7
|
+
function expectNoError(original, updated) {
|
|
8
|
+
const mms = compare(original, updated);
|
|
9
9
|
for (const msg of mms.messages()) {
|
|
10
10
|
console.error(`- ${msg}`);
|
|
11
11
|
}
|
|
12
12
|
expect(mms.count).toBe(0);
|
|
13
13
|
}
|
|
14
14
|
exports.expectNoError = expectNoError;
|
|
15
|
-
|
|
15
|
+
function expectError(error, original, updated) {
|
|
16
16
|
if (error == null) {
|
|
17
|
-
|
|
17
|
+
expectNoError(original, updated);
|
|
18
18
|
return;
|
|
19
19
|
}
|
|
20
|
-
const mms =
|
|
20
|
+
const mms = compare(original, updated);
|
|
21
21
|
expect(mms.count).not.toBe(0);
|
|
22
22
|
const msgs = Array.from(mms.messages());
|
|
23
23
|
if (!msgs.some((m) => error.test(m))) {
|
|
@@ -25,16 +25,14 @@ async function expectError(error, original, updated) {
|
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
27
|
exports.expectError = expectError;
|
|
28
|
-
|
|
28
|
+
function compare(original, updated) {
|
|
29
29
|
const ass1 = jsii_1.sourceToAssemblyHelper(original);
|
|
30
|
-
await expect(ass1).resolves.not.toThrowError();
|
|
31
30
|
const ts1 = new reflect.TypeSystem();
|
|
32
|
-
const originalAssembly = ts1.addAssembly(new reflect.Assembly(ts1,
|
|
31
|
+
const originalAssembly = ts1.addAssembly(new reflect.Assembly(ts1, ass1));
|
|
33
32
|
const ass2 = jsii_1.sourceToAssemblyHelper(updated);
|
|
34
|
-
await expect(ass2).resolves.not.toThrowError();
|
|
35
33
|
const ts2 = new reflect.TypeSystem();
|
|
36
|
-
const updatedAssembly = ts2.addAssembly(new reflect.Assembly(ts2,
|
|
34
|
+
const updatedAssembly = ts2.addAssembly(new reflect.Assembly(ts2, ass2));
|
|
37
35
|
return lib_1.compareAssemblies(originalAssembly, updatedAssembly);
|
|
38
36
|
}
|
|
39
37
|
exports.compare = compare;
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0JBQThDO0FBQzlDLHdDQUF3QztBQUV4QyxnQ0FBMkM7QUFHM0MsU0FBZ0IsYUFBYSxDQUFDLFFBQWdCLEVBQUUsT0FBZTtJQUM3RCxNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3ZDLEtBQUssTUFBTSxHQUFHLElBQUksR0FBRyxDQUFDLFFBQVEsRUFBRSxFQUFFO1FBQ2hDLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxDQUFDO0tBQzNCO0lBQ0QsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDNUIsQ0FBQztBQU5ELHNDQU1DO0FBRUQsU0FBZ0IsV0FBVyxDQUN6QixLQUF5QixFQUN6QixRQUFnQixFQUNoQixPQUFlO0lBRWYsSUFBSSxLQUFLLElBQUksSUFBSSxFQUFFO1FBQ2pCLGFBQWEsQ0FBQyxRQUFRLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDakMsT0FBTztLQUNSO0lBRUQsTUFBTSxHQUFHLEdBQUcsT0FBTyxDQUFDLFFBQVEsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUN2QyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFOUIsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztJQUV4QyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFO1FBQ3BDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0tBQ3ZDO0FBQ0gsQ0FBQztBQWxCRCxrQ0FrQkM7QUFFRCxTQUFnQixPQUFPLENBQUMsUUFBZ0IsRUFBRSxPQUFlO0lBQ3ZELE1BQU0sSUFBSSxHQUFHLDZCQUFzQixDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzlDLE1BQU0sR0FBRyxHQUFHLElBQUksT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3JDLE1BQU0sZ0JBQWdCLEdBQUcsR0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7SUFFMUUsTUFBTSxJQUFJLEdBQUcsNkJBQXNCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0MsTUFBTSxHQUFHLEdBQUcsSUFBSSxPQUFPLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDckMsTUFBTSxlQUFlLEdBQUcsR0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7SUFFekUsT0FBTyx1QkFBaUIsQ0FBQyxnQkFBZ0IsRUFBRSxlQUFlLENBQUMsQ0FBQztBQUM5RCxDQUFDO0FBVkQsMEJBVUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzb3VyY2VUb0Fzc2VtYmx5SGVscGVyIH0gZnJvbSAnanNpaSc7XG5pbXBvcnQgKiBhcyByZWZsZWN0IGZyb20gJ2pzaWktcmVmbGVjdCc7XG5cbmltcG9ydCB7IGNvbXBhcmVBc3NlbWJsaWVzIH0gZnJvbSAnLi4vbGliJztcbmltcG9ydCB7IE1pc21hdGNoZXMgfSBmcm9tICcuLi9saWIvdHlwZXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZXhwZWN0Tm9FcnJvcihvcmlnaW5hbDogc3RyaW5nLCB1cGRhdGVkOiBzdHJpbmcpIHtcbiAgY29uc3QgbW1zID0gY29tcGFyZShvcmlnaW5hbCwgdXBkYXRlZCk7XG4gIGZvciAoY29uc3QgbXNnIG9mIG1tcy5tZXNzYWdlcygpKSB7XG4gICAgY29uc29sZS5lcnJvcihgLSAke21zZ31gKTtcbiAgfVxuICBleHBlY3QobW1zLmNvdW50KS50b0JlKDApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZXhwZWN0RXJyb3IoXG4gIGVycm9yOiBSZWdFeHAgfCB1bmRlZmluZWQsXG4gIG9yaWdpbmFsOiBzdHJpbmcsXG4gIHVwZGF0ZWQ6IHN0cmluZyxcbikge1xuICBpZiAoZXJyb3IgPT0gbnVsbCkge1xuICAgIGV4cGVjdE5vRXJyb3Iob3JpZ2luYWwsIHVwZGF0ZWQpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IG1tcyA9IGNvbXBhcmUob3JpZ2luYWwsIHVwZGF0ZWQpO1xuICBleHBlY3QobW1zLmNvdW50KS5ub3QudG9CZSgwKTtcblxuICBjb25zdCBtc2dzID0gQXJyYXkuZnJvbShtbXMubWVzc2FnZXMoKSk7XG5cbiAgaWYgKCFtc2dzLnNvbWUoKG0pID0+IGVycm9yLnRlc3QobSkpKSB7XG4gICAgZXhwZWN0KG1zZ3Muam9pbignLCcpKS50b01hdGNoKGVycm9yKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gY29tcGFyZShvcmlnaW5hbDogc3RyaW5nLCB1cGRhdGVkOiBzdHJpbmcpOiBNaXNtYXRjaGVzIHtcbiAgY29uc3QgYXNzMSA9IHNvdXJjZVRvQXNzZW1ibHlIZWxwZXIob3JpZ2luYWwpO1xuICBjb25zdCB0czEgPSBuZXcgcmVmbGVjdC5UeXBlU3lzdGVtKCk7XG4gIGNvbnN0IG9yaWdpbmFsQXNzZW1ibHkgPSB0czEuYWRkQXNzZW1ibHkobmV3IHJlZmxlY3QuQXNzZW1ibHkodHMxLCBhc3MxKSk7XG5cbiAgY29uc3QgYXNzMiA9IHNvdXJjZVRvQXNzZW1ibHlIZWxwZXIodXBkYXRlZCk7XG4gIGNvbnN0IHRzMiA9IG5ldyByZWZsZWN0LlR5cGVTeXN0ZW0oKTtcbiAgY29uc3QgdXBkYXRlZEFzc2VtYmx5ID0gdHMyLmFkZEFzc2VtYmx5KG5ldyByZWZsZWN0LkFzc2VtYmx5KHRzMiwgYXNzMikpO1xuXG4gIHJldHVybiBjb21wYXJlQXNzZW1ibGllcyhvcmlnaW5hbEFzc2VtYmx5LCB1cGRhdGVkQXNzZW1ibHkpO1xufVxuIl19
|