@jayf0x/fluidity-js 0.1.4 → 0.1.6
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/README.md +22 -14
- package/dist/globals.d.ts +16 -3
- package/dist/index.js +536 -498
- package/package.json +4 -1
package/dist/index.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
if (!
|
|
5
|
-
throw TypeError("Cannot " +
|
|
1
|
+
var $I = Object.defineProperty;
|
|
2
|
+
var Ig = (C, I, i) => I in C ? $I(C, I, { enumerable: !0, configurable: !0, writable: !0, value: i }) : C[I] = i;
|
|
3
|
+
var yI = (C, I, i) => (Ig(C, typeof I != "symbol" ? I + "" : I, i), i), UI = (C, I, i) => {
|
|
4
|
+
if (!I.has(C))
|
|
5
|
+
throw TypeError("Cannot " + i);
|
|
6
6
|
};
|
|
7
|
-
var
|
|
8
|
-
if (
|
|
7
|
+
var g = (C, I, i) => (UI(C, I, "read from private field"), i ? i.call(C) : I.get(C)), m = (C, I, i) => {
|
|
8
|
+
if (I.has(C))
|
|
9
9
|
throw TypeError("Cannot add the same private member more than once");
|
|
10
|
-
|
|
11
|
-
},
|
|
12
|
-
var
|
|
13
|
-
import { jsx as
|
|
14
|
-
import { useRef as
|
|
15
|
-
const
|
|
10
|
+
I instanceof WeakSet ? I.add(C) : I.set(C, i);
|
|
11
|
+
}, l = (C, I, i, e) => (UI(C, I, "write to private field"), e ? e.call(C, i) : I.set(C, i), i);
|
|
12
|
+
var b = (C, I, i) => (UI(C, I, "access private method"), i);
|
|
13
|
+
import { jsx as NI } from "react/jsx-runtime";
|
|
14
|
+
import { useRef as mI, useEffect as j, forwardRef as zI, useImperativeHandle as QI } from "react";
|
|
15
|
+
const OI = {
|
|
16
16
|
densityDissipation: 0.992,
|
|
17
17
|
velocityDissipation: 0.93,
|
|
18
18
|
pressureIterations: 1,
|
|
@@ -26,8 +26,8 @@ const Mg = {
|
|
|
26
26
|
glowColor: [0.7, 0.85, 1],
|
|
27
27
|
algorithm: "standard",
|
|
28
28
|
warpStrength: 0.015
|
|
29
|
-
},
|
|
30
|
-
...
|
|
29
|
+
}, TI = {
|
|
30
|
+
...OI,
|
|
31
31
|
densityDissipation: 0.99,
|
|
32
32
|
velocityDissipation: 0.98,
|
|
33
33
|
pressureIterations: 3,
|
|
@@ -38,22 +38,23 @@ const Mg = {
|
|
|
38
38
|
specularExp: 1,
|
|
39
39
|
shine: 0.1,
|
|
40
40
|
glowColor: [0, 0.502, 1]
|
|
41
|
-
},
|
|
41
|
+
}, gg = { dpr: 1, sim: 0.5 }, HI = {
|
|
42
42
|
backgroundColor: "#0a0a0a",
|
|
43
43
|
backgroundSize: "cover",
|
|
44
44
|
isMouseEnabled: !0,
|
|
45
|
-
isWorkerEnabled: !0
|
|
46
|
-
|
|
47
|
-
|
|
45
|
+
isWorkerEnabled: !0,
|
|
46
|
+
quality: gg
|
|
47
|
+
}, iI = {
|
|
48
|
+
...HI,
|
|
48
49
|
effect: 0,
|
|
49
50
|
imageSize: "cover"
|
|
50
|
-
},
|
|
51
|
-
...
|
|
51
|
+
}, $ = {
|
|
52
|
+
...HI,
|
|
52
53
|
fontSize: 100,
|
|
53
54
|
color: "#ffffff",
|
|
54
55
|
fontFamily: "sans-serif",
|
|
55
56
|
fontWeight: 900
|
|
56
|
-
},
|
|
57
|
+
}, ig = {
|
|
57
58
|
calm: {
|
|
58
59
|
densityDissipation: 0.999,
|
|
59
60
|
velocityDissipation: 0.98,
|
|
@@ -65,17 +66,17 @@ const Mg = {
|
|
|
65
66
|
glowColor: [0.6, 0.85, 1],
|
|
66
67
|
waterColor: [0, 0.02, 0.05]
|
|
67
68
|
},
|
|
68
|
-
|
|
69
|
-
densityDissipation: 0.
|
|
70
|
-
velocityDissipation: 0.
|
|
71
|
-
curl:
|
|
72
|
-
splatRadius: 0.
|
|
73
|
-
splatForce:
|
|
74
|
-
refraction: 0.
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
69
|
+
sand: {
|
|
70
|
+
densityDissipation: 0.997,
|
|
71
|
+
velocityDissipation: 0.98,
|
|
72
|
+
curl: 1,
|
|
73
|
+
splatRadius: 0.01,
|
|
74
|
+
splatForce: 0.9,
|
|
75
|
+
refraction: 0.8,
|
|
76
|
+
specularExp: 0.1,
|
|
77
|
+
shine: 0.05,
|
|
78
|
+
glowColor: [0.027, 0.027, 0.027],
|
|
79
|
+
waterColor: [0.451, 0.329, 0.125]
|
|
79
80
|
},
|
|
80
81
|
wave: {
|
|
81
82
|
densityDissipation: 0.994,
|
|
@@ -85,7 +86,6 @@ const Mg = {
|
|
|
85
86
|
splatForce: 1.2,
|
|
86
87
|
refraction: 0.35,
|
|
87
88
|
shine: 0.03,
|
|
88
|
-
pressureIterations: 5,
|
|
89
89
|
glowColor: [0.5, 0.8, 1],
|
|
90
90
|
waterColor: [0, 0.01, 0.03]
|
|
91
91
|
},
|
|
@@ -113,73 +113,73 @@ const Mg = {
|
|
|
113
113
|
waterColor: [0.06, 0.06, 0.06]
|
|
114
114
|
}
|
|
115
115
|
};
|
|
116
|
-
function
|
|
117
|
-
return { ...
|
|
116
|
+
function pI(C = {}, I, i = OI) {
|
|
117
|
+
return { ...I ? { ...i, ...ig[I] } : i, ...C };
|
|
118
118
|
}
|
|
119
|
-
function
|
|
120
|
-
let
|
|
121
|
-
|
|
122
|
-
const
|
|
123
|
-
return { x: (
|
|
119
|
+
function vI(C, I, i, e, s = "cover") {
|
|
120
|
+
let o;
|
|
121
|
+
s === "cover" ? o = Math.max(i / C, e / I) : s === "contain" ? o = Math.min(i / C, e / I) : typeof s == "string" && s.endsWith("%") ? o = Math.min(i / C, e / I) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? o = parseFloat(s) / Math.max(C, I) : typeof s == "number" ? o = s : o = Math.max(i / C, e / I);
|
|
122
|
+
const t = C * o, u = I * o;
|
|
123
|
+
return { x: (i - t) / 2, y: (e - u) / 2, drawW: t, drawH: u };
|
|
124
124
|
}
|
|
125
|
-
function
|
|
126
|
-
const { text:
|
|
127
|
-
((
|
|
128
|
-
if (
|
|
129
|
-
|
|
130
|
-
const { x:
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
125
|
+
function Cg(C, I, i, e, s = null, o = "cover") {
|
|
126
|
+
const { text: t, fontSize: u, color: a, fontFamily: c = "sans-serif", fontWeight: n = 900 } = e, G = new OffscreenCanvas(I, i), d = G.getContext("2d");
|
|
127
|
+
((F) => {
|
|
128
|
+
if (s) {
|
|
129
|
+
d.clearRect(0, 0, I, i), d.fillStyle = "black", d.fillRect(0, 0, I, i);
|
|
130
|
+
const { x: w, y: D, drawW: A, drawH: y } = vI(
|
|
131
|
+
s.width,
|
|
132
|
+
s.height,
|
|
133
|
+
I,
|
|
134
|
+
i,
|
|
135
|
+
o
|
|
136
136
|
);
|
|
137
|
-
|
|
137
|
+
d.drawImage(s, w, D, A, y);
|
|
138
138
|
} else
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
})(
|
|
142
|
-
const
|
|
143
|
-
|
|
144
|
-
const
|
|
145
|
-
return { backgroundTex:
|
|
139
|
+
d.fillStyle = "black", d.fillRect(0, 0, I, i);
|
|
140
|
+
d.fillStyle = F, d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
|
|
141
|
+
})(a);
|
|
142
|
+
const W = BI(C, G);
|
|
143
|
+
d.fillStyle = "black", d.fillRect(0, 0, I, i), d.fillStyle = "white", d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
|
|
144
|
+
const x = BI(C, G);
|
|
145
|
+
return { backgroundTex: W, obstacleTex: x, coverageTex: x };
|
|
146
146
|
}
|
|
147
|
-
function
|
|
148
|
-
const
|
|
149
|
-
if (
|
|
147
|
+
function eg(C, I, i, e, s = 0, o = "cover", t = null, u = "cover") {
|
|
148
|
+
const a = new OffscreenCanvas(i, e), c = a.getContext("2d"), { x: n, y: G, drawW: d, drawH: h } = vI(I.width, I.height, i, e, o);
|
|
149
|
+
if (c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), t) {
|
|
150
150
|
const {
|
|
151
|
-
x:
|
|
152
|
-
y:
|
|
153
|
-
drawW:
|
|
154
|
-
drawH:
|
|
155
|
-
} =
|
|
156
|
-
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
const
|
|
160
|
-
|
|
161
|
-
const
|
|
162
|
-
|
|
163
|
-
Math.max(0,
|
|
164
|
-
Math.max(0,
|
|
165
|
-
Math.min(
|
|
166
|
-
Math.min(
|
|
151
|
+
x: w,
|
|
152
|
+
y: D,
|
|
153
|
+
drawW: A,
|
|
154
|
+
drawH: y
|
|
155
|
+
} = vI(t.width, t.height, i, e, u);
|
|
156
|
+
c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, w, D, A, y), c.filter = "none";
|
|
157
|
+
}
|
|
158
|
+
c.drawImage(I, n, G, d, h);
|
|
159
|
+
const W = BI(C, a);
|
|
160
|
+
c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(I, n, G, d, h), c.filter = "none";
|
|
161
|
+
const x = BI(C, a);
|
|
162
|
+
c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.fillStyle = "white", c.fillRect(
|
|
163
|
+
Math.max(0, n),
|
|
164
|
+
Math.max(0, G),
|
|
165
|
+
Math.min(d, i - Math.max(0, n)),
|
|
166
|
+
Math.min(h, e - Math.max(0, G))
|
|
167
167
|
);
|
|
168
|
-
const
|
|
169
|
-
return { backgroundTex:
|
|
168
|
+
const F = BI(C, a);
|
|
169
|
+
return { backgroundTex: W, obstacleTex: x, coverageTex: F };
|
|
170
170
|
}
|
|
171
|
-
function
|
|
172
|
-
const
|
|
173
|
-
return
|
|
171
|
+
function BI(C, I) {
|
|
172
|
+
const i = C.createTexture();
|
|
173
|
+
return C.bindTexture(C.TEXTURE_2D, i), C.pixelStorei(C.UNPACK_FLIP_Y_WEBGL, !0), C.texImage2D(C.TEXTURE_2D, 0, C.RGBA, C.RGBA, C.UNSIGNED_BYTE, I), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), i;
|
|
174
174
|
}
|
|
175
|
-
async function
|
|
176
|
-
const
|
|
177
|
-
if (!
|
|
178
|
-
throw new Error(`Failed to fetch image: ${
|
|
179
|
-
const
|
|
180
|
-
return createImageBitmap(
|
|
175
|
+
async function kI(C) {
|
|
176
|
+
const I = await fetch(C);
|
|
177
|
+
if (!I.ok)
|
|
178
|
+
throw new Error(`Failed to fetch image: ${C} (${I.status})`);
|
|
179
|
+
const i = await I.blob();
|
|
180
|
+
return createImageBitmap(i);
|
|
181
181
|
}
|
|
182
|
-
const
|
|
182
|
+
const II = (
|
|
183
183
|
/* glsl */
|
|
184
184
|
`
|
|
185
185
|
precision highp float;
|
|
@@ -196,7 +196,7 @@ const P = (
|
|
|
196
196
|
gl_Position = vec4(aPosition, 0.0, 1.0);
|
|
197
197
|
}
|
|
198
198
|
`
|
|
199
|
-
),
|
|
199
|
+
), sg = (
|
|
200
200
|
/* glsl */
|
|
201
201
|
`
|
|
202
202
|
precision highp float;
|
|
@@ -213,7 +213,7 @@ const P = (
|
|
|
213
213
|
gl_FragColor = dissipation * texture2D(uSource, coord);
|
|
214
214
|
}
|
|
215
215
|
`
|
|
216
|
-
),
|
|
216
|
+
), lg = (
|
|
217
217
|
/* glsl */
|
|
218
218
|
`
|
|
219
219
|
precision highp float;
|
|
@@ -228,7 +228,7 @@ const P = (
|
|
|
228
228
|
gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
|
|
229
229
|
}
|
|
230
230
|
`
|
|
231
|
-
),
|
|
231
|
+
), og = (
|
|
232
232
|
/* glsl */
|
|
233
233
|
`
|
|
234
234
|
precision highp float;
|
|
@@ -246,7 +246,7 @@ const P = (
|
|
|
246
246
|
gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
|
|
247
247
|
}
|
|
248
248
|
`
|
|
249
|
-
),
|
|
249
|
+
), tg = (
|
|
250
250
|
/* glsl */
|
|
251
251
|
`
|
|
252
252
|
precision highp float;
|
|
@@ -264,7 +264,7 @@ const P = (
|
|
|
264
264
|
gl_FragColor = vec4(vel, 0.0, 1.0);
|
|
265
265
|
}
|
|
266
266
|
`
|
|
267
|
-
),
|
|
267
|
+
), cg = (
|
|
268
268
|
/* glsl */
|
|
269
269
|
`
|
|
270
270
|
precision highp float;
|
|
@@ -281,7 +281,7 @@ const P = (
|
|
|
281
281
|
gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
|
|
282
282
|
}
|
|
283
283
|
`
|
|
284
|
-
),
|
|
284
|
+
), ag = (
|
|
285
285
|
/* glsl */
|
|
286
286
|
`
|
|
287
287
|
precision highp float;
|
|
@@ -295,7 +295,7 @@ const P = (
|
|
|
295
295
|
gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
|
|
296
296
|
}
|
|
297
297
|
`
|
|
298
|
-
),
|
|
298
|
+
), dg = (
|
|
299
299
|
/* glsl */
|
|
300
300
|
`
|
|
301
301
|
precision highp float;
|
|
@@ -316,7 +316,7 @@ const P = (
|
|
|
316
316
|
gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
|
|
317
317
|
}
|
|
318
318
|
`
|
|
319
|
-
),
|
|
319
|
+
), Ag = (
|
|
320
320
|
/* glsl */
|
|
321
321
|
`
|
|
322
322
|
precision highp float;
|
|
@@ -338,8 +338,9 @@ const P = (
|
|
|
338
338
|
uniform int uAlgorithm;
|
|
339
339
|
|
|
340
340
|
void main () {
|
|
341
|
-
float density = max(texture2D(uTexture, vUv).r, 0.0);
|
|
342
341
|
float obs = texture2D(uObstacle, vUv).r;
|
|
342
|
+
// Mask density inside obstacles so splats don't flicker the text/image content.
|
|
343
|
+
float density = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
|
|
343
344
|
float coverage = texture2D(uCoverage, vUv).r;
|
|
344
345
|
|
|
345
346
|
float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
|
|
@@ -416,37 +417,37 @@ const P = (
|
|
|
416
417
|
}
|
|
417
418
|
`
|
|
418
419
|
);
|
|
419
|
-
function
|
|
420
|
-
const
|
|
421
|
-
let
|
|
422
|
-
const e = !!
|
|
423
|
-
e || (
|
|
424
|
-
const
|
|
425
|
-
return
|
|
426
|
-
gl:
|
|
420
|
+
function mg(C) {
|
|
421
|
+
const I = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
|
|
422
|
+
let i = C.getContext("webgl2", I);
|
|
423
|
+
const e = !!i;
|
|
424
|
+
e || (i = C.getContext("webgl", I), i.getExtension("EXT_color_buffer_half_float"));
|
|
425
|
+
const s = e ? null : i.getExtension("OES_texture_half_float"), o = e ? i.HALF_FLOAT : s.HALF_FLOAT_OES;
|
|
426
|
+
return i.getExtension("EXT_color_buffer_float"), i.getExtension("OES_texture_half_float_linear"), {
|
|
427
|
+
gl: i,
|
|
427
428
|
isWebGL2: e,
|
|
428
429
|
ext: {
|
|
429
|
-
internalFormat: e ?
|
|
430
|
-
format:
|
|
431
|
-
type:
|
|
430
|
+
internalFormat: e ? i.RGBA16F : i.RGBA,
|
|
431
|
+
format: i.RGBA,
|
|
432
|
+
type: o
|
|
432
433
|
}
|
|
433
434
|
};
|
|
434
435
|
}
|
|
435
|
-
class
|
|
436
|
-
constructor(
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
this._gl =
|
|
441
|
-
const
|
|
442
|
-
for (let
|
|
443
|
-
const
|
|
444
|
-
this.uniforms[
|
|
436
|
+
class gI {
|
|
437
|
+
constructor(I, i, e) {
|
|
438
|
+
yI(this, "program");
|
|
439
|
+
yI(this, "uniforms", {});
|
|
440
|
+
yI(this, "_gl");
|
|
441
|
+
this._gl = I, this.program = I.createProgram(), I.attachShader(this.program, this._compile(I.VERTEX_SHADER, i)), I.attachShader(this.program, this._compile(I.FRAGMENT_SHADER, e)), I.linkProgram(this.program);
|
|
442
|
+
const s = I.getProgramParameter(this.program, I.ACTIVE_UNIFORMS);
|
|
443
|
+
for (let o = 0; o < s; o++) {
|
|
444
|
+
const t = I.getActiveUniform(this.program, o).name;
|
|
445
|
+
this.uniforms[t] = I.getUniformLocation(this.program, t);
|
|
445
446
|
}
|
|
446
447
|
}
|
|
447
|
-
_compile(
|
|
448
|
-
const e = this._gl,
|
|
449
|
-
return e.shaderSource(
|
|
448
|
+
_compile(I, i) {
|
|
449
|
+
const e = this._gl, s = e.createShader(I);
|
|
450
|
+
return e.shaderSource(s, i), e.compileShader(s), s;
|
|
450
451
|
}
|
|
451
452
|
bind() {
|
|
452
453
|
this._gl.useProgram(this.program);
|
|
@@ -455,112 +456,119 @@ class _ {
|
|
|
455
456
|
this._gl.deleteProgram(this.program);
|
|
456
457
|
}
|
|
457
458
|
}
|
|
458
|
-
function
|
|
459
|
+
function rg(C) {
|
|
459
460
|
return {
|
|
460
|
-
advection: new
|
|
461
|
-
divergence: new
|
|
462
|
-
pressure: new
|
|
463
|
-
gradientSubtract: new
|
|
464
|
-
splat: new
|
|
465
|
-
curl: new
|
|
466
|
-
vorticity: new
|
|
467
|
-
display: new
|
|
461
|
+
advection: new gI(C, II, sg),
|
|
462
|
+
divergence: new gI(C, II, lg),
|
|
463
|
+
pressure: new gI(C, II, og),
|
|
464
|
+
gradientSubtract: new gI(C, II, tg),
|
|
465
|
+
splat: new gI(C, II, cg),
|
|
466
|
+
curl: new gI(C, II, ag),
|
|
467
|
+
vorticity: new gI(C, II, dg),
|
|
468
|
+
display: new gI(C, II, Ag)
|
|
468
469
|
};
|
|
469
470
|
}
|
|
470
|
-
function
|
|
471
|
-
|
|
472
|
-
const
|
|
473
|
-
|
|
474
|
-
const
|
|
475
|
-
return
|
|
471
|
+
function KI(C, I, i, e) {
|
|
472
|
+
C.activeTexture(C.TEXTURE0);
|
|
473
|
+
const s = C.createTexture();
|
|
474
|
+
C.bindTexture(C.TEXTURE_2D, s), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), C.texImage2D(C.TEXTURE_2D, 0, I.internalFormat, i, e, 0, I.format, I.type, null);
|
|
475
|
+
const o = C.createFramebuffer();
|
|
476
|
+
return C.bindFramebuffer(C.FRAMEBUFFER, o), C.framebufferTexture2D(C.FRAMEBUFFER, C.COLOR_ATTACHMENT0, C.TEXTURE_2D, s, 0), { tex: s, fbo: o, width: i, height: e };
|
|
476
477
|
}
|
|
477
|
-
function
|
|
478
|
-
let
|
|
478
|
+
function WI(C, I, i, e) {
|
|
479
|
+
let s = KI(C, I, i, e), o = KI(C, I, i, e);
|
|
479
480
|
return {
|
|
480
481
|
get read() {
|
|
481
|
-
return
|
|
482
|
+
return s;
|
|
482
483
|
},
|
|
483
484
|
get write() {
|
|
484
|
-
return
|
|
485
|
+
return o;
|
|
485
486
|
},
|
|
486
487
|
swap() {
|
|
487
|
-
[
|
|
488
|
+
[s, o] = [o, s];
|
|
488
489
|
},
|
|
489
490
|
dispose() {
|
|
490
|
-
|
|
491
|
+
C.deleteTexture(s.tex), C.deleteFramebuffer(s.fbo), C.deleteTexture(o.tex), C.deleteFramebuffer(o.fbo);
|
|
491
492
|
}
|
|
492
493
|
};
|
|
493
494
|
}
|
|
494
|
-
function
|
|
495
|
-
const
|
|
496
|
-
return
|
|
497
|
-
|
|
495
|
+
function ng(C) {
|
|
496
|
+
const I = C.createBuffer();
|
|
497
|
+
return C.bindBuffer(C.ARRAY_BUFFER, I), C.bufferData(C.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), C.STATIC_DRAW), C.vertexAttribPointer(0, 2, C.FLOAT, !1, 0, 0), C.enableVertexAttribArray(0), function(e) {
|
|
498
|
+
C.bindFramebuffer(C.FRAMEBUFFER, e), C.drawArrays(C.TRIANGLE_FAN, 0, 4);
|
|
498
499
|
};
|
|
499
500
|
}
|
|
500
|
-
const
|
|
501
|
-
var
|
|
502
|
-
class
|
|
503
|
-
constructor(
|
|
501
|
+
const xI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (C) => setTimeout(C, 1e3 / 60), ug = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, MI = 0.016, Zg = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
|
|
502
|
+
var lI, X, SI, oI, rI, K, R, CI, eI, k, nI, P, H, B, E, J, N, _, v, z, f, uI, tI, L, Y, Q, cI, bI, aI, GI, LI, YI, sI, AI, dI, hI, VI, FI, wI, DI, RI, jI;
|
|
503
|
+
class EI {
|
|
504
|
+
constructor(I, i = {}, e = {}) {
|
|
504
505
|
// ---------------------------------------------------------------------------
|
|
505
506
|
// Private helpers
|
|
506
507
|
// ---------------------------------------------------------------------------
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
508
|
+
m(this, aI);
|
|
509
|
+
m(this, LI);
|
|
510
|
+
m(this, sI);
|
|
511
|
+
m(this, dI);
|
|
512
|
+
m(this, VI);
|
|
513
|
+
m(this, wI);
|
|
514
|
+
m(this, RI);
|
|
515
|
+
m(this, lI, void 0);
|
|
516
|
+
m(this, X, void 0);
|
|
517
|
+
m(this, SI, void 0);
|
|
518
|
+
m(this, oI, void 0);
|
|
519
|
+
m(this, rI, void 0);
|
|
520
|
+
m(this, K, 0);
|
|
521
|
+
m(this, R, 0);
|
|
522
|
+
m(this, CI, 0);
|
|
523
|
+
m(this, eI, 0);
|
|
524
|
+
m(this, k, 1);
|
|
525
|
+
m(this, nI, 1);
|
|
526
|
+
m(this, P, 0.5);
|
|
527
|
+
m(this, H, null);
|
|
528
|
+
m(this, B, null);
|
|
529
|
+
m(this, E, null);
|
|
530
|
+
m(this, J, null);
|
|
531
|
+
m(this, N, null);
|
|
532
|
+
m(this, _, null);
|
|
533
|
+
m(this, v, null);
|
|
534
|
+
m(this, z, null);
|
|
532
535
|
// binary content mask for transparent canvas support
|
|
533
|
-
|
|
536
|
+
m(this, f, null);
|
|
534
537
|
// optional background image (from backgroundSrc prop)
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
+
m(this, uI, "cover");
|
|
539
|
+
m(this, tI, void 0);
|
|
540
|
+
m(this, L, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
|
|
538
541
|
// Stores source so textures can be rebuilt on resize
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
542
|
+
m(this, Y, null);
|
|
543
|
+
m(this, Q, null);
|
|
544
|
+
m(this, cI, !1);
|
|
545
|
+
m(this, bI, !1);
|
|
546
|
+
l(this, lI, I), l(this, nI, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, P, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, tI, pI(i));
|
|
547
|
+
const { gl: s, ext: o } = mg(I);
|
|
548
|
+
l(this, X, s), l(this, SI, o), l(this, oI, rg(s)), l(this, rI, ng(s)), s.clearColor(0, 0, 0, 0);
|
|
545
549
|
}
|
|
546
550
|
// ---------------------------------------------------------------------------
|
|
547
551
|
// Public API
|
|
548
552
|
// ---------------------------------------------------------------------------
|
|
549
|
-
setTextSource(
|
|
550
|
-
|
|
553
|
+
setTextSource(I) {
|
|
554
|
+
l(this, Y, { type: "text", opts: I }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
551
555
|
}
|
|
552
|
-
async setImageSource(
|
|
553
|
-
const
|
|
554
|
-
|
|
556
|
+
async setImageSource(I, i = 0, e = "cover") {
|
|
557
|
+
const s = await kI(I);
|
|
558
|
+
if (g(this, bI)) {
|
|
559
|
+
s.close();
|
|
560
|
+
return;
|
|
561
|
+
}
|
|
562
|
+
l(this, Y, { type: "image", bitmap: s, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
555
563
|
}
|
|
556
|
-
setImageBitmap(
|
|
557
|
-
|
|
564
|
+
setImageBitmap(I, i = 0, e = "cover") {
|
|
565
|
+
l(this, Y, { type: "image", bitmap: I, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
558
566
|
}
|
|
559
|
-
setBackground(
|
|
560
|
-
|
|
567
|
+
setBackground(I, i = "cover") {
|
|
568
|
+
g(this, f) && g(this, f) !== I && g(this, f).close(), l(this, f, I), l(this, uI, i ?? "cover"), g(this, Y) && g(this, K) > 0 && g(this, R) > 0 && b(this, sI, AI).call(this);
|
|
561
569
|
}
|
|
562
|
-
handleMove(
|
|
563
|
-
|
|
570
|
+
handleMove(I, i, e = 1) {
|
|
571
|
+
g(this, L).moved = !0, g(this, L).dx = (I - g(this, L).targetX) * e, g(this, L).dy = (i - g(this, L).targetY) * e, g(this, L).targetX = I, g(this, L).targetY = i;
|
|
564
572
|
}
|
|
565
573
|
/**
|
|
566
574
|
* Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
|
|
@@ -569,149 +577,157 @@ class Fg {
|
|
|
569
577
|
* where you want N independent injection points per frame without flooding the
|
|
570
578
|
* mouse-state machine or the worker message queue.
|
|
571
579
|
*/
|
|
572
|
-
splat(
|
|
573
|
-
if (!
|
|
580
|
+
splat(I, i, e, s, o = 1) {
|
|
581
|
+
if (!g(this, cI) || g(this, K) === 0)
|
|
574
582
|
return;
|
|
575
|
-
const
|
|
576
|
-
|
|
583
|
+
const t = g(this, X), u = g(this, tI), { splat: a } = g(this, oI), c = g(this, rI);
|
|
584
|
+
t.viewport(0, 0, g(this, CI), g(this, eI)), a.bind(), t.uniform1f(a.uniforms.aspectRatio, g(this, K) / g(this, R)), t.uniform2f(a.uniforms.point, I * g(this, k) / g(this, K), 1 - i * g(this, k) / g(this, R)), t.uniform1f(a.uniforms.radius, u.splatRadius), t.uniform1i(a.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, B).read.tex), t.uniform3f(a.uniforms.color, e * u.splatForce * o, -s * u.splatForce * o, 0), c(g(this, B).write.fbo), g(this, B).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, H).read.tex), t.uniform3f(a.uniforms.color, o, o, o), c(g(this, H).write.fbo), g(this, H).swap();
|
|
585
|
+
}
|
|
586
|
+
updateQuality(I) {
|
|
587
|
+
I.dpr !== void 0 && l(this, nI, Math.max(0.1, Math.min(1, I.dpr))), I.sim !== void 0 && l(this, P, Math.max(0.1, Math.min(1, I.sim)));
|
|
577
588
|
}
|
|
578
|
-
resize(
|
|
579
|
-
if (e !== void 0 ?
|
|
580
|
-
if (
|
|
589
|
+
resize(I, i, e) {
|
|
590
|
+
if (e !== void 0 ? l(this, k, e) : typeof window < "u" && window.devicePixelRatio && l(this, k, window.devicePixelRatio), I !== void 0 && I > 0) {
|
|
591
|
+
if (i === void 0 || i <= 0)
|
|
581
592
|
return;
|
|
582
|
-
|
|
593
|
+
l(this, K, g(this, lI).width = I), l(this, R, g(this, lI).height = i), l(this, CI, Math.max(1, Math.round(I * g(this, P)))), l(this, eI, Math.max(1, Math.round(i * g(this, P)))), b(this, LI, YI).call(this);
|
|
583
594
|
} else
|
|
584
|
-
|
|
585
|
-
|
|
595
|
+
b(this, aI, GI).call(this);
|
|
596
|
+
g(this, Y) && b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
586
597
|
}
|
|
587
|
-
updateConfig(
|
|
588
|
-
Object.assign(
|
|
598
|
+
updateConfig(I) {
|
|
599
|
+
Object.assign(g(this, tI), I);
|
|
589
600
|
}
|
|
590
601
|
destroy() {
|
|
591
|
-
this.stop();
|
|
592
|
-
const
|
|
593
|
-
|
|
594
|
-
for (const e of Object.values(
|
|
602
|
+
l(this, bI, !0), this.stop();
|
|
603
|
+
const I = g(this, X);
|
|
604
|
+
b(this, VI, FI).call(this), b(this, wI, DI).call(this), g(this, f) && (g(this, f).close(), l(this, f, null));
|
|
605
|
+
for (const e of Object.values(g(this, oI)))
|
|
595
606
|
e.dispose();
|
|
596
|
-
const
|
|
597
|
-
|
|
607
|
+
const i = I.getExtension("WEBGL_lose_context");
|
|
608
|
+
i == null || i.loseContext();
|
|
598
609
|
}
|
|
599
610
|
// ---------------------------------------------------------------------------
|
|
600
611
|
// Loop control
|
|
601
612
|
// ---------------------------------------------------------------------------
|
|
602
613
|
start() {
|
|
603
|
-
if (
|
|
614
|
+
if (g(this, Q) !== null)
|
|
604
615
|
return;
|
|
605
|
-
const
|
|
606
|
-
|
|
616
|
+
const I = () => {
|
|
617
|
+
b(this, RI, jI).call(this), l(this, Q, xI(I));
|
|
607
618
|
};
|
|
608
|
-
|
|
619
|
+
l(this, Q, xI(I));
|
|
609
620
|
}
|
|
610
621
|
stop() {
|
|
611
|
-
|
|
622
|
+
g(this, Q) !== null && (ug(g(this, Q)), l(this, Q, null));
|
|
612
623
|
}
|
|
613
624
|
get isRunning() {
|
|
614
|
-
return
|
|
625
|
+
return g(this, Q) !== null;
|
|
615
626
|
}
|
|
616
627
|
}
|
|
617
|
-
|
|
618
|
-
const
|
|
619
|
-
"clientWidth" in
|
|
620
|
-
},
|
|
621
|
-
const
|
|
622
|
-
|
|
623
|
-
},
|
|
624
|
-
if (!(!
|
|
625
|
-
if (
|
|
626
|
-
const { backgroundTex:
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
628
|
+
lI = new WeakMap(), X = new WeakMap(), SI = new WeakMap(), oI = new WeakMap(), rI = new WeakMap(), K = new WeakMap(), R = new WeakMap(), CI = new WeakMap(), eI = new WeakMap(), k = new WeakMap(), nI = new WeakMap(), P = new WeakMap(), H = new WeakMap(), B = new WeakMap(), E = new WeakMap(), J = new WeakMap(), N = new WeakMap(), _ = new WeakMap(), v = new WeakMap(), z = new WeakMap(), f = new WeakMap(), uI = new WeakMap(), tI = new WeakMap(), L = new WeakMap(), Y = new WeakMap(), Q = new WeakMap(), cI = new WeakMap(), bI = new WeakMap(), aI = new WeakSet(), GI = function() {
|
|
629
|
+
const I = g(this, lI);
|
|
630
|
+
"clientWidth" in I && I.clientWidth > 0 ? (l(this, k, (typeof window < "u" && window.devicePixelRatio || 1) * g(this, nI)), l(this, K, I.width = Math.round(I.clientWidth * g(this, k))), l(this, R, I.height = Math.round(I.clientHeight * g(this, k)))) : (l(this, K, I.width), l(this, R, I.height)), !(g(this, K) === 0 || g(this, R) === 0) && (l(this, CI, Math.max(1, Math.round(g(this, K) * g(this, P)))), l(this, eI, Math.max(1, Math.round(g(this, R) * g(this, P)))), b(this, LI, YI).call(this));
|
|
631
|
+
}, LI = new WeakSet(), YI = function() {
|
|
632
|
+
const I = g(this, X), i = g(this, SI), e = g(this, CI), s = g(this, eI);
|
|
633
|
+
b(this, VI, FI).call(this), l(this, H, WI(I, i, e, s)), l(this, B, WI(I, i, e, s)), l(this, J, WI(I, i, e, s)), l(this, E, KI(I, i, e, s)), l(this, N, KI(I, i, e, s));
|
|
634
|
+
}, sI = new WeakSet(), AI = function() {
|
|
635
|
+
if (!(!g(this, Y) || g(this, K) === 0 || g(this, R) === 0)) {
|
|
636
|
+
if (b(this, wI, DI).call(this), g(this, Y).type === "text") {
|
|
637
|
+
const { backgroundTex: I, obstacleTex: i, coverageTex: e } = Cg(
|
|
638
|
+
g(this, X),
|
|
639
|
+
g(this, K),
|
|
640
|
+
g(this, R),
|
|
641
|
+
g(this, Y).opts,
|
|
642
|
+
g(this, f),
|
|
643
|
+
g(this, uI)
|
|
633
644
|
);
|
|
634
|
-
|
|
645
|
+
l(this, _, I), l(this, v, i), l(this, z, e);
|
|
635
646
|
} else {
|
|
636
|
-
const { backgroundTex:
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
647
|
+
const { backgroundTex: I, obstacleTex: i, coverageTex: e } = eg(
|
|
648
|
+
g(this, X),
|
|
649
|
+
g(this, Y).bitmap,
|
|
650
|
+
g(this, K),
|
|
651
|
+
g(this, R),
|
|
652
|
+
g(this, Y).effect,
|
|
653
|
+
g(this, Y).size,
|
|
654
|
+
g(this, f),
|
|
655
|
+
g(this, uI)
|
|
645
656
|
);
|
|
646
|
-
|
|
657
|
+
l(this, _, I), l(this, v, i), l(this, z, e);
|
|
647
658
|
}
|
|
648
|
-
|
|
649
|
-
}
|
|
650
|
-
},
|
|
651
|
-
|
|
652
|
-
},
|
|
653
|
-
var
|
|
654
|
-
(
|
|
655
|
-
},
|
|
656
|
-
|
|
657
|
-
},
|
|
658
|
-
if (!
|
|
659
|
+
l(this, cI, !0);
|
|
660
|
+
}
|
|
661
|
+
}, dI = new WeakSet(), hI = function() {
|
|
662
|
+
g(this, cI) && !this.isRunning && this.start();
|
|
663
|
+
}, VI = new WeakSet(), FI = function() {
|
|
664
|
+
var I, i, e;
|
|
665
|
+
(I = g(this, H)) == null || I.dispose(), (i = g(this, B)) == null || i.dispose(), (e = g(this, J)) == null || e.dispose(), g(this, E) && (g(this, X).deleteTexture(g(this, E).tex), g(this, X).deleteFramebuffer(g(this, E).fbo)), g(this, N) && (g(this, X).deleteTexture(g(this, N).tex), g(this, X).deleteFramebuffer(g(this, N).fbo)), l(this, H, l(this, B, l(this, J, l(this, E, l(this, N, null)))));
|
|
666
|
+
}, wI = new WeakSet(), DI = function() {
|
|
667
|
+
g(this, _) && g(this, X).deleteTexture(g(this, _)), g(this, v) && g(this, X).deleteTexture(g(this, v)), g(this, z) && g(this, z) !== g(this, v) && g(this, X).deleteTexture(g(this, z)), l(this, _, l(this, v, l(this, z, null)));
|
|
668
|
+
}, RI = new WeakSet(), jI = function() {
|
|
669
|
+
if (!g(this, cI) || g(this, K) === 0 || !g(this, H) || !g(this, B))
|
|
659
670
|
return;
|
|
660
|
-
const
|
|
661
|
-
|
|
662
|
-
const
|
|
663
|
-
|
|
664
|
-
for (let
|
|
665
|
-
|
|
666
|
-
|
|
671
|
+
const I = g(this, X), i = g(this, tI), { advection: e, divergence: s, pressure: o, gradientSubtract: t, splat: u, curl: a, vorticity: c, display: n } = g(this, oI);
|
|
672
|
+
g(this, L).x += (g(this, L).targetX - g(this, L).x) * 0.15, g(this, L).y += (g(this, L).targetY - g(this, L).y) * 0.15;
|
|
673
|
+
const G = g(this, CI), d = g(this, eI), h = g(this, rI);
|
|
674
|
+
I.viewport(0, 0, G, d), e.bind(), I.uniform2f(e.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(e.uniforms.dt, MI), I.uniform1i(e.uniforms.uObstacle, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.uniform1f(e.uniforms.dissipation, i.velocityDissipation), I.uniform1i(e.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(e.uniforms.uSource, 1), h(g(this, B).write.fbo), g(this, B).swap(), I.uniform1f(e.uniforms.dissipation, i.densityDissipation), I.uniform1i(e.uniforms.uSource, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), h(g(this, H).write.fbo), g(this, H).swap(), a.bind(), I.uniform2f(a.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(a.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), h(g(this, N).fbo), c.bind(), I.uniform2f(c.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(c.uniforms.curl, i.curl), I.uniform1f(c.uniforms.dt, MI), I.uniform1i(c.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(c.uniforms.uCurl, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, N).tex), h(g(this, B).write.fbo), g(this, B).swap(), g(this, L).moved && (u.bind(), I.uniform1f(u.uniforms.aspectRatio, g(this, K) / g(this, R)), I.uniform2f(u.uniforms.point, g(this, L).x * g(this, k) / g(this, K), 1 - g(this, L).y * g(this, k) / g(this, R)), I.uniform1f(u.uniforms.radius, i.splatRadius), I.uniform1i(u.uniforms.uTarget, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform3f(u.uniforms.color, g(this, L).dx * i.splatForce, -g(this, L).dy * i.splatForce, 0), h(g(this, B).write.fbo), g(this, B).swap(), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.uniform3f(u.uniforms.color, 1, 1, 1), h(g(this, H).write.fbo), g(this, H).swap(), g(this, L).moved = !1), s.bind(), I.uniform2f(s.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(s.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(s.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, E).fbo), o.bind(), I.uniform2f(o.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(o.uniforms.uDivergence, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, E).tex), I.uniform1i(o.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v));
|
|
675
|
+
for (let W = 0; W < i.pressureIterations; W++)
|
|
676
|
+
I.uniform1i(o.uniforms.uPressure, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), h(g(this, J).write.fbo), g(this, J).swap();
|
|
677
|
+
t.bind(), I.uniform2f(t.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(t.uniforms.uPressure, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), I.uniform1i(t.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(t.uniforms.uObstacle, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, B).write.fbo), g(this, B).swap(), I.viewport(0, 0, g(this, K), g(this, R)), I.bindFramebuffer(I.FRAMEBUFFER, null), I.clear(I.COLOR_BUFFER_BIT), n.bind(), I.uniform2f(n.uniforms.texelSize, 1 / g(this, K), 1 / g(this, R)), I.uniform3fv(n.uniforms.uWaterColor, i.waterColor), I.uniform3fv(n.uniforms.uGlowColor, i.glowColor), I.uniform1f(n.uniforms.uRefraction, i.refraction), I.uniform1f(n.uniforms.uSpecularExp, i.specularExp), I.uniform1f(n.uniforms.uShine, i.shine), I.uniform1f(n.uniforms.uWarpStrength, i.warpStrength ?? 0.015), I.uniform1i(n.uniforms.uAlgorithm, Zg[i.algorithm] ?? 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, _)), I.activeTexture(I.TEXTURE3), I.bindTexture(I.TEXTURE_2D, g(this, z)), I.activeTexture(I.TEXTURE4), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(n.uniforms.uTexture, 0), I.uniform1i(n.uniforms.uObstacle, 1), I.uniform1i(n.uniforms.uBackground, 2), I.uniform1i(n.uniforms.uCoverage, 3), I.uniform1i(n.uniforms.uVelocity, 4), h(null);
|
|
667
678
|
};
|
|
668
|
-
const Og = "dmFyIFJlID0gT2JqZWN0LmRlZmluZVByb3BlcnR5Owp2YXIgeWUgPSAoaSwgZSwgcikgPT4gZSBpbiBpID8gUmUoaSwgZSwgeyBlbnVtZXJhYmxlOiAhMCwgY29uZmlndXJhYmxlOiAhMCwgd3JpdGFibGU6ICEwLCB2YWx1ZTogciB9KSA6IGlbZV0gPSByOwp2YXIgb2UgPSAoaSwgZSwgcikgPT4gKHllKGksIHR5cGVvZiBlICE9ICJzeW1ib2wiID8gZSArICIiIDogZSwgciksIHIpLCB2ZSA9IChpLCBlLCByKSA9PiB7CiAgaWYgKCFlLmhhcyhpKSkKICAgIHRocm93IFR5cGVFcnJvcigiQ2Fubm90ICIgKyByKTsKfTsKdmFyIHQgPSAoaSwgZSwgcikgPT4gKHZlKGksIGUsICJyZWFkIGZyb20gcHJpdmF0ZSBmaWVsZCIpLCByID8gci5jYWxsKGkpIDogZS5nZXQoaSkpLCBsID0gKGksIGUsIHIpID0+IHsKICBpZiAoZS5oYXMoaSkpCiAgICB0aHJvdyBUeXBlRXJyb3IoIkNhbm5vdCBhZGQgdGhlIHNhbWUgcHJpdmF0ZSBtZW1iZXIgbW9yZSB0aGFuIG9uY2UiKTsKICBlIGluc3RhbmNlb2YgV2Vha1NldCA/IGUuYWRkKGkpIDogZS5zZXQoaSwgcik7Cn0sIGEgPSAoaSwgZSwgciwgbykgPT4gKHZlKGksIGUsICJ3cml0ZSB0byBwcml2YXRlIGZpZWxkIiksIG8gPyBvLmNhbGwoaSwgcikgOiBlLnNldChpLCByKSwgcik7CnZhciBkID0gKGksIGUsIHIpID0+ICh2ZShpLCBlLCAiYWNjZXNzIHByaXZhdGUgbWV0aG9kIiksIHIpOwpjb25zdCBnZSA9IHsKICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTkyLAogIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgcHJlc3N1cmVJdGVyYXRpb25zOiAxLAogIGN1cmw6IDFlLTQsCiAgc3BsYXRSYWRpdXM6IDRlLTMsCiAgc3BsYXRGb3JjZTogMC45MSwKICByZWZyYWN0aW9uOiAwLjI1LAogIHNwZWN1bGFyRXhwOiAxLjAxLAogIHNoaW5lOiAwLjAxLAogIHdhdGVyQ29sb3I6IFswLCAwLCAwXSwKICBnbG93Q29sb3I6IFswLjcsIDAuODUsIDFdLAogIGFsZ29yaXRobTogInN0YW5kYXJkIiwKICB3YXJwU3RyZW5ndGg6IDAuMDE1Cn07Cih7CiAgLi4uZ2UKfSk7CmNvbnN0IERlID0gewogIGNhbG06IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45OTksCiAgICB2ZWxvY2l0eURpc3NpcGF0aW9uOiAwLjk4LAogICAgY3VybDogMWUtNCwKICAgIHNwbGF0UmFkaXVzOiAzZS0zLAogICAgc3BsYXRGb3JjZTogMC41LAogICAgcmVmcmFjdGlvbjogMC4xNSwKICAgIHNoaW5lOiA1ZS0zLAogICAgZ2xvd0NvbG9yOiBbMC42LCAwLjg1LCAxXSwKICAgIHdhdGVyQ29sb3I6IFswLCAwLjAyLCAwLjA1XQogIH0sCiAgc3Rvcm06IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45NywKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuODgsCiAgICBjdXJsOiAwLjQ1LAogICAgc3BsYXRSYWRpdXM6IDAuMDEyLAogICAgc3BsYXRGb3JjZTogMywKICAgIHJlZnJhY3Rpb246IDAuNiwKICAgIHNoaW5lOiAwLjA4LAogICAgZ2xvd0NvbG9yOiBbMC4yLCAwLjMsIDAuOF0sCiAgICB3YXRlckNvbG9yOiBbMCwgMCwgMC4xXSwKICAgIHByZXNzdXJlSXRlcmF0aW9uczogMTUwCiAgfSwKICB3YXZlOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk0LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45MiwKICAgIGN1cmw6IDAuMiwKICAgIHNwbGF0UmFkaXVzOiA1ZS0zLAogICAgc3BsYXRGb3JjZTogMS4yLAogICAgcmVmcmFjdGlvbjogMC4zNSwKICAgIHNoaW5lOiAwLjAzLAogICAgcHJlc3N1cmVJdGVyYXRpb25zOiA1LAogICAgZ2xvd0NvbG9yOiBbMC41LCAwLjgsIDFdLAogICAgd2F0ZXJDb2xvcjogWzAsIDAuMDEsIDAuMDNdCiAgfSwKICBuZW9uOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTg1LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45MywKICAgIGN1cmw6IDAuMDUsCiAgICBzcGxhdFJhZGl1czogOGUtMywKICAgIHNwbGF0Rm9yY2U6IDEuNSwKICAgIHJlZnJhY3Rpb246IDAuMjUsCiAgICBzcGVjdWxhckV4cDogMC41LAogICAgc2hpbmU6IDAuMTQsCiAgICBnbG93Q29sb3I6IFsxLCAwLjIsIDAuOF0sCiAgICB3YXRlckNvbG9yOiBbMC4wNSwgMCwgMC4wOF0KICB9LAogIHNtb2tlOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk2LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45NywKICAgIGN1cmw6IDAuMDQsCiAgICBzcGxhdFJhZGl1czogOWUtMywKICAgIHNwbGF0Rm9yY2U6IDAuOCwKICAgIHJlZnJhY3Rpb246IDAuMDgsCiAgICBzaGluZTogMCwKICAgIGdsb3dDb2xvcjogWzAuNSwgMC41LCAwLjVdLAogICAgd2F0ZXJDb2xvcjogWzAuMDYsIDAuMDYsIDAuMDZdCiAgfQp9OwpmdW5jdGlvbiBVZShpID0ge30sIGUsIHIgPSBnZSkgewogIHJldHVybiB7IC4uLmUgPyB7IC4uLnIsIC4uLkRlW2VdIH0gOiByLCAuLi5pIH07Cn0KY29uc3QgUCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICBhdHRyaWJ1dGUgdmVjMiBhUG9zaXRpb247CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSB2ZWMyIHRleGVsU2l6ZTsKICB2b2lkIG1haW4gKCkgewogICAgdlV2ID0gYVBvc2l0aW9uICogMC41ICsgMC41OwogICAgdkwgPSB2VXYgLSB2ZWMyKHRleGVsU2l6ZS54LCAwLjApOwogICAgdlIgPSB2VXYgKyB2ZWMyKHRleGVsU2l6ZS54LCAwLjApOwogICAgdlQgPSB2VXYgKyB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkpOwogICAgdkIgPSB2VXYgLSB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkpOwogICAgZ2xfUG9zaXRpb24gPSB2ZWM0KGFQb3NpdGlvbiwgMC4wLCAxLjApOwogIH0KYAopLCBfZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1U291cmNlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB1bmlmb3JtIHZlYzIgdGV4ZWxTaXplOwogIHVuaWZvcm0gZmxvYXQgZHQ7CiAgdW5pZm9ybSBmbG9hdCBkaXNzaXBhdGlvbjsKICB2b2lkIG1haW4gKCkgewogICAgaWYgKHRleHR1cmUyRCh1T2JzdGFjbGUsIHZVdikuciA+IDAuNSkgeyBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuMCk7IHJldHVybjsgfQogICAgdmVjMiBjb29yZCA9IHZVdiAtIGR0ICogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSAqIHRleGVsU2l6ZTsKICAgIGdsX0ZyYWdDb2xvciA9IGRpc3NpcGF0aW9uICogdGV4dHVyZTJEKHVTb3VyY2UsIGNvb3JkKTsKICB9CmAKKSwgd2UgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2TCkuciA+IDAuNSA/IDAuMCA6IHRleHR1cmUyRCh1VmVsb2NpdHksIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZSKS5yID4gMC41ID8gMC4wIDogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlQpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VCkueTsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2QikuciA+IDAuNSA/IDAuMCA6IHRleHR1cmUyRCh1VmVsb2NpdHksIHZCKS55OwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjUgKiAoUiAtIEwgKyBUIC0gQiksIDAuMCwgMC4wLCAxLjApOwogIH0KYAopLCBDZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OyB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVByZXNzdXJlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVEaXZlcmdlbmNlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgQyA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZVdikueDsKICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2TCkuciA+IDAuNSA/IEMgOiB0ZXh0dXJlMkQodVByZXNzdXJlLCB2TCkueDsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2UikuciA+IDAuNSA/IEMgOiB0ZXh0dXJlMkQodVByZXNzdXJlLCB2UikueDsKICAgIGZsb2F0IFQgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VCkuciA+IDAuNSA/IEMgOiB0ZXh0dXJlMkQodVByZXNzdXJlLCB2VCkueDsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2QikuciA+IDAuNSA/IEMgOiB0ZXh0dXJlMkQodVByZXNzdXJlLCB2QikueDsKICAgIGZsb2F0IGRpdiA9IHRleHR1cmUyRCh1RGl2ZXJnZW5jZSwgdlV2KS54OwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCgoTCArIFIgKyBCICsgVCAtIGRpdikgKiAwLjI1LCAwLjAsIDAuMCwgMS4wKTsKICB9CmAKKSwgU2UgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVQcmVzc3VyZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHZvaWQgbWFpbiAoKSB7CiAgICBpZiAodGV4dHVyZTJEKHVPYnN0YWNsZSwgdlV2KS5yID4gMC41KSB7IGdsX0ZyYWdDb2xvciA9IHZlYzQoMC4wKTsgcmV0dXJuOyB9CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkwpLng7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkIpLng7CiAgICB2ZWMyIHZlbCA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHkgLSB2ZWMyKFIgLSBMLCBUIC0gQik7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KHZlbCwgMC4wLCAxLjApOwogIH0KYAopLCBGZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVUYXJnZXQ7CiAgdW5pZm9ybSBmbG9hdCBhc3BlY3RSYXRpbzsKICB1bmlmb3JtIHZlYzMgY29sb3I7CiAgdW5pZm9ybSB2ZWMyIHBvaW50OwogIHVuaWZvcm0gZmxvYXQgcmFkaXVzOwogIHZvaWQgbWFpbiAoKSB7CiAgICB2ZWMyIHAgPSB2VXYgLSBwb2ludC54eTsKICAgIHAueCAqPSBhc3BlY3RSYXRpbzsKICAgIHZlYzMgc3BsYXQgPSBleHAoLWRvdChwLCBwKSAvIHJhZGl1cykgKiBjb2xvcjsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQodGV4dHVyZTJEKHVUYXJnZXQsIHZVdikueHl6ICsgc3BsYXQsIDEuMCk7CiAgfQpgCiksIFhlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2TCkueTsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2UikueTsKICAgIGZsb2F0IFQgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VCkueDsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2QikueDsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoMC41ICogKFIgLSBMIC0gVCArIEIpLCAwLjAsIDAuMCwgMS4wKTsKICB9CmAKKSwgQmUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1Q3VybDsKICB1bmlmb3JtIGZsb2F0IGN1cmw7CiAgdW5pZm9ybSBmbG9hdCBkdDsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1Q3VybCwgdkwpLng7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVDdXJsLCB2UikueDsKICAgIGZsb2F0IFQgPSB0ZXh0dXJlMkQodUN1cmwsIHZUKS54OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1Q3VybCwgdkIpLng7CiAgICBmbG9hdCBDID0gdGV4dHVyZTJEKHVDdXJsLCB2VXYpLng7CiAgICB2ZWMyIGZvcmNlID0gMC41ICogdmVjMihhYnMoVCkgLSBhYnMoQiksIGFicyhSKSAtIGFicyhMKSk7CiAgICBmb3JjZSAvPSBsZW5ndGgoZm9yY2UpICsgMC4wMDAxOwogICAgZm9yY2UgKj0gY3VybCAqIDMwLjAgKiBDOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCh0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5ICsgZm9yY2UgKiBkdCwgMC4wLCAxLjApOwogIH0KYAopLCBBZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OwoKICB1bmlmb3JtIHNhbXBsZXIyRCB1VGV4dHVyZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdUJhY2tncm91bmQ7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdUNvdmVyYWdlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKCiAgdW5pZm9ybSB2ZWMyICB0ZXhlbFNpemU7CiAgdW5pZm9ybSB2ZWMzICB1V2F0ZXJDb2xvcjsKICB1bmlmb3JtIHZlYzMgIHVHbG93Q29sb3I7CiAgdW5pZm9ybSBmbG9hdCB1UmVmcmFjdGlvbjsKICB1bmlmb3JtIGZsb2F0IHVTcGVjdWxhckV4cDsKICB1bmlmb3JtIGZsb2F0IHVTaGluZTsKICB1bmlmb3JtIGZsb2F0IHVXYXJwU3RyZW5ndGg7CiAgdW5pZm9ybSBpbnQgICB1QWxnb3JpdGhtOwoKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgZGVuc2l0eSAgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCAgIHZVdikuciwgMC4wKTsKICAgIGZsb2F0IG9icyAgICAgID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgIHZVdikucjsKICAgIGZsb2F0IGNvdmVyYWdlID0gdGV4dHVyZTJEKHVDb3ZlcmFnZSwgIHZVdikucjsKCiAgICBmbG9hdCBkTCA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiAtIHZlYzIodGV4ZWxTaXplLnggKiAyLjAsIDAuMCkpLnIsIDAuMCk7CiAgICBmbG9hdCBkUiA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIodGV4ZWxTaXplLnggKiAyLjAsIDAuMCkpLnIsIDAuMCk7CiAgICBmbG9hdCBkVCA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIoMC4wLCB0ZXhlbFNpemUueSAqIDIuMCkpLnIsIDAuMCk7CiAgICBmbG9hdCBkQiA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiAtIHZlYzIoMC4wLCB0ZXhlbFNpemUueSAqIDIuMCkpLnIsIDAuMCk7CgogICAgdmVjMyAgbm9ybWFsICAgPSBub3JtYWxpemUodmVjMyhkTCAtIGRSLCBkQiAtIGRULCAwLjIpKTsKICAgIHZlYzMgIGxpZ2h0RGlyID0gbm9ybWFsaXplKHZlYzMoMC41LCAxLjAsIDAuNSkpOwogICAgdmVjMyAgaGFsZlYgICAgPSBub3JtYWxpemUobGlnaHREaXIgKyB2ZWMzKDAuMCwgMC4wLCAxLjApKTsKICAgIGZsb2F0IHNwZWMgICAgID0gcG93KG1heChkb3Qobm9ybWFsLCBoYWxmViksIDAuMCksIHVTcGVjdWxhckV4cCkgKiB1U2hpbmUgKiBkZW5zaXR5OwoKICAgIC8vIEluIHRyYW5zcGFyZW50IChub24tY292ZXJhZ2UpIGFyZWFzIHRoZSBiYWNrZ3JvdW5kIHRleHR1cmUgaXMgZW1wdHkgYmxhY2sgY2FudmFzLgogICAgLy8gUmVwbGFjZSBpdCB3aXRoIHVXYXRlckNvbG9yIHNvIGZsdWlkIGNvbG91ciBpcyBub3QgY29udGFtaW5hdGVkIGJ5IHRoYXQgYmxhY2ssCiAgICAvLyBhbGxvd2luZyB0aGUgQ1NTIGJhY2tncm91bmRDb2xvciB0byBzaG93IHRocm91Z2ggY29ycmVjdGx5IHZpYSBwcmVtdWx0aXBsaWVkIGFscGhhLgogICAgdmVjMyBiZ1JhdyA9IHRleHR1cmUyRCh1QmFja2dyb3VuZCwgdlV2KS5yZ2I7CiAgICB2ZWMzIGJnICAgID0gbWl4KHVXYXRlckNvbG9yLCBiZ1JhdywgY292ZXJhZ2UpOwogICAgdmVjMyBjb2xvciA9IGJnOwoKICAgIGlmICh1QWxnb3JpdGhtID09IDEpIHsKICAgICAgLy8g4pSA4pSAIGdsYXNzIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBTdHJvbmcgVVYgZGlzdG9ydGlvbiBvbmx5LiBJbWFnZSBiZW5kcyBidXQgbm8gY29sb3VyIG92ZXJsYXkuCiAgICAgIHZlYzIgcmVmclV2ID0gY2xhbXAodlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5ICogMy4wLCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgcmVmckJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJlZnJVdiwgMS4wIC0gb2JzKSkucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yID0gcmVmckJnICsgc3BlYyAqIHVHbG93Q29sb3IgKiAyLjU7CiAgICAgIGNvbG9yID0gbWl4KGNvbG9yLCBiZyAqIDAuNiwgb2JzICogMC4zKTsKCiAgICB9IGVsc2UgaWYgKHVBbGdvcml0aG0gPT0gMikgewogICAgICAvLyDilIDilIAgaW5rIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBEZW5zZSBvcGFxdWUgcGlnbWVudCB0aGF0IHN0YWlucy4gU3VidGxlIHJlZnJhY3Rpb24gdW5kZXJuZWF0aC4KICAgICAgZmxvYXQgaW5rRCAgPSBtaW4oZGVuc2l0eSAqIDQuMCwgMS4wKTsKICAgICAgdmVjMiByZWZyVXYgPSBjbGFtcCh2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHkgKiAwLjQsIDAuMCwgMS4wKTsKICAgICAgdmVjMyByZWZyQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmVmclV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgPSBtaXgocmVmckJnLCB1V2F0ZXJDb2xvciArIHNwZWMgKiB1R2xvd0NvbG9yLCBpbmtEKTsKICAgICAgY29sb3IgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjE1KTsKCiAgICB9IGVsc2UgaWYgKHVBbGdvcml0aG0gPT0gMykgewogICAgICAvLyDilIDilIAgYXVyb3JhIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBWZWxvY2l0eSBmaWVsZCB3YXJwcyBiYWNrZ3JvdW5kIFVWcyDigJQgbGlxdWlkIG1ldGFsIC8gbGF2YS1sYW1wIGZlZWwuCiAgICAgIHZlYzIgIHZlbCAgICA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHk7CiAgICAgIGZsb2F0IHZlbE1hZyA9IGNsYW1wKGxlbmd0aCh2ZWwpICogMjAuMCwgMC4wLCAxLjApOwogICAgICB2ZWMyICB3YXJwVXYgPSBjbGFtcCh2VXYgKyB2ZWwgKiB1V2FycFN0cmVuZ3RoLCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgIHdhcnBCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCB3YXJwVXYpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciAgPSBtaXgoYmcsIHdhcnBCZywgdmVsTWFnICogKDEuMCAtIG9icykpOwogICAgICBjb2xvciArPSBzcGVjICogdUdsb3dDb2xvciAqIHZlbE1hZyAqIDEuNTsKICAgICAgY29sb3IgKz0gdVdhdGVyQ29sb3IgKiBkZW5zaXR5ICogMC4zOwogICAgICBjb2xvciAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwoKICAgIH0gZWxzZSBpZiAodUFsZ29yaXRobSA9PSA0KSB7CiAgICAgIC8vIOKUgOKUgCByaXBwbGUg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIEV4YWdnZXJhdGVkIG5vcm1hbCBwZXJ0dXJiYXRpb24gKyBGcmVzbmVsIHJpbSDigJQgY2FsbSB3YXRlciBzdXJmYWNlLgogICAgICB2ZWMyICByaXBwbGVVdiA9IGNsYW1wKHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eSAqIDYuMCwgMC4wLCAxLjApOwogICAgICB2ZWMzICByZWZyQmcgICA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByaXBwbGVVdiwgMS4wIC0gb2JzKSkucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGZsb2F0IGZyZXNuZWwgID0gcG93KGNsYW1wKDEuMCAtIGRvdChub3JtYWwsIHZlYzMoMC4wLCAwLjAsIDEuMCkpLCAwLjAsIDEuMCksIDMuMCkgKiBkZW5zaXR5OwogICAgICBjb2xvciAgPSByZWZyQmc7CiAgICAgIGNvbG9yICs9IGZyZXNuZWwgKiB1R2xvd0NvbG9yICogMi4wOwogICAgICBjb2xvciArPSBzcGVjICogdUdsb3dDb2xvciAqIGRlbnNpdHkgKiAyLjA7CiAgICAgIGNvbG9yICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMik7CgogICAgfSBlbHNlIHsKICAgICAgLy8g4pSA4pSAIHN0YW5kYXJkICgwKSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gT3JpZ2luYWw6IGNvbG91ciBvdmVybGF5IGJsZW5kZWQgb3ZlciByZWZyYWN0ZWQgYmFja2dyb3VuZC4KICAgICAgdmVjMiByZWZyVXYgPSB2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHk7CiAgICAgIHZlYzMgcmVmckJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJlZnJVdiwgMS4wIC0gb2JzKSkucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yICA9IG1peChyZWZyQmcsIHVXYXRlckNvbG9yLCBtaW4oZGVuc2l0eSAqIDEuNSwgMC44KSk7CiAgICAgIGNvbG9yICs9IHNwZWMgKiB1R2xvd0NvbG9yOwogICAgICBjb2xvciAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwogICAgfQoKICAgIC8vIFByZW11bHRpcGxpZWQgYWxwaGEg4oCUIHRyYW5zcGFyZW50IHdoZXJlIHRoZXJlIGlzIG5laXRoZXIgY29udGVudCBub3IgZmx1aWQsCiAgICAvLyBsZXR0aW5nIHRoZSBDU1MgYmFja2dyb3VuZENvbG9yIG9uIHRoZSBjb250YWluZXIgZGl2IHNob3cgdGhyb3VnaC4KICAgIGZsb2F0IGFscGhhID0gY2xhbXAobWF4KGRlbnNpdHkgKiAxLjUsIGNvdmVyYWdlKSwgMC4wLCAxLjApOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNChjb2xvciAqIGFscGhhLCBhbHBoYSk7CiAgfQpgCik7CmZ1bmN0aW9uIExlKGkpIHsKICBjb25zdCBlID0geyBhbHBoYTogITAsIGRlcHRoOiAhMSwgc3RlbmNpbDogITEsIGFudGlhbGlhczogITAsIHByZXNlcnZlRHJhd2luZ0J1ZmZlcjogITEgfTsKICBsZXQgciA9IGkuZ2V0Q29udGV4dCgid2ViZ2wyIiwgZSk7CiAgY29uc3QgbyA9ICEhcjsKICBvIHx8IChyID0gaS5nZXRDb250ZXh0KCJ3ZWJnbCIsIGUpLCByLmdldEV4dGVuc2lvbigiRVhUX2NvbG9yX2J1ZmZlcl9oYWxmX2Zsb2F0IikpOwogIGNvbnN0IHMgPSBvID8gbnVsbCA6IHIuZ2V0RXh0ZW5zaW9uKCJPRVNfdGV4dHVyZV9oYWxmX2Zsb2F0IiksIG4gPSBvID8gci5IQUxGX0ZMT0FUIDogcy5IQUxGX0ZMT0FUX09FUzsKICByZXR1cm4gci5nZXRFeHRlbnNpb24oIkVYVF9jb2xvcl9idWZmZXJfZmxvYXQiKSwgci5nZXRFeHRlbnNpb24oIk9FU190ZXh0dXJlX2hhbGZfZmxvYXRfbGluZWFyIiksIHsKICAgIGdsOiByLAogICAgaXNXZWJHTDI6IG8sCiAgICBleHQ6IHsKICAgICAgaW50ZXJuYWxGb3JtYXQ6IG8gPyByLlJHQkExNkYgOiByLlJHQkEsCiAgICAgIGZvcm1hdDogci5SR0JBLAogICAgICB0eXBlOiBuCiAgICB9CiAgfTsKfQpjbGFzcyBPIHsKICBjb25zdHJ1Y3RvcihlLCByLCBvKSB7CiAgICBvZSh0aGlzLCAicHJvZ3JhbSIpOwogICAgb2UodGhpcywgInVuaWZvcm1zIiwge30pOwogICAgb2UodGhpcywgIl9nbCIpOwogICAgdGhpcy5fZ2wgPSBlLCB0aGlzLnByb2dyYW0gPSBlLmNyZWF0ZVByb2dyYW0oKSwgZS5hdHRhY2hTaGFkZXIodGhpcy5wcm9ncmFtLCB0aGlzLl9jb21waWxlKGUuVkVSVEVYX1NIQURFUiwgcikpLCBlLmF0dGFjaFNoYWRlcih0aGlzLnByb2dyYW0sIHRoaXMuX2NvbXBpbGUoZS5GUkFHTUVOVF9TSEFERVIsIG8pKSwgZS5saW5rUHJvZ3JhbSh0aGlzLnByb2dyYW0pOwogICAgY29uc3QgcyA9IGUuZ2V0UHJvZ3JhbVBhcmFtZXRlcih0aGlzLnByb2dyYW0sIGUuQUNUSVZFX1VOSUZPUk1TKTsKICAgIGZvciAobGV0IG4gPSAwOyBuIDwgczsgbisrKSB7CiAgICAgIGNvbnN0IHUgPSBlLmdldEFjdGl2ZVVuaWZvcm0odGhpcy5wcm9ncmFtLCBuKS5uYW1lOwogICAgICB0aGlzLnVuaWZvcm1zW3VdID0gZS5nZXRVbmlmb3JtTG9jYXRpb24odGhpcy5wcm9ncmFtLCB1KTsKICAgIH0KICB9CiAgX2NvbXBpbGUoZSwgcikgewogICAgY29uc3QgbyA9IHRoaXMuX2dsLCBzID0gby5jcmVhdGVTaGFkZXIoZSk7CiAgICByZXR1cm4gby5zaGFkZXJTb3VyY2UocywgciksIG8uY29tcGlsZVNoYWRlcihzKSwgczsKICB9CiAgYmluZCgpIHsKICAgIHRoaXMuX2dsLnVzZVByb2dyYW0odGhpcy5wcm9ncmFtKTsKICB9CiAgZGlzcG9zZSgpIHsKICAgIHRoaXMuX2dsLmRlbGV0ZVByb2dyYW0odGhpcy5wcm9ncmFtKTsKICB9Cn0KZnVuY3Rpb24gUGUoaSkgewogIHJldHVybiB7CiAgICBhZHZlY3Rpb246IG5ldyBPKGksIFAsIF9lKSwKICAgIGRpdmVyZ2VuY2U6IG5ldyBPKGksIFAsIHdlKSwKICAgIHByZXNzdXJlOiBuZXcgTyhpLCBQLCBDZSksCiAgICBncmFkaWVudFN1YnRyYWN0OiBuZXcgTyhpLCBQLCBTZSksCiAgICBzcGxhdDogbmV3IE8oaSwgUCwgRmUpLAogICAgY3VybDogbmV3IE8oaSwgUCwgWGUpLAogICAgdm9ydGljaXR5OiBuZXcgTyhpLCBQLCBCZSksCiAgICBkaXNwbGF5OiBuZXcgTyhpLCBQLCBBZSkKICB9Owp9CmZ1bmN0aW9uIGFlKGksIGUsIHIsIG8pIHsKICBpLmFjdGl2ZVRleHR1cmUoaS5URVhUVVJFMCk7CiAgY29uc3QgcyA9IGkuY3JlYXRlVGV4dHVyZSgpOwogIGkuYmluZFRleHR1cmUoaS5URVhUVVJFXzJELCBzKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX01JTl9GSUxURVIsIGkuTElORUFSKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX01BR19GSUxURVIsIGkuTElORUFSKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX1dSQVBfUywgaS5DTEFNUF9UT19FREdFKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX1dSQVBfVCwgaS5DTEFNUF9UT19FREdFKSwgaS50ZXhJbWFnZTJEKGkuVEVYVFVSRV8yRCwgMCwgZS5pbnRlcm5hbEZvcm1hdCwgciwgbywgMCwgZS5mb3JtYXQsIGUudHlwZSwgbnVsbCk7CiAgY29uc3QgbiA9IGkuY3JlYXRlRnJhbWVidWZmZXIoKTsKICByZXR1cm4gaS5iaW5kRnJhbWVidWZmZXIoaS5GUkFNRUJVRkZFUiwgbiksIGkuZnJhbWVidWZmZXJUZXh0dXJlMkQoaS5GUkFNRUJVRkZFUiwgaS5DT0xPUl9BVFRBQ0hNRU5UMCwgaS5URVhUVVJFXzJELCBzLCAwKSwgeyB0ZXg6IHMsIGZibzogbiwgd2lkdGg6IHIsIGhlaWdodDogbyB9Owp9CmZ1bmN0aW9uIGhlKGksIGUsIHIsIG8pIHsKICBsZXQgcyA9IGFlKGksIGUsIHIsIG8pLCBuID0gYWUoaSwgZSwgciwgbyk7CiAgcmV0dXJuIHsKICAgIGdldCByZWFkKCkgewogICAgICByZXR1cm4gczsKICAgIH0sCiAgICBnZXQgd3JpdGUoKSB7CiAgICAgIHJldHVybiBuOwogICAgfSwKICAgIHN3YXAoKSB7CiAgICAgIFtzLCBuXSA9IFtuLCBzXTsKICAgIH0sCiAgICBkaXNwb3NlKCkgewogICAgICBpLmRlbGV0ZVRleHR1cmUocy50ZXgpLCBpLmRlbGV0ZUZyYW1lYnVmZmVyKHMuZmJvKSwgaS5kZWxldGVUZXh0dXJlKG4udGV4KSwgaS5kZWxldGVGcmFtZWJ1ZmZlcihuLmZibyk7CiAgICB9CiAgfTsKfQpmdW5jdGlvbiBPZShpKSB7CiAgY29uc3QgZSA9IGkuY3JlYXRlQnVmZmVyKCk7CiAgcmV0dXJuIGkuYmluZEJ1ZmZlcihpLkFSUkFZX0JVRkZFUiwgZSksIGkuYnVmZmVyRGF0YShpLkFSUkFZX0JVRkZFUiwgbmV3IEZsb2F0MzJBcnJheShbLTEsIC0xLCAtMSwgMSwgMSwgMSwgMSwgLTFdKSwgaS5TVEFUSUNfRFJBVyksIGkudmVydGV4QXR0cmliUG9pbnRlcigwLCAyLCBpLkZMT0FULCAhMSwgMCwgMCksIGkuZW5hYmxlVmVydGV4QXR0cmliQXJyYXkoMCksIGZ1bmN0aW9uKG8pIHsKICAgIGkuYmluZEZyYW1lYnVmZmVyKGkuRlJBTUVCVUZGRVIsIG8pLCBpLmRyYXdBcnJheXMoaS5UUklBTkdMRV9GQU4sIDAsIDQpOwogIH07Cn0KZnVuY3Rpb24gbWUoaSwgZSwgciwgbywgcyA9ICJjb3ZlciIpIHsKICBsZXQgbjsKICBzID09PSAiY292ZXIiID8gbiA9IE1hdGgubWF4KHIgLyBpLCBvIC8gZSkgOiBzID09PSAiY29udGFpbiIgPyBuID0gTWF0aC5taW4ociAvIGksIG8gLyBlKSA6IHR5cGVvZiBzID09ICJzdHJpbmciICYmIHMuZW5kc1dpdGgoIiUiKSA/IG4gPSBNYXRoLm1pbihyIC8gaSwgbyAvIGUpICogKHBhcnNlRmxvYXQocykgLyAxMDApIDogdHlwZW9mIHMgPT0gInN0cmluZyIgJiYgcy5lbmRzV2l0aCgicHgiKSA/IG4gPSBwYXJzZUZsb2F0KHMpIC8gTWF0aC5tYXgoaSwgZSkgOiB0eXBlb2YgcyA9PSAibnVtYmVyIiA/IG4gPSBzIDogbiA9IE1hdGgubWF4KHIgLyBpLCBvIC8gZSk7CiAgY29uc3QgdSA9IGkgKiBuLCBUID0gZSAqIG47CiAgcmV0dXJuIHsgeDogKHIgLSB1KSAvIDIsIHk6IChvIC0gVCkgLyAyLCBkcmF3VzogdSwgZHJhd0g6IFQgfTsKfQpmdW5jdGlvbiBrZShpLCBlLCByLCBvLCBzID0gbnVsbCwgbiA9ICJjb3ZlciIpIHsKICBjb25zdCB7IHRleHQ6IHUsIGZvbnRTaXplOiBULCBjb2xvcjogRSwgZm9udEZhbWlseTogYyA9ICJzYW5zLXNlcmlmIiwgZm9udFdlaWdodDogaCA9IDkwMCB9ID0gbywgYiA9IG5ldyBPZmZzY3JlZW5DYW52YXMoZSwgciksIGYgPSBiLmdldENvbnRleHQoIjJkIik7CiAgKChpZSkgPT4gewogICAgaWYgKHMpIHsKICAgICAgZi5jbGVhclJlY3QoMCwgMCwgZSwgciksIGYuZmlsbFN0eWxlID0gImJsYWNrIiwgZi5maWxsUmVjdCgwLCAwLCBlLCByKTsKICAgICAgY29uc3QgeyB4OiB1ZSwgeTogbGUsIGRyYXdXOiBjZSwgZHJhd0g6IGZlIH0gPSBtZSgKICAgICAgICBzLndpZHRoLAogICAgICAgIHMuaGVpZ2h0LAogICAgICAgIGUsCiAgICAgICAgciwKICAgICAgICBuCiAgICAgICk7CiAgICAgIGYuZHJhd0ltYWdlKHMsIHVlLCBsZSwgY2UsIGZlKTsKICAgIH0gZWxzZQogICAgICBmLmZpbGxTdHlsZSA9ICJibGFjayIsIGYuZmlsbFJlY3QoMCwgMCwgZSwgcik7CiAgICBmLnNoYWRvd0NvbG9yID0gaWUsIGYuZmlsbFN0eWxlID0gaWUsIGYuZm9udCA9IGAke2h9ICR7VH1weCAke2N9YCwgZi50ZXh0QWxpZ24gPSAiY2VudGVyIiwgZi50ZXh0QmFzZWxpbmUgPSAibWlkZGxlIiwgZi5maWxsVGV4dCh1LCBlIC8gMiwgciAvIDIpOwogIH0pKEUpOwogIGNvbnN0ICQgPSBKKGksIGIpOwogIGYuZmlsbFN0eWxlID0gImJsYWNrIiwgZi5maWxsUmVjdCgwLCAwLCBlLCByKSwgZi5maWxsU3R5bGUgPSAid2hpdGUiLCBmLmZvbnQgPSBgJHtofSAke1R9cHggJHtjfWAsIGYudGV4dEFsaWduID0gImNlbnRlciIsIGYudGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIGYuZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICBjb25zdCByZSA9IEooaSwgYik7CiAgcmV0dXJuIHsgYmFja2dyb3VuZFRleDogJCwgb2JzdGFjbGVUZXg6IHJlLCBjb3ZlcmFnZVRleDogcmUgfTsKfQpmdW5jdGlvbiBJZShpLCBlLCByLCBvLCBzID0gMCwgbiA9ICJjb3ZlciIsIHUgPSBudWxsLCBUID0gImNvdmVyIikgewogIGNvbnN0IEUgPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKHIsIG8pLCBjID0gRS5nZXRDb250ZXh0KCIyZCIpLCB7IHg6IGgsIHk6IGIsIGRyYXdXOiBmLCBkcmF3SDogRCB9ID0gbWUoZS53aWR0aCwgZS5oZWlnaHQsIHIsIG8sIG4pOwogIGlmIChjLmNsZWFyUmVjdCgwLCAwLCByLCBvKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIG8pLCB1KSB7CiAgICBjb25zdCB7CiAgICAgIHg6IHVlLAogICAgICB5OiBsZSwKICAgICAgZHJhd1c6IGNlLAogICAgICBkcmF3SDogZmUKICAgIH0gPSBtZSh1LndpZHRoLCB1LmhlaWdodCwgciwgbywgVCk7CiAgICBjLmZpbHRlciA9IGBicmlnaHRuZXNzKCR7c30pIGJsdXIoOHB4KWAsIGMuZHJhd0ltYWdlKHUsIHVlLCBsZSwgY2UsIGZlKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgfQogIGMuZHJhd0ltYWdlKGUsIGgsIGIsIGYsIEQpOwogIGNvbnN0ICQgPSBKKGksIEUpOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIG8pLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgbyksIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtzfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UoZSwgaCwgYiwgZiwgRCksIGMuZmlsdGVyID0gIm5vbmUiOwogIGNvbnN0IHJlID0gSihpLCBFKTsKICBjLmNsZWFyUmVjdCgwLCAwLCByLCBvKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIG8pLCBjLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIGMuZmlsbFJlY3QoCiAgICBNYXRoLm1heCgwLCBoKSwKICAgIE1hdGgubWF4KDAsIGIpLAogICAgTWF0aC5taW4oZiwgciAtIE1hdGgubWF4KDAsIGgpKSwKICAgIE1hdGgubWluKEQsIG8gLSBNYXRoLm1heCgwLCBiKSkKICApOwogIGNvbnN0IGllID0gSihpLCBFKTsKICByZXR1cm4geyBiYWNrZ3JvdW5kVGV4OiAkLCBvYnN0YWNsZVRleDogcmUsIGNvdmVyYWdlVGV4OiBpZSB9Owp9CmZ1bmN0aW9uIEooaSwgZSkgewogIGNvbnN0IHIgPSBpLmNyZWF0ZVRleHR1cmUoKTsKICByZXR1cm4gaS5iaW5kVGV4dHVyZShpLlRFWFRVUkVfMkQsIHIpLCBpLnBpeGVsU3RvcmVpKGkuVU5QQUNLX0ZMSVBfWV9XRUJHTCwgITApLCBpLnRleEltYWdlMkQoaS5URVhUVVJFXzJELCAwLCBpLlJHQkEsIGkuUkdCQSwgaS5VTlNJR05FRF9CWVRFLCBlKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX01JTl9GSUxURVIsIGkuTElORUFSKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX01BR19GSUxURVIsIGkuTElORUFSKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX1dSQVBfUywgaS5DTEFNUF9UT19FREdFKSwgaS50ZXhQYXJhbWV0ZXJpKGkuVEVYVFVSRV8yRCwgaS5URVhUVVJFX1dSQVBfVCwgaS5DTEFNUF9UT19FREdFKSwgcjsKfQphc3luYyBmdW5jdGlvbiBNZShpKSB7CiAgY29uc3QgZSA9IGF3YWl0IGZldGNoKGkpOwogIGlmICghZS5vaykKICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGZldGNoIGltYWdlOiAke2l9ICgke2Uuc3RhdHVzfSlgKTsKICBjb25zdCByID0gYXdhaXQgZS5ibG9iKCk7CiAgcmV0dXJuIGNyZWF0ZUltYWdlQml0bWFwKHIpOwp9CmNvbnN0IHBlID0gdHlwZW9mIHJlcXVlc3RBbmltYXRpb25GcmFtZSA8ICJ1IiA/IHJlcXVlc3RBbmltYXRpb25GcmFtZS5iaW5kKGdsb2JhbFRoaXMpIDogKGkpID0+IHNldFRpbWVvdXQoaSwgMWUzIC8gNjApLCBWZSA9IHR5cGVvZiBjYW5jZWxBbmltYXRpb25GcmFtZSA8ICJ1IiA/IGNhbmNlbEFuaW1hdGlvbkZyYW1lLmJpbmQoZ2xvYmFsVGhpcykgOiBjbGVhclRpbWVvdXQsIEVlID0gMC4wMTYsIFdlID0geyBzdGFuZGFyZDogMCwgZ2xhc3M6IDEsIGluazogMiwgYXVyb3JhOiAzLCByaXBwbGU6IDQgfTsKdmFyIFYsIGcsIFEsIFcsIHEsIHAsIFIsIGssIEksIHcsIHksIHYsIFMsIEYsIFgsIEwsIFUsIEIsIEMsIEgsIEcsIHgsIF8sIEEsIHosIE4sIEssIFosIHhlLCBNLCBZLCBqLCBzZSwgZWUsIFRlLCB0ZSwgZGUsIG5lLCBiZTsKY2xhc3MgR2UgewogIGNvbnN0cnVjdG9yKGUsIHIgPSB7fSkgewogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIGhlbHBlcnMKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgbCh0aGlzLCBOKTsKICAgIGwodGhpcywgWik7CiAgICBsKHRoaXMsIE0pOwogICAgbCh0aGlzLCBqKTsKICAgIGwodGhpcywgZWUpOwogICAgbCh0aGlzLCB0ZSk7CiAgICBsKHRoaXMsIG5lKTsKICAgIGwodGhpcywgViwgdm9pZCAwKTsKICAgIGwodGhpcywgZywgdm9pZCAwKTsKICAgIGwodGhpcywgUSwgdm9pZCAwKTsKICAgIGwodGhpcywgVywgdm9pZCAwKTsKICAgIGwodGhpcywgcSwgdm9pZCAwKTsKICAgIGwodGhpcywgcCwgMCk7CiAgICBsKHRoaXMsIFIsIDApOwogICAgbCh0aGlzLCBrLCAwKTsKICAgIGwodGhpcywgSSwgMCk7CiAgICBsKHRoaXMsIHcsIDEpOwogICAgbCh0aGlzLCB5LCBudWxsKTsKICAgIGwodGhpcywgdiwgbnVsbCk7CiAgICBsKHRoaXMsIFMsIG51bGwpOwogICAgbCh0aGlzLCBGLCBudWxsKTsKICAgIGwodGhpcywgWCwgbnVsbCk7CiAgICBsKHRoaXMsIEwsIG51bGwpOwogICAgbCh0aGlzLCBVLCBudWxsKTsKICAgIGwodGhpcywgQiwgbnVsbCk7CiAgICAvLyBiaW5hcnkgY29udGVudCBtYXNrIGZvciB0cmFuc3BhcmVudCBjYW52YXMgc3VwcG9ydAogICAgbCh0aGlzLCBDLCBudWxsKTsKICAgIC8vIG9wdGlvbmFsIGJhY2tncm91bmQgaW1hZ2UgKGZyb20gYmFja2dyb3VuZFNyYyBwcm9wKQogICAgbCh0aGlzLCBILCAiY292ZXIiKTsKICAgIGwodGhpcywgRywgdm9pZCAwKTsKICAgIGwodGhpcywgeCwgeyB4OiAwLCB5OiAwLCBkeDogMCwgZHk6IDAsIHRhcmdldFg6IDAsIHRhcmdldFk6IDAsIG1vdmVkOiAhMSB9KTsKICAgIC8vIFN0b3JlcyBzb3VyY2Ugc28gdGV4dHVyZXMgY2FuIGJlIHJlYnVpbHQgb24gcmVzaXplCiAgICBsKHRoaXMsIF8sIG51bGwpOwogICAgbCh0aGlzLCBBLCBudWxsKTsKICAgIGwodGhpcywgeiwgITEpOwogICAgYSh0aGlzLCBWLCBlKSwgYSh0aGlzLCBHLCBVZShyKSk7CiAgICBjb25zdCB7IGdsOiBvLCBleHQ6IHMgfSA9IExlKGUpOwogICAgYSh0aGlzLCBnLCBvKSwgYSh0aGlzLCBRLCBzKSwgYSh0aGlzLCBXLCBQZShvKSksIGEodGhpcywgcSwgT2UobykpLCBvLmNsZWFyQ29sb3IoMCwgMCwgMCwgMCk7CiAgfQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIC8vIFB1YmxpYyBBUEkKICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICBzZXRUZXh0U291cmNlKGUpIHsKICAgIGEodGhpcywgXywgeyB0eXBlOiAidGV4dCIsIG9wdHM6IGUgfSksIGQodGhpcywgTiwgSykuY2FsbCh0aGlzKSwgZCh0aGlzLCBNLCBZKS5jYWxsKHRoaXMpLCBkKHRoaXMsIGosIHNlKS5jYWxsKHRoaXMpOwogIH0KICBhc3luYyBzZXRJbWFnZVNvdXJjZShlLCByID0gMCwgbyA9ICJjb3ZlciIpIHsKICAgIGNvbnN0IHMgPSBhd2FpdCBNZShlKTsKICAgIGEodGhpcywgXywgeyB0eXBlOiAiaW1hZ2UiLCBiaXRtYXA6IHMsIGVmZmVjdDogciwgc2l6ZTogbyB9KSwgZCh0aGlzLCBOLCBLKS5jYWxsKHRoaXMpLCBkKHRoaXMsIE0sIFkpLmNhbGwodGhpcyksIGQodGhpcywgaiwgc2UpLmNhbGwodGhpcyk7CiAgfQogIHNldEltYWdlQml0bWFwKGUsIHIgPSAwLCBvID0gImNvdmVyIikgewogICAgYSh0aGlzLCBfLCB7IHR5cGU6ICJpbWFnZSIsIGJpdG1hcDogZSwgZWZmZWN0OiByLCBzaXplOiBvIH0pLCBkKHRoaXMsIE4sIEspLmNhbGwodGhpcyksIGQodGhpcywgTSwgWSkuY2FsbCh0aGlzKSwgZCh0aGlzLCBqLCBzZSkuY2FsbCh0aGlzKTsKICB9CiAgc2V0QmFja2dyb3VuZChlLCByID0gImNvdmVyIikgewogICAgdCh0aGlzLCBDKSAmJiB0KHRoaXMsIEMpICE9PSBlICYmIHQodGhpcywgQykuY2xvc2UoKSwgYSh0aGlzLCBDLCBlKSwgYSh0aGlzLCBILCByID8/ICJjb3ZlciIpLCB0KHRoaXMsIF8pICYmIHQodGhpcywgcCkgPiAwICYmIGQodGhpcywgTSwgWSkuY2FsbCh0aGlzKTsKICB9CiAgaGFuZGxlTW92ZShlLCByLCBvID0gMSkgewogICAgdCh0aGlzLCB4KS5tb3ZlZCA9ICEwLCB0KHRoaXMsIHgpLmR4ID0gKGUgLSB0KHRoaXMsIHgpLnRhcmdldFgpICogbywgdCh0aGlzLCB4KS5keSA9IChyIC0gdCh0aGlzLCB4KS50YXJnZXRZKSAqIG8sIHQodGhpcywgeCkudGFyZ2V0WCA9IGUsIHQodGhpcywgeCkudGFyZ2V0WSA9IHI7CiAgfQogIC8qKgogICAqIEltbWVkaWF0ZWx5IGFwcGxpZXMgb25lIGZsdWlkIHNwbGF0IGF0ICh4LCB5KSB3aXRoIGV4cGxpY2l0IHZlbG9jaXR5ICh2eCwgdnkpLgogICAqIFNhZmUgdG8gY2FsbCBtdWx0aXBsZSB0aW1lcyBwZXIgZnJhbWUg4oCUIGVhY2ggY2FsbCB3cml0ZXMgZGlyZWN0bHkgdG8gdGhlIEZCT3MuCiAgICogRGVzaWduZWQgZm9yIHByb2dyYW1tYXRpYyB1c2UgY2FzZXMgKGUuZy4gcGFydGljbGUgc3lzdGVtcywgYXR0cmFjdG9yIHBhdGhzKQogICAqIHdoZXJlIHlvdSB3YW50IE4gaW5kZXBlbmRlbnQgaW5qZWN0aW9uIHBvaW50cyBwZXIgZnJhbWUgd2l0aG91dCBmbG9vZGluZyB0aGUKICAgKiBtb3VzZS1zdGF0ZSBtYWNoaW5lIG9yIHRoZSB3b3JrZXIgbWVzc2FnZSBxdWV1ZS4KICAgKi8KICBzcGxhdChlLCByLCBvLCBzLCBuID0gMSkgewogICAgaWYgKCF0KHRoaXMsIHopIHx8IHQodGhpcywgcCkgPT09IDApCiAgICAgIHJldHVybjsKICAgIGNvbnN0IHUgPSB0KHRoaXMsIGcpLCBUID0gdCh0aGlzLCBHKSwgeyBzcGxhdDogRSB9ID0gdCh0aGlzLCBXKSwgYyA9IHQodGhpcywgcSk7CiAgICB1LnZpZXdwb3J0KDAsIDAsIHQodGhpcywgayksIHQodGhpcywgSSkpLCBFLmJpbmQoKSwgdS51bmlmb3JtMWYoRS51bmlmb3Jtcy5hc3BlY3RSYXRpbywgdCh0aGlzLCBwKSAvIHQodGhpcywgUikpLCB1LnVuaWZvcm0yZihFLnVuaWZvcm1zLnBvaW50LCBlICogdCh0aGlzLCB3KSAvIHQodGhpcywgcCksIDEgLSByICogdCh0aGlzLCB3KSAvIHQodGhpcywgUikpLCB1LnVuaWZvcm0xZihFLnVuaWZvcm1zLnJhZGl1cywgVC5zcGxhdFJhZGl1cyksIHUudW5pZm9ybTFpKEUudW5pZm9ybXMudVRhcmdldCwgMCksIHUuYWN0aXZlVGV4dHVyZSh1LlRFWFRVUkUwKSwgdS5iaW5kVGV4dHVyZSh1LlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCB1LnVuaWZvcm0zZihFLnVuaWZvcm1zLmNvbG9yLCBvICogVC5zcGxhdEZvcmNlICogbiwgLXMgKiBULnNwbGF0Rm9yY2UgKiBuLCAwKSwgYyh0KHRoaXMsIHYpLndyaXRlLmZibyksIHQodGhpcywgdikuc3dhcCgpLCB1LmFjdGl2ZVRleHR1cmUodS5URVhUVVJFMCksIHUuYmluZFRleHR1cmUodS5URVhUVVJFXzJELCB0KHRoaXMsIHkpLnJlYWQudGV4KSwgdS51bmlmb3JtM2YoRS51bmlmb3Jtcy5jb2xvciwgbiwgbiwgbiksIGModCh0aGlzLCB5KS53cml0ZS5mYm8pLCB0KHRoaXMsIHkpLnN3YXAoKTsKICB9CiAgcmVzaXplKGUsIHIsIG8pIHsKICAgIGlmIChvICE9PSB2b2lkIDAgPyBhKHRoaXMsIHcsIG8pIDogdHlwZW9mIHdpbmRvdyA8ICJ1IiAmJiB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpbyAmJiBhKHRoaXMsIHcsIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvKSwgZSAhPT0gdm9pZCAwICYmIGUgPiAwKSB7CiAgICAgIGlmIChyID09PSB2b2lkIDAgfHwgciA8PSAwKQogICAgICAgIHJldHVybjsKICAgICAgYSh0aGlzLCBwLCB0KHRoaXMsIFYpLndpZHRoID0gZSksIGEodGhpcywgUiwgdCh0aGlzLCBWKS5oZWlnaHQgPSByKSwgYSh0aGlzLCBrLCBlID4+IDEpLCBhKHRoaXMsIEksIHIgPj4gMSksIGQodGhpcywgWiwgeGUpLmNhbGwodGhpcyk7CiAgICB9IGVsc2UKICAgICAgZCh0aGlzLCBOLCBLKS5jYWxsKHRoaXMpOwogICAgdCh0aGlzLCBfKSAmJiBkKHRoaXMsIE0sIFkpLmNhbGwodGhpcyk7CiAgfQogIHVwZGF0ZUNvbmZpZyhlKSB7CiAgICBPYmplY3QuYXNzaWduKHQodGhpcywgRyksIGUpOwogIH0KICBkZXN0cm95KCkgewogICAgdGhpcy5zdG9wKCk7CiAgICBjb25zdCBlID0gdCh0aGlzLCBnKTsKICAgIGQodGhpcywgZWUsIFRlKS5jYWxsKHRoaXMpLCBkKHRoaXMsIHRlLCBkZSkuY2FsbCh0aGlzKSwgdCh0aGlzLCBDKSAmJiAodCh0aGlzLCBDKS5jbG9zZSgpLCBhKHRoaXMsIEMsIG51bGwpKTsKICAgIGZvciAoY29uc3QgbyBvZiBPYmplY3QudmFsdWVzKHQodGhpcywgVykpKQogICAgICBvLmRpc3Bvc2UoKTsKICAgIGNvbnN0IHIgPSBlLmdldEV4dGVuc2lvbigiV0VCR0xfbG9zZV9jb250ZXh0Iik7CiAgICByID09IG51bGwgfHwgci5sb3NlQ29udGV4dCgpOwogIH0KICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAvLyBMb29wIGNvbnRyb2wKICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICBzdGFydCgpIHsKICAgIGlmICh0KHRoaXMsIEEpICE9PSBudWxsKQogICAgICByZXR1cm47CiAgICBjb25zdCBlID0gKCkgPT4gewogICAgICBkKHRoaXMsIG5lLCBiZSkuY2FsbCh0aGlzKSwgYSh0aGlzLCBBLCBwZShlKSk7CiAgICB9OwogICAgYSh0aGlzLCBBLCBwZShlKSk7CiAgfQogIHN0b3AoKSB7CiAgICB0KHRoaXMsIEEpICE9PSBudWxsICYmIChWZSh0KHRoaXMsIEEpKSwgYSh0aGlzLCBBLCBudWxsKSk7CiAgfQogIGdldCBpc1J1bm5pbmcoKSB7CiAgICByZXR1cm4gdCh0aGlzLCBBKSAhPT0gbnVsbDsKICB9Cn0KViA9IG5ldyBXZWFrTWFwKCksIGcgPSBuZXcgV2Vha01hcCgpLCBRID0gbmV3IFdlYWtNYXAoKSwgVyA9IG5ldyBXZWFrTWFwKCksIHEgPSBuZXcgV2Vha01hcCgpLCBwID0gbmV3IFdlYWtNYXAoKSwgUiA9IG5ldyBXZWFrTWFwKCksIGsgPSBuZXcgV2Vha01hcCgpLCBJID0gbmV3IFdlYWtNYXAoKSwgdyA9IG5ldyBXZWFrTWFwKCksIHkgPSBuZXcgV2Vha01hcCgpLCB2ID0gbmV3IFdlYWtNYXAoKSwgUyA9IG5ldyBXZWFrTWFwKCksIEYgPSBuZXcgV2Vha01hcCgpLCBYID0gbmV3IFdlYWtNYXAoKSwgTCA9IG5ldyBXZWFrTWFwKCksIFUgPSBuZXcgV2Vha01hcCgpLCBCID0gbmV3IFdlYWtNYXAoKSwgQyA9IG5ldyBXZWFrTWFwKCksIEggPSBuZXcgV2Vha01hcCgpLCBHID0gbmV3IFdlYWtNYXAoKSwgeCA9IG5ldyBXZWFrTWFwKCksIF8gPSBuZXcgV2Vha01hcCgpLCBBID0gbmV3IFdlYWtNYXAoKSwgeiA9IG5ldyBXZWFrTWFwKCksIE4gPSBuZXcgV2Vha1NldCgpLCBLID0gZnVuY3Rpb24oKSB7CiAgY29uc3QgZSA9IHQodGhpcywgVik7CiAgImNsaWVudFdpZHRoIiBpbiBlICYmIGUuY2xpZW50V2lkdGggPiAwID8gKGEodGhpcywgdywgdHlwZW9mIHdpbmRvdyA8ICJ1IiAmJiB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpbyB8fCAxKSwgYSh0aGlzLCBwLCBlLndpZHRoID0gTWF0aC5yb3VuZChlLmNsaWVudFdpZHRoICogdCh0aGlzLCB3KSkpLCBhKHRoaXMsIFIsIGUuaGVpZ2h0ID0gTWF0aC5yb3VuZChlLmNsaWVudEhlaWdodCAqIHQodGhpcywgdykpKSkgOiAoYSh0aGlzLCBwLCBlLndpZHRoKSwgYSh0aGlzLCBSLCBlLmhlaWdodCkpLCAhKHQodGhpcywgcCkgPT09IDAgfHwgdCh0aGlzLCBSKSA9PT0gMCkgJiYgKGEodGhpcywgaywgdCh0aGlzLCBwKSA+PiAxKSwgYSh0aGlzLCBJLCB0KHRoaXMsIFIpID4+IDEpLCBkKHRoaXMsIFosIHhlKS5jYWxsKHRoaXMpKTsKfSwgWiA9IG5ldyBXZWFrU2V0KCksIHhlID0gZnVuY3Rpb24oKSB7CiAgY29uc3QgZSA9IHQodGhpcywgZyksIHIgPSB0KHRoaXMsIFEpLCBvID0gdCh0aGlzLCBrKSwgcyA9IHQodGhpcywgSSk7CiAgZCh0aGlzLCBlZSwgVGUpLmNhbGwodGhpcyksIGEodGhpcywgeSwgaGUoZSwgciwgbywgcykpLCBhKHRoaXMsIHYsIGhlKGUsIHIsIG8sIHMpKSwgYSh0aGlzLCBGLCBoZShlLCByLCBvLCBzKSksIGEodGhpcywgUywgYWUoZSwgciwgbywgcykpLCBhKHRoaXMsIFgsIGFlKGUsIHIsIG8sIHMpKTsKfSwgTSA9IG5ldyBXZWFrU2V0KCksIFkgPSBmdW5jdGlvbigpIHsKICBpZiAoISghdCh0aGlzLCBfKSB8fCB0KHRoaXMsIHApID09PSAwKSkgewogICAgaWYgKGQodGhpcywgdGUsIGRlKS5jYWxsKHRoaXMpLCB0KHRoaXMsIF8pLnR5cGUgPT09ICJ0ZXh0IikgewogICAgICBjb25zdCB7IGJhY2tncm91bmRUZXg6IGUsIG9ic3RhY2xlVGV4OiByLCBjb3ZlcmFnZVRleDogbyB9ID0ga2UoCiAgICAgICAgdCh0aGlzLCBnKSwKICAgICAgICB0KHRoaXMsIHApLAogICAgICAgIHQodGhpcywgUiksCiAgICAgICAgdCh0aGlzLCBfKS5vcHRzLAogICAgICAgIHQodGhpcywgQyksCiAgICAgICAgdCh0aGlzLCBIKQogICAgICApOwogICAgICBhKHRoaXMsIEwsIGUpLCBhKHRoaXMsIFUsIHIpLCBhKHRoaXMsIEIsIG8pOwogICAgfSBlbHNlIHsKICAgICAgY29uc3QgeyBiYWNrZ3JvdW5kVGV4OiBlLCBvYnN0YWNsZVRleDogciwgY292ZXJhZ2VUZXg6IG8gfSA9IEllKAogICAgICAgIHQodGhpcywgZyksCiAgICAgICAgdCh0aGlzLCBfKS5iaXRtYXAsCiAgICAgICAgdCh0aGlzLCBwKSwKICAgICAgICB0KHRoaXMsIFIpLAogICAgICAgIHQodGhpcywgXykuZWZmZWN0LAogICAgICAgIHQodGhpcywgXykuc2l6ZSwKICAgICAgICB0KHRoaXMsIEMpLAogICAgICAgIHQodGhpcywgSCkKICAgICAgKTsKICAgICAgYSh0aGlzLCBMLCBlKSwgYSh0aGlzLCBVLCByKSwgYSh0aGlzLCBCLCBvKTsKICAgIH0KICAgIGEodGhpcywgeiwgITApOwogIH0KfSwgaiA9IG5ldyBXZWFrU2V0KCksIHNlID0gZnVuY3Rpb24oKSB7CiAgdCh0aGlzLCB6KSAmJiAhdGhpcy5pc1J1bm5pbmcgJiYgdGhpcy5zdGFydCgpOwp9LCBlZSA9IG5ldyBXZWFrU2V0KCksIFRlID0gZnVuY3Rpb24oKSB7CiAgdmFyIGUsIHIsIG87CiAgKGUgPSB0KHRoaXMsIHkpKSA9PSBudWxsIHx8IGUuZGlzcG9zZSgpLCAociA9IHQodGhpcywgdikpID09IG51bGwgfHwgci5kaXNwb3NlKCksIChvID0gdCh0aGlzLCBGKSkgPT0gbnVsbCB8fCBvLmRpc3Bvc2UoKSwgdCh0aGlzLCBTKSAmJiAodCh0aGlzLCBnKS5kZWxldGVUZXh0dXJlKHQodGhpcywgUykudGV4KSwgdCh0aGlzLCBnKS5kZWxldGVGcmFtZWJ1ZmZlcih0KHRoaXMsIFMpLmZibykpLCB0KHRoaXMsIFgpICYmICh0KHRoaXMsIGcpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBYKS50ZXgpLCB0KHRoaXMsIGcpLmRlbGV0ZUZyYW1lYnVmZmVyKHQodGhpcywgWCkuZmJvKSksIGEodGhpcywgeSwgYSh0aGlzLCB2LCBhKHRoaXMsIEYsIGEodGhpcywgUywgYSh0aGlzLCBYLCBudWxsKSkpKSk7Cn0sIHRlID0gbmV3IFdlYWtTZXQoKSwgZGUgPSBmdW5jdGlvbigpIHsKICB0KHRoaXMsIEwpICYmIHQodGhpcywgZykuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIEwpKSwgdCh0aGlzLCBVKSAmJiB0KHRoaXMsIGcpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBVKSksIHQodGhpcywgQikgJiYgdCh0aGlzLCBCKSAhPT0gdCh0aGlzLCBVKSAmJiB0KHRoaXMsIGcpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBCKSksIGEodGhpcywgTCwgYSh0aGlzLCBVLCBhKHRoaXMsIEIsIG51bGwpKSk7Cn0sIG5lID0gbmV3IFdlYWtTZXQoKSwgYmUgPSBmdW5jdGlvbigpIHsKICBpZiAoIXQodGhpcywgeikgfHwgdCh0aGlzLCBwKSA9PT0gMCkKICAgIHJldHVybjsKICBjb25zdCBlID0gdCh0aGlzLCBnKSwgciA9IHQodGhpcywgRyksIHsgYWR2ZWN0aW9uOiBvLCBkaXZlcmdlbmNlOiBzLCBwcmVzc3VyZTogbiwgZ3JhZGllbnRTdWJ0cmFjdDogdSwgc3BsYXQ6IFQsIGN1cmw6IEUsIHZvcnRpY2l0eTogYywgZGlzcGxheTogaCB9ID0gdCh0aGlzLCBXKTsKICB0KHRoaXMsIHgpLnggKz0gKHQodGhpcywgeCkudGFyZ2V0WCAtIHQodGhpcywgeCkueCkgKiAwLjE1LCB0KHRoaXMsIHgpLnkgKz0gKHQodGhpcywgeCkudGFyZ2V0WSAtIHQodGhpcywgeCkueSkgKiAwLjE1OwogIGNvbnN0IGIgPSB0KHRoaXMsIGspLCBmID0gdCh0aGlzLCBJKSwgRCA9IHQodGhpcywgcSk7CiAgZS52aWV3cG9ydCgwLCAwLCBiLCBmKSwgby5iaW5kKCksIGUudW5pZm9ybTJmKG8udW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gYiwgMSAvIGYpLCBlLnVuaWZvcm0xZihvLnVuaWZvcm1zLmR0LCBFZSksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudU9ic3RhY2xlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBVKSksIGUudW5pZm9ybTFmKG8udW5pZm9ybXMuZGlzc2lwYXRpb24sIHIudmVsb2NpdHlEaXNzaXBhdGlvbiksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudVZlbG9jaXR5LCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCB2KS5yZWFkLnRleCksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudVNvdXJjZSwgMSksIEQodCh0aGlzLCB2KS53cml0ZS5mYm8pLCB0KHRoaXMsIHYpLnN3YXAoKSwgZS51bmlmb3JtMWYoby51bmlmb3Jtcy5kaXNzaXBhdGlvbiwgci5kZW5zaXR5RGlzc2lwYXRpb24pLCBlLnVuaWZvcm0xaShvLnVuaWZvcm1zLnVTb3VyY2UsIDIpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIHkpLnJlYWQudGV4KSwgRCh0KHRoaXMsIHkpLndyaXRlLmZibyksIHQodGhpcywgeSkuc3dhcCgpLCBFLmJpbmQoKSwgZS51bmlmb3JtMmYoRS51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyBiLCAxIC8gZiksIGUudW5pZm9ybTFpKEUudW5pZm9ybXMudVZlbG9jaXR5LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCB2KS5yZWFkLnRleCksIEQodCh0aGlzLCBYKS5mYm8pLCBjLmJpbmQoKSwgZS51bmlmb3JtMmYoYy51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyBiLCAxIC8gZiksIGUudW5pZm9ybTFmKGMudW5pZm9ybXMuY3VybCwgci5jdXJsKSwgZS51bmlmb3JtMWYoYy51bmlmb3Jtcy5kdCwgRWUpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVWZWxvY2l0eSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVDdXJsLCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBYKS50ZXgpLCBEKHQodGhpcywgdikud3JpdGUuZmJvKSwgdCh0aGlzLCB2KS5zd2FwKCksIHQodGhpcywgeCkubW92ZWQgJiYgKFQuYmluZCgpLCBlLnVuaWZvcm0xZihULnVuaWZvcm1zLmFzcGVjdFJhdGlvLCB0KHRoaXMsIHApIC8gdCh0aGlzLCBSKSksIGUudW5pZm9ybTJmKFQudW5pZm9ybXMucG9pbnQsIHQodGhpcywgeCkueCAqIHQodGhpcywgdykgLyB0KHRoaXMsIHApLCAxIC0gdCh0aGlzLCB4KS55ICogdCh0aGlzLCB3KSAvIHQodGhpcywgUikpLCBlLnVuaWZvcm0xZihULnVuaWZvcm1zLnJhZGl1cywgci5zcGxhdFJhZGl1cyksIGUudW5pZm9ybTFpKFQudW5pZm9ybXMudVRhcmdldCwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0zZihULnVuaWZvcm1zLmNvbG9yLCB0KHRoaXMsIHgpLmR4ICogci5zcGxhdEZvcmNlLCAtdCh0aGlzLCB4KS5keSAqIHIuc3BsYXRGb3JjZSwgMCksIEQodCh0aGlzLCB2KS53cml0ZS5mYm8pLCB0KHRoaXMsIHYpLnN3YXAoKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCB5KS5yZWFkLnRleCksIGUudW5pZm9ybTNmKFQudW5pZm9ybXMuY29sb3IsIDEsIDEsIDEpLCBEKHQodGhpcywgeSkud3JpdGUuZmJvKSwgdCh0aGlzLCB5KS5zd2FwKCksIHQodGhpcywgeCkubW92ZWQgPSAhMSksIHMuYmluZCgpLCBlLnVuaWZvcm0yZihzLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIGIsIDEgLyBmKSwgZS51bmlmb3JtMWkocy51bmlmb3Jtcy51VmVsb2NpdHksIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIHYpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkocy51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFUpKSwgRCh0KHRoaXMsIFMpLmZibyksIG4uYmluZCgpLCBlLnVuaWZvcm0yZihuLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIGIsIDEgLyBmKSwgZS51bmlmb3JtMWkobi51bmlmb3Jtcy51RGl2ZXJnZW5jZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUykudGV4KSwgZS51bmlmb3JtMWkobi51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFUpKTsKICBmb3IgKGxldCAkID0gMDsgJCA8IHIucHJlc3N1cmVJdGVyYXRpb25zOyAkKyspCiAgICBlLnVuaWZvcm0xaShuLnVuaWZvcm1zLnVQcmVzc3VyZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgRikucmVhZC50ZXgpLCBEKHQodGhpcywgRikud3JpdGUuZmJvKSwgdCh0aGlzLCBGKS5zd2FwKCk7CiAgdS5iaW5kKCksIGUudW5pZm9ybTJmKHUudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gYiwgMSAvIGYpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVQcmVzc3VyZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgRikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVWZWxvY2l0eSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVPYnN0YWNsZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpLCBEKHQodGhpcywgdikud3JpdGUuZmJvKSwgdCh0aGlzLCB2KS5zd2FwKCksIGUudmlld3BvcnQoMCwgMCwgdCh0aGlzLCBwKSwgdCh0aGlzLCBSKSksIGUuYmluZEZyYW1lYnVmZmVyKGUuRlJBTUVCVUZGRVIsIG51bGwpLCBlLmNsZWFyKGUuQ09MT1JfQlVGRkVSX0JJVCksIGguYmluZCgpLCBlLnVuaWZvcm0yZihoLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHQodGhpcywgcCksIDEgLyB0KHRoaXMsIFIpKSwgZS51bmlmb3JtM2Z2KGgudW5pZm9ybXMudVdhdGVyQ29sb3IsIHIud2F0ZXJDb2xvciksIGUudW5pZm9ybTNmdihoLnVuaWZvcm1zLnVHbG93Q29sb3IsIHIuZ2xvd0NvbG9yKSwgZS51bmlmb3JtMWYoaC51bmlmb3Jtcy51UmVmcmFjdGlvbiwgci5yZWZyYWN0aW9uKSwgZS51bmlmb3JtMWYoaC51bmlmb3Jtcy51U3BlY3VsYXJFeHAsIHIuc3BlY3VsYXJFeHApLCBlLnVuaWZvcm0xZihoLnVuaWZvcm1zLnVTaGluZSwgci5zaGluZSksIGUudW5pZm9ybTFmKGgudW5pZm9ybXMudVdhcnBTdHJlbmd0aCwgci53YXJwU3RyZW5ndGggPz8gMC4wMTUpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVBbGdvcml0aG0sIFdlW3IuYWxnb3JpdGhtXSA/PyAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCB5KS5yZWFkLnRleCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTMpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBCKSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkU0KSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVUZXh0dXJlLCAwKSwgZS51bmlmb3JtMWkoaC51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVCYWNrZ3JvdW5kLCAyKSwgZS51bmlmb3JtMWkoaC51bmlmb3Jtcy51Q292ZXJhZ2UsIDMpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVWZWxvY2l0eSwgNCksIEQobnVsbCk7Cn07CmxldCBtID0gbnVsbDsKc2VsZi5vbm1lc3NhZ2UgPSBhc3luYyAoaSkgPT4gewogIGNvbnN0IHsgdHlwZTogZSwgLi4uciB9ID0gaS5kYXRhOwogIHRyeSB7CiAgICBzd2l0Y2ggKGUpIHsKICAgICAgY2FzZSAiaW5pdCI6IHsKICAgICAgICBjb25zdCB7IGNhbnZhczogbywgd2lkdGg6IHMsIGhlaWdodDogbiwgY29uZmlnOiB1LCBkcHI6IFQgfSA9IHI7CiAgICAgICAgby53aWR0aCA9IHMsIG8uaGVpZ2h0ID0gbiwgbSA9IG5ldyBHZShvLCB1KSwgbS5yZXNpemUocywgbiwgVCB8fCAxKSwgc2VsZi5wb3N0TWVzc2FnZSh7IHR5cGU6ICJyZWFkeSIgfSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0VGV4dFNvdXJjZSI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS5zZXRUZXh0U291cmNlKHIub3B0cyk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0SW1hZ2VTb3VyY2UiOiB7CiAgICAgICAgaWYgKCFtKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIGF3YWl0IG0uc2V0SW1hZ2VTb3VyY2UoCiAgICAgICAgICByLnNyYywKICAgICAgICAgIHIuZWZmZWN0LAogICAgICAgICAgci5zaXplCiAgICAgICAgKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRJbWFnZUJpdG1hcCI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS5zZXRJbWFnZUJpdG1hcCgKICAgICAgICAgIHIuYml0bWFwLAogICAgICAgICAgci5lZmZlY3QsCiAgICAgICAgICByLnNpemUKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNldEJhY2tncm91bmQiOiB7CiAgICAgICAgaWYgKCFtKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIG0uc2V0QmFja2dyb3VuZChyLmJpdG1hcCwgci5zaXplKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzcGxhdCI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS5zcGxhdCgKICAgICAgICAgIHIueCwKICAgICAgICAgIHIueSwKICAgICAgICAgIHIudngsCiAgICAgICAgICByLnZ5LAogICAgICAgICAgci5zdHJlbmd0aCA/PyAxCiAgICAgICAgKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJtb3ZlIjogewogICAgICAgIGlmICghbSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBtLmhhbmRsZU1vdmUoci54LCByLnksIHIuc3RyZW5ndGggPz8gMSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAicmVzaXplIjogewogICAgICAgIGlmICghbSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBtLnJlc2l6ZShyLndpZHRoLCByLmhlaWdodCwgci5kcHIpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInVwZGF0ZUNvbmZpZyI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS51cGRhdGVDb25maWcoci5jb25maWcpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgImRlc3Ryb3kiOiB7CiAgICAgICAgbSA9PSBudWxsIHx8IG0uZGVzdHJveSgpLCBtID0gbnVsbDsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBkZWZhdWx0OgogICAgICAgIGNvbnNvbGUud2FybigiW2ZsdWlkaXR5LWpzIHdvcmtlcl0gVW5rbm93biBtZXNzYWdlIHR5cGU6IiwgZSk7CiAgICB9CiAgfSBjYXRjaCAobykgewogICAgc2VsZi5wb3N0TWVzc2FnZSh7IHR5cGU6ICJlcnJvciIsIG1lc3NhZ2U6IChvID09IG51bGwgPyB2b2lkIDAgOiBvLm1lc3NhZ2UpID8/IFN0cmluZyhvKSB9KTsKICB9Cn07Cg==", fg = typeof window < "u" && window.Blob && new Blob([atob(Og)], { type: "text/javascript;charset=utf-8" });
|
|
669
|
-
function
|
|
670
|
-
let
|
|
679
|
+
const PI = "dmFyIFVlID0gT2JqZWN0LmRlZmluZVByb3BlcnR5Owp2YXIgX2UgPSAoaSwgZSwgcikgPT4gZSBpbiBpID8gVWUoaSwgZSwgeyBlbnVtZXJhYmxlOiAhMCwgY29uZmlndXJhYmxlOiAhMCwgd3JpdGFibGU6ICEwLCB2YWx1ZTogciB9KSA6IGlbZV0gPSByOwp2YXIgbmUgPSAoaSwgZSwgcikgPT4gKF9lKGksIHR5cGVvZiBlICE9ICJzeW1ib2wiID8gZSArICIiIDogZSwgciksIHIpLCB4ZSA9IChpLCBlLCByKSA9PiB7CiAgaWYgKCFlLmhhcyhpKSkKICAgIHRocm93IFR5cGVFcnJvcigiQ2Fubm90ICIgKyByKTsKfTsKdmFyIHQgPSAoaSwgZSwgcikgPT4gKHhlKGksIGUsICJyZWFkIGZyb20gcHJpdmF0ZSBmaWVsZCIpLCByID8gci5jYWxsKGkpIDogZS5nZXQoaSkpLCBsID0gKGksIGUsIHIpID0+IHsKICBpZiAoZS5oYXMoaSkpCiAgICB0aHJvdyBUeXBlRXJyb3IoIkNhbm5vdCBhZGQgdGhlIHNhbWUgcHJpdmF0ZSBtZW1iZXIgbW9yZSB0aGFuIG9uY2UiKTsKICBlIGluc3RhbmNlb2YgV2Vha1NldCA/IGUuYWRkKGkpIDogZS5zZXQoaSwgcik7Cn0sIGEgPSAoaSwgZSwgciwgbykgPT4gKHhlKGksIGUsICJ3cml0ZSB0byBwcml2YXRlIGZpZWxkIiksIG8gPyBvLmNhbGwoaSwgcikgOiBlLnNldChpLCByKSwgcik7CnZhciBUID0gKGksIGUsIHIpID0+ICh4ZShpLCBlLCAiYWNjZXNzIHByaXZhdGUgbWV0aG9kIiksIHIpOwpjb25zdCB5ZSA9IHsKICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTkyLAogIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgcHJlc3N1cmVJdGVyYXRpb25zOiAxLAogIGN1cmw6IDFlLTQsCiAgc3BsYXRSYWRpdXM6IDRlLTMsCiAgc3BsYXRGb3JjZTogMC45MSwKICByZWZyYWN0aW9uOiAwLjI1LAogIHNwZWN1bGFyRXhwOiAxLjAxLAogIHNoaW5lOiAwLjAxLAogIHdhdGVyQ29sb3I6IFswLCAwLCAwXSwKICBnbG93Q29sb3I6IFswLjcsIDAuODUsIDFdLAogIGFsZ29yaXRobTogInN0YW5kYXJkIiwKICB3YXJwU3RyZW5ndGg6IDAuMDE1Cn07Cih7CiAgLi4ueWUKfSk7CmNvbnN0IHdlID0gewogIGNhbG06IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45OTksCiAgICB2ZWxvY2l0eURpc3NpcGF0aW9uOiAwLjk4LAogICAgY3VybDogMWUtNCwKICAgIHNwbGF0UmFkaXVzOiAzZS0zLAogICAgc3BsYXRGb3JjZTogMC41LAogICAgcmVmcmFjdGlvbjogMC4xNSwKICAgIHNoaW5lOiA1ZS0zLAogICAgZ2xvd0NvbG9yOiBbMC42LCAwLjg1LCAxXSwKICAgIHdhdGVyQ29sb3I6IFswLCAwLjAyLCAwLjA1XQogIH0sCiAgc2FuZDogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NywKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTgsCiAgICBjdXJsOiAxLAogICAgc3BsYXRSYWRpdXM6IDAuMDEsCiAgICBzcGxhdEZvcmNlOiAwLjksCiAgICByZWZyYWN0aW9uOiAwLjgsCiAgICBzcGVjdWxhckV4cDogMC4xLAogICAgc2hpbmU6IDAuMDUsCiAgICBnbG93Q29sb3I6IFswLjAyNywgMC4wMjcsIDAuMDI3XSwKICAgIHdhdGVyQ29sb3I6IFswLjQ1MSwgMC4zMjksIDAuMTI1XQogIH0sCiAgd2F2ZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NCwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTIsCiAgICBjdXJsOiAwLjIsCiAgICBzcGxhdFJhZGl1czogNWUtMywKICAgIHNwbGF0Rm9yY2U6IDEuMiwKICAgIHJlZnJhY3Rpb246IDAuMzUsCiAgICBzaGluZTogMC4wMywKICAgIGdsb3dDb2xvcjogWzAuNSwgMC44LCAxXSwKICAgIHdhdGVyQ29sb3I6IFswLCAwLjAxLCAwLjAzXQogIH0sCiAgbmVvbjogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk4NSwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgICBjdXJsOiAwLjA1LAogICAgc3BsYXRSYWRpdXM6IDhlLTMsCiAgICBzcGxhdEZvcmNlOiAxLjUsCiAgICByZWZyYWN0aW9uOiAwLjI1LAogICAgc3BlY3VsYXJFeHA6IDAuNSwKICAgIHNoaW5lOiAwLjE0LAogICAgZ2xvd0NvbG9yOiBbMSwgMC4yLCAwLjhdLAogICAgd2F0ZXJDb2xvcjogWzAuMDUsIDAsIDAuMDhdCiAgfSwKICBzbW9rZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NiwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTcsCiAgICBjdXJsOiAwLjA0LAogICAgc3BsYXRSYWRpdXM6IDllLTMsCiAgICBzcGxhdEZvcmNlOiAwLjgsCiAgICByZWZyYWN0aW9uOiAwLjA4LAogICAgc2hpbmU6IDAsCiAgICBnbG93Q29sb3I6IFswLjUsIDAuNSwgMC41XSwKICAgIHdhdGVyQ29sb3I6IFswLjA2LCAwLjA2LCAwLjA2XQogIH0KfTsKZnVuY3Rpb24gU2UoaSA9IHt9LCBlLCByID0geWUpIHsKICByZXR1cm4geyAuLi5lID8geyAuLi5yLCAuLi53ZVtlXSB9IDogciwgLi4uaSB9Owp9CmNvbnN0IFAgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgYXR0cmlidXRlIHZlYzIgYVBvc2l0aW9uOwogIHZhcnlpbmcgdmVjMiB2VXY7CiAgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gdmVjMiB0ZXhlbFNpemU7CiAgdm9pZCBtYWluICgpIHsKICAgIHZVdiA9IGFQb3NpdGlvbiAqIDAuNSArIDAuNTsKICAgIHZMID0gdlV2IC0gdmVjMih0ZXhlbFNpemUueCwgMC4wKTsKICAgIHZSID0gdlV2ICsgdmVjMih0ZXhlbFNpemUueCwgMC4wKTsKICAgIHZUID0gdlV2ICsgdmVjMigwLjAsIHRleGVsU2l6ZS55KTsKICAgIHZCID0gdlV2IC0gdmVjMigwLjAsIHRleGVsU2l6ZS55KTsKICAgIGdsX1Bvc2l0aW9uID0gdmVjNChhUG9zaXRpb24sIDAuMCwgMS4wKTsKICB9CmAKKSwgQ2UgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVNvdXJjZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdW5pZm9ybSB2ZWMyIHRleGVsU2l6ZTsKICB1bmlmb3JtIGZsb2F0IGR0OwogIHVuaWZvcm0gZmxvYXQgZGlzc2lwYXRpb247CiAgdm9pZCBtYWluICgpIHsKICAgIGlmICh0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VXYpLnIgPiAwLjUpIHsgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjApOyByZXR1cm47IH0KICAgIHZlYzIgY29vcmQgPSB2VXYgLSBkdCAqIHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHkgKiB0ZXhlbFNpemU7CiAgICBnbF9GcmFnQ29sb3IgPSBkaXNzaXBhdGlvbiAqIHRleHR1cmUyRCh1U291cmNlLCBjb29yZCk7CiAgfQpgCiksIEZlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkwpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2TCkueDsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2UikuciA+IDAuNSA/IDAuMCA6IHRleHR1cmUyRCh1VmVsb2NpdHksIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZUKS5yID4gMC41ID8gMC4wIDogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLnk7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkIpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2QikueTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoMC41ICogKFIgLSBMICsgVCAtIEIpLCAwLjAsIDAuMCwgMS4wKTsKICB9CmAKKSwgWGUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVQcmVzc3VyZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1RGl2ZXJnZW5jZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEMgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2VXYpLng7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkwpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkwpLng7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlIpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlQpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkIpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkIpLng7CiAgICBmbG9hdCBkaXYgPSB0ZXh0dXJlMkQodURpdmVyZ2VuY2UsIHZVdikueDsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoKEwgKyBSICsgQiArIFQgLSBkaXYpICogMC4yNSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIEJlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1UHJlc3N1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgaWYgKHRleHR1cmUyRCh1T2JzdGFjbGUsIHZVdikuciA+IDAuNSkgeyBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuMCk7IHJldHVybjsgfQogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZUKS54OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZCKS54OwogICAgdmVjMiB2ZWwgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5IC0gdmVjMihSIC0gTCwgVCAtIEIpOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCh2ZWwsIDAuMCwgMS4wKTsKICB9CmAKKSwgQWUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VGFyZ2V0OwogIHVuaWZvcm0gZmxvYXQgYXNwZWN0UmF0aW87CiAgdW5pZm9ybSB2ZWMzIGNvbG9yOwogIHVuaWZvcm0gdmVjMiBwb2ludDsKICB1bmlmb3JtIGZsb2F0IHJhZGl1czsKICB2b2lkIG1haW4gKCkgewogICAgdmVjMiBwID0gdlV2IC0gcG9pbnQueHk7CiAgICBwLnggKj0gYXNwZWN0UmF0aW87CiAgICB2ZWMzIHNwbGF0ID0gZXhwKC1kb3QocCwgcCkgLyByYWRpdXMpICogY29sb3I7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KHRleHR1cmUyRCh1VGFyZ2V0LCB2VXYpLnh5eiArIHNwbGF0LCAxLjApOwogIH0KYAopLCBMZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkwpLnk7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlIpLnk7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkIpLng7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuNSAqIChSIC0gTCAtIFQgKyBCKSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIE1lID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdUN1cmw7CiAgdW5pZm9ybSBmbG9hdCBjdXJsOwogIHVuaWZvcm0gZmxvYXQgZHQ7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodUN1cmwsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1Q3VybCwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVDdXJsLCB2VCkueDsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodUN1cmwsIHZCKS54OwogICAgZmxvYXQgQyA9IHRleHR1cmUyRCh1Q3VybCwgdlV2KS54OwogICAgdmVjMiBmb3JjZSA9IDAuNSAqIHZlYzIoYWJzKFQpIC0gYWJzKEIpLCBhYnMoUikgLSBhYnMoTCkpOwogICAgZm9yY2UgLz0gbGVuZ3RoKGZvcmNlKSArIDAuMDAwMTsKICAgIGZvcmNlICo9IGN1cmwgKiAzMC4wICogQzsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQodGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSArIGZvcmNlICogZHQsIDAuMCwgMS4wKTsKICB9CmAKKSwgUGUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKCiAgdW5pZm9ybSBzYW1wbGVyMkQgdVRleHR1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVCYWNrZ3JvdW5kOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVDb3ZlcmFnZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CgogIHVuaWZvcm0gdmVjMiAgdGV4ZWxTaXplOwogIHVuaWZvcm0gdmVjMyAgdVdhdGVyQ29sb3I7CiAgdW5pZm9ybSB2ZWMzICB1R2xvd0NvbG9yOwogIHVuaWZvcm0gZmxvYXQgdVJlZnJhY3Rpb247CiAgdW5pZm9ybSBmbG9hdCB1U3BlY3VsYXJFeHA7CiAgdW5pZm9ybSBmbG9hdCB1U2hpbmU7CiAgdW5pZm9ybSBmbG9hdCB1V2FycFN0cmVuZ3RoOwogIHVuaWZvcm0gaW50ICAgdUFsZ29yaXRobTsKCiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IG9icyAgICAgID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgIHZVdikucjsKICAgIC8vIE1hc2sgZGVuc2l0eSBpbnNpZGUgb2JzdGFjbGVzIHNvIHNwbGF0cyBkb24ndCBmbGlja2VyIHRoZSB0ZXh0L2ltYWdlIGNvbnRlbnQuCiAgICBmbG9hdCBkZW5zaXR5ICA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdikuciwgMC4wKSAqICgxLjAgLSBzdGVwKDAuNSwgb2JzKSk7CiAgICBmbG9hdCBjb3ZlcmFnZSA9IHRleHR1cmUyRCh1Q292ZXJhZ2UsICB2VXYpLnI7CgogICAgZmxvYXQgZEwgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgLSB2ZWMyKHRleGVsU2l6ZS54ICogMi4wLCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZFIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKHRleGVsU2l6ZS54ICogMi4wLCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZFQgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkgKiAyLjApKS5yLCAwLjApOwogICAgZmxvYXQgZEIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgLSB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkgKiAyLjApKS5yLCAwLjApOwoKICAgIHZlYzMgIG5vcm1hbCAgID0gbm9ybWFsaXplKHZlYzMoZEwgLSBkUiwgZEIgLSBkVCwgMC4yKSk7CiAgICB2ZWMzICBsaWdodERpciA9IG5vcm1hbGl6ZSh2ZWMzKDAuNSwgMS4wLCAwLjUpKTsKICAgIHZlYzMgIGhhbGZWICAgID0gbm9ybWFsaXplKGxpZ2h0RGlyICsgdmVjMygwLjAsIDAuMCwgMS4wKSk7CiAgICBmbG9hdCBzcGVjICAgICA9IHBvdyhtYXgoZG90KG5vcm1hbCwgaGFsZlYpLCAwLjApLCB1U3BlY3VsYXJFeHApICogdVNoaW5lICogZGVuc2l0eTsKCiAgICAvLyBJbiB0cmFuc3BhcmVudCAobm9uLWNvdmVyYWdlKSBhcmVhcyB0aGUgYmFja2dyb3VuZCB0ZXh0dXJlIGlzIGVtcHR5IGJsYWNrIGNhbnZhcy4KICAgIC8vIFJlcGxhY2UgaXQgd2l0aCB1V2F0ZXJDb2xvciBzbyBmbHVpZCBjb2xvdXIgaXMgbm90IGNvbnRhbWluYXRlZCBieSB0aGF0IGJsYWNrLAogICAgLy8gYWxsb3dpbmcgdGhlIENTUyBiYWNrZ3JvdW5kQ29sb3IgdG8gc2hvdyB0aHJvdWdoIGNvcnJlY3RseSB2aWEgcHJlbXVsdGlwbGllZCBhbHBoYS4KICAgIHZlYzMgYmdSYXcgPSB0ZXh0dXJlMkQodUJhY2tncm91bmQsIHZVdikucmdiOwogICAgdmVjMyBiZyAgICA9IG1peCh1V2F0ZXJDb2xvciwgYmdSYXcsIGNvdmVyYWdlKTsKICAgIHZlYzMgY29sb3IgPSBiZzsKCiAgICBpZiAodUFsZ29yaXRobSA9PSAxKSB7CiAgICAgIC8vIOKUgOKUgCBnbGFzcyDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gU3Ryb25nIFVWIGRpc3RvcnRpb24gb25seS4gSW1hZ2UgYmVuZHMgYnV0IG5vIGNvbG91ciBvdmVybGF5LgogICAgICB2ZWMyIHJlZnJVdiA9IGNsYW1wKHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eSAqIDMuMCwgMC4wLCAxLjApOwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciA9IHJlZnJCZyArIHNwZWMgKiB1R2xvd0NvbG9yICogMi41OwogICAgICBjb2xvciA9IG1peChjb2xvciwgYmcgKiAwLjYsIG9icyAqIDAuMyk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDIpIHsKICAgICAgLy8g4pSA4pSAIGluayDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gRGVuc2Ugb3BhcXVlIHBpZ21lbnQgdGhhdCBzdGFpbnMuIFN1YnRsZSByZWZyYWN0aW9uIHVuZGVybmVhdGguCiAgICAgIGZsb2F0IGlua0QgID0gbWluKGRlbnNpdHkgKiA0LjAsIDEuMCk7CiAgICAgIHZlYzIgcmVmclV2ID0gY2xhbXAodlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5ICogMC40LCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgcmVmckJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJlZnJVdiwgMS4wIC0gb2JzKSkucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yID0gbWl4KHJlZnJCZywgdVdhdGVyQ29sb3IgKyBzcGVjICogdUdsb3dDb2xvciwgaW5rRCk7CiAgICAgIGNvbG9yID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4xNSk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDMpIHsKICAgICAgLy8g4pSA4pSAIGF1cm9yYSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gVmVsb2NpdHkgZmllbGQgd2FycHMgYmFja2dyb3VuZCBVVnMg4oCUIGxpcXVpZCBtZXRhbCAvIGxhdmEtbGFtcCBmZWVsLgogICAgICB2ZWMyICB2ZWwgICAgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5OwogICAgICBmbG9hdCB2ZWxNYWcgPSBjbGFtcChsZW5ndGgodmVsKSAqIDIwLjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMiAgd2FycFV2ID0gY2xhbXAodlV2ICsgdmVsICogdVdhcnBTdHJlbmd0aCwgMC4wLCAxLjApOwogICAgICB2ZWMzICB3YXJwQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgd2FycFV2KS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgID0gbWl4KGJnLCB3YXJwQmcsIHZlbE1hZyAqICgxLjAgLSBvYnMpKTsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiB2ZWxNYWcgKiAxLjU7CiAgICAgIGNvbG9yICs9IHVXYXRlckNvbG9yICogZGVuc2l0eSAqIDAuMzsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKCiAgICB9IGVsc2UgaWYgKHVBbGdvcml0aG0gPT0gNCkgewogICAgICAvLyDilIDilIAgcmlwcGxlIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBFeGFnZ2VyYXRlZCBub3JtYWwgcGVydHVyYmF0aW9uICsgRnJlc25lbCByaW0g4oCUIGNhbG0gd2F0ZXIgc3VyZmFjZS4KICAgICAgdmVjMiAgcmlwcGxlVXYgPSBjbGFtcCh2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHkgKiA2LjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMyAgcmVmckJnICAgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmlwcGxlVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBmbG9hdCBmcmVzbmVsICA9IHBvdyhjbGFtcCgxLjAgLSBkb3Qobm9ybWFsLCB2ZWMzKDAuMCwgMC4wLCAxLjApKSwgMC4wLCAxLjApLCAzLjApICogZGVuc2l0eTsKICAgICAgY29sb3IgID0gcmVmckJnOwogICAgICBjb2xvciArPSBmcmVzbmVsICogdUdsb3dDb2xvciAqIDIuMDsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiBkZW5zaXR5ICogMi4wOwogICAgICBjb2xvciAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwoKICAgIH0gZWxzZSB7CiAgICAgIC8vIOKUgOKUgCBzdGFuZGFyZCAoMCkg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIE9yaWdpbmFsOiBjb2xvdXIgb3ZlcmxheSBibGVuZGVkIG92ZXIgcmVmcmFjdGVkIGJhY2tncm91bmQuCiAgICAgIHZlYzIgcmVmclV2ID0gdlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5OwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciAgPSBtaXgocmVmckJnLCB1V2F0ZXJDb2xvciwgbWluKGRlbnNpdHkgKiAxLjUsIDAuOCkpOwogICAgICBjb2xvciArPSBzcGVjICogdUdsb3dDb2xvcjsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICAgIH0KCiAgICAvLyBQcmVtdWx0aXBsaWVkIGFscGhhIOKAlCB0cmFuc3BhcmVudCB3aGVyZSB0aGVyZSBpcyBuZWl0aGVyIGNvbnRlbnQgbm9yIGZsdWlkLAogICAgLy8gbGV0dGluZyB0aGUgQ1NTIGJhY2tncm91bmRDb2xvciBvbiB0aGUgY29udGFpbmVyIGRpdiBzaG93IHRocm91Z2guCiAgICBmbG9hdCBhbHBoYSA9IGNsYW1wKG1heChkZW5zaXR5ICogMS41LCBjb3ZlcmFnZSksIDAuMCwgMS4wKTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoY29sb3IgKiBhbHBoYSwgYWxwaGEpOwogIH0KYAopOwpmdW5jdGlvbiBrZShpKSB7CiAgY29uc3QgZSA9IHsgYWxwaGE6ICEwLCBkZXB0aDogITEsIHN0ZW5jaWw6ICExLCBhbnRpYWxpYXM6ICEwLCBwcmVzZXJ2ZURyYXdpbmdCdWZmZXI6ICExIH07CiAgbGV0IHIgPSBpLmdldENvbnRleHQoIndlYmdsMiIsIGUpOwogIGNvbnN0IG8gPSAhIXI7CiAgbyB8fCAociA9IGkuZ2V0Q29udGV4dCgid2ViZ2wiLCBlKSwgci5nZXRFeHRlbnNpb24oIkVYVF9jb2xvcl9idWZmZXJfaGFsZl9mbG9hdCIpKTsKICBjb25zdCBzID0gbyA/IG51bGwgOiByLmdldEV4dGVuc2lvbigiT0VTX3RleHR1cmVfaGFsZl9mbG9hdCIpLCBuID0gbyA/IHIuSEFMRl9GTE9BVCA6IHMuSEFMRl9GTE9BVF9PRVM7CiAgcmV0dXJuIHIuZ2V0RXh0ZW5zaW9uKCJFWFRfY29sb3JfYnVmZmVyX2Zsb2F0IiksIHIuZ2V0RXh0ZW5zaW9uKCJPRVNfdGV4dHVyZV9oYWxmX2Zsb2F0X2xpbmVhciIpLCB7CiAgICBnbDogciwKICAgIGlzV2ViR0wyOiBvLAogICAgZXh0OiB7CiAgICAgIGludGVybmFsRm9ybWF0OiBvID8gci5SR0JBMTZGIDogci5SR0JBLAogICAgICBmb3JtYXQ6IHIuUkdCQSwKICAgICAgdHlwZTogbgogICAgfQogIH07Cn0KY2xhc3MgayB7CiAgY29uc3RydWN0b3IoZSwgciwgbykgewogICAgbmUodGhpcywgInByb2dyYW0iKTsKICAgIG5lKHRoaXMsICJ1bmlmb3JtcyIsIHt9KTsKICAgIG5lKHRoaXMsICJfZ2wiKTsKICAgIHRoaXMuX2dsID0gZSwgdGhpcy5wcm9ncmFtID0gZS5jcmVhdGVQcm9ncmFtKCksIGUuYXR0YWNoU2hhZGVyKHRoaXMucHJvZ3JhbSwgdGhpcy5fY29tcGlsZShlLlZFUlRFWF9TSEFERVIsIHIpKSwgZS5hdHRhY2hTaGFkZXIodGhpcy5wcm9ncmFtLCB0aGlzLl9jb21waWxlKGUuRlJBR01FTlRfU0hBREVSLCBvKSksIGUubGlua1Byb2dyYW0odGhpcy5wcm9ncmFtKTsKICAgIGNvbnN0IHMgPSBlLmdldFByb2dyYW1QYXJhbWV0ZXIodGhpcy5wcm9ncmFtLCBlLkFDVElWRV9VTklGT1JNUyk7CiAgICBmb3IgKGxldCBuID0gMDsgbiA8IHM7IG4rKykgewogICAgICBjb25zdCB1ID0gZS5nZXRBY3RpdmVVbmlmb3JtKHRoaXMucHJvZ3JhbSwgbikubmFtZTsKICAgICAgdGhpcy51bmlmb3Jtc1t1XSA9IGUuZ2V0VW5pZm9ybUxvY2F0aW9uKHRoaXMucHJvZ3JhbSwgdSk7CiAgICB9CiAgfQogIF9jb21waWxlKGUsIHIpIHsKICAgIGNvbnN0IG8gPSB0aGlzLl9nbCwgcyA9IG8uY3JlYXRlU2hhZGVyKGUpOwogICAgcmV0dXJuIG8uc2hhZGVyU291cmNlKHMsIHIpLCBvLmNvbXBpbGVTaGFkZXIocyksIHM7CiAgfQogIGJpbmQoKSB7CiAgICB0aGlzLl9nbC51c2VQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQogIGRpc3Bvc2UoKSB7CiAgICB0aGlzLl9nbC5kZWxldGVQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQp9CmZ1bmN0aW9uIE9lKGkpIHsKICByZXR1cm4gewogICAgYWR2ZWN0aW9uOiBuZXcgayhpLCBQLCBDZSksCiAgICBkaXZlcmdlbmNlOiBuZXcgayhpLCBQLCBGZSksCiAgICBwcmVzc3VyZTogbmV3IGsoaSwgUCwgWGUpLAogICAgZ3JhZGllbnRTdWJ0cmFjdDogbmV3IGsoaSwgUCwgQmUpLAogICAgc3BsYXQ6IG5ldyBrKGksIFAsIEFlKSwKICAgIGN1cmw6IG5ldyBrKGksIFAsIExlKSwKICAgIHZvcnRpY2l0eTogbmV3IGsoaSwgUCwgTWUpLAogICAgZGlzcGxheTogbmV3IGsoaSwgUCwgUGUpCiAgfTsKfQpmdW5jdGlvbiB1ZShpLCBlLCByLCBvKSB7CiAgaS5hY3RpdmVUZXh0dXJlKGkuVEVYVFVSRTApOwogIGNvbnN0IHMgPSBpLmNyZWF0ZVRleHR1cmUoKTsKICBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgcyksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NSU5fRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NQUdfRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1MsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1QsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGUuaW50ZXJuYWxGb3JtYXQsIHIsIG8sIDAsIGUuZm9ybWF0LCBlLnR5cGUsIG51bGwpOwogIGNvbnN0IG4gPSBpLmNyZWF0ZUZyYW1lYnVmZmVyKCk7CiAgcmV0dXJuIGkuYmluZEZyYW1lYnVmZmVyKGkuRlJBTUVCVUZGRVIsIG4pLCBpLmZyYW1lYnVmZmVyVGV4dHVyZTJEKGkuRlJBTUVCVUZGRVIsIGkuQ09MT1JfQVRUQUNITUVOVDAsIGkuVEVYVFVSRV8yRCwgcywgMCksIHsgdGV4OiBzLCBmYm86IG4sIHdpZHRoOiByLCBoZWlnaHQ6IG8gfTsKfQpmdW5jdGlvbiBkZShpLCBlLCByLCBvKSB7CiAgbGV0IHMgPSB1ZShpLCBlLCByLCBvKSwgbiA9IHVlKGksIGUsIHIsIG8pOwogIHJldHVybiB7CiAgICBnZXQgcmVhZCgpIHsKICAgICAgcmV0dXJuIHM7CiAgICB9LAogICAgZ2V0IHdyaXRlKCkgewogICAgICByZXR1cm4gbjsKICAgIH0sCiAgICBzd2FwKCkgewogICAgICBbcywgbl0gPSBbbiwgc107CiAgICB9LAogICAgZGlzcG9zZSgpIHsKICAgICAgaS5kZWxldGVUZXh0dXJlKHMudGV4KSwgaS5kZWxldGVGcmFtZWJ1ZmZlcihzLmZibyksIGkuZGVsZXRlVGV4dHVyZShuLnRleCksIGkuZGVsZXRlRnJhbWVidWZmZXIobi5mYm8pOwogICAgfQogIH07Cn0KZnVuY3Rpb24gSWUoaSkgewogIGNvbnN0IGUgPSBpLmNyZWF0ZUJ1ZmZlcigpOwogIHJldHVybiBpLmJpbmRCdWZmZXIoaS5BUlJBWV9CVUZGRVIsIGUpLCBpLmJ1ZmZlckRhdGEoaS5BUlJBWV9CVUZGRVIsIG5ldyBGbG9hdDMyQXJyYXkoWy0xLCAtMSwgLTEsIDEsIDEsIDEsIDEsIC0xXSksIGkuU1RBVElDX0RSQVcpLCBpLnZlcnRleEF0dHJpYlBvaW50ZXIoMCwgMiwgaS5GTE9BVCwgITEsIDAsIDApLCBpLmVuYWJsZVZlcnRleEF0dHJpYkFycmF5KDApLCBmdW5jdGlvbihvKSB7CiAgICBpLmJpbmRGcmFtZWJ1ZmZlcihpLkZSQU1FQlVGRkVSLCBvKSwgaS5kcmF3QXJyYXlzKGkuVFJJQU5HTEVfRkFOLCAwLCA0KTsKICB9Owp9CmZ1bmN0aW9uIFRlKGksIGUsIHIsIG8sIHMgPSAiY292ZXIiKSB7CiAgbGV0IG47CiAgcyA9PT0gImNvdmVyIiA/IG4gPSBNYXRoLm1heChyIC8gaSwgbyAvIGUpIDogcyA9PT0gImNvbnRhaW4iID8gbiA9IE1hdGgubWluKHIgLyBpLCBvIC8gZSkgOiB0eXBlb2YgcyA9PSAic3RyaW5nIiAmJiBzLmVuZHNXaXRoKCIlIikgPyBuID0gTWF0aC5taW4ociAvIGksIG8gLyBlKSAqIChwYXJzZUZsb2F0KHMpIC8gMTAwKSA6IHR5cGVvZiBzID09ICJzdHJpbmciICYmIHMuZW5kc1dpdGgoInB4IikgPyBuID0gcGFyc2VGbG9hdChzKSAvIE1hdGgubWF4KGksIGUpIDogdHlwZW9mIHMgPT0gIm51bWJlciIgPyBuID0gcyA6IG4gPSBNYXRoLm1heChyIC8gaSwgbyAvIGUpOwogIGNvbnN0IHUgPSBpICogbiwgZCA9IGUgKiBuOwogIHJldHVybiB7IHg6IChyIC0gdSkgLyAyLCB5OiAobyAtIGQpIC8gMiwgZHJhd1c6IHUsIGRyYXdIOiBkIH07Cn0KZnVuY3Rpb24gVmUoaSwgZSwgciwgbywgcyA9IG51bGwsIG4gPSAiY292ZXIiKSB7CiAgY29uc3QgeyB0ZXh0OiB1LCBmb250U2l6ZTogZCwgY29sb3I6IHAsIGZvbnRGYW1pbHk6IGMgPSAic2Fucy1zZXJpZiIsIGZvbnRXZWlnaHQ6IG0gPSA5MDAgfSA9IG8sIHkgPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKGUsIHIpLCBmID0geS5nZXRDb250ZXh0KCIyZCIpOwogICgoY2UpID0+IHsKICAgIGlmIChzKSB7CiAgICAgIGYuY2xlYXJSZWN0KDAsIDAsIGUsIHIpLCBmLmZpbGxTdHlsZSA9ICJibGFjayIsIGYuZmlsbFJlY3QoMCwgMCwgZSwgcik7CiAgICAgIGNvbnN0IHsgeDogZmUsIHk6IGhlLCBkcmF3VzogdmUsIGRyYXdIOiBtZSB9ID0gVGUoCiAgICAgICAgcy53aWR0aCwKICAgICAgICBzLmhlaWdodCwKICAgICAgICBlLAogICAgICAgIHIsCiAgICAgICAgbgogICAgICApOwogICAgICBmLmRyYXdJbWFnZShzLCBmZSwgaGUsIHZlLCBtZSk7CiAgICB9IGVsc2UKICAgICAgZi5maWxsU3R5bGUgPSAiYmxhY2siLCBmLmZpbGxSZWN0KDAsIDAsIGUsIHIpOwogICAgZi5maWxsU3R5bGUgPSBjZSwgZi5mb250ID0gYCR7bX0gJHtkfXB4ICR7Y31gLCBmLnRleHRBbGlnbiA9ICJjZW50ZXIiLCBmLnRleHRCYXNlbGluZSA9ICJtaWRkbGUiLCBmLmZpbGxUZXh0KHUsIGUgLyAyLCByIC8gMik7CiAgfSkocCk7CiAgY29uc3QgSCA9IGVlKGksIHkpOwogIGYuZmlsbFN0eWxlID0gImJsYWNrIiwgZi5maWxsUmVjdCgwLCAwLCBlLCByKSwgZi5maWxsU3R5bGUgPSAid2hpdGUiLCBmLmZvbnQgPSBgJHttfSAke2R9cHggJHtjfWAsIGYudGV4dEFsaWduID0gImNlbnRlciIsIGYudGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIGYuZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICBjb25zdCBhZSA9IGVlKGksIHkpOwogIHJldHVybiB7IGJhY2tncm91bmRUZXg6IEgsIG9ic3RhY2xlVGV4OiBhZSwgY292ZXJhZ2VUZXg6IGFlIH07Cn0KZnVuY3Rpb24gV2UoaSwgZSwgciwgbywgcyA9IDAsIG4gPSAiY292ZXIiLCB1ID0gbnVsbCwgZCA9ICJjb3ZlciIpIHsKICBjb25zdCBwID0gbmV3IE9mZnNjcmVlbkNhbnZhcyhyLCBvKSwgYyA9IHAuZ2V0Q29udGV4dCgiMmQiKSwgeyB4OiBtLCB5LCBkcmF3VzogZiwgZHJhd0g6IEQgfSA9IFRlKGUud2lkdGgsIGUuaGVpZ2h0LCByLCBvLCBuKTsKICBpZiAoYy5jbGVhclJlY3QoMCwgMCwgciwgbyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBvKSwgdSkgewogICAgY29uc3QgewogICAgICB4OiBmZSwKICAgICAgeTogaGUsCiAgICAgIGRyYXdXOiB2ZSwKICAgICAgZHJhd0g6IG1lCiAgICB9ID0gVGUodS53aWR0aCwgdS5oZWlnaHQsIHIsIG8sIGQpOwogICAgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke3N9KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZSh1LCBmZSwgaGUsIHZlLCBtZSksIGMuZmlsdGVyID0gIm5vbmUiOwogIH0KICBjLmRyYXdJbWFnZShlLCBtLCB5LCBmLCBEKTsKICBjb25zdCBIID0gZWUoaSwgcCk7CiAgYy5jbGVhclJlY3QoMCwgMCwgciwgbyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBvKSwgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke3N9KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZShlLCBtLCB5LCBmLCBEKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgY29uc3QgYWUgPSBlZShpLCBwKTsKICBjLmNsZWFyUmVjdCgwLCAwLCByLCBvKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIG8pLCBjLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIGMuZmlsbFJlY3QoCiAgICBNYXRoLm1heCgwLCBtKSwKICAgIE1hdGgubWF4KDAsIHkpLAogICAgTWF0aC5taW4oZiwgciAtIE1hdGgubWF4KDAsIG0pKSwKICAgIE1hdGgubWluKEQsIG8gLSBNYXRoLm1heCgwLCB5KSkKICApOwogIGNvbnN0IGNlID0gZWUoaSwgcCk7CiAgcmV0dXJuIHsgYmFja2dyb3VuZFRleDogSCwgb2JzdGFjbGVUZXg6IGFlLCBjb3ZlcmFnZVRleDogY2UgfTsKfQpmdW5jdGlvbiBlZShpLCBlKSB7CiAgY29uc3QgciA9IGkuY3JlYXRlVGV4dHVyZSgpOwogIHJldHVybiBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgciksIGkucGl4ZWxTdG9yZWkoaS5VTlBBQ0tfRkxJUF9ZX1dFQkdMLCAhMCksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGkuUkdCQSwgaS5SR0JBLCBpLlVOU0lHTkVEX0JZVEUsIGUpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUlOX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUFHX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9TLCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9ULCBpLkNMQU1QX1RPX0VER0UpLCByOwp9CmFzeW5jIGZ1bmN0aW9uIEdlKGkpIHsKICBjb25zdCBlID0gYXdhaXQgZmV0Y2goaSk7CiAgaWYgKCFlLm9rKQogICAgdGhyb3cgbmV3IEVycm9yKGBGYWlsZWQgdG8gZmV0Y2ggaW1hZ2U6ICR7aX0gKCR7ZS5zdGF0dXN9KWApOwogIGNvbnN0IHIgPSBhd2FpdCBlLmJsb2IoKTsKICByZXR1cm4gY3JlYXRlSW1hZ2VCaXRtYXAocik7Cn0KY29uc3QgZ2UgPSB0eXBlb2YgcmVxdWVzdEFuaW1hdGlvbkZyYW1lIDwgInUiID8gcmVxdWVzdEFuaW1hdGlvbkZyYW1lLmJpbmQoZ2xvYmFsVGhpcykgOiAoaSkgPT4gc2V0VGltZW91dChpLCAxZTMgLyA2MCksIHplID0gdHlwZW9mIGNhbmNlbEFuaW1hdGlvbkZyYW1lIDwgInUiID8gY2FuY2VsQW5pbWF0aW9uRnJhbWUuYmluZChnbG9iYWxUaGlzKSA6IGNsZWFyVGltZW91dCwgUmUgPSAwLjAxNiwgTmUgPSB7IHN0YW5kYXJkOiAwLCBnbGFzczogMSwgaW5rOiAyLCBhdXJvcmE6IDMsIHJpcHBsZTogNCB9Owp2YXIgVywgZywgdGUsIEcsIHEsIEUsIGIsIE8sIEksIHcsIFEsIEwsIFIsIGgsIEMsIEYsIFgsIE0sIFUsIEIsIFMsIEssIHosIHgsIF8sIEEsIE4sIHJlLCAkLCBKLCBpZSwgcGUsIFYsIGosIFksIFosIG9lLCBFZSwgc2UsIGJlLCBsZSwgRGU7CmNsYXNzICRlIHsKICBjb25zdHJ1Y3RvcihlLCByID0ge30sIG8gPSB7fSkgewogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIGhlbHBlcnMKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgbCh0aGlzLCAkKTsKICAgIGwodGhpcywgaWUpOwogICAgbCh0aGlzLCBWKTsKICAgIGwodGhpcywgWSk7CiAgICBsKHRoaXMsIG9lKTsKICAgIGwodGhpcywgc2UpOwogICAgbCh0aGlzLCBsZSk7CiAgICBsKHRoaXMsIFcsIHZvaWQgMCk7CiAgICBsKHRoaXMsIGcsIHZvaWQgMCk7CiAgICBsKHRoaXMsIHRlLCB2b2lkIDApOwogICAgbCh0aGlzLCBHLCB2b2lkIDApOwogICAgbCh0aGlzLCBxLCB2b2lkIDApOwogICAgbCh0aGlzLCBFLCAwKTsKICAgIGwodGhpcywgYiwgMCk7CiAgICBsKHRoaXMsIE8sIDApOwogICAgbCh0aGlzLCBJLCAwKTsKICAgIGwodGhpcywgdywgMSk7CiAgICBsKHRoaXMsIFEsIDEpOwogICAgbCh0aGlzLCBMLCAwLjUpOwogICAgbCh0aGlzLCBSLCBudWxsKTsKICAgIGwodGhpcywgaCwgbnVsbCk7CiAgICBsKHRoaXMsIEMsIG51bGwpOwogICAgbCh0aGlzLCBGLCBudWxsKTsKICAgIGwodGhpcywgWCwgbnVsbCk7CiAgICBsKHRoaXMsIE0sIG51bGwpOwogICAgbCh0aGlzLCBVLCBudWxsKTsKICAgIGwodGhpcywgQiwgbnVsbCk7CiAgICAvLyBiaW5hcnkgY29udGVudCBtYXNrIGZvciB0cmFuc3BhcmVudCBjYW52YXMgc3VwcG9ydAogICAgbCh0aGlzLCBTLCBudWxsKTsKICAgIC8vIG9wdGlvbmFsIGJhY2tncm91bmQgaW1hZ2UgKGZyb20gYmFja2dyb3VuZFNyYyBwcm9wKQogICAgbCh0aGlzLCBLLCAiY292ZXIiKTsKICAgIGwodGhpcywgeiwgdm9pZCAwKTsKICAgIGwodGhpcywgeCwgeyB4OiAwLCB5OiAwLCBkeDogMCwgZHk6IDAsIHRhcmdldFg6IDAsIHRhcmdldFk6IDAsIG1vdmVkOiAhMSB9KTsKICAgIC8vIFN0b3JlcyBzb3VyY2Ugc28gdGV4dHVyZXMgY2FuIGJlIHJlYnVpbHQgb24gcmVzaXplCiAgICBsKHRoaXMsIF8sIG51bGwpOwogICAgbCh0aGlzLCBBLCBudWxsKTsKICAgIGwodGhpcywgTiwgITEpOwogICAgbCh0aGlzLCByZSwgITEpOwogICAgYSh0aGlzLCBXLCBlKSwgYSh0aGlzLCBRLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIG8uZHByID8/IDEpKSksIGEodGhpcywgTCwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBvLnNpbSA/PyAwLjUpKSksIGEodGhpcywgeiwgU2UocikpOwogICAgY29uc3QgeyBnbDogcywgZXh0OiBuIH0gPSBrZShlKTsKICAgIGEodGhpcywgZywgcyksIGEodGhpcywgdGUsIG4pLCBhKHRoaXMsIEcsIE9lKHMpKSwgYSh0aGlzLCBxLCBJZShzKSksIHMuY2xlYXJDb2xvcigwLCAwLCAwLCAwKTsKICB9CiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgLy8gUHVibGljIEFQSQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIHNldFRleHRTb3VyY2UoZSkgewogICAgYSh0aGlzLCBfLCB7IHR5cGU6ICJ0ZXh0Iiwgb3B0czogZSB9KSwgVCh0aGlzLCAkLCBKKS5jYWxsKHRoaXMpLCBUKHRoaXMsIFYsIGopLmNhbGwodGhpcyksIFQodGhpcywgWSwgWikuY2FsbCh0aGlzKTsKICB9CiAgYXN5bmMgc2V0SW1hZ2VTb3VyY2UoZSwgciA9IDAsIG8gPSAiY292ZXIiKSB7CiAgICBjb25zdCBzID0gYXdhaXQgR2UoZSk7CiAgICBpZiAodCh0aGlzLCByZSkpIHsKICAgICAgcy5jbG9zZSgpOwogICAgICByZXR1cm47CiAgICB9CiAgICBhKHRoaXMsIF8sIHsgdHlwZTogImltYWdlIiwgYml0bWFwOiBzLCBlZmZlY3Q6IHIsIHNpemU6IG8gfSksIFQodGhpcywgJCwgSikuY2FsbCh0aGlzKSwgVCh0aGlzLCBWLCBqKS5jYWxsKHRoaXMpLCBUKHRoaXMsIFksIFopLmNhbGwodGhpcyk7CiAgfQogIHNldEltYWdlQml0bWFwKGUsIHIgPSAwLCBvID0gImNvdmVyIikgewogICAgYSh0aGlzLCBfLCB7IHR5cGU6ICJpbWFnZSIsIGJpdG1hcDogZSwgZWZmZWN0OiByLCBzaXplOiBvIH0pLCBUKHRoaXMsICQsIEopLmNhbGwodGhpcyksIFQodGhpcywgViwgaikuY2FsbCh0aGlzKSwgVCh0aGlzLCBZLCBaKS5jYWxsKHRoaXMpOwogIH0KICBzZXRCYWNrZ3JvdW5kKGUsIHIgPSAiY292ZXIiKSB7CiAgICB0KHRoaXMsIFMpICYmIHQodGhpcywgUykgIT09IGUgJiYgdCh0aGlzLCBTKS5jbG9zZSgpLCBhKHRoaXMsIFMsIGUpLCBhKHRoaXMsIEssIHIgPz8gImNvdmVyIiksIHQodGhpcywgXykgJiYgdCh0aGlzLCBFKSA+IDAgJiYgdCh0aGlzLCBiKSA+IDAgJiYgVCh0aGlzLCBWLCBqKS5jYWxsKHRoaXMpOwogIH0KICBoYW5kbGVNb3ZlKGUsIHIsIG8gPSAxKSB7CiAgICB0KHRoaXMsIHgpLm1vdmVkID0gITAsIHQodGhpcywgeCkuZHggPSAoZSAtIHQodGhpcywgeCkudGFyZ2V0WCkgKiBvLCB0KHRoaXMsIHgpLmR5ID0gKHIgLSB0KHRoaXMsIHgpLnRhcmdldFkpICogbywgdCh0aGlzLCB4KS50YXJnZXRYID0gZSwgdCh0aGlzLCB4KS50YXJnZXRZID0gcjsKICB9CiAgLyoqCiAgICogSW1tZWRpYXRlbHkgYXBwbGllcyBvbmUgZmx1aWQgc3BsYXQgYXQgKHgsIHkpIHdpdGggZXhwbGljaXQgdmVsb2NpdHkgKHZ4LCB2eSkuCiAgICogU2FmZSB0byBjYWxsIG11bHRpcGxlIHRpbWVzIHBlciBmcmFtZSDigJQgZWFjaCBjYWxsIHdyaXRlcyBkaXJlY3RseSB0byB0aGUgRkJPcy4KICAgKiBEZXNpZ25lZCBmb3IgcHJvZ3JhbW1hdGljIHVzZSBjYXNlcyAoZS5nLiBwYXJ0aWNsZSBzeXN0ZW1zLCBhdHRyYWN0b3IgcGF0aHMpCiAgICogd2hlcmUgeW91IHdhbnQgTiBpbmRlcGVuZGVudCBpbmplY3Rpb24gcG9pbnRzIHBlciBmcmFtZSB3aXRob3V0IGZsb29kaW5nIHRoZQogICAqIG1vdXNlLXN0YXRlIG1hY2hpbmUgb3IgdGhlIHdvcmtlciBtZXNzYWdlIHF1ZXVlLgogICAqLwogIHNwbGF0KGUsIHIsIG8sIHMsIG4gPSAxKSB7CiAgICBpZiAoIXQodGhpcywgTikgfHwgdCh0aGlzLCBFKSA9PT0gMCkKICAgICAgcmV0dXJuOwogICAgY29uc3QgdSA9IHQodGhpcywgZyksIGQgPSB0KHRoaXMsIHopLCB7IHNwbGF0OiBwIH0gPSB0KHRoaXMsIEcpLCBjID0gdCh0aGlzLCBxKTsKICAgIHUudmlld3BvcnQoMCwgMCwgdCh0aGlzLCBPKSwgdCh0aGlzLCBJKSksIHAuYmluZCgpLCB1LnVuaWZvcm0xZihwLnVuaWZvcm1zLmFzcGVjdFJhdGlvLCB0KHRoaXMsIEUpIC8gdCh0aGlzLCBiKSksIHUudW5pZm9ybTJmKHAudW5pZm9ybXMucG9pbnQsIGUgKiB0KHRoaXMsIHcpIC8gdCh0aGlzLCBFKSwgMSAtIHIgKiB0KHRoaXMsIHcpIC8gdCh0aGlzLCBiKSksIHUudW5pZm9ybTFmKHAudW5pZm9ybXMucmFkaXVzLCBkLnNwbGF0UmFkaXVzKSwgdS51bmlmb3JtMWkocC51bmlmb3Jtcy51VGFyZ2V0LCAwKSwgdS5hY3RpdmVUZXh0dXJlKHUuVEVYVFVSRTApLCB1LmJpbmRUZXh0dXJlKHUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIHUudW5pZm9ybTNmKHAudW5pZm9ybXMuY29sb3IsIG8gKiBkLnNwbGF0Rm9yY2UgKiBuLCAtcyAqIGQuc3BsYXRGb3JjZSAqIG4sIDApLCBjKHQodGhpcywgaCkud3JpdGUuZmJvKSwgdCh0aGlzLCBoKS5zd2FwKCksIHUuYWN0aXZlVGV4dHVyZSh1LlRFWFRVUkUwKSwgdS5iaW5kVGV4dHVyZSh1LlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCB1LnVuaWZvcm0zZihwLnVuaWZvcm1zLmNvbG9yLCBuLCBuLCBuKSwgYyh0KHRoaXMsIFIpLndyaXRlLmZibyksIHQodGhpcywgUikuc3dhcCgpOwogIH0KICB1cGRhdGVRdWFsaXR5KGUpIHsKICAgIGUuZHByICE9PSB2b2lkIDAgJiYgYSh0aGlzLCBRLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIGUuZHByKSkpLCBlLnNpbSAhPT0gdm9pZCAwICYmIGEodGhpcywgTCwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBlLnNpbSkpKTsKICB9CiAgcmVzaXplKGUsIHIsIG8pIHsKICAgIGlmIChvICE9PSB2b2lkIDAgPyBhKHRoaXMsIHcsIG8pIDogdHlwZW9mIHdpbmRvdyA8ICJ1IiAmJiB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpbyAmJiBhKHRoaXMsIHcsIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvKSwgZSAhPT0gdm9pZCAwICYmIGUgPiAwKSB7CiAgICAgIGlmIChyID09PSB2b2lkIDAgfHwgciA8PSAwKQogICAgICAgIHJldHVybjsKICAgICAgYSh0aGlzLCBFLCB0KHRoaXMsIFcpLndpZHRoID0gZSksIGEodGhpcywgYiwgdCh0aGlzLCBXKS5oZWlnaHQgPSByKSwgYSh0aGlzLCBPLCBNYXRoLm1heCgxLCBNYXRoLnJvdW5kKGUgKiB0KHRoaXMsIEwpKSkpLCBhKHRoaXMsIEksIE1hdGgubWF4KDEsIE1hdGgucm91bmQociAqIHQodGhpcywgTCkpKSksIFQodGhpcywgaWUsIHBlKS5jYWxsKHRoaXMpOwogICAgfSBlbHNlCiAgICAgIFQodGhpcywgJCwgSikuY2FsbCh0aGlzKTsKICAgIHQodGhpcywgXykgJiYgVCh0aGlzLCBWLCBqKS5jYWxsKHRoaXMpLCBUKHRoaXMsIFksIFopLmNhbGwodGhpcyk7CiAgfQogIHVwZGF0ZUNvbmZpZyhlKSB7CiAgICBPYmplY3QuYXNzaWduKHQodGhpcywgeiksIGUpOwogIH0KICBkZXN0cm95KCkgewogICAgYSh0aGlzLCByZSwgITApLCB0aGlzLnN0b3AoKTsKICAgIGNvbnN0IGUgPSB0KHRoaXMsIGcpOwogICAgVCh0aGlzLCBvZSwgRWUpLmNhbGwodGhpcyksIFQodGhpcywgc2UsIGJlKS5jYWxsKHRoaXMpLCB0KHRoaXMsIFMpICYmICh0KHRoaXMsIFMpLmNsb3NlKCksIGEodGhpcywgUywgbnVsbCkpOwogICAgZm9yIChjb25zdCBvIG9mIE9iamVjdC52YWx1ZXModCh0aGlzLCBHKSkpCiAgICAgIG8uZGlzcG9zZSgpOwogICAgY29uc3QgciA9IGUuZ2V0RXh0ZW5zaW9uKCJXRUJHTF9sb3NlX2NvbnRleHQiKTsKICAgIHIgPT0gbnVsbCB8fCByLmxvc2VDb250ZXh0KCk7CiAgfQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIC8vIExvb3AgY29udHJvbAogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIHN0YXJ0KCkgewogICAgaWYgKHQodGhpcywgQSkgIT09IG51bGwpCiAgICAgIHJldHVybjsKICAgIGNvbnN0IGUgPSAoKSA9PiB7CiAgICAgIFQodGhpcywgbGUsIERlKS5jYWxsKHRoaXMpLCBhKHRoaXMsIEEsIGdlKGUpKTsKICAgIH07CiAgICBhKHRoaXMsIEEsIGdlKGUpKTsKICB9CiAgc3RvcCgpIHsKICAgIHQodGhpcywgQSkgIT09IG51bGwgJiYgKHplKHQodGhpcywgQSkpLCBhKHRoaXMsIEEsIG51bGwpKTsKICB9CiAgZ2V0IGlzUnVubmluZygpIHsKICAgIHJldHVybiB0KHRoaXMsIEEpICE9PSBudWxsOwogIH0KfQpXID0gbmV3IFdlYWtNYXAoKSwgZyA9IG5ldyBXZWFrTWFwKCksIHRlID0gbmV3IFdlYWtNYXAoKSwgRyA9IG5ldyBXZWFrTWFwKCksIHEgPSBuZXcgV2Vha01hcCgpLCBFID0gbmV3IFdlYWtNYXAoKSwgYiA9IG5ldyBXZWFrTWFwKCksIE8gPSBuZXcgV2Vha01hcCgpLCBJID0gbmV3IFdlYWtNYXAoKSwgdyA9IG5ldyBXZWFrTWFwKCksIFEgPSBuZXcgV2Vha01hcCgpLCBMID0gbmV3IFdlYWtNYXAoKSwgUiA9IG5ldyBXZWFrTWFwKCksIGggPSBuZXcgV2Vha01hcCgpLCBDID0gbmV3IFdlYWtNYXAoKSwgRiA9IG5ldyBXZWFrTWFwKCksIFggPSBuZXcgV2Vha01hcCgpLCBNID0gbmV3IFdlYWtNYXAoKSwgVSA9IG5ldyBXZWFrTWFwKCksIEIgPSBuZXcgV2Vha01hcCgpLCBTID0gbmV3IFdlYWtNYXAoKSwgSyA9IG5ldyBXZWFrTWFwKCksIHogPSBuZXcgV2Vha01hcCgpLCB4ID0gbmV3IFdlYWtNYXAoKSwgXyA9IG5ldyBXZWFrTWFwKCksIEEgPSBuZXcgV2Vha01hcCgpLCBOID0gbmV3IFdlYWtNYXAoKSwgcmUgPSBuZXcgV2Vha01hcCgpLCAkID0gbmV3IFdlYWtTZXQoKSwgSiA9IGZ1bmN0aW9uKCkgewogIGNvbnN0IGUgPSB0KHRoaXMsIFcpOwogICJjbGllbnRXaWR0aCIgaW4gZSAmJiBlLmNsaWVudFdpZHRoID4gMCA/IChhKHRoaXMsIHcsICh0eXBlb2Ygd2luZG93IDwgInUiICYmIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvIHx8IDEpICogdCh0aGlzLCBRKSksIGEodGhpcywgRSwgZS53aWR0aCA9IE1hdGgucm91bmQoZS5jbGllbnRXaWR0aCAqIHQodGhpcywgdykpKSwgYSh0aGlzLCBiLCBlLmhlaWdodCA9IE1hdGgucm91bmQoZS5jbGllbnRIZWlnaHQgKiB0KHRoaXMsIHcpKSkpIDogKGEodGhpcywgRSwgZS53aWR0aCksIGEodGhpcywgYiwgZS5oZWlnaHQpKSwgISh0KHRoaXMsIEUpID09PSAwIHx8IHQodGhpcywgYikgPT09IDApICYmIChhKHRoaXMsIE8sIE1hdGgubWF4KDEsIE1hdGgucm91bmQodCh0aGlzLCBFKSAqIHQodGhpcywgTCkpKSksIGEodGhpcywgSSwgTWF0aC5tYXgoMSwgTWF0aC5yb3VuZCh0KHRoaXMsIGIpICogdCh0aGlzLCBMKSkpKSwgVCh0aGlzLCBpZSwgcGUpLmNhbGwodGhpcykpOwp9LCBpZSA9IG5ldyBXZWFrU2V0KCksIHBlID0gZnVuY3Rpb24oKSB7CiAgY29uc3QgZSA9IHQodGhpcywgZyksIHIgPSB0KHRoaXMsIHRlKSwgbyA9IHQodGhpcywgTyksIHMgPSB0KHRoaXMsIEkpOwogIFQodGhpcywgb2UsIEVlKS5jYWxsKHRoaXMpLCBhKHRoaXMsIFIsIGRlKGUsIHIsIG8sIHMpKSwgYSh0aGlzLCBoLCBkZShlLCByLCBvLCBzKSksIGEodGhpcywgRiwgZGUoZSwgciwgbywgcykpLCBhKHRoaXMsIEMsIHVlKGUsIHIsIG8sIHMpKSwgYSh0aGlzLCBYLCB1ZShlLCByLCBvLCBzKSk7Cn0sIFYgPSBuZXcgV2Vha1NldCgpLCBqID0gZnVuY3Rpb24oKSB7CiAgaWYgKCEoIXQodGhpcywgXykgfHwgdCh0aGlzLCBFKSA9PT0gMCB8fCB0KHRoaXMsIGIpID09PSAwKSkgewogICAgaWYgKFQodGhpcywgc2UsIGJlKS5jYWxsKHRoaXMpLCB0KHRoaXMsIF8pLnR5cGUgPT09ICJ0ZXh0IikgewogICAgICBjb25zdCB7IGJhY2tncm91bmRUZXg6IGUsIG9ic3RhY2xlVGV4OiByLCBjb3ZlcmFnZVRleDogbyB9ID0gVmUoCiAgICAgICAgdCh0aGlzLCBnKSwKICAgICAgICB0KHRoaXMsIEUpLAogICAgICAgIHQodGhpcywgYiksCiAgICAgICAgdCh0aGlzLCBfKS5vcHRzLAogICAgICAgIHQodGhpcywgUyksCiAgICAgICAgdCh0aGlzLCBLKQogICAgICApOwogICAgICBhKHRoaXMsIE0sIGUpLCBhKHRoaXMsIFUsIHIpLCBhKHRoaXMsIEIsIG8pOwogICAgfSBlbHNlIHsKICAgICAgY29uc3QgeyBiYWNrZ3JvdW5kVGV4OiBlLCBvYnN0YWNsZVRleDogciwgY292ZXJhZ2VUZXg6IG8gfSA9IFdlKAogICAgICAgIHQodGhpcywgZyksCiAgICAgICAgdCh0aGlzLCBfKS5iaXRtYXAsCiAgICAgICAgdCh0aGlzLCBFKSwKICAgICAgICB0KHRoaXMsIGIpLAogICAgICAgIHQodGhpcywgXykuZWZmZWN0LAogICAgICAgIHQodGhpcywgXykuc2l6ZSwKICAgICAgICB0KHRoaXMsIFMpLAogICAgICAgIHQodGhpcywgSykKICAgICAgKTsKICAgICAgYSh0aGlzLCBNLCBlKSwgYSh0aGlzLCBVLCByKSwgYSh0aGlzLCBCLCBvKTsKICAgIH0KICAgIGEodGhpcywgTiwgITApOwogIH0KfSwgWSA9IG5ldyBXZWFrU2V0KCksIFogPSBmdW5jdGlvbigpIHsKICB0KHRoaXMsIE4pICYmICF0aGlzLmlzUnVubmluZyAmJiB0aGlzLnN0YXJ0KCk7Cn0sIG9lID0gbmV3IFdlYWtTZXQoKSwgRWUgPSBmdW5jdGlvbigpIHsKICB2YXIgZSwgciwgbzsKICAoZSA9IHQodGhpcywgUikpID09IG51bGwgfHwgZS5kaXNwb3NlKCksIChyID0gdCh0aGlzLCBoKSkgPT0gbnVsbCB8fCByLmRpc3Bvc2UoKSwgKG8gPSB0KHRoaXMsIEYpKSA9PSBudWxsIHx8IG8uZGlzcG9zZSgpLCB0KHRoaXMsIEMpICYmICh0KHRoaXMsIGcpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBDKS50ZXgpLCB0KHRoaXMsIGcpLmRlbGV0ZUZyYW1lYnVmZmVyKHQodGhpcywgQykuZmJvKSksIHQodGhpcywgWCkgJiYgKHQodGhpcywgZykuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIFgpLnRleCksIHQodGhpcywgZykuZGVsZXRlRnJhbWVidWZmZXIodCh0aGlzLCBYKS5mYm8pKSwgYSh0aGlzLCBSLCBhKHRoaXMsIGgsIGEodGhpcywgRiwgYSh0aGlzLCBDLCBhKHRoaXMsIFgsIG51bGwpKSkpKTsKfSwgc2UgPSBuZXcgV2Vha1NldCgpLCBiZSA9IGZ1bmN0aW9uKCkgewogIHQodGhpcywgTSkgJiYgdCh0aGlzLCBnKS5kZWxldGVUZXh0dXJlKHQodGhpcywgTSkpLCB0KHRoaXMsIFUpICYmIHQodGhpcywgZykuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIFUpKSwgdCh0aGlzLCBCKSAmJiB0KHRoaXMsIEIpICE9PSB0KHRoaXMsIFUpICYmIHQodGhpcywgZykuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIEIpKSwgYSh0aGlzLCBNLCBhKHRoaXMsIFUsIGEodGhpcywgQiwgbnVsbCkpKTsKfSwgbGUgPSBuZXcgV2Vha1NldCgpLCBEZSA9IGZ1bmN0aW9uKCkgewogIGlmICghdCh0aGlzLCBOKSB8fCB0KHRoaXMsIEUpID09PSAwIHx8ICF0KHRoaXMsIFIpIHx8ICF0KHRoaXMsIGgpKQogICAgcmV0dXJuOwogIGNvbnN0IGUgPSB0KHRoaXMsIGcpLCByID0gdCh0aGlzLCB6KSwgeyBhZHZlY3Rpb246IG8sIGRpdmVyZ2VuY2U6IHMsIHByZXNzdXJlOiBuLCBncmFkaWVudFN1YnRyYWN0OiB1LCBzcGxhdDogZCwgY3VybDogcCwgdm9ydGljaXR5OiBjLCBkaXNwbGF5OiBtIH0gPSB0KHRoaXMsIEcpOwogIHQodGhpcywgeCkueCArPSAodCh0aGlzLCB4KS50YXJnZXRYIC0gdCh0aGlzLCB4KS54KSAqIDAuMTUsIHQodGhpcywgeCkueSArPSAodCh0aGlzLCB4KS50YXJnZXRZIC0gdCh0aGlzLCB4KS55KSAqIDAuMTU7CiAgY29uc3QgeSA9IHQodGhpcywgTyksIGYgPSB0KHRoaXMsIEkpLCBEID0gdCh0aGlzLCBxKTsKICBlLnZpZXdwb3J0KDAsIDAsIHksIGYpLCBvLmJpbmQoKSwgZS51bmlmb3JtMmYoby51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB5LCAxIC8gZiksIGUudW5pZm9ybTFmKG8udW5pZm9ybXMuZHQsIFJlKSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51T2JzdGFjbGUsIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFUpKSwgZS51bmlmb3JtMWYoby51bmlmb3Jtcy5kaXNzaXBhdGlvbiwgci52ZWxvY2l0eURpc3NpcGF0aW9uKSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51VmVsb2NpdHksIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIGgpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51U291cmNlLCAxKSwgRCh0KHRoaXMsIGgpLndyaXRlLmZibyksIHQodGhpcywgaCkuc3dhcCgpLCBlLnVuaWZvcm0xZihvLnVuaWZvcm1zLmRpc3NpcGF0aW9uLCByLmRlbnNpdHlEaXNzaXBhdGlvbiksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudVNvdXJjZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBEKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIHAuYmluZCgpLCBlLnVuaWZvcm0yZihwLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHksIDEgLyBmKSwgZS51bmlmb3JtMWkocC51bmlmb3Jtcy51VmVsb2NpdHksIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIGgpLnJlYWQudGV4KSwgRCh0KHRoaXMsIFgpLmZibyksIGMuYmluZCgpLCBlLnVuaWZvcm0yZihjLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHksIDEgLyBmKSwgZS51bmlmb3JtMWYoYy51bmlmb3Jtcy5jdXJsLCByLmN1cmwpLCBlLnVuaWZvcm0xZihjLnVuaWZvcm1zLmR0LCBSZSksIGUudW5pZm9ybTFpKGMudW5pZm9ybXMudVZlbG9jaXR5LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKGMudW5pZm9ybXMudUN1cmwsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFgpLnRleCksIEQodCh0aGlzLCBoKS53cml0ZS5mYm8pLCB0KHRoaXMsIGgpLnN3YXAoKSwgdCh0aGlzLCB4KS5tb3ZlZCAmJiAoZC5iaW5kKCksIGUudW5pZm9ybTFmKGQudW5pZm9ybXMuYXNwZWN0UmF0aW8sIHQodGhpcywgRSkgLyB0KHRoaXMsIGIpKSwgZS51bmlmb3JtMmYoZC51bmlmb3Jtcy5wb2ludCwgdCh0aGlzLCB4KS54ICogdCh0aGlzLCB3KSAvIHQodGhpcywgRSksIDEgLSB0KHRoaXMsIHgpLnkgKiB0KHRoaXMsIHcpIC8gdCh0aGlzLCBiKSksIGUudW5pZm9ybTFmKGQudW5pZm9ybXMucmFkaXVzLCByLnNwbGF0UmFkaXVzKSwgZS51bmlmb3JtMWkoZC51bmlmb3Jtcy51VGFyZ2V0LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTNmKGQudW5pZm9ybXMuY29sb3IsIHQodGhpcywgeCkuZHggKiByLnNwbGF0Rm9yY2UsIC10KHRoaXMsIHgpLmR5ICogci5zcGxhdEZvcmNlLCAwKSwgRCh0KHRoaXMsIGgpLndyaXRlLmZibyksIHQodGhpcywgaCkuc3dhcCgpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtM2YoZC51bmlmb3Jtcy5jb2xvciwgMSwgMSwgMSksIEQodCh0aGlzLCBSKS53cml0ZS5mYm8pLCB0KHRoaXMsIFIpLnN3YXAoKSwgdCh0aGlzLCB4KS5tb3ZlZCA9ICExKSwgcy5iaW5kKCksIGUudW5pZm9ybTJmKHMudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geSwgMSAvIGYpLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVWZWxvY2l0eSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgaCkucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVPYnN0YWNsZSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpLCBEKHQodGhpcywgQykuZmJvKSwgbi5iaW5kKCksIGUudW5pZm9ybTJmKG4udW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geSwgMSAvIGYpLCBlLnVuaWZvcm0xaShuLnVuaWZvcm1zLnVEaXZlcmdlbmNlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBDKS50ZXgpLCBlLnVuaWZvcm0xaShuLnVuaWZvcm1zLnVPYnN0YWNsZSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpOwogIGZvciAobGV0IEggPSAwOyBIIDwgci5wcmVzc3VyZUl0ZXJhdGlvbnM7IEgrKykKICAgIGUudW5pZm9ybTFpKG4udW5pZm9ybXMudVByZXNzdXJlLCAyKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTIpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBGKS5yZWFkLnRleCksIEQodCh0aGlzLCBGKS53cml0ZS5mYm8pLCB0KHRoaXMsIEYpLnN3YXAoKTsKICB1LmJpbmQoKSwgZS51bmlmb3JtMmYodS51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB5LCAxIC8gZiksIGUudW5pZm9ybTFpKHUudW5pZm9ybXMudVByZXNzdXJlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBGKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKHUudW5pZm9ybXMudVZlbG9jaXR5LCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKHUudW5pZm9ybXMudU9ic3RhY2xlLCAyKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTIpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBVKSksIEQodCh0aGlzLCBoKS53cml0ZS5mYm8pLCB0KHRoaXMsIGgpLnN3YXAoKSwgZS52aWV3cG9ydCgwLCAwLCB0KHRoaXMsIEUpLCB0KHRoaXMsIGIpKSwgZS5iaW5kRnJhbWVidWZmZXIoZS5GUkFNRUJVRkZFUiwgbnVsbCksIGUuY2xlYXIoZS5DT0xPUl9CVUZGRVJfQklUKSwgbS5iaW5kKCksIGUudW5pZm9ybTJmKG0udW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gdCh0aGlzLCBFKSwgMSAvIHQodGhpcywgYikpLCBlLnVuaWZvcm0zZnYobS51bmlmb3Jtcy51V2F0ZXJDb2xvciwgci53YXRlckNvbG9yKSwgZS51bmlmb3JtM2Z2KG0udW5pZm9ybXMudUdsb3dDb2xvciwgci5nbG93Q29sb3IpLCBlLnVuaWZvcm0xZihtLnVuaWZvcm1zLnVSZWZyYWN0aW9uLCByLnJlZnJhY3Rpb24pLCBlLnVuaWZvcm0xZihtLnVuaWZvcm1zLnVTcGVjdWxhckV4cCwgci5zcGVjdWxhckV4cCksIGUudW5pZm9ybTFmKG0udW5pZm9ybXMudVNoaW5lLCByLnNoaW5lKSwgZS51bmlmb3JtMWYobS51bmlmb3Jtcy51V2FycFN0cmVuZ3RoLCByLndhcnBTdHJlbmd0aCA/PyAwLjAxNSksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudUFsZ29yaXRobSwgTmVbci5hbGdvcml0aG1dID8/IDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBVKSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgTSkpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMyksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEIpKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTQpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudVRleHR1cmUsIDApLCBlLnVuaWZvcm0xaShtLnVuaWZvcm1zLnVPYnN0YWNsZSwgMSksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudUJhY2tncm91bmQsIDIpLCBlLnVuaWZvcm0xaShtLnVuaWZvcm1zLnVDb3ZlcmFnZSwgMyksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudVZlbG9jaXR5LCA0KSwgRChudWxsKTsKfTsKbGV0IHYgPSBudWxsOwpzZWxmLm9ubWVzc2FnZSA9IGFzeW5jIChpKSA9PiB7CiAgY29uc3QgeyB0eXBlOiBlLCAuLi5yIH0gPSBpLmRhdGE7CiAgdHJ5IHsKICAgIHN3aXRjaCAoZSkgewogICAgICBjYXNlICJpbml0IjogewogICAgICAgIGNvbnN0IHsgY2FudmFzOiBvLCB3aWR0aDogcywgaGVpZ2h0OiBuLCBjb25maWc6IHUsIGRwcjogZCwgcXVhbGl0eTogcCB9ID0gcjsKICAgICAgICBvLndpZHRoID0gcywgby5oZWlnaHQgPSBuLCB2ID0gbmV3ICRlKG8sIHUsIHAgPz8ge30pLCB2LnJlc2l6ZShzLCBuLCBkIHx8IDEpLCBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogInJlYWR5IiB9KTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRUZXh0U291cmNlIjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnNldFRleHRTb3VyY2Uoci5vcHRzKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRJbWFnZVNvdXJjZSI6IHsKICAgICAgICBpZiAoIXYpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgYXdhaXQgdi5zZXRJbWFnZVNvdXJjZSgKICAgICAgICAgIHIuc3JjLAogICAgICAgICAgci5lZmZlY3QsCiAgICAgICAgICByLnNpemUKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNldEltYWdlQml0bWFwIjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnNldEltYWdlQml0bWFwKAogICAgICAgICAgci5iaXRtYXAsCiAgICAgICAgICByLmVmZmVjdCwKICAgICAgICAgIHIuc2l6ZQogICAgICAgICk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0QmFja2dyb3VuZCI6IHsKICAgICAgICBpZiAoIXYpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgdi5zZXRCYWNrZ3JvdW5kKHIuYml0bWFwLCByLnNpemUpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNwbGF0IjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnNwbGF0KAogICAgICAgICAgci54LAogICAgICAgICAgci55LAogICAgICAgICAgci52eCwKICAgICAgICAgIHIudnksCiAgICAgICAgICByLnN0cmVuZ3RoID8/IDEKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgIm1vdmUiOiB7CiAgICAgICAgaWYgKCF2KQogICAgICAgICAgcmV0dXJuOwogICAgICAgIHYuaGFuZGxlTW92ZShyLngsIHIueSwgci5zdHJlbmd0aCA/PyAxKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJyZXNpemUiOiB7CiAgICAgICAgaWYgKCF2KQogICAgICAgICAgcmV0dXJuOwogICAgICAgIHYucmVzaXplKHIud2lkdGgsIHIuaGVpZ2h0LCByLmRwcik7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlUXVhbGl0eSI6IHsKICAgICAgICBpZiAoIXYpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgdi51cGRhdGVRdWFsaXR5KHIucXVhbGl0eSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlQ29uZmlnIjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnVwZGF0ZUNvbmZpZyhyLmNvbmZpZyk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAiZGVzdHJveSI6IHsKICAgICAgICB2ID09IG51bGwgfHwgdi5kZXN0cm95KCksIHYgPSBudWxsOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGRlZmF1bHQ6CiAgICAgICAgY29uc29sZS53YXJuKCJbZmx1aWRpdHktanMgd29ya2VyXSBVbmtub3duIG1lc3NhZ2UgdHlwZToiLCBlKTsKICAgIH0KICB9IGNhdGNoIChvKSB7CiAgICBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogImVycm9yIiwgbWVzc2FnZTogKG8gPT0gbnVsbCA/IHZvaWQgMCA6IG8ubWVzc2FnZSkgPz8gU3RyaW5nKG8pIH0pOwogIH0KfTsK", JI = typeof window < "u" && window.Blob && new Blob([atob(PI)], { type: "text/javascript;charset=utf-8" });
|
|
680
|
+
function Gg() {
|
|
681
|
+
let C;
|
|
671
682
|
try {
|
|
672
|
-
if (
|
|
683
|
+
if (C = JI && (window.URL || window.webkitURL).createObjectURL(JI), !C)
|
|
673
684
|
throw "";
|
|
674
|
-
return new Worker(
|
|
685
|
+
return new Worker(C);
|
|
675
686
|
} catch {
|
|
676
|
-
return new Worker("data:application/javascript;base64," +
|
|
687
|
+
return new Worker("data:application/javascript;base64," + PI, { type: "module" });
|
|
677
688
|
} finally {
|
|
678
|
-
|
|
689
|
+
C && (window.URL || window.webkitURL).revokeObjectURL(C);
|
|
679
690
|
}
|
|
680
691
|
}
|
|
681
|
-
const
|
|
682
|
-
var
|
|
683
|
-
class
|
|
684
|
-
constructor(
|
|
692
|
+
const hg = typeof Worker < "u" && typeof OffscreenCanvas < "u";
|
|
693
|
+
var p, U, ZI, T, O, XI, _I;
|
|
694
|
+
class Bg {
|
|
695
|
+
constructor(I, {
|
|
696
|
+
isWorkerEnabled: i = !0,
|
|
697
|
+
quality: e = {},
|
|
698
|
+
config: s = {}
|
|
699
|
+
} = {}) {
|
|
685
700
|
// ---------------------------------------------------------------------------
|
|
686
701
|
// Private
|
|
687
702
|
// ---------------------------------------------------------------------------
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
703
|
+
m(this, XI);
|
|
704
|
+
m(this, p, null);
|
|
705
|
+
m(this, U, null);
|
|
706
|
+
m(this, ZI, void 0);
|
|
707
|
+
m(this, T, void 0);
|
|
708
|
+
m(this, O, void 0);
|
|
709
|
+
l(this, T, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, O, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, ZI, i && hg), g(this, ZI) ? b(this, XI, _I).call(this, I, s) : l(this, U, new EI(I, s, { dpr: g(this, T), sim: g(this, O) }));
|
|
694
710
|
}
|
|
695
711
|
// ---------------------------------------------------------------------------
|
|
696
712
|
// Source setters
|
|
697
713
|
// ---------------------------------------------------------------------------
|
|
698
|
-
setTextSource(
|
|
699
|
-
|
|
714
|
+
setTextSource(I) {
|
|
715
|
+
g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, U).setTextSource(I);
|
|
700
716
|
}
|
|
701
|
-
setImageSource(
|
|
702
|
-
if (
|
|
703
|
-
const
|
|
704
|
-
|
|
717
|
+
setImageSource(I, i = iI.effect, e = iI.imageSize) {
|
|
718
|
+
if (g(this, p)) {
|
|
719
|
+
const s = new URL(I, location.href).href;
|
|
720
|
+
g(this, p).postMessage({ type: "setImageSource", src: s, effect: i, size: e });
|
|
705
721
|
} else
|
|
706
|
-
|
|
722
|
+
g(this, U).setImageSource(I, i, e);
|
|
707
723
|
}
|
|
708
|
-
setBackground(
|
|
724
|
+
setBackground(I, i = "cover") {
|
|
709
725
|
var e;
|
|
710
|
-
if (
|
|
711
|
-
const
|
|
712
|
-
|
|
726
|
+
if (g(this, p)) {
|
|
727
|
+
const s = I ? [I] : [];
|
|
728
|
+
g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, s);
|
|
713
729
|
} else
|
|
714
|
-
(e =
|
|
730
|
+
(e = g(this, U)) == null || e.setBackground(I ?? null, i);
|
|
715
731
|
}
|
|
716
732
|
// ---------------------------------------------------------------------------
|
|
717
733
|
// Interaction
|
|
@@ -720,293 +736,315 @@ class rI {
|
|
|
720
736
|
* Immediately injects one splat at (x, y) with explicit velocity (vx, vy).
|
|
721
737
|
* Safe to call multiple times per frame. See FluidSimulation.splat for details.
|
|
722
738
|
*/
|
|
723
|
-
splat(
|
|
724
|
-
|
|
739
|
+
splat(I, i, e, s, o = 1) {
|
|
740
|
+
g(this, p) ? g(this, p).postMessage({ type: "splat", x: I, y: i, vx: e, vy: s, strength: o }) : g(this, U).splat(I, i, e, s, o);
|
|
725
741
|
}
|
|
726
|
-
handleMove(
|
|
727
|
-
|
|
742
|
+
handleMove(I, i, e = 1) {
|
|
743
|
+
g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this, U).handleMove(I, i, e);
|
|
728
744
|
}
|
|
729
745
|
// ---------------------------------------------------------------------------
|
|
730
746
|
// Config + control
|
|
731
747
|
// ---------------------------------------------------------------------------
|
|
732
|
-
|
|
733
|
-
I(this,
|
|
748
|
+
updateQuality(I) {
|
|
749
|
+
l(this, T, Math.max(0.1, Math.min(1, I.dpr ?? g(this, T)))), l(this, O, Math.max(0.1, Math.min(1, I.sim ?? g(this, O)))), g(this, p) ? g(this, p).postMessage({ type: "updateQuality", quality: { dpr: g(this, T), sim: g(this, O) } }) : g(this, U).updateQuality(I);
|
|
734
750
|
}
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
751
|
+
updateConfig(I) {
|
|
752
|
+
g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, U).updateConfig(I);
|
|
753
|
+
}
|
|
754
|
+
resize(I, i) {
|
|
755
|
+
const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T);
|
|
756
|
+
g(this, p) ? g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e }) : g(this, U).resize(I, i, e);
|
|
741
757
|
}
|
|
742
758
|
destroy() {
|
|
743
|
-
var
|
|
744
|
-
if (
|
|
745
|
-
const
|
|
746
|
-
|
|
759
|
+
var I;
|
|
760
|
+
if (g(this, p)) {
|
|
761
|
+
const i = g(this, p);
|
|
762
|
+
l(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
|
|
747
763
|
} else
|
|
748
|
-
(
|
|
764
|
+
(I = g(this, U)) == null || I.destroy(), l(this, U, null);
|
|
749
765
|
}
|
|
750
766
|
}
|
|
751
|
-
|
|
752
|
-
const e = typeof window < "u" && window.devicePixelRatio || 1,
|
|
753
|
-
|
|
754
|
-
let
|
|
767
|
+
p = new WeakMap(), U = new WeakMap(), ZI = new WeakMap(), T = new WeakMap(), O = new WeakMap(), XI = new WeakSet(), _I = function(I, i) {
|
|
768
|
+
const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T), s = Math.round(I.clientWidth * e), o = Math.round(I.clientHeight * e);
|
|
769
|
+
I.width = s, I.height = o;
|
|
770
|
+
let t;
|
|
755
771
|
try {
|
|
756
|
-
|
|
772
|
+
t = I.transferControlToOffscreen();
|
|
757
773
|
} catch {
|
|
758
774
|
console.warn(
|
|
759
775
|
"[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
|
|
760
|
-
),
|
|
776
|
+
), l(this, ZI, !1), l(this, U, new EI(I, i, { dpr: g(this, T), sim: g(this, O) }));
|
|
761
777
|
return;
|
|
762
778
|
}
|
|
763
|
-
const
|
|
764
|
-
|
|
765
|
-
console.error("[fluidity-js] Worker error:",
|
|
766
|
-
},
|
|
767
|
-
|
|
768
|
-
},
|
|
779
|
+
const u = l(this, p, new Gg());
|
|
780
|
+
u.onerror = (a) => {
|
|
781
|
+
console.error("[fluidity-js] Worker error:", a.message);
|
|
782
|
+
}, u.onmessage = (a) => {
|
|
783
|
+
a.data.type === "error" && console.error("[fluidity-js] Simulation error:", a.data.message);
|
|
784
|
+
}, u.postMessage(
|
|
785
|
+
{ type: "init", canvas: t, width: s, height: o, config: i, dpr: e, quality: { dpr: g(this, T), sim: g(this, O) } },
|
|
786
|
+
[t]
|
|
787
|
+
);
|
|
769
788
|
};
|
|
770
|
-
function
|
|
771
|
-
const
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
789
|
+
function qI(C, { isWorkerEnabled: I = !0, quality: i = {}, config: e = {} } = {}) {
|
|
790
|
+
const s = mI(null), o = mI({ isWorkerEnabled: I, quality: i, config: e }), t = mI(Math.max(0.1, Math.min(1, i.dpr ?? 1))), u = mI({
|
|
791
|
+
dpr: i.dpr,
|
|
792
|
+
sim: i.sim
|
|
793
|
+
});
|
|
794
|
+
return j(() => {
|
|
795
|
+
const a = C.current;
|
|
796
|
+
if (!a)
|
|
775
797
|
return;
|
|
776
|
-
const
|
|
777
|
-
|
|
778
|
-
const n = window.devicePixelRatio || 1,
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
const
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
798
|
+
const c = document.createElement("canvas");
|
|
799
|
+
c.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", a.appendChild(c);
|
|
800
|
+
const { isWorkerEnabled: n, quality: G, config: d } = o.current, h = (window.devicePixelRatio || 1) * t.current, W = a.getBoundingClientRect(), x = Math.round((W.width || a.clientWidth) * h) || 0, F = Math.round((W.height || a.clientHeight) * h) || 0;
|
|
801
|
+
x > 0 && (c.width = x, c.height = F), F === 0 && console.warn(
|
|
802
|
+
"[fluidity-js] Container has zero height — simulation will not render. Avoid height:auto or percentage heights without a sized ancestor. Use explicit pixel values instead."
|
|
803
|
+
);
|
|
804
|
+
const w = new Bg(c, { isWorkerEnabled: n, quality: G, config: d });
|
|
805
|
+
s.current = w;
|
|
806
|
+
const D = new ResizeObserver((A) => {
|
|
807
|
+
for (const y of A) {
|
|
808
|
+
const r = (window.devicePixelRatio || 1) * t.current, { inlineSize: Z, blockSize: V } = y.contentBoxSize[0];
|
|
809
|
+
w.resize(Math.round(Z * r), Math.round(V * r));
|
|
786
810
|
}
|
|
787
811
|
});
|
|
788
|
-
return
|
|
789
|
-
|
|
812
|
+
return D.observe(a), () => {
|
|
813
|
+
D.disconnect(), w.destroy(), c.remove(), s.current = null;
|
|
790
814
|
};
|
|
791
|
-
}, []),
|
|
815
|
+
}, []), j(() => {
|
|
816
|
+
t.current = Math.max(0.1, Math.min(1, i.dpr ?? 1));
|
|
817
|
+
const a = u.current;
|
|
818
|
+
u.current = { dpr: i.dpr, sim: i.sim };
|
|
819
|
+
const c = s.current, n = C.current;
|
|
820
|
+
if (!c || !n || a.dpr === i.dpr && a.sim === i.sim)
|
|
821
|
+
return;
|
|
822
|
+
c.updateQuality(i);
|
|
823
|
+
const G = (window.devicePixelRatio || 1) * t.current, d = n.clientWidth, h = n.clientHeight;
|
|
824
|
+
d > 0 && h > 0 && c.resize(Math.round(d * G), Math.round(h * G));
|
|
825
|
+
}, [i.dpr, i.sim]), s;
|
|
792
826
|
}
|
|
793
|
-
const
|
|
794
|
-
text:
|
|
795
|
-
fontSize:
|
|
796
|
-
color: e =
|
|
797
|
-
fontFamily:
|
|
798
|
-
fontWeight:
|
|
799
|
-
className:
|
|
800
|
-
style:
|
|
801
|
-
config:
|
|
802
|
-
preset:
|
|
803
|
-
algorithm:
|
|
804
|
-
backgroundColor:
|
|
805
|
-
backgroundSrc:
|
|
806
|
-
backgroundSize:
|
|
807
|
-
isMouseEnabled:
|
|
808
|
-
isWorkerEnabled:
|
|
827
|
+
const Lg = zI(function({
|
|
828
|
+
text: I,
|
|
829
|
+
fontSize: i = $.fontSize,
|
|
830
|
+
color: e = $.color,
|
|
831
|
+
fontFamily: s = $.fontFamily,
|
|
832
|
+
fontWeight: o = $.fontWeight,
|
|
833
|
+
className: t,
|
|
834
|
+
style: u,
|
|
835
|
+
config: a,
|
|
836
|
+
preset: c,
|
|
837
|
+
algorithm: n,
|
|
838
|
+
backgroundColor: G = $.backgroundColor,
|
|
839
|
+
backgroundSrc: d,
|
|
840
|
+
backgroundSize: h = $.backgroundSize,
|
|
841
|
+
isMouseEnabled: W = $.isMouseEnabled,
|
|
842
|
+
isWorkerEnabled: x = $.isWorkerEnabled,
|
|
843
|
+
quality: F = HI.quality
|
|
809
844
|
}, w) {
|
|
810
|
-
const
|
|
811
|
-
isWorkerEnabled:
|
|
812
|
-
|
|
845
|
+
const D = mI(null), A = qI(D, {
|
|
846
|
+
isWorkerEnabled: x,
|
|
847
|
+
quality: F,
|
|
848
|
+
config: pI({ ...a, ...n ? { algorithm: n } : {} }, c, TI)
|
|
813
849
|
});
|
|
814
|
-
|
|
850
|
+
QI(
|
|
815
851
|
w,
|
|
816
852
|
() => ({
|
|
817
853
|
reset() {
|
|
818
|
-
var
|
|
819
|
-
(
|
|
854
|
+
var r;
|
|
855
|
+
(r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
|
|
820
856
|
},
|
|
821
|
-
move(
|
|
857
|
+
move(r, Z, V = 1) {
|
|
822
858
|
var S;
|
|
823
|
-
(S =
|
|
859
|
+
(S = A.current) == null || S.handleMove(r, Z, V);
|
|
824
860
|
},
|
|
825
|
-
splat(
|
|
826
|
-
var
|
|
827
|
-
(
|
|
861
|
+
splat(r, Z, V, S, M = 1) {
|
|
862
|
+
var q;
|
|
863
|
+
(q = A.current) == null || q.splat(r, Z, V, S, M);
|
|
828
864
|
},
|
|
829
|
-
updateConfig(
|
|
830
|
-
var
|
|
831
|
-
(
|
|
865
|
+
updateConfig(r) {
|
|
866
|
+
var Z;
|
|
867
|
+
(Z = A.current) == null || Z.updateConfig(r);
|
|
832
868
|
}
|
|
833
869
|
}),
|
|
834
|
-
[
|
|
835
|
-
),
|
|
836
|
-
var
|
|
837
|
-
(
|
|
838
|
-
}, [
|
|
839
|
-
const
|
|
840
|
-
return
|
|
841
|
-
var
|
|
842
|
-
(
|
|
843
|
-
|
|
870
|
+
[I, i, e, s, o]
|
|
871
|
+
), j(() => {
|
|
872
|
+
var r;
|
|
873
|
+
(r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
|
|
874
|
+
}, [I, i, e, s, o]);
|
|
875
|
+
const y = JSON.stringify(a);
|
|
876
|
+
return j(() => {
|
|
877
|
+
var r;
|
|
878
|
+
(r = A.current) == null || r.updateConfig(
|
|
879
|
+
pI({ ...a, ...n !== void 0 ? { algorithm: n } : {} }, c, TI)
|
|
844
880
|
);
|
|
845
|
-
}, [
|
|
846
|
-
var
|
|
847
|
-
if (!
|
|
848
|
-
(
|
|
881
|
+
}, [c, n, y]), j(() => {
|
|
882
|
+
var Z;
|
|
883
|
+
if (!d) {
|
|
884
|
+
(Z = A.current) == null || Z.setBackground(null);
|
|
849
885
|
return;
|
|
850
886
|
}
|
|
851
|
-
let
|
|
852
|
-
return
|
|
887
|
+
let r = !1;
|
|
888
|
+
return kI(d).then((V) => {
|
|
853
889
|
var S;
|
|
854
|
-
if (
|
|
855
|
-
|
|
890
|
+
if (r) {
|
|
891
|
+
V.close();
|
|
856
892
|
return;
|
|
857
893
|
}
|
|
858
|
-
(S =
|
|
859
|
-
}).catch((
|
|
860
|
-
|
|
894
|
+
(S = A.current) == null || S.setBackground(V, h);
|
|
895
|
+
}).catch((V) => console.error("[fluidity-js] backgroundSrc load failed:", V)), () => {
|
|
896
|
+
r = !0;
|
|
861
897
|
};
|
|
862
|
-
}, [
|
|
863
|
-
if (!
|
|
898
|
+
}, [d, h]), j(() => {
|
|
899
|
+
if (!W)
|
|
864
900
|
return;
|
|
865
|
-
const
|
|
866
|
-
if (!
|
|
901
|
+
const r = D.current;
|
|
902
|
+
if (!r)
|
|
867
903
|
return;
|
|
868
|
-
const
|
|
869
|
-
var
|
|
870
|
-
const
|
|
871
|
-
(
|
|
872
|
-
},
|
|
873
|
-
var
|
|
904
|
+
const Z = (S) => {
|
|
905
|
+
var q;
|
|
906
|
+
const M = r.getBoundingClientRect();
|
|
907
|
+
(q = A.current) == null || q.handleMove(S.clientX - M.left, S.clientY - M.top, 2);
|
|
908
|
+
}, V = (S) => {
|
|
909
|
+
var fI;
|
|
874
910
|
S.preventDefault();
|
|
875
|
-
const
|
|
876
|
-
(
|
|
911
|
+
const M = r.getBoundingClientRect(), q = S.touches[0];
|
|
912
|
+
(fI = A.current) == null || fI.handleMove(q.clientX - M.left, q.clientY - M.top, 1);
|
|
877
913
|
};
|
|
878
|
-
return
|
|
879
|
-
|
|
914
|
+
return r.addEventListener("mousemove", Z), r.addEventListener("touchmove", V, { passive: !1 }), () => {
|
|
915
|
+
r.removeEventListener("mousemove", Z), r.removeEventListener("touchmove", V);
|
|
880
916
|
};
|
|
881
|
-
}, [
|
|
917
|
+
}, [W]), /* @__PURE__ */ NI(
|
|
882
918
|
"div",
|
|
883
919
|
{
|
|
884
|
-
ref:
|
|
885
|
-
className:
|
|
920
|
+
ref: D,
|
|
921
|
+
className: t,
|
|
886
922
|
style: {
|
|
887
923
|
position: "relative",
|
|
888
924
|
display: "block",
|
|
889
925
|
width: "100%",
|
|
890
926
|
height: "100%",
|
|
891
|
-
background:
|
|
892
|
-
...
|
|
927
|
+
background: G,
|
|
928
|
+
...u
|
|
893
929
|
}
|
|
894
930
|
}
|
|
895
931
|
);
|
|
896
|
-
}),
|
|
897
|
-
src:
|
|
898
|
-
effect:
|
|
899
|
-
imageSize: e =
|
|
900
|
-
className:
|
|
901
|
-
style:
|
|
902
|
-
config:
|
|
903
|
-
preset:
|
|
904
|
-
algorithm:
|
|
905
|
-
backgroundColor:
|
|
906
|
-
backgroundSrc:
|
|
907
|
-
backgroundSize:
|
|
908
|
-
isMouseEnabled:
|
|
909
|
-
isWorkerEnabled:
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
932
|
+
}), Vg = zI(function({
|
|
933
|
+
src: I,
|
|
934
|
+
effect: i = iI.effect,
|
|
935
|
+
imageSize: e = iI.imageSize,
|
|
936
|
+
className: s,
|
|
937
|
+
style: o,
|
|
938
|
+
config: t,
|
|
939
|
+
preset: u,
|
|
940
|
+
algorithm: a,
|
|
941
|
+
backgroundColor: c = iI.backgroundColor,
|
|
942
|
+
backgroundSrc: n,
|
|
943
|
+
backgroundSize: G = iI.backgroundSize,
|
|
944
|
+
isMouseEnabled: d = iI.isMouseEnabled,
|
|
945
|
+
isWorkerEnabled: h = iI.isWorkerEnabled,
|
|
946
|
+
quality: W = HI.quality
|
|
947
|
+
}, x) {
|
|
948
|
+
const F = mI(null), w = qI(F, {
|
|
949
|
+
isWorkerEnabled: h,
|
|
950
|
+
quality: W,
|
|
951
|
+
config: pI({ ...t, ...a ? { algorithm: a } : {} }, u)
|
|
914
952
|
});
|
|
915
|
-
|
|
916
|
-
|
|
953
|
+
QI(
|
|
954
|
+
x,
|
|
917
955
|
() => ({
|
|
918
956
|
reset() {
|
|
919
|
-
var
|
|
920
|
-
|
|
957
|
+
var A;
|
|
958
|
+
I && ((A = w.current) == null || A.setImageSource(I, i, e));
|
|
921
959
|
},
|
|
922
|
-
move(
|
|
923
|
-
var
|
|
924
|
-
(
|
|
960
|
+
move(A, y, r = 1) {
|
|
961
|
+
var Z;
|
|
962
|
+
(Z = w.current) == null || Z.handleMove(A, y, r);
|
|
925
963
|
},
|
|
926
|
-
splat(
|
|
964
|
+
splat(A, y, r, Z, V = 1) {
|
|
927
965
|
var S;
|
|
928
|
-
(S = w.current) == null || S.splat(
|
|
966
|
+
(S = w.current) == null || S.splat(A, y, r, Z, V);
|
|
929
967
|
},
|
|
930
|
-
updateConfig(
|
|
931
|
-
var
|
|
932
|
-
(
|
|
968
|
+
updateConfig(A) {
|
|
969
|
+
var y;
|
|
970
|
+
(y = w.current) == null || y.updateConfig(A);
|
|
933
971
|
}
|
|
934
972
|
}),
|
|
935
|
-
[
|
|
936
|
-
),
|
|
937
|
-
var
|
|
938
|
-
|
|
939
|
-
}, [
|
|
940
|
-
const
|
|
941
|
-
return
|
|
942
|
-
var
|
|
943
|
-
(
|
|
944
|
-
|
|
973
|
+
[I, i, e]
|
|
974
|
+
), j(() => {
|
|
975
|
+
var A;
|
|
976
|
+
I && ((A = w.current) == null || A.setImageSource(I, i, e));
|
|
977
|
+
}, [I, i, e]);
|
|
978
|
+
const D = JSON.stringify(t);
|
|
979
|
+
return j(() => {
|
|
980
|
+
var A;
|
|
981
|
+
(A = w.current) == null || A.updateConfig(
|
|
982
|
+
pI({ ...t, ...a !== void 0 ? { algorithm: a } : {} }, u)
|
|
945
983
|
);
|
|
946
|
-
}, [
|
|
947
|
-
var
|
|
948
|
-
if (!
|
|
949
|
-
(
|
|
984
|
+
}, [u, a, D]), j(() => {
|
|
985
|
+
var y;
|
|
986
|
+
if (!n) {
|
|
987
|
+
(y = w.current) == null || y.setBackground(null);
|
|
950
988
|
return;
|
|
951
989
|
}
|
|
952
|
-
let
|
|
953
|
-
return
|
|
954
|
-
var
|
|
955
|
-
if (
|
|
956
|
-
|
|
990
|
+
let A = !1;
|
|
991
|
+
return kI(n).then((r) => {
|
|
992
|
+
var Z;
|
|
993
|
+
if (A) {
|
|
994
|
+
r.close();
|
|
957
995
|
return;
|
|
958
996
|
}
|
|
959
|
-
(
|
|
960
|
-
}).catch((
|
|
961
|
-
|
|
997
|
+
(Z = w.current) == null || Z.setBackground(r, G);
|
|
998
|
+
}).catch((r) => console.error("[fluidity-js] backgroundSrc load failed:", r)), () => {
|
|
999
|
+
A = !0;
|
|
962
1000
|
};
|
|
963
|
-
}, [
|
|
964
|
-
if (!
|
|
1001
|
+
}, [n, G]), j(() => {
|
|
1002
|
+
if (!d)
|
|
965
1003
|
return;
|
|
966
|
-
const
|
|
967
|
-
if (!
|
|
1004
|
+
const A = F.current;
|
|
1005
|
+
if (!A)
|
|
968
1006
|
return;
|
|
969
|
-
const
|
|
1007
|
+
const y = (Z) => {
|
|
970
1008
|
var S;
|
|
971
|
-
const
|
|
972
|
-
(S = w.current) == null || S.handleMove(
|
|
973
|
-
},
|
|
974
|
-
var
|
|
975
|
-
|
|
976
|
-
const
|
|
977
|
-
(
|
|
1009
|
+
const V = A.getBoundingClientRect();
|
|
1010
|
+
(S = w.current) == null || S.handleMove(Z.clientX - V.left, Z.clientY - V.top, 2);
|
|
1011
|
+
}, r = (Z) => {
|
|
1012
|
+
var M;
|
|
1013
|
+
Z.preventDefault();
|
|
1014
|
+
const V = A.getBoundingClientRect(), S = Z.touches[0];
|
|
1015
|
+
(M = w.current) == null || M.handleMove(S.clientX - V.left, S.clientY - V.top, 1);
|
|
978
1016
|
};
|
|
979
|
-
return
|
|
980
|
-
|
|
1017
|
+
return A.addEventListener("mousemove", y), A.addEventListener("touchmove", r, { passive: !1 }), () => {
|
|
1018
|
+
A.removeEventListener("mousemove", y), A.removeEventListener("touchmove", r);
|
|
981
1019
|
};
|
|
982
|
-
}, [
|
|
1020
|
+
}, [d]), /* @__PURE__ */ NI(
|
|
983
1021
|
"div",
|
|
984
1022
|
{
|
|
985
|
-
ref:
|
|
986
|
-
className:
|
|
1023
|
+
ref: F,
|
|
1024
|
+
className: s,
|
|
987
1025
|
style: {
|
|
988
1026
|
position: "relative",
|
|
989
1027
|
display: "block",
|
|
990
1028
|
width: "100%",
|
|
991
1029
|
height: "100%",
|
|
992
|
-
background:
|
|
993
|
-
...
|
|
1030
|
+
background: c,
|
|
1031
|
+
...o
|
|
994
1032
|
}
|
|
995
1033
|
}
|
|
996
1034
|
);
|
|
997
1035
|
});
|
|
998
1036
|
export {
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
1037
|
+
OI as DEFAULT_CONFIG,
|
|
1038
|
+
TI as DEFAULT_CONFIG_TEXT,
|
|
1039
|
+
iI as DEFAULT_PROPS_IMAGE,
|
|
1040
|
+
HI as DEFAULT_PROPS_SHARED,
|
|
1041
|
+
$ as DEFAULT_PROPS_TEXT,
|
|
1042
|
+
Bg as FluidController,
|
|
1043
|
+
Vg as FluidImage,
|
|
1044
|
+
EI as FluidSimulation,
|
|
1045
|
+
Lg as FluidText,
|
|
1046
|
+
ig as PRESETS,
|
|
1047
|
+
kI as loadImageBitmap,
|
|
1048
|
+
pI as mergeConfig,
|
|
1049
|
+
qI as useFluid
|
|
1012
1050
|
};
|