@jayf0x/fluidity-js 0.1.7 → 0.2.2

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 $I = Object.defineProperty;
2
- var Ig = (C, I, i) => I in C ? $I(C, I, { enumerable: !0, configurable: !0, writable: !0, value: i }) : C[I] = i;
3
- var yI = (C, I, i) => (Ig(C, typeof I != "symbol" ? I + "" : I, i), i), UI = (C, I, i) => {
4
- if (!I.has(C))
5
- throw TypeError("Cannot " + i);
1
+ var qI = Object.defineProperty;
2
+ var $I = (e, g, C) => g in e ? qI(e, g, { enumerable: !0, configurable: !0, writable: !0, value: C }) : e[g] = C;
3
+ var oI = (e, g, C) => ($I(e, typeof g != "symbol" ? g + "" : g, C), C), LI = (e, g, C) => {
4
+ if (!g.has(e))
5
+ throw TypeError("Cannot " + C);
6
6
  };
7
- var g = (C, I, i) => (UI(C, I, "read from private field"), i ? i.call(C) : I.get(C)), m = (C, I, i) => {
8
- if (I.has(C))
7
+ var I = (e, g, C) => (LI(e, g, "read from private field"), C ? C.call(e) : g.get(e)), d = (e, g, C) => {
8
+ if (g.has(e))
9
9
  throw TypeError("Cannot add the same private member more than once");
10
- I instanceof WeakSet ? I.add(C) : I.set(C, i);
11
- }, l = (C, I, i, e) => (UI(C, I, "write to private field"), e ? e.call(C, i) : I.set(C, i), i);
12
- var b = (C, I, i) => (UI(C, I, "access private method"), i);
13
- import { jsx as NI } from "react/jsx-runtime";
14
- import { useRef as mI, useEffect as j, forwardRef as zI, useImperativeHandle as QI } from "react";
15
- const OI = {
10
+ g instanceof WeakSet ? g.add(e) : g.set(e, C);
11
+ }, o = (e, g, C, i) => (LI(e, g, "write to private field"), i ? i.call(e, C) : g.set(e, C), C);
12
+ var h = (e, g, C) => (LI(e, g, "access private method"), C);
13
+ import { jsx as xI } from "react/jsx-runtime";
14
+ import { useRef as Tg, useEffect as sg, forwardRef as FI, useImperativeHandle as DI } from "react";
15
+ const TI = {
16
16
  densityDissipation: 0.992,
17
17
  velocityDissipation: 0.93,
18
18
  pressureIterations: 1,
@@ -22,12 +22,12 @@ const OI = {
22
22
  refraction: 0.25,
23
23
  specularExp: 1.01,
24
24
  shine: 0.01,
25
- waterColor: [0, 0, 0],
26
- glowColor: [0.7, 0.85, 1],
25
+ waterColor: "#000000",
26
+ glowColor: "#b3d9ff",
27
27
  algorithm: "standard",
28
28
  warpStrength: 0.015
29
- }, TI = {
30
- ...OI,
29
+ }, UI = {
30
+ ...TI,
31
31
  densityDissipation: 0.99,
32
32
  velocityDissipation: 0.98,
33
33
  pressureIterations: 3,
@@ -37,24 +37,24 @@ const OI = {
37
37
  refraction: 0.25,
38
38
  specularExp: 1,
39
39
  shine: 0.1,
40
- glowColor: [0, 0.502, 1]
41
- }, gg = { dpr: 1, sim: 0.5 }, HI = {
40
+ glowColor: "#0080ff"
41
+ }, gC = { dpr: 1, sim: 0.5 }, wI = {
42
42
  backgroundColor: "#0a0a0a",
43
43
  backgroundSize: "cover",
44
44
  isMouseEnabled: !0,
45
45
  isWorkerEnabled: !0,
46
- quality: gg
47
- }, iI = {
48
- ...HI,
46
+ quality: gC
47
+ }, ng = {
48
+ ...wI,
49
49
  effect: 0,
50
50
  imageSize: "cover"
51
- }, $ = {
52
- ...HI,
51
+ }, ag = {
52
+ ...wI,
53
53
  fontSize: 100,
54
54
  color: "#ffffff",
55
55
  fontFamily: "sans-serif",
56
56
  fontWeight: 900
57
- }, ig = {
57
+ }, IC = {
58
58
  calm: {
59
59
  densityDissipation: 0.999,
60
60
  velocityDissipation: 0.98,
@@ -63,8 +63,8 @@ const OI = {
63
63
  splatForce: 0.5,
64
64
  refraction: 0.15,
65
65
  shine: 5e-3,
66
- glowColor: [0.6, 0.85, 1],
67
- waterColor: [0, 0.02, 0.05]
66
+ glowColor: "#99d9ff",
67
+ waterColor: "#00050d"
68
68
  },
69
69
  sand: {
70
70
  densityDissipation: 0.997,
@@ -75,8 +75,8 @@ const OI = {
75
75
  refraction: 0.8,
76
76
  specularExp: 0.1,
77
77
  shine: 0.05,
78
- glowColor: [0.027, 0.027, 0.027],
79
- waterColor: [0.451, 0.329, 0.125]
78
+ glowColor: "#070707",
79
+ waterColor: "#735420"
80
80
  },
81
81
  wave: {
82
82
  densityDissipation: 0.994,
@@ -86,8 +86,8 @@ const OI = {
86
86
  splatForce: 1.2,
87
87
  refraction: 0.35,
88
88
  shine: 0.03,
89
- glowColor: [0.5, 0.8, 1],
90
- waterColor: [0, 0.01, 0.03]
89
+ glowColor: "#80ccff",
90
+ waterColor: "#000308"
91
91
  },
92
92
  neon: {
93
93
  densityDissipation: 0.985,
@@ -98,8 +98,8 @@ const OI = {
98
98
  refraction: 0.25,
99
99
  specularExp: 0.5,
100
100
  shine: 0.14,
101
- glowColor: [1, 0.2, 0.8],
102
- waterColor: [0.05, 0, 0.08]
101
+ glowColor: "#ff33cc",
102
+ waterColor: "#0d0014"
103
103
  },
104
104
  smoke: {
105
105
  densityDissipation: 0.996,
@@ -109,77 +109,161 @@ const OI = {
109
109
  splatForce: 0.8,
110
110
  refraction: 0.08,
111
111
  shine: 0,
112
- glowColor: [0.5, 0.5, 0.5],
113
- waterColor: [0.06, 0.06, 0.06]
112
+ glowColor: "#808080",
113
+ waterColor: "#0f0f0f"
114
114
  }
115
115
  };
116
- function pI(C = {}, I, i = OI) {
117
- return { ...I ? { ...i, ...ig[I] } : i, ...C };
116
+ function AI(e) {
117
+ if (Array.isArray(e))
118
+ return e;
119
+ const g = e.slice(1, 7);
120
+ return g.length === 3 ? [
121
+ parseInt(g[0] + g[0], 16) / 255,
122
+ parseInt(g[1] + g[1], 16) / 255,
123
+ parseInt(g[2] + g[2], 16) / 255
124
+ ] : [
125
+ parseInt(g.slice(0, 2), 16) / 255,
126
+ parseInt(g.slice(2, 4), 16) / 255,
127
+ parseInt(g.slice(4, 6), 16) / 255
128
+ ];
118
129
  }
119
- function vI(C, I, i, e, s = "cover") {
120
- let o;
121
- s === "cover" ? o = Math.max(i / C, e / I) : s === "contain" ? o = Math.min(i / C, e / I) : typeof s == "string" && s.endsWith("%") ? o = Math.min(i / C, e / I) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? o = parseFloat(s) / Math.max(C, I) : typeof s == "number" ? o = s : o = Math.max(i / C, e / I);
122
- const t = C * o, u = I * o;
123
- return { x: (i - t) / 2, y: (e - u) / 2, drawW: t, drawH: u };
130
+ function II(e = {}, g, C = TI) {
131
+ return { ...g ? { ...C, ...IC[g] } : C, ...e };
124
132
  }
125
- function Cg(C, I, i, e, s = null, o = "cover") {
126
- const { text: t, fontSize: u, color: a, fontFamily: c = "sans-serif", fontWeight: n = 900 } = e, G = new OffscreenCanvas(I, i), d = G.getContext("2d");
127
- ((F) => {
133
+ function jg(e, g, C, i, s = "cover") {
134
+ let l;
135
+ s === "cover" ? l = Math.max(C / e, i / g) : s === "contain" ? l = Math.min(C / e, i / g) : typeof s == "string" && s.endsWith("%") ? l = Math.min(C / e, i / g) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? l = parseFloat(s) / Math.max(e, g) : typeof s == "number" ? l = s : l = Math.max(C / e, i / g);
136
+ const t = e * l, a = g * l;
137
+ return { x: (C - t) / 2, y: (i - a) / 2, drawW: t, drawH: a };
138
+ }
139
+ function CC(e, g, C, i, s = null, l = "cover") {
140
+ const { text: t, fontSize: a, color: u, fontFamily: c = "sans-serif", fontWeight: Z = 900 } = i, S = new OffscreenCanvas(g, C), A = S.getContext("2d");
141
+ ((L) => {
128
142
  if (s) {
129
- d.clearRect(0, 0, I, i), d.fillStyle = "black", d.fillRect(0, 0, I, i);
130
- const { x: w, y: D, drawW: A, drawH: y } = vI(
143
+ A.clearRect(0, 0, g, C), A.fillStyle = "black", A.fillRect(0, 0, g, C);
144
+ const { x: G, y: K, drawW: b, drawH: Y } = jg(
131
145
  s.width,
132
146
  s.height,
133
- I,
134
- i,
135
- o
147
+ g,
148
+ C,
149
+ l
136
150
  );
137
- d.drawImage(s, w, D, A, y);
151
+ A.drawImage(s, G, K, b, Y);
138
152
  } else
139
- d.fillStyle = "black", d.fillRect(0, 0, I, i);
140
- d.fillStyle = F, d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
141
- })(a);
142
- const W = BI(C, G);
143
- d.fillStyle = "black", d.fillRect(0, 0, I, i), d.fillStyle = "white", d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
144
- const x = BI(C, G);
145
- return { backgroundTex: W, obstacleTex: x, coverageTex: x };
153
+ A.fillStyle = "black", A.fillRect(0, 0, g, C);
154
+ A.fillStyle = L, A.font = `${Z} ${a}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
155
+ })(u);
156
+ const m = $g(e, S);
157
+ A.fillStyle = "black", A.fillRect(0, 0, g, C), A.fillStyle = "white", A.font = `${Z} ${a}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
158
+ const r = $g(e, S);
159
+ return { backgroundTex: m, obstacleTex: r, coverageTex: r };
146
160
  }
147
- function eg(C, I, i, e, s = 0, o = "cover", t = null, u = "cover") {
148
- const a = new OffscreenCanvas(i, e), c = a.getContext("2d"), { x: n, y: G, drawW: d, drawH: h } = vI(I.width, I.height, i, e, o);
149
- if (c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), t) {
161
+ function iC(e, g, C, i, s = 0, l = "cover", t = null, a = "cover") {
162
+ const u = new OffscreenCanvas(C, i), c = u.getContext("2d"), { x: Z, y: S, drawW: A, drawH: B } = jg(g.width, g.height, C, i, l);
163
+ if (c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), t) {
150
164
  const {
151
- x: w,
152
- y: D,
153
- drawW: A,
154
- drawH: y
155
- } = vI(t.width, t.height, i, e, u);
156
- c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, w, D, A, y), c.filter = "none";
165
+ x: G,
166
+ y: K,
167
+ drawW: b,
168
+ drawH: Y
169
+ } = jg(t.width, t.height, C, i, a);
170
+ c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, G, K, b, Y), c.filter = "none";
157
171
  }
158
- c.drawImage(I, n, G, d, h);
159
- const W = BI(C, a);
160
- c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(I, n, G, d, h), c.filter = "none";
161
- const x = BI(C, a);
162
- c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.fillStyle = "white", c.fillRect(
163
- Math.max(0, n),
164
- Math.max(0, G),
165
- Math.min(d, i - Math.max(0, n)),
166
- Math.min(h, e - Math.max(0, G))
172
+ c.drawImage(g, Z, S, A, B);
173
+ const m = $g(e, u);
174
+ c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(g, Z, S, A, B), c.filter = "none";
175
+ const r = $g(e, u);
176
+ c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.fillStyle = "white", c.fillRect(
177
+ Math.max(0, Z),
178
+ Math.max(0, S),
179
+ Math.min(A, C - Math.max(0, Z)),
180
+ Math.min(B, i - Math.max(0, S))
167
181
  );
168
- const F = BI(C, a);
169
- return { backgroundTex: W, obstacleTex: x, coverageTex: F };
182
+ const L = $g(e, u);
183
+ return { backgroundTex: m, obstacleTex: r, coverageTex: L };
184
+ }
185
+ function $g(e, g) {
186
+ const C = e.createTexture();
187
+ return e.bindTexture(e.TEXTURE_2D, C), e.pixelStorei(e.UNPACK_FLIP_Y_WEBGL, !0), e.texImage2D(e.TEXTURE_2D, 0, e.RGBA, e.RGBA, e.UNSIGNED_BYTE, g), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_MIN_FILTER, e.LINEAR), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_MAG_FILTER, e.LINEAR), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_WRAP_S, e.CLAMP_TO_EDGE), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_WRAP_T, e.CLAMP_TO_EDGE), C;
188
+ }
189
+ function eC(e, g, C, i, s = null, l = "cover") {
190
+ const { text: t, fontSize: a, color: u, fontFamily: c = "sans-serif", fontWeight: Z = 900 } = i, S = new OffscreenCanvas(g, C), A = S.getContext("2d");
191
+ ((L) => {
192
+ if (s) {
193
+ A.clearRect(0, 0, g, C), A.fillStyle = "black", A.fillRect(0, 0, g, C);
194
+ const { x: G, y: K, drawW: b, drawH: Y } = jg(
195
+ s.width,
196
+ s.height,
197
+ g,
198
+ C,
199
+ l
200
+ );
201
+ A.drawImage(s, G, K, b, Y);
202
+ } else
203
+ A.fillStyle = "black", A.fillRect(0, 0, g, C);
204
+ A.fillStyle = L, A.font = `${Z} ${a}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
205
+ })(u);
206
+ const m = gI(e, S, g, C);
207
+ A.fillStyle = "black", A.fillRect(0, 0, g, C), A.fillStyle = "white", A.font = `${Z} ${a}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
208
+ const r = gI(e, S, g, C);
209
+ return {
210
+ backgroundTex: m,
211
+ backgroundView: m.createView(),
212
+ obstacleTex: r,
213
+ obstacleView: r.createView(),
214
+ coverageTex: r,
215
+ coverageView: r.createView(),
216
+ sharedCoverage: !0
217
+ };
218
+ }
219
+ function sC(e, g, C, i, s = 0, l = "cover", t = null, a = "cover") {
220
+ const u = new OffscreenCanvas(C, i), c = u.getContext("2d"), { x: Z, y: S, drawW: A, drawH: B } = jg(g.width, g.height, C, i, l);
221
+ if (c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), t) {
222
+ const { x: G, y: K, drawW: b, drawH: Y } = jg(
223
+ t.width,
224
+ t.height,
225
+ C,
226
+ i,
227
+ a
228
+ );
229
+ c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, G, K, b, Y), c.filter = "none";
230
+ }
231
+ c.drawImage(g, Z, S, A, B);
232
+ const m = gI(e, u, C, i);
233
+ c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(g, Z, S, A, B), c.filter = "none";
234
+ const r = gI(e, u, C, i);
235
+ c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.fillStyle = "white", c.fillRect(Math.max(0, Z), Math.max(0, S), Math.min(A, C - Math.max(0, Z)), Math.min(B, i - Math.max(0, S)));
236
+ const L = gI(e, u, C, i);
237
+ return {
238
+ backgroundTex: m,
239
+ backgroundView: m.createView(),
240
+ obstacleTex: r,
241
+ obstacleView: r.createView(),
242
+ coverageTex: L,
243
+ coverageView: L.createView(),
244
+ sharedCoverage: !1
245
+ };
170
246
  }
171
- function BI(C, I) {
172
- const i = C.createTexture();
173
- return C.bindTexture(C.TEXTURE_2D, i), C.pixelStorei(C.UNPACK_FLIP_Y_WEBGL, !0), C.texImage2D(C.TEXTURE_2D, 0, C.RGBA, C.RGBA, C.UNSIGNED_BYTE, I), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), i;
247
+ function gI(e, g, C, i) {
248
+ const s = e.createTexture({
249
+ size: [C, i],
250
+ format: "rgba8unorm",
251
+ usage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT
252
+ });
253
+ return e.queue.copyExternalImageToTexture(
254
+ { source: g },
255
+ { texture: s },
256
+ [C, i]
257
+ ), s;
174
258
  }
175
- async function kI(C) {
176
- const I = await fetch(C);
177
- if (!I.ok)
178
- throw new Error(`Failed to fetch image: ${C} (${I.status})`);
179
- const i = await I.blob();
180
- return createImageBitmap(i);
259
+ async function XI(e) {
260
+ const g = await fetch(e);
261
+ if (!g.ok)
262
+ throw new Error(`Failed to fetch image: ${e} (${g.status})`);
263
+ const C = await g.blob();
264
+ return createImageBitmap(C);
181
265
  }
182
- const II = (
266
+ const Zg = (
183
267
  /* glsl */
184
268
  `
185
269
  precision highp float;
@@ -196,7 +280,7 @@ const II = (
196
280
  gl_Position = vec4(aPosition, 0.0, 1.0);
197
281
  }
198
282
  `
199
- ), sg = (
283
+ ), lC = (
200
284
  /* glsl */
201
285
  `
202
286
  precision highp float;
@@ -213,7 +297,7 @@ const II = (
213
297
  gl_FragColor = dissipation * texture2D(uSource, coord);
214
298
  }
215
299
  `
216
- ), lg = (
300
+ ), tC = (
217
301
  /* glsl */
218
302
  `
219
303
  precision highp float;
@@ -228,7 +312,7 @@ const II = (
228
312
  gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
229
313
  }
230
314
  `
231
- ), og = (
315
+ ), oC = (
232
316
  /* glsl */
233
317
  `
234
318
  precision highp float;
@@ -246,7 +330,7 @@ const II = (
246
330
  gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
247
331
  }
248
332
  `
249
- ), tg = (
333
+ ), AC = (
250
334
  /* glsl */
251
335
  `
252
336
  precision highp float;
@@ -264,7 +348,7 @@ const II = (
264
348
  gl_FragColor = vec4(vel, 0.0, 1.0);
265
349
  }
266
350
  `
267
- ), cg = (
351
+ ), cC = (
268
352
  /* glsl */
269
353
  `
270
354
  precision highp float;
@@ -281,7 +365,7 @@ const II = (
281
365
  gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
282
366
  }
283
367
  `
284
- ), ag = (
368
+ ), dC = (
285
369
  /* glsl */
286
370
  `
287
371
  precision highp float;
@@ -295,7 +379,7 @@ const II = (
295
379
  gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
296
380
  }
297
381
  `
298
- ), dg = (
382
+ ), SC = (
299
383
  /* glsl */
300
384
  `
301
385
  precision highp float;
@@ -316,7 +400,7 @@ const II = (
316
400
  gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
317
401
  }
318
402
  `
319
- ), Ag = (
403
+ ), aC = (
320
404
  /* glsl */
321
405
  `
322
406
  precision highp float;
@@ -336,6 +420,7 @@ const II = (
336
420
  uniform float uShine;
337
421
  uniform float uWarpStrength;
338
422
  uniform int uAlgorithm;
423
+ uniform int uEnableAlpha;
339
424
 
340
425
  void main () {
341
426
  float obs = texture2D(uObstacle, vUv).r;
@@ -410,44 +495,65 @@ const II = (
410
495
  color = mix(color, bg * 0.5, obs * 0.2);
411
496
  }
412
497
 
413
- // Premultiplied alpha transparent where there is neither content nor fluid,
414
- // letting the CSS backgroundColor on the container div show through.
498
+ // Output: premultiplied alpha when transparency is enabled (lets CSS backgroundColor
499
+ // show through), or straight opaque colour when enableAlpha is off (perf mode).
415
500
  float alpha = clamp(max(density * 1.5, coverage), 0.0, 1.0);
416
- gl_FragColor = vec4(color * alpha, alpha);
501
+ if (uEnableAlpha == 1) {
502
+ gl_FragColor = vec4(color * alpha, alpha);
503
+ } else {
504
+ gl_FragColor = vec4(color, 1.0);
505
+ }
417
506
  }
418
507
  `
419
508
  );
420
- function mg(C) {
421
- const I = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
422
- let i = C.getContext("webgl2", I);
423
- const e = !!i;
424
- e || (i = C.getContext("webgl", I), i.getExtension("EXT_color_buffer_half_float"));
425
- const s = e ? null : i.getExtension("OES_texture_half_float"), o = e ? i.HALF_FLOAT : s.HALF_FLOAT_OES;
509
+ function ZC(e, g = !0) {
510
+ const C = { alpha: g, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
511
+ let i = e.getContext("webgl2", C);
512
+ const s = !!i;
513
+ s || (i = e.getContext("webgl", C), i.getExtension("EXT_color_buffer_half_float"));
514
+ const l = s ? null : i.getExtension("OES_texture_half_float"), t = s ? i.HALF_FLOAT : l.HALF_FLOAT_OES;
426
515
  return i.getExtension("EXT_color_buffer_float"), i.getExtension("OES_texture_half_float_linear"), {
516
+ type: s ? "webgl2" : "webgl1",
427
517
  gl: i,
428
- isWebGL2: e,
518
+ isWebGL2: s,
429
519
  ext: {
430
- internalFormat: e ? i.RGBA16F : i.RGBA,
520
+ internalFormat: s ? i.RGBA16F : i.RGBA,
431
521
  format: i.RGBA,
432
- type: o
522
+ type: t
433
523
  }
434
524
  };
435
525
  }
436
- class gI {
437
- constructor(I, i, e) {
438
- yI(this, "program");
439
- yI(this, "uniforms", {});
440
- yI(this, "_gl");
441
- this._gl = I, this.program = I.createProgram(), I.attachShader(this.program, this._compile(I.VERTEX_SHADER, i)), I.attachShader(this.program, this._compile(I.FRAGMENT_SHADER, e)), I.linkProgram(this.program);
442
- const s = I.getProgramParameter(this.program, I.ACTIVE_UNIFORMS);
443
- for (let o = 0; o < s; o++) {
444
- const t = I.getActiveUniform(this.program, o).name;
445
- this.uniforms[t] = I.getUniformLocation(this.program, t);
526
+ async function uC(e, g = !0) {
527
+ if (typeof navigator > "u" || !navigator.gpu)
528
+ return null;
529
+ try {
530
+ const C = await navigator.gpu.requestAdapter();
531
+ if (!C)
532
+ return null;
533
+ const i = await C.requestDevice(), s = e.getContext("webgpu");
534
+ if (!s)
535
+ return null;
536
+ const l = navigator.gpu.getPreferredCanvasFormat();
537
+ return s.configure({ device: i, format: l, alphaMode: g ? "premultiplied" : "opaque" }), { type: "webgpu", adapter: C, device: i, context: s, format: l };
538
+ } catch {
539
+ return null;
540
+ }
541
+ }
542
+ class ug {
543
+ constructor(g, C, i) {
544
+ oI(this, "program");
545
+ oI(this, "uniforms", {});
546
+ oI(this, "_gl");
547
+ 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, i)), g.linkProgram(this.program);
548
+ const s = g.getProgramParameter(this.program, g.ACTIVE_UNIFORMS);
549
+ for (let l = 0; l < s; l++) {
550
+ const t = g.getActiveUniform(this.program, l).name;
551
+ this.uniforms[t] = g.getUniformLocation(this.program, t);
446
552
  }
447
553
  }
448
- _compile(I, i) {
449
- const e = this._gl, s = e.createShader(I);
450
- return e.shaderSource(s, i), e.compileShader(s), s;
554
+ _compile(g, C) {
555
+ const i = this._gl, s = i.createShader(g);
556
+ return i.shaderSource(s, C), i.compileShader(s), s;
451
557
  }
452
558
  bind() {
453
559
  this._gl.useProgram(this.program);
@@ -456,119 +562,658 @@ class gI {
456
562
  this._gl.deleteProgram(this.program);
457
563
  }
458
564
  }
459
- function rg(C) {
565
+ function BC(e) {
460
566
  return {
461
- advection: new gI(C, II, sg),
462
- divergence: new gI(C, II, lg),
463
- pressure: new gI(C, II, og),
464
- gradientSubtract: new gI(C, II, tg),
465
- splat: new gI(C, II, cg),
466
- curl: new gI(C, II, ag),
467
- vorticity: new gI(C, II, dg),
468
- display: new gI(C, II, Ag)
567
+ advection: new ug(e, Zg, lC),
568
+ divergence: new ug(e, Zg, tC),
569
+ pressure: new ug(e, Zg, oC),
570
+ gradientSubtract: new ug(e, Zg, AC),
571
+ splat: new ug(e, Zg, cC),
572
+ curl: new ug(e, Zg, dC),
573
+ vorticity: new ug(e, Zg, SC),
574
+ display: new ug(e, Zg, aC)
469
575
  };
470
576
  }
471
- function KI(C, I, i, e) {
472
- C.activeTexture(C.TEXTURE0);
473
- const s = C.createTexture();
474
- C.bindTexture(C.TEXTURE_2D, s), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), C.texImage2D(C.TEXTURE_2D, 0, I.internalFormat, i, e, 0, I.format, I.type, null);
475
- const o = C.createFramebuffer();
476
- return C.bindFramebuffer(C.FRAMEBUFFER, o), C.framebufferTexture2D(C.FRAMEBUFFER, C.COLOR_ATTACHMENT0, C.TEXTURE_2D, s, 0), { tex: s, fbo: o, width: i, height: e };
577
+ function SI(e, g, C, i) {
578
+ e.activeTexture(e.TEXTURE0);
579
+ const s = e.createTexture();
580
+ e.bindTexture(e.TEXTURE_2D, s), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_MIN_FILTER, e.LINEAR), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_MAG_FILTER, e.LINEAR), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_WRAP_S, e.CLAMP_TO_EDGE), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_WRAP_T, e.CLAMP_TO_EDGE), e.texImage2D(e.TEXTURE_2D, 0, g.internalFormat, C, i, 0, g.format, g.type, null);
581
+ const l = e.createFramebuffer();
582
+ return e.bindFramebuffer(e.FRAMEBUFFER, l), e.framebufferTexture2D(e.FRAMEBUFFER, e.COLOR_ATTACHMENT0, e.TEXTURE_2D, s, 0), { tex: s, fbo: l, width: C, height: i };
477
583
  }
478
- function WI(C, I, i, e) {
479
- let s = KI(C, I, i, e), o = KI(C, I, i, e);
584
+ function bI(e, g, C, i) {
585
+ let s = SI(e, g, C, i), l = SI(e, g, C, i);
480
586
  return {
481
587
  get read() {
482
588
  return s;
483
589
  },
484
590
  get write() {
485
- return o;
591
+ return l;
486
592
  },
487
593
  swap() {
488
- [s, o] = [o, s];
594
+ [s, l] = [l, s];
489
595
  },
490
596
  dispose() {
491
- C.deleteTexture(s.tex), C.deleteFramebuffer(s.fbo), C.deleteTexture(o.tex), C.deleteFramebuffer(o.fbo);
597
+ e.deleteTexture(s.tex), e.deleteFramebuffer(s.fbo), e.deleteTexture(l.tex), e.deleteFramebuffer(l.fbo);
492
598
  }
493
599
  };
494
600
  }
495
- function ng(C) {
496
- const I = C.createBuffer();
497
- return C.bindBuffer(C.ARRAY_BUFFER, I), C.bufferData(C.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), C.STATIC_DRAW), C.vertexAttribPointer(0, 2, C.FLOAT, !1, 0, 0), C.enableVertexAttribArray(0), function(e) {
498
- C.bindFramebuffer(C.FRAMEBUFFER, e), C.drawArrays(C.TRIANGLE_FAN, 0, 4);
601
+ function nC(e) {
602
+ const g = e.createBuffer();
603
+ return e.bindBuffer(e.ARRAY_BUFFER, g), e.bufferData(e.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), e.STATIC_DRAW), e.vertexAttribPointer(0, 2, e.FLOAT, !1, 0, 0), e.enableVertexAttribArray(0), function(i) {
604
+ e.bindFramebuffer(e.FRAMEBUFFER, i), e.drawArrays(e.TRIANGLE_FAN, 0, 4);
499
605
  };
500
606
  }
501
- const xI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (C) => setTimeout(C, 1e3 / 60), ug = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, MI = 0.016, Zg = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
502
- var lI, X, SI, oI, rI, K, R, CI, eI, k, nI, P, H, B, E, J, N, _, v, z, f, uI, tI, L, Y, Q, cI, bI, aI, GI, LI, YI, sI, AI, dI, hI, VI, FI, wI, DI, RI, jI;
503
- class EI {
504
- constructor(I, i = {}, e = {}) {
607
+ const bg = (
608
+ /* wgsl */
609
+ `
610
+ struct VSOut {
611
+ @builtin(position) pos : vec4f,
612
+ @location(0) uv : vec2f,
613
+ @location(1) vL : vec2f,
614
+ @location(2) vR : vec2f,
615
+ @location(3) vT : vec2f,
616
+ @location(4) vB : vec2f,
617
+ }`
618
+ ), mC = (
619
+ /* wgsl */
620
+ `
621
+ ${bg}
622
+
623
+ struct U {
624
+ texelSize : vec2f,
625
+ dt : f32,
626
+ dissipation: f32,
627
+ }
628
+ @group(0) @binding(0) var<uniform> u : U;
629
+ @group(0) @binding(1) var samp : sampler;
630
+ @group(0) @binding(2) var uVel : texture_2d<f32>;
631
+ @group(0) @binding(3) var uSrc : texture_2d<f32>;
632
+ @group(0) @binding(4) var uObs : texture_2d<f32>;
633
+
634
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
635
+ var o: VSOut;
636
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
637
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
638
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
639
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
640
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
641
+ o.pos = vec4f(a, 0.0, 1.0);
642
+ return o;
643
+ }
644
+
645
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
646
+ // Sample all textures before branching — textureSample requires uniform control flow
647
+ let obs = textureSample(uObs, samp, i.uv).r;
648
+ let vel = textureSample(uVel, samp, i.uv).xy;
649
+ let coord = i.uv - u.dt * vel * u.texelSize;
650
+ let src = textureSample(uSrc, samp, coord);
651
+ if (obs > 0.5) { return vec4f(0.0); }
652
+ return u.dissipation * src;
653
+ }
654
+ `
655
+ ), GC = (
656
+ /* wgsl */
657
+ `
658
+ ${bg}
659
+
660
+ struct U { texelSize: vec2f, _pad: vec2f }
661
+ @group(0) @binding(0) var<uniform> u : U;
662
+ @group(0) @binding(1) var samp : sampler;
663
+ @group(0) @binding(2) var uVel : texture_2d<f32>;
664
+ @group(0) @binding(3) var uObs : texture_2d<f32>;
665
+
666
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
667
+ var o: VSOut;
668
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
669
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
670
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
671
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
672
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
673
+ o.pos = vec4f(a, 0.0, 1.0);
674
+ return o;
675
+ }
676
+
677
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
678
+ let L = select(textureSample(uVel, samp, i.vL).x, 0.0, textureSample(uObs, samp, i.vL).r > 0.5);
679
+ let R = select(textureSample(uVel, samp, i.vR).x, 0.0, textureSample(uObs, samp, i.vR).r > 0.5);
680
+ let T = select(textureSample(uVel, samp, i.vT).y, 0.0, textureSample(uObs, samp, i.vT).r > 0.5);
681
+ let B = select(textureSample(uVel, samp, i.vB).y, 0.0, textureSample(uObs, samp, i.vB).r > 0.5);
682
+ return vec4f(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
683
+ }
684
+ `
685
+ ), pC = (
686
+ /* wgsl */
687
+ `
688
+ ${bg}
689
+
690
+ struct U { texelSize: vec2f, _pad: vec2f }
691
+ @group(0) @binding(0) var<uniform> u : U;
692
+ @group(0) @binding(1) var samp : sampler;
693
+ @group(0) @binding(2) var uPres: texture_2d<f32>;
694
+ @group(0) @binding(3) var uDiv : texture_2d<f32>;
695
+ @group(0) @binding(4) var uObs : texture_2d<f32>;
696
+
697
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
698
+ var o: VSOut;
699
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
700
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
701
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
702
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
703
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
704
+ o.pos = vec4f(a, 0.0, 1.0);
705
+ return o;
706
+ }
707
+
708
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
709
+ let C = textureSample(uPres, samp, i.uv).x;
710
+ let L = select(textureSample(uPres, samp, i.vL).x, C, textureSample(uObs, samp, i.vL).r > 0.5);
711
+ let R = select(textureSample(uPres, samp, i.vR).x, C, textureSample(uObs, samp, i.vR).r > 0.5);
712
+ let T = select(textureSample(uPres, samp, i.vT).x, C, textureSample(uObs, samp, i.vT).r > 0.5);
713
+ let B = select(textureSample(uPres, samp, i.vB).x, C, textureSample(uObs, samp, i.vB).r > 0.5);
714
+ let dv = textureSample(uDiv, samp, i.uv).x;
715
+ return vec4f((L + R + B + T - dv) * 0.25, 0.0, 0.0, 1.0);
716
+ }
717
+ `
718
+ ), rC = (
719
+ /* wgsl */
720
+ `
721
+ ${bg}
722
+
723
+ struct U { texelSize: vec2f, _pad: vec2f }
724
+ @group(0) @binding(0) var<uniform> u : U;
725
+ @group(0) @binding(1) var samp : sampler;
726
+ @group(0) @binding(2) var uPres: texture_2d<f32>;
727
+ @group(0) @binding(3) var uVel : texture_2d<f32>;
728
+ @group(0) @binding(4) var uObs : texture_2d<f32>;
729
+
730
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
731
+ var o: VSOut;
732
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
733
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
734
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
735
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
736
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
737
+ o.pos = vec4f(a, 0.0, 1.0);
738
+ return o;
739
+ }
740
+
741
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
742
+ // Sample all textures before branching — textureSample requires uniform control flow
743
+ let obs = textureSample(uObs, samp, i.uv).r;
744
+ let L = textureSample(uPres, samp, i.vL).x;
745
+ let R = textureSample(uPres, samp, i.vR).x;
746
+ let T = textureSample(uPres, samp, i.vT).x;
747
+ let B = textureSample(uPres, samp, i.vB).x;
748
+ let vel = textureSample(uVel, samp, i.uv).xy - vec2f(R - L, T - B);
749
+ if (obs > 0.5) { return vec4f(0.0); }
750
+ return vec4f(vel, 0.0, 1.0);
751
+ }
752
+ `
753
+ ), wC = (
754
+ /* wgsl */
755
+ `
756
+ ${bg}
757
+
758
+ // texelSize occupies bytes 0-7 for the shared vertex stage; aspectRatio/radius fill the rest.
759
+ struct U {
760
+ texelSize : vec2f,
761
+ aspectRatio: f32,
762
+ radius : f32,
763
+ color : vec4f, // xyz = colour, w unused
764
+ point : vec2f,
765
+ _pad : vec2f,
766
+ }
767
+ @group(0) @binding(0) var<uniform> u : U;
768
+ @group(0) @binding(1) var samp : sampler;
769
+ @group(0) @binding(2) var uTgt : texture_2d<f32>;
770
+
771
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
772
+ var o: VSOut;
773
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
774
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
775
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
776
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
777
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
778
+ o.pos = vec4f(a, 0.0, 1.0);
779
+ return o;
780
+ }
781
+
782
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
783
+ var p = i.uv - u.point;
784
+ p.x *= u.aspectRatio;
785
+ let sp = exp(-dot(p, p) / u.radius) * u.color.xyz;
786
+ return vec4f(textureSample(uTgt, samp, i.uv).xyz + sp, 1.0);
787
+ }
788
+ `
789
+ ), LC = (
790
+ /* wgsl */
791
+ `
792
+ ${bg}
793
+
794
+ struct U { texelSize: vec2f, _pad: vec2f }
795
+ @group(0) @binding(0) var<uniform> u : U;
796
+ @group(0) @binding(1) var samp : sampler;
797
+ @group(0) @binding(2) var uVel : texture_2d<f32>;
798
+
799
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
800
+ var o: VSOut;
801
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
802
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
803
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
804
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
805
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
806
+ o.pos = vec4f(a, 0.0, 1.0);
807
+ return o;
808
+ }
809
+
810
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
811
+ let L = textureSample(uVel, samp, i.vL).y;
812
+ let R = textureSample(uVel, samp, i.vR).y;
813
+ let T = textureSample(uVel, samp, i.vT).x;
814
+ let B = textureSample(uVel, samp, i.vB).x;
815
+ return vec4f(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
816
+ }
817
+ `
818
+ ), bC = (
819
+ /* wgsl */
820
+ `
821
+ ${bg}
822
+
823
+ struct U {
824
+ texelSize: vec2f,
825
+ curl : f32,
826
+ dt : f32,
827
+ }
828
+ @group(0) @binding(0) var<uniform> u : U;
829
+ @group(0) @binding(1) var samp : sampler;
830
+ @group(0) @binding(2) var uVel : texture_2d<f32>;
831
+ @group(0) @binding(3) var uCrl : texture_2d<f32>;
832
+
833
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
834
+ var o: VSOut;
835
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
836
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
837
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
838
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
839
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
840
+ o.pos = vec4f(a, 0.0, 1.0);
841
+ return o;
842
+ }
843
+
844
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
845
+ let L = textureSample(uCrl, samp, i.vL).x;
846
+ let R = textureSample(uCrl, samp, i.vR).x;
847
+ let T = textureSample(uCrl, samp, i.vT).x;
848
+ let B = textureSample(uCrl, samp, i.vB).x;
849
+ let C = textureSample(uCrl, samp, i.uv).x;
850
+ var force = 0.5 * vec2f(abs(T) - abs(B), abs(R) - abs(L));
851
+ force /= length(force) + 0.0001;
852
+ force *= u.curl * 30.0 * C;
853
+ let vel = textureSample(uVel, samp, i.uv).xy + force * u.dt;
854
+ return vec4f(vel, 0.0, 1.0);
855
+ }
856
+ `
857
+ ), hC = (
858
+ /* wgsl */
859
+ `
860
+ ${bg}
861
+
862
+ struct U {
863
+ texelSize : vec2f,
864
+ refraction : f32,
865
+ specularExp : f32,
866
+ waterColor : vec4f,
867
+ glowColor : vec4f,
868
+ shine : f32,
869
+ warpStrength: f32,
870
+ algorithm : i32,
871
+ enableAlpha : i32,
872
+ }
873
+ @group(0) @binding(0) var<uniform> u : U;
874
+ @group(0) @binding(1) var samp : sampler;
875
+ @group(0) @binding(2) var uTex : texture_2d<f32>;
876
+ @group(0) @binding(3) var uObs : texture_2d<f32>;
877
+ @group(0) @binding(4) var uBg : texture_2d<f32>;
878
+ @group(0) @binding(5) var uCov : texture_2d<f32>;
879
+ @group(0) @binding(6) var uVel : texture_2d<f32>;
880
+
881
+ @vertex fn vs(@location(0) a: vec2f) -> VSOut {
882
+ var o: VSOut;
883
+ o.uv = vec2f(a.x * 0.5 + 0.5, 0.5 - a.y * 0.5);
884
+ o.vL = o.uv - vec2f(u.texelSize.x, 0.0);
885
+ o.vR = o.uv + vec2f(u.texelSize.x, 0.0);
886
+ o.vT = o.uv + vec2f(0.0, u.texelSize.y);
887
+ o.vB = o.uv - vec2f(0.0, u.texelSize.y);
888
+ o.pos = vec4f(a, 0.0, 1.0);
889
+ return o;
890
+ }
891
+
892
+ @fragment fn fs(i: VSOut) -> @location(0) vec4f {
893
+ let obs = textureSample(uObs, samp, i.uv).r;
894
+ let density = max(textureSample(uTex, samp, i.uv).r, 0.0) * (1.0 - step(0.5, obs));
895
+ let cov = textureSample(uCov, samp, i.uv).r;
896
+
897
+ let ts2 = u.texelSize * 2.0;
898
+ let dL = max(textureSample(uTex, samp, i.uv - vec2f(ts2.x, 0.0)).r, 0.0);
899
+ let dR = max(textureSample(uTex, samp, i.uv + vec2f(ts2.x, 0.0)).r, 0.0);
900
+ let dT = max(textureSample(uTex, samp, i.uv + vec2f(0.0, ts2.y)).r, 0.0);
901
+ let dB = max(textureSample(uTex, samp, i.uv - vec2f(0.0, ts2.y)).r, 0.0);
902
+
903
+ let norm = normalize(vec3f(dL - dR, dB - dT, 0.2));
904
+ let ldir = normalize(vec3f(0.5, 1.0, 0.5));
905
+ let halfV = normalize(ldir + vec3f(0.0, 0.0, 1.0));
906
+ let spec = pow(max(dot(norm, halfV), 0.0), u.specularExp) * u.shine * density;
907
+
908
+ let bgRaw = textureSample(uBg, samp, i.uv).rgb;
909
+ let wc = u.waterColor.rgb;
910
+ let gc = u.glowColor.rgb;
911
+ let bg = mix(wc, bgRaw, cov);
912
+ var color = bg;
913
+
914
+ if (u.algorithm == 1) {
915
+ let ruv = clamp(i.uv + norm.xy * u.refraction * density * 3.0, vec2f(0.0), vec2f(1.0));
916
+ let rbg = mix(wc, textureSample(uBg, samp, mix(i.uv, ruv, 1.0 - obs)).rgb, cov);
917
+ color = rbg + spec * gc * 2.5;
918
+ color = mix(color, bg * 0.6, obs * 0.3);
919
+ } else if (u.algorithm == 2) {
920
+ let inkD = min(density * 4.0, 1.0);
921
+ let ruv = clamp(i.uv + norm.xy * u.refraction * density * 0.4, vec2f(0.0), vec2f(1.0));
922
+ let rbg = mix(wc, textureSample(uBg, samp, mix(i.uv, ruv, 1.0 - obs)).rgb, cov);
923
+ color = mix(rbg, wc + spec * gc, inkD);
924
+ color = mix(color, bg * 0.5, obs * 0.15);
925
+ } else if (u.algorithm == 3) {
926
+ let vel = textureSample(uVel, samp, i.uv).xy;
927
+ let velMag = clamp(length(vel) * 20.0, 0.0, 1.0);
928
+ let wuv = clamp(i.uv + vel * u.warpStrength, vec2f(0.0), vec2f(1.0));
929
+ let wbg = mix(wc, textureSample(uBg, samp, wuv).rgb, cov);
930
+ color = mix(bg, wbg, velMag * (1.0 - obs));
931
+ color += spec * gc * velMag * 1.5;
932
+ color += wc * density * 0.3;
933
+ color = mix(color, bg * 0.5, obs * 0.2);
934
+ } else if (u.algorithm == 4) {
935
+ let ruv = clamp(i.uv + norm.xy * u.refraction * density * 6.0, vec2f(0.0), vec2f(1.0));
936
+ let rbg = mix(wc, textureSample(uBg, samp, mix(i.uv, ruv, 1.0 - obs)).rgb, cov);
937
+ let fres = pow(clamp(1.0 - dot(norm, vec3f(0.0, 0.0, 1.0)), 0.0, 1.0), 3.0) * density;
938
+ color = rbg;
939
+ color += fres * gc * 2.0;
940
+ color += spec * gc * density * 2.0;
941
+ color = mix(color, bg * 0.5, obs * 0.2);
942
+ } else {
943
+ let ruv = i.uv + norm.xy * u.refraction * density;
944
+ let rbg = mix(wc, textureSample(uBg, samp, mix(i.uv, ruv, 1.0 - obs)).rgb, cov);
945
+ color = mix(rbg, wc, min(density * 1.5, 0.8));
946
+ color += spec * gc;
947
+ color = mix(color, bg * 0.5, obs * 0.2);
948
+ }
949
+
950
+ let alpha = clamp(max(density * 1.5, cov), 0.0, 1.0);
951
+ if (u.enableAlpha == 1) {
952
+ return vec4f(color * alpha, alpha);
953
+ }
954
+ return vec4f(color, 1.0);
955
+ }
956
+ `
957
+ ), KC = {
958
+ arrayStride: 8,
959
+ attributes: [{ shaderLocation: 0, offset: 0, format: "float32x2" }]
960
+ }, WI = new Float32Array([
961
+ -1,
962
+ -1,
963
+ -1,
964
+ 1,
965
+ 1,
966
+ -1,
967
+ 1,
968
+ -1,
969
+ -1,
970
+ 1,
971
+ 1,
972
+ 1
973
+ ]);
974
+ function VC(e) {
975
+ const g = e.createBuffer({ size: WI.byteLength, usage: GPUBufferUsage.VERTEX | GPUBufferUsage.COPY_DST });
976
+ return e.queue.writeBuffer(g, 0, WI), g;
977
+ }
978
+ function aI(e, g, C, i) {
979
+ const s = e.createTexture({
980
+ size: [C, i],
981
+ format: g,
982
+ usage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.RENDER_ATTACHMENT | GPUTextureUsage.COPY_SRC
983
+ });
984
+ return { tex: s, view: s.createView(), width: C, height: i };
985
+ }
986
+ function hI(e, g, C, i) {
987
+ let s = aI(e, g, C, i), l = aI(e, g, C, i);
988
+ return {
989
+ get read() {
990
+ return s;
991
+ },
992
+ get write() {
993
+ return l;
994
+ },
995
+ swap() {
996
+ [s, l] = [l, s];
997
+ },
998
+ dispose() {
999
+ s.tex.destroy(), l.tex.destroy();
1000
+ }
1001
+ };
1002
+ }
1003
+ function Bg(e, g, C, i) {
1004
+ const s = e.createShaderModule({ code: g });
1005
+ return e.createRenderPipeline({
1006
+ layout: "auto",
1007
+ vertex: { module: s, entryPoint: "vs", buffers: [KC] },
1008
+ fragment: { module: s, entryPoint: "fs", targets: [{ format: C, ...i ? { blend: i } : {} }] },
1009
+ primitive: { topology: "triangle-list" }
1010
+ });
1011
+ }
1012
+ const yC = {
1013
+ color: { operation: "add", srcFactor: "one", dstFactor: "zero" },
1014
+ alpha: { operation: "add", srcFactor: "one", dstFactor: "zero" }
1015
+ };
1016
+ function HC(e, g, C = !0) {
1017
+ const i = "rgba16float";
1018
+ return {
1019
+ advection: Bg(e, mC, i),
1020
+ divergence: Bg(e, GC, i),
1021
+ pressure: Bg(e, pC, i),
1022
+ gradientSubtract: Bg(e, rC, i),
1023
+ splat: Bg(e, wC, i),
1024
+ curl: Bg(e, LC, i),
1025
+ vorticity: Bg(e, bC, i),
1026
+ display: Bg(e, hC, g, C ? void 0 : yC)
1027
+ };
1028
+ }
1029
+ function XC(e) {
1030
+ return e.createSampler({ magFilter: "linear", minFilter: "linear", addressModeU: "clamp-to-edge", addressModeV: "clamp-to-edge" });
1031
+ }
1032
+ function q(e, g) {
1033
+ return e.createBuffer({ size: g, usage: GPUBufferUsage.UNIFORM | GPUBufferUsage.COPY_DST });
1034
+ }
1035
+ function YI(e, g, C, i, s, l) {
1036
+ const t = new Float32Array([C, i, s, l]);
1037
+ e.queue.writeBuffer(g, 0, t);
1038
+ }
1039
+ function cI(e, g, C, i) {
1040
+ const s = new Float32Array([C, i, 0, 0]);
1041
+ e.queue.writeBuffer(g, 0, s);
1042
+ }
1043
+ function vC(e, g, C, i, s, l) {
1044
+ const t = new Float32Array([C, i, s, l]);
1045
+ e.queue.writeBuffer(g, 0, t);
1046
+ }
1047
+ function dI(e, g, C, i, s, l, t, a, u, c, Z) {
1048
+ const S = new Float32Array(12);
1049
+ S[0] = C, S[1] = i, S[2] = s, S[3] = l, S[4] = t, S[5] = a, S[6] = u, S[7] = 0, S[8] = c, S[9] = Z, S[10] = 0, S[11] = 0, e.queue.writeBuffer(g, 0, S);
1050
+ }
1051
+ function RC(e, g, C, i, s, l, t, a, u, c, Z, S) {
1052
+ const A = new Float32Array(16), B = new Int32Array(A.buffer);
1053
+ A[0] = C, A[1] = i, A[2] = s, A[3] = l, A[4] = t[0], A[5] = t[1], A[6] = t[2], A[7] = 0, A[8] = a[0], A[9] = a[1], A[10] = a[2], A[11] = 0, A[12] = u, A[13] = c, B[14] = Z, B[15] = S ? 1 : 0, e.queue.writeBuffer(g, 0, A);
1054
+ }
1055
+ function Q(e, g, C, i, s) {
1056
+ const l = e.beginRenderPass({
1057
+ colorAttachments: [{
1058
+ view: s,
1059
+ clearValue: [0, 0, 0, 0],
1060
+ loadOp: "clear",
1061
+ storeOp: "store"
1062
+ }]
1063
+ });
1064
+ l.setPipeline(g), l.setBindGroup(0, C), l.setVertexBuffer(0, i), l.draw(6), l.end();
1065
+ }
1066
+ function UC(e, g, C, i, s) {
1067
+ const l = e.beginRenderPass({
1068
+ colorAttachments: [{
1069
+ view: s,
1070
+ clearValue: [0, 0, 0, 0],
1071
+ loadOp: "clear",
1072
+ storeOp: "store"
1073
+ }]
1074
+ });
1075
+ l.setPipeline(g), l.setBindGroup(0, C), l.setVertexBuffer(0, i), l.draw(6), l.end();
1076
+ }
1077
+ const kI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (e) => setTimeout(e, 1e3 / 60), WC = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, Pg = 0.016, MI = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
1078
+ var hg, O, CI, Kg, Jg, M, X, $, gg, Ig, lg, J, Cg, D, zg, Vg, Ng, f, y, mg, ig, Gg, N, yg, Hg, Xg, vg, Rg, tg, og, Ug, Wg, Yg, H, v, E, j, T, Qg, Ag, z, pg, cg, w, k, eg, kg, iI, Mg, uI, JI, fg, _g, eI, KI, rg, Dg, xg, qg, sI, VI, lI, yI, BI, zI, nI, NI, mI, QI, GI, OI, pI, EI;
1079
+ const vI = class vI {
1080
+ // ── Constructor ─────────────────────────────────────────────────────────────
1081
+ constructor(g, C = {}, i = {}, s, l = !0) {
1082
+ // ---------------------------------------------------------------------------
1083
+ // Private — GPU initialisation
1084
+ // ---------------------------------------------------------------------------
1085
+ d(this, uI);
1086
+ // ---------------------------------------------------------------------------
1087
+ // Private — shared helpers
1088
+ // ---------------------------------------------------------------------------
1089
+ d(this, fg);
1090
+ d(this, eI);
1091
+ d(this, rg);
1092
+ d(this, xg);
1093
+ d(this, sI);
1094
+ d(this, lI);
1095
+ // ---------------------------------------------------------------------------
1096
+ // Private — frame dispatch
1097
+ // ---------------------------------------------------------------------------
1098
+ d(this, BI);
1099
+ // ---------------------------------------------------------------------------
1100
+ // Private — WebGPU simulation step
1101
+ // ---------------------------------------------------------------------------
1102
+ d(this, nI);
505
1103
  // ---------------------------------------------------------------------------
506
- // Private helpers
1104
+ // Private — WebGPU direct splat
507
1105
  // ---------------------------------------------------------------------------
508
- m(this, aI);
509
- m(this, LI);
510
- m(this, sI);
511
- m(this, dI);
512
- m(this, VI);
513
- m(this, wI);
514
- m(this, RI);
515
- m(this, lI, void 0);
516
- m(this, X, void 0);
517
- m(this, SI, void 0);
518
- m(this, oI, void 0);
519
- m(this, rI, void 0);
520
- m(this, K, 0);
521
- m(this, R, 0);
522
- m(this, CI, 0);
523
- m(this, eI, 0);
524
- m(this, k, 1);
525
- m(this, nI, 1);
526
- m(this, P, 0.5);
527
- m(this, H, null);
528
- m(this, B, null);
529
- m(this, E, null);
530
- m(this, J, null);
531
- m(this, N, null);
532
- m(this, _, null);
533
- m(this, v, null);
534
- m(this, z, null);
535
- // binary content mask for transparent canvas support
536
- m(this, f, null);
537
- // optional background image (from backgroundSrc prop)
538
- m(this, uI, "cover");
539
- m(this, tI, void 0);
540
- m(this, L, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
541
- // Stores source so textures can be rebuilt on resize
542
- m(this, Y, null);
543
- m(this, Q, null);
544
- m(this, cI, !1);
545
- m(this, bI, !1);
546
- l(this, lI, I), l(this, nI, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, P, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, tI, pI(i));
547
- const { gl: s, ext: o } = mg(I);
548
- l(this, X, s), l(this, SI, o), l(this, oI, rg(s)), l(this, rI, ng(s)), s.clearColor(0, 0, 0, 0);
1106
+ d(this, mI);
1107
+ // ---------------------------------------------------------------------------
1108
+ // Private — WebGL splat
1109
+ // ---------------------------------------------------------------------------
1110
+ d(this, GI);
1111
+ // ---------------------------------------------------------------------------
1112
+ // Private — WebGL simulation step (unchanged from original)
1113
+ // ---------------------------------------------------------------------------
1114
+ d(this, pI);
1115
+ d(this, hg, void 0);
1116
+ // ── WebGL path ──────────────────────────────────────────────────────────────
1117
+ d(this, O, null);
1118
+ d(this, CI, null);
1119
+ d(this, Kg, null);
1120
+ d(this, Jg, null);
1121
+ d(this, M, null);
1122
+ d(this, X, null);
1123
+ d(this, $, null);
1124
+ d(this, gg, null);
1125
+ d(this, Ig, null);
1126
+ d(this, lg, null);
1127
+ d(this, J, null);
1128
+ d(this, Cg, null);
1129
+ // ── WebGPU path ─────────────────────────────────────────────────────────────
1130
+ d(this, D, null);
1131
+ d(this, zg, null);
1132
+ d(this, Vg, null);
1133
+ d(this, Ng, null);
1134
+ d(this, f, null);
1135
+ d(this, y, null);
1136
+ d(this, mg, null);
1137
+ d(this, ig, null);
1138
+ d(this, Gg, null);
1139
+ d(this, N, null);
1140
+ // Pre-allocated uniform buffers (sizes: see gpu-utils writeXxx docs)
1141
+ // Velocity/density advection use separate buffers — writeBuffer is a queue op;
1142
+ // a second write to the same buffer before queue.submit() aliases both passes.
1143
+ d(this, yg, null);
1144
+ // 16 bytes velocity advection
1145
+ d(this, Hg, null);
1146
+ // 16 bytes density advection
1147
+ d(this, Xg, null);
1148
+ // 16 bytes
1149
+ d(this, vg, null);
1150
+ // 16 bytes
1151
+ d(this, Rg, null);
1152
+ // 16 bytes
1153
+ d(this, tg, null);
1154
+ // 48 bytes — velocity splat
1155
+ d(this, og, null);
1156
+ // 48 bytes — density splat
1157
+ d(this, Ug, null);
1158
+ // 16 bytes
1159
+ d(this, Wg, null);
1160
+ // 16 bytes
1161
+ d(this, Yg, null);
1162
+ // 64 bytes
1163
+ // ── Shared state ────────────────────────────────────────────────────────────
1164
+ d(this, H, 0);
1165
+ d(this, v, 0);
1166
+ d(this, E, 0);
1167
+ d(this, j, 0);
1168
+ d(this, T, 1);
1169
+ d(this, Qg, 1);
1170
+ d(this, Ag, 0.5);
1171
+ d(this, z, null);
1172
+ d(this, pg, "cover");
1173
+ d(this, cg, void 0);
1174
+ d(this, w, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
1175
+ d(this, k, null);
1176
+ d(this, eg, null);
1177
+ d(this, kg, !1);
1178
+ d(this, iI, !1);
1179
+ d(this, Mg, !0);
1180
+ if (o(this, hg, g), o(this, Qg, Math.max(0.1, Math.min(1, i.dpr ?? 1))), o(this, Ag, Math.max(0.1, Math.min(1, i.sim ?? 0.5))), o(this, cg, II(C)), o(this, Mg, l), s)
1181
+ o(this, D, s), h(this, uI, JI).call(this, s);
1182
+ else {
1183
+ const { gl: t, ext: a } = ZC(g, l);
1184
+ o(this, O, t), o(this, CI, a), o(this, Kg, BC(t)), o(this, Jg, nC(t)), t.clearColor(0, 0, 0, l ? 0 : 1);
1185
+ }
1186
+ }
1187
+ /**
1188
+ * WebGPU-first factory. Tries WebGPU, falls back to WebGL2 → WebGL1.
1189
+ * This is the recommended entry point when WebGPU support is desired.
1190
+ */
1191
+ static async create(g, C = {}, i = {}, s = !0, l = !0) {
1192
+ const t = s ? await uC(g, l) : null;
1193
+ return new vI(g, C, i, t ?? void 0, l);
549
1194
  }
550
1195
  // ---------------------------------------------------------------------------
551
1196
  // Public API
552
1197
  // ---------------------------------------------------------------------------
553
- setTextSource(I) {
554
- l(this, Y, { type: "text", opts: I }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
1198
+ setTextSource(g) {
1199
+ o(this, k, { type: "text", opts: g }), h(this, fg, _g).call(this), h(this, rg, Dg).call(this), h(this, xg, qg).call(this);
555
1200
  }
556
- async setImageSource(I, i = 0, e = "cover") {
557
- const s = await kI(I);
558
- if (g(this, bI)) {
1201
+ async setImageSource(g, C = 0, i = "cover") {
1202
+ const s = await XI(g);
1203
+ if (I(this, iI)) {
559
1204
  s.close();
560
1205
  return;
561
1206
  }
562
- l(this, Y, { type: "image", bitmap: s, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
1207
+ o(this, k, { type: "image", bitmap: s, effect: C, size: i }), h(this, fg, _g).call(this), h(this, rg, Dg).call(this), h(this, xg, qg).call(this);
563
1208
  }
564
- setImageBitmap(I, i = 0, e = "cover") {
565
- l(this, Y, { type: "image", bitmap: I, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
1209
+ setImageBitmap(g, C = 0, i = "cover") {
1210
+ o(this, k, { type: "image", bitmap: g, effect: C, size: i }), h(this, fg, _g).call(this), h(this, rg, Dg).call(this), h(this, xg, qg).call(this);
566
1211
  }
567
- setBackground(I, i = "cover") {
568
- g(this, f) && g(this, f) !== I && g(this, f).close(), l(this, f, I), l(this, uI, i ?? "cover"), g(this, Y) && g(this, K) > 0 && g(this, R) > 0 && b(this, sI, AI).call(this);
1212
+ setBackground(g, C = "cover") {
1213
+ I(this, z) && I(this, z) !== g && I(this, z).close(), o(this, z, g), o(this, pg, C ?? "cover"), I(this, k) && I(this, H) > 0 && I(this, v) > 0 && h(this, rg, Dg).call(this);
569
1214
  }
570
- handleMove(I, i, e = 1) {
571
- g(this, L).moved = !0, g(this, L).dx = (I - g(this, L).targetX) * e, g(this, L).dy = (i - g(this, L).targetY) * e, g(this, L).targetX = I, g(this, L).targetY = i;
1215
+ handleMove(g, C, i = 1) {
1216
+ I(this, w).moved = !0, I(this, w).dx = (g - I(this, w).targetX) * i, I(this, w).dy = (C - I(this, w).targetY) * i, I(this, w).targetX = g, I(this, w).targetY = C;
572
1217
  }
573
1218
  /**
574
1219
  * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
@@ -577,157 +1222,416 @@ class EI {
577
1222
  * where you want N independent injection points per frame without flooding the
578
1223
  * mouse-state machine or the worker message queue.
579
1224
  */
580
- splat(I, i, e, s, o = 1) {
581
- if (!g(this, cI) || g(this, K) === 0)
582
- return;
583
- const t = g(this, X), u = g(this, tI), { splat: a } = g(this, oI), c = g(this, rI);
584
- t.viewport(0, 0, g(this, CI), g(this, eI)), a.bind(), t.uniform1f(a.uniforms.aspectRatio, g(this, K) / g(this, R)), t.uniform2f(a.uniforms.point, I * g(this, k) / g(this, K), 1 - i * g(this, k) / g(this, R)), t.uniform1f(a.uniforms.radius, u.splatRadius), t.uniform1i(a.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, B).read.tex), t.uniform3f(a.uniforms.color, e * u.splatForce * o, -s * u.splatForce * o, 0), c(g(this, B).write.fbo), g(this, B).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, H).read.tex), t.uniform3f(a.uniforms.color, o, o, o), c(g(this, H).write.fbo), g(this, H).swap();
1225
+ splat(g, C, i, s, l = 1) {
1226
+ !I(this, kg) || I(this, H) === 0 || (I(this, D) ? h(this, mI, QI).call(this, g, C, i, s, l) : h(this, GI, OI).call(this, g, C, i, s, l));
585
1227
  }
586
- updateQuality(I) {
587
- I.dpr !== void 0 && l(this, nI, Math.max(0.1, Math.min(1, I.dpr))), I.sim !== void 0 && l(this, P, Math.max(0.1, Math.min(1, I.sim)));
1228
+ updateQuality(g) {
1229
+ g.dpr !== void 0 && o(this, Qg, Math.max(0.1, Math.min(1, g.dpr))), g.sim !== void 0 && o(this, Ag, Math.max(0.1, Math.min(1, g.sim)));
588
1230
  }
589
- resize(I, i, e) {
590
- if (e !== void 0 ? l(this, k, e) : typeof window < "u" && window.devicePixelRatio && l(this, k, window.devicePixelRatio), I !== void 0 && I > 0) {
591
- if (i === void 0 || i <= 0)
1231
+ resize(g, C, i) {
1232
+ if (i !== void 0 ? o(this, T, i) : typeof window < "u" && window.devicePixelRatio && o(this, T, window.devicePixelRatio), g !== void 0 && g > 0) {
1233
+ if (C === void 0 || C <= 0)
592
1234
  return;
593
- l(this, K, g(this, lI).width = I), l(this, R, g(this, lI).height = i), l(this, CI, Math.max(1, Math.round(I * g(this, P)))), l(this, eI, Math.max(1, Math.round(i * g(this, P)))), b(this, LI, YI).call(this);
1235
+ o(this, H, I(this, hg).width = g), o(this, v, I(this, hg).height = C), o(this, E, Math.max(1, Math.round(g * I(this, Ag)))), o(this, j, Math.max(1, Math.round(C * I(this, Ag)))), h(this, eI, KI).call(this);
594
1236
  } else
595
- b(this, aI, GI).call(this);
596
- g(this, Y) && b(this, sI, AI).call(this), b(this, dI, hI).call(this);
1237
+ h(this, fg, _g).call(this);
1238
+ I(this, k) && h(this, rg, Dg).call(this), h(this, xg, qg).call(this);
597
1239
  }
598
- updateConfig(I) {
599
- Object.assign(g(this, tI), I);
1240
+ updateConfig(g) {
1241
+ Object.assign(I(this, cg), g);
600
1242
  }
601
1243
  destroy() {
602
- l(this, bI, !0), this.stop();
603
- const I = g(this, X);
604
- b(this, VI, FI).call(this), b(this, wI, DI).call(this), g(this, f) && (g(this, f).close(), l(this, f, null));
605
- for (const e of Object.values(g(this, oI)))
606
- e.dispose();
607
- const i = I.getExtension("WEBGL_lose_context");
608
- i == null || i.loseContext();
1244
+ var g, C, i, s, l, t, a, u, c, Z, S;
1245
+ if (o(this, iI, !0), this.stop(), h(this, sI, VI).call(this), h(this, lI, yI).call(this), I(this, z) && (I(this, z).close(), o(this, z, null)), I(this, D))
1246
+ (g = I(this, yg)) == null || g.destroy(), (C = I(this, Hg)) == null || C.destroy(), (i = I(this, Xg)) == null || i.destroy(), (s = I(this, vg)) == null || s.destroy(), (l = I(this, Rg)) == null || l.destroy(), (t = I(this, tg)) == null || t.destroy(), (a = I(this, og)) == null || a.destroy(), (u = I(this, Ug)) == null || u.destroy(), (c = I(this, Wg)) == null || c.destroy(), (Z = I(this, Yg)) == null || Z.destroy(), (S = I(this, Vg)) == null || S.destroy(), I(this, D).device.destroy();
1247
+ else {
1248
+ const A = I(this, O);
1249
+ for (const m of Object.values(I(this, Kg)))
1250
+ m.dispose();
1251
+ const B = A.getExtension("WEBGL_lose_context");
1252
+ B == null || B.loseContext();
1253
+ }
609
1254
  }
610
1255
  // ---------------------------------------------------------------------------
611
1256
  // Loop control
612
1257
  // ---------------------------------------------------------------------------
613
1258
  start() {
614
- if (g(this, Q) !== null)
1259
+ if (I(this, eg) !== null)
615
1260
  return;
616
- const I = () => {
617
- b(this, RI, jI).call(this), l(this, Q, xI(I));
1261
+ const g = () => {
1262
+ h(this, BI, zI).call(this), o(this, eg, kI(g));
618
1263
  };
619
- l(this, Q, xI(I));
1264
+ o(this, eg, kI(g));
620
1265
  }
621
1266
  stop() {
622
- g(this, Q) !== null && (ug(g(this, Q)), l(this, Q, null));
1267
+ I(this, eg) !== null && (WC(I(this, eg)), o(this, eg, null));
623
1268
  }
624
1269
  get isRunning() {
625
- return g(this, Q) !== null;
1270
+ return I(this, eg) !== null;
626
1271
  }
627
- }
628
- lI = new WeakMap(), X = new WeakMap(), SI = new WeakMap(), oI = new WeakMap(), rI = new WeakMap(), K = new WeakMap(), R = new WeakMap(), CI = new WeakMap(), eI = new WeakMap(), k = new WeakMap(), nI = new WeakMap(), P = new WeakMap(), H = new WeakMap(), B = new WeakMap(), E = new WeakMap(), J = new WeakMap(), N = new WeakMap(), _ = new WeakMap(), v = new WeakMap(), z = new WeakMap(), f = new WeakMap(), uI = new WeakMap(), tI = new WeakMap(), L = new WeakMap(), Y = new WeakMap(), Q = new WeakMap(), cI = new WeakMap(), bI = new WeakMap(), aI = new WeakSet(), GI = function() {
629
- const I = g(this, lI);
630
- "clientWidth" in I && I.clientWidth > 0 ? (l(this, k, (typeof window < "u" && window.devicePixelRatio || 1) * g(this, nI)), l(this, K, I.width = Math.round(I.clientWidth * g(this, k))), l(this, R, I.height = Math.round(I.clientHeight * g(this, k)))) : (l(this, K, I.width), l(this, R, I.height)), !(g(this, K) === 0 || g(this, R) === 0) && (l(this, CI, Math.max(1, Math.round(g(this, K) * g(this, P)))), l(this, eI, Math.max(1, Math.round(g(this, R) * g(this, P)))), b(this, LI, YI).call(this));
631
- }, LI = new WeakSet(), YI = function() {
632
- const I = g(this, X), i = g(this, SI), e = g(this, CI), s = g(this, eI);
633
- b(this, VI, FI).call(this), l(this, H, WI(I, i, e, s)), l(this, B, WI(I, i, e, s)), l(this, J, WI(I, i, e, s)), l(this, E, KI(I, i, e, s)), l(this, N, KI(I, i, e, s));
634
- }, sI = new WeakSet(), AI = function() {
635
- if (!(!g(this, Y) || g(this, K) === 0 || g(this, R) === 0)) {
636
- if (b(this, wI, DI).call(this), g(this, Y).type === "text") {
637
- const { backgroundTex: I, obstacleTex: i, coverageTex: e } = Cg(
638
- g(this, X),
639
- g(this, K),
640
- g(this, R),
641
- g(this, Y).opts,
642
- g(this, f),
643
- g(this, uI)
644
- );
645
- l(this, _, I), l(this, v, i), l(this, z, e);
1272
+ };
1273
+ hg = new WeakMap(), O = new WeakMap(), CI = new WeakMap(), Kg = new WeakMap(), Jg = new WeakMap(), M = new WeakMap(), X = new WeakMap(), $ = new WeakMap(), gg = new WeakMap(), Ig = new WeakMap(), lg = new WeakMap(), J = new WeakMap(), Cg = new WeakMap(), D = new WeakMap(), zg = new WeakMap(), Vg = new WeakMap(), Ng = new WeakMap(), f = new WeakMap(), y = new WeakMap(), mg = new WeakMap(), ig = new WeakMap(), Gg = new WeakMap(), N = new WeakMap(), yg = new WeakMap(), Hg = new WeakMap(), Xg = new WeakMap(), vg = new WeakMap(), Rg = new WeakMap(), tg = new WeakMap(), og = new WeakMap(), Ug = new WeakMap(), Wg = new WeakMap(), Yg = new WeakMap(), H = new WeakMap(), v = new WeakMap(), E = new WeakMap(), j = new WeakMap(), T = new WeakMap(), Qg = new WeakMap(), Ag = new WeakMap(), z = new WeakMap(), pg = new WeakMap(), cg = new WeakMap(), w = new WeakMap(), k = new WeakMap(), eg = new WeakMap(), kg = new WeakMap(), iI = new WeakMap(), Mg = new WeakMap(), uI = new WeakSet(), JI = function(g) {
1274
+ const { device: C, format: i } = g;
1275
+ o(this, zg, HC(C, i, I(this, Mg))), o(this, Vg, VC(C)), o(this, Ng, XC(C)), o(this, yg, q(C, 16)), o(this, Hg, q(C, 16)), o(this, Xg, q(C, 16)), o(this, vg, q(C, 16)), o(this, Rg, q(C, 16)), o(this, tg, q(C, 48)), o(this, og, q(C, 48)), o(this, Ug, q(C, 16)), o(this, Wg, q(C, 16)), o(this, Yg, q(C, 64));
1276
+ }, fg = new WeakSet(), _g = function() {
1277
+ const g = I(this, hg);
1278
+ "clientWidth" in g && g.clientWidth > 0 ? (o(this, T, (typeof window < "u" && window.devicePixelRatio || 1) * I(this, Qg)), o(this, H, g.width = Math.round(g.clientWidth * I(this, T))), o(this, v, g.height = Math.round(g.clientHeight * I(this, T)))) : (o(this, H, g.width), o(this, v, g.height)), !(I(this, H) === 0 || I(this, v) === 0) && (o(this, E, Math.max(1, Math.round(I(this, H) * I(this, Ag)))), o(this, j, Math.max(1, Math.round(I(this, v) * I(this, Ag)))), h(this, eI, KI).call(this));
1279
+ }, eI = new WeakSet(), KI = function() {
1280
+ if (h(this, sI, VI).call(this), I(this, D)) {
1281
+ const { device: g } = I(this, D), C = "rgba16float", i = I(this, E), s = I(this, j);
1282
+ o(this, f, hI(g, C, i, s)), o(this, y, hI(g, C, i, s)), o(this, ig, hI(g, C, i, s)), o(this, mg, aI(g, C, i, s)), o(this, Gg, aI(g, C, i, s));
1283
+ } else {
1284
+ const g = I(this, O), C = I(this, CI), i = I(this, E), s = I(this, j);
1285
+ o(this, M, bI(g, C, i, s)), o(this, X, bI(g, C, i, s)), o(this, gg, bI(g, C, i, s)), o(this, $, SI(g, C, i, s)), o(this, Ig, SI(g, C, i, s));
1286
+ }
1287
+ }, rg = new WeakSet(), Dg = function() {
1288
+ if (!(!I(this, k) || I(this, H) === 0 || I(this, v) === 0)) {
1289
+ if (h(this, lI, yI).call(this), I(this, D)) {
1290
+ const { device: g } = I(this, D);
1291
+ I(this, k).type === "text" ? o(this, N, eC(
1292
+ g,
1293
+ I(this, H),
1294
+ I(this, v),
1295
+ I(this, k).opts,
1296
+ I(this, z),
1297
+ I(this, pg)
1298
+ )) : o(this, N, sC(
1299
+ g,
1300
+ I(this, k).bitmap,
1301
+ I(this, H),
1302
+ I(this, v),
1303
+ I(this, k).effect,
1304
+ I(this, k).size,
1305
+ I(this, z),
1306
+ I(this, pg)
1307
+ ));
646
1308
  } else {
647
- const { backgroundTex: I, obstacleTex: i, coverageTex: e } = eg(
648
- g(this, X),
649
- g(this, Y).bitmap,
650
- g(this, K),
651
- g(this, R),
652
- g(this, Y).effect,
653
- g(this, Y).size,
654
- g(this, f),
655
- g(this, uI)
656
- );
657
- l(this, _, I), l(this, v, i), l(this, z, e);
1309
+ const g = I(this, O);
1310
+ if (I(this, k).type === "text") {
1311
+ const { backgroundTex: C, obstacleTex: i, coverageTex: s } = CC(
1312
+ g,
1313
+ I(this, H),
1314
+ I(this, v),
1315
+ I(this, k).opts,
1316
+ I(this, z),
1317
+ I(this, pg)
1318
+ );
1319
+ o(this, lg, C), o(this, J, i), o(this, Cg, s);
1320
+ } else {
1321
+ const { backgroundTex: C, obstacleTex: i, coverageTex: s } = iC(
1322
+ g,
1323
+ I(this, k).bitmap,
1324
+ I(this, H),
1325
+ I(this, v),
1326
+ I(this, k).effect,
1327
+ I(this, k).size,
1328
+ I(this, z),
1329
+ I(this, pg)
1330
+ );
1331
+ o(this, lg, C), o(this, J, i), o(this, Cg, s);
1332
+ }
658
1333
  }
659
- l(this, cI, !0);
1334
+ o(this, kg, !0);
1335
+ }
1336
+ }, xg = new WeakSet(), qg = function() {
1337
+ I(this, kg) && !this.isRunning && this.start();
1338
+ }, sI = new WeakSet(), VI = function() {
1339
+ var g, C, i, s, l, t, a, u;
1340
+ if (I(this, D))
1341
+ (g = I(this, f)) == null || g.dispose(), (C = I(this, y)) == null || C.dispose(), (i = I(this, ig)) == null || i.dispose(), (s = I(this, mg)) == null || s.tex.destroy(), (l = I(this, Gg)) == null || l.tex.destroy(), o(this, f, o(this, y, o(this, ig, null))), o(this, mg, o(this, Gg, null));
1342
+ else {
1343
+ const c = I(this, O);
1344
+ (t = I(this, M)) == null || t.dispose(), (a = I(this, X)) == null || a.dispose(), (u = I(this, gg)) == null || u.dispose(), I(this, $) && (c.deleteTexture(I(this, $).tex), c.deleteFramebuffer(I(this, $).fbo)), I(this, Ig) && (c.deleteTexture(I(this, Ig).tex), c.deleteFramebuffer(I(this, Ig).fbo)), o(this, M, o(this, X, o(this, gg, o(this, $, o(this, Ig, null)))));
660
1345
  }
661
- }, dI = new WeakSet(), hI = function() {
662
- g(this, cI) && !this.isRunning && this.start();
663
- }, VI = new WeakSet(), FI = function() {
664
- var I, i, e;
665
- (I = g(this, H)) == null || I.dispose(), (i = g(this, B)) == null || i.dispose(), (e = g(this, J)) == null || e.dispose(), g(this, E) && (g(this, X).deleteTexture(g(this, E).tex), g(this, X).deleteFramebuffer(g(this, E).fbo)), g(this, N) && (g(this, X).deleteTexture(g(this, N).tex), g(this, X).deleteFramebuffer(g(this, N).fbo)), l(this, H, l(this, B, l(this, J, l(this, E, l(this, N, null)))));
666
- }, wI = new WeakSet(), DI = function() {
667
- g(this, _) && g(this, X).deleteTexture(g(this, _)), g(this, v) && g(this, X).deleteTexture(g(this, v)), g(this, z) && g(this, z) !== g(this, v) && g(this, X).deleteTexture(g(this, z)), l(this, _, l(this, v, l(this, z, null)));
668
- }, RI = new WeakSet(), jI = function() {
669
- if (!g(this, cI) || g(this, K) === 0 || !g(this, H) || !g(this, B))
1346
+ }, lI = new WeakSet(), yI = function() {
1347
+ if (I(this, D))
1348
+ I(this, N) && (I(this, N).backgroundTex.destroy(), I(this, N).obstacleTex.destroy(), I(this, N).sharedCoverage || I(this, N).coverageTex.destroy(), o(this, N, null));
1349
+ else {
1350
+ const g = I(this, O);
1351
+ I(this, lg) && g.deleteTexture(I(this, lg)), I(this, J) && g.deleteTexture(I(this, J)), I(this, Cg) && I(this, Cg) !== I(this, J) && g.deleteTexture(I(this, Cg)), o(this, lg, o(this, J, o(this, Cg, null)));
1352
+ }
1353
+ }, BI = new WeakSet(), zI = function() {
1354
+ !I(this, kg) || I(this, H) === 0 || (I(this, D) ? h(this, nI, NI).call(this) : h(this, pI, EI).call(this));
1355
+ }, nI = new WeakSet(), NI = function() {
1356
+ const g = I(this, D), C = g.device, i = I(this, zg), s = I(this, Vg), l = I(this, Ng), t = I(this, cg), a = I(this, N);
1357
+ if (!I(this, f) || !I(this, y))
670
1358
  return;
671
- const I = g(this, X), i = g(this, tI), { advection: e, divergence: s, pressure: o, gradientSubtract: t, splat: u, curl: a, vorticity: c, display: n } = g(this, oI);
672
- g(this, L).x += (g(this, L).targetX - g(this, L).x) * 0.15, g(this, L).y += (g(this, L).targetY - g(this, L).y) * 0.15;
673
- const G = g(this, CI), d = g(this, eI), h = g(this, rI);
674
- I.viewport(0, 0, G, d), e.bind(), I.uniform2f(e.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(e.uniforms.dt, MI), I.uniform1i(e.uniforms.uObstacle, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.uniform1f(e.uniforms.dissipation, i.velocityDissipation), I.uniform1i(e.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(e.uniforms.uSource, 1), h(g(this, B).write.fbo), g(this, B).swap(), I.uniform1f(e.uniforms.dissipation, i.densityDissipation), I.uniform1i(e.uniforms.uSource, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), h(g(this, H).write.fbo), g(this, H).swap(), a.bind(), I.uniform2f(a.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(a.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), h(g(this, N).fbo), c.bind(), I.uniform2f(c.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(c.uniforms.curl, i.curl), I.uniform1f(c.uniforms.dt, MI), I.uniform1i(c.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(c.uniforms.uCurl, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, N).tex), h(g(this, B).write.fbo), g(this, B).swap(), g(this, L).moved && (u.bind(), I.uniform1f(u.uniforms.aspectRatio, g(this, K) / g(this, R)), I.uniform2f(u.uniforms.point, g(this, L).x * g(this, k) / g(this, K), 1 - g(this, L).y * g(this, k) / g(this, R)), I.uniform1f(u.uniforms.radius, i.splatRadius), I.uniform1i(u.uniforms.uTarget, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform3f(u.uniforms.color, g(this, L).dx * i.splatForce, -g(this, L).dy * i.splatForce, 0), h(g(this, B).write.fbo), g(this, B).swap(), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.uniform3f(u.uniforms.color, 1, 1, 1), h(g(this, H).write.fbo), g(this, H).swap(), g(this, L).moved = !1), s.bind(), I.uniform2f(s.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(s.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(s.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, E).fbo), o.bind(), I.uniform2f(o.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(o.uniforms.uDivergence, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, E).tex), I.uniform1i(o.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v));
675
- for (let W = 0; W < i.pressureIterations; W++)
676
- I.uniform1i(o.uniforms.uPressure, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), h(g(this, J).write.fbo), g(this, J).swap();
677
- t.bind(), I.uniform2f(t.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(t.uniforms.uPressure, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), I.uniform1i(t.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(t.uniforms.uObstacle, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, B).write.fbo), g(this, B).swap(), I.viewport(0, 0, g(this, K), g(this, R)), I.bindFramebuffer(I.FRAMEBUFFER, null), I.clear(I.COLOR_BUFFER_BIT), n.bind(), I.uniform2f(n.uniforms.texelSize, 1 / g(this, K), 1 / g(this, R)), I.uniform3fv(n.uniforms.uWaterColor, i.waterColor), I.uniform3fv(n.uniforms.uGlowColor, i.glowColor), I.uniform1f(n.uniforms.uRefraction, i.refraction), I.uniform1f(n.uniforms.uSpecularExp, i.specularExp), I.uniform1f(n.uniforms.uShine, i.shine), I.uniform1f(n.uniforms.uWarpStrength, i.warpStrength ?? 0.015), I.uniform1i(n.uniforms.uAlgorithm, Zg[i.algorithm] ?? 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, _)), I.activeTexture(I.TEXTURE3), I.bindTexture(I.TEXTURE_2D, g(this, z)), I.activeTexture(I.TEXTURE4), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(n.uniforms.uTexture, 0), I.uniform1i(n.uniforms.uObstacle, 1), I.uniform1i(n.uniforms.uBackground, 2), I.uniform1i(n.uniforms.uCoverage, 3), I.uniform1i(n.uniforms.uVelocity, 4), h(null);
1359
+ I(this, w).x += (I(this, w).targetX - I(this, w).x) * 0.15, I(this, w).y += (I(this, w).targetY - I(this, w).y) * 0.15;
1360
+ const u = I(this, E), c = I(this, j), Z = I(this, H), S = I(this, v), A = 1 / u, B = 1 / c;
1361
+ YI(C, I(this, yg), A, B, Pg, t.velocityDissipation), cI(C, I(this, Xg), A, B), cI(C, I(this, vg), A, B), cI(C, I(this, Rg), A, B), cI(C, I(this, Ug), A, B), vC(C, I(this, Wg), A, B, t.curl, Pg), RC(
1362
+ C,
1363
+ I(this, Yg),
1364
+ 1 / Z,
1365
+ 1 / S,
1366
+ t.refraction,
1367
+ t.specularExp,
1368
+ AI(t.waterColor),
1369
+ AI(t.glowColor),
1370
+ t.shine,
1371
+ t.warpStrength ?? 0.015,
1372
+ MI[t.algorithm] ?? 0,
1373
+ I(this, Mg)
1374
+ );
1375
+ const m = C.createCommandEncoder(), r = (G, K) => C.createBindGroup({ layout: G.getBindGroupLayout(0), entries: K }), L = { binding: 1, resource: l };
1376
+ {
1377
+ const G = r(i.advection, [
1378
+ { binding: 0, resource: { buffer: I(this, yg) } },
1379
+ L,
1380
+ { binding: 2, resource: I(this, y).read.view },
1381
+ { binding: 3, resource: I(this, y).read.view },
1382
+ { binding: 4, resource: a.obstacleView }
1383
+ ]);
1384
+ Q(m, i.advection, G, s, I(this, y).write.view);
1385
+ }
1386
+ I(this, y).swap();
1387
+ {
1388
+ YI(C, I(this, Hg), A, B, Pg, t.densityDissipation);
1389
+ const G = r(i.advection, [
1390
+ { binding: 0, resource: { buffer: I(this, Hg) } },
1391
+ L,
1392
+ { binding: 2, resource: I(this, y).read.view },
1393
+ { binding: 3, resource: I(this, f).read.view },
1394
+ { binding: 4, resource: a.obstacleView }
1395
+ ]);
1396
+ Q(m, i.advection, G, s, I(this, f).write.view);
1397
+ }
1398
+ I(this, f).swap();
1399
+ {
1400
+ const G = r(i.curl, [
1401
+ { binding: 0, resource: { buffer: I(this, Ug) } },
1402
+ L,
1403
+ { binding: 2, resource: I(this, y).read.view }
1404
+ ]);
1405
+ Q(m, i.curl, G, s, I(this, Gg).view);
1406
+ }
1407
+ {
1408
+ const G = r(i.vorticity, [
1409
+ { binding: 0, resource: { buffer: I(this, Wg) } },
1410
+ L,
1411
+ { binding: 2, resource: I(this, y).read.view },
1412
+ { binding: 3, resource: I(this, Gg).view }
1413
+ ]);
1414
+ Q(m, i.vorticity, G, s, I(this, y).write.view);
1415
+ }
1416
+ if (I(this, y).swap(), I(this, w).moved) {
1417
+ const G = I(this, w).x * I(this, T) / Z, K = I(this, w).y * I(this, T) / S;
1418
+ dI(
1419
+ C,
1420
+ I(this, tg),
1421
+ A,
1422
+ B,
1423
+ Z / S,
1424
+ t.splatRadius,
1425
+ I(this, w).dx * t.splatForce,
1426
+ I(this, w).dy * t.splatForce,
1427
+ 0,
1428
+ G,
1429
+ K
1430
+ );
1431
+ {
1432
+ const b = r(i.splat, [
1433
+ { binding: 0, resource: { buffer: I(this, tg) } },
1434
+ L,
1435
+ { binding: 2, resource: I(this, y).read.view }
1436
+ ]);
1437
+ Q(m, i.splat, b, s, I(this, y).write.view);
1438
+ }
1439
+ I(this, y).swap(), dI(
1440
+ C,
1441
+ I(this, og),
1442
+ A,
1443
+ B,
1444
+ Z / S,
1445
+ t.splatRadius,
1446
+ 1,
1447
+ 1,
1448
+ 1,
1449
+ G,
1450
+ K
1451
+ );
1452
+ {
1453
+ const b = r(i.splat, [
1454
+ { binding: 0, resource: { buffer: I(this, og) } },
1455
+ L,
1456
+ { binding: 2, resource: I(this, f).read.view }
1457
+ ]);
1458
+ Q(m, i.splat, b, s, I(this, f).write.view);
1459
+ }
1460
+ I(this, f).swap(), I(this, w).moved = !1;
1461
+ }
1462
+ {
1463
+ const G = r(i.divergence, [
1464
+ { binding: 0, resource: { buffer: I(this, Xg) } },
1465
+ L,
1466
+ { binding: 2, resource: I(this, y).read.view },
1467
+ { binding: 3, resource: a.obstacleView }
1468
+ ]);
1469
+ Q(m, i.divergence, G, s, I(this, mg).view);
1470
+ }
1471
+ for (let G = 0; G < t.pressureIterations; G++) {
1472
+ const K = r(i.pressure, [
1473
+ { binding: 0, resource: { buffer: I(this, vg) } },
1474
+ L,
1475
+ { binding: 2, resource: I(this, ig).read.view },
1476
+ { binding: 3, resource: I(this, mg).view },
1477
+ { binding: 4, resource: a.obstacleView }
1478
+ ]);
1479
+ Q(m, i.pressure, K, s, I(this, ig).write.view), I(this, ig).swap();
1480
+ }
1481
+ {
1482
+ const G = r(i.gradientSubtract, [
1483
+ { binding: 0, resource: { buffer: I(this, Rg) } },
1484
+ L,
1485
+ { binding: 2, resource: I(this, ig).read.view },
1486
+ { binding: 3, resource: I(this, y).read.view },
1487
+ { binding: 4, resource: a.obstacleView }
1488
+ ]);
1489
+ Q(m, i.gradientSubtract, G, s, I(this, y).write.view);
1490
+ }
1491
+ I(this, y).swap();
1492
+ {
1493
+ const G = g.context.getCurrentTexture().createView(), K = r(i.display, [
1494
+ { binding: 0, resource: { buffer: I(this, Yg) } },
1495
+ L,
1496
+ { binding: 2, resource: I(this, f).read.view },
1497
+ { binding: 3, resource: a.obstacleView },
1498
+ { binding: 4, resource: a.backgroundView },
1499
+ { binding: 5, resource: a.coverageView },
1500
+ { binding: 6, resource: I(this, y).read.view }
1501
+ ]);
1502
+ UC(m, i.display, K, s, G);
1503
+ }
1504
+ C.queue.submit([m.finish()]);
1505
+ }, mI = new WeakSet(), QI = function(g, C, i, s, l) {
1506
+ const a = I(this, D).device, u = I(this, zg).splat, c = I(this, Vg), Z = I(this, Ng), S = I(this, cg), A = I(this, E), B = I(this, j), m = 1 / A, r = 1 / B, L = a.createCommandEncoder(), G = { binding: 1, resource: Z }, K = (n) => a.createBindGroup({ layout: u.getBindGroupLayout(0), entries: n }), b = g * I(this, T) / I(this, H), Y = C * I(this, T) / I(this, v);
1507
+ dI(
1508
+ a,
1509
+ I(this, tg),
1510
+ m,
1511
+ r,
1512
+ I(this, H) / I(this, v),
1513
+ S.splatRadius,
1514
+ i * S.splatForce * l,
1515
+ s * S.splatForce * l,
1516
+ 0,
1517
+ b,
1518
+ Y
1519
+ );
1520
+ {
1521
+ const n = K([
1522
+ { binding: 0, resource: { buffer: I(this, tg) } },
1523
+ G,
1524
+ { binding: 2, resource: I(this, y).read.view }
1525
+ ]);
1526
+ Q(L, u, n, c, I(this, y).write.view);
1527
+ }
1528
+ I(this, y).swap(), dI(
1529
+ a,
1530
+ I(this, og),
1531
+ m,
1532
+ r,
1533
+ I(this, H) / I(this, v),
1534
+ S.splatRadius,
1535
+ l,
1536
+ l,
1537
+ l,
1538
+ b,
1539
+ Y
1540
+ );
1541
+ {
1542
+ const n = K([
1543
+ { binding: 0, resource: { buffer: I(this, og) } },
1544
+ G,
1545
+ { binding: 2, resource: I(this, f).read.view }
1546
+ ]);
1547
+ Q(L, u, n, c, I(this, f).write.view);
1548
+ }
1549
+ I(this, f).swap(), a.queue.submit([L.finish()]);
1550
+ }, GI = new WeakSet(), OI = function(g, C, i, s, l) {
1551
+ const t = I(this, O), a = I(this, cg), u = I(this, Kg).splat, c = I(this, Jg);
1552
+ t.viewport(0, 0, I(this, E), I(this, j)), u.bind(), t.uniform1f(u.uniforms.aspectRatio, I(this, H) / I(this, v)), t.uniform2f(u.uniforms.point, g * I(this, T) / I(this, H), 1 - C * I(this, T) / I(this, v)), t.uniform1f(u.uniforms.radius, a.splatRadius), t.uniform1i(u.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, I(this, X).read.tex), t.uniform3f(u.uniforms.color, i * a.splatForce * l, -s * a.splatForce * l, 0), c(I(this, X).write.fbo), I(this, X).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, I(this, M).read.tex), t.uniform3f(u.uniforms.color, l, l, l), c(I(this, M).write.fbo), I(this, M).swap();
1553
+ }, pI = new WeakSet(), EI = function() {
1554
+ if (!I(this, M) || !I(this, X))
1555
+ return;
1556
+ const g = I(this, O), C = I(this, cg), { advection: i, divergence: s, pressure: l, gradientSubtract: t, splat: a, curl: u, vorticity: c, display: Z } = I(this, Kg);
1557
+ I(this, w).x += (I(this, w).targetX - I(this, w).x) * 0.15, I(this, w).y += (I(this, w).targetY - I(this, w).y) * 0.15;
1558
+ const S = I(this, E), A = I(this, j), B = I(this, Jg);
1559
+ g.viewport(0, 0, S, A), i.bind(), g.uniform2f(i.uniforms.texelSize, 1 / S, 1 / A), g.uniform1f(i.uniforms.dt, Pg), g.uniform1i(i.uniforms.uObstacle, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, J)), g.uniform1f(i.uniforms.dissipation, C.velocityDissipation), g.uniform1i(i.uniforms.uVelocity, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), g.uniform1i(i.uniforms.uSource, 1), B(I(this, X).write.fbo), I(this, X).swap(), g.uniform1f(i.uniforms.dissipation, C.densityDissipation), g.uniform1i(i.uniforms.uSource, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, M).read.tex), B(I(this, M).write.fbo), I(this, M).swap(), u.bind(), g.uniform2f(u.uniforms.texelSize, 1 / S, 1 / A), g.uniform1i(u.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), B(I(this, Ig).fbo), c.bind(), g.uniform2f(c.uniforms.texelSize, 1 / S, 1 / A), g.uniform1f(c.uniforms.curl, C.curl), g.uniform1f(c.uniforms.dt, Pg), g.uniform1i(c.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), g.uniform1i(c.uniforms.uCurl, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, Ig).tex), B(I(this, X).write.fbo), I(this, X).swap(), I(this, w).moved && (a.bind(), g.uniform1f(a.uniforms.aspectRatio, I(this, H) / I(this, v)), g.uniform2f(a.uniforms.point, I(this, w).x * I(this, T) / I(this, H), 1 - I(this, w).y * I(this, T) / I(this, v)), g.uniform1f(a.uniforms.radius, C.splatRadius), g.uniform1i(a.uniforms.uTarget, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), g.uniform3f(a.uniforms.color, I(this, w).dx * C.splatForce, -I(this, w).dy * C.splatForce, 0), B(I(this, X).write.fbo), I(this, X).swap(), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, M).read.tex), g.uniform3f(a.uniforms.color, 1, 1, 1), B(I(this, M).write.fbo), I(this, M).swap(), I(this, w).moved = !1), s.bind(), g.uniform2f(s.uniforms.texelSize, 1 / S, 1 / A), g.uniform1i(s.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), g.uniform1i(s.uniforms.uObstacle, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, J)), B(I(this, $).fbo), l.bind(), g.uniform2f(l.uniforms.texelSize, 1 / S, 1 / A), g.uniform1i(l.uniforms.uDivergence, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, $).tex), g.uniform1i(l.uniforms.uObstacle, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, J));
1560
+ for (let m = 0; m < C.pressureIterations; m++)
1561
+ g.uniform1i(l.uniforms.uPressure, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, gg).read.tex), B(I(this, gg).write.fbo), I(this, gg).swap();
1562
+ t.bind(), g.uniform2f(t.uniforms.texelSize, 1 / S, 1 / A), g.uniform1i(t.uniforms.uPressure, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, gg).read.tex), g.uniform1i(t.uniforms.uVelocity, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), g.uniform1i(t.uniforms.uObstacle, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, J)), B(I(this, X).write.fbo), I(this, X).swap(), g.viewport(0, 0, I(this, H), I(this, v)), g.bindFramebuffer(g.FRAMEBUFFER, null), g.clear(g.COLOR_BUFFER_BIT), Z.bind(), g.uniform2f(Z.uniforms.texelSize, 1 / I(this, H), 1 / I(this, v)), g.uniform3fv(Z.uniforms.uWaterColor, AI(C.waterColor)), g.uniform3fv(Z.uniforms.uGlowColor, AI(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, MI[C.algorithm] ?? 0), g.uniform1i(Z.uniforms.uEnableAlpha, I(this, Mg) ? 1 : 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, M).read.tex), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, J)), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, lg)), g.activeTexture(g.TEXTURE3), g.bindTexture(g.TEXTURE_2D, I(this, Cg)), g.activeTexture(g.TEXTURE4), g.bindTexture(g.TEXTURE_2D, I(this, X).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), B(null);
678
1563
  };
679
- const PI = "dmFyIFVlID0gT2JqZWN0LmRlZmluZVByb3BlcnR5Owp2YXIgX2UgPSAoaSwgZSwgcikgPT4gZSBpbiBpID8gVWUoaSwgZSwgeyBlbnVtZXJhYmxlOiAhMCwgY29uZmlndXJhYmxlOiAhMCwgd3JpdGFibGU6ICEwLCB2YWx1ZTogciB9KSA6IGlbZV0gPSByOwp2YXIgbmUgPSAoaSwgZSwgcikgPT4gKF9lKGksIHR5cGVvZiBlICE9ICJzeW1ib2wiID8gZSArICIiIDogZSwgciksIHIpLCB4ZSA9IChpLCBlLCByKSA9PiB7CiAgaWYgKCFlLmhhcyhpKSkKICAgIHRocm93IFR5cGVFcnJvcigiQ2Fubm90ICIgKyByKTsKfTsKdmFyIHQgPSAoaSwgZSwgcikgPT4gKHhlKGksIGUsICJyZWFkIGZyb20gcHJpdmF0ZSBmaWVsZCIpLCByID8gci5jYWxsKGkpIDogZS5nZXQoaSkpLCBsID0gKGksIGUsIHIpID0+IHsKICBpZiAoZS5oYXMoaSkpCiAgICB0aHJvdyBUeXBlRXJyb3IoIkNhbm5vdCBhZGQgdGhlIHNhbWUgcHJpdmF0ZSBtZW1iZXIgbW9yZSB0aGFuIG9uY2UiKTsKICBlIGluc3RhbmNlb2YgV2Vha1NldCA/IGUuYWRkKGkpIDogZS5zZXQoaSwgcik7Cn0sIGEgPSAoaSwgZSwgciwgbykgPT4gKHhlKGksIGUsICJ3cml0ZSB0byBwcml2YXRlIGZpZWxkIiksIG8gPyBvLmNhbGwoaSwgcikgOiBlLnNldChpLCByKSwgcik7CnZhciBUID0gKGksIGUsIHIpID0+ICh4ZShpLCBlLCAiYWNjZXNzIHByaXZhdGUgbWV0aG9kIiksIHIpOwpjb25zdCB5ZSA9IHsKICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTkyLAogIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgcHJlc3N1cmVJdGVyYXRpb25zOiAxLAogIGN1cmw6IDFlLTQsCiAgc3BsYXRSYWRpdXM6IDRlLTMsCiAgc3BsYXRGb3JjZTogMC45MSwKICByZWZyYWN0aW9uOiAwLjI1LAogIHNwZWN1bGFyRXhwOiAxLjAxLAogIHNoaW5lOiAwLjAxLAogIHdhdGVyQ29sb3I6IFswLCAwLCAwXSwKICBnbG93Q29sb3I6IFswLjcsIDAuODUsIDFdLAogIGFsZ29yaXRobTogInN0YW5kYXJkIiwKICB3YXJwU3RyZW5ndGg6IDAuMDE1Cn07Cih7CiAgLi4ueWUKfSk7CmNvbnN0IHdlID0gewogIGNhbG06IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45OTksCiAgICB2ZWxvY2l0eURpc3NpcGF0aW9uOiAwLjk4LAogICAgY3VybDogMWUtNCwKICAgIHNwbGF0UmFkaXVzOiAzZS0zLAogICAgc3BsYXRGb3JjZTogMC41LAogICAgcmVmcmFjdGlvbjogMC4xNSwKICAgIHNoaW5lOiA1ZS0zLAogICAgZ2xvd0NvbG9yOiBbMC42LCAwLjg1LCAxXSwKICAgIHdhdGVyQ29sb3I6IFswLCAwLjAyLCAwLjA1XQogIH0sCiAgc2FuZDogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NywKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTgsCiAgICBjdXJsOiAxLAogICAgc3BsYXRSYWRpdXM6IDAuMDEsCiAgICBzcGxhdEZvcmNlOiAwLjksCiAgICByZWZyYWN0aW9uOiAwLjgsCiAgICBzcGVjdWxhckV4cDogMC4xLAogICAgc2hpbmU6IDAuMDUsCiAgICBnbG93Q29sb3I6IFswLjAyNywgMC4wMjcsIDAuMDI3XSwKICAgIHdhdGVyQ29sb3I6IFswLjQ1MSwgMC4zMjksIDAuMTI1XQogIH0sCiAgd2F2ZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NCwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTIsCiAgICBjdXJsOiAwLjIsCiAgICBzcGxhdFJhZGl1czogNWUtMywKICAgIHNwbGF0Rm9yY2U6IDEuMiwKICAgIHJlZnJhY3Rpb246IDAuMzUsCiAgICBzaGluZTogMC4wMywKICAgIGdsb3dDb2xvcjogWzAuNSwgMC44LCAxXSwKICAgIHdhdGVyQ29sb3I6IFswLCAwLjAxLCAwLjAzXQogIH0sCiAgbmVvbjogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk4NSwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgICBjdXJsOiAwLjA1LAogICAgc3BsYXRSYWRpdXM6IDhlLTMsCiAgICBzcGxhdEZvcmNlOiAxLjUsCiAgICByZWZyYWN0aW9uOiAwLjI1LAogICAgc3BlY3VsYXJFeHA6IDAuNSwKICAgIHNoaW5lOiAwLjE0LAogICAgZ2xvd0NvbG9yOiBbMSwgMC4yLCAwLjhdLAogICAgd2F0ZXJDb2xvcjogWzAuMDUsIDAsIDAuMDhdCiAgfSwKICBzbW9rZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NiwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTcsCiAgICBjdXJsOiAwLjA0LAogICAgc3BsYXRSYWRpdXM6IDllLTMsCiAgICBzcGxhdEZvcmNlOiAwLjgsCiAgICByZWZyYWN0aW9uOiAwLjA4LAogICAgc2hpbmU6IDAsCiAgICBnbG93Q29sb3I6IFswLjUsIDAuNSwgMC41XSwKICAgIHdhdGVyQ29sb3I6IFswLjA2LCAwLjA2LCAwLjA2XQogIH0KfTsKZnVuY3Rpb24gU2UoaSA9IHt9LCBlLCByID0geWUpIHsKICByZXR1cm4geyAuLi5lID8geyAuLi5yLCAuLi53ZVtlXSB9IDogciwgLi4uaSB9Owp9CmNvbnN0IFAgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgYXR0cmlidXRlIHZlYzIgYVBvc2l0aW9uOwogIHZhcnlpbmcgdmVjMiB2VXY7CiAgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gdmVjMiB0ZXhlbFNpemU7CiAgdm9pZCBtYWluICgpIHsKICAgIHZVdiA9IGFQb3NpdGlvbiAqIDAuNSArIDAuNTsKICAgIHZMID0gdlV2IC0gdmVjMih0ZXhlbFNpemUueCwgMC4wKTsKICAgIHZSID0gdlV2ICsgdmVjMih0ZXhlbFNpemUueCwgMC4wKTsKICAgIHZUID0gdlV2ICsgdmVjMigwLjAsIHRleGVsU2l6ZS55KTsKICAgIHZCID0gdlV2IC0gdmVjMigwLjAsIHRleGVsU2l6ZS55KTsKICAgIGdsX1Bvc2l0aW9uID0gdmVjNChhUG9zaXRpb24sIDAuMCwgMS4wKTsKICB9CmAKKSwgQ2UgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVNvdXJjZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdW5pZm9ybSB2ZWMyIHRleGVsU2l6ZTsKICB1bmlmb3JtIGZsb2F0IGR0OwogIHVuaWZvcm0gZmxvYXQgZGlzc2lwYXRpb247CiAgdm9pZCBtYWluICgpIHsKICAgIGlmICh0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VXYpLnIgPiAwLjUpIHsgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjApOyByZXR1cm47IH0KICAgIHZlYzIgY29vcmQgPSB2VXYgLSBkdCAqIHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHkgKiB0ZXhlbFNpemU7CiAgICBnbF9GcmFnQ29sb3IgPSBkaXNzaXBhdGlvbiAqIHRleHR1cmUyRCh1U291cmNlLCBjb29yZCk7CiAgfQpgCiksIEZlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkwpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2TCkueDsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2UikuciA+IDAuNSA/IDAuMCA6IHRleHR1cmUyRCh1VmVsb2NpdHksIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZUKS5yID4gMC41ID8gMC4wIDogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLnk7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkIpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2QikueTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoMC41ICogKFIgLSBMICsgVCAtIEIpLCAwLjAsIDAuMCwgMS4wKTsKICB9CmAKKSwgWGUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVQcmVzc3VyZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1RGl2ZXJnZW5jZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEMgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2VXYpLng7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkwpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkwpLng7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlIpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlQpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkIpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkIpLng7CiAgICBmbG9hdCBkaXYgPSB0ZXh0dXJlMkQodURpdmVyZ2VuY2UsIHZVdikueDsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoKEwgKyBSICsgQiArIFQgLSBkaXYpICogMC4yNSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIEJlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1UHJlc3N1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgaWYgKHRleHR1cmUyRCh1T2JzdGFjbGUsIHZVdikuciA+IDAuNSkgeyBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuMCk7IHJldHVybjsgfQogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZUKS54OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZCKS54OwogICAgdmVjMiB2ZWwgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5IC0gdmVjMihSIC0gTCwgVCAtIEIpOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCh2ZWwsIDAuMCwgMS4wKTsKICB9CmAKKSwgQWUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VGFyZ2V0OwogIHVuaWZvcm0gZmxvYXQgYXNwZWN0UmF0aW87CiAgdW5pZm9ybSB2ZWMzIGNvbG9yOwogIHVuaWZvcm0gdmVjMiBwb2ludDsKICB1bmlmb3JtIGZsb2F0IHJhZGl1czsKICB2b2lkIG1haW4gKCkgewogICAgdmVjMiBwID0gdlV2IC0gcG9pbnQueHk7CiAgICBwLnggKj0gYXNwZWN0UmF0aW87CiAgICB2ZWMzIHNwbGF0ID0gZXhwKC1kb3QocCwgcCkgLyByYWRpdXMpICogY29sb3I7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KHRleHR1cmUyRCh1VGFyZ2V0LCB2VXYpLnh5eiArIHNwbGF0LCAxLjApOwogIH0KYAopLCBMZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkwpLnk7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlIpLnk7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkIpLng7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuNSAqIChSIC0gTCAtIFQgKyBCKSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIE1lID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdUN1cmw7CiAgdW5pZm9ybSBmbG9hdCBjdXJsOwogIHVuaWZvcm0gZmxvYXQgZHQ7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodUN1cmwsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1Q3VybCwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVDdXJsLCB2VCkueDsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodUN1cmwsIHZCKS54OwogICAgZmxvYXQgQyA9IHRleHR1cmUyRCh1Q3VybCwgdlV2KS54OwogICAgdmVjMiBmb3JjZSA9IDAuNSAqIHZlYzIoYWJzKFQpIC0gYWJzKEIpLCBhYnMoUikgLSBhYnMoTCkpOwogICAgZm9yY2UgLz0gbGVuZ3RoKGZvcmNlKSArIDAuMDAwMTsKICAgIGZvcmNlICo9IGN1cmwgKiAzMC4wICogQzsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQodGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSArIGZvcmNlICogZHQsIDAuMCwgMS4wKTsKICB9CmAKKSwgUGUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKCiAgdW5pZm9ybSBzYW1wbGVyMkQgdVRleHR1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVCYWNrZ3JvdW5kOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVDb3ZlcmFnZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CgogIHVuaWZvcm0gdmVjMiAgdGV4ZWxTaXplOwogIHVuaWZvcm0gdmVjMyAgdVdhdGVyQ29sb3I7CiAgdW5pZm9ybSB2ZWMzICB1R2xvd0NvbG9yOwogIHVuaWZvcm0gZmxvYXQgdVJlZnJhY3Rpb247CiAgdW5pZm9ybSBmbG9hdCB1U3BlY3VsYXJFeHA7CiAgdW5pZm9ybSBmbG9hdCB1U2hpbmU7CiAgdW5pZm9ybSBmbG9hdCB1V2FycFN0cmVuZ3RoOwogIHVuaWZvcm0gaW50ICAgdUFsZ29yaXRobTsKCiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IG9icyAgICAgID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgIHZVdikucjsKICAgIC8vIE1hc2sgZGVuc2l0eSBpbnNpZGUgb2JzdGFjbGVzIHNvIHNwbGF0cyBkb24ndCBmbGlja2VyIHRoZSB0ZXh0L2ltYWdlIGNvbnRlbnQuCiAgICBmbG9hdCBkZW5zaXR5ICA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdikuciwgMC4wKSAqICgxLjAgLSBzdGVwKDAuNSwgb2JzKSk7CiAgICBmbG9hdCBjb3ZlcmFnZSA9IHRleHR1cmUyRCh1Q292ZXJhZ2UsICB2VXYpLnI7CgogICAgZmxvYXQgZEwgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgLSB2ZWMyKHRleGVsU2l6ZS54ICogMi4wLCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZFIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKHRleGVsU2l6ZS54ICogMi4wLCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZFQgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkgKiAyLjApKS5yLCAwLjApOwogICAgZmxvYXQgZEIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgLSB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkgKiAyLjApKS5yLCAwLjApOwoKICAgIHZlYzMgIG5vcm1hbCAgID0gbm9ybWFsaXplKHZlYzMoZEwgLSBkUiwgZEIgLSBkVCwgMC4yKSk7CiAgICB2ZWMzICBsaWdodERpciA9IG5vcm1hbGl6ZSh2ZWMzKDAuNSwgMS4wLCAwLjUpKTsKICAgIHZlYzMgIGhhbGZWICAgID0gbm9ybWFsaXplKGxpZ2h0RGlyICsgdmVjMygwLjAsIDAuMCwgMS4wKSk7CiAgICBmbG9hdCBzcGVjICAgICA9IHBvdyhtYXgoZG90KG5vcm1hbCwgaGFsZlYpLCAwLjApLCB1U3BlY3VsYXJFeHApICogdVNoaW5lICogZGVuc2l0eTsKCiAgICAvLyBJbiB0cmFuc3BhcmVudCAobm9uLWNvdmVyYWdlKSBhcmVhcyB0aGUgYmFja2dyb3VuZCB0ZXh0dXJlIGlzIGVtcHR5IGJsYWNrIGNhbnZhcy4KICAgIC8vIFJlcGxhY2UgaXQgd2l0aCB1V2F0ZXJDb2xvciBzbyBmbHVpZCBjb2xvdXIgaXMgbm90IGNvbnRhbWluYXRlZCBieSB0aGF0IGJsYWNrLAogICAgLy8gYWxsb3dpbmcgdGhlIENTUyBiYWNrZ3JvdW5kQ29sb3IgdG8gc2hvdyB0aHJvdWdoIGNvcnJlY3RseSB2aWEgcHJlbXVsdGlwbGllZCBhbHBoYS4KICAgIHZlYzMgYmdSYXcgPSB0ZXh0dXJlMkQodUJhY2tncm91bmQsIHZVdikucmdiOwogICAgdmVjMyBiZyAgICA9IG1peCh1V2F0ZXJDb2xvciwgYmdSYXcsIGNvdmVyYWdlKTsKICAgIHZlYzMgY29sb3IgPSBiZzsKCiAgICBpZiAodUFsZ29yaXRobSA9PSAxKSB7CiAgICAgIC8vIOKUgOKUgCBnbGFzcyDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gU3Ryb25nIFVWIGRpc3RvcnRpb24gb25seS4gSW1hZ2UgYmVuZHMgYnV0IG5vIGNvbG91ciBvdmVybGF5LgogICAgICB2ZWMyIHJlZnJVdiA9IGNsYW1wKHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eSAqIDMuMCwgMC4wLCAxLjApOwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciA9IHJlZnJCZyArIHNwZWMgKiB1R2xvd0NvbG9yICogMi41OwogICAgICBjb2xvciA9IG1peChjb2xvciwgYmcgKiAwLjYsIG9icyAqIDAuMyk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDIpIHsKICAgICAgLy8g4pSA4pSAIGluayDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gRGVuc2Ugb3BhcXVlIHBpZ21lbnQgdGhhdCBzdGFpbnMuIFN1YnRsZSByZWZyYWN0aW9uIHVuZGVybmVhdGguCiAgICAgIGZsb2F0IGlua0QgID0gbWluKGRlbnNpdHkgKiA0LjAsIDEuMCk7CiAgICAgIHZlYzIgcmVmclV2ID0gY2xhbXAodlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5ICogMC40LCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgcmVmckJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJlZnJVdiwgMS4wIC0gb2JzKSkucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yID0gbWl4KHJlZnJCZywgdVdhdGVyQ29sb3IgKyBzcGVjICogdUdsb3dDb2xvciwgaW5rRCk7CiAgICAgIGNvbG9yID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4xNSk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDMpIHsKICAgICAgLy8g4pSA4pSAIGF1cm9yYSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gVmVsb2NpdHkgZmllbGQgd2FycHMgYmFja2dyb3VuZCBVVnMg4oCUIGxpcXVpZCBtZXRhbCAvIGxhdmEtbGFtcCBmZWVsLgogICAgICB2ZWMyICB2ZWwgICAgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5OwogICAgICBmbG9hdCB2ZWxNYWcgPSBjbGFtcChsZW5ndGgodmVsKSAqIDIwLjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMiAgd2FycFV2ID0gY2xhbXAodlV2ICsgdmVsICogdVdhcnBTdHJlbmd0aCwgMC4wLCAxLjApOwogICAgICB2ZWMzICB3YXJwQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgd2FycFV2KS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgID0gbWl4KGJnLCB3YXJwQmcsIHZlbE1hZyAqICgxLjAgLSBvYnMpKTsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiB2ZWxNYWcgKiAxLjU7CiAgICAgIGNvbG9yICs9IHVXYXRlckNvbG9yICogZGVuc2l0eSAqIDAuMzsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKCiAgICB9IGVsc2UgaWYgKHVBbGdvcml0aG0gPT0gNCkgewogICAgICAvLyDilIDilIAgcmlwcGxlIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBFeGFnZ2VyYXRlZCBub3JtYWwgcGVydHVyYmF0aW9uICsgRnJlc25lbCByaW0g4oCUIGNhbG0gd2F0ZXIgc3VyZmFjZS4KICAgICAgdmVjMiAgcmlwcGxlVXYgPSBjbGFtcCh2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHkgKiA2LjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMyAgcmVmckJnICAgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmlwcGxlVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBmbG9hdCBmcmVzbmVsICA9IHBvdyhjbGFtcCgxLjAgLSBkb3Qobm9ybWFsLCB2ZWMzKDAuMCwgMC4wLCAxLjApKSwgMC4wLCAxLjApLCAzLjApICogZGVuc2l0eTsKICAgICAgY29sb3IgID0gcmVmckJnOwogICAgICBjb2xvciArPSBmcmVzbmVsICogdUdsb3dDb2xvciAqIDIuMDsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiBkZW5zaXR5ICogMi4wOwogICAgICBjb2xvciAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwoKICAgIH0gZWxzZSB7CiAgICAgIC8vIOKUgOKUgCBzdGFuZGFyZCAoMCkg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIE9yaWdpbmFsOiBjb2xvdXIgb3ZlcmxheSBibGVuZGVkIG92ZXIgcmVmcmFjdGVkIGJhY2tncm91bmQuCiAgICAgIHZlYzIgcmVmclV2ID0gdlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5OwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciAgPSBtaXgocmVmckJnLCB1V2F0ZXJDb2xvciwgbWluKGRlbnNpdHkgKiAxLjUsIDAuOCkpOwogICAgICBjb2xvciArPSBzcGVjICogdUdsb3dDb2xvcjsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICAgIH0KCiAgICAvLyBQcmVtdWx0aXBsaWVkIGFscGhhIOKAlCB0cmFuc3BhcmVudCB3aGVyZSB0aGVyZSBpcyBuZWl0aGVyIGNvbnRlbnQgbm9yIGZsdWlkLAogICAgLy8gbGV0dGluZyB0aGUgQ1NTIGJhY2tncm91bmRDb2xvciBvbiB0aGUgY29udGFpbmVyIGRpdiBzaG93IHRocm91Z2guCiAgICBmbG9hdCBhbHBoYSA9IGNsYW1wKG1heChkZW5zaXR5ICogMS41LCBjb3ZlcmFnZSksIDAuMCwgMS4wKTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoY29sb3IgKiBhbHBoYSwgYWxwaGEpOwogIH0KYAopOwpmdW5jdGlvbiBrZShpKSB7CiAgY29uc3QgZSA9IHsgYWxwaGE6ICEwLCBkZXB0aDogITEsIHN0ZW5jaWw6ICExLCBhbnRpYWxpYXM6ICEwLCBwcmVzZXJ2ZURyYXdpbmdCdWZmZXI6ICExIH07CiAgbGV0IHIgPSBpLmdldENvbnRleHQoIndlYmdsMiIsIGUpOwogIGNvbnN0IG8gPSAhIXI7CiAgbyB8fCAociA9IGkuZ2V0Q29udGV4dCgid2ViZ2wiLCBlKSwgci5nZXRFeHRlbnNpb24oIkVYVF9jb2xvcl9idWZmZXJfaGFsZl9mbG9hdCIpKTsKICBjb25zdCBzID0gbyA/IG51bGwgOiByLmdldEV4dGVuc2lvbigiT0VTX3RleHR1cmVfaGFsZl9mbG9hdCIpLCBuID0gbyA/IHIuSEFMRl9GTE9BVCA6IHMuSEFMRl9GTE9BVF9PRVM7CiAgcmV0dXJuIHIuZ2V0RXh0ZW5zaW9uKCJFWFRfY29sb3JfYnVmZmVyX2Zsb2F0IiksIHIuZ2V0RXh0ZW5zaW9uKCJPRVNfdGV4dHVyZV9oYWxmX2Zsb2F0X2xpbmVhciIpLCB7CiAgICBnbDogciwKICAgIGlzV2ViR0wyOiBvLAogICAgZXh0OiB7CiAgICAgIGludGVybmFsRm9ybWF0OiBvID8gci5SR0JBMTZGIDogci5SR0JBLAogICAgICBmb3JtYXQ6IHIuUkdCQSwKICAgICAgdHlwZTogbgogICAgfQogIH07Cn0KY2xhc3MgayB7CiAgY29uc3RydWN0b3IoZSwgciwgbykgewogICAgbmUodGhpcywgInByb2dyYW0iKTsKICAgIG5lKHRoaXMsICJ1bmlmb3JtcyIsIHt9KTsKICAgIG5lKHRoaXMsICJfZ2wiKTsKICAgIHRoaXMuX2dsID0gZSwgdGhpcy5wcm9ncmFtID0gZS5jcmVhdGVQcm9ncmFtKCksIGUuYXR0YWNoU2hhZGVyKHRoaXMucHJvZ3JhbSwgdGhpcy5fY29tcGlsZShlLlZFUlRFWF9TSEFERVIsIHIpKSwgZS5hdHRhY2hTaGFkZXIodGhpcy5wcm9ncmFtLCB0aGlzLl9jb21waWxlKGUuRlJBR01FTlRfU0hBREVSLCBvKSksIGUubGlua1Byb2dyYW0odGhpcy5wcm9ncmFtKTsKICAgIGNvbnN0IHMgPSBlLmdldFByb2dyYW1QYXJhbWV0ZXIodGhpcy5wcm9ncmFtLCBlLkFDVElWRV9VTklGT1JNUyk7CiAgICBmb3IgKGxldCBuID0gMDsgbiA8IHM7IG4rKykgewogICAgICBjb25zdCB1ID0gZS5nZXRBY3RpdmVVbmlmb3JtKHRoaXMucHJvZ3JhbSwgbikubmFtZTsKICAgICAgdGhpcy51bmlmb3Jtc1t1XSA9IGUuZ2V0VW5pZm9ybUxvY2F0aW9uKHRoaXMucHJvZ3JhbSwgdSk7CiAgICB9CiAgfQogIF9jb21waWxlKGUsIHIpIHsKICAgIGNvbnN0IG8gPSB0aGlzLl9nbCwgcyA9IG8uY3JlYXRlU2hhZGVyKGUpOwogICAgcmV0dXJuIG8uc2hhZGVyU291cmNlKHMsIHIpLCBvLmNvbXBpbGVTaGFkZXIocyksIHM7CiAgfQogIGJpbmQoKSB7CiAgICB0aGlzLl9nbC51c2VQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQogIGRpc3Bvc2UoKSB7CiAgICB0aGlzLl9nbC5kZWxldGVQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQp9CmZ1bmN0aW9uIE9lKGkpIHsKICByZXR1cm4gewogICAgYWR2ZWN0aW9uOiBuZXcgayhpLCBQLCBDZSksCiAgICBkaXZlcmdlbmNlOiBuZXcgayhpLCBQLCBGZSksCiAgICBwcmVzc3VyZTogbmV3IGsoaSwgUCwgWGUpLAogICAgZ3JhZGllbnRTdWJ0cmFjdDogbmV3IGsoaSwgUCwgQmUpLAogICAgc3BsYXQ6IG5ldyBrKGksIFAsIEFlKSwKICAgIGN1cmw6IG5ldyBrKGksIFAsIExlKSwKICAgIHZvcnRpY2l0eTogbmV3IGsoaSwgUCwgTWUpLAogICAgZGlzcGxheTogbmV3IGsoaSwgUCwgUGUpCiAgfTsKfQpmdW5jdGlvbiB1ZShpLCBlLCByLCBvKSB7CiAgaS5hY3RpdmVUZXh0dXJlKGkuVEVYVFVSRTApOwogIGNvbnN0IHMgPSBpLmNyZWF0ZVRleHR1cmUoKTsKICBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgcyksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NSU5fRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NQUdfRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1MsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1QsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGUuaW50ZXJuYWxGb3JtYXQsIHIsIG8sIDAsIGUuZm9ybWF0LCBlLnR5cGUsIG51bGwpOwogIGNvbnN0IG4gPSBpLmNyZWF0ZUZyYW1lYnVmZmVyKCk7CiAgcmV0dXJuIGkuYmluZEZyYW1lYnVmZmVyKGkuRlJBTUVCVUZGRVIsIG4pLCBpLmZyYW1lYnVmZmVyVGV4dHVyZTJEKGkuRlJBTUVCVUZGRVIsIGkuQ09MT1JfQVRUQUNITUVOVDAsIGkuVEVYVFVSRV8yRCwgcywgMCksIHsgdGV4OiBzLCBmYm86IG4sIHdpZHRoOiByLCBoZWlnaHQ6IG8gfTsKfQpmdW5jdGlvbiBkZShpLCBlLCByLCBvKSB7CiAgbGV0IHMgPSB1ZShpLCBlLCByLCBvKSwgbiA9IHVlKGksIGUsIHIsIG8pOwogIHJldHVybiB7CiAgICBnZXQgcmVhZCgpIHsKICAgICAgcmV0dXJuIHM7CiAgICB9LAogICAgZ2V0IHdyaXRlKCkgewogICAgICByZXR1cm4gbjsKICAgIH0sCiAgICBzd2FwKCkgewogICAgICBbcywgbl0gPSBbbiwgc107CiAgICB9LAogICAgZGlzcG9zZSgpIHsKICAgICAgaS5kZWxldGVUZXh0dXJlKHMudGV4KSwgaS5kZWxldGVGcmFtZWJ1ZmZlcihzLmZibyksIGkuZGVsZXRlVGV4dHVyZShuLnRleCksIGkuZGVsZXRlRnJhbWVidWZmZXIobi5mYm8pOwogICAgfQogIH07Cn0KZnVuY3Rpb24gSWUoaSkgewogIGNvbnN0IGUgPSBpLmNyZWF0ZUJ1ZmZlcigpOwogIHJldHVybiBpLmJpbmRCdWZmZXIoaS5BUlJBWV9CVUZGRVIsIGUpLCBpLmJ1ZmZlckRhdGEoaS5BUlJBWV9CVUZGRVIsIG5ldyBGbG9hdDMyQXJyYXkoWy0xLCAtMSwgLTEsIDEsIDEsIDEsIDEsIC0xXSksIGkuU1RBVElDX0RSQVcpLCBpLnZlcnRleEF0dHJpYlBvaW50ZXIoMCwgMiwgaS5GTE9BVCwgITEsIDAsIDApLCBpLmVuYWJsZVZlcnRleEF0dHJpYkFycmF5KDApLCBmdW5jdGlvbihvKSB7CiAgICBpLmJpbmRGcmFtZWJ1ZmZlcihpLkZSQU1FQlVGRkVSLCBvKSwgaS5kcmF3QXJyYXlzKGkuVFJJQU5HTEVfRkFOLCAwLCA0KTsKICB9Owp9CmZ1bmN0aW9uIFRlKGksIGUsIHIsIG8sIHMgPSAiY292ZXIiKSB7CiAgbGV0IG47CiAgcyA9PT0gImNvdmVyIiA/IG4gPSBNYXRoLm1heChyIC8gaSwgbyAvIGUpIDogcyA9PT0gImNvbnRhaW4iID8gbiA9IE1hdGgubWluKHIgLyBpLCBvIC8gZSkgOiB0eXBlb2YgcyA9PSAic3RyaW5nIiAmJiBzLmVuZHNXaXRoKCIlIikgPyBuID0gTWF0aC5taW4ociAvIGksIG8gLyBlKSAqIChwYXJzZUZsb2F0KHMpIC8gMTAwKSA6IHR5cGVvZiBzID09ICJzdHJpbmciICYmIHMuZW5kc1dpdGgoInB4IikgPyBuID0gcGFyc2VGbG9hdChzKSAvIE1hdGgubWF4KGksIGUpIDogdHlwZW9mIHMgPT0gIm51bWJlciIgPyBuID0gcyA6IG4gPSBNYXRoLm1heChyIC8gaSwgbyAvIGUpOwogIGNvbnN0IHUgPSBpICogbiwgZCA9IGUgKiBuOwogIHJldHVybiB7IHg6IChyIC0gdSkgLyAyLCB5OiAobyAtIGQpIC8gMiwgZHJhd1c6IHUsIGRyYXdIOiBkIH07Cn0KZnVuY3Rpb24gVmUoaSwgZSwgciwgbywgcyA9IG51bGwsIG4gPSAiY292ZXIiKSB7CiAgY29uc3QgeyB0ZXh0OiB1LCBmb250U2l6ZTogZCwgY29sb3I6IHAsIGZvbnRGYW1pbHk6IGMgPSAic2Fucy1zZXJpZiIsIGZvbnRXZWlnaHQ6IG0gPSA5MDAgfSA9IG8sIHkgPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKGUsIHIpLCBmID0geS5nZXRDb250ZXh0KCIyZCIpOwogICgoY2UpID0+IHsKICAgIGlmIChzKSB7CiAgICAgIGYuY2xlYXJSZWN0KDAsIDAsIGUsIHIpLCBmLmZpbGxTdHlsZSA9ICJibGFjayIsIGYuZmlsbFJlY3QoMCwgMCwgZSwgcik7CiAgICAgIGNvbnN0IHsgeDogZmUsIHk6IGhlLCBkcmF3VzogdmUsIGRyYXdIOiBtZSB9ID0gVGUoCiAgICAgICAgcy53aWR0aCwKICAgICAgICBzLmhlaWdodCwKICAgICAgICBlLAogICAgICAgIHIsCiAgICAgICAgbgogICAgICApOwogICAgICBmLmRyYXdJbWFnZShzLCBmZSwgaGUsIHZlLCBtZSk7CiAgICB9IGVsc2UKICAgICAgZi5maWxsU3R5bGUgPSAiYmxhY2siLCBmLmZpbGxSZWN0KDAsIDAsIGUsIHIpOwogICAgZi5maWxsU3R5bGUgPSBjZSwgZi5mb250ID0gYCR7bX0gJHtkfXB4ICR7Y31gLCBmLnRleHRBbGlnbiA9ICJjZW50ZXIiLCBmLnRleHRCYXNlbGluZSA9ICJtaWRkbGUiLCBmLmZpbGxUZXh0KHUsIGUgLyAyLCByIC8gMik7CiAgfSkocCk7CiAgY29uc3QgSCA9IGVlKGksIHkpOwogIGYuZmlsbFN0eWxlID0gImJsYWNrIiwgZi5maWxsUmVjdCgwLCAwLCBlLCByKSwgZi5maWxsU3R5bGUgPSAid2hpdGUiLCBmLmZvbnQgPSBgJHttfSAke2R9cHggJHtjfWAsIGYudGV4dEFsaWduID0gImNlbnRlciIsIGYudGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIGYuZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICBjb25zdCBhZSA9IGVlKGksIHkpOwogIHJldHVybiB7IGJhY2tncm91bmRUZXg6IEgsIG9ic3RhY2xlVGV4OiBhZSwgY292ZXJhZ2VUZXg6IGFlIH07Cn0KZnVuY3Rpb24gV2UoaSwgZSwgciwgbywgcyA9IDAsIG4gPSAiY292ZXIiLCB1ID0gbnVsbCwgZCA9ICJjb3ZlciIpIHsKICBjb25zdCBwID0gbmV3IE9mZnNjcmVlbkNhbnZhcyhyLCBvKSwgYyA9IHAuZ2V0Q29udGV4dCgiMmQiKSwgeyB4OiBtLCB5LCBkcmF3VzogZiwgZHJhd0g6IEQgfSA9IFRlKGUud2lkdGgsIGUuaGVpZ2h0LCByLCBvLCBuKTsKICBpZiAoYy5jbGVhclJlY3QoMCwgMCwgciwgbyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBvKSwgdSkgewogICAgY29uc3QgewogICAgICB4OiBmZSwKICAgICAgeTogaGUsCiAgICAgIGRyYXdXOiB2ZSwKICAgICAgZHJhd0g6IG1lCiAgICB9ID0gVGUodS53aWR0aCwgdS5oZWlnaHQsIHIsIG8sIGQpOwogICAgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke3N9KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZSh1LCBmZSwgaGUsIHZlLCBtZSksIGMuZmlsdGVyID0gIm5vbmUiOwogIH0KICBjLmRyYXdJbWFnZShlLCBtLCB5LCBmLCBEKTsKICBjb25zdCBIID0gZWUoaSwgcCk7CiAgYy5jbGVhclJlY3QoMCwgMCwgciwgbyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBvKSwgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke3N9KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZShlLCBtLCB5LCBmLCBEKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgY29uc3QgYWUgPSBlZShpLCBwKTsKICBjLmNsZWFyUmVjdCgwLCAwLCByLCBvKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIG8pLCBjLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIGMuZmlsbFJlY3QoCiAgICBNYXRoLm1heCgwLCBtKSwKICAgIE1hdGgubWF4KDAsIHkpLAogICAgTWF0aC5taW4oZiwgciAtIE1hdGgubWF4KDAsIG0pKSwKICAgIE1hdGgubWluKEQsIG8gLSBNYXRoLm1heCgwLCB5KSkKICApOwogIGNvbnN0IGNlID0gZWUoaSwgcCk7CiAgcmV0dXJuIHsgYmFja2dyb3VuZFRleDogSCwgb2JzdGFjbGVUZXg6IGFlLCBjb3ZlcmFnZVRleDogY2UgfTsKfQpmdW5jdGlvbiBlZShpLCBlKSB7CiAgY29uc3QgciA9IGkuY3JlYXRlVGV4dHVyZSgpOwogIHJldHVybiBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgciksIGkucGl4ZWxTdG9yZWkoaS5VTlBBQ0tfRkxJUF9ZX1dFQkdMLCAhMCksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGkuUkdCQSwgaS5SR0JBLCBpLlVOU0lHTkVEX0JZVEUsIGUpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUlOX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUFHX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9TLCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9ULCBpLkNMQU1QX1RPX0VER0UpLCByOwp9CmFzeW5jIGZ1bmN0aW9uIEdlKGkpIHsKICBjb25zdCBlID0gYXdhaXQgZmV0Y2goaSk7CiAgaWYgKCFlLm9rKQogICAgdGhyb3cgbmV3IEVycm9yKGBGYWlsZWQgdG8gZmV0Y2ggaW1hZ2U6ICR7aX0gKCR7ZS5zdGF0dXN9KWApOwogIGNvbnN0IHIgPSBhd2FpdCBlLmJsb2IoKTsKICByZXR1cm4gY3JlYXRlSW1hZ2VCaXRtYXAocik7Cn0KY29uc3QgZ2UgPSB0eXBlb2YgcmVxdWVzdEFuaW1hdGlvbkZyYW1lIDwgInUiID8gcmVxdWVzdEFuaW1hdGlvbkZyYW1lLmJpbmQoZ2xvYmFsVGhpcykgOiAoaSkgPT4gc2V0VGltZW91dChpLCAxZTMgLyA2MCksIHplID0gdHlwZW9mIGNhbmNlbEFuaW1hdGlvbkZyYW1lIDwgInUiID8gY2FuY2VsQW5pbWF0aW9uRnJhbWUuYmluZChnbG9iYWxUaGlzKSA6IGNsZWFyVGltZW91dCwgUmUgPSAwLjAxNiwgTmUgPSB7IHN0YW5kYXJkOiAwLCBnbGFzczogMSwgaW5rOiAyLCBhdXJvcmE6IDMsIHJpcHBsZTogNCB9Owp2YXIgVywgZywgdGUsIEcsIHEsIEUsIGIsIE8sIEksIHcsIFEsIEwsIFIsIGgsIEMsIEYsIFgsIE0sIFUsIEIsIFMsIEssIHosIHgsIF8sIEEsIE4sIHJlLCAkLCBKLCBpZSwgcGUsIFYsIGosIFksIFosIG9lLCBFZSwgc2UsIGJlLCBsZSwgRGU7CmNsYXNzICRlIHsKICBjb25zdHJ1Y3RvcihlLCByID0ge30sIG8gPSB7fSkgewogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIGhlbHBlcnMKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgbCh0aGlzLCAkKTsKICAgIGwodGhpcywgaWUpOwogICAgbCh0aGlzLCBWKTsKICAgIGwodGhpcywgWSk7CiAgICBsKHRoaXMsIG9lKTsKICAgIGwodGhpcywgc2UpOwogICAgbCh0aGlzLCBsZSk7CiAgICBsKHRoaXMsIFcsIHZvaWQgMCk7CiAgICBsKHRoaXMsIGcsIHZvaWQgMCk7CiAgICBsKHRoaXMsIHRlLCB2b2lkIDApOwogICAgbCh0aGlzLCBHLCB2b2lkIDApOwogICAgbCh0aGlzLCBxLCB2b2lkIDApOwogICAgbCh0aGlzLCBFLCAwKTsKICAgIGwodGhpcywgYiwgMCk7CiAgICBsKHRoaXMsIE8sIDApOwogICAgbCh0aGlzLCBJLCAwKTsKICAgIGwodGhpcywgdywgMSk7CiAgICBsKHRoaXMsIFEsIDEpOwogICAgbCh0aGlzLCBMLCAwLjUpOwogICAgbCh0aGlzLCBSLCBudWxsKTsKICAgIGwodGhpcywgaCwgbnVsbCk7CiAgICBsKHRoaXMsIEMsIG51bGwpOwogICAgbCh0aGlzLCBGLCBudWxsKTsKICAgIGwodGhpcywgWCwgbnVsbCk7CiAgICBsKHRoaXMsIE0sIG51bGwpOwogICAgbCh0aGlzLCBVLCBudWxsKTsKICAgIGwodGhpcywgQiwgbnVsbCk7CiAgICAvLyBiaW5hcnkgY29udGVudCBtYXNrIGZvciB0cmFuc3BhcmVudCBjYW52YXMgc3VwcG9ydAogICAgbCh0aGlzLCBTLCBudWxsKTsKICAgIC8vIG9wdGlvbmFsIGJhY2tncm91bmQgaW1hZ2UgKGZyb20gYmFja2dyb3VuZFNyYyBwcm9wKQogICAgbCh0aGlzLCBLLCAiY292ZXIiKTsKICAgIGwodGhpcywgeiwgdm9pZCAwKTsKICAgIGwodGhpcywgeCwgeyB4OiAwLCB5OiAwLCBkeDogMCwgZHk6IDAsIHRhcmdldFg6IDAsIHRhcmdldFk6IDAsIG1vdmVkOiAhMSB9KTsKICAgIC8vIFN0b3JlcyBzb3VyY2Ugc28gdGV4dHVyZXMgY2FuIGJlIHJlYnVpbHQgb24gcmVzaXplCiAgICBsKHRoaXMsIF8sIG51bGwpOwogICAgbCh0aGlzLCBBLCBudWxsKTsKICAgIGwodGhpcywgTiwgITEpOwogICAgbCh0aGlzLCByZSwgITEpOwogICAgYSh0aGlzLCBXLCBlKSwgYSh0aGlzLCBRLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIG8uZHByID8/IDEpKSksIGEodGhpcywgTCwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBvLnNpbSA/PyAwLjUpKSksIGEodGhpcywgeiwgU2UocikpOwogICAgY29uc3QgeyBnbDogcywgZXh0OiBuIH0gPSBrZShlKTsKICAgIGEodGhpcywgZywgcyksIGEodGhpcywgdGUsIG4pLCBhKHRoaXMsIEcsIE9lKHMpKSwgYSh0aGlzLCBxLCBJZShzKSksIHMuY2xlYXJDb2xvcigwLCAwLCAwLCAwKTsKICB9CiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgLy8gUHVibGljIEFQSQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIHNldFRleHRTb3VyY2UoZSkgewogICAgYSh0aGlzLCBfLCB7IHR5cGU6ICJ0ZXh0Iiwgb3B0czogZSB9KSwgVCh0aGlzLCAkLCBKKS5jYWxsKHRoaXMpLCBUKHRoaXMsIFYsIGopLmNhbGwodGhpcyksIFQodGhpcywgWSwgWikuY2FsbCh0aGlzKTsKICB9CiAgYXN5bmMgc2V0SW1hZ2VTb3VyY2UoZSwgciA9IDAsIG8gPSAiY292ZXIiKSB7CiAgICBjb25zdCBzID0gYXdhaXQgR2UoZSk7CiAgICBpZiAodCh0aGlzLCByZSkpIHsKICAgICAgcy5jbG9zZSgpOwogICAgICByZXR1cm47CiAgICB9CiAgICBhKHRoaXMsIF8sIHsgdHlwZTogImltYWdlIiwgYml0bWFwOiBzLCBlZmZlY3Q6IHIsIHNpemU6IG8gfSksIFQodGhpcywgJCwgSikuY2FsbCh0aGlzKSwgVCh0aGlzLCBWLCBqKS5jYWxsKHRoaXMpLCBUKHRoaXMsIFksIFopLmNhbGwodGhpcyk7CiAgfQogIHNldEltYWdlQml0bWFwKGUsIHIgPSAwLCBvID0gImNvdmVyIikgewogICAgYSh0aGlzLCBfLCB7IHR5cGU6ICJpbWFnZSIsIGJpdG1hcDogZSwgZWZmZWN0OiByLCBzaXplOiBvIH0pLCBUKHRoaXMsICQsIEopLmNhbGwodGhpcyksIFQodGhpcywgViwgaikuY2FsbCh0aGlzKSwgVCh0aGlzLCBZLCBaKS5jYWxsKHRoaXMpOwogIH0KICBzZXRCYWNrZ3JvdW5kKGUsIHIgPSAiY292ZXIiKSB7CiAgICB0KHRoaXMsIFMpICYmIHQodGhpcywgUykgIT09IGUgJiYgdCh0aGlzLCBTKS5jbG9zZSgpLCBhKHRoaXMsIFMsIGUpLCBhKHRoaXMsIEssIHIgPz8gImNvdmVyIiksIHQodGhpcywgXykgJiYgdCh0aGlzLCBFKSA+IDAgJiYgdCh0aGlzLCBiKSA+IDAgJiYgVCh0aGlzLCBWLCBqKS5jYWxsKHRoaXMpOwogIH0KICBoYW5kbGVNb3ZlKGUsIHIsIG8gPSAxKSB7CiAgICB0KHRoaXMsIHgpLm1vdmVkID0gITAsIHQodGhpcywgeCkuZHggPSAoZSAtIHQodGhpcywgeCkudGFyZ2V0WCkgKiBvLCB0KHRoaXMsIHgpLmR5ID0gKHIgLSB0KHRoaXMsIHgpLnRhcmdldFkpICogbywgdCh0aGlzLCB4KS50YXJnZXRYID0gZSwgdCh0aGlzLCB4KS50YXJnZXRZID0gcjsKICB9CiAgLyoqCiAgICogSW1tZWRpYXRlbHkgYXBwbGllcyBvbmUgZmx1aWQgc3BsYXQgYXQgKHgsIHkpIHdpdGggZXhwbGljaXQgdmVsb2NpdHkgKHZ4LCB2eSkuCiAgICogU2FmZSB0byBjYWxsIG11bHRpcGxlIHRpbWVzIHBlciBmcmFtZSDigJQgZWFjaCBjYWxsIHdyaXRlcyBkaXJlY3RseSB0byB0aGUgRkJPcy4KICAgKiBEZXNpZ25lZCBmb3IgcHJvZ3JhbW1hdGljIHVzZSBjYXNlcyAoZS5nLiBwYXJ0aWNsZSBzeXN0ZW1zLCBhdHRyYWN0b3IgcGF0aHMpCiAgICogd2hlcmUgeW91IHdhbnQgTiBpbmRlcGVuZGVudCBpbmplY3Rpb24gcG9pbnRzIHBlciBmcmFtZSB3aXRob3V0IGZsb29kaW5nIHRoZQogICAqIG1vdXNlLXN0YXRlIG1hY2hpbmUgb3IgdGhlIHdvcmtlciBtZXNzYWdlIHF1ZXVlLgogICAqLwogIHNwbGF0KGUsIHIsIG8sIHMsIG4gPSAxKSB7CiAgICBpZiAoIXQodGhpcywgTikgfHwgdCh0aGlzLCBFKSA9PT0gMCkKICAgICAgcmV0dXJuOwogICAgY29uc3QgdSA9IHQodGhpcywgZyksIGQgPSB0KHRoaXMsIHopLCB7IHNwbGF0OiBwIH0gPSB0KHRoaXMsIEcpLCBjID0gdCh0aGlzLCBxKTsKICAgIHUudmlld3BvcnQoMCwgMCwgdCh0aGlzLCBPKSwgdCh0aGlzLCBJKSksIHAuYmluZCgpLCB1LnVuaWZvcm0xZihwLnVuaWZvcm1zLmFzcGVjdFJhdGlvLCB0KHRoaXMsIEUpIC8gdCh0aGlzLCBiKSksIHUudW5pZm9ybTJmKHAudW5pZm9ybXMucG9pbnQsIGUgKiB0KHRoaXMsIHcpIC8gdCh0aGlzLCBFKSwgMSAtIHIgKiB0KHRoaXMsIHcpIC8gdCh0aGlzLCBiKSksIHUudW5pZm9ybTFmKHAudW5pZm9ybXMucmFkaXVzLCBkLnNwbGF0UmFkaXVzKSwgdS51bmlmb3JtMWkocC51bmlmb3Jtcy51VGFyZ2V0LCAwKSwgdS5hY3RpdmVUZXh0dXJlKHUuVEVYVFVSRTApLCB1LmJpbmRUZXh0dXJlKHUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIHUudW5pZm9ybTNmKHAudW5pZm9ybXMuY29sb3IsIG8gKiBkLnNwbGF0Rm9yY2UgKiBuLCAtcyAqIGQuc3BsYXRGb3JjZSAqIG4sIDApLCBjKHQodGhpcywgaCkud3JpdGUuZmJvKSwgdCh0aGlzLCBoKS5zd2FwKCksIHUuYWN0aXZlVGV4dHVyZSh1LlRFWFRVUkUwKSwgdS5iaW5kVGV4dHVyZSh1LlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCB1LnVuaWZvcm0zZihwLnVuaWZvcm1zLmNvbG9yLCBuLCBuLCBuKSwgYyh0KHRoaXMsIFIpLndyaXRlLmZibyksIHQodGhpcywgUikuc3dhcCgpOwogIH0KICB1cGRhdGVRdWFsaXR5KGUpIHsKICAgIGUuZHByICE9PSB2b2lkIDAgJiYgYSh0aGlzLCBRLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIGUuZHByKSkpLCBlLnNpbSAhPT0gdm9pZCAwICYmIGEodGhpcywgTCwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBlLnNpbSkpKTsKICB9CiAgcmVzaXplKGUsIHIsIG8pIHsKICAgIGlmIChvICE9PSB2b2lkIDAgPyBhKHRoaXMsIHcsIG8pIDogdHlwZW9mIHdpbmRvdyA8ICJ1IiAmJiB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpbyAmJiBhKHRoaXMsIHcsIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvKSwgZSAhPT0gdm9pZCAwICYmIGUgPiAwKSB7CiAgICAgIGlmIChyID09PSB2b2lkIDAgfHwgciA8PSAwKQogICAgICAgIHJldHVybjsKICAgICAgYSh0aGlzLCBFLCB0KHRoaXMsIFcpLndpZHRoID0gZSksIGEodGhpcywgYiwgdCh0aGlzLCBXKS5oZWlnaHQgPSByKSwgYSh0aGlzLCBPLCBNYXRoLm1heCgxLCBNYXRoLnJvdW5kKGUgKiB0KHRoaXMsIEwpKSkpLCBhKHRoaXMsIEksIE1hdGgubWF4KDEsIE1hdGgucm91bmQociAqIHQodGhpcywgTCkpKSksIFQodGhpcywgaWUsIHBlKS5jYWxsKHRoaXMpOwogICAgfSBlbHNlCiAgICAgIFQodGhpcywgJCwgSikuY2FsbCh0aGlzKTsKICAgIHQodGhpcywgXykgJiYgVCh0aGlzLCBWLCBqKS5jYWxsKHRoaXMpLCBUKHRoaXMsIFksIFopLmNhbGwodGhpcyk7CiAgfQogIHVwZGF0ZUNvbmZpZyhlKSB7CiAgICBPYmplY3QuYXNzaWduKHQodGhpcywgeiksIGUpOwogIH0KICBkZXN0cm95KCkgewogICAgYSh0aGlzLCByZSwgITApLCB0aGlzLnN0b3AoKTsKICAgIGNvbnN0IGUgPSB0KHRoaXMsIGcpOwogICAgVCh0aGlzLCBvZSwgRWUpLmNhbGwodGhpcyksIFQodGhpcywgc2UsIGJlKS5jYWxsKHRoaXMpLCB0KHRoaXMsIFMpICYmICh0KHRoaXMsIFMpLmNsb3NlKCksIGEodGhpcywgUywgbnVsbCkpOwogICAgZm9yIChjb25zdCBvIG9mIE9iamVjdC52YWx1ZXModCh0aGlzLCBHKSkpCiAgICAgIG8uZGlzcG9zZSgpOwogICAgY29uc3QgciA9IGUuZ2V0RXh0ZW5zaW9uKCJXRUJHTF9sb3NlX2NvbnRleHQiKTsKICAgIHIgPT0gbnVsbCB8fCByLmxvc2VDb250ZXh0KCk7CiAgfQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIC8vIExvb3AgY29udHJvbAogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIHN0YXJ0KCkgewogICAgaWYgKHQodGhpcywgQSkgIT09IG51bGwpCiAgICAgIHJldHVybjsKICAgIGNvbnN0IGUgPSAoKSA9PiB7CiAgICAgIFQodGhpcywgbGUsIERlKS5jYWxsKHRoaXMpLCBhKHRoaXMsIEEsIGdlKGUpKTsKICAgIH07CiAgICBhKHRoaXMsIEEsIGdlKGUpKTsKICB9CiAgc3RvcCgpIHsKICAgIHQodGhpcywgQSkgIT09IG51bGwgJiYgKHplKHQodGhpcywgQSkpLCBhKHRoaXMsIEEsIG51bGwpKTsKICB9CiAgZ2V0IGlzUnVubmluZygpIHsKICAgIHJldHVybiB0KHRoaXMsIEEpICE9PSBudWxsOwogIH0KfQpXID0gbmV3IFdlYWtNYXAoKSwgZyA9IG5ldyBXZWFrTWFwKCksIHRlID0gbmV3IFdlYWtNYXAoKSwgRyA9IG5ldyBXZWFrTWFwKCksIHEgPSBuZXcgV2Vha01hcCgpLCBFID0gbmV3IFdlYWtNYXAoKSwgYiA9IG5ldyBXZWFrTWFwKCksIE8gPSBuZXcgV2Vha01hcCgpLCBJID0gbmV3IFdlYWtNYXAoKSwgdyA9IG5ldyBXZWFrTWFwKCksIFEgPSBuZXcgV2Vha01hcCgpLCBMID0gbmV3IFdlYWtNYXAoKSwgUiA9IG5ldyBXZWFrTWFwKCksIGggPSBuZXcgV2Vha01hcCgpLCBDID0gbmV3IFdlYWtNYXAoKSwgRiA9IG5ldyBXZWFrTWFwKCksIFggPSBuZXcgV2Vha01hcCgpLCBNID0gbmV3IFdlYWtNYXAoKSwgVSA9IG5ldyBXZWFrTWFwKCksIEIgPSBuZXcgV2Vha01hcCgpLCBTID0gbmV3IFdlYWtNYXAoKSwgSyA9IG5ldyBXZWFrTWFwKCksIHogPSBuZXcgV2Vha01hcCgpLCB4ID0gbmV3IFdlYWtNYXAoKSwgXyA9IG5ldyBXZWFrTWFwKCksIEEgPSBuZXcgV2Vha01hcCgpLCBOID0gbmV3IFdlYWtNYXAoKSwgcmUgPSBuZXcgV2Vha01hcCgpLCAkID0gbmV3IFdlYWtTZXQoKSwgSiA9IGZ1bmN0aW9uKCkgewogIGNvbnN0IGUgPSB0KHRoaXMsIFcpOwogICJjbGllbnRXaWR0aCIgaW4gZSAmJiBlLmNsaWVudFdpZHRoID4gMCA/IChhKHRoaXMsIHcsICh0eXBlb2Ygd2luZG93IDwgInUiICYmIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvIHx8IDEpICogdCh0aGlzLCBRKSksIGEodGhpcywgRSwgZS53aWR0aCA9IE1hdGgucm91bmQoZS5jbGllbnRXaWR0aCAqIHQodGhpcywgdykpKSwgYSh0aGlzLCBiLCBlLmhlaWdodCA9IE1hdGgucm91bmQoZS5jbGllbnRIZWlnaHQgKiB0KHRoaXMsIHcpKSkpIDogKGEodGhpcywgRSwgZS53aWR0aCksIGEodGhpcywgYiwgZS5oZWlnaHQpKSwgISh0KHRoaXMsIEUpID09PSAwIHx8IHQodGhpcywgYikgPT09IDApICYmIChhKHRoaXMsIE8sIE1hdGgubWF4KDEsIE1hdGgucm91bmQodCh0aGlzLCBFKSAqIHQodGhpcywgTCkpKSksIGEodGhpcywgSSwgTWF0aC5tYXgoMSwgTWF0aC5yb3VuZCh0KHRoaXMsIGIpICogdCh0aGlzLCBMKSkpKSwgVCh0aGlzLCBpZSwgcGUpLmNhbGwodGhpcykpOwp9LCBpZSA9IG5ldyBXZWFrU2V0KCksIHBlID0gZnVuY3Rpb24oKSB7CiAgY29uc3QgZSA9IHQodGhpcywgZyksIHIgPSB0KHRoaXMsIHRlKSwgbyA9IHQodGhpcywgTyksIHMgPSB0KHRoaXMsIEkpOwogIFQodGhpcywgb2UsIEVlKS5jYWxsKHRoaXMpLCBhKHRoaXMsIFIsIGRlKGUsIHIsIG8sIHMpKSwgYSh0aGlzLCBoLCBkZShlLCByLCBvLCBzKSksIGEodGhpcywgRiwgZGUoZSwgciwgbywgcykpLCBhKHRoaXMsIEMsIHVlKGUsIHIsIG8sIHMpKSwgYSh0aGlzLCBYLCB1ZShlLCByLCBvLCBzKSk7Cn0sIFYgPSBuZXcgV2Vha1NldCgpLCBqID0gZnVuY3Rpb24oKSB7CiAgaWYgKCEoIXQodGhpcywgXykgfHwgdCh0aGlzLCBFKSA9PT0gMCB8fCB0KHRoaXMsIGIpID09PSAwKSkgewogICAgaWYgKFQodGhpcywgc2UsIGJlKS5jYWxsKHRoaXMpLCB0KHRoaXMsIF8pLnR5cGUgPT09ICJ0ZXh0IikgewogICAgICBjb25zdCB7IGJhY2tncm91bmRUZXg6IGUsIG9ic3RhY2xlVGV4OiByLCBjb3ZlcmFnZVRleDogbyB9ID0gVmUoCiAgICAgICAgdCh0aGlzLCBnKSwKICAgICAgICB0KHRoaXMsIEUpLAogICAgICAgIHQodGhpcywgYiksCiAgICAgICAgdCh0aGlzLCBfKS5vcHRzLAogICAgICAgIHQodGhpcywgUyksCiAgICAgICAgdCh0aGlzLCBLKQogICAgICApOwogICAgICBhKHRoaXMsIE0sIGUpLCBhKHRoaXMsIFUsIHIpLCBhKHRoaXMsIEIsIG8pOwogICAgfSBlbHNlIHsKICAgICAgY29uc3QgeyBiYWNrZ3JvdW5kVGV4OiBlLCBvYnN0YWNsZVRleDogciwgY292ZXJhZ2VUZXg6IG8gfSA9IFdlKAogICAgICAgIHQodGhpcywgZyksCiAgICAgICAgdCh0aGlzLCBfKS5iaXRtYXAsCiAgICAgICAgdCh0aGlzLCBFKSwKICAgICAgICB0KHRoaXMsIGIpLAogICAgICAgIHQodGhpcywgXykuZWZmZWN0LAogICAgICAgIHQodGhpcywgXykuc2l6ZSwKICAgICAgICB0KHRoaXMsIFMpLAogICAgICAgIHQodGhpcywgSykKICAgICAgKTsKICAgICAgYSh0aGlzLCBNLCBlKSwgYSh0aGlzLCBVLCByKSwgYSh0aGlzLCBCLCBvKTsKICAgIH0KICAgIGEodGhpcywgTiwgITApOwogIH0KfSwgWSA9IG5ldyBXZWFrU2V0KCksIFogPSBmdW5jdGlvbigpIHsKICB0KHRoaXMsIE4pICYmICF0aGlzLmlzUnVubmluZyAmJiB0aGlzLnN0YXJ0KCk7Cn0sIG9lID0gbmV3IFdlYWtTZXQoKSwgRWUgPSBmdW5jdGlvbigpIHsKICB2YXIgZSwgciwgbzsKICAoZSA9IHQodGhpcywgUikpID09IG51bGwgfHwgZS5kaXNwb3NlKCksIChyID0gdCh0aGlzLCBoKSkgPT0gbnVsbCB8fCByLmRpc3Bvc2UoKSwgKG8gPSB0KHRoaXMsIEYpKSA9PSBudWxsIHx8IG8uZGlzcG9zZSgpLCB0KHRoaXMsIEMpICYmICh0KHRoaXMsIGcpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBDKS50ZXgpLCB0KHRoaXMsIGcpLmRlbGV0ZUZyYW1lYnVmZmVyKHQodGhpcywgQykuZmJvKSksIHQodGhpcywgWCkgJiYgKHQodGhpcywgZykuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIFgpLnRleCksIHQodGhpcywgZykuZGVsZXRlRnJhbWVidWZmZXIodCh0aGlzLCBYKS5mYm8pKSwgYSh0aGlzLCBSLCBhKHRoaXMsIGgsIGEodGhpcywgRiwgYSh0aGlzLCBDLCBhKHRoaXMsIFgsIG51bGwpKSkpKTsKfSwgc2UgPSBuZXcgV2Vha1NldCgpLCBiZSA9IGZ1bmN0aW9uKCkgewogIHQodGhpcywgTSkgJiYgdCh0aGlzLCBnKS5kZWxldGVUZXh0dXJlKHQodGhpcywgTSkpLCB0KHRoaXMsIFUpICYmIHQodGhpcywgZykuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIFUpKSwgdCh0aGlzLCBCKSAmJiB0KHRoaXMsIEIpICE9PSB0KHRoaXMsIFUpICYmIHQodGhpcywgZykuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIEIpKSwgYSh0aGlzLCBNLCBhKHRoaXMsIFUsIGEodGhpcywgQiwgbnVsbCkpKTsKfSwgbGUgPSBuZXcgV2Vha1NldCgpLCBEZSA9IGZ1bmN0aW9uKCkgewogIGlmICghdCh0aGlzLCBOKSB8fCB0KHRoaXMsIEUpID09PSAwIHx8ICF0KHRoaXMsIFIpIHx8ICF0KHRoaXMsIGgpKQogICAgcmV0dXJuOwogIGNvbnN0IGUgPSB0KHRoaXMsIGcpLCByID0gdCh0aGlzLCB6KSwgeyBhZHZlY3Rpb246IG8sIGRpdmVyZ2VuY2U6IHMsIHByZXNzdXJlOiBuLCBncmFkaWVudFN1YnRyYWN0OiB1LCBzcGxhdDogZCwgY3VybDogcCwgdm9ydGljaXR5OiBjLCBkaXNwbGF5OiBtIH0gPSB0KHRoaXMsIEcpOwogIHQodGhpcywgeCkueCArPSAodCh0aGlzLCB4KS50YXJnZXRYIC0gdCh0aGlzLCB4KS54KSAqIDAuMTUsIHQodGhpcywgeCkueSArPSAodCh0aGlzLCB4KS50YXJnZXRZIC0gdCh0aGlzLCB4KS55KSAqIDAuMTU7CiAgY29uc3QgeSA9IHQodGhpcywgTyksIGYgPSB0KHRoaXMsIEkpLCBEID0gdCh0aGlzLCBxKTsKICBlLnZpZXdwb3J0KDAsIDAsIHksIGYpLCBvLmJpbmQoKSwgZS51bmlmb3JtMmYoby51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB5LCAxIC8gZiksIGUudW5pZm9ybTFmKG8udW5pZm9ybXMuZHQsIFJlKSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51T2JzdGFjbGUsIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFUpKSwgZS51bmlmb3JtMWYoby51bmlmb3Jtcy5kaXNzaXBhdGlvbiwgci52ZWxvY2l0eURpc3NpcGF0aW9uKSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51VmVsb2NpdHksIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIGgpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51U291cmNlLCAxKSwgRCh0KHRoaXMsIGgpLndyaXRlLmZibyksIHQodGhpcywgaCkuc3dhcCgpLCBlLnVuaWZvcm0xZihvLnVuaWZvcm1zLmRpc3NpcGF0aW9uLCByLmRlbnNpdHlEaXNzaXBhdGlvbiksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudVNvdXJjZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBEKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIHAuYmluZCgpLCBlLnVuaWZvcm0yZihwLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHksIDEgLyBmKSwgZS51bmlmb3JtMWkocC51bmlmb3Jtcy51VmVsb2NpdHksIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIGgpLnJlYWQudGV4KSwgRCh0KHRoaXMsIFgpLmZibyksIGMuYmluZCgpLCBlLnVuaWZvcm0yZihjLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHksIDEgLyBmKSwgZS51bmlmb3JtMWYoYy51bmlmb3Jtcy5jdXJsLCByLmN1cmwpLCBlLnVuaWZvcm0xZihjLnVuaWZvcm1zLmR0LCBSZSksIGUudW5pZm9ybTFpKGMudW5pZm9ybXMudVZlbG9jaXR5LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKGMudW5pZm9ybXMudUN1cmwsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFgpLnRleCksIEQodCh0aGlzLCBoKS53cml0ZS5mYm8pLCB0KHRoaXMsIGgpLnN3YXAoKSwgdCh0aGlzLCB4KS5tb3ZlZCAmJiAoZC5iaW5kKCksIGUudW5pZm9ybTFmKGQudW5pZm9ybXMuYXNwZWN0UmF0aW8sIHQodGhpcywgRSkgLyB0KHRoaXMsIGIpKSwgZS51bmlmb3JtMmYoZC51bmlmb3Jtcy5wb2ludCwgdCh0aGlzLCB4KS54ICogdCh0aGlzLCB3KSAvIHQodGhpcywgRSksIDEgLSB0KHRoaXMsIHgpLnkgKiB0KHRoaXMsIHcpIC8gdCh0aGlzLCBiKSksIGUudW5pZm9ybTFmKGQudW5pZm9ybXMucmFkaXVzLCByLnNwbGF0UmFkaXVzKSwgZS51bmlmb3JtMWkoZC51bmlmb3Jtcy51VGFyZ2V0LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTNmKGQudW5pZm9ybXMuY29sb3IsIHQodGhpcywgeCkuZHggKiByLnNwbGF0Rm9yY2UsIC10KHRoaXMsIHgpLmR5ICogci5zcGxhdEZvcmNlLCAwKSwgRCh0KHRoaXMsIGgpLndyaXRlLmZibyksIHQodGhpcywgaCkuc3dhcCgpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtM2YoZC51bmlmb3Jtcy5jb2xvciwgMSwgMSwgMSksIEQodCh0aGlzLCBSKS53cml0ZS5mYm8pLCB0KHRoaXMsIFIpLnN3YXAoKSwgdCh0aGlzLCB4KS5tb3ZlZCA9ICExKSwgcy5iaW5kKCksIGUudW5pZm9ybTJmKHMudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geSwgMSAvIGYpLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVWZWxvY2l0eSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgaCkucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVPYnN0YWNsZSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpLCBEKHQodGhpcywgQykuZmJvKSwgbi5iaW5kKCksIGUudW5pZm9ybTJmKG4udW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geSwgMSAvIGYpLCBlLnVuaWZvcm0xaShuLnVuaWZvcm1zLnVEaXZlcmdlbmNlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBDKS50ZXgpLCBlLnVuaWZvcm0xaShuLnVuaWZvcm1zLnVPYnN0YWNsZSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpOwogIGZvciAobGV0IEggPSAwOyBIIDwgci5wcmVzc3VyZUl0ZXJhdGlvbnM7IEgrKykKICAgIGUudW5pZm9ybTFpKG4udW5pZm9ybXMudVByZXNzdXJlLCAyKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTIpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBGKS5yZWFkLnRleCksIEQodCh0aGlzLCBGKS53cml0ZS5mYm8pLCB0KHRoaXMsIEYpLnN3YXAoKTsKICB1LmJpbmQoKSwgZS51bmlmb3JtMmYodS51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB5LCAxIC8gZiksIGUudW5pZm9ybTFpKHUudW5pZm9ybXMudVByZXNzdXJlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBGKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKHUudW5pZm9ybXMudVZlbG9jaXR5LCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKHUudW5pZm9ybXMudU9ic3RhY2xlLCAyKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTIpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBVKSksIEQodCh0aGlzLCBoKS53cml0ZS5mYm8pLCB0KHRoaXMsIGgpLnN3YXAoKSwgZS52aWV3cG9ydCgwLCAwLCB0KHRoaXMsIEUpLCB0KHRoaXMsIGIpKSwgZS5iaW5kRnJhbWVidWZmZXIoZS5GUkFNRUJVRkZFUiwgbnVsbCksIGUuY2xlYXIoZS5DT0xPUl9CVUZGRVJfQklUKSwgbS5iaW5kKCksIGUudW5pZm9ybTJmKG0udW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gdCh0aGlzLCBFKSwgMSAvIHQodGhpcywgYikpLCBlLnVuaWZvcm0zZnYobS51bmlmb3Jtcy51V2F0ZXJDb2xvciwgci53YXRlckNvbG9yKSwgZS51bmlmb3JtM2Z2KG0udW5pZm9ybXMudUdsb3dDb2xvciwgci5nbG93Q29sb3IpLCBlLnVuaWZvcm0xZihtLnVuaWZvcm1zLnVSZWZyYWN0aW9uLCByLnJlZnJhY3Rpb24pLCBlLnVuaWZvcm0xZihtLnVuaWZvcm1zLnVTcGVjdWxhckV4cCwgci5zcGVjdWxhckV4cCksIGUudW5pZm9ybTFmKG0udW5pZm9ybXMudVNoaW5lLCByLnNoaW5lKSwgZS51bmlmb3JtMWYobS51bmlmb3Jtcy51V2FycFN0cmVuZ3RoLCByLndhcnBTdHJlbmd0aCA/PyAwLjAxNSksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudUFsZ29yaXRobSwgTmVbci5hbGdvcml0aG1dID8/IDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBVKSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgTSkpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMyksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEIpKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTQpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBoKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudVRleHR1cmUsIDApLCBlLnVuaWZvcm0xaShtLnVuaWZvcm1zLnVPYnN0YWNsZSwgMSksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudUJhY2tncm91bmQsIDIpLCBlLnVuaWZvcm0xaShtLnVuaWZvcm1zLnVDb3ZlcmFnZSwgMyksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudVZlbG9jaXR5LCA0KSwgRChudWxsKTsKfTsKbGV0IHYgPSBudWxsOwpzZWxmLm9ubWVzc2FnZSA9IGFzeW5jIChpKSA9PiB7CiAgY29uc3QgeyB0eXBlOiBlLCAuLi5yIH0gPSBpLmRhdGE7CiAgdHJ5IHsKICAgIHN3aXRjaCAoZSkgewogICAgICBjYXNlICJpbml0IjogewogICAgICAgIGNvbnN0IHsgY2FudmFzOiBvLCB3aWR0aDogcywgaGVpZ2h0OiBuLCBjb25maWc6IHUsIGRwcjogZCwgcXVhbGl0eTogcCB9ID0gcjsKICAgICAgICBvLndpZHRoID0gcywgby5oZWlnaHQgPSBuLCB2ID0gbmV3ICRlKG8sIHUsIHAgPz8ge30pLCB2LnJlc2l6ZShzLCBuLCBkIHx8IDEpLCBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogInJlYWR5IiB9KTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRUZXh0U291cmNlIjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnNldFRleHRTb3VyY2Uoci5vcHRzKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRJbWFnZVNvdXJjZSI6IHsKICAgICAgICBpZiAoIXYpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgYXdhaXQgdi5zZXRJbWFnZVNvdXJjZSgKICAgICAgICAgIHIuc3JjLAogICAgICAgICAgci5lZmZlY3QsCiAgICAgICAgICByLnNpemUKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNldEltYWdlQml0bWFwIjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnNldEltYWdlQml0bWFwKAogICAgICAgICAgci5iaXRtYXAsCiAgICAgICAgICByLmVmZmVjdCwKICAgICAgICAgIHIuc2l6ZQogICAgICAgICk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0QmFja2dyb3VuZCI6IHsKICAgICAgICBpZiAoIXYpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgdi5zZXRCYWNrZ3JvdW5kKHIuYml0bWFwLCByLnNpemUpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNwbGF0IjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnNwbGF0KAogICAgICAgICAgci54LAogICAgICAgICAgci55LAogICAgICAgICAgci52eCwKICAgICAgICAgIHIudnksCiAgICAgICAgICByLnN0cmVuZ3RoID8/IDEKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgIm1vdmUiOiB7CiAgICAgICAgaWYgKCF2KQogICAgICAgICAgcmV0dXJuOwogICAgICAgIHYuaGFuZGxlTW92ZShyLngsIHIueSwgci5zdHJlbmd0aCA/PyAxKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJyZXNpemUiOiB7CiAgICAgICAgaWYgKCF2KQogICAgICAgICAgcmV0dXJuOwogICAgICAgIHYucmVzaXplKHIud2lkdGgsIHIuaGVpZ2h0LCByLmRwcik7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlUXVhbGl0eSI6IHsKICAgICAgICBpZiAoIXYpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgdi51cGRhdGVRdWFsaXR5KHIucXVhbGl0eSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlQ29uZmlnIjogewogICAgICAgIGlmICghdikKICAgICAgICAgIHJldHVybjsKICAgICAgICB2LnVwZGF0ZUNvbmZpZyhyLmNvbmZpZyk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAiZGVzdHJveSI6IHsKICAgICAgICB2ID09IG51bGwgfHwgdi5kZXN0cm95KCksIHYgPSBudWxsOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGRlZmF1bHQ6CiAgICAgICAgY29uc29sZS53YXJuKCJbZmx1aWRpdHktanMgd29ya2VyXSBVbmtub3duIG1lc3NhZ2UgdHlwZToiLCBlKTsKICAgIH0KICB9IGNhdGNoIChvKSB7CiAgICBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogImVycm9yIiwgbWVzc2FnZTogKG8gPT0gbnVsbCA/IHZvaWQgMCA6IG8ubWVzc2FnZSkgPz8gU3RyaW5nKG8pIH0pOwogIH0KfTsK", JI = typeof window < "u" && window.Blob && new Blob([atob(PI)], { type: "text/javascript;charset=utf-8" });
680
- function Gg() {
681
- let C;
1564
+ let ZI = vI;
1565
+ const jI = "dmFyIFR0ID0gT2JqZWN0LmRlZmluZVByb3BlcnR5Owp2YXIgeXQgPSAoaSwgZSwgcikgPT4gZSBpbiBpID8gVHQoaSwgZSwgeyBlbnVtZXJhYmxlOiAhMCwgY29uZmlndXJhYmxlOiAhMCwgd3JpdGFibGU6ICEwLCB2YWx1ZTogciB9KSA6IGlbZV0gPSByOwp2YXIga2UgPSAoaSwgZSwgcikgPT4gKHl0KGksIHR5cGVvZiBlICE9ICJzeW1ib2wiID8gZSArICIiIDogZSwgciksIHIpLCBldCA9IChpLCBlLCByKSA9PiB7CiAgaWYgKCFlLmhhcyhpKSkKICAgIHRocm93IFR5cGVFcnJvcigiQ2Fubm90ICIgKyByKTsKfTsKdmFyIHQgPSAoaSwgZSwgcikgPT4gKGV0KGksIGUsICJyZWFkIGZyb20gcHJpdmF0ZSBmaWVsZCIpLCByID8gci5jYWxsKGkpIDogZS5nZXQoaSkpLCBmID0gKGksIGUsIHIpID0+IHsKICBpZiAoZS5oYXMoaSkpCiAgICB0aHJvdyBUeXBlRXJyb3IoIkNhbm5vdCBhZGQgdGhlIHNhbWUgcHJpdmF0ZSBtZW1iZXIgbW9yZSB0aGFuIG9uY2UiKTsKICBlIGluc3RhbmNlb2YgV2Vha1NldCA/IGUuYWRkKGkpIDogZS5zZXQoaSwgcik7Cn0sIGwgPSAoaSwgZSwgciwgcykgPT4gKGV0KGksIGUsICJ3cml0ZSB0byBwcml2YXRlIGZpZWxkIiksIHMgPyBzLmNhbGwoaSwgcikgOiBlLnNldChpLCByKSwgcik7CnZhciBTID0gKGksIGUsIHIpID0+IChldChpLCBlLCAiYWNjZXNzIHByaXZhdGUgbWV0aG9kIiksIHIpOwpjb25zdCB2dCA9IHsKICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTkyLAogIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgcHJlc3N1cmVJdGVyYXRpb25zOiAxLAogIGN1cmw6IDFlLTQsCiAgc3BsYXRSYWRpdXM6IDRlLTMsCiAgc3BsYXRGb3JjZTogMC45MSwKICByZWZyYWN0aW9uOiAwLjI1LAogIHNwZWN1bGFyRXhwOiAxLjAxLAogIHNoaW5lOiAwLjAxLAogIHdhdGVyQ29sb3I6ICIjMDAwMDAwIiwKICBnbG93Q29sb3I6ICIjYjNkOWZmIiwKICBhbGdvcml0aG06ICJzdGFuZGFyZCIsCiAgd2FycFN0cmVuZ3RoOiAwLjAxNQp9OwooewogIC4uLnZ0Cn0pOwpjb25zdCBTdCA9IHsKICBjYWxtOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk5LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45OCwKICAgIGN1cmw6IDFlLTQsCiAgICBzcGxhdFJhZGl1czogM2UtMywKICAgIHNwbGF0Rm9yY2U6IDAuNSwKICAgIHJlZnJhY3Rpb246IDAuMTUsCiAgICBzaGluZTogNWUtMywKICAgIGdsb3dDb2xvcjogIiM5OWQ5ZmYiLAogICAgd2F0ZXJDb2xvcjogIiMwMDA1MGQiCiAgfSwKICBzYW5kOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk3LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45OCwKICAgIGN1cmw6IDEsCiAgICBzcGxhdFJhZGl1czogMC4wMSwKICAgIHNwbGF0Rm9yY2U6IDAuOSwKICAgIHJlZnJhY3Rpb246IDAuOCwKICAgIHNwZWN1bGFyRXhwOiAwLjEsCiAgICBzaGluZTogMC4wNSwKICAgIGdsb3dDb2xvcjogIiMwNzA3MDciLAogICAgd2F0ZXJDb2xvcjogIiM3MzU0MjAiCiAgfSwKICB3YXZlOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk0LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45MiwKICAgIGN1cmw6IDAuMiwKICAgIHNwbGF0UmFkaXVzOiA1ZS0zLAogICAgc3BsYXRGb3JjZTogMS4yLAogICAgcmVmcmFjdGlvbjogMC4zNSwKICAgIHNoaW5lOiAwLjAzLAogICAgZ2xvd0NvbG9yOiAiIzgwY2NmZiIsCiAgICB3YXRlckNvbG9yOiAiIzAwMDMwOCIKICB9LAogIG5lb246IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45ODUsCiAgICB2ZWxvY2l0eURpc3NpcGF0aW9uOiAwLjkzLAogICAgY3VybDogMC4wNSwKICAgIHNwbGF0UmFkaXVzOiA4ZS0zLAogICAgc3BsYXRGb3JjZTogMS41LAogICAgcmVmcmFjdGlvbjogMC4yNSwKICAgIHNwZWN1bGFyRXhwOiAwLjUsCiAgICBzaGluZTogMC4xNCwKICAgIGdsb3dDb2xvcjogIiNmZjMzY2MiLAogICAgd2F0ZXJDb2xvcjogIiMwZDAwMTQiCiAgfSwKICBzbW9rZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NiwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTcsCiAgICBjdXJsOiAwLjA0LAogICAgc3BsYXRSYWRpdXM6IDllLTMsCiAgICBzcGxhdEZvcmNlOiAwLjgsCiAgICByZWZyYWN0aW9uOiAwLjA4LAogICAgc2hpbmU6IDAsCiAgICBnbG93Q29sb3I6ICIjODA4MDgwIiwKICAgIHdhdGVyQ29sb3I6ICIjMGYwZjBmIgogIH0KfTsKZnVuY3Rpb24gV2UoaSkgewogIGlmIChBcnJheS5pc0FycmF5KGkpKQogICAgcmV0dXJuIGk7CiAgY29uc3QgZSA9IGkuc2xpY2UoMSwgNyk7CiAgcmV0dXJuIGUubGVuZ3RoID09PSAzID8gWwogICAgcGFyc2VJbnQoZVswXSArIGVbMF0sIDE2KSAvIDI1NSwKICAgIHBhcnNlSW50KGVbMV0gKyBlWzFdLCAxNikgLyAyNTUsCiAgICBwYXJzZUludChlWzJdICsgZVsyXSwgMTYpIC8gMjU1CiAgXSA6IFsKICAgIHBhcnNlSW50KGUuc2xpY2UoMCwgMiksIDE2KSAvIDI1NSwKICAgIHBhcnNlSW50KGUuc2xpY2UoMiwgNCksIDE2KSAvIDI1NSwKICAgIHBhcnNlSW50KGUuc2xpY2UoNCwgNiksIDE2KSAvIDI1NQogIF07Cn0KZnVuY3Rpb24gd3QoaSA9IHt9LCBlLCByID0gdnQpIHsKICByZXR1cm4geyAuLi5lID8geyAuLi5yLCAuLi5TdFtlXSB9IDogciwgLi4uaSB9Owp9CmNvbnN0IHJlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIGF0dHJpYnV0ZSB2ZWMyIGFQb3NpdGlvbjsKICB2YXJ5aW5nIHZlYzIgdlV2OwogIHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHZlYzIgdGV4ZWxTaXplOwogIHZvaWQgbWFpbiAoKSB7CiAgICB2VXYgPSBhUG9zaXRpb24gKiAwLjUgKyAwLjU7CiAgICB2TCA9IHZVdiAtIHZlYzIodGV4ZWxTaXplLngsIDAuMCk7CiAgICB2UiA9IHZVdiArIHZlYzIodGV4ZWxTaXplLngsIDAuMCk7CiAgICB2VCA9IHZVdiArIHZlYzIoMC4wLCB0ZXhlbFNpemUueSk7CiAgICB2QiA9IHZVdiAtIHZlYzIoMC4wLCB0ZXhlbFNpemUueSk7CiAgICBnbF9Qb3NpdGlvbiA9IHZlYzQoYVBvc2l0aW9uLCAwLjAsIDEuMCk7CiAgfQpgCiksIFJ0ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVTb3VyY2U7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHVuaWZvcm0gdmVjMiB0ZXhlbFNpemU7CiAgdW5pZm9ybSBmbG9hdCBkdDsKICB1bmlmb3JtIGZsb2F0IGRpc3NpcGF0aW9uOwogIHZvaWQgbWFpbiAoKSB7CiAgICBpZiAodGV4dHVyZTJEKHVPYnN0YWNsZSwgdlV2KS5yID4gMC41KSB7IGdsX0ZyYWdDb2xvciA9IHZlYzQoMC4wKTsgcmV0dXJuOyB9CiAgICB2ZWMyIGNvb3JkID0gdlV2IC0gZHQgKiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5ICogdGV4ZWxTaXplOwogICAgZ2xfRnJhZ0NvbG9yID0gZGlzc2lwYXRpb24gKiB0ZXh0dXJlMkQodVNvdXJjZSwgY29vcmQpOwogIH0KYAopLCBFdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZMKS5yID4gMC41ID8gMC4wIDogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkwpLng7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlIpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2UikueDsKICAgIGZsb2F0IFQgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VCkuciA+IDAuNSA/IDAuMCA6IHRleHR1cmUyRCh1VmVsb2NpdHksIHZUKS55OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZCKS5yID4gMC41ID8gMC4wIDogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkIpLnk7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuNSAqIChSIC0gTCArIFQgLSBCKSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIFV0ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1UHJlc3N1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdURpdmVyZ2VuY2U7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBDID0gdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlV2KS54OwogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZMKS5yID4gMC41ID8gQyA6IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZSKS5yID4gMC41ID8gQyA6IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZUKS5yID4gMC41ID8gQyA6IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZUKS54OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZCKS5yID4gMC41ID8gQyA6IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZCKS54OwogICAgZmxvYXQgZGl2ID0gdGV4dHVyZTJEKHVEaXZlcmdlbmNlLCB2VXYpLng7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KChMICsgUiArIEIgKyBUIC0gZGl2KSAqIDAuMjUsIDAuMCwgMC4wLCAxLjApOwogIH0KYAopLCBEdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OyB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVByZXNzdXJlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdm9pZCBtYWluICgpIHsKICAgIGlmICh0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VXYpLnIgPiAwLjUpIHsgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjApOyByZXR1cm47IH0KICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2TCkueDsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2UikueDsKICAgIGZsb2F0IFQgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2VCkueDsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2QikueDsKICAgIHZlYzIgdmVsID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSAtIHZlYzIoUiAtIEwsIFQgLSBCKTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQodmVsLCAwLjAsIDEuMCk7CiAgfQpgCiksIF90ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVRhcmdldDsKICB1bmlmb3JtIGZsb2F0IGFzcGVjdFJhdGlvOwogIHVuaWZvcm0gdmVjMyBjb2xvcjsKICB1bmlmb3JtIHZlYzIgcG9pbnQ7CiAgdW5pZm9ybSBmbG9hdCByYWRpdXM7CiAgdm9pZCBtYWluICgpIHsKICAgIHZlYzIgcCA9IHZVdiAtIHBvaW50Lnh5OwogICAgcC54ICo9IGFzcGVjdFJhdGlvOwogICAgdmVjMyBzcGxhdCA9IGV4cCgtZG90KHAsIHApIC8gcmFkaXVzKSAqIGNvbG9yOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCh0ZXh0dXJlMkQodVRhcmdldCwgdlV2KS54eXogKyBzcGxhdCwgMS4wKTsKICB9CmAKKSwgQ3QgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZMKS55OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZSKS55OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZUKS54OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZCKS54OwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjUgKiAoUiAtIEwgLSBUICsgQiksIDAuMCwgMC4wLCAxLjApOwogIH0KYAopLCBCdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OyB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVDdXJsOwogIHVuaWZvcm0gZmxvYXQgY3VybDsKICB1bmlmb3JtIGZsb2F0IGR0OwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVDdXJsLCB2TCkueDsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodUN1cmwsIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1Q3VybCwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVDdXJsLCB2QikueDsKICAgIGZsb2F0IEMgPSB0ZXh0dXJlMkQodUN1cmwsIHZVdikueDsKICAgIHZlYzIgZm9yY2UgPSAwLjUgKiB2ZWMyKGFicyhUKSAtIGFicyhCKSwgYWJzKFIpIC0gYWJzKEwpKTsKICAgIGZvcmNlIC89IGxlbmd0aChmb3JjZSkgKyAwLjAwMDE7CiAgICBmb3JjZSAqPSBjdXJsICogMzAuMCAqIEM7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHkgKyBmb3JjZSAqIGR0LCAwLjAsIDEuMCk7CiAgfQpgCiksIFZ0ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7CgogIHVuaWZvcm0gc2FtcGxlcjJEIHVUZXh0dXJlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1QmFja2dyb3VuZDsKICB1bmlmb3JtIHNhbXBsZXIyRCB1Q292ZXJhZ2U7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwoKICB1bmlmb3JtIHZlYzIgIHRleGVsU2l6ZTsKICB1bmlmb3JtIHZlYzMgIHVXYXRlckNvbG9yOwogIHVuaWZvcm0gdmVjMyAgdUdsb3dDb2xvcjsKICB1bmlmb3JtIGZsb2F0IHVSZWZyYWN0aW9uOwogIHVuaWZvcm0gZmxvYXQgdVNwZWN1bGFyRXhwOwogIHVuaWZvcm0gZmxvYXQgdVNoaW5lOwogIHVuaWZvcm0gZmxvYXQgdVdhcnBTdHJlbmd0aDsKICB1bmlmb3JtIGludCAgIHVBbGdvcml0aG07CiAgdW5pZm9ybSBpbnQgICB1RW5hYmxlQWxwaGE7CgogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBvYnMgICAgICA9IHRleHR1cmUyRCh1T2JzdGFjbGUsICB2VXYpLnI7CiAgICAvLyBNYXNrIGRlbnNpdHkgaW5zaWRlIG9ic3RhY2xlcyBzbyBzcGxhdHMgZG9uJ3QgZmxpY2tlciB0aGUgdGV4dC9pbWFnZSBjb250ZW50LgogICAgZmxvYXQgZGVuc2l0eSAgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYpLnIsIDAuMCkgKiAoMS4wIC0gc3RlcCgwLjUsIG9icykpOwogICAgZmxvYXQgY292ZXJhZ2UgPSB0ZXh0dXJlMkQodUNvdmVyYWdlLCAgdlV2KS5yOwoKICAgIGZsb2F0IGRMID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2IC0gdmVjMih0ZXhlbFNpemUueCAqIDIuMCwgMC4wKSkuciwgMC4wKTsKICAgIGZsb2F0IGRSID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2ICsgdmVjMih0ZXhlbFNpemUueCAqIDIuMCwgMC4wKSkuciwgMC4wKTsKICAgIGZsb2F0IGRUID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2ICsgdmVjMigwLjAsIHRleGVsU2l6ZS55ICogMi4wKSkuciwgMC4wKTsKICAgIGZsb2F0IGRCID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2IC0gdmVjMigwLjAsIHRleGVsU2l6ZS55ICogMi4wKSkuciwgMC4wKTsKCiAgICB2ZWMzICBub3JtYWwgICA9IG5vcm1hbGl6ZSh2ZWMzKGRMIC0gZFIsIGRCIC0gZFQsIDAuMikpOwogICAgdmVjMyAgbGlnaHREaXIgPSBub3JtYWxpemUodmVjMygwLjUsIDEuMCwgMC41KSk7CiAgICB2ZWMzICBoYWxmViAgICA9IG5vcm1hbGl6ZShsaWdodERpciArIHZlYzMoMC4wLCAwLjAsIDEuMCkpOwogICAgZmxvYXQgc3BlYyAgICAgPSBwb3cobWF4KGRvdChub3JtYWwsIGhhbGZWKSwgMC4wKSwgdVNwZWN1bGFyRXhwKSAqIHVTaGluZSAqIGRlbnNpdHk7CgogICAgLy8gSW4gdHJhbnNwYXJlbnQgKG5vbi1jb3ZlcmFnZSkgYXJlYXMgdGhlIGJhY2tncm91bmQgdGV4dHVyZSBpcyBlbXB0eSBibGFjayBjYW52YXMuCiAgICAvLyBSZXBsYWNlIGl0IHdpdGggdVdhdGVyQ29sb3Igc28gZmx1aWQgY29sb3VyIGlzIG5vdCBjb250YW1pbmF0ZWQgYnkgdGhhdCBibGFjaywKICAgIC8vIGFsbG93aW5nIHRoZSBDU1MgYmFja2dyb3VuZENvbG9yIHRvIHNob3cgdGhyb3VnaCBjb3JyZWN0bHkgdmlhIHByZW11bHRpcGxpZWQgYWxwaGEuCiAgICB2ZWMzIGJnUmF3ID0gdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCB2VXYpLnJnYjsKICAgIHZlYzMgYmcgICAgPSBtaXgodVdhdGVyQ29sb3IsIGJnUmF3LCBjb3ZlcmFnZSk7CiAgICB2ZWMzIGNvbG9yID0gYmc7CgogICAgaWYgKHVBbGdvcml0aG0gPT0gMSkgewogICAgICAvLyDilIDilIAgZ2xhc3Mg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIFN0cm9uZyBVViBkaXN0b3J0aW9uIG9ubHkuIEltYWdlIGJlbmRzIGJ1dCBubyBjb2xvdXIgb3ZlcmxheS4KICAgICAgdmVjMiByZWZyVXYgPSBjbGFtcCh2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHkgKiAzLjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMyByZWZyQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmVmclV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgPSByZWZyQmcgKyBzcGVjICogdUdsb3dDb2xvciAqIDIuNTsKICAgICAgY29sb3IgPSBtaXgoY29sb3IsIGJnICogMC42LCBvYnMgKiAwLjMpOwoKICAgIH0gZWxzZSBpZiAodUFsZ29yaXRobSA9PSAyKSB7CiAgICAgIC8vIOKUgOKUgCBpbmsg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIERlbnNlIG9wYXF1ZSBwaWdtZW50IHRoYXQgc3RhaW5zLiBTdWJ0bGUgcmVmcmFjdGlvbiB1bmRlcm5lYXRoLgogICAgICBmbG9hdCBpbmtEICA9IG1pbihkZW5zaXR5ICogNC4wLCAxLjApOwogICAgICB2ZWMyIHJlZnJVdiA9IGNsYW1wKHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eSAqIDAuNCwgMC4wLCAxLjApOwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciA9IG1peChyZWZyQmcsIHVXYXRlckNvbG9yICsgc3BlYyAqIHVHbG93Q29sb3IsIGlua0QpOwogICAgICBjb2xvciA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMTUpOwoKICAgIH0gZWxzZSBpZiAodUFsZ29yaXRobSA9PSAzKSB7CiAgICAgIC8vIOKUgOKUgCBhdXJvcmEg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIFZlbG9jaXR5IGZpZWxkIHdhcnBzIGJhY2tncm91bmQgVVZzIOKAlCBsaXF1aWQgbWV0YWwgLyBsYXZhLWxhbXAgZmVlbC4KICAgICAgdmVjMiAgdmVsICAgID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eTsKICAgICAgZmxvYXQgdmVsTWFnID0gY2xhbXAobGVuZ3RoKHZlbCkgKiAyMC4wLCAwLjAsIDEuMCk7CiAgICAgIHZlYzIgIHdhcnBVdiA9IGNsYW1wKHZVdiArIHZlbCAqIHVXYXJwU3RyZW5ndGgsIDAuMCwgMS4wKTsKICAgICAgdmVjMyAgd2FycEJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIHdhcnBVdikucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yICA9IG1peChiZywgd2FycEJnLCB2ZWxNYWcgKiAoMS4wIC0gb2JzKSk7CiAgICAgIGNvbG9yICs9IHNwZWMgKiB1R2xvd0NvbG9yICogdmVsTWFnICogMS41OwogICAgICBjb2xvciArPSB1V2F0ZXJDb2xvciAqIGRlbnNpdHkgKiAwLjM7CiAgICAgIGNvbG9yICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMik7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDQpIHsKICAgICAgLy8g4pSA4pSAIHJpcHBsZSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gRXhhZ2dlcmF0ZWQgbm9ybWFsIHBlcnR1cmJhdGlvbiArIEZyZXNuZWwgcmltIOKAlCBjYWxtIHdhdGVyIHN1cmZhY2UuCiAgICAgIHZlYzIgIHJpcHBsZVV2ID0gY2xhbXAodlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5ICogNi4wLCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgIHJlZnJCZyAgID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJpcHBsZVV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgZmxvYXQgZnJlc25lbCAgPSBwb3coY2xhbXAoMS4wIC0gZG90KG5vcm1hbCwgdmVjMygwLjAsIDAuMCwgMS4wKSksIDAuMCwgMS4wKSwgMy4wKSAqIGRlbnNpdHk7CiAgICAgIGNvbG9yICA9IHJlZnJCZzsKICAgICAgY29sb3IgKz0gZnJlc25lbCAqIHVHbG93Q29sb3IgKiAyLjA7CiAgICAgIGNvbG9yICs9IHNwZWMgKiB1R2xvd0NvbG9yICogZGVuc2l0eSAqIDIuMDsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKCiAgICB9IGVsc2UgewogICAgICAvLyDilIDilIAgc3RhbmRhcmQgKDApIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBPcmlnaW5hbDogY29sb3VyIG92ZXJsYXkgYmxlbmRlZCBvdmVyIHJlZnJhY3RlZCBiYWNrZ3JvdW5kLgogICAgICB2ZWMyIHJlZnJVdiA9IHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eTsKICAgICAgdmVjMyByZWZyQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmVmclV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgID0gbWl4KHJlZnJCZywgdVdhdGVyQ29sb3IsIG1pbihkZW5zaXR5ICogMS41LCAwLjgpKTsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3I7CiAgICAgIGNvbG9yICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMik7CiAgICB9CgogICAgLy8gT3V0cHV0OiBwcmVtdWx0aXBsaWVkIGFscGhhIHdoZW4gdHJhbnNwYXJlbmN5IGlzIGVuYWJsZWQgKGxldHMgQ1NTIGJhY2tncm91bmRDb2xvcgogICAgLy8gc2hvdyB0aHJvdWdoKSwgb3Igc3RyYWlnaHQgb3BhcXVlIGNvbG91ciB3aGVuIGVuYWJsZUFscGhhIGlzIG9mZiAocGVyZiBtb2RlKS4KICAgIGZsb2F0IGFscGhhID0gY2xhbXAobWF4KGRlbnNpdHkgKiAxLjUsIGNvdmVyYWdlKSwgMC4wLCAxLjApOwogICAgaWYgKHVFbmFibGVBbHBoYSA9PSAxKSB7CiAgICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoY29sb3IgKiBhbHBoYSwgYWxwaGEpOwogICAgfSBlbHNlIHsKICAgICAgZ2xfRnJhZ0NvbG9yID0gdmVjNChjb2xvciwgMS4wKTsKICAgIH0KICB9CmAKKTsKZnVuY3Rpb24gT3QoaSwgZSA9ICEwKSB7CiAgY29uc3QgciA9IHsgYWxwaGE6IGUsIGRlcHRoOiAhMSwgc3RlbmNpbDogITEsIGFudGlhbGlhczogITAsIHByZXNlcnZlRHJhd2luZ0J1ZmZlcjogITEgfTsKICBsZXQgcyA9IGkuZ2V0Q29udGV4dCgid2ViZ2wyIiwgcik7CiAgY29uc3QgbyA9ICEhczsKICBvIHx8IChzID0gaS5nZXRDb250ZXh0KCJ3ZWJnbCIsIHIpLCBzLmdldEV4dGVuc2lvbigiRVhUX2NvbG9yX2J1ZmZlcl9oYWxmX2Zsb2F0IikpOwogIGNvbnN0IGEgPSBvID8gbnVsbCA6IHMuZ2V0RXh0ZW5zaW9uKCJPRVNfdGV4dHVyZV9oYWxmX2Zsb2F0IiksIHUgPSBvID8gcy5IQUxGX0ZMT0FUIDogYS5IQUxGX0ZMT0FUX09FUzsKICByZXR1cm4gcy5nZXRFeHRlbnNpb24oIkVYVF9jb2xvcl9idWZmZXJfZmxvYXQiKSwgcy5nZXRFeHRlbnNpb24oIk9FU190ZXh0dXJlX2hhbGZfZmxvYXRfbGluZWFyIiksIHsKICAgIHR5cGU6IG8gPyAid2ViZ2wyIiA6ICJ3ZWJnbDEiLAogICAgZ2w6IHMsCiAgICBpc1dlYkdMMjogbywKICAgIGV4dDogewogICAgICBpbnRlcm5hbEZvcm1hdDogbyA/IHMuUkdCQTE2RiA6IHMuUkdCQSwKICAgICAgZm9ybWF0OiBzLlJHQkEsCiAgICAgIHR5cGU6IHUKICAgIH0KICB9Owp9CmFzeW5jIGZ1bmN0aW9uIEZ0KGksIGUgPSAhMCkgewogIGlmICh0eXBlb2YgbmF2aWdhdG9yID4gInUiIHx8ICFuYXZpZ2F0b3IuZ3B1KQogICAgcmV0dXJuIG51bGw7CiAgdHJ5IHsKICAgIGNvbnN0IHIgPSBhd2FpdCBuYXZpZ2F0b3IuZ3B1LnJlcXVlc3RBZGFwdGVyKCk7CiAgICBpZiAoIXIpCiAgICAgIHJldHVybiBudWxsOwogICAgY29uc3QgcyA9IGF3YWl0IHIucmVxdWVzdERldmljZSgpLCBvID0gaS5nZXRDb250ZXh0KCJ3ZWJncHUiKTsKICAgIGlmICghbykKICAgICAgcmV0dXJuIG51bGw7CiAgICBjb25zdCBhID0gbmF2aWdhdG9yLmdwdS5nZXRQcmVmZXJyZWRDYW52YXNGb3JtYXQoKTsKICAgIHJldHVybiBvLmNvbmZpZ3VyZSh7IGRldmljZTogcywgZm9ybWF0OiBhLCBhbHBoYU1vZGU6IGUgPyAicHJlbXVsdGlwbGllZCIgOiAib3BhcXVlIiB9KSwgeyB0eXBlOiAid2ViZ3B1IiwgYWRhcHRlcjogciwgZGV2aWNlOiBzLCBjb250ZXh0OiBvLCBmb3JtYXQ6IGEgfTsKICB9IGNhdGNoIHsKICAgIHJldHVybiBudWxsOwogIH0KfQpjbGFzcyBpZSB7CiAgY29uc3RydWN0b3IoZSwgciwgcykgewogICAga2UodGhpcywgInByb2dyYW0iKTsKICAgIGtlKHRoaXMsICJ1bmlmb3JtcyIsIHt9KTsKICAgIGtlKHRoaXMsICJfZ2wiKTsKICAgIHRoaXMuX2dsID0gZSwgdGhpcy5wcm9ncmFtID0gZS5jcmVhdGVQcm9ncmFtKCksIGUuYXR0YWNoU2hhZGVyKHRoaXMucHJvZ3JhbSwgdGhpcy5fY29tcGlsZShlLlZFUlRFWF9TSEFERVIsIHIpKSwgZS5hdHRhY2hTaGFkZXIodGhpcy5wcm9ncmFtLCB0aGlzLl9jb21waWxlKGUuRlJBR01FTlRfU0hBREVSLCBzKSksIGUubGlua1Byb2dyYW0odGhpcy5wcm9ncmFtKTsKICAgIGNvbnN0IG8gPSBlLmdldFByb2dyYW1QYXJhbWV0ZXIodGhpcy5wcm9ncmFtLCBlLkFDVElWRV9VTklGT1JNUyk7CiAgICBmb3IgKGxldCBhID0gMDsgYSA8IG87IGErKykgewogICAgICBjb25zdCB1ID0gZS5nZXRBY3RpdmVVbmlmb3JtKHRoaXMucHJvZ3JhbSwgYSkubmFtZTsKICAgICAgdGhpcy51bmlmb3Jtc1t1XSA9IGUuZ2V0VW5pZm9ybUxvY2F0aW9uKHRoaXMucHJvZ3JhbSwgdSk7CiAgICB9CiAgfQogIF9jb21waWxlKGUsIHIpIHsKICAgIGNvbnN0IHMgPSB0aGlzLl9nbCwgbyA9IHMuY3JlYXRlU2hhZGVyKGUpOwogICAgcmV0dXJuIHMuc2hhZGVyU291cmNlKG8sIHIpLCBzLmNvbXBpbGVTaGFkZXIobyksIG87CiAgfQogIGJpbmQoKSB7CiAgICB0aGlzLl9nbC51c2VQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQogIGRpc3Bvc2UoKSB7CiAgICB0aGlzLl9nbC5kZWxldGVQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQp9CmZ1bmN0aW9uIFB0KGkpIHsKICByZXR1cm4gewogICAgYWR2ZWN0aW9uOiBuZXcgaWUoaSwgcmUsIFJ0KSwKICAgIGRpdmVyZ2VuY2U6IG5ldyBpZShpLCByZSwgRXQpLAogICAgcHJlc3N1cmU6IG5ldyBpZShpLCByZSwgVXQpLAogICAgZ3JhZGllbnRTdWJ0cmFjdDogbmV3IGllKGksIHJlLCBEdCksCiAgICBzcGxhdDogbmV3IGllKGksIHJlLCBfdCksCiAgICBjdXJsOiBuZXcgaWUoaSwgcmUsIEN0KSwKICAgIHZvcnRpY2l0eTogbmV3IGllKGksIHJlLCBCdCksCiAgICBkaXNwbGF5OiBuZXcgaWUoaSwgcmUsIFZ0KQogIH07Cn0KZnVuY3Rpb24gcWUoaSwgZSwgciwgcykgewogIGkuYWN0aXZlVGV4dHVyZShpLlRFWFRVUkUwKTsKICBjb25zdCBvID0gaS5jcmVhdGVUZXh0dXJlKCk7CiAgaS5iaW5kVGV4dHVyZShpLlRFWFRVUkVfMkQsIG8pLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUlOX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUFHX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9TLCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9ULCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleEltYWdlMkQoaS5URVhUVVJFXzJELCAwLCBlLmludGVybmFsRm9ybWF0LCByLCBzLCAwLCBlLmZvcm1hdCwgZS50eXBlLCBudWxsKTsKICBjb25zdCBhID0gaS5jcmVhdGVGcmFtZWJ1ZmZlcigpOwogIHJldHVybiBpLmJpbmRGcmFtZWJ1ZmZlcihpLkZSQU1FQlVGRkVSLCBhKSwgaS5mcmFtZWJ1ZmZlclRleHR1cmUyRChpLkZSQU1FQlVGRkVSLCBpLkNPTE9SX0FUVEFDSE1FTlQwLCBpLlRFWFRVUkVfMkQsIG8sIDApLCB7IHRleDogbywgZmJvOiBhLCB3aWR0aDogciwgaGVpZ2h0OiBzIH07Cn0KZnVuY3Rpb24gdHQoaSwgZSwgciwgcykgewogIGxldCBvID0gcWUoaSwgZSwgciwgcyksIGEgPSBxZShpLCBlLCByLCBzKTsKICByZXR1cm4gewogICAgZ2V0IHJlYWQoKSB7CiAgICAgIHJldHVybiBvOwogICAgfSwKICAgIGdldCB3cml0ZSgpIHsKICAgICAgcmV0dXJuIGE7CiAgICB9LAogICAgc3dhcCgpIHsKICAgICAgW28sIGFdID0gW2EsIG9dOwogICAgfSwKICAgIGRpc3Bvc2UoKSB7CiAgICAgIGkuZGVsZXRlVGV4dHVyZShvLnRleCksIGkuZGVsZXRlRnJhbWVidWZmZXIoby5mYm8pLCBpLmRlbGV0ZVRleHR1cmUoYS50ZXgpLCBpLmRlbGV0ZUZyYW1lYnVmZmVyKGEuZmJvKTsKICAgIH0KICB9Owp9CmZ1bmN0aW9uIEx0KGkpIHsKICBjb25zdCBlID0gaS5jcmVhdGVCdWZmZXIoKTsKICByZXR1cm4gaS5iaW5kQnVmZmVyKGkuQVJSQVlfQlVGRkVSLCBlKSwgaS5idWZmZXJEYXRhKGkuQVJSQVlfQlVGRkVSLCBuZXcgRmxvYXQzMkFycmF5KFstMSwgLTEsIC0xLCAxLCAxLCAxLCAxLCAtMV0pLCBpLlNUQVRJQ19EUkFXKSwgaS52ZXJ0ZXhBdHRyaWJQb2ludGVyKDAsIDIsIGkuRkxPQVQsICExLCAwLCAwKSwgaS5lbmFibGVWZXJ0ZXhBdHRyaWJBcnJheSgwKSwgZnVuY3Rpb24ocykgewogICAgaS5iaW5kRnJhbWVidWZmZXIoaS5GUkFNRUJVRkZFUiwgcyksIGkuZHJhd0FycmF5cyhpLlRSSUFOR0xFX0ZBTiwgMCwgNCk7CiAgfTsKfQpjb25zdCBsZSA9ICgKICAvKiB3Z3NsICovCiAgYApzdHJ1Y3QgVlNPdXQgewogIEBidWlsdGluKHBvc2l0aW9uKSBwb3MgOiB2ZWM0ZiwKICBAbG9jYXRpb24oMCkgICAgICAgdXYgIDogdmVjMmYsCiAgQGxvY2F0aW9uKDEpICAgICAgIHZMICA6IHZlYzJmLAogIEBsb2NhdGlvbigyKSAgICAgICB2UiAgOiB2ZWMyZiwKICBAbG9jYXRpb24oMykgICAgICAgdlQgIDogdmVjMmYsCiAgQGxvY2F0aW9uKDQpICAgICAgIHZCICA6IHZlYzJmLAp9YAopLCBBdCA9ICgKICAvKiB3Z3NsICovCiAgYAoke2xlfQoKc3RydWN0IFUgewogIHRleGVsU2l6ZSAgOiB2ZWMyZiwKICBkdCAgICAgICAgIDogZjMyLAogIGRpc3NpcGF0aW9uOiBmMzIsCn0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVWZWwgIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoMykgdmFyICAgICAgICAgIHVTcmMgIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoNCkgdmFyICAgICAgICAgIHVPYnMgIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICAvLyBTYW1wbGUgYWxsIHRleHR1cmVzIGJlZm9yZSBicmFuY2hpbmcg4oCUIHRleHR1cmVTYW1wbGUgcmVxdWlyZXMgdW5pZm9ybSBjb250cm9sIGZsb3cKICBsZXQgb2JzICAgPSB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudXYpLnI7CiAgbGV0IHZlbCAgID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnV2KS54eTsKICBsZXQgY29vcmQgPSBpLnV2IC0gdS5kdCAqIHZlbCAqIHUudGV4ZWxTaXplOwogIGxldCBzcmMgICA9IHRleHR1cmVTYW1wbGUodVNyYywgc2FtcCwgY29vcmQpOwogIGlmIChvYnMgPiAwLjUpIHsgcmV0dXJuIHZlYzRmKDAuMCk7IH0KICByZXR1cm4gdS5kaXNzaXBhdGlvbiAqIHNyYzsKfQpgCiksIHp0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7IHRleGVsU2l6ZTogdmVjMmYsIF9wYWQ6IHZlYzJmIH0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgIDogVTsKQGdyb3VwKDApIEBiaW5kaW5nKDEpIHZhciAgICAgICAgICBzYW1wIDogc2FtcGxlcjsKQGdyb3VwKDApIEBiaW5kaW5nKDIpIHZhciAgICAgICAgICB1VmVsIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoMykgdmFyICAgICAgICAgIHVPYnMgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIGxldCBMID0gc2VsZWN0KHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52TCkueCwgMC4wLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkwpLnIgPiAwLjUpOwogIGxldCBSID0gc2VsZWN0KHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52UikueCwgMC4wLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlIpLnIgPiAwLjUpOwogIGxldCBUID0gc2VsZWN0KHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52VCkueSwgMC4wLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlQpLnIgPiAwLjUpOwogIGxldCBCID0gc2VsZWN0KHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52QikueSwgMC4wLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkIpLnIgPiAwLjUpOwogIHJldHVybiB2ZWM0ZigwLjUgKiAoUiAtIEwgKyBUIC0gQiksIDAuMCwgMC4wLCAxLjApOwp9CmAKKSwgWHQgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsgdGV4ZWxTaXplOiB2ZWMyZiwgX3BhZDogdmVjMmYgfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVQcmVzOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZygzKSB2YXIgICAgICAgICAgdURpdiA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDQpIHZhciAgICAgICAgICB1T2JzIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgQyAgPSB0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnV2KS54OwogIGxldCBMICA9IHNlbGVjdCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZMKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkwpLnIgPiAwLjUpOwogIGxldCBSICA9IHNlbGVjdCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZSKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlIpLnIgPiAwLjUpOwogIGxldCBUICA9IHNlbGVjdCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZUKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlQpLnIgPiAwLjUpOwogIGxldCBCICA9IHNlbGVjdCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZCKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkIpLnIgPiAwLjUpOwogIGxldCBkdiA9IHRleHR1cmVTYW1wbGUodURpdiwgc2FtcCwgaS51dikueDsKICByZXR1cm4gdmVjNGYoKEwgKyBSICsgQiArIFQgLSBkdikgKiAwLjI1LCAwLjAsIDAuMCwgMS4wKTsKfQpgCiksIE10ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7IHRleGVsU2l6ZTogdmVjMmYsIF9wYWQ6IHZlYzJmIH0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgIDogVTsKQGdyb3VwKDApIEBiaW5kaW5nKDEpIHZhciAgICAgICAgICBzYW1wIDogc2FtcGxlcjsKQGdyb3VwKDApIEBiaW5kaW5nKDIpIHZhciAgICAgICAgICB1UHJlczogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoMykgdmFyICAgICAgICAgIHVWZWwgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZyg0KSB2YXIgICAgICAgICAgdU9icyA6IHRleHR1cmVfMmQ8ZjMyPjsKCkB2ZXJ0ZXggZm4gdnMoQGxvY2F0aW9uKDApIGE6IHZlYzJmKSAtPiBWU091dCB7CiAgdmFyIG86IFZTT3V0OwogIG8udXYgPSB2ZWMyZihhLnggKiAwLjUgKyAwLjUsIDAuNSAtIGEueSAqIDAuNSk7CiAgby52TCA9IG8udXYgLSB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlIgPSBvLnV2ICsgdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZUID0gby51diArIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby52QiA9IG8udXYgLSB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8ucG9zID0gdmVjNGYoYSwgMC4wLCAxLjApOwogIHJldHVybiBvOwp9CgpAZnJhZ21lbnQgZm4gZnMoaTogVlNPdXQpIC0+IEBsb2NhdGlvbigwKSB2ZWM0ZiB7CiAgLy8gU2FtcGxlIGFsbCB0ZXh0dXJlcyBiZWZvcmUgYnJhbmNoaW5nIOKAlCB0ZXh0dXJlU2FtcGxlIHJlcXVpcmVzIHVuaWZvcm0gY29udHJvbCBmbG93CiAgbGV0IG9icyA9IHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS51dikucjsKICBsZXQgTCAgID0gdGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS52TCkueDsKICBsZXQgUiAgID0gdGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS52UikueDsKICBsZXQgVCAgID0gdGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS52VCkueDsKICBsZXQgQiAgID0gdGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS52QikueDsKICBsZXQgdmVsID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnV2KS54eSAtIHZlYzJmKFIgLSBMLCBUIC0gQik7CiAgaWYgKG9icyA+IDAuNSkgeyByZXR1cm4gdmVjNGYoMC4wKTsgfQogIHJldHVybiB2ZWM0Zih2ZWwsIDAuMCwgMS4wKTsKfQpgCiksIEd0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgovLyB0ZXhlbFNpemUgb2NjdXBpZXMgYnl0ZXMgMC03IGZvciB0aGUgc2hhcmVkIHZlcnRleCBzdGFnZTsgYXNwZWN0UmF0aW8vcmFkaXVzIGZpbGwgdGhlIHJlc3QuCnN0cnVjdCBVIHsKICB0ZXhlbFNpemUgIDogdmVjMmYsCiAgYXNwZWN0UmF0aW86IGYzMiwKICByYWRpdXMgICAgIDogZjMyLAogIGNvbG9yICAgICAgOiB2ZWM0ZiwgIC8vIHh5eiA9IGNvbG91ciwgdyB1bnVzZWQKICBwb2ludCAgICAgIDogdmVjMmYsCiAgX3BhZCAgICAgICA6IHZlYzJmLAp9CkBncm91cCgwKSBAYmluZGluZygwKSB2YXI8dW5pZm9ybT4gdSAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCA6IHNhbXBsZXI7CkBncm91cCgwKSBAYmluZGluZygyKSB2YXIgICAgICAgICAgdVRndCA6IHRleHR1cmVfMmQ8ZjMyPjsKCkB2ZXJ0ZXggZm4gdnMoQGxvY2F0aW9uKDApIGE6IHZlYzJmKSAtPiBWU091dCB7CiAgdmFyIG86IFZTT3V0OwogIG8udXYgPSB2ZWMyZihhLnggKiAwLjUgKyAwLjUsIDAuNSAtIGEueSAqIDAuNSk7CiAgby52TCA9IG8udXYgLSB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlIgPSBvLnV2ICsgdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZUID0gby51diArIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby52QiA9IG8udXYgLSB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8ucG9zID0gdmVjNGYoYSwgMC4wLCAxLjApOwogIHJldHVybiBvOwp9CgpAZnJhZ21lbnQgZm4gZnMoaTogVlNPdXQpIC0+IEBsb2NhdGlvbigwKSB2ZWM0ZiB7CiAgdmFyIHAgID0gaS51diAtIHUucG9pbnQ7CiAgcC54ICAgKj0gdS5hc3BlY3RSYXRpbzsKICBsZXQgc3AgPSBleHAoLWRvdChwLCBwKSAvIHUucmFkaXVzKSAqIHUuY29sb3IueHl6OwogIHJldHVybiB2ZWM0Zih0ZXh0dXJlU2FtcGxlKHVUZ3QsIHNhbXAsIGkudXYpLnh5eiArIHNwLCAxLjApOwp9CmAKKSwgSXQgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsgdGV4ZWxTaXplOiB2ZWMyZiwgX3BhZDogdmVjMmYgfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVWZWwgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIGxldCBMID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZMKS55OwogIGxldCBSID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZSKS55OwogIGxldCBUID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZUKS54OwogIGxldCBCID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZCKS54OwogIHJldHVybiB2ZWM0ZigwLjUgKiAoUiAtIEwgLSBUICsgQiksIDAuMCwgMC4wLCAxLjApOwp9CmAKKSwga3QgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsKICB0ZXhlbFNpemU6IHZlYzJmLAogIGN1cmwgICAgIDogZjMyLAogIGR0ICAgICAgIDogZjMyLAp9CkBncm91cCgwKSBAYmluZGluZygwKSB2YXI8dW5pZm9ybT4gdSAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCA6IHNhbXBsZXI7CkBncm91cCgwKSBAYmluZGluZygyKSB2YXIgICAgICAgICAgdVZlbCA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDMpIHZhciAgICAgICAgICB1Q3JsIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgTCAgICAgPSB0ZXh0dXJlU2FtcGxlKHVDcmwsIHNhbXAsIGkudkwpLng7CiAgbGV0IFIgICAgID0gdGV4dHVyZVNhbXBsZSh1Q3JsLCBzYW1wLCBpLnZSKS54OwogIGxldCBUICAgICA9IHRleHR1cmVTYW1wbGUodUNybCwgc2FtcCwgaS52VCkueDsKICBsZXQgQiAgICAgPSB0ZXh0dXJlU2FtcGxlKHVDcmwsIHNhbXAsIGkudkIpLng7CiAgbGV0IEMgICAgID0gdGV4dHVyZVNhbXBsZSh1Q3JsLCBzYW1wLCBpLnV2KS54OwogIHZhciBmb3JjZSA9IDAuNSAqIHZlYzJmKGFicyhUKSAtIGFicyhCKSwgYWJzKFIpIC0gYWJzKEwpKTsKICBmb3JjZSAgICAvPSBsZW5ndGgoZm9yY2UpICsgMC4wMDAxOwogIGZvcmNlICAgICo9IHUuY3VybCAqIDMwLjAgKiBDOwogIGxldCB2ZWwgICA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS51dikueHkgKyBmb3JjZSAqIHUuZHQ7CiAgcmV0dXJuIHZlYzRmKHZlbCwgMC4wLCAxLjApOwp9CmAKKSwgV3QgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsKICB0ZXhlbFNpemUgICA6IHZlYzJmLAogIHJlZnJhY3Rpb24gIDogZjMyLAogIHNwZWN1bGFyRXhwIDogZjMyLAogIHdhdGVyQ29sb3IgIDogdmVjNGYsCiAgZ2xvd0NvbG9yICAgOiB2ZWM0ZiwKICBzaGluZSAgICAgICA6IGYzMiwKICB3YXJwU3RyZW5ndGg6IGYzMiwKICBhbGdvcml0aG0gICA6IGkzMiwKICBlbmFibGVBbHBoYSA6IGkzMiwKfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVUZXggOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZygzKSB2YXIgICAgICAgICAgdU9icyA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDQpIHZhciAgICAgICAgICB1QmcgIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoNSkgdmFyICAgICAgICAgIHVDb3YgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZyg2KSB2YXIgICAgICAgICAgdVZlbCA6IHRleHR1cmVfMmQ8ZjMyPjsKCkB2ZXJ0ZXggZm4gdnMoQGxvY2F0aW9uKDApIGE6IHZlYzJmKSAtPiBWU091dCB7CiAgdmFyIG86IFZTT3V0OwogIG8udXYgPSB2ZWMyZihhLnggKiAwLjUgKyAwLjUsIDAuNSAtIGEueSAqIDAuNSk7CiAgby52TCA9IG8udXYgLSB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlIgPSBvLnV2ICsgdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZUID0gby51diArIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby52QiA9IG8udXYgLSB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8ucG9zID0gdmVjNGYoYSwgMC4wLCAxLjApOwogIHJldHVybiBvOwp9CgpAZnJhZ21lbnQgZm4gZnMoaTogVlNPdXQpIC0+IEBsb2NhdGlvbigwKSB2ZWM0ZiB7CiAgbGV0IG9icyAgICAgPSB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudXYpLnI7CiAgbGV0IGRlbnNpdHkgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2KS5yLCAwLjApICogKDEuMCAtIHN0ZXAoMC41LCBvYnMpKTsKICBsZXQgY292ICAgICA9IHRleHR1cmVTYW1wbGUodUNvdiwgc2FtcCwgaS51dikucjsKCiAgbGV0IHRzMiA9IHUudGV4ZWxTaXplICogMi4wOwogIGxldCBkTCAgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2IC0gdmVjMmYodHMyLngsIDAuMCkpLnIsIDAuMCk7CiAgbGV0IGRSICA9IG1heCh0ZXh0dXJlU2FtcGxlKHVUZXgsIHNhbXAsIGkudXYgKyB2ZWMyZih0czIueCwgMC4wKSkuciwgMC4wKTsKICBsZXQgZFQgID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKDAuMCwgdHMyLnkpKS5yLCAwLjApOwogIGxldCBkQiAgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2IC0gdmVjMmYoMC4wLCB0czIueSkpLnIsIDAuMCk7CgogIGxldCBub3JtICA9IG5vcm1hbGl6ZSh2ZWMzZihkTCAtIGRSLCBkQiAtIGRULCAwLjIpKTsKICBsZXQgbGRpciAgPSBub3JtYWxpemUodmVjM2YoMC41LCAxLjAsIDAuNSkpOwogIGxldCBoYWxmViA9IG5vcm1hbGl6ZShsZGlyICsgdmVjM2YoMC4wLCAwLjAsIDEuMCkpOwogIGxldCBzcGVjICA9IHBvdyhtYXgoZG90KG5vcm0sIGhhbGZWKSwgMC4wKSwgdS5zcGVjdWxhckV4cCkgKiB1LnNoaW5lICogZGVuc2l0eTsKCiAgbGV0IGJnUmF3ID0gdGV4dHVyZVNhbXBsZSh1QmcsIHNhbXAsIGkudXYpLnJnYjsKICBsZXQgd2MgICAgPSB1LndhdGVyQ29sb3IucmdiOwogIGxldCBnYyAgICA9IHUuZ2xvd0NvbG9yLnJnYjsKICBsZXQgYmcgICAgPSBtaXgod2MsIGJnUmF3LCBjb3YpOwogIHZhciBjb2xvciA9IGJnOwoKICBpZiAodS5hbGdvcml0aG0gPT0gMSkgewogICAgbGV0IHJ1diA9IGNsYW1wKGkudXYgKyBub3JtLnh5ICogdS5yZWZyYWN0aW9uICogZGVuc2l0eSAqIDMuMCwgdmVjMmYoMC4wKSwgdmVjMmYoMS4wKSk7CiAgICBsZXQgcmJnID0gbWl4KHdjLCB0ZXh0dXJlU2FtcGxlKHVCZywgc2FtcCwgbWl4KGkudXYsIHJ1diwgMS4wIC0gb2JzKSkucmdiLCBjb3YpOwogICAgY29sb3IgICA9IHJiZyArIHNwZWMgKiBnYyAqIDIuNTsKICAgIGNvbG9yICAgPSBtaXgoY29sb3IsIGJnICogMC42LCBvYnMgKiAwLjMpOwogIH0gZWxzZSBpZiAodS5hbGdvcml0aG0gPT0gMikgewogICAgbGV0IGlua0QgPSBtaW4oZGVuc2l0eSAqIDQuMCwgMS4wKTsKICAgIGxldCBydXYgID0gY2xhbXAoaS51diArIG5vcm0ueHkgKiB1LnJlZnJhY3Rpb24gKiBkZW5zaXR5ICogMC40LCB2ZWMyZigwLjApLCB2ZWMyZigxLjApKTsKICAgIGxldCByYmcgID0gbWl4KHdjLCB0ZXh0dXJlU2FtcGxlKHVCZywgc2FtcCwgbWl4KGkudXYsIHJ1diwgMS4wIC0gb2JzKSkucmdiLCBjb3YpOwogICAgY29sb3IgICAgPSBtaXgocmJnLCB3YyArIHNwZWMgKiBnYywgaW5rRCk7CiAgICBjb2xvciAgICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMTUpOwogIH0gZWxzZSBpZiAodS5hbGdvcml0aG0gPT0gMykgewogICAgbGV0IHZlbCAgICA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS51dikueHk7CiAgICBsZXQgdmVsTWFnID0gY2xhbXAobGVuZ3RoKHZlbCkgKiAyMC4wLCAwLjAsIDEuMCk7CiAgICBsZXQgd3V2ICAgID0gY2xhbXAoaS51diArIHZlbCAqIHUud2FycFN0cmVuZ3RoLCB2ZWMyZigwLjApLCB2ZWMyZigxLjApKTsKICAgIGxldCB3YmcgICAgPSBtaXgod2MsIHRleHR1cmVTYW1wbGUodUJnLCBzYW1wLCB3dXYpLnJnYiwgY292KTsKICAgIGNvbG9yICAgICAgPSBtaXgoYmcsIHdiZywgdmVsTWFnICogKDEuMCAtIG9icykpOwogICAgY29sb3IgICAgICs9IHNwZWMgKiBnYyAqIHZlbE1hZyAqIDEuNTsKICAgIGNvbG9yICAgICArPSB3YyAqIGRlbnNpdHkgKiAwLjM7CiAgICBjb2xvciAgICAgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICB9IGVsc2UgaWYgKHUuYWxnb3JpdGhtID09IDQpIHsKICAgIGxldCBydXYgICA9IGNsYW1wKGkudXYgKyBub3JtLnh5ICogdS5yZWZyYWN0aW9uICogZGVuc2l0eSAqIDYuMCwgdmVjMmYoMC4wKSwgdmVjMmYoMS4wKSk7CiAgICBsZXQgcmJnICAgPSBtaXgod2MsIHRleHR1cmVTYW1wbGUodUJnLCBzYW1wLCBtaXgoaS51diwgcnV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdik7CiAgICBsZXQgZnJlcyAgPSBwb3coY2xhbXAoMS4wIC0gZG90KG5vcm0sIHZlYzNmKDAuMCwgMC4wLCAxLjApKSwgMC4wLCAxLjApLCAzLjApICogZGVuc2l0eTsKICAgIGNvbG9yICAgICA9IHJiZzsKICAgIGNvbG9yICAgICs9IGZyZXMgKiBnYyAqIDIuMDsKICAgIGNvbG9yICAgICs9IHNwZWMgKiBnYyAqIGRlbnNpdHkgKiAyLjA7CiAgICBjb2xvciAgICAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwogIH0gZWxzZSB7CiAgICBsZXQgcnV2ID0gaS51diArIG5vcm0ueHkgKiB1LnJlZnJhY3Rpb24gKiBkZW5zaXR5OwogICAgbGV0IHJiZyA9IG1peCh3YywgdGV4dHVyZVNhbXBsZSh1QmcsIHNhbXAsIG1peChpLnV2LCBydXYsIDEuMCAtIG9icykpLnJnYiwgY292KTsKICAgIGNvbG9yICAgPSBtaXgocmJnLCB3YywgbWluKGRlbnNpdHkgKiAxLjUsIDAuOCkpOwogICAgY29sb3IgICs9IHNwZWMgKiBnYzsKICAgIGNvbG9yICAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwogIH0KCiAgbGV0IGFscGhhID0gY2xhbXAobWF4KGRlbnNpdHkgKiAxLjUsIGNvdiksIDAuMCwgMS4wKTsKICBpZiAodS5lbmFibGVBbHBoYSA9PSAxKSB7CiAgICByZXR1cm4gdmVjNGYoY29sb3IgKiBhbHBoYSwgYWxwaGEpOwogIH0KICByZXR1cm4gdmVjNGYoY29sb3IsIDEuMCk7Cn0KYAopLCBOdCA9IHsKICBhcnJheVN0cmlkZTogOCwKICBhdHRyaWJ1dGVzOiBbeyBzaGFkZXJMb2NhdGlvbjogMCwgb2Zmc2V0OiAwLCBmb3JtYXQ6ICJmbG9hdDMyeDIiIH1dCn0sIG50ID0gbmV3IEZsb2F0MzJBcnJheShbCiAgLTEsCiAgLTEsCiAgLTEsCiAgMSwKICAxLAogIC0xLAogIDEsCiAgLTEsCiAgLTEsCiAgMSwKICAxLAogIDEKXSk7CmZ1bmN0aW9uICR0KGkpIHsKICBjb25zdCBlID0gaS5jcmVhdGVCdWZmZXIoeyBzaXplOiBudC5ieXRlTGVuZ3RoLCB1c2FnZTogR1BVQnVmZmVyVXNhZ2UuVkVSVEVYIHwgR1BVQnVmZmVyVXNhZ2UuQ09QWV9EU1QgfSk7CiAgcmV0dXJuIGkucXVldWUud3JpdGVCdWZmZXIoZSwgMCwgbnQpLCBlOwp9CmZ1bmN0aW9uIEhlKGksIGUsIHIsIHMpIHsKICBjb25zdCBvID0gaS5jcmVhdGVUZXh0dXJlKHsKICAgIHNpemU6IFtyLCBzXSwKICAgIGZvcm1hdDogZSwKICAgIHVzYWdlOiBHUFVUZXh0dXJlVXNhZ2UuVEVYVFVSRV9CSU5ESU5HIHwgR1BVVGV4dHVyZVVzYWdlLlJFTkRFUl9BVFRBQ0hNRU5UIHwgR1BVVGV4dHVyZVVzYWdlLkNPUFlfU1JDCiAgfSk7CiAgcmV0dXJuIHsgdGV4OiBvLCB2aWV3OiBvLmNyZWF0ZVZpZXcoKSwgd2lkdGg6IHIsIGhlaWdodDogcyB9Owp9CmZ1bmN0aW9uIHJ0KGksIGUsIHIsIHMpIHsKICBsZXQgbyA9IEhlKGksIGUsIHIsIHMpLCBhID0gSGUoaSwgZSwgciwgcyk7CiAgcmV0dXJuIHsKICAgIGdldCByZWFkKCkgewogICAgICByZXR1cm4gbzsKICAgIH0sCiAgICBnZXQgd3JpdGUoKSB7CiAgICAgIHJldHVybiBhOwogICAgfSwKICAgIHN3YXAoKSB7CiAgICAgIFtvLCBhXSA9IFthLCBvXTsKICAgIH0sCiAgICBkaXNwb3NlKCkgewogICAgICBvLnRleC5kZXN0cm95KCksIGEudGV4LmRlc3Ryb3koKTsKICAgIH0KICB9Owp9CmZ1bmN0aW9uIHNlKGksIGUsIHIsIHMpIHsKICBjb25zdCBvID0gaS5jcmVhdGVTaGFkZXJNb2R1bGUoeyBjb2RlOiBlIH0pOwogIHJldHVybiBpLmNyZWF0ZVJlbmRlclBpcGVsaW5lKHsKICAgIGxheW91dDogImF1dG8iLAogICAgdmVydGV4OiB7IG1vZHVsZTogbywgZW50cnlQb2ludDogInZzIiwgYnVmZmVyczogW050XSB9LAogICAgZnJhZ21lbnQ6IHsgbW9kdWxlOiBvLCBlbnRyeVBvaW50OiAiZnMiLCB0YXJnZXRzOiBbeyBmb3JtYXQ6IHIsIC4uLnMgPyB7IGJsZW5kOiBzIH0gOiB7fSB9XSB9LAogICAgcHJpbWl0aXZlOiB7IHRvcG9sb2d5OiAidHJpYW5nbGUtbGlzdCIgfQogIH0pOwp9CmNvbnN0IHF0ID0gewogIGNvbG9yOiB7IG9wZXJhdGlvbjogImFkZCIsIHNyY0ZhY3RvcjogIm9uZSIsIGRzdEZhY3RvcjogInplcm8iIH0sCiAgYWxwaGE6IHsgb3BlcmF0aW9uOiAiYWRkIiwgc3JjRmFjdG9yOiAib25lIiwgZHN0RmFjdG9yOiAiemVybyIgfQp9OwpmdW5jdGlvbiBIdChpLCBlLCByID0gITApIHsKICBjb25zdCBzID0gInJnYmExNmZsb2F0IjsKICByZXR1cm4gewogICAgYWR2ZWN0aW9uOiBzZShpLCBBdCwgcyksCiAgICBkaXZlcmdlbmNlOiBzZShpLCB6dCwgcyksCiAgICBwcmVzc3VyZTogc2UoaSwgWHQsIHMpLAogICAgZ3JhZGllbnRTdWJ0cmFjdDogc2UoaSwgTXQsIHMpLAogICAgc3BsYXQ6IHNlKGksIEd0LCBzKSwKICAgIGN1cmw6IHNlKGksIEl0LCBzKSwKICAgIHZvcnRpY2l0eTogc2UoaSwga3QsIHMpLAogICAgZGlzcGxheTogc2UoaSwgV3QsIGUsIHIgPyB2b2lkIDAgOiBxdCkKICB9Owp9CmZ1bmN0aW9uIFl0KGkpIHsKICByZXR1cm4gaS5jcmVhdGVTYW1wbGVyKHsgbWFnRmlsdGVyOiAibGluZWFyIiwgbWluRmlsdGVyOiAibGluZWFyIiwgYWRkcmVzc01vZGVVOiAiY2xhbXAtdG8tZWRnZSIsIGFkZHJlc3NNb2RlVjogImNsYW1wLXRvLWVkZ2UiIH0pOwp9CmZ1bmN0aW9uIFcoaSwgZSkgewogIHJldHVybiBpLmNyZWF0ZUJ1ZmZlcih7IHNpemU6IGUsIHVzYWdlOiBHUFVCdWZmZXJVc2FnZS5VTklGT1JNIHwgR1BVQnVmZmVyVXNhZ2UuQ09QWV9EU1QgfSk7Cn0KZnVuY3Rpb24gbHQoaSwgZSwgciwgcywgbywgYSkgewogIGNvbnN0IHUgPSBuZXcgRmxvYXQzMkFycmF5KFtyLCBzLCBvLCBhXSk7CiAgaS5xdWV1ZS53cml0ZUJ1ZmZlcihlLCAwLCB1KTsKfQpmdW5jdGlvbiBOZShpLCBlLCByLCBzKSB7CiAgY29uc3QgbyA9IG5ldyBGbG9hdDMyQXJyYXkoW3IsIHMsIDAsIDBdKTsKICBpLnF1ZXVlLndyaXRlQnVmZmVyKGUsIDAsIG8pOwp9CmZ1bmN0aW9uIFF0KGksIGUsIHIsIHMsIG8sIGEpIHsKICBjb25zdCB1ID0gbmV3IEZsb2F0MzJBcnJheShbciwgcywgbywgYV0pOwogIGkucXVldWUud3JpdGVCdWZmZXIoZSwgMCwgdSk7Cn0KZnVuY3Rpb24gJGUoaSwgZSwgciwgcywgbywgYSwgdSwgdiwgbSwgYywgeCkgewogIGNvbnN0IHAgPSBuZXcgRmxvYXQzMkFycmF5KDEyKTsKICBwWzBdID0gciwgcFsxXSA9IHMsIHBbMl0gPSBvLCBwWzNdID0gYSwgcFs0XSA9IHUsIHBbNV0gPSB2LCBwWzZdID0gbSwgcFs3XSA9IDAsIHBbOF0gPSBjLCBwWzldID0geCwgcFsxMF0gPSAwLCBwWzExXSA9IDAsIGkucXVldWUud3JpdGVCdWZmZXIoZSwgMCwgcCk7Cn0KZnVuY3Rpb24ganQoaSwgZSwgciwgcywgbywgYSwgdSwgdiwgbSwgYywgeCwgcCkgewogIGNvbnN0IG4gPSBuZXcgRmxvYXQzMkFycmF5KDE2KSwgZCA9IG5ldyBJbnQzMkFycmF5KG4uYnVmZmVyKTsKICBuWzBdID0gciwgblsxXSA9IHMsIG5bMl0gPSBvLCBuWzNdID0gYSwgbls0XSA9IHVbMF0sIG5bNV0gPSB1WzFdLCBuWzZdID0gdVsyXSwgbls3XSA9IDAsIG5bOF0gPSB2WzBdLCBuWzldID0gdlsxXSwgblsxMF0gPSB2WzJdLCBuWzExXSA9IDAsIG5bMTJdID0gbSwgblsxM10gPSBjLCBkWzE0XSA9IHgsIGRbMTVdID0gcCA/IDEgOiAwLCBpLnF1ZXVlLndyaXRlQnVmZmVyKGUsIDAsIG4pOwp9CmZ1bmN0aW9uIFgoaSwgZSwgciwgcywgbykgewogIGNvbnN0IGEgPSBpLmJlZ2luUmVuZGVyUGFzcyh7CiAgICBjb2xvckF0dGFjaG1lbnRzOiBbewogICAgICB2aWV3OiBvLAogICAgICBjbGVhclZhbHVlOiBbMCwgMCwgMCwgMF0sCiAgICAgIGxvYWRPcDogImNsZWFyIiwKICAgICAgc3RvcmVPcDogInN0b3JlIgogICAgfV0KICB9KTsKICBhLnNldFBpcGVsaW5lKGUpLCBhLnNldEJpbmRHcm91cCgwLCByKSwgYS5zZXRWZXJ0ZXhCdWZmZXIoMCwgcyksIGEuZHJhdyg2KSwgYS5lbmQoKTsKfQpmdW5jdGlvbiBLdChpLCBlLCByLCBzLCBvKSB7CiAgY29uc3QgYSA9IGkuYmVnaW5SZW5kZXJQYXNzKHsKICAgIGNvbG9yQXR0YWNobWVudHM6IFt7CiAgICAgIHZpZXc6IG8sCiAgICAgIGNsZWFyVmFsdWU6IFswLCAwLCAwLCAwXSwKICAgICAgbG9hZE9wOiAiY2xlYXIiLAogICAgICBzdG9yZU9wOiAic3RvcmUiCiAgICB9XQogIH0pOwogIGEuc2V0UGlwZWxpbmUoZSksIGEuc2V0QmluZEdyb3VwKDAsIHIpLCBhLnNldFZlcnRleEJ1ZmZlcigwLCBzKSwgYS5kcmF3KDYpLCBhLmVuZCgpOwp9CmZ1bmN0aW9uIEJlKGksIGUsIHIsIHMsIG8gPSAiY292ZXIiKSB7CiAgbGV0IGE7CiAgbyA9PT0gImNvdmVyIiA/IGEgPSBNYXRoLm1heChyIC8gaSwgcyAvIGUpIDogbyA9PT0gImNvbnRhaW4iID8gYSA9IE1hdGgubWluKHIgLyBpLCBzIC8gZSkgOiB0eXBlb2YgbyA9PSAic3RyaW5nIiAmJiBvLmVuZHNXaXRoKCIlIikgPyBhID0gTWF0aC5taW4ociAvIGksIHMgLyBlKSAqIChwYXJzZUZsb2F0KG8pIC8gMTAwKSA6IHR5cGVvZiBvID09ICJzdHJpbmciICYmIG8uZW5kc1dpdGgoInB4IikgPyBhID0gcGFyc2VGbG9hdChvKSAvIE1hdGgubWF4KGksIGUpIDogdHlwZW9mIG8gPT0gIm51bWJlciIgPyBhID0gbyA6IGEgPSBNYXRoLm1heChyIC8gaSwgcyAvIGUpOwogIGNvbnN0IHUgPSBpICogYSwgdiA9IGUgKiBhOwogIHJldHVybiB7IHg6IChyIC0gdSkgLyAyLCB5OiAocyAtIHYpIC8gMiwgZHJhd1c6IHUsIGRyYXdIOiB2IH07Cn0KZnVuY3Rpb24gSnQoaSwgZSwgciwgcywgbyA9IG51bGwsIGEgPSAiY292ZXIiKSB7CiAgY29uc3QgeyB0ZXh0OiB1LCBmb250U2l6ZTogdiwgY29sb3I6IG0sIGZvbnRGYW1pbHk6IGMgPSAic2Fucy1zZXJpZiIsIGZvbnRXZWlnaHQ6IHggPSA5MDAgfSA9IHMsIHAgPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKGUsIHIpLCBuID0gcC5nZXRDb250ZXh0KCIyZCIpOwogICgoRCkgPT4gewogICAgaWYgKG8pIHsKICAgICAgbi5jbGVhclJlY3QoMCwgMCwgZSwgciksIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKTsKICAgICAgY29uc3QgeyB4OiBnLCB5OiBfLCBkcmF3VzogUCwgZHJhd0g6IGsgfSA9IEJlKAogICAgICAgIG8ud2lkdGgsCiAgICAgICAgby5oZWlnaHQsCiAgICAgICAgZSwKICAgICAgICByLAogICAgICAgIGEKICAgICAgKTsKICAgICAgbi5kcmF3SW1hZ2UobywgZywgXywgUCwgayk7CiAgICB9IGVsc2UKICAgICAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpOwogICAgbi5maWxsU3R5bGUgPSBELCBuLmZvbnQgPSBgJHt4fSAke3Z9cHggJHtjfWAsIG4udGV4dEFsaWduID0gImNlbnRlciIsIG4udGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIG4uZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICB9KShtKTsKICBjb25zdCBiID0gTGUoaSwgcCk7CiAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpLCBuLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIG4uZm9udCA9IGAke3h9ICR7dn1weCAke2N9YCwgbi50ZXh0QWxpZ24gPSAiY2VudGVyIiwgbi50ZXh0QmFzZWxpbmUgPSAibWlkZGxlIiwgbi5maWxsVGV4dCh1LCBlIC8gMiwgciAvIDIpOwogIGNvbnN0IHkgPSBMZShpLCBwKTsKICByZXR1cm4geyBiYWNrZ3JvdW5kVGV4OiBiLCBvYnN0YWNsZVRleDogeSwgY292ZXJhZ2VUZXg6IHkgfTsKfQpmdW5jdGlvbiBadChpLCBlLCByLCBzLCBvID0gMCwgYSA9ICJjb3ZlciIsIHUgPSBudWxsLCB2ID0gImNvdmVyIikgewogIGNvbnN0IG0gPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKHIsIHMpLCBjID0gbS5nZXRDb250ZXh0KCIyZCIpLCB7IHgsIHk6IHAsIGRyYXdXOiBuLCBkcmF3SDogZCB9ID0gQmUoZS53aWR0aCwgZS5oZWlnaHQsIHIsIHMsIGEpOwogIGlmIChjLmNsZWFyUmVjdCgwLCAwLCByLCBzKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIHMpLCB1KSB7CiAgICBjb25zdCB7CiAgICAgIHg6IGcsCiAgICAgIHk6IF8sCiAgICAgIGRyYXdXOiBQLAogICAgICBkcmF3SDogawogICAgfSA9IEJlKHUud2lkdGgsIHUuaGVpZ2h0LCByLCBzLCB2KTsKICAgIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtvfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UodSwgZywgXywgUCwgayksIGMuZmlsdGVyID0gIm5vbmUiOwogIH0KICBjLmRyYXdJbWFnZShlLCB4LCBwLCBuLCBkKTsKICBjb25zdCBiID0gTGUoaSwgbSk7CiAgYy5jbGVhclJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBzKSwgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke299KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZShlLCB4LCBwLCBuLCBkKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgY29uc3QgeSA9IExlKGksIG0pOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gIndoaXRlIiwgYy5maWxsUmVjdCgKICAgIE1hdGgubWF4KDAsIHgpLAogICAgTWF0aC5tYXgoMCwgcCksCiAgICBNYXRoLm1pbihuLCByIC0gTWF0aC5tYXgoMCwgeCkpLAogICAgTWF0aC5taW4oZCwgcyAtIE1hdGgubWF4KDAsIHApKQogICk7CiAgY29uc3QgRCA9IExlKGksIG0pOwogIHJldHVybiB7IGJhY2tncm91bmRUZXg6IGIsIG9ic3RhY2xlVGV4OiB5LCBjb3ZlcmFnZVRleDogRCB9Owp9CmZ1bmN0aW9uIExlKGksIGUpIHsKICBjb25zdCByID0gaS5jcmVhdGVUZXh0dXJlKCk7CiAgcmV0dXJuIGkuYmluZFRleHR1cmUoaS5URVhUVVJFXzJELCByKSwgaS5waXhlbFN0b3JlaShpLlVOUEFDS19GTElQX1lfV0VCR0wsICEwKSwgaS50ZXhJbWFnZTJEKGkuVEVYVFVSRV8yRCwgMCwgaS5SR0JBLCBpLlJHQkEsIGkuVU5TSUdORURfQllURSwgZSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NSU5fRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NQUdfRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1MsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1QsIGkuQ0xBTVBfVE9fRURHRSksIHI7Cn0KZnVuY3Rpb24gZXIoaSwgZSwgciwgcywgbyA9IG51bGwsIGEgPSAiY292ZXIiKSB7CiAgY29uc3QgeyB0ZXh0OiB1LCBmb250U2l6ZTogdiwgY29sb3I6IG0sIGZvbnRGYW1pbHk6IGMgPSAic2Fucy1zZXJpZiIsIGZvbnRXZWlnaHQ6IHggPSA5MDAgfSA9IHMsIHAgPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKGUsIHIpLCBuID0gcC5nZXRDb250ZXh0KCIyZCIpOwogICgoRCkgPT4gewogICAgaWYgKG8pIHsKICAgICAgbi5jbGVhclJlY3QoMCwgMCwgZSwgciksIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKTsKICAgICAgY29uc3QgeyB4OiBnLCB5OiBfLCBkcmF3VzogUCwgZHJhd0g6IGsgfSA9IEJlKAogICAgICAgIG8ud2lkdGgsCiAgICAgICAgby5oZWlnaHQsCiAgICAgICAgZSwKICAgICAgICByLAogICAgICAgIGEKICAgICAgKTsKICAgICAgbi5kcmF3SW1hZ2UobywgZywgXywgUCwgayk7CiAgICB9IGVsc2UKICAgICAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpOwogICAgbi5maWxsU3R5bGUgPSBELCBuLmZvbnQgPSBgJHt4fSAke3Z9cHggJHtjfWAsIG4udGV4dEFsaWduID0gImNlbnRlciIsIG4udGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIG4uZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICB9KShtKTsKICBjb25zdCBiID0gQWUoaSwgcCwgZSwgcik7CiAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpLCBuLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIG4uZm9udCA9IGAke3h9ICR7dn1weCAke2N9YCwgbi50ZXh0QWxpZ24gPSAiY2VudGVyIiwgbi50ZXh0QmFzZWxpbmUgPSAibWlkZGxlIiwgbi5maWxsVGV4dCh1LCBlIC8gMiwgciAvIDIpOwogIGNvbnN0IHkgPSBBZShpLCBwLCBlLCByKTsKICByZXR1cm4gewogICAgYmFja2dyb3VuZFRleDogYiwKICAgIGJhY2tncm91bmRWaWV3OiBiLmNyZWF0ZVZpZXcoKSwKICAgIG9ic3RhY2xlVGV4OiB5LAogICAgb2JzdGFjbGVWaWV3OiB5LmNyZWF0ZVZpZXcoKSwKICAgIGNvdmVyYWdlVGV4OiB5LAogICAgY292ZXJhZ2VWaWV3OiB5LmNyZWF0ZVZpZXcoKSwKICAgIHNoYXJlZENvdmVyYWdlOiAhMAogIH07Cn0KZnVuY3Rpb24gdHIoaSwgZSwgciwgcywgbyA9IDAsIGEgPSAiY292ZXIiLCB1ID0gbnVsbCwgdiA9ICJjb3ZlciIpIHsKICBjb25zdCBtID0gbmV3IE9mZnNjcmVlbkNhbnZhcyhyLCBzKSwgYyA9IG0uZ2V0Q29udGV4dCgiMmQiKSwgeyB4LCB5OiBwLCBkcmF3VzogbiwgZHJhd0g6IGQgfSA9IEJlKGUud2lkdGgsIGUuaGVpZ2h0LCByLCBzLCBhKTsKICBpZiAoYy5jbGVhclJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBzKSwgdSkgewogICAgY29uc3QgeyB4OiBnLCB5OiBfLCBkcmF3VzogUCwgZHJhd0g6IGsgfSA9IEJlKAogICAgICB1LndpZHRoLAogICAgICB1LmhlaWdodCwKICAgICAgciwKICAgICAgcywKICAgICAgdgogICAgKTsKICAgIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtvfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UodSwgZywgXywgUCwgayksIGMuZmlsdGVyID0gIm5vbmUiOwogIH0KICBjLmRyYXdJbWFnZShlLCB4LCBwLCBuLCBkKTsKICBjb25zdCBiID0gQWUoaSwgbSwgciwgcyk7CiAgYy5jbGVhclJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBzKSwgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke299KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZShlLCB4LCBwLCBuLCBkKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgY29uc3QgeSA9IEFlKGksIG0sIHIsIHMpOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gIndoaXRlIiwgYy5maWxsUmVjdChNYXRoLm1heCgwLCB4KSwgTWF0aC5tYXgoMCwgcCksIE1hdGgubWluKG4sIHIgLSBNYXRoLm1heCgwLCB4KSksIE1hdGgubWluKGQsIHMgLSBNYXRoLm1heCgwLCBwKSkpOwogIGNvbnN0IEQgPSBBZShpLCBtLCByLCBzKTsKICByZXR1cm4gewogICAgYmFja2dyb3VuZFRleDogYiwKICAgIGJhY2tncm91bmRWaWV3OiBiLmNyZWF0ZVZpZXcoKSwKICAgIG9ic3RhY2xlVGV4OiB5LAogICAgb2JzdGFjbGVWaWV3OiB5LmNyZWF0ZVZpZXcoKSwKICAgIGNvdmVyYWdlVGV4OiBELAogICAgY292ZXJhZ2VWaWV3OiBELmNyZWF0ZVZpZXcoKSwKICAgIHNoYXJlZENvdmVyYWdlOiAhMQogIH07Cn0KZnVuY3Rpb24gQWUoaSwgZSwgciwgcykgewogIGNvbnN0IG8gPSBpLmNyZWF0ZVRleHR1cmUoewogICAgc2l6ZTogW3IsIHNdLAogICAgZm9ybWF0OiAicmdiYTh1bm9ybSIsCiAgICB1c2FnZTogR1BVVGV4dHVyZVVzYWdlLlRFWFRVUkVfQklORElORyB8IEdQVVRleHR1cmVVc2FnZS5DT1BZX0RTVCB8IEdQVVRleHR1cmVVc2FnZS5SRU5ERVJfQVRUQUNITUVOVAogIH0pOwogIHJldHVybiBpLnF1ZXVlLmNvcHlFeHRlcm5hbEltYWdlVG9UZXh0dXJlKAogICAgeyBzb3VyY2U6IGUgfSwKICAgIHsgdGV4dHVyZTogbyB9LAogICAgW3IsIHNdCiAgKSwgbzsKfQphc3luYyBmdW5jdGlvbiBycihpKSB7CiAgY29uc3QgZSA9IGF3YWl0IGZldGNoKGkpOwogIGlmICghZS5vaykKICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGZldGNoIGltYWdlOiAke2l9ICgke2Uuc3RhdHVzfSlgKTsKICBjb25zdCByID0gYXdhaXQgZS5ibG9iKCk7CiAgcmV0dXJuIGNyZWF0ZUltYWdlQml0bWFwKHIpOwp9CmNvbnN0IGN0ID0gdHlwZW9mIHJlcXVlc3RBbmltYXRpb25GcmFtZSA8ICJ1IiA/IHJlcXVlc3RBbmltYXRpb25GcmFtZS5iaW5kKGdsb2JhbFRoaXMpIDogKGkpID0+IHNldFRpbWVvdXQoaSwgMWUzIC8gNjApLCBpciA9IHR5cGVvZiBjYW5jZWxBbmltYXRpb25GcmFtZSA8ICJ1IiA/IGNhbmNlbEFuaW1hdGlvbkZyYW1lLmJpbmQoZ2xvYmFsVGhpcykgOiBjbGVhclRpbWVvdXQsIE9lID0gMC4wMTYsIGZ0ID0geyBzdGFuZGFyZDogMCwgZ2xhc3M6IDEsIGluazogMiwgYXVyb3JhOiAzLCByaXBwbGU6IDQgfTsKdmFyIGNlLCBNLCB6ZSwgZmUsIFVlLCBCLCBSLCAkLCBxLCBILCBLLCBMLCBZLCBPLCBEZSwgdmUsIF9lLCBWLCBULCBvZSwgUSwgYWUsIHosIHBlLCB4ZSwgbWUsIGRlLCBoZSwgSiwgWiwgZ2UsIGJlLCBUZSwgdywgVSwgRywgSSwgRiwgQ2UsIGVlLCBBLCB1ZSwgdGUsIGgsIEMsIGosIHllLCBYZSwgU2UsIFllLCBwdCwgd2UsIEZlLCBNZSwgc3QsIG5lLCBFZSwgUmUsIFBlLCBHZSwgb3QsIEllLCBhdCwgUWUsIHh0LCBqZSwgbXQsIEtlLCBkdCwgSmUsIGh0LCBaZSwgZ3Q7CmNvbnN0IHV0ID0gY2xhc3MgdXQgewogIC8vIOKUgOKUgCBDb25zdHJ1Y3RvciDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICBjb25zdHJ1Y3RvcihlLCByID0ge30sIHMgPSB7fSwgbywgYSA9ICEwKSB7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIEdQVSBpbml0aWFsaXNhdGlvbgogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIFllKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgc2hhcmVkIGhlbHBlcnMKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCB3ZSk7CiAgICBmKHRoaXMsIE1lKTsKICAgIGYodGhpcywgbmUpOwogICAgZih0aGlzLCBSZSk7CiAgICBmKHRoaXMsIEdlKTsKICAgIGYodGhpcywgSWUpOwogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIOKAlCBmcmFtZSBkaXNwYXRjaAogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIFFlKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgV2ViR1BVIHNpbXVsYXRpb24gc3RlcAogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIGplKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgV2ViR1BVIGRpcmVjdCBzcGxhdAogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIEtlKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgV2ViR0wgc3BsYXQKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCBKZSk7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIFdlYkdMIHNpbXVsYXRpb24gc3RlcCAodW5jaGFuZ2VkIGZyb20gb3JpZ2luYWwpCiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIGYodGhpcywgWmUpOwogICAgZih0aGlzLCBjZSwgdm9pZCAwKTsKICAgIC8vIOKUgOKUgCBXZWJHTCBwYXRoIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgZih0aGlzLCBNLCBudWxsKTsKICAgIGYodGhpcywgemUsIG51bGwpOwogICAgZih0aGlzLCBmZSwgbnVsbCk7CiAgICBmKHRoaXMsIFVlLCBudWxsKTsKICAgIGYodGhpcywgQiwgbnVsbCk7CiAgICBmKHRoaXMsIFIsIG51bGwpOwogICAgZih0aGlzLCAkLCBudWxsKTsKICAgIGYodGhpcywgcSwgbnVsbCk7CiAgICBmKHRoaXMsIEgsIG51bGwpOwogICAgZih0aGlzLCBLLCBudWxsKTsKICAgIGYodGhpcywgTCwgbnVsbCk7CiAgICBmKHRoaXMsIFksIG51bGwpOwogICAgLy8g4pSA4pSAIFdlYkdQVSBwYXRoIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgZih0aGlzLCBPLCBudWxsKTsKICAgIGYodGhpcywgRGUsIG51bGwpOwogICAgZih0aGlzLCB2ZSwgbnVsbCk7CiAgICBmKHRoaXMsIF9lLCBudWxsKTsKICAgIGYodGhpcywgViwgbnVsbCk7CiAgICBmKHRoaXMsIFQsIG51bGwpOwogICAgZih0aGlzLCBvZSwgbnVsbCk7CiAgICBmKHRoaXMsIFEsIG51bGwpOwogICAgZih0aGlzLCBhZSwgbnVsbCk7CiAgICBmKHRoaXMsIHosIG51bGwpOwogICAgLy8gUHJlLWFsbG9jYXRlZCB1bmlmb3JtIGJ1ZmZlcnMgKHNpemVzOiBzZWUgZ3B1LXV0aWxzIHdyaXRlWHh4IGRvY3MpCiAgICAvLyBWZWxvY2l0eS9kZW5zaXR5IGFkdmVjdGlvbiB1c2Ugc2VwYXJhdGUgYnVmZmVycyDigJQgd3JpdGVCdWZmZXIgaXMgYSBxdWV1ZSBvcDsKICAgIC8vIGEgc2Vjb25kIHdyaXRlIHRvIHRoZSBzYW1lIGJ1ZmZlciBiZWZvcmUgcXVldWUuc3VibWl0KCkgYWxpYXNlcyBib3RoIHBhc3Nlcy4KICAgIGYodGhpcywgcGUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMg4oCUIHZlbG9jaXR5IGFkdmVjdGlvbgogICAgZih0aGlzLCB4ZSwgbnVsbCk7CiAgICAvLyAxNiBieXRlcyDigJQgZGVuc2l0eSBhZHZlY3Rpb24KICAgIGYodGhpcywgbWUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgZGUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgaGUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgSiwgbnVsbCk7CiAgICAvLyA0OCBieXRlcyDigJQgdmVsb2NpdHkgc3BsYXQKICAgIGYodGhpcywgWiwgbnVsbCk7CiAgICAvLyA0OCBieXRlcyDigJQgZGVuc2l0eSBzcGxhdAogICAgZih0aGlzLCBnZSwgbnVsbCk7CiAgICAvLyAxNiBieXRlcwogICAgZih0aGlzLCBiZSwgbnVsbCk7CiAgICAvLyAxNiBieXRlcwogICAgZih0aGlzLCBUZSwgbnVsbCk7CiAgICAvLyA2NCBieXRlcwogICAgLy8g4pSA4pSAIFNoYXJlZCBzdGF0ZSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgIGYodGhpcywgdywgMCk7CiAgICBmKHRoaXMsIFUsIDApOwogICAgZih0aGlzLCBHLCAwKTsKICAgIGYodGhpcywgSSwgMCk7CiAgICBmKHRoaXMsIEYsIDEpOwogICAgZih0aGlzLCBDZSwgMSk7CiAgICBmKHRoaXMsIGVlLCAwLjUpOwogICAgZih0aGlzLCBBLCBudWxsKTsKICAgIGYodGhpcywgdWUsICJjb3ZlciIpOwogICAgZih0aGlzLCB0ZSwgdm9pZCAwKTsKICAgIGYodGhpcywgaCwgeyB4OiAwLCB5OiAwLCBkeDogMCwgZHk6IDAsIHRhcmdldFg6IDAsIHRhcmdldFk6IDAsIG1vdmVkOiAhMSB9KTsKICAgIGYodGhpcywgQywgbnVsbCk7CiAgICBmKHRoaXMsIGosIG51bGwpOwogICAgZih0aGlzLCB5ZSwgITEpOwogICAgZih0aGlzLCBYZSwgITEpOwogICAgZih0aGlzLCBTZSwgITApOwogICAgaWYgKGwodGhpcywgY2UsIGUpLCBsKHRoaXMsIENlLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIHMuZHByID8/IDEpKSksIGwodGhpcywgZWUsIE1hdGgubWF4KDAuMSwgTWF0aC5taW4oMSwgcy5zaW0gPz8gMC41KSkpLCBsKHRoaXMsIHRlLCB3dChyKSksIGwodGhpcywgU2UsIGEpLCBvKQogICAgICBsKHRoaXMsIE8sIG8pLCBTKHRoaXMsIFllLCBwdCkuY2FsbCh0aGlzLCBvKTsKICAgIGVsc2UgewogICAgICBjb25zdCB7IGdsOiB1LCBleHQ6IHYgfSA9IE90KGUsIGEpOwogICAgICBsKHRoaXMsIE0sIHUpLCBsKHRoaXMsIHplLCB2KSwgbCh0aGlzLCBmZSwgUHQodSkpLCBsKHRoaXMsIFVlLCBMdCh1KSksIHUuY2xlYXJDb2xvcigwLCAwLCAwLCBhID8gMCA6IDEpOwogICAgfQogIH0KICAvKioKICAgKiBXZWJHUFUtZmlyc3QgZmFjdG9yeS4gVHJpZXMgV2ViR1BVLCBmYWxscyBiYWNrIHRvIFdlYkdMMiDihpIgV2ViR0wxLgogICAqIFRoaXMgaXMgdGhlIHJlY29tbWVuZGVkIGVudHJ5IHBvaW50IHdoZW4gV2ViR1BVIHN1cHBvcnQgaXMgZGVzaXJlZC4KICAgKi8KICBzdGF0aWMgYXN5bmMgY3JlYXRlKGUsIHIgPSB7fSwgcyA9IHt9LCBvID0gITAsIGEgPSAhMCkgewogICAgY29uc3QgdSA9IG8gPyBhd2FpdCBGdChlLCBhKSA6IG51bGw7CiAgICByZXR1cm4gbmV3IHV0KGUsIHIsIHMsIHUgPz8gdm9pZCAwLCBhKTsKICB9CiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgLy8gUHVibGljIEFQSQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIHNldFRleHRTb3VyY2UoZSkgewogICAgbCh0aGlzLCBDLCB7IHR5cGU6ICJ0ZXh0Iiwgb3B0czogZSB9KSwgUyh0aGlzLCB3ZSwgRmUpLmNhbGwodGhpcyksIFModGhpcywgbmUsIEVlKS5jYWxsKHRoaXMpLCBTKHRoaXMsIFJlLCBQZSkuY2FsbCh0aGlzKTsKICB9CiAgYXN5bmMgc2V0SW1hZ2VTb3VyY2UoZSwgciA9IDAsIHMgPSAiY292ZXIiKSB7CiAgICBjb25zdCBvID0gYXdhaXQgcnIoZSk7CiAgICBpZiAodCh0aGlzLCBYZSkpIHsKICAgICAgby5jbG9zZSgpOwogICAgICByZXR1cm47CiAgICB9CiAgICBsKHRoaXMsIEMsIHsgdHlwZTogImltYWdlIiwgYml0bWFwOiBvLCBlZmZlY3Q6IHIsIHNpemU6IHMgfSksIFModGhpcywgd2UsIEZlKS5jYWxsKHRoaXMpLCBTKHRoaXMsIG5lLCBFZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBSZSwgUGUpLmNhbGwodGhpcyk7CiAgfQogIHNldEltYWdlQml0bWFwKGUsIHIgPSAwLCBzID0gImNvdmVyIikgewogICAgbCh0aGlzLCBDLCB7IHR5cGU6ICJpbWFnZSIsIGJpdG1hcDogZSwgZWZmZWN0OiByLCBzaXplOiBzIH0pLCBTKHRoaXMsIHdlLCBGZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBuZSwgRWUpLmNhbGwodGhpcyksIFModGhpcywgUmUsIFBlKS5jYWxsKHRoaXMpOwogIH0KICBzZXRCYWNrZ3JvdW5kKGUsIHIgPSAiY292ZXIiKSB7CiAgICB0KHRoaXMsIEEpICYmIHQodGhpcywgQSkgIT09IGUgJiYgdCh0aGlzLCBBKS5jbG9zZSgpLCBsKHRoaXMsIEEsIGUpLCBsKHRoaXMsIHVlLCByID8/ICJjb3ZlciIpLCB0KHRoaXMsIEMpICYmIHQodGhpcywgdykgPiAwICYmIHQodGhpcywgVSkgPiAwICYmIFModGhpcywgbmUsIEVlKS5jYWxsKHRoaXMpOwogIH0KICBoYW5kbGVNb3ZlKGUsIHIsIHMgPSAxKSB7CiAgICB0KHRoaXMsIGgpLm1vdmVkID0gITAsIHQodGhpcywgaCkuZHggPSAoZSAtIHQodGhpcywgaCkudGFyZ2V0WCkgKiBzLCB0KHRoaXMsIGgpLmR5ID0gKHIgLSB0KHRoaXMsIGgpLnRhcmdldFkpICogcywgdCh0aGlzLCBoKS50YXJnZXRYID0gZSwgdCh0aGlzLCBoKS50YXJnZXRZID0gcjsKICB9CiAgLyoqCiAgICogSW1tZWRpYXRlbHkgYXBwbGllcyBvbmUgZmx1aWQgc3BsYXQgYXQgKHgsIHkpIHdpdGggZXhwbGljaXQgdmVsb2NpdHkgKHZ4LCB2eSkuCiAgICogU2FmZSB0byBjYWxsIG11bHRpcGxlIHRpbWVzIHBlciBmcmFtZSDigJQgZWFjaCBjYWxsIHdyaXRlcyBkaXJlY3RseSB0byB0aGUgRkJPcy4KICAgKiBEZXNpZ25lZCBmb3IgcHJvZ3JhbW1hdGljIHVzZSBjYXNlcyAoZS5nLiBwYXJ0aWNsZSBzeXN0ZW1zLCBhdHRyYWN0b3IgcGF0aHMpCiAgICogd2hlcmUgeW91IHdhbnQgTiBpbmRlcGVuZGVudCBpbmplY3Rpb24gcG9pbnRzIHBlciBmcmFtZSB3aXRob3V0IGZsb29kaW5nIHRoZQogICAqIG1vdXNlLXN0YXRlIG1hY2hpbmUgb3IgdGhlIHdvcmtlciBtZXNzYWdlIHF1ZXVlLgogICAqLwogIHNwbGF0KGUsIHIsIHMsIG8sIGEgPSAxKSB7CiAgICAhdCh0aGlzLCB5ZSkgfHwgdCh0aGlzLCB3KSA9PT0gMCB8fCAodCh0aGlzLCBPKSA/IFModGhpcywgS2UsIGR0KS5jYWxsKHRoaXMsIGUsIHIsIHMsIG8sIGEpIDogUyh0aGlzLCBKZSwgaHQpLmNhbGwodGhpcywgZSwgciwgcywgbywgYSkpOwogIH0KICB1cGRhdGVRdWFsaXR5KGUpIHsKICAgIGUuZHByICE9PSB2b2lkIDAgJiYgbCh0aGlzLCBDZSwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBlLmRwcikpKSwgZS5zaW0gIT09IHZvaWQgMCAmJiBsKHRoaXMsIGVlLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIGUuc2ltKSkpOwogIH0KICByZXNpemUoZSwgciwgcykgewogICAgaWYgKHMgIT09IHZvaWQgMCA/IGwodGhpcywgRiwgcykgOiB0eXBlb2Ygd2luZG93IDwgInUiICYmIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvICYmIGwodGhpcywgRiwgd2luZG93LmRldmljZVBpeGVsUmF0aW8pLCBlICE9PSB2b2lkIDAgJiYgZSA+IDApIHsKICAgICAgaWYgKHIgPT09IHZvaWQgMCB8fCByIDw9IDApCiAgICAgICAgcmV0dXJuOwogICAgICBsKHRoaXMsIHcsIHQodGhpcywgY2UpLndpZHRoID0gZSksIGwodGhpcywgVSwgdCh0aGlzLCBjZSkuaGVpZ2h0ID0gciksIGwodGhpcywgRywgTWF0aC5tYXgoMSwgTWF0aC5yb3VuZChlICogdCh0aGlzLCBlZSkpKSksIGwodGhpcywgSSwgTWF0aC5tYXgoMSwgTWF0aC5yb3VuZChyICogdCh0aGlzLCBlZSkpKSksIFModGhpcywgTWUsIHN0KS5jYWxsKHRoaXMpOwogICAgfSBlbHNlCiAgICAgIFModGhpcywgd2UsIEZlKS5jYWxsKHRoaXMpOwogICAgdCh0aGlzLCBDKSAmJiBTKHRoaXMsIG5lLCBFZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBSZSwgUGUpLmNhbGwodGhpcyk7CiAgfQogIHVwZGF0ZUNvbmZpZyhlKSB7CiAgICBPYmplY3QuYXNzaWduKHQodGhpcywgdGUpLCBlKTsKICB9CiAgZGVzdHJveSgpIHsKICAgIHZhciBlLCByLCBzLCBvLCBhLCB1LCB2LCBtLCBjLCB4LCBwOwogICAgaWYgKGwodGhpcywgWGUsICEwKSwgdGhpcy5zdG9wKCksIFModGhpcywgR2UsIG90KS5jYWxsKHRoaXMpLCBTKHRoaXMsIEllLCBhdCkuY2FsbCh0aGlzKSwgdCh0aGlzLCBBKSAmJiAodCh0aGlzLCBBKS5jbG9zZSgpLCBsKHRoaXMsIEEsIG51bGwpKSwgdCh0aGlzLCBPKSkKICAgICAgKGUgPSB0KHRoaXMsIHBlKSkgPT0gbnVsbCB8fCBlLmRlc3Ryb3koKSwgKHIgPSB0KHRoaXMsIHhlKSkgPT0gbnVsbCB8fCByLmRlc3Ryb3koKSwgKHMgPSB0KHRoaXMsIG1lKSkgPT0gbnVsbCB8fCBzLmRlc3Ryb3koKSwgKG8gPSB0KHRoaXMsIGRlKSkgPT0gbnVsbCB8fCBvLmRlc3Ryb3koKSwgKGEgPSB0KHRoaXMsIGhlKSkgPT0gbnVsbCB8fCBhLmRlc3Ryb3koKSwgKHUgPSB0KHRoaXMsIEopKSA9PSBudWxsIHx8IHUuZGVzdHJveSgpLCAodiA9IHQodGhpcywgWikpID09IG51bGwgfHwgdi5kZXN0cm95KCksIChtID0gdCh0aGlzLCBnZSkpID09IG51bGwgfHwgbS5kZXN0cm95KCksIChjID0gdCh0aGlzLCBiZSkpID09IG51bGwgfHwgYy5kZXN0cm95KCksICh4ID0gdCh0aGlzLCBUZSkpID09IG51bGwgfHwgeC5kZXN0cm95KCksIChwID0gdCh0aGlzLCB2ZSkpID09IG51bGwgfHwgcC5kZXN0cm95KCksIHQodGhpcywgTykuZGV2aWNlLmRlc3Ryb3koKTsKICAgIGVsc2UgewogICAgICBjb25zdCBuID0gdCh0aGlzLCBNKTsKICAgICAgZm9yIChjb25zdCBiIG9mIE9iamVjdC52YWx1ZXModCh0aGlzLCBmZSkpKQogICAgICAgIGIuZGlzcG9zZSgpOwogICAgICBjb25zdCBkID0gbi5nZXRFeHRlbnNpb24oIldFQkdMX2xvc2VfY29udGV4dCIpOwogICAgICBkID09IG51bGwgfHwgZC5sb3NlQ29udGV4dCgpOwogICAgfQogIH0KICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAvLyBMb29wIGNvbnRyb2wKICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICBzdGFydCgpIHsKICAgIGlmICh0KHRoaXMsIGopICE9PSBudWxsKQogICAgICByZXR1cm47CiAgICBjb25zdCBlID0gKCkgPT4gewogICAgICBTKHRoaXMsIFFlLCB4dCkuY2FsbCh0aGlzKSwgbCh0aGlzLCBqLCBjdChlKSk7CiAgICB9OwogICAgbCh0aGlzLCBqLCBjdChlKSk7CiAgfQogIHN0b3AoKSB7CiAgICB0KHRoaXMsIGopICE9PSBudWxsICYmIChpcih0KHRoaXMsIGopKSwgbCh0aGlzLCBqLCBudWxsKSk7CiAgfQogIGdldCBpc1J1bm5pbmcoKSB7CiAgICByZXR1cm4gdCh0aGlzLCBqKSAhPT0gbnVsbDsKICB9Cn07CmNlID0gbmV3IFdlYWtNYXAoKSwgTSA9IG5ldyBXZWFrTWFwKCksIHplID0gbmV3IFdlYWtNYXAoKSwgZmUgPSBuZXcgV2Vha01hcCgpLCBVZSA9IG5ldyBXZWFrTWFwKCksIEIgPSBuZXcgV2Vha01hcCgpLCBSID0gbmV3IFdlYWtNYXAoKSwgJCA9IG5ldyBXZWFrTWFwKCksIHEgPSBuZXcgV2Vha01hcCgpLCBIID0gbmV3IFdlYWtNYXAoKSwgSyA9IG5ldyBXZWFrTWFwKCksIEwgPSBuZXcgV2Vha01hcCgpLCBZID0gbmV3IFdlYWtNYXAoKSwgTyA9IG5ldyBXZWFrTWFwKCksIERlID0gbmV3IFdlYWtNYXAoKSwgdmUgPSBuZXcgV2Vha01hcCgpLCBfZSA9IG5ldyBXZWFrTWFwKCksIFYgPSBuZXcgV2Vha01hcCgpLCBUID0gbmV3IFdlYWtNYXAoKSwgb2UgPSBuZXcgV2Vha01hcCgpLCBRID0gbmV3IFdlYWtNYXAoKSwgYWUgPSBuZXcgV2Vha01hcCgpLCB6ID0gbmV3IFdlYWtNYXAoKSwgcGUgPSBuZXcgV2Vha01hcCgpLCB4ZSA9IG5ldyBXZWFrTWFwKCksIG1lID0gbmV3IFdlYWtNYXAoKSwgZGUgPSBuZXcgV2Vha01hcCgpLCBoZSA9IG5ldyBXZWFrTWFwKCksIEogPSBuZXcgV2Vha01hcCgpLCBaID0gbmV3IFdlYWtNYXAoKSwgZ2UgPSBuZXcgV2Vha01hcCgpLCBiZSA9IG5ldyBXZWFrTWFwKCksIFRlID0gbmV3IFdlYWtNYXAoKSwgdyA9IG5ldyBXZWFrTWFwKCksIFUgPSBuZXcgV2Vha01hcCgpLCBHID0gbmV3IFdlYWtNYXAoKSwgSSA9IG5ldyBXZWFrTWFwKCksIEYgPSBuZXcgV2Vha01hcCgpLCBDZSA9IG5ldyBXZWFrTWFwKCksIGVlID0gbmV3IFdlYWtNYXAoKSwgQSA9IG5ldyBXZWFrTWFwKCksIHVlID0gbmV3IFdlYWtNYXAoKSwgdGUgPSBuZXcgV2Vha01hcCgpLCBoID0gbmV3IFdlYWtNYXAoKSwgQyA9IG5ldyBXZWFrTWFwKCksIGogPSBuZXcgV2Vha01hcCgpLCB5ZSA9IG5ldyBXZWFrTWFwKCksIFhlID0gbmV3IFdlYWtNYXAoKSwgU2UgPSBuZXcgV2Vha01hcCgpLCBZZSA9IG5ldyBXZWFrU2V0KCksIHB0ID0gZnVuY3Rpb24oZSkgewogIGNvbnN0IHsgZGV2aWNlOiByLCBmb3JtYXQ6IHMgfSA9IGU7CiAgbCh0aGlzLCBEZSwgSHQociwgcywgdCh0aGlzLCBTZSkpKSwgbCh0aGlzLCB2ZSwgJHQocikpLCBsKHRoaXMsIF9lLCBZdChyKSksIGwodGhpcywgcGUsIFcociwgMTYpKSwgbCh0aGlzLCB4ZSwgVyhyLCAxNikpLCBsKHRoaXMsIG1lLCBXKHIsIDE2KSksIGwodGhpcywgZGUsIFcociwgMTYpKSwgbCh0aGlzLCBoZSwgVyhyLCAxNikpLCBsKHRoaXMsIEosIFcociwgNDgpKSwgbCh0aGlzLCBaLCBXKHIsIDQ4KSksIGwodGhpcywgZ2UsIFcociwgMTYpKSwgbCh0aGlzLCBiZSwgVyhyLCAxNikpLCBsKHRoaXMsIFRlLCBXKHIsIDY0KSk7Cn0sIHdlID0gbmV3IFdlYWtTZXQoKSwgRmUgPSBmdW5jdGlvbigpIHsKICBjb25zdCBlID0gdCh0aGlzLCBjZSk7CiAgImNsaWVudFdpZHRoIiBpbiBlICYmIGUuY2xpZW50V2lkdGggPiAwID8gKGwodGhpcywgRiwgKHR5cGVvZiB3aW5kb3cgPCAidSIgJiYgd2luZG93LmRldmljZVBpeGVsUmF0aW8gfHwgMSkgKiB0KHRoaXMsIENlKSksIGwodGhpcywgdywgZS53aWR0aCA9IE1hdGgucm91bmQoZS5jbGllbnRXaWR0aCAqIHQodGhpcywgRikpKSwgbCh0aGlzLCBVLCBlLmhlaWdodCA9IE1hdGgucm91bmQoZS5jbGllbnRIZWlnaHQgKiB0KHRoaXMsIEYpKSkpIDogKGwodGhpcywgdywgZS53aWR0aCksIGwodGhpcywgVSwgZS5oZWlnaHQpKSwgISh0KHRoaXMsIHcpID09PSAwIHx8IHQodGhpcywgVSkgPT09IDApICYmIChsKHRoaXMsIEcsIE1hdGgubWF4KDEsIE1hdGgucm91bmQodCh0aGlzLCB3KSAqIHQodGhpcywgZWUpKSkpLCBsKHRoaXMsIEksIE1hdGgubWF4KDEsIE1hdGgucm91bmQodCh0aGlzLCBVKSAqIHQodGhpcywgZWUpKSkpLCBTKHRoaXMsIE1lLCBzdCkuY2FsbCh0aGlzKSk7Cn0sIE1lID0gbmV3IFdlYWtTZXQoKSwgc3QgPSBmdW5jdGlvbigpIHsKICBpZiAoUyh0aGlzLCBHZSwgb3QpLmNhbGwodGhpcyksIHQodGhpcywgTykpIHsKICAgIGNvbnN0IHsgZGV2aWNlOiBlIH0gPSB0KHRoaXMsIE8pLCByID0gInJnYmExNmZsb2F0IiwgcyA9IHQodGhpcywgRyksIG8gPSB0KHRoaXMsIEkpOwogICAgbCh0aGlzLCBWLCBydChlLCByLCBzLCBvKSksIGwodGhpcywgVCwgcnQoZSwgciwgcywgbykpLCBsKHRoaXMsIFEsIHJ0KGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBvZSwgSGUoZSwgciwgcywgbykpLCBsKHRoaXMsIGFlLCBIZShlLCByLCBzLCBvKSk7CiAgfSBlbHNlIHsKICAgIGNvbnN0IGUgPSB0KHRoaXMsIE0pLCByID0gdCh0aGlzLCB6ZSksIHMgPSB0KHRoaXMsIEcpLCBvID0gdCh0aGlzLCBJKTsKICAgIGwodGhpcywgQiwgdHQoZSwgciwgcywgbykpLCBsKHRoaXMsIFIsIHR0KGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBxLCB0dChlLCByLCBzLCBvKSksIGwodGhpcywgJCwgcWUoZSwgciwgcywgbykpLCBsKHRoaXMsIEgsIHFlKGUsIHIsIHMsIG8pKTsKICB9Cn0sIG5lID0gbmV3IFdlYWtTZXQoKSwgRWUgPSBmdW5jdGlvbigpIHsKICBpZiAoISghdCh0aGlzLCBDKSB8fCB0KHRoaXMsIHcpID09PSAwIHx8IHQodGhpcywgVSkgPT09IDApKSB7CiAgICBpZiAoUyh0aGlzLCBJZSwgYXQpLmNhbGwodGhpcyksIHQodGhpcywgTykpIHsKICAgICAgY29uc3QgeyBkZXZpY2U6IGUgfSA9IHQodGhpcywgTyk7CiAgICAgIHQodGhpcywgQykudHlwZSA9PT0gInRleHQiID8gbCh0aGlzLCB6LCBlcigKICAgICAgICBlLAogICAgICAgIHQodGhpcywgdyksCiAgICAgICAgdCh0aGlzLCBVKSwKICAgICAgICB0KHRoaXMsIEMpLm9wdHMsCiAgICAgICAgdCh0aGlzLCBBKSwKICAgICAgICB0KHRoaXMsIHVlKQogICAgICApKSA6IGwodGhpcywgeiwgdHIoCiAgICAgICAgZSwKICAgICAgICB0KHRoaXMsIEMpLmJpdG1hcCwKICAgICAgICB0KHRoaXMsIHcpLAogICAgICAgIHQodGhpcywgVSksCiAgICAgICAgdCh0aGlzLCBDKS5lZmZlY3QsCiAgICAgICAgdCh0aGlzLCBDKS5zaXplLAogICAgICAgIHQodGhpcywgQSksCiAgICAgICAgdCh0aGlzLCB1ZSkKICAgICAgKSk7CiAgICB9IGVsc2UgewogICAgICBjb25zdCBlID0gdCh0aGlzLCBNKTsKICAgICAgaWYgKHQodGhpcywgQykudHlwZSA9PT0gInRleHQiKSB7CiAgICAgICAgY29uc3QgeyBiYWNrZ3JvdW5kVGV4OiByLCBvYnN0YWNsZVRleDogcywgY292ZXJhZ2VUZXg6IG8gfSA9IEp0KAogICAgICAgICAgZSwKICAgICAgICAgIHQodGhpcywgdyksCiAgICAgICAgICB0KHRoaXMsIFUpLAogICAgICAgICAgdCh0aGlzLCBDKS5vcHRzLAogICAgICAgICAgdCh0aGlzLCBBKSwKICAgICAgICAgIHQodGhpcywgdWUpCiAgICAgICAgKTsKICAgICAgICBsKHRoaXMsIEssIHIpLCBsKHRoaXMsIEwsIHMpLCBsKHRoaXMsIFksIG8pOwogICAgICB9IGVsc2UgewogICAgICAgIGNvbnN0IHsgYmFja2dyb3VuZFRleDogciwgb2JzdGFjbGVUZXg6IHMsIGNvdmVyYWdlVGV4OiBvIH0gPSBadCgKICAgICAgICAgIGUsCiAgICAgICAgICB0KHRoaXMsIEMpLmJpdG1hcCwKICAgICAgICAgIHQodGhpcywgdyksCiAgICAgICAgICB0KHRoaXMsIFUpLAogICAgICAgICAgdCh0aGlzLCBDKS5lZmZlY3QsCiAgICAgICAgICB0KHRoaXMsIEMpLnNpemUsCiAgICAgICAgICB0KHRoaXMsIEEpLAogICAgICAgICAgdCh0aGlzLCB1ZSkKICAgICAgICApOwogICAgICAgIGwodGhpcywgSywgciksIGwodGhpcywgTCwgcyksIGwodGhpcywgWSwgbyk7CiAgICAgIH0KICAgIH0KICAgIGwodGhpcywgeWUsICEwKTsKICB9Cn0sIFJlID0gbmV3IFdlYWtTZXQoKSwgUGUgPSBmdW5jdGlvbigpIHsKICB0KHRoaXMsIHllKSAmJiAhdGhpcy5pc1J1bm5pbmcgJiYgdGhpcy5zdGFydCgpOwp9LCBHZSA9IG5ldyBXZWFrU2V0KCksIG90ID0gZnVuY3Rpb24oKSB7CiAgdmFyIGUsIHIsIHMsIG8sIGEsIHUsIHYsIG07CiAgaWYgKHQodGhpcywgTykpCiAgICAoZSA9IHQodGhpcywgVikpID09IG51bGwgfHwgZS5kaXNwb3NlKCksIChyID0gdCh0aGlzLCBUKSkgPT0gbnVsbCB8fCByLmRpc3Bvc2UoKSwgKHMgPSB0KHRoaXMsIFEpKSA9PSBudWxsIHx8IHMuZGlzcG9zZSgpLCAobyA9IHQodGhpcywgb2UpKSA9PSBudWxsIHx8IG8udGV4LmRlc3Ryb3koKSwgKGEgPSB0KHRoaXMsIGFlKSkgPT0gbnVsbCB8fCBhLnRleC5kZXN0cm95KCksIGwodGhpcywgViwgbCh0aGlzLCBULCBsKHRoaXMsIFEsIG51bGwpKSksIGwodGhpcywgb2UsIGwodGhpcywgYWUsIG51bGwpKTsKICBlbHNlIHsKICAgIGNvbnN0IGMgPSB0KHRoaXMsIE0pOwogICAgKHUgPSB0KHRoaXMsIEIpKSA9PSBudWxsIHx8IHUuZGlzcG9zZSgpLCAodiA9IHQodGhpcywgUikpID09IG51bGwgfHwgdi5kaXNwb3NlKCksIChtID0gdCh0aGlzLCBxKSkgPT0gbnVsbCB8fCBtLmRpc3Bvc2UoKSwgdCh0aGlzLCAkKSAmJiAoYy5kZWxldGVUZXh0dXJlKHQodGhpcywgJCkudGV4KSwgYy5kZWxldGVGcmFtZWJ1ZmZlcih0KHRoaXMsICQpLmZibykpLCB0KHRoaXMsIEgpICYmIChjLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBIKS50ZXgpLCBjLmRlbGV0ZUZyYW1lYnVmZmVyKHQodGhpcywgSCkuZmJvKSksIGwodGhpcywgQiwgbCh0aGlzLCBSLCBsKHRoaXMsIHEsIGwodGhpcywgJCwgbCh0aGlzLCBILCBudWxsKSkpKSk7CiAgfQp9LCBJZSA9IG5ldyBXZWFrU2V0KCksIGF0ID0gZnVuY3Rpb24oKSB7CiAgaWYgKHQodGhpcywgTykpCiAgICB0KHRoaXMsIHopICYmICh0KHRoaXMsIHopLmJhY2tncm91bmRUZXguZGVzdHJveSgpLCB0KHRoaXMsIHopLm9ic3RhY2xlVGV4LmRlc3Ryb3koKSwgdCh0aGlzLCB6KS5zaGFyZWRDb3ZlcmFnZSB8fCB0KHRoaXMsIHopLmNvdmVyYWdlVGV4LmRlc3Ryb3koKSwgbCh0aGlzLCB6LCBudWxsKSk7CiAgZWxzZSB7CiAgICBjb25zdCBlID0gdCh0aGlzLCBNKTsKICAgIHQodGhpcywgSykgJiYgZS5kZWxldGVUZXh0dXJlKHQodGhpcywgSykpLCB0KHRoaXMsIEwpICYmIGUuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIEwpKSwgdCh0aGlzLCBZKSAmJiB0KHRoaXMsIFkpICE9PSB0KHRoaXMsIEwpICYmIGUuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIFkpKSwgbCh0aGlzLCBLLCBsKHRoaXMsIEwsIGwodGhpcywgWSwgbnVsbCkpKTsKICB9Cn0sIFFlID0gbmV3IFdlYWtTZXQoKSwgeHQgPSBmdW5jdGlvbigpIHsKICAhdCh0aGlzLCB5ZSkgfHwgdCh0aGlzLCB3KSA9PT0gMCB8fCAodCh0aGlzLCBPKSA/IFModGhpcywgamUsIG10KS5jYWxsKHRoaXMpIDogUyh0aGlzLCBaZSwgZ3QpLmNhbGwodGhpcykpOwp9LCBqZSA9IG5ldyBXZWFrU2V0KCksIG10ID0gZnVuY3Rpb24oKSB7CiAgY29uc3QgZSA9IHQodGhpcywgTyksIHIgPSBlLmRldmljZSwgcyA9IHQodGhpcywgRGUpLCBvID0gdCh0aGlzLCB2ZSksIGEgPSB0KHRoaXMsIF9lKSwgdSA9IHQodGhpcywgdGUpLCB2ID0gdCh0aGlzLCB6KTsKICBpZiAoIXQodGhpcywgVikgfHwgIXQodGhpcywgVCkpCiAgICByZXR1cm47CiAgdCh0aGlzLCBoKS54ICs9ICh0KHRoaXMsIGgpLnRhcmdldFggLSB0KHRoaXMsIGgpLngpICogMC4xNSwgdCh0aGlzLCBoKS55ICs9ICh0KHRoaXMsIGgpLnRhcmdldFkgLSB0KHRoaXMsIGgpLnkpICogMC4xNTsKICBjb25zdCBtID0gdCh0aGlzLCBHKSwgYyA9IHQodGhpcywgSSksIHggPSB0KHRoaXMsIHcpLCBwID0gdCh0aGlzLCBVKSwgbiA9IDEgLyBtLCBkID0gMSAvIGM7CiAgbHQociwgdCh0aGlzLCBwZSksIG4sIGQsIE9lLCB1LnZlbG9jaXR5RGlzc2lwYXRpb24pLCBOZShyLCB0KHRoaXMsIG1lKSwgbiwgZCksIE5lKHIsIHQodGhpcywgZGUpLCBuLCBkKSwgTmUociwgdCh0aGlzLCBoZSksIG4sIGQpLCBOZShyLCB0KHRoaXMsIGdlKSwgbiwgZCksIFF0KHIsIHQodGhpcywgYmUpLCBuLCBkLCB1LmN1cmwsIE9lKSwganQoCiAgICByLAogICAgdCh0aGlzLCBUZSksCiAgICAxIC8geCwKICAgIDEgLyBwLAogICAgdS5yZWZyYWN0aW9uLAogICAgdS5zcGVjdWxhckV4cCwKICAgIFdlKHUud2F0ZXJDb2xvciksCiAgICBXZSh1Lmdsb3dDb2xvciksCiAgICB1LnNoaW5lLAogICAgdS53YXJwU3RyZW5ndGggPz8gMC4wMTUsCiAgICBmdFt1LmFsZ29yaXRobV0gPz8gMCwKICAgIHQodGhpcywgU2UpCiAgKTsKICBjb25zdCBiID0gci5jcmVhdGVDb21tYW5kRW5jb2RlcigpLCB5ID0gKGcsIF8pID0+IHIuY3JlYXRlQmluZEdyb3VwKHsgbGF5b3V0OiBnLmdldEJpbmRHcm91cExheW91dCgwKSwgZW50cmllczogXyB9KSwgRCA9IHsgYmluZGluZzogMSwgcmVzb3VyY2U6IGEgfTsKICB7CiAgICBjb25zdCBnID0geShzLmFkdmVjdGlvbiwgWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBwZSkgfSB9LAogICAgICBELAogICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIFQpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDMsIHJlc291cmNlOiB0KHRoaXMsIFQpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDQsIHJlc291cmNlOiB2Lm9ic3RhY2xlVmlldyB9CiAgICBdKTsKICAgIFgoYiwgcy5hZHZlY3Rpb24sIGcsIG8sIHQodGhpcywgVCkud3JpdGUudmlldyk7CiAgfQogIHQodGhpcywgVCkuc3dhcCgpOwogIHsKICAgIGx0KHIsIHQodGhpcywgeGUpLCBuLCBkLCBPZSwgdS5kZW5zaXR5RGlzc2lwYXRpb24pOwogICAgY29uc3QgZyA9IHkocy5hZHZlY3Rpb24sIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgeGUpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiAzLCByZXNvdXJjZTogdCh0aGlzLCBWKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA0LCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuYWR2ZWN0aW9uLCBnLCBvLCB0KHRoaXMsIFYpLndyaXRlLnZpZXcpOwogIH0KICB0KHRoaXMsIFYpLnN3YXAoKTsKICB7CiAgICBjb25zdCBnID0geShzLmN1cmwsIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgZ2UpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuY3VybCwgZywgbywgdCh0aGlzLCBhZSkudmlldyk7CiAgfQogIHsKICAgIGNvbnN0IGcgPSB5KHMudm9ydGljaXR5LCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIGJlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHQodGhpcywgYWUpLnZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMudm9ydGljaXR5LCBnLCBvLCB0KHRoaXMsIFQpLndyaXRlLnZpZXcpOwogIH0KICBpZiAodCh0aGlzLCBUKS5zd2FwKCksIHQodGhpcywgaCkubW92ZWQpIHsKICAgIGNvbnN0IGcgPSB0KHRoaXMsIGgpLnggKiB0KHRoaXMsIEYpIC8geCwgXyA9IHQodGhpcywgaCkueSAqIHQodGhpcywgRikgLyBwOwogICAgJGUoCiAgICAgIHIsCiAgICAgIHQodGhpcywgSiksCiAgICAgIG4sCiAgICAgIGQsCiAgICAgIHggLyBwLAogICAgICB1LnNwbGF0UmFkaXVzLAogICAgICB0KHRoaXMsIGgpLmR4ICogdS5zcGxhdEZvcmNlLAogICAgICB0KHRoaXMsIGgpLmR5ICogdS5zcGxhdEZvcmNlLAogICAgICAwLAogICAgICBnLAogICAgICBfCiAgICApOwogICAgewogICAgICBjb25zdCBQID0geShzLnNwbGF0LCBbCiAgICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgSikgfSB9LAogICAgICAgIEQsCiAgICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgICBdKTsKICAgICAgWChiLCBzLnNwbGF0LCBQLCBvLCB0KHRoaXMsIFQpLndyaXRlLnZpZXcpOwogICAgfQogICAgdCh0aGlzLCBUKS5zd2FwKCksICRlKAogICAgICByLAogICAgICB0KHRoaXMsIFopLAogICAgICBuLAogICAgICBkLAogICAgICB4IC8gcCwKICAgICAgdS5zcGxhdFJhZGl1cywKICAgICAgMSwKICAgICAgMSwKICAgICAgMSwKICAgICAgZywKICAgICAgXwogICAgKTsKICAgIHsKICAgICAgY29uc3QgUCA9IHkocy5zcGxhdCwgWwogICAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIFopIH0gfSwKICAgICAgICBELAogICAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVikucmVhZC52aWV3IH0KICAgICAgXSk7CiAgICAgIFgoYiwgcy5zcGxhdCwgUCwgbywgdCh0aGlzLCBWKS53cml0ZS52aWV3KTsKICAgIH0KICAgIHQodGhpcywgVikuc3dhcCgpLCB0KHRoaXMsIGgpLm1vdmVkID0gITE7CiAgfQogIHsKICAgIGNvbnN0IGcgPSB5KHMuZGl2ZXJnZW5jZSwgWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBtZSkgfSB9LAogICAgICBELAogICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIFQpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDMsIHJlc291cmNlOiB2Lm9ic3RhY2xlVmlldyB9CiAgICBdKTsKICAgIFgoYiwgcy5kaXZlcmdlbmNlLCBnLCBvLCB0KHRoaXMsIG9lKS52aWV3KTsKICB9CiAgZm9yIChsZXQgZyA9IDA7IGcgPCB1LnByZXNzdXJlSXRlcmF0aW9uczsgZysrKSB7CiAgICBjb25zdCBfID0geShzLnByZXNzdXJlLCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIGRlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgUSkucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHQodGhpcywgb2UpLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA0LCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMucHJlc3N1cmUsIF8sIG8sIHQodGhpcywgUSkud3JpdGUudmlldyksIHQodGhpcywgUSkuc3dhcCgpOwogIH0KICB7CiAgICBjb25zdCBnID0geShzLmdyYWRpZW50U3VidHJhY3QsIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgaGUpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBRKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiAzLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA0LCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuZ3JhZGllbnRTdWJ0cmFjdCwgZywgbywgdCh0aGlzLCBUKS53cml0ZS52aWV3KTsKICB9CiAgdCh0aGlzLCBUKS5zd2FwKCk7CiAgewogICAgY29uc3QgZyA9IGUuY29udGV4dC5nZXRDdXJyZW50VGV4dHVyZSgpLmNyZWF0ZVZpZXcoKSwgXyA9IHkocy5kaXNwbGF5LCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIFRlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVikucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHYub2JzdGFjbGVWaWV3IH0sCiAgICAgIHsgYmluZGluZzogNCwgcmVzb3VyY2U6IHYuYmFja2dyb3VuZFZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA1LCByZXNvdXJjZTogdi5jb3ZlcmFnZVZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA2LCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBLdChiLCBzLmRpc3BsYXksIF8sIG8sIGcpOwogIH0KICByLnF1ZXVlLnN1Ym1pdChbYi5maW5pc2goKV0pOwp9LCBLZSA9IG5ldyBXZWFrU2V0KCksIGR0ID0gZnVuY3Rpb24oZSwgciwgcywgbywgYSkgewogIGNvbnN0IHYgPSB0KHRoaXMsIE8pLmRldmljZSwgbSA9IHQodGhpcywgRGUpLnNwbGF0LCBjID0gdCh0aGlzLCB2ZSksIHggPSB0KHRoaXMsIF9lKSwgcCA9IHQodGhpcywgdGUpLCBuID0gdCh0aGlzLCBHKSwgZCA9IHQodGhpcywgSSksIGIgPSAxIC8gbiwgeSA9IDEgLyBkLCBEID0gdi5jcmVhdGVDb21tYW5kRW5jb2RlcigpLCBnID0geyBiaW5kaW5nOiAxLCByZXNvdXJjZTogeCB9LCBfID0gKFZlKSA9PiB2LmNyZWF0ZUJpbmRHcm91cCh7IGxheW91dDogbS5nZXRCaW5kR3JvdXBMYXlvdXQoMCksIGVudHJpZXM6IFZlIH0pLCBQID0gZSAqIHQodGhpcywgRikgLyB0KHRoaXMsIHcpLCBrID0gciAqIHQodGhpcywgRikgLyB0KHRoaXMsIFUpOwogICRlKAogICAgdiwKICAgIHQodGhpcywgSiksCiAgICBiLAogICAgeSwKICAgIHQodGhpcywgdykgLyB0KHRoaXMsIFUpLAogICAgcC5zcGxhdFJhZGl1cywKICAgIHMgKiBwLnNwbGF0Rm9yY2UgKiBhLAogICAgbyAqIHAuc3BsYXRGb3JjZSAqIGEsCiAgICAwLAogICAgUCwKICAgIGsKICApOwogIHsKICAgIGNvbnN0IFZlID0gXyhbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIEopIH0gfSwKICAgICAgZywKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBYKEQsIG0sIFZlLCBjLCB0KHRoaXMsIFQpLndyaXRlLnZpZXcpOwogIH0KICB0KHRoaXMsIFQpLnN3YXAoKSwgJGUoCiAgICB2LAogICAgdCh0aGlzLCBaKSwKICAgIGIsCiAgICB5LAogICAgdCh0aGlzLCB3KSAvIHQodGhpcywgVSksCiAgICBwLnNwbGF0UmFkaXVzLAogICAgYSwKICAgIGEsCiAgICBhLAogICAgUCwKICAgIGsKICApOwogIHsKICAgIGNvbnN0IFZlID0gXyhbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIFopIH0gfSwKICAgICAgZywKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBWKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBYKEQsIG0sIFZlLCBjLCB0KHRoaXMsIFYpLndyaXRlLnZpZXcpOwogIH0KICB0KHRoaXMsIFYpLnN3YXAoKSwgdi5xdWV1ZS5zdWJtaXQoW0QuZmluaXNoKCldKTsKfSwgSmUgPSBuZXcgV2Vha1NldCgpLCBodCA9IGZ1bmN0aW9uKGUsIHIsIHMsIG8sIGEpIHsKICBjb25zdCB1ID0gdCh0aGlzLCBNKSwgdiA9IHQodGhpcywgdGUpLCBtID0gdCh0aGlzLCBmZSkuc3BsYXQsIGMgPSB0KHRoaXMsIFVlKTsKICB1LnZpZXdwb3J0KDAsIDAsIHQodGhpcywgRyksIHQodGhpcywgSSkpLCBtLmJpbmQoKSwgdS51bmlmb3JtMWYobS51bmlmb3Jtcy5hc3BlY3RSYXRpbywgdCh0aGlzLCB3KSAvIHQodGhpcywgVSkpLCB1LnVuaWZvcm0yZihtLnVuaWZvcm1zLnBvaW50LCBlICogdCh0aGlzLCBGKSAvIHQodGhpcywgdyksIDEgLSByICogdCh0aGlzLCBGKSAvIHQodGhpcywgVSkpLCB1LnVuaWZvcm0xZihtLnVuaWZvcm1zLnJhZGl1cywgdi5zcGxhdFJhZGl1cyksIHUudW5pZm9ybTFpKG0udW5pZm9ybXMudVRhcmdldCwgMCksIHUuYWN0aXZlVGV4dHVyZSh1LlRFWFRVUkUwKSwgdS5iaW5kVGV4dHVyZSh1LlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCB1LnVuaWZvcm0zZihtLnVuaWZvcm1zLmNvbG9yLCBzICogdi5zcGxhdEZvcmNlICogYSwgLW8gKiB2LnNwbGF0Rm9yY2UgKiBhLCAwKSwgYyh0KHRoaXMsIFIpLndyaXRlLmZibyksIHQodGhpcywgUikuc3dhcCgpLCB1LmFjdGl2ZVRleHR1cmUodS5URVhUVVJFMCksIHUuYmluZFRleHR1cmUodS5URVhUVVJFXzJELCB0KHRoaXMsIEIpLnJlYWQudGV4KSwgdS51bmlmb3JtM2YobS51bmlmb3Jtcy5jb2xvciwgYSwgYSwgYSksIGModCh0aGlzLCBCKS53cml0ZS5mYm8pLCB0KHRoaXMsIEIpLnN3YXAoKTsKfSwgWmUgPSBuZXcgV2Vha1NldCgpLCBndCA9IGZ1bmN0aW9uKCkgewogIGlmICghdCh0aGlzLCBCKSB8fCAhdCh0aGlzLCBSKSkKICAgIHJldHVybjsKICBjb25zdCBlID0gdCh0aGlzLCBNKSwgciA9IHQodGhpcywgdGUpLCB7IGFkdmVjdGlvbjogcywgZGl2ZXJnZW5jZTogbywgcHJlc3N1cmU6IGEsIGdyYWRpZW50U3VidHJhY3Q6IHUsIHNwbGF0OiB2LCBjdXJsOiBtLCB2b3J0aWNpdHk6IGMsIGRpc3BsYXk6IHggfSA9IHQodGhpcywgZmUpOwogIHQodGhpcywgaCkueCArPSAodCh0aGlzLCBoKS50YXJnZXRYIC0gdCh0aGlzLCBoKS54KSAqIDAuMTUsIHQodGhpcywgaCkueSArPSAodCh0aGlzLCBoKS50YXJnZXRZIC0gdCh0aGlzLCBoKS55KSAqIDAuMTU7CiAgY29uc3QgcCA9IHQodGhpcywgRyksIG4gPSB0KHRoaXMsIEkpLCBkID0gdCh0aGlzLCBVZSk7CiAgZS52aWV3cG9ydCgwLCAwLCBwLCBuKSwgcy5iaW5kKCksIGUudW5pZm9ybTJmKHMudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gcCwgMSAvIG4pLCBlLnVuaWZvcm0xZihzLnVuaWZvcm1zLmR0LCBPZSksIGUudW5pZm9ybTFpKHMudW5pZm9ybXMudU9ic3RhY2xlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBMKSksIGUudW5pZm9ybTFmKHMudW5pZm9ybXMuZGlzc2lwYXRpb24sIHIudmVsb2NpdHlEaXNzaXBhdGlvbiksIGUudW5pZm9ybTFpKHMudW5pZm9ybXMudVZlbG9jaXR5LCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBSKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKHMudW5pZm9ybXMudVNvdXJjZSwgMSksIGQodCh0aGlzLCBSKS53cml0ZS5mYm8pLCB0KHRoaXMsIFIpLnN3YXAoKSwgZS51bmlmb3JtMWYocy51bmlmb3Jtcy5kaXNzaXBhdGlvbiwgci5kZW5zaXR5RGlzc2lwYXRpb24pLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVTb3VyY2UsIDIpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEIpLnJlYWQudGV4KSwgZCh0KHRoaXMsIEIpLndyaXRlLmZibyksIHQodGhpcywgQikuc3dhcCgpLCBtLmJpbmQoKSwgZS51bmlmb3JtMmYobS51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyBwLCAxIC8gbiksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudVZlbG9jaXR5LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBSKS5yZWFkLnRleCksIGQodCh0aGlzLCBIKS5mYm8pLCBjLmJpbmQoKSwgZS51bmlmb3JtMmYoYy51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyBwLCAxIC8gbiksIGUudW5pZm9ybTFmKGMudW5pZm9ybXMuY3VybCwgci5jdXJsKSwgZS51bmlmb3JtMWYoYy51bmlmb3Jtcy5kdCwgT2UpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVWZWxvY2l0eSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVDdXJsLCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBIKS50ZXgpLCBkKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIHQodGhpcywgaCkubW92ZWQgJiYgKHYuYmluZCgpLCBlLnVuaWZvcm0xZih2LnVuaWZvcm1zLmFzcGVjdFJhdGlvLCB0KHRoaXMsIHcpIC8gdCh0aGlzLCBVKSksIGUudW5pZm9ybTJmKHYudW5pZm9ybXMucG9pbnQsIHQodGhpcywgaCkueCAqIHQodGhpcywgRikgLyB0KHRoaXMsIHcpLCAxIC0gdCh0aGlzLCBoKS55ICogdCh0aGlzLCBGKSAvIHQodGhpcywgVSkpLCBlLnVuaWZvcm0xZih2LnVuaWZvcm1zLnJhZGl1cywgci5zcGxhdFJhZGl1cyksIGUudW5pZm9ybTFpKHYudW5pZm9ybXMudVRhcmdldCwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBlLnVuaWZvcm0zZih2LnVuaWZvcm1zLmNvbG9yLCB0KHRoaXMsIGgpLmR4ICogci5zcGxhdEZvcmNlLCAtdCh0aGlzLCBoKS5keSAqIHIuc3BsYXRGb3JjZSwgMCksIGQodCh0aGlzLCBSKS53cml0ZS5mYm8pLCB0KHRoaXMsIFIpLnN3YXAoKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBCKS5yZWFkLnRleCksIGUudW5pZm9ybTNmKHYudW5pZm9ybXMuY29sb3IsIDEsIDEsIDEpLCBkKHQodGhpcywgQikud3JpdGUuZmJvKSwgdCh0aGlzLCBCKS5zd2FwKCksIHQodGhpcywgaCkubW92ZWQgPSAhMSksIG8uYmluZCgpLCBlLnVuaWZvcm0yZihvLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHAsIDEgLyBuKSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51VmVsb2NpdHksIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKSwgZCh0KHRoaXMsICQpLmZibyksIGEuYmluZCgpLCBlLnVuaWZvcm0yZihhLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHAsIDEgLyBuKSwgZS51bmlmb3JtMWkoYS51bmlmb3Jtcy51RGl2ZXJnZW5jZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgJCkudGV4KSwgZS51bmlmb3JtMWkoYS51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKTsKICBmb3IgKGxldCBiID0gMDsgYiA8IHIucHJlc3N1cmVJdGVyYXRpb25zOyBiKyspCiAgICBlLnVuaWZvcm0xaShhLnVuaWZvcm1zLnVQcmVzc3VyZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgcSkucmVhZC50ZXgpLCBkKHQodGhpcywgcSkud3JpdGUuZmJvKSwgdCh0aGlzLCBxKS5zd2FwKCk7CiAgdS5iaW5kKCksIGUudW5pZm9ybTJmKHUudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gcCwgMSAvIG4pLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVQcmVzc3VyZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgcSkucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVWZWxvY2l0eSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVPYnN0YWNsZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgTCkpLCBkKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIGUudmlld3BvcnQoMCwgMCwgdCh0aGlzLCB3KSwgdCh0aGlzLCBVKSksIGUuYmluZEZyYW1lYnVmZmVyKGUuRlJBTUVCVUZGRVIsIG51bGwpLCBlLmNsZWFyKGUuQ09MT1JfQlVGRkVSX0JJVCksIHguYmluZCgpLCBlLnVuaWZvcm0yZih4LnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHQodGhpcywgdyksIDEgLyB0KHRoaXMsIFUpKSwgZS51bmlmb3JtM2Z2KHgudW5pZm9ybXMudVdhdGVyQ29sb3IsIFdlKHIud2F0ZXJDb2xvcikpLCBlLnVuaWZvcm0zZnYoeC51bmlmb3Jtcy51R2xvd0NvbG9yLCBXZShyLmdsb3dDb2xvcikpLCBlLnVuaWZvcm0xZih4LnVuaWZvcm1zLnVSZWZyYWN0aW9uLCByLnJlZnJhY3Rpb24pLCBlLnVuaWZvcm0xZih4LnVuaWZvcm1zLnVTcGVjdWxhckV4cCwgci5zcGVjdWxhckV4cCksIGUudW5pZm9ybTFmKHgudW5pZm9ybXMudVNoaW5lLCByLnNoaW5lKSwgZS51bmlmb3JtMWYoeC51bmlmb3Jtcy51V2FycFN0cmVuZ3RoLCByLndhcnBTdHJlbmd0aCA/PyAwLjAxNSksIGUudW5pZm9ybTFpKHgudW5pZm9ybXMudUFsZ29yaXRobSwgZnRbci5hbGdvcml0aG1dID8/IDApLCBlLnVuaWZvcm0xaSh4LnVuaWZvcm1zLnVFbmFibGVBbHBoYSwgdCh0aGlzLCBTZSkgPyAxIDogMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgQikucmVhZC50ZXgpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTIpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBLKSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUzKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgWSkpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFNCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkoeC51bmlmb3Jtcy51VGV4dHVyZSwgMCksIGUudW5pZm9ybTFpKHgudW5pZm9ybXMudU9ic3RhY2xlLCAxKSwgZS51bmlmb3JtMWkoeC51bmlmb3Jtcy51QmFja2dyb3VuZCwgMiksIGUudW5pZm9ybTFpKHgudW5pZm9ybXMudUNvdmVyYWdlLCAzKSwgZS51bmlmb3JtMWkoeC51bmlmb3Jtcy51VmVsb2NpdHksIDQpLCBkKG51bGwpOwp9OwpsZXQgaXQgPSB1dCwgRSA9IG51bGwsIGJ0Owpjb25zdCBOID0gbmV3IFByb21pc2UoKGkpID0+IHsKICBidCA9IGk7Cn0pOwpzZWxmLm9ubWVzc2FnZSA9IGFzeW5jIChpKSA9PiB7CiAgY29uc3QgeyB0eXBlOiBlLCAuLi5yIH0gPSBpLmRhdGE7CiAgdHJ5IHsKICAgIHN3aXRjaCAoZSkgewogICAgICBjYXNlICJpbml0IjogewogICAgICAgIGNvbnN0IHsgY2FudmFzOiBzLCB3aWR0aDogbywgaGVpZ2h0OiBhLCBjb25maWc6IHUsIGRwcjogdiwgcXVhbGl0eTogbSwgdXNlV2ViR1BVOiBjLCBlbmFibGVBbHBoYTogeCB9ID0gcjsKICAgICAgICBzLndpZHRoID0gbywgcy5oZWlnaHQgPSBhLCBFID0gYXdhaXQgaXQuY3JlYXRlKHMsIHUsIG0gPz8ge30sIGMgPz8gITAsIHggPz8gITApLCBFLnJlc2l6ZShvLCBhLCB2IHx8IDEpLCBidCgpLCBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogInJlYWR5IiB9KTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRUZXh0U291cmNlIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnNldFRleHRTb3VyY2Uoci5vcHRzKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRJbWFnZVNvdXJjZSI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgYXdhaXQgRS5zZXRJbWFnZVNvdXJjZSgKICAgICAgICAgIHIuc3JjLAogICAgICAgICAgci5lZmZlY3QsCiAgICAgICAgICByLnNpemUKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNldEltYWdlQml0bWFwIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnNldEltYWdlQml0bWFwKAogICAgICAgICAgci5iaXRtYXAsCiAgICAgICAgICByLmVmZmVjdCwKICAgICAgICAgIHIuc2l6ZQogICAgICAgICk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0QmFja2dyb3VuZCI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS5zZXRCYWNrZ3JvdW5kKHIuYml0bWFwLCByLnNpemUpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNwbGF0IjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnNwbGF0KAogICAgICAgICAgci54LAogICAgICAgICAgci55LAogICAgICAgICAgci52eCwKICAgICAgICAgIHIudnksCiAgICAgICAgICByLnN0cmVuZ3RoID8/IDEKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgIm1vdmUiOiB7CiAgICAgICAgaWYgKGF3YWl0IE4sICFFKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIEUuaGFuZGxlTW92ZShyLngsIHIueSwgci5zdHJlbmd0aCA/PyAxKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJyZXNpemUiOiB7CiAgICAgICAgaWYgKGF3YWl0IE4sICFFKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIEUucmVzaXplKHIud2lkdGgsIHIuaGVpZ2h0LCByLmRwcik7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlUXVhbGl0eSI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS51cGRhdGVRdWFsaXR5KHIucXVhbGl0eSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlQ29uZmlnIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnVwZGF0ZUNvbmZpZyhyLmNvbmZpZyk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAiZGVzdHJveSI6IHsKICAgICAgICBhd2FpdCBOLCBFID09IG51bGwgfHwgRS5kZXN0cm95KCksIEUgPSBudWxsOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGRlZmF1bHQ6CiAgICAgICAgY29uc29sZS53YXJuKCJbZmx1aWRpdHktanMgd29ya2VyXSBVbmtub3duIG1lc3NhZ2UgdHlwZToiLCBlKTsKICAgIH0KICB9IGNhdGNoIChzKSB7CiAgICBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogImVycm9yIiwgbWVzc2FnZTogKHMgPT0gbnVsbCA/IHZvaWQgMCA6IHMubWVzc2FnZSkgPz8gU3RyaW5nKHMpIH0pOwogIH0KfTsK", fI = typeof window < "u" && window.Blob && new Blob([atob(jI)], { type: "text/javascript;charset=utf-8" });
1566
+ function YC() {
1567
+ let e;
682
1568
  try {
683
- if (C = JI && (window.URL || window.webkitURL).createObjectURL(JI), !C)
1569
+ if (e = fI && (window.URL || window.webkitURL).createObjectURL(fI), !e)
684
1570
  throw "";
685
- return new Worker(C);
1571
+ return new Worker(e);
686
1572
  } catch {
687
- return new Worker("data:application/javascript;base64," + PI, { type: "module" });
1573
+ return new Worker("data:application/javascript;base64," + jI, { type: "module" });
688
1574
  } finally {
689
- C && (window.URL || window.webkitURL).revokeObjectURL(C);
1575
+ e && (window.URL || window.webkitURL).revokeObjectURL(e);
690
1576
  }
691
1577
  }
692
- const hg = typeof Worker < "u" && typeof OffscreenCanvas < "u";
693
- var p, U, ZI, T, O, XI, _I;
694
- class Bg {
695
- constructor(I, {
696
- isWorkerEnabled: i = !0,
697
- quality: e = {},
698
- config: s = {}
1578
+ const kC = typeof Worker < "u" && typeof OffscreenCanvas < "u";
1579
+ var R, x, Og, Eg, Fg, P, dg, wg, Lg, tI, HI, rI, PI;
1580
+ class MC {
1581
+ constructor(g, {
1582
+ isWorkerEnabled: C = !0,
1583
+ useWebGPU: i = !0,
1584
+ enableAlpha: s = !0,
1585
+ quality: l = {},
1586
+ config: t = {}
699
1587
  } = {}) {
700
1588
  // ---------------------------------------------------------------------------
701
1589
  // Private
702
1590
  // ---------------------------------------------------------------------------
703
- m(this, XI);
704
- m(this, p, null);
705
- m(this, U, null);
706
- m(this, ZI, void 0);
707
- m(this, T, void 0);
708
- m(this, O, void 0);
709
- l(this, T, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, O, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, ZI, i && hg), g(this, ZI) ? b(this, XI, _I).call(this, I, s) : l(this, U, new EI(I, s, { dpr: g(this, T), sim: g(this, O) }));
1591
+ /**
1592
+ * Main-thread renderer init.
1593
+ *
1594
+ * When `navigator.gpu` is present we attempt WebGPU asynchronously and
1595
+ * queue any source calls that arrive before the init resolves.
1596
+ *
1597
+ * When `navigator.gpu` is absent we fall back to WebGL synchronously
1598
+ * this is the common path in jsdom/test environments and keeps the
1599
+ * constructor behaviour synchronous where possible.
1600
+ */
1601
+ d(this, tI);
1602
+ d(this, rI);
1603
+ d(this, R, null);
1604
+ d(this, x, null);
1605
+ d(this, Og, void 0);
1606
+ d(this, Eg, void 0);
1607
+ d(this, Fg, void 0);
1608
+ d(this, P, void 0);
1609
+ d(this, dg, void 0);
1610
+ // Pending source calls queued while WebGPU async init is in progress (main-thread only)
1611
+ d(this, wg, null);
1612
+ d(this, Lg, null);
1613
+ o(this, P, Math.max(0.1, Math.min(1, l.dpr ?? 1))), o(this, dg, Math.max(0.1, Math.min(1, l.sim ?? 0.5))), o(this, Eg, i), o(this, Fg, s), o(this, Og, C && kC), I(this, Og) ? h(this, rI, PI).call(this, g, t) : h(this, tI, HI).call(this, g, t);
710
1614
  }
711
1615
  // ---------------------------------------------------------------------------
712
1616
  // Source setters
713
1617
  // ---------------------------------------------------------------------------
714
- setTextSource(I) {
715
- g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, U).setTextSource(I);
1618
+ setTextSource(g) {
1619
+ I(this, R) ? I(this, R).postMessage({ type: "setTextSource", opts: g }) : I(this, x) ? I(this, x).setTextSource(g) : (o(this, wg, g), o(this, Lg, null));
716
1620
  }
717
- setImageSource(I, i = iI.effect, e = iI.imageSize) {
718
- if (g(this, p)) {
719
- const s = new URL(I, location.href).href;
720
- g(this, p).postMessage({ type: "setImageSource", src: s, effect: i, size: e });
1621
+ setImageSource(g, C = ng.effect, i = ng.imageSize) {
1622
+ if (I(this, R)) {
1623
+ const s = new URL(g, location.href).href;
1624
+ I(this, R).postMessage({ type: "setImageSource", src: s, effect: C, size: i });
721
1625
  } else
722
- g(this, U).setImageSource(I, i, e);
1626
+ I(this, x) ? I(this, x).setImageSource(g, C, i) : (o(this, Lg, { src: g, effect: C, size: i }), o(this, wg, null));
723
1627
  }
724
- setBackground(I, i = "cover") {
725
- var e;
726
- if (g(this, p)) {
727
- const s = I ? [I] : [];
728
- g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, s);
1628
+ setBackground(g, C = "cover") {
1629
+ var i;
1630
+ if (I(this, R)) {
1631
+ const s = g ? [g] : [];
1632
+ I(this, R).postMessage({ type: "setBackground", bitmap: g ?? null, size: C }, s);
729
1633
  } else
730
- (e = g(this, U)) == null || e.setBackground(I ?? null, i);
1634
+ (i = I(this, x)) == null || i.setBackground(g ?? null, C);
731
1635
  }
732
1636
  // ---------------------------------------------------------------------------
733
1637
  // Interaction
@@ -736,291 +1640,323 @@ class Bg {
736
1640
  * Immediately injects one splat at (x, y) with explicit velocity (vx, vy).
737
1641
  * Safe to call multiple times per frame. See FluidSimulation.splat for details.
738
1642
  */
739
- splat(I, i, e, s, o = 1) {
740
- g(this, p) ? g(this, p).postMessage({ type: "splat", x: I, y: i, vx: e, vy: s, strength: o }) : g(this, U).splat(I, i, e, s, o);
1643
+ splat(g, C, i, s, l = 1) {
1644
+ I(this, R) ? I(this, R).postMessage({ type: "splat", x: g, y: C, vx: i, vy: s, strength: l }) : I(this, x).splat(g, C, i, s, l);
741
1645
  }
742
- handleMove(I, i, e = 1) {
743
- g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this, U).handleMove(I, i, e);
1646
+ handleMove(g, C, i = 1) {
1647
+ I(this, R) ? I(this, R).postMessage({ type: "move", x: g, y: C, strength: i }) : I(this, x).handleMove(g, C, i);
744
1648
  }
745
1649
  // ---------------------------------------------------------------------------
746
1650
  // Config + control
747
1651
  // ---------------------------------------------------------------------------
748
- updateQuality(I) {
749
- l(this, T, Math.max(0.1, Math.min(1, I.dpr ?? g(this, T)))), l(this, O, Math.max(0.1, Math.min(1, I.sim ?? g(this, O)))), g(this, p) ? g(this, p).postMessage({ type: "updateQuality", quality: { dpr: g(this, T), sim: g(this, O) } }) : g(this, U).updateQuality(I);
1652
+ updateQuality(g) {
1653
+ o(this, P, Math.max(0.1, Math.min(1, g.dpr ?? I(this, P)))), o(this, dg, Math.max(0.1, Math.min(1, g.sim ?? I(this, dg)))), I(this, R) ? I(this, R).postMessage({ type: "updateQuality", quality: { dpr: I(this, P), sim: I(this, dg) } }) : I(this, x).updateQuality(g);
750
1654
  }
751
- updateConfig(I) {
752
- g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, U).updateConfig(I);
1655
+ updateConfig(g) {
1656
+ I(this, R) ? I(this, R).postMessage({ type: "updateConfig", config: g }) : I(this, x).updateConfig(g);
753
1657
  }
754
- resize(I, i) {
755
- const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T);
756
- g(this, p) ? g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e }) : g(this, U).resize(I, i, e);
1658
+ resize(g, C) {
1659
+ const i = (typeof window < "u" && window.devicePixelRatio || 1) * I(this, P);
1660
+ I(this, R) ? I(this, R).postMessage({ type: "resize", width: g, height: C, dpr: i }) : I(this, x).resize(g, C, i);
757
1661
  }
758
1662
  destroy() {
759
- var I;
760
- if (g(this, p)) {
761
- const i = g(this, p);
762
- l(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
1663
+ var g;
1664
+ if (I(this, R)) {
1665
+ const C = I(this, R);
1666
+ o(this, R, null), C.postMessage({ type: "destroy" }), setTimeout(() => C.terminate(), 50);
763
1667
  } else
764
- (I = g(this, U)) == null || I.destroy(), l(this, U, null);
1668
+ (g = I(this, x)) == null || g.destroy(), o(this, x, null);
765
1669
  }
766
1670
  }
767
- p = new WeakMap(), U = new WeakMap(), ZI = new WeakMap(), T = new WeakMap(), O = new WeakMap(), XI = new WeakSet(), _I = function(I, i) {
768
- const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T), s = Math.round(I.clientWidth * e), o = Math.round(I.clientHeight * e);
769
- I.width = s, I.height = o;
1671
+ R = new WeakMap(), x = new WeakMap(), Og = new WeakMap(), Eg = new WeakMap(), Fg = new WeakMap(), P = new WeakMap(), dg = new WeakMap(), wg = new WeakMap(), Lg = new WeakMap(), tI = new WeakSet(), HI = function(g, C) {
1672
+ const i = { dpr: I(this, P), sim: I(this, dg) };
1673
+ I(this, Eg) && typeof navigator < "u" && !!navigator.gpu ? ZI.create(g, C, i, !0, I(this, Fg)).then((l) => {
1674
+ if (o(this, x, l), I(this, wg))
1675
+ l.setTextSource(I(this, wg)), o(this, wg, null);
1676
+ else if (I(this, Lg)) {
1677
+ const { src: t, effect: a, size: u } = I(this, Lg);
1678
+ l.setImageSource(t, a, u), o(this, Lg, null);
1679
+ }
1680
+ }).catch((l) => {
1681
+ console.error("[fluidity-js] Renderer init failed:", l);
1682
+ }) : o(this, x, new ZI(g, C, i, void 0, I(this, Fg)));
1683
+ }, rI = new WeakSet(), PI = function(g, C) {
1684
+ const i = (typeof window < "u" && window.devicePixelRatio || 1) * I(this, P), s = Math.round(g.clientWidth * i), l = Math.round(g.clientHeight * i);
1685
+ g.width = s, g.height = l;
770
1686
  let t;
771
1687
  try {
772
- t = I.transferControlToOffscreen();
1688
+ t = g.transferControlToOffscreen();
773
1689
  } catch {
774
1690
  console.warn(
775
1691
  "[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
776
- ), l(this, ZI, !1), l(this, U, new EI(I, i, { dpr: g(this, T), sim: g(this, O) }));
1692
+ ), o(this, Og, !1), h(this, tI, HI).call(this, g, C);
777
1693
  return;
778
1694
  }
779
- const u = l(this, p, new Gg());
780
- u.onerror = (a) => {
781
- console.error("[fluidity-js] Worker error:", a.message);
782
- }, u.onmessage = (a) => {
783
- a.data.type === "error" && console.error("[fluidity-js] Simulation error:", a.data.message);
784
- }, u.postMessage(
785
- { type: "init", canvas: t, width: s, height: o, config: i, dpr: e, quality: { dpr: g(this, T), sim: g(this, O) } },
1695
+ const a = o(this, R, new YC());
1696
+ a.onerror = (u) => {
1697
+ console.error("[fluidity-js] Worker error:", u.message);
1698
+ }, a.onmessage = (u) => {
1699
+ u.data.type === "error" && console.error("[fluidity-js] Simulation error:", u.data.message);
1700
+ }, a.postMessage(
1701
+ { type: "init", canvas: t, width: s, height: l, config: C, dpr: i, quality: { dpr: I(this, P), sim: I(this, dg) }, useWebGPU: I(this, Eg), enableAlpha: I(this, Fg) },
786
1702
  [t]
787
1703
  );
788
1704
  };
789
- function qI(C, { isWorkerEnabled: I = !0, quality: i = {}, config: e = {} } = {}) {
790
- const s = mI(null), o = mI({ isWorkerEnabled: I, quality: i, config: e }), t = mI(Math.max(0.1, Math.min(1, i.dpr ?? 1))), u = mI({
791
- dpr: i.dpr,
792
- sim: i.sim
1705
+ function _I(e, {
1706
+ isWorkerEnabled: g = !0,
1707
+ useWebGPU: C = !0,
1708
+ enableAlpha: i = !0,
1709
+ quality: s = {},
1710
+ config: l = {}
1711
+ } = {}) {
1712
+ const t = Tg(null), a = Tg({ isWorkerEnabled: g, quality: s, config: l }), u = Tg(Math.max(0.1, Math.min(1, s.dpr ?? 1))), c = Tg({
1713
+ dpr: s.dpr,
1714
+ sim: s.sim
793
1715
  });
794
- return j(() => {
795
- const a = C.current;
796
- if (!a)
1716
+ return sg(() => {
1717
+ const Z = e.current;
1718
+ if (!Z)
797
1719
  return;
798
- const c = document.createElement("canvas");
799
- c.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", a.appendChild(c);
800
- const { isWorkerEnabled: n, quality: G, config: d } = o.current, h = (window.devicePixelRatio || 1) * t.current, W = a.getBoundingClientRect(), x = Math.round((W.width || a.clientWidth) * h) || 0, F = Math.round((W.height || a.clientHeight) * h) || 0;
801
- x > 0 && (c.width = x, c.height = F), F === 0 && console.warn(
1720
+ const S = document.createElement("canvas");
1721
+ S.id = `fluid_canvas_${Date.now()}`, S.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", Z.appendChild(S);
1722
+ const { isWorkerEnabled: A, quality: B, config: m } = a.current, r = (window.devicePixelRatio || 1) * u.current, L = Z.getBoundingClientRect(), G = Math.round((L.width || Z.clientWidth) * r) || 0, K = Math.round((L.height || Z.clientHeight) * r) || 0;
1723
+ G > 0 && (S.width = G, S.height = K), K === 0 && console.warn(
802
1724
  "[fluidity-js] Container has zero height — simulation will not render. Avoid height:auto or percentage heights without a sized ancestor. Use explicit pixel values instead."
803
1725
  );
804
- const w = new Bg(c, { isWorkerEnabled: n, quality: G, config: d });
805
- s.current = w;
806
- const D = new ResizeObserver((A) => {
807
- for (const y of A) {
808
- const r = (window.devicePixelRatio || 1) * t.current, { inlineSize: Z, blockSize: V } = y.contentBoxSize[0];
809
- w.resize(Math.round(Z * r), Math.round(V * r));
1726
+ const b = new MC(S, {
1727
+ isWorkerEnabled: A,
1728
+ useWebGPU: C,
1729
+ enableAlpha: i,
1730
+ quality: B,
1731
+ config: m
1732
+ });
1733
+ t.current = b;
1734
+ const Y = new ResizeObserver((n) => {
1735
+ for (const F of n) {
1736
+ const p = (window.devicePixelRatio || 1) * u.current, { inlineSize: V, blockSize: W } = F.contentBoxSize[0];
1737
+ b.resize(Math.round(V * p), Math.round(W * p));
810
1738
  }
811
1739
  });
812
- return D.observe(a), () => {
813
- D.disconnect(), w.destroy(), c.remove(), s.current = null;
1740
+ return Y.observe(Z), () => {
1741
+ Y.disconnect(), b.destroy(), S.remove(), t.current = null;
814
1742
  };
815
- }, []), j(() => {
816
- t.current = Math.max(0.1, Math.min(1, i.dpr ?? 1));
817
- const a = u.current;
818
- u.current = { dpr: i.dpr, sim: i.sim };
819
- const c = s.current, n = C.current;
820
- if (!c || !n || a.dpr === i.dpr && a.sim === i.sim)
1743
+ }, [C, i]), sg(() => {
1744
+ u.current = Math.max(0.1, Math.min(1, s.dpr ?? 1));
1745
+ const Z = c.current;
1746
+ c.current = { dpr: s.dpr, sim: s.sim };
1747
+ const S = t.current, A = e.current;
1748
+ if (!S || !A || Z.dpr === s.dpr && Z.sim === s.sim)
821
1749
  return;
822
- c.updateQuality(i);
823
- const G = (window.devicePixelRatio || 1) * t.current, d = n.clientWidth, h = n.clientHeight;
824
- d > 0 && h > 0 && c.resize(Math.round(d * G), Math.round(h * G));
825
- }, [i.dpr, i.sim]), s;
1750
+ S.updateQuality(s);
1751
+ const B = (window.devicePixelRatio || 1) * u.current, m = A.clientWidth, r = A.clientHeight;
1752
+ m > 0 && r > 0 && S.resize(Math.round(m * B), Math.round(r * B));
1753
+ }, [s.dpr, s.sim, C, i]), t;
826
1754
  }
827
- const Lg = zI(function({
828
- text: I,
829
- fontSize: i = $.fontSize,
830
- color: e = $.color,
831
- fontFamily: s = $.fontFamily,
832
- fontWeight: o = $.fontWeight,
1755
+ const DC = FI(function({
1756
+ text: g,
1757
+ fontSize: C = ag.fontSize,
1758
+ color: i = ag.color,
1759
+ fontFamily: s = ag.fontFamily,
1760
+ fontWeight: l = ag.fontWeight,
833
1761
  className: t,
834
- style: u,
835
- config: a,
1762
+ style: a,
1763
+ config: u,
836
1764
  preset: c,
837
- algorithm: n,
838
- backgroundColor: G = $.backgroundColor,
839
- backgroundSrc: d,
840
- backgroundSize: h = $.backgroundSize,
841
- isMouseEnabled: W = $.isMouseEnabled,
842
- isWorkerEnabled: x = $.isWorkerEnabled,
843
- quality: F = HI.quality
844
- }, w) {
845
- const D = mI(null), A = qI(D, {
846
- isWorkerEnabled: x,
847
- quality: F,
848
- config: pI({ ...a, ...n ? { algorithm: n } : {} }, c, TI)
1765
+ algorithm: Z,
1766
+ backgroundColor: S = ag.backgroundColor,
1767
+ backgroundSrc: A,
1768
+ backgroundSize: B = ag.backgroundSize,
1769
+ isMouseEnabled: m = ag.isMouseEnabled,
1770
+ isWorkerEnabled: r = ag.isWorkerEnabled,
1771
+ useWebGPU: L = !0,
1772
+ enableAlpha: G = !0,
1773
+ quality: K = wI.quality
1774
+ }, b) {
1775
+ const Y = Tg(null), n = _I(Y, {
1776
+ isWorkerEnabled: r,
1777
+ useWebGPU: L,
1778
+ enableAlpha: G,
1779
+ quality: K,
1780
+ config: II({ ...u, ...Z ? { algorithm: Z } : {} }, c, UI)
849
1781
  });
850
- QI(
851
- w,
1782
+ DI(
1783
+ b,
852
1784
  () => ({
853
1785
  reset() {
854
- var r;
855
- (r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
1786
+ var p;
1787
+ (p = n.current) == null || p.setTextSource({ text: g, fontSize: C, color: i, fontFamily: s, fontWeight: l });
856
1788
  },
857
- move(r, Z, V = 1) {
858
- var S;
859
- (S = A.current) == null || S.handleMove(r, Z, V);
1789
+ move(p, V, W = 1) {
1790
+ var U;
1791
+ (U = n.current) == null || U.handleMove(p, V, W);
860
1792
  },
861
- splat(r, Z, V, S, M = 1) {
862
- var q;
863
- (q = A.current) == null || q.splat(r, Z, V, S, M);
1793
+ splat(p, V, W, U, _ = 1) {
1794
+ var Sg;
1795
+ (Sg = n.current) == null || Sg.splat(p, V, W, U, _);
864
1796
  },
865
- updateConfig(r) {
866
- var Z;
867
- (Z = A.current) == null || Z.updateConfig(r);
1797
+ updateConfig(p) {
1798
+ var V;
1799
+ (V = n.current) == null || V.updateConfig(p);
868
1800
  }
869
1801
  }),
870
- [I, i, e, s, o]
871
- ), j(() => {
872
- var r;
873
- (r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
874
- }, [I, i, e, s, o]);
875
- const y = JSON.stringify(a);
876
- return j(() => {
877
- var r;
878
- (r = A.current) == null || r.updateConfig(
879
- pI({ ...a, ...n !== void 0 ? { algorithm: n } : {} }, c, TI)
1802
+ [g, C, i, s, l]
1803
+ ), sg(() => {
1804
+ var p;
1805
+ (p = n.current) == null || p.setTextSource({ text: g, fontSize: C, color: i, fontFamily: s, fontWeight: l });
1806
+ }, [g, C, i, s, l, L, G]);
1807
+ const F = JSON.stringify(u);
1808
+ return sg(() => {
1809
+ var p;
1810
+ (p = n.current) == null || p.updateConfig(
1811
+ II({ ...u, ...Z !== void 0 ? { algorithm: Z } : {} }, c, UI)
880
1812
  );
881
- }, [c, n, y]), j(() => {
882
- var Z;
883
- if (!d) {
884
- (Z = A.current) == null || Z.setBackground(null);
1813
+ }, [c, Z, F, L, G]), sg(() => {
1814
+ var V;
1815
+ if (!A) {
1816
+ (V = n.current) == null || V.setBackground(null);
885
1817
  return;
886
1818
  }
887
- let r = !1;
888
- return kI(d).then((V) => {
889
- var S;
890
- if (r) {
891
- V.close();
1819
+ let p = !1;
1820
+ return XI(A).then((W) => {
1821
+ var U;
1822
+ if (p) {
1823
+ W.close();
892
1824
  return;
893
1825
  }
894
- (S = A.current) == null || S.setBackground(V, h);
895
- }).catch((V) => console.error("[fluidity-js] backgroundSrc load failed:", V)), () => {
896
- r = !0;
1826
+ (U = n.current) == null || U.setBackground(W, B);
1827
+ }).catch((W) => console.error("[fluidity-js] backgroundSrc load failed:", W)), () => {
1828
+ p = !0;
897
1829
  };
898
- }, [d, h]), j(() => {
899
- if (!W)
1830
+ }, [A, B, L, G]), sg(() => {
1831
+ if (!m)
900
1832
  return;
901
- const r = D.current;
902
- if (!r)
1833
+ const p = Y.current;
1834
+ if (!p)
903
1835
  return;
904
- const Z = (S) => {
905
- var q;
906
- const M = r.getBoundingClientRect();
907
- (q = A.current) == null || q.handleMove(S.clientX - M.left, S.clientY - M.top, 2);
908
- }, V = (S) => {
909
- var fI;
910
- S.preventDefault();
911
- const M = r.getBoundingClientRect(), q = S.touches[0];
912
- (fI = A.current) == null || fI.handleMove(q.clientX - M.left, q.clientY - M.top, 1);
1836
+ const V = (U) => {
1837
+ var Sg;
1838
+ const _ = p.getBoundingClientRect();
1839
+ (Sg = n.current) == null || Sg.handleMove(U.clientX - _.left, U.clientY - _.top, 2);
1840
+ }, W = (U) => {
1841
+ var RI;
1842
+ U.preventDefault();
1843
+ const _ = p.getBoundingClientRect(), Sg = U.touches[0];
1844
+ (RI = n.current) == null || RI.handleMove(Sg.clientX - _.left, Sg.clientY - _.top, 1);
913
1845
  };
914
- return r.addEventListener("mousemove", Z), r.addEventListener("touchmove", V, { passive: !1 }), () => {
915
- r.removeEventListener("mousemove", Z), r.removeEventListener("touchmove", V);
1846
+ return p.addEventListener("mousemove", V), p.addEventListener("touchmove", W, { passive: !1 }), () => {
1847
+ p.removeEventListener("mousemove", V), p.removeEventListener("touchmove", W);
916
1848
  };
917
- }, [W]), /* @__PURE__ */ NI(
1849
+ }, [m]), /* @__PURE__ */ xI(
918
1850
  "div",
919
1851
  {
920
- ref: D,
1852
+ ref: Y,
921
1853
  className: t,
922
1854
  style: {
923
1855
  position: "relative",
924
1856
  display: "block",
925
1857
  width: "100%",
926
1858
  height: "100%",
927
- background: G,
928
- ...u
1859
+ background: S,
1860
+ ...a
929
1861
  }
930
1862
  }
931
1863
  );
932
- }), Vg = zI(function({
933
- src: I,
934
- effect: i = iI.effect,
935
- imageSize: e = iI.imageSize,
1864
+ }), TC = FI(function({
1865
+ src: g,
1866
+ effect: C = ng.effect,
1867
+ imageSize: i = ng.imageSize,
936
1868
  className: s,
937
- style: o,
1869
+ style: l,
938
1870
  config: t,
939
- preset: u,
940
- algorithm: a,
941
- backgroundColor: c = iI.backgroundColor,
942
- backgroundSrc: n,
943
- backgroundSize: G = iI.backgroundSize,
944
- isMouseEnabled: d = iI.isMouseEnabled,
945
- isWorkerEnabled: h = iI.isWorkerEnabled,
946
- quality: W = HI.quality
947
- }, x) {
948
- const F = mI(null), w = qI(F, {
949
- isWorkerEnabled: h,
950
- quality: W,
951
- config: pI({ ...t, ...a ? { algorithm: a } : {} }, u)
1871
+ preset: a,
1872
+ algorithm: u,
1873
+ backgroundColor: c = ng.backgroundColor,
1874
+ backgroundSrc: Z,
1875
+ backgroundSize: S = ng.backgroundSize,
1876
+ isMouseEnabled: A = ng.isMouseEnabled,
1877
+ isWorkerEnabled: B = ng.isWorkerEnabled,
1878
+ useWebGPU: m = !0,
1879
+ enableAlpha: r = !0,
1880
+ quality: L = wI.quality
1881
+ }, G) {
1882
+ const K = Tg(null), b = _I(K, {
1883
+ isWorkerEnabled: B,
1884
+ useWebGPU: m,
1885
+ enableAlpha: r,
1886
+ quality: L,
1887
+ config: II({ ...t, ...u ? { algorithm: u } : {} }, a)
952
1888
  });
953
- QI(
954
- x,
1889
+ DI(
1890
+ G,
955
1891
  () => ({
956
1892
  reset() {
957
- var A;
958
- I && ((A = w.current) == null || A.setImageSource(I, i, e));
1893
+ var n;
1894
+ g && ((n = b.current) == null || n.setImageSource(g, C, i));
959
1895
  },
960
- move(A, y, r = 1) {
961
- var Z;
962
- (Z = w.current) == null || Z.handleMove(A, y, r);
1896
+ move(n, F, p = 1) {
1897
+ var V;
1898
+ (V = b.current) == null || V.handleMove(n, F, p);
963
1899
  },
964
- splat(A, y, r, Z, V = 1) {
965
- var S;
966
- (S = w.current) == null || S.splat(A, y, r, Z, V);
1900
+ splat(n, F, p, V, W = 1) {
1901
+ var U;
1902
+ (U = b.current) == null || U.splat(n, F, p, V, W);
967
1903
  },
968
- updateConfig(A) {
969
- var y;
970
- (y = w.current) == null || y.updateConfig(A);
1904
+ updateConfig(n) {
1905
+ var F;
1906
+ (F = b.current) == null || F.updateConfig(n);
971
1907
  }
972
1908
  }),
973
- [I, i, e]
974
- ), j(() => {
975
- var A;
976
- I && ((A = w.current) == null || A.setImageSource(I, i, e));
977
- }, [I, i, e]);
978
- const D = JSON.stringify(t);
979
- return j(() => {
980
- var A;
981
- (A = w.current) == null || A.updateConfig(
982
- pI({ ...t, ...a !== void 0 ? { algorithm: a } : {} }, u)
1909
+ [g, C, i]
1910
+ ), sg(() => {
1911
+ var n;
1912
+ g && ((n = b.current) == null || n.setImageSource(g, C, i));
1913
+ }, [g, C, i, m, r]);
1914
+ const Y = JSON.stringify(t);
1915
+ return sg(() => {
1916
+ var n;
1917
+ (n = b.current) == null || n.updateConfig(
1918
+ II({ ...t, ...u !== void 0 ? { algorithm: u } : {} }, a)
983
1919
  );
984
- }, [u, a, D]), j(() => {
985
- var y;
986
- if (!n) {
987
- (y = w.current) == null || y.setBackground(null);
1920
+ }, [a, u, Y, m, r]), sg(() => {
1921
+ var F;
1922
+ if (!Z) {
1923
+ (F = b.current) == null || F.setBackground(null);
988
1924
  return;
989
1925
  }
990
- let A = !1;
991
- return kI(n).then((r) => {
992
- var Z;
993
- if (A) {
994
- r.close();
1926
+ let n = !1;
1927
+ return XI(Z).then((p) => {
1928
+ var V;
1929
+ if (n) {
1930
+ p.close();
995
1931
  return;
996
1932
  }
997
- (Z = w.current) == null || Z.setBackground(r, G);
998
- }).catch((r) => console.error("[fluidity-js] backgroundSrc load failed:", r)), () => {
999
- A = !0;
1933
+ (V = b.current) == null || V.setBackground(p, S);
1934
+ }).catch((p) => console.error("[fluidity-js] backgroundSrc load failed:", p)), () => {
1935
+ n = !0;
1000
1936
  };
1001
- }, [n, G]), j(() => {
1002
- if (!d)
1003
- return;
1004
- const A = F.current;
1937
+ }, [Z, S, m, r]), sg(() => {
1005
1938
  if (!A)
1006
1939
  return;
1007
- const y = (Z) => {
1008
- var S;
1009
- const V = A.getBoundingClientRect();
1010
- (S = w.current) == null || S.handleMove(Z.clientX - V.left, Z.clientY - V.top, 2);
1011
- }, r = (Z) => {
1012
- var M;
1013
- Z.preventDefault();
1014
- const V = A.getBoundingClientRect(), S = Z.touches[0];
1015
- (M = w.current) == null || M.handleMove(S.clientX - V.left, S.clientY - V.top, 1);
1940
+ const n = K.current;
1941
+ if (!n)
1942
+ return;
1943
+ const F = (V) => {
1944
+ var U;
1945
+ const W = n.getBoundingClientRect();
1946
+ (U = b.current) == null || U.handleMove(V.clientX - W.left, V.clientY - W.top, 2);
1947
+ }, p = (V) => {
1948
+ var _;
1949
+ V.preventDefault();
1950
+ const W = n.getBoundingClientRect(), U = V.touches[0];
1951
+ (_ = b.current) == null || _.handleMove(U.clientX - W.left, U.clientY - W.top, 1);
1016
1952
  };
1017
- return A.addEventListener("mousemove", y), A.addEventListener("touchmove", r, { passive: !1 }), () => {
1018
- A.removeEventListener("mousemove", y), A.removeEventListener("touchmove", r);
1953
+ return n.addEventListener("mousemove", F), n.addEventListener("touchmove", p, { passive: !1 }), () => {
1954
+ n.removeEventListener("mousemove", F), n.removeEventListener("touchmove", p);
1019
1955
  };
1020
- }, [d]), /* @__PURE__ */ NI(
1956
+ }, [A]), /* @__PURE__ */ xI(
1021
1957
  "div",
1022
1958
  {
1023
- ref: F,
1959
+ ref: K,
1024
1960
  className: s,
1025
1961
  style: {
1026
1962
  position: "relative",
@@ -1028,23 +1964,24 @@ const Lg = zI(function({
1028
1964
  width: "100%",
1029
1965
  height: "100%",
1030
1966
  background: c,
1031
- ...o
1967
+ ...l
1032
1968
  }
1033
1969
  }
1034
1970
  );
1035
1971
  });
1036
1972
  export {
1037
- OI as DEFAULT_CONFIG,
1038
- TI as DEFAULT_CONFIG_TEXT,
1039
- iI as DEFAULT_PROPS_IMAGE,
1040
- HI as DEFAULT_PROPS_SHARED,
1041
- $ as DEFAULT_PROPS_TEXT,
1042
- Bg as FluidController,
1043
- Vg as FluidImage,
1044
- EI as FluidSimulation,
1045
- Lg as FluidText,
1046
- ig as PRESETS,
1047
- kI as loadImageBitmap,
1048
- pI as mergeConfig,
1049
- qI as useFluid
1973
+ TI as DEFAULT_CONFIG,
1974
+ UI as DEFAULT_CONFIG_TEXT,
1975
+ ng as DEFAULT_PROPS_IMAGE,
1976
+ wI as DEFAULT_PROPS_SHARED,
1977
+ ag as DEFAULT_PROPS_TEXT,
1978
+ MC as FluidController,
1979
+ TC as FluidImage,
1980
+ ZI as FluidSimulation,
1981
+ DC as FluidText,
1982
+ IC as PRESETS,
1983
+ XI as loadImageBitmap,
1984
+ II as mergeConfig,
1985
+ AI as parseColor,
1986
+ _I as useFluid
1050
1987
  };