@jayf0x/fluidity-js 0.1.4 → 0.1.5

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