@jayf0x/fluidity-js 0.2.4 → 0.2.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,119 +1,139 @@
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) => {
1
+ var aC = Object.defineProperty;
2
+ var uC = (e, g, C) => g in e ? aC(e, g, { enumerable: !0, configurable: !0, writable: !0, value: C }) : e[g] = C;
3
+ var nI = (e, g, C) => (uC(e, typeof g != "symbol" ? g + "" : g, C), C), kI = (e, g, C) => {
4
4
  if (!g.has(e))
5
5
  throw TypeError("Cannot " + C);
6
6
  };
7
- var I = (e, g, C) => (LI(e, g, "read from private field"), C ? C.call(e) : g.get(e)), A = (e, g, C) => {
7
+ var I = (e, g, C) => (kI(e, g, "read from private field"), C ? C.call(e) : g.get(e)), d = (e, g, C) => {
8
8
  if (g.has(e))
9
9
  throw TypeError("Cannot add the same private member more than once");
10
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 V = (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 FI } from "react";
15
- const TI = {
16
- densityDissipation: 0.992,
17
- velocityDissipation: 0.93,
11
+ }, o = (e, g, C, i) => (kI(e, g, "write to private field"), i ? i.call(e, C) : g.set(e, C), C);
12
+ var L = (e, g, C) => (kI(e, g, "access private method"), C);
13
+ import { jsx as $I } from "react/jsx-runtime";
14
+ import { useRef as Qg, useEffect as tg, forwardRef as gC, useImperativeHandle as IC } from "react";
15
+ const mC = {
16
+ densityDissipation: [0.94, 1],
17
+ velocityDissipation: [0.9, 0.999],
18
+ splatRadius: [1e-3, 0.04],
19
+ splatForce: [0.1, 5],
20
+ specularExp: [0.1, 10],
21
+ shine: [0, 0.15],
22
+ warpStrength: [1e-3, 0.1]
23
+ };
24
+ function Eg(e) {
25
+ const g = { ...e };
26
+ for (const [C, [i, s]] of Object.entries(mC)) {
27
+ const l = e[C];
28
+ l !== void 0 && l >= 0 && l <= 1 && (g[C] = i + (s - i) * l);
29
+ }
30
+ return g;
31
+ }
32
+ const CC = {
33
+ densityDissipation: 0.83,
34
+ velocityDissipation: 0.91,
18
35
  pressureIterations: 1,
19
- curl: 1e-4,
20
- splatRadius: 4e-3,
21
- splatForce: 0.91,
22
- refraction: 0.25,
23
- specularExp: 1.01,
24
- shine: 0.01,
36
+ curl: 0,
37
+ splatRadius: 0.1,
38
+ splatForce: 0.08,
39
+ refraction: 1,
40
+ specularExp: 0,
41
+ shine: 0,
25
42
  waterColor: "#000000",
26
43
  glowColor: "#b3d9ff",
27
- algorithm: "standard",
28
- warpStrength: 0.015
29
- }, WI = {
30
- ...TI,
31
- densityDissipation: 0.99,
32
- velocityDissipation: 0.98,
44
+ algorithm: "aurora",
45
+ warpStrength: 0.04
46
+ }, EI = {
47
+ ...CC,
48
+ densityDissipation: 0.9,
49
+ velocityDissipation: 0.9,
33
50
  pressureIterations: 3,
34
- curl: 0.15,
35
- splatRadius: 0.01,
36
- splatForce: 3,
37
- refraction: 0.25,
38
- specularExp: 1,
39
- shine: 0.1,
40
- glowColor: "#0080ff"
41
- }, gC = { dpr: 1, sim: 0.5 }, pI = {
51
+ curl: 0.2,
52
+ splatRadius: 0.2,
53
+ splatForce: 0.5,
54
+ refraction: 0.2,
55
+ specularExp: 0.01,
56
+ shine: 0.5,
57
+ waterColor: "#090017",
58
+ glowColor: "#b04721"
59
+ }, gI = {
60
+ dpr: typeof window < "u" ? 1 / (window.devicePixelRatio || 1) : 1,
61
+ sim: 0.5
62
+ }, iC = {
42
63
  backgroundColor: "#0a0a0a",
43
64
  backgroundSize: "cover",
44
- isMouseEnabled: !0,
45
- isWorkerEnabled: !0,
46
- quality: gC
65
+ mouseEnabled: !0,
66
+ workerEnabled: !0
47
67
  }, Gg = {
48
- ...pI,
68
+ ...iC,
49
69
  effect: 0,
50
70
  imageSize: "cover"
51
- }, Bg = {
52
- ...pI,
71
+ }, mg = {
72
+ ...iC,
53
73
  fontSize: 100,
54
74
  color: "#ffffff",
55
75
  fontFamily: "sans-serif",
56
76
  fontWeight: 900
57
- }, IC = {
77
+ }, pC = {
58
78
  calm: {
59
- densityDissipation: 0.999,
60
- velocityDissipation: 0.98,
79
+ densityDissipation: 0.98,
80
+ velocityDissipation: 0.81,
61
81
  curl: 1e-4,
62
- splatRadius: 3e-3,
63
- splatForce: 0.5,
82
+ splatRadius: 0.05,
83
+ splatForce: 0.08,
64
84
  refraction: 0.15,
65
- shine: 5e-3,
85
+ shine: 0.03,
66
86
  glowColor: "#99d9ff",
67
87
  waterColor: "#00050d"
68
88
  },
69
89
  sand: {
70
- densityDissipation: 0.997,
71
- velocityDissipation: 0.98,
90
+ densityDissipation: 0.95,
91
+ velocityDissipation: 0.81,
72
92
  curl: 1,
73
- splatRadius: 0.01,
74
- splatForce: 0.9,
93
+ splatRadius: 0.23,
94
+ splatForce: 0.16,
75
95
  refraction: 0.8,
76
- specularExp: 0.1,
77
- shine: 0.05,
96
+ specularExp: 0,
97
+ shine: 0.33,
78
98
  glowColor: "#070707",
79
99
  waterColor: "#735420"
80
100
  },
81
101
  wave: {
82
- densityDissipation: 0.994,
83
- velocityDissipation: 0.92,
102
+ densityDissipation: 0.9,
103
+ velocityDissipation: 0.2,
84
104
  curl: 0.2,
85
- splatRadius: 5e-3,
86
- splatForce: 1.2,
105
+ splatRadius: 0.1,
106
+ splatForce: 0.22,
87
107
  refraction: 0.35,
88
- shine: 0.03,
108
+ shine: 0.2,
89
109
  glowColor: "#80ccff",
90
110
  waterColor: "#000308"
91
111
  },
92
112
  neon: {
93
- densityDissipation: 0.985,
94
- velocityDissipation: 0.93,
113
+ densityDissipation: 0.75,
114
+ velocityDissipation: 0.3,
95
115
  curl: 0.05,
96
- splatRadius: 8e-3,
97
- splatForce: 1.5,
116
+ splatRadius: 0.18,
117
+ splatForce: 0.29,
98
118
  refraction: 0.25,
99
- specularExp: 0.5,
100
- shine: 0.14,
119
+ specularExp: 0.04,
120
+ shine: 0.93,
101
121
  glowColor: "#ff33cc",
102
122
  waterColor: "#0d0014"
103
123
  },
104
124
  smoke: {
105
- densityDissipation: 0.996,
106
- velocityDissipation: 0.97,
125
+ densityDissipation: 0.93,
126
+ velocityDissipation: 0.71,
107
127
  curl: 0.04,
108
- splatRadius: 9e-3,
109
- splatForce: 0.8,
128
+ splatRadius: 0.21,
129
+ splatForce: 0.14,
110
130
  refraction: 0.08,
111
131
  shine: 0,
112
132
  glowColor: "#808080",
113
133
  waterColor: "#0f0f0f"
114
134
  }
115
135
  };
116
- function dI(e) {
136
+ function bI(e) {
117
137
  if (Array.isArray(e))
118
138
  return e;
119
139
  const g = e.slice(1, 7);
@@ -127,124 +147,124 @@ function dI(e) {
127
147
  parseInt(g.slice(4, 6), 16) / 255
128
148
  ];
129
149
  }
130
- function II(e = {}, g, C = TI) {
131
- return { ...g ? { ...C, ...IC[g] } : C, ...e };
150
+ function uI(e = {}, g, C = CC) {
151
+ return { ...g ? { ...C, ...pC[g] } : C, ...e };
132
152
  }
133
- function jg(e, g, C, i, s = "cover") {
153
+ function II(e, g, C, i, s = "cover") {
134
154
  let l;
135
155
  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, B = g * l;
137
- return { x: (C - t) / 2, y: (i - B) / 2, drawW: t, drawH: B };
156
+ const t = e * l, S = g * l;
157
+ return { x: (C - t) / 2, y: (i - S) / 2, drawW: t, drawH: S };
138
158
  }
139
- function CC(e, g, C, i, s = null, l = "cover") {
140
- const { text: t, fontSize: B, color: S, fontFamily: c = "sans-serif", fontWeight: u = 900 } = i, a = new OffscreenCanvas(g, C), d = a.getContext("2d");
141
- ((L) => {
159
+ function ZC(e, g, C, i, s = null, l = "cover") {
160
+ const { text: t, fontSize: S, color: u, fontFamily: c = "sans-serif", fontWeight: p = 900 } = i, a = new OffscreenCanvas(g, C), A = a.getContext("2d");
161
+ ((b) => {
142
162
  if (s) {
143
- d.clearRect(0, 0, g, C), d.fillStyle = "black", d.fillRect(0, 0, g, C);
144
- const { x: m, y: h, drawW: b, drawH: U } = jg(
163
+ A.clearRect(0, 0, g, C), A.fillStyle = "black", A.fillRect(0, 0, g, C);
164
+ const { x: B, y: K, drawW: W, drawH: x } = II(
145
165
  s.width,
146
166
  s.height,
147
167
  g,
148
168
  C,
149
169
  l
150
170
  );
151
- d.drawImage(s, m, h, b, U);
171
+ A.drawImage(s, B, K, W, x);
152
172
  } else
153
- d.fillStyle = "black", d.fillRect(0, 0, g, C);
154
- d.fillStyle = L, d.font = `${u} ${B}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, g / 2, C / 2);
155
- })(S);
156
- const n = $g(e, a);
157
- d.fillStyle = "black", d.fillRect(0, 0, g, C), d.fillStyle = "white", d.font = `${u} ${B}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, g / 2, C / 2);
158
- const w = $g(e, a);
159
- return { backgroundTex: n, obstacleTex: w, coverageTex: w };
173
+ A.fillStyle = "black", A.fillRect(0, 0, g, C);
174
+ A.fillStyle = b, A.font = `${p} ${S}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
175
+ })(u);
176
+ const Z = SI(e, a);
177
+ A.fillStyle = "black", A.fillRect(0, 0, g, C), A.fillStyle = "white", A.font = `${p} ${S}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
178
+ const r = SI(e, a);
179
+ return { backgroundTex: Z, obstacleTex: r, coverageTex: r };
160
180
  }
161
- function iC(e, g, C, i, s = 0, l = "cover", t = null, B = "cover") {
162
- const S = new OffscreenCanvas(C, i), c = S.getContext("2d"), { x: u, y: a, drawW: d, drawH: Z } = jg(g.width, g.height, C, i, l);
181
+ function BC(e, g, C, i, s = 0, l = "cover", t = null, S = "cover") {
182
+ const u = new OffscreenCanvas(C, i), c = u.getContext("2d"), { x: p, y: a, drawW: A, drawH: m } = II(g.width, g.height, C, i, l);
163
183
  if (c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), t) {
164
184
  const {
165
- x: m,
166
- y: h,
167
- drawW: b,
168
- drawH: U
169
- } = jg(t.width, t.height, C, i, B);
170
- c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, m, h, b, U), c.filter = "none";
185
+ x: B,
186
+ y: K,
187
+ drawW: W,
188
+ drawH: x
189
+ } = II(t.width, t.height, C, i, S);
190
+ c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, B, K, W, x), c.filter = "none";
171
191
  }
172
- c.drawImage(g, u, a, d, Z);
173
- const n = $g(e, S);
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, u, a, d, Z), c.filter = "none";
175
- const w = $g(e, S);
192
+ c.drawImage(g, p, a, A, m);
193
+ const Z = SI(e, u);
194
+ c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(g, p, a, A, m), c.filter = "none";
195
+ const r = SI(e, u);
176
196
  c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.fillStyle = "white", c.fillRect(
177
- Math.max(0, u),
197
+ Math.max(0, p),
178
198
  Math.max(0, a),
179
- Math.min(d, C - Math.max(0, u)),
180
- Math.min(Z, i - Math.max(0, a))
199
+ Math.min(A, C - Math.max(0, p)),
200
+ Math.min(m, i - Math.max(0, a))
181
201
  );
182
- const L = $g(e, S);
183
- return { backgroundTex: n, obstacleTex: w, coverageTex: L };
202
+ const b = SI(e, u);
203
+ return { backgroundTex: Z, obstacleTex: r, coverageTex: b };
184
204
  }
185
- function $g(e, g) {
205
+ function SI(e, g) {
186
206
  const C = e.createTexture();
187
207
  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
208
  }
189
- function eC(e, g, C, i, s = null, l = "cover") {
190
- const { text: t, fontSize: B, color: S, fontFamily: c = "sans-serif", fontWeight: u = 900 } = i, a = new OffscreenCanvas(g, C), d = a.getContext("2d");
191
- ((L) => {
209
+ function GC(e, g, C, i, s = null, l = "cover") {
210
+ const { text: t, fontSize: S, color: u, fontFamily: c = "sans-serif", fontWeight: p = 900 } = i, a = new OffscreenCanvas(g, C), A = a.getContext("2d");
211
+ ((b) => {
192
212
  if (s) {
193
- d.clearRect(0, 0, g, C), d.fillStyle = "black", d.fillRect(0, 0, g, C);
194
- const { x: m, y: h, drawW: b, drawH: U } = jg(
213
+ A.clearRect(0, 0, g, C), A.fillStyle = "black", A.fillRect(0, 0, g, C);
214
+ const { x: B, y: K, drawW: W, drawH: x } = II(
195
215
  s.width,
196
216
  s.height,
197
217
  g,
198
218
  C,
199
219
  l
200
220
  );
201
- d.drawImage(s, m, h, b, U);
221
+ A.drawImage(s, B, K, W, x);
202
222
  } else
203
- d.fillStyle = "black", d.fillRect(0, 0, g, C);
204
- d.fillStyle = L, d.font = `${u} ${B}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, g / 2, C / 2);
205
- })(S);
206
- const n = gI(e, a, g, C);
207
- d.fillStyle = "black", d.fillRect(0, 0, g, C), d.fillStyle = "white", d.font = `${u} ${B}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, g / 2, C / 2);
208
- const w = gI(e, a, g, C);
223
+ A.fillStyle = "black", A.fillRect(0, 0, g, C);
224
+ A.fillStyle = b, A.font = `${p} ${S}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
225
+ })(u);
226
+ const Z = aI(e, a, g, C);
227
+ A.fillStyle = "black", A.fillRect(0, 0, g, C), A.fillStyle = "white", A.font = `${p} ${S}px ${c}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, g / 2, C / 2);
228
+ const r = aI(e, a, g, C);
209
229
  return {
210
- backgroundTex: n,
211
- backgroundView: n.createView(),
212
- obstacleTex: w,
213
- obstacleView: w.createView(),
214
- coverageTex: w,
215
- coverageView: w.createView(),
230
+ backgroundTex: Z,
231
+ backgroundView: Z.createView(),
232
+ obstacleTex: r,
233
+ obstacleView: r.createView(),
234
+ coverageTex: r,
235
+ coverageView: r.createView(),
216
236
  sharedCoverage: !0
217
237
  };
218
238
  }
219
- function sC(e, g, C, i, s = 0, l = "cover", t = null, B = "cover") {
220
- const S = new OffscreenCanvas(C, i), c = S.getContext("2d"), { x: u, y: a, drawW: d, drawH: Z } = jg(g.width, g.height, C, i, l);
239
+ function rC(e, g, C, i, s = 0, l = "cover", t = null, S = "cover") {
240
+ const u = new OffscreenCanvas(C, i), c = u.getContext("2d"), { x: p, y: a, drawW: A, drawH: m } = II(g.width, g.height, C, i, l);
221
241
  if (c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), t) {
222
- const { x: m, y: h, drawW: b, drawH: U } = jg(
242
+ const { x: B, y: K, drawW: W, drawH: x } = II(
223
243
  t.width,
224
244
  t.height,
225
245
  C,
226
246
  i,
227
- B
247
+ S
228
248
  );
229
- c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, m, h, b, U), c.filter = "none";
249
+ c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, B, K, W, x), c.filter = "none";
230
250
  }
231
- c.drawImage(g, u, a, d, Z);
232
- const n = gI(e, S, 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, u, a, d, Z), c.filter = "none";
234
- const w = gI(e, S, 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, u), Math.max(0, a), Math.min(d, C - Math.max(0, u)), Math.min(Z, i - Math.max(0, a)));
236
- const L = gI(e, S, C, i);
251
+ c.drawImage(g, p, a, A, m);
252
+ const Z = aI(e, u, C, i);
253
+ c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(g, p, a, A, m), c.filter = "none";
254
+ const r = aI(e, u, C, i);
255
+ c.clearRect(0, 0, C, i), c.fillStyle = "black", c.fillRect(0, 0, C, i), c.fillStyle = "white", c.fillRect(Math.max(0, p), Math.max(0, a), Math.min(A, C - Math.max(0, p)), Math.min(m, i - Math.max(0, a)));
256
+ const b = aI(e, u, C, i);
237
257
  return {
238
- backgroundTex: n,
239
- backgroundView: n.createView(),
240
- obstacleTex: w,
241
- obstacleView: w.createView(),
242
- coverageTex: L,
243
- coverageView: L.createView(),
258
+ backgroundTex: Z,
259
+ backgroundView: Z.createView(),
260
+ obstacleTex: r,
261
+ obstacleView: r.createView(),
262
+ coverageTex: b,
263
+ coverageView: b.createView(),
244
264
  sharedCoverage: !1
245
265
  };
246
266
  }
247
- function gI(e, g, C, i) {
267
+ function aI(e, g, C, i) {
248
268
  const s = e.createTexture({
249
269
  size: [C, i],
250
270
  format: "rgba8unorm",
@@ -256,14 +276,14 @@ function gI(e, g, C, i) {
256
276
  [C, i]
257
277
  ), s;
258
278
  }
259
- async function XI(e) {
279
+ async function zI(e) {
260
280
  const g = await fetch(e);
261
281
  if (!g.ok)
262
282
  throw new Error(`Failed to fetch image: ${e} (${g.status})`);
263
283
  const C = await g.blob();
264
284
  return createImageBitmap(C);
265
285
  }
266
- const ug = (
286
+ const pg = (
267
287
  /* glsl */
268
288
  `
269
289
  precision highp float;
@@ -280,7 +300,7 @@ const ug = (
280
300
  gl_Position = vec4(aPosition, 0.0, 1.0);
281
301
  }
282
302
  `
283
- ), lC = (
303
+ ), nC = (
284
304
  /* glsl */
285
305
  `
286
306
  precision highp float;
@@ -300,7 +320,7 @@ const ug = (
300
320
  gl_FragColor = dissipation * texture2D(uSource, coord) * (1.0 - obs);
301
321
  }
302
322
  `
303
- ), tC = (
323
+ ), bC = (
304
324
  /* glsl */
305
325
  `
306
326
  precision highp float;
@@ -315,7 +335,7 @@ const ug = (
315
335
  gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
316
336
  }
317
337
  `
318
- ), oC = (
338
+ ), wC = (
319
339
  /* glsl */
320
340
  `
321
341
  precision highp float;
@@ -333,7 +353,7 @@ const ug = (
333
353
  gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
334
354
  }
335
355
  `
336
- ), dC = (
356
+ ), LC = (
337
357
  /* glsl */
338
358
  `
339
359
  precision highp float;
@@ -352,7 +372,7 @@ const ug = (
352
372
  gl_FragColor = vec4(vel, 0.0, 1.0);
353
373
  }
354
374
  `
355
- ), cC = (
375
+ ), hC = (
356
376
  /* glsl */
357
377
  `
358
378
  precision highp float;
@@ -369,7 +389,7 @@ const ug = (
369
389
  gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
370
390
  }
371
391
  `
372
- ), AC = (
392
+ ), KC = (
373
393
  /* glsl */
374
394
  `
375
395
  precision highp float;
@@ -383,7 +403,7 @@ const ug = (
383
403
  gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
384
404
  }
385
405
  `
386
- ), aC = (
406
+ ), yC = (
387
407
  /* glsl */
388
408
  `
389
409
  precision highp float;
@@ -404,7 +424,7 @@ const ug = (
404
424
  gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
405
425
  }
406
426
  `
407
- ), BC = (
427
+ ), VC = (
408
428
  /* glsl */
409
429
  `
410
430
  precision highp float;
@@ -525,7 +545,7 @@ const ug = (
525
545
  }
526
546
  `
527
547
  );
528
- function uC(e, g = !0) {
548
+ function HC(e, g = !0) {
529
549
  const C = { alpha: g, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
530
550
  let i = e.getContext("webgl2", C);
531
551
  const s = !!i;
@@ -542,7 +562,7 @@ function uC(e, g = !0) {
542
562
  }
543
563
  };
544
564
  }
545
- async function SC(e, g = !0) {
565
+ async function XC(e, g = !0) {
546
566
  if (typeof navigator > "u" || !navigator.gpu)
547
567
  return null;
548
568
  try {
@@ -558,11 +578,11 @@ async function SC(e, g = !0) {
558
578
  return null;
559
579
  }
560
580
  }
561
- class Sg {
581
+ class Zg {
562
582
  constructor(g, C, i) {
563
- oI(this, "program");
564
- oI(this, "uniforms", {});
565
- oI(this, "_gl");
583
+ nI(this, "program");
584
+ nI(this, "uniforms", {});
585
+ nI(this, "_gl");
566
586
  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);
567
587
  const s = g.getProgramParameter(this.program, g.ACTIVE_UNIFORMS);
568
588
  for (let l = 0; l < s; l++) {
@@ -581,27 +601,27 @@ class Sg {
581
601
  this._gl.deleteProgram(this.program);
582
602
  }
583
603
  }
584
- function ZC(e) {
604
+ function vC(e) {
585
605
  return {
586
- advection: new Sg(e, ug, lC),
587
- divergence: new Sg(e, ug, tC),
588
- pressure: new Sg(e, ug, oC),
589
- gradientSubtract: new Sg(e, ug, dC),
590
- splat: new Sg(e, ug, cC),
591
- curl: new Sg(e, ug, AC),
592
- vorticity: new Sg(e, ug, aC),
593
- display: new Sg(e, ug, BC)
606
+ advection: new Zg(e, pg, nC),
607
+ divergence: new Zg(e, pg, bC),
608
+ pressure: new Zg(e, pg, wC),
609
+ gradientSubtract: new Zg(e, pg, LC),
610
+ splat: new Zg(e, pg, hC),
611
+ curl: new Zg(e, pg, KC),
612
+ vorticity: new Zg(e, pg, yC),
613
+ display: new Zg(e, pg, VC)
594
614
  };
595
615
  }
596
- function aI(e, g, C, i) {
616
+ function hI(e, g, C, i) {
597
617
  e.activeTexture(e.TEXTURE0);
598
618
  const s = e.createTexture();
599
619
  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);
600
620
  const l = e.createFramebuffer();
601
621
  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 };
602
622
  }
603
- function bI(e, g, C, i) {
604
- let s = aI(e, g, C, i), l = aI(e, g, C, i);
623
+ function MI(e, g, C, i) {
624
+ let s = hI(e, g, C, i), l = hI(e, g, C, i);
605
625
  return {
606
626
  get read() {
607
627
  return s;
@@ -617,13 +637,13 @@ function bI(e, g, C, i) {
617
637
  }
618
638
  };
619
639
  }
620
- function GC(e) {
640
+ function RC(e) {
621
641
  const g = e.createBuffer();
622
642
  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) {
623
643
  e.bindFramebuffer(e.FRAMEBUFFER, i), e.drawArrays(e.TRIANGLE_FAN, 0, 4);
624
644
  };
625
645
  }
626
- const bg = (
646
+ const Kg = (
627
647
  /* wgsl */
628
648
  `
629
649
  struct VSOut {
@@ -634,10 +654,10 @@ struct VSOut {
634
654
  @location(3) vT : vec2f,
635
655
  @location(4) vB : vec2f,
636
656
  }`
637
- ), nC = (
657
+ ), WC = (
638
658
  /* wgsl */
639
659
  `
640
- ${bg}
660
+ ${Kg}
641
661
 
642
662
  struct U {
643
663
  texelSize : vec2f,
@@ -669,10 +689,10 @@ struct U {
669
689
  return u.dissipation * src * (1.0 - obs);
670
690
  }
671
691
  `
672
- ), mC = (
692
+ ), YC = (
673
693
  /* wgsl */
674
694
  `
675
- ${bg}
695
+ ${Kg}
676
696
 
677
697
  struct U { texelSize: vec2f, _pad: vec2f }
678
698
  @group(0) @binding(0) var<uniform> u : U;
@@ -699,10 +719,10 @@ struct U { texelSize: vec2f, _pad: vec2f }
699
719
  return vec4f(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
700
720
  }
701
721
  `
702
- ), rC = (
722
+ ), UC = (
703
723
  /* wgsl */
704
724
  `
705
- ${bg}
725
+ ${Kg}
706
726
 
707
727
  struct U { texelSize: vec2f, _pad: vec2f }
708
728
  @group(0) @binding(0) var<uniform> u : U;
@@ -732,10 +752,10 @@ struct U { texelSize: vec2f, _pad: vec2f }
732
752
  return vec4f((L + R + B + T - dv) * 0.25, 0.0, 0.0, 1.0);
733
753
  }
734
754
  `
735
- ), wC = (
755
+ ), xC = (
736
756
  /* wgsl */
737
757
  `
738
- ${bg}
758
+ ${Kg}
739
759
 
740
760
  struct U { texelSize: vec2f, _pad: vec2f }
741
761
  @group(0) @binding(0) var<uniform> u : U;
@@ -766,10 +786,10 @@ struct U { texelSize: vec2f, _pad: vec2f }
766
786
  return vec4f(vel, 0.0, 1.0);
767
787
  }
768
788
  `
769
- ), pC = (
789
+ ), kC = (
770
790
  /* wgsl */
771
791
  `
772
- ${bg}
792
+ ${Kg}
773
793
 
774
794
  // texelSize occupies bytes 0-7 for the shared vertex stage; aspectRatio/radius fill the rest.
775
795
  struct U {
@@ -802,10 +822,10 @@ struct U {
802
822
  return vec4f(textureSample(uTgt, samp, i.uv).xyz + sp, 1.0);
803
823
  }
804
824
  `
805
- ), LC = (
825
+ ), MC = (
806
826
  /* wgsl */
807
827
  `
808
- ${bg}
828
+ ${Kg}
809
829
 
810
830
  struct U { texelSize: vec2f, _pad: vec2f }
811
831
  @group(0) @binding(0) var<uniform> u : U;
@@ -831,10 +851,10 @@ struct U { texelSize: vec2f, _pad: vec2f }
831
851
  return vec4f(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
832
852
  }
833
853
  `
834
- ), bC = (
854
+ ), fC = (
835
855
  /* wgsl */
836
856
  `
837
- ${bg}
857
+ ${Kg}
838
858
 
839
859
  struct U {
840
860
  texelSize: vec2f,
@@ -870,10 +890,10 @@ struct U {
870
890
  return vec4f(vel, 0.0, 1.0);
871
891
  }
872
892
  `
873
- ), VC = (
893
+ ), DC = (
874
894
  /* wgsl */
875
895
  `
876
- ${bg}
896
+ ${Kg}
877
897
 
878
898
  struct U {
879
899
  texelSize : vec2f,
@@ -978,10 +998,10 @@ struct U {
978
998
  return vec4f(color, 1.0);
979
999
  }
980
1000
  `
981
- ), hC = {
1001
+ ), FC = {
982
1002
  arrayStride: 8,
983
1003
  attributes: [{ shaderLocation: 0, offset: 0, format: "float32x2" }]
984
- }, YI = new Float32Array([
1004
+ }, OI = new Float32Array([
985
1005
  -1,
986
1006
  -1,
987
1007
  -1,
@@ -995,11 +1015,11 @@ struct U {
995
1015
  1,
996
1016
  1
997
1017
  ]);
998
- function yC(e) {
999
- const g = e.createBuffer({ size: YI.byteLength, usage: GPUBufferUsage.VERTEX | GPUBufferUsage.COPY_DST });
1000
- return e.queue.writeBuffer(g, 0, YI), g;
1018
+ function JC(e) {
1019
+ const g = e.createBuffer({ size: OI.byteLength, usage: GPUBufferUsage.VERTEX | GPUBufferUsage.COPY_DST });
1020
+ return e.queue.writeBuffer(g, 0, OI), g;
1001
1021
  }
1002
- function BI(e, g, C, i) {
1022
+ function KI(e, g, C, i) {
1003
1023
  const s = e.createTexture({
1004
1024
  size: [C, i],
1005
1025
  format: g,
@@ -1007,8 +1027,8 @@ function BI(e, g, C, i) {
1007
1027
  });
1008
1028
  return { tex: s, view: s.createView(), width: C, height: i };
1009
1029
  }
1010
- function VI(e, g, C, i) {
1011
- let s = BI(e, g, C, i), l = BI(e, g, C, i);
1030
+ function fI(e, g, C, i) {
1031
+ let s = KI(e, g, C, i), l = KI(e, g, C, i);
1012
1032
  return {
1013
1033
  get read() {
1014
1034
  return s;
@@ -1024,57 +1044,57 @@ function VI(e, g, C, i) {
1024
1044
  }
1025
1045
  };
1026
1046
  }
1027
- function Zg(e, g, C, i) {
1047
+ function Bg(e, g, C, i) {
1028
1048
  const s = e.createShaderModule({ code: g });
1029
1049
  return e.createRenderPipeline({
1030
1050
  layout: "auto",
1031
- vertex: { module: s, entryPoint: "vs", buffers: [hC] },
1051
+ vertex: { module: s, entryPoint: "vs", buffers: [FC] },
1032
1052
  fragment: { module: s, entryPoint: "fs", targets: [{ format: C, ...i ? { blend: i } : {} }] },
1033
1053
  primitive: { topology: "triangle-list" }
1034
1054
  });
1035
1055
  }
1036
- const KC = {
1056
+ const TC = {
1037
1057
  color: { operation: "add", srcFactor: "one", dstFactor: "zero" },
1038
1058
  alpha: { operation: "add", srcFactor: "one", dstFactor: "zero" }
1039
1059
  };
1040
- function HC(e, g, C = !0) {
1060
+ function zC(e, g, C = !0) {
1041
1061
  const i = "rgba16float";
1042
1062
  return {
1043
- advection: Zg(e, nC, i),
1044
- divergence: Zg(e, mC, i),
1045
- pressure: Zg(e, rC, i),
1046
- gradientSubtract: Zg(e, wC, i),
1047
- splat: Zg(e, pC, i),
1048
- curl: Zg(e, LC, i),
1049
- vorticity: Zg(e, bC, i),
1050
- display: Zg(e, VC, g, C ? void 0 : KC)
1063
+ advection: Bg(e, WC, i),
1064
+ divergence: Bg(e, YC, i),
1065
+ pressure: Bg(e, UC, i),
1066
+ gradientSubtract: Bg(e, xC, i),
1067
+ splat: Bg(e, kC, i),
1068
+ curl: Bg(e, MC, i),
1069
+ vorticity: Bg(e, fC, i),
1070
+ display: Bg(e, DC, g, C ? void 0 : TC)
1051
1071
  };
1052
1072
  }
1053
- function XC(e) {
1073
+ function NC(e) {
1054
1074
  return e.createSampler({ magFilter: "linear", minFilter: "linear", addressModeU: "clamp-to-edge", addressModeV: "clamp-to-edge" });
1055
1075
  }
1056
- function q(e, g) {
1076
+ function gg(e, g) {
1057
1077
  return e.createBuffer({ size: g, usage: GPUBufferUsage.UNIFORM | GPUBufferUsage.COPY_DST });
1058
1078
  }
1059
- function UI(e, g, C, i, s, l) {
1079
+ function jI(e, g, C, i, s, l) {
1060
1080
  const t = new Float32Array([C, i, s, l]);
1061
1081
  e.queue.writeBuffer(g, 0, t);
1062
1082
  }
1063
- function cI(e, g, C, i) {
1083
+ function wI(e, g, C, i) {
1064
1084
  const s = new Float32Array([C, i, 0, 0]);
1065
1085
  e.queue.writeBuffer(g, 0, s);
1066
1086
  }
1067
- function vC(e, g, C, i, s, l) {
1087
+ function QC(e, g, C, i, s, l) {
1068
1088
  const t = new Float32Array([C, i, s, l]);
1069
1089
  e.queue.writeBuffer(g, 0, t);
1070
1090
  }
1071
- function AI(e, g, C, i, s, l, t, B, S, c, u) {
1091
+ function LI(e, g, C, i, s, l, t, S, u, c, p) {
1072
1092
  const a = new Float32Array(12);
1073
- a[0] = C, a[1] = i, a[2] = s, a[3] = l, a[4] = t, a[5] = B, a[6] = S, a[7] = 0, a[8] = c, a[9] = u, a[10] = 0, a[11] = 0, e.queue.writeBuffer(g, 0, a);
1093
+ a[0] = C, a[1] = i, a[2] = s, a[3] = l, a[4] = t, a[5] = S, a[6] = u, a[7] = 0, a[8] = c, a[9] = p, a[10] = 0, a[11] = 0, e.queue.writeBuffer(g, 0, a);
1074
1094
  }
1075
- function RC(e, g, C, i, s, l, t, B, S, c, u, a) {
1076
- const d = new Float32Array(16), Z = new Int32Array(d.buffer);
1077
- d[0] = C, d[1] = i, d[2] = s, d[3] = l, d[4] = t[0], d[5] = t[1], d[6] = t[2], d[7] = 0, d[8] = B[0], d[9] = B[1], d[10] = B[2], d[11] = 0, d[12] = S, d[13] = c, Z[14] = u, Z[15] = a ? 1 : 0, e.queue.writeBuffer(g, 0, d);
1095
+ function EC(e, g, C, i, s, l, t, S, u, c, p, a) {
1096
+ const A = new Float32Array(16), m = new Int32Array(A.buffer);
1097
+ 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] = S[0], A[9] = S[1], A[10] = S[2], A[11] = 0, A[12] = u, A[13] = c, m[14] = p, m[15] = a ? 1 : 0, e.queue.writeBuffer(g, 0, A);
1078
1098
  }
1079
1099
  function O(e, g, C, i, s) {
1080
1100
  const l = e.beginRenderPass({
@@ -1087,7 +1107,7 @@ function O(e, g, C, i, s) {
1087
1107
  });
1088
1108
  l.setPipeline(g), l.setBindGroup(0, C), l.setVertexBuffer(0, i), l.draw(6), l.end();
1089
1109
  }
1090
- function WC(e, g, C, i, s) {
1110
+ function OC(e, g, C, i, s) {
1091
1111
  const l = e.beginRenderPass({
1092
1112
  colorAttachments: [{
1093
1113
  view: s,
@@ -1098,114 +1118,114 @@ function WC(e, g, C, i, s) {
1098
1118
  });
1099
1119
  l.setPipeline(g), l.setBindGroup(0, C), l.setVertexBuffer(0, i), l.draw(6), l.end();
1100
1120
  }
1101
- const kI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (e) => setTimeout(e, 1e3 / 60), YC = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, Pg = 0.016, DI = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
1102
- var Vg, Q, CI, hg, zg, D, X, $, gg, Ig, lg, z, Cg, F, Jg, yg, Ng, M, K, ng, ig, mg, N, Kg, Hg, Xg, vg, Rg, tg, og, Wg, Yg, Ug, H, v, E, j, T, Og, dg, J, rg, cg, p, k, eg, kg, iI, Dg, SI, zI, Mg, _g, eI, hI, wg, Fg, xg, qg, sI, yI, lI, KI, ZI, JI, GI, NI, nI, OI, mI, QI, rI, EI;
1103
- const vI = class vI {
1121
+ const PI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (e) => setTimeout(e, 1e3 / 60), jC = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, AI = 0.016, _I = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
1122
+ var yg, j, mI, Vg, Og, k, H, Ig, Cg, ig, og, z, eg, D, jg, Hg, Pg, M, h, rg, sg, ng, E, Xg, vg, Rg, Wg, Yg, Ag, cg, Ug, xg, kg, V, X, P, _, F, _g, dg, N, bg, Sg, w, U, lg, Mg, pI, fg, VI, eC, Dg, cI, ZI, DI, wg, Ng, Fg, dI, BI, FI, GI, JI, HI, sC, XI, lC, vI, tC, RI, oC, WI, AC;
1123
+ const NI = class NI {
1104
1124
  // ── Constructor ─────────────────────────────────────────────────────────────
1105
1125
  constructor(g, C = {}, i = {}, s, l = !0) {
1106
1126
  // ---------------------------------------------------------------------------
1107
1127
  // Private — GPU initialisation
1108
1128
  // ---------------------------------------------------------------------------
1109
- A(this, SI);
1129
+ d(this, VI);
1110
1130
  // ---------------------------------------------------------------------------
1111
1131
  // Private — shared helpers
1112
1132
  // ---------------------------------------------------------------------------
1113
- A(this, Mg);
1114
- A(this, eI);
1115
- A(this, wg);
1116
- A(this, xg);
1117
- A(this, sI);
1118
- A(this, lI);
1133
+ d(this, Dg);
1134
+ d(this, ZI);
1135
+ d(this, wg);
1136
+ d(this, Fg);
1137
+ d(this, BI);
1138
+ d(this, GI);
1119
1139
  // ---------------------------------------------------------------------------
1120
1140
  // Private — frame dispatch
1121
1141
  // ---------------------------------------------------------------------------
1122
- A(this, ZI);
1142
+ d(this, HI);
1123
1143
  // ---------------------------------------------------------------------------
1124
1144
  // Private — WebGPU simulation step
1125
1145
  // ---------------------------------------------------------------------------
1126
- A(this, GI);
1146
+ d(this, XI);
1127
1147
  // ---------------------------------------------------------------------------
1128
1148
  // Private — WebGPU direct splat
1129
1149
  // ---------------------------------------------------------------------------
1130
- A(this, nI);
1150
+ d(this, vI);
1131
1151
  // ---------------------------------------------------------------------------
1132
1152
  // Private — WebGL splat
1133
1153
  // ---------------------------------------------------------------------------
1134
- A(this, mI);
1154
+ d(this, RI);
1135
1155
  // ---------------------------------------------------------------------------
1136
1156
  // Private — WebGL simulation step (unchanged from original)
1137
1157
  // ---------------------------------------------------------------------------
1138
- A(this, rI);
1139
- A(this, Vg, void 0);
1158
+ d(this, WI);
1159
+ d(this, yg, void 0);
1140
1160
  // ── WebGL path ──────────────────────────────────────────────────────────────
1141
- A(this, Q, null);
1142
- A(this, CI, null);
1143
- A(this, hg, null);
1144
- A(this, zg, null);
1145
- A(this, D, null);
1146
- A(this, X, null);
1147
- A(this, $, null);
1148
- A(this, gg, null);
1149
- A(this, Ig, null);
1150
- A(this, lg, null);
1151
- A(this, z, null);
1152
- A(this, Cg, null);
1161
+ d(this, j, null);
1162
+ d(this, mI, null);
1163
+ d(this, Vg, null);
1164
+ d(this, Og, null);
1165
+ d(this, k, null);
1166
+ d(this, H, null);
1167
+ d(this, Ig, null);
1168
+ d(this, Cg, null);
1169
+ d(this, ig, null);
1170
+ d(this, og, null);
1171
+ d(this, z, null);
1172
+ d(this, eg, null);
1153
1173
  // ── WebGPU path ─────────────────────────────────────────────────────────────
1154
- A(this, F, null);
1155
- A(this, Jg, null);
1156
- A(this, yg, null);
1157
- A(this, Ng, null);
1158
- A(this, M, null);
1159
- A(this, K, null);
1160
- A(this, ng, null);
1161
- A(this, ig, null);
1162
- A(this, mg, null);
1163
- A(this, N, null);
1174
+ d(this, D, null);
1175
+ d(this, jg, null);
1176
+ d(this, Hg, null);
1177
+ d(this, Pg, null);
1178
+ d(this, M, null);
1179
+ d(this, h, null);
1180
+ d(this, rg, null);
1181
+ d(this, sg, null);
1182
+ d(this, ng, null);
1183
+ d(this, E, null);
1164
1184
  // Pre-allocated uniform buffers (sizes: see gpu-utils writeXxx docs)
1165
1185
  // Velocity/density advection use separate buffers — writeBuffer is a queue op;
1166
1186
  // a second write to the same buffer before queue.submit() aliases both passes.
1167
- A(this, Kg, null);
1187
+ d(this, Xg, null);
1168
1188
  // 16 bytes — velocity advection
1169
- A(this, Hg, null);
1189
+ d(this, vg, null);
1170
1190
  // 16 bytes — density advection
1171
- A(this, Xg, null);
1191
+ d(this, Rg, null);
1172
1192
  // 16 bytes
1173
- A(this, vg, null);
1193
+ d(this, Wg, null);
1174
1194
  // 16 bytes
1175
- A(this, Rg, null);
1195
+ d(this, Yg, null);
1176
1196
  // 16 bytes
1177
- A(this, tg, null);
1197
+ d(this, Ag, null);
1178
1198
  // 48 bytes — velocity splat
1179
- A(this, og, null);
1199
+ d(this, cg, null);
1180
1200
  // 48 bytes — density splat
1181
- A(this, Wg, null);
1201
+ d(this, Ug, null);
1182
1202
  // 16 bytes
1183
- A(this, Yg, null);
1203
+ d(this, xg, null);
1184
1204
  // 16 bytes
1185
- A(this, Ug, null);
1205
+ d(this, kg, null);
1186
1206
  // 64 bytes
1187
1207
  // ── Shared state ────────────────────────────────────────────────────────────
1188
- A(this, H, 0);
1189
- A(this, v, 0);
1190
- A(this, E, 0);
1191
- A(this, j, 0);
1192
- A(this, T, 1);
1193
- A(this, Og, 1);
1194
- A(this, dg, 0.5);
1195
- A(this, J, null);
1196
- A(this, rg, "cover");
1197
- A(this, cg, void 0);
1198
- A(this, p, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
1199
- A(this, k, null);
1200
- A(this, eg, null);
1201
- A(this, kg, !1);
1202
- A(this, iI, !1);
1203
- A(this, Dg, !0);
1204
- if (o(this, Vg, g), o(this, Og, Math.max(0.1, Math.min(1, i.dpr ?? 1))), o(this, dg, Math.max(0.1, Math.min(1, i.sim ?? 0.5))), o(this, cg, II(C)), o(this, Dg, l), s)
1205
- o(this, F, s), V(this, SI, zI).call(this, s);
1208
+ d(this, V, 0);
1209
+ d(this, X, 0);
1210
+ d(this, P, 0);
1211
+ d(this, _, 0);
1212
+ d(this, F, 1);
1213
+ d(this, _g, 1);
1214
+ d(this, dg, 0.5);
1215
+ d(this, N, null);
1216
+ d(this, bg, "cover");
1217
+ d(this, Sg, void 0);
1218
+ d(this, w, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
1219
+ d(this, U, null);
1220
+ d(this, lg, null);
1221
+ d(this, Mg, !1);
1222
+ d(this, pI, !1);
1223
+ d(this, fg, !0);
1224
+ if (o(this, yg, g), o(this, _g, Math.max(0.1, Math.min(1, i.dpr ?? 1))), o(this, dg, Math.max(0.1, Math.min(1, i.sim ?? 0.5))), o(this, Sg, uI(C)), o(this, fg, l), s)
1225
+ o(this, D, s), L(this, VI, eC).call(this, s);
1206
1226
  else {
1207
- const { gl: t, ext: B } = uC(g, l);
1208
- o(this, Q, t), o(this, CI, B), o(this, hg, ZC(t)), o(this, zg, GC(t)), t.clearColor(0, 0, 0, l ? 0 : 1);
1227
+ const { gl: t, ext: S } = HC(g, l);
1228
+ o(this, j, t), o(this, mI, S), o(this, Vg, vC(t)), o(this, Og, RC(t)), t.clearColor(0, 0, 0, l ? 0 : 1);
1209
1229
  }
1210
1230
  }
1211
1231
  /**
@@ -1213,31 +1233,31 @@ const vI = class vI {
1213
1233
  * This is the recommended entry point when WebGPU support is desired.
1214
1234
  */
1215
1235
  static async create(g, C = {}, i = {}, s = !0, l = !0) {
1216
- const t = s ? await SC(g, l) : null;
1217
- return new vI(g, C, i, t ?? void 0, l);
1236
+ const t = s ? await XC(g, l) : null;
1237
+ return new NI(g, C, i, t ?? void 0, l);
1218
1238
  }
1219
1239
  // ---------------------------------------------------------------------------
1220
1240
  // Public API
1221
1241
  // ---------------------------------------------------------------------------
1222
1242
  setTextSource(g) {
1223
- o(this, k, { type: "text", opts: g }), V(this, Mg, _g).call(this), V(this, wg, Fg).call(this), V(this, xg, qg).call(this);
1243
+ o(this, U, { type: "text", opts: g }), L(this, Dg, cI).call(this), L(this, wg, Ng).call(this), L(this, Fg, dI).call(this);
1224
1244
  }
1225
1245
  async setImageSource(g, C = 0, i = "cover") {
1226
- const s = await XI(g);
1227
- if (I(this, iI)) {
1246
+ const s = await zI(g);
1247
+ if (I(this, pI)) {
1228
1248
  s.close();
1229
1249
  return;
1230
1250
  }
1231
- o(this, k, { type: "image", bitmap: s, effect: C, size: i }), V(this, Mg, _g).call(this), V(this, wg, Fg).call(this), V(this, xg, qg).call(this);
1251
+ o(this, U, { type: "image", bitmap: s, effect: C, size: i }), L(this, Dg, cI).call(this), L(this, wg, Ng).call(this), L(this, Fg, dI).call(this);
1232
1252
  }
1233
1253
  setImageBitmap(g, C = 0, i = "cover") {
1234
- o(this, k, { type: "image", bitmap: g, effect: C, size: i }), V(this, Mg, _g).call(this), V(this, wg, Fg).call(this), V(this, xg, qg).call(this);
1254
+ o(this, U, { type: "image", bitmap: g, effect: C, size: i }), L(this, Dg, cI).call(this), L(this, wg, Ng).call(this), L(this, Fg, dI).call(this);
1235
1255
  }
1236
1256
  setBackground(g, C = "cover") {
1237
- I(this, J) && I(this, J) !== g && I(this, J).close(), o(this, J, g), o(this, rg, C ?? "cover"), I(this, k) && I(this, H) > 0 && I(this, v) > 0 && V(this, wg, Fg).call(this);
1257
+ I(this, N) && I(this, N) !== g && I(this, N).close(), o(this, N, g), o(this, bg, C ?? "cover"), I(this, U) && I(this, V) > 0 && I(this, X) > 0 && L(this, wg, Ng).call(this);
1238
1258
  }
1239
1259
  handleMove(g, C, i = 1) {
1240
- I(this, p).moved = !0, I(this, p).dx = (g - I(this, p).targetX) * i, I(this, p).dy = (C - I(this, p).targetY) * i, I(this, p).targetX = g, I(this, p).targetY = C;
1260
+ 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;
1241
1261
  }
1242
1262
  /**
1243
1263
  * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
@@ -1247,365 +1267,365 @@ const vI = class vI {
1247
1267
  * mouse-state machine or the worker message queue.
1248
1268
  */
1249
1269
  splat(g, C, i, s, l = 1) {
1250
- !I(this, kg) || I(this, H) === 0 || (I(this, F) ? V(this, nI, OI).call(this, g, C, i, s, l) : V(this, mI, QI).call(this, g, C, i, s, l));
1270
+ !I(this, Mg) || I(this, V) === 0 || (I(this, D) ? L(this, vI, tC).call(this, g, C, i, s, l) : L(this, RI, oC).call(this, g, C, i, s, l));
1251
1271
  }
1252
1272
  updateQuality(g) {
1253
- g.dpr !== void 0 && o(this, Og, Math.max(0.1, Math.min(1, g.dpr))), g.sim !== void 0 && o(this, dg, Math.max(0.1, Math.min(1, g.sim)));
1273
+ g.dpr !== void 0 && o(this, _g, Math.max(0.1, Math.min(1, g.dpr))), g.sim !== void 0 && o(this, dg, Math.max(0.1, Math.min(1, g.sim)));
1254
1274
  }
1255
1275
  resize(g, C, i) {
1256
- if (i !== void 0 ? o(this, T, i) : typeof window < "u" && window.devicePixelRatio && o(this, T, window.devicePixelRatio), g !== void 0 && g > 0) {
1276
+ if (i !== void 0 ? o(this, F, i) : typeof window < "u" && window.devicePixelRatio && o(this, F, window.devicePixelRatio), g !== void 0 && g > 0) {
1257
1277
  if (C === void 0 || C <= 0)
1258
1278
  return;
1259
- o(this, H, I(this, Vg).width = g), o(this, v, I(this, Vg).height = C), o(this, E, Math.max(1, Math.round(g * I(this, dg)))), o(this, j, Math.max(1, Math.round(C * I(this, dg)))), V(this, eI, hI).call(this);
1279
+ o(this, V, I(this, yg).width = g), o(this, X, I(this, yg).height = C), o(this, P, Math.max(1, Math.round(g * I(this, dg)))), o(this, _, Math.max(1, Math.round(C * I(this, dg)))), L(this, ZI, DI).call(this);
1260
1280
  } else
1261
- V(this, Mg, _g).call(this);
1262
- I(this, k) && V(this, wg, Fg).call(this), V(this, xg, qg).call(this);
1281
+ L(this, Dg, cI).call(this);
1282
+ I(this, U) && L(this, wg, Ng).call(this), L(this, Fg, dI).call(this);
1263
1283
  }
1264
1284
  updateConfig(g) {
1265
- Object.assign(I(this, cg), g);
1285
+ Object.assign(I(this, Sg), g);
1266
1286
  }
1267
1287
  destroy() {
1268
- var g, C, i, s, l, t, B, S, c, u, a;
1269
- if (o(this, iI, !0), this.stop(), V(this, sI, yI).call(this), V(this, lI, KI).call(this), I(this, J) && (I(this, J).close(), o(this, J, null)), I(this, F))
1270
- (g = I(this, Kg)) == 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(), (B = I(this, og)) == null || B.destroy(), (S = I(this, Wg)) == null || S.destroy(), (c = I(this, Yg)) == null || c.destroy(), (u = I(this, Ug)) == null || u.destroy(), (a = I(this, yg)) == null || a.destroy(), I(this, F).device.destroy();
1288
+ var g, C, i, s, l, t, S, u, c, p, a;
1289
+ if (o(this, pI, !0), this.stop(), L(this, BI, FI).call(this), L(this, GI, JI).call(this), I(this, N) && (I(this, N).close(), o(this, N, null)), I(this, D))
1290
+ (g = I(this, Xg)) == null || g.destroy(), (C = I(this, vg)) == null || C.destroy(), (i = I(this, Rg)) == null || i.destroy(), (s = I(this, Wg)) == null || s.destroy(), (l = I(this, Yg)) == null || l.destroy(), (t = I(this, Ag)) == null || t.destroy(), (S = I(this, cg)) == null || S.destroy(), (u = I(this, Ug)) == null || u.destroy(), (c = I(this, xg)) == null || c.destroy(), (p = I(this, kg)) == null || p.destroy(), (a = I(this, Hg)) == null || a.destroy(), I(this, D).device.destroy();
1271
1291
  else {
1272
- const d = I(this, Q);
1273
- for (const n of Object.values(I(this, hg)))
1274
- n.dispose();
1275
- const Z = d.getExtension("WEBGL_lose_context");
1276
- Z == null || Z.loseContext();
1292
+ const A = I(this, j);
1293
+ for (const Z of Object.values(I(this, Vg)))
1294
+ Z.dispose();
1295
+ const m = A.getExtension("WEBGL_lose_context");
1296
+ m == null || m.loseContext();
1277
1297
  }
1278
1298
  }
1279
1299
  // ---------------------------------------------------------------------------
1280
1300
  // Loop control
1281
1301
  // ---------------------------------------------------------------------------
1282
1302
  start() {
1283
- if (I(this, eg) !== null)
1303
+ if (I(this, lg) !== null)
1284
1304
  return;
1285
1305
  const g = () => {
1286
- V(this, ZI, JI).call(this), o(this, eg, kI(g));
1306
+ L(this, HI, sC).call(this), o(this, lg, PI(g));
1287
1307
  };
1288
- o(this, eg, kI(g));
1308
+ o(this, lg, PI(g));
1289
1309
  }
1290
1310
  stop() {
1291
- I(this, eg) !== null && (YC(I(this, eg)), o(this, eg, null));
1311
+ I(this, lg) !== null && (jC(I(this, lg)), o(this, lg, null));
1292
1312
  }
1293
1313
  get isRunning() {
1294
- return I(this, eg) !== null;
1314
+ return I(this, lg) !== null;
1295
1315
  }
1296
1316
  };
1297
- Vg = new WeakMap(), Q = new WeakMap(), CI = new WeakMap(), hg = new WeakMap(), zg = new WeakMap(), D = new WeakMap(), X = new WeakMap(), $ = new WeakMap(), gg = new WeakMap(), Ig = new WeakMap(), lg = new WeakMap(), z = new WeakMap(), Cg = new WeakMap(), F = new WeakMap(), Jg = new WeakMap(), yg = new WeakMap(), Ng = new WeakMap(), M = new WeakMap(), K = new WeakMap(), ng = new WeakMap(), ig = new WeakMap(), mg = new WeakMap(), N = new WeakMap(), Kg = new WeakMap(), Hg = new WeakMap(), Xg = new WeakMap(), vg = new WeakMap(), Rg = new WeakMap(), tg = new WeakMap(), og = new WeakMap(), Wg = new WeakMap(), Yg = new WeakMap(), Ug = new WeakMap(), H = new WeakMap(), v = new WeakMap(), E = new WeakMap(), j = new WeakMap(), T = new WeakMap(), Og = new WeakMap(), dg = new WeakMap(), J = new WeakMap(), rg = new WeakMap(), cg = new WeakMap(), p = new WeakMap(), k = new WeakMap(), eg = new WeakMap(), kg = new WeakMap(), iI = new WeakMap(), Dg = new WeakMap(), SI = new WeakSet(), zI = function(g) {
1317
+ yg = new WeakMap(), j = new WeakMap(), mI = new WeakMap(), Vg = new WeakMap(), Og = new WeakMap(), k = new WeakMap(), H = new WeakMap(), Ig = new WeakMap(), Cg = new WeakMap(), ig = new WeakMap(), og = new WeakMap(), z = new WeakMap(), eg = new WeakMap(), D = new WeakMap(), jg = new WeakMap(), Hg = new WeakMap(), Pg = new WeakMap(), M = new WeakMap(), h = new WeakMap(), rg = new WeakMap(), sg = new WeakMap(), ng = new WeakMap(), E = new WeakMap(), Xg = new WeakMap(), vg = new WeakMap(), Rg = new WeakMap(), Wg = new WeakMap(), Yg = new WeakMap(), Ag = new WeakMap(), cg = new WeakMap(), Ug = new WeakMap(), xg = new WeakMap(), kg = new WeakMap(), V = new WeakMap(), X = new WeakMap(), P = new WeakMap(), _ = new WeakMap(), F = new WeakMap(), _g = new WeakMap(), dg = new WeakMap(), N = new WeakMap(), bg = new WeakMap(), Sg = new WeakMap(), w = new WeakMap(), U = new WeakMap(), lg = new WeakMap(), Mg = new WeakMap(), pI = new WeakMap(), fg = new WeakMap(), VI = new WeakSet(), eC = function(g) {
1298
1318
  const { device: C, format: i } = g;
1299
- o(this, Jg, HC(C, i, I(this, Dg))), o(this, yg, yC(C)), o(this, Ng, XC(C)), o(this, Kg, 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, Wg, q(C, 16)), o(this, Yg, q(C, 16)), o(this, Ug, q(C, 64));
1300
- }, Mg = new WeakSet(), _g = function() {
1301
- const g = I(this, Vg);
1302
- "clientWidth" in g && g.clientWidth > 0 ? (o(this, T, (typeof window < "u" && window.devicePixelRatio || 1) * I(this, Og)), 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, dg)))), o(this, j, Math.max(1, Math.round(I(this, v) * I(this, dg)))), V(this, eI, hI).call(this));
1303
- }, eI = new WeakSet(), hI = function() {
1304
- if (V(this, sI, yI).call(this), I(this, F)) {
1305
- const { device: g } = I(this, F), C = "rgba16float", i = I(this, E), s = I(this, j);
1306
- o(this, M, VI(g, C, i, s)), o(this, K, VI(g, C, i, s)), o(this, ig, VI(g, C, i, s)), o(this, ng, BI(g, C, i, s)), o(this, mg, BI(g, C, i, s));
1319
+ o(this, jg, zC(C, i, I(this, fg))), o(this, Hg, JC(C)), o(this, Pg, NC(C)), o(this, Xg, gg(C, 16)), o(this, vg, gg(C, 16)), o(this, Rg, gg(C, 16)), o(this, Wg, gg(C, 16)), o(this, Yg, gg(C, 16)), o(this, Ag, gg(C, 48)), o(this, cg, gg(C, 48)), o(this, Ug, gg(C, 16)), o(this, xg, gg(C, 16)), o(this, kg, gg(C, 64));
1320
+ }, Dg = new WeakSet(), cI = function() {
1321
+ const g = I(this, yg);
1322
+ "clientWidth" in g && g.clientWidth > 0 ? (o(this, F, (typeof window < "u" && window.devicePixelRatio || 1) * I(this, _g)), o(this, V, g.width = Math.round(g.clientWidth * I(this, F))), o(this, X, g.height = Math.round(g.clientHeight * I(this, F)))) : (o(this, V, g.width), o(this, X, g.height)), !(I(this, V) === 0 || I(this, X) === 0) && (o(this, P, Math.max(1, Math.round(I(this, V) * I(this, dg)))), o(this, _, Math.max(1, Math.round(I(this, X) * I(this, dg)))), L(this, ZI, DI).call(this));
1323
+ }, ZI = new WeakSet(), DI = function() {
1324
+ if (L(this, BI, FI).call(this), I(this, D)) {
1325
+ const { device: g } = I(this, D), C = "rgba16float", i = I(this, P), s = I(this, _);
1326
+ o(this, M, fI(g, C, i, s)), o(this, h, fI(g, C, i, s)), o(this, sg, fI(g, C, i, s)), o(this, rg, KI(g, C, i, s)), o(this, ng, KI(g, C, i, s));
1307
1327
  } else {
1308
- const g = I(this, Q), C = I(this, CI), i = I(this, E), s = I(this, j);
1309
- o(this, D, bI(g, C, i, s)), o(this, X, bI(g, C, i, s)), o(this, gg, bI(g, C, i, s)), o(this, $, aI(g, C, i, s)), o(this, Ig, aI(g, C, i, s));
1328
+ const g = I(this, j), C = I(this, mI), i = I(this, P), s = I(this, _);
1329
+ o(this, k, MI(g, C, i, s)), o(this, H, MI(g, C, i, s)), o(this, Cg, MI(g, C, i, s)), o(this, Ig, hI(g, C, i, s)), o(this, ig, hI(g, C, i, s));
1310
1330
  }
1311
- }, wg = new WeakSet(), Fg = function() {
1312
- if (!(!I(this, k) || I(this, H) === 0 || I(this, v) === 0)) {
1313
- if (V(this, lI, KI).call(this), I(this, F)) {
1314
- const { device: g } = I(this, F);
1315
- I(this, k).type === "text" ? o(this, N, eC(
1331
+ }, wg = new WeakSet(), Ng = function() {
1332
+ if (!(!I(this, U) || I(this, V) === 0 || I(this, X) === 0)) {
1333
+ if (L(this, GI, JI).call(this), I(this, D)) {
1334
+ const { device: g } = I(this, D);
1335
+ I(this, U).type === "text" ? o(this, E, GC(
1316
1336
  g,
1317
- I(this, H),
1318
- I(this, v),
1319
- I(this, k).opts,
1320
- I(this, J),
1321
- I(this, rg)
1322
- )) : o(this, N, sC(
1337
+ I(this, V),
1338
+ I(this, X),
1339
+ I(this, U).opts,
1340
+ I(this, N),
1341
+ I(this, bg)
1342
+ )) : o(this, E, rC(
1323
1343
  g,
1324
- I(this, k).bitmap,
1325
- I(this, H),
1326
- I(this, v),
1327
- I(this, k).effect,
1328
- I(this, k).size,
1329
- I(this, J),
1330
- I(this, rg)
1344
+ I(this, U).bitmap,
1345
+ I(this, V),
1346
+ I(this, X),
1347
+ I(this, U).effect,
1348
+ I(this, U).size,
1349
+ I(this, N),
1350
+ I(this, bg)
1331
1351
  ));
1332
1352
  } else {
1333
- const g = I(this, Q);
1334
- if (I(this, k).type === "text") {
1335
- const { backgroundTex: C, obstacleTex: i, coverageTex: s } = CC(
1353
+ const g = I(this, j);
1354
+ if (I(this, U).type === "text") {
1355
+ const { backgroundTex: C, obstacleTex: i, coverageTex: s } = ZC(
1336
1356
  g,
1337
- I(this, H),
1338
- I(this, v),
1339
- I(this, k).opts,
1340
- I(this, J),
1341
- I(this, rg)
1357
+ I(this, V),
1358
+ I(this, X),
1359
+ I(this, U).opts,
1360
+ I(this, N),
1361
+ I(this, bg)
1342
1362
  );
1343
- o(this, lg, C), o(this, z, i), o(this, Cg, s);
1363
+ o(this, og, C), o(this, z, i), o(this, eg, s);
1344
1364
  } else {
1345
- const { backgroundTex: C, obstacleTex: i, coverageTex: s } = iC(
1365
+ const { backgroundTex: C, obstacleTex: i, coverageTex: s } = BC(
1346
1366
  g,
1347
- I(this, k).bitmap,
1348
- I(this, H),
1349
- I(this, v),
1350
- I(this, k).effect,
1351
- I(this, k).size,
1352
- I(this, J),
1353
- I(this, rg)
1367
+ I(this, U).bitmap,
1368
+ I(this, V),
1369
+ I(this, X),
1370
+ I(this, U).effect,
1371
+ I(this, U).size,
1372
+ I(this, N),
1373
+ I(this, bg)
1354
1374
  );
1355
- o(this, lg, C), o(this, z, i), o(this, Cg, s);
1375
+ o(this, og, C), o(this, z, i), o(this, eg, s);
1356
1376
  }
1357
1377
  }
1358
- o(this, kg, !0);
1378
+ o(this, Mg, !0);
1359
1379
  }
1360
- }, xg = new WeakSet(), qg = function() {
1361
- I(this, kg) && !this.isRunning && this.start();
1362
- }, sI = new WeakSet(), yI = function() {
1363
- var g, C, i, s, l, t, B, S;
1364
- if (I(this, F))
1365
- (g = I(this, M)) == null || g.dispose(), (C = I(this, K)) == null || C.dispose(), (i = I(this, ig)) == null || i.dispose(), (s = I(this, ng)) == null || s.tex.destroy(), (l = I(this, mg)) == null || l.tex.destroy(), o(this, M, o(this, K, o(this, ig, null))), o(this, ng, o(this, mg, null));
1380
+ }, Fg = new WeakSet(), dI = function() {
1381
+ I(this, Mg) && !this.isRunning && this.start();
1382
+ }, BI = new WeakSet(), FI = function() {
1383
+ var g, C, i, s, l, t, S, u;
1384
+ if (I(this, D))
1385
+ (g = I(this, M)) == null || g.dispose(), (C = I(this, h)) == null || C.dispose(), (i = I(this, sg)) == null || i.dispose(), (s = I(this, rg)) == null || s.tex.destroy(), (l = I(this, ng)) == null || l.tex.destroy(), o(this, M, o(this, h, o(this, sg, null))), o(this, rg, o(this, ng, null));
1366
1386
  else {
1367
- const c = I(this, Q);
1368
- (t = I(this, D)) == null || t.dispose(), (B = I(this, X)) == null || B.dispose(), (S = I(this, gg)) == null || S.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, D, o(this, X, o(this, gg, o(this, $, o(this, Ig, null)))));
1387
+ const c = I(this, j);
1388
+ (t = I(this, k)) == null || t.dispose(), (S = I(this, H)) == null || S.dispose(), (u = I(this, Cg)) == null || u.dispose(), I(this, Ig) && (c.deleteTexture(I(this, Ig).tex), c.deleteFramebuffer(I(this, Ig).fbo)), I(this, ig) && (c.deleteTexture(I(this, ig).tex), c.deleteFramebuffer(I(this, ig).fbo)), o(this, k, o(this, H, o(this, Cg, o(this, Ig, o(this, ig, null)))));
1369
1389
  }
1370
- }, lI = new WeakSet(), KI = function() {
1371
- if (I(this, F))
1372
- 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));
1390
+ }, GI = new WeakSet(), JI = function() {
1391
+ if (I(this, D))
1392
+ I(this, E) && (I(this, E).backgroundTex.destroy(), I(this, E).obstacleTex.destroy(), I(this, E).sharedCoverage || I(this, E).coverageTex.destroy(), o(this, E, null));
1373
1393
  else {
1374
- const g = I(this, Q);
1375
- I(this, lg) && g.deleteTexture(I(this, lg)), I(this, z) && g.deleteTexture(I(this, z)), I(this, Cg) && I(this, Cg) !== I(this, z) && g.deleteTexture(I(this, Cg)), o(this, lg, o(this, z, o(this, Cg, null)));
1394
+ const g = I(this, j);
1395
+ I(this, og) && g.deleteTexture(I(this, og)), I(this, z) && g.deleteTexture(I(this, z)), I(this, eg) && I(this, eg) !== I(this, z) && g.deleteTexture(I(this, eg)), o(this, og, o(this, z, o(this, eg, null)));
1376
1396
  }
1377
- }, ZI = new WeakSet(), JI = function() {
1378
- !I(this, kg) || I(this, H) === 0 || (I(this, F) ? V(this, GI, NI).call(this) : V(this, rI, EI).call(this));
1379
- }, GI = new WeakSet(), NI = function() {
1380
- const g = I(this, F), C = g.device, i = I(this, Jg), s = I(this, yg), l = I(this, Ng), t = I(this, cg), B = I(this, N);
1381
- if (!I(this, M) || !I(this, K))
1397
+ }, HI = new WeakSet(), sC = function() {
1398
+ !I(this, Mg) || I(this, V) === 0 || (I(this, D) ? L(this, XI, lC).call(this) : L(this, WI, AC).call(this));
1399
+ }, XI = new WeakSet(), lC = function() {
1400
+ const g = I(this, D), C = g.device, i = I(this, jg), s = I(this, Hg), l = I(this, Pg), t = I(this, Sg), S = I(this, E);
1401
+ if (!I(this, M) || !I(this, h))
1382
1402
  return;
1383
- I(this, p).x += (I(this, p).targetX - I(this, p).x) * 0.15, I(this, p).y += (I(this, p).targetY - I(this, p).y) * 0.15;
1384
- const S = I(this, E), c = I(this, j), u = I(this, H), a = I(this, v), d = 1 / S, Z = 1 / c;
1385
- UI(C, I(this, Kg), d, Z, Pg, t.velocityDissipation), cI(C, I(this, Xg), d, Z), cI(C, I(this, vg), d, Z), cI(C, I(this, Rg), d, Z), cI(C, I(this, Wg), d, Z), vC(C, I(this, Yg), d, Z, t.curl, Pg), RC(
1403
+ 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;
1404
+ const u = I(this, P), c = I(this, _), p = I(this, V), a = I(this, X), A = 1 / u, m = 1 / c;
1405
+ jI(C, I(this, Xg), A, m, AI, t.velocityDissipation), wI(C, I(this, Rg), A, m), wI(C, I(this, Wg), A, m), wI(C, I(this, Yg), A, m), wI(C, I(this, Ug), A, m), QC(C, I(this, xg), A, m, t.curl, AI), EC(
1386
1406
  C,
1387
- I(this, Ug),
1388
- 1 / u,
1407
+ I(this, kg),
1408
+ 1 / p,
1389
1409
  1 / a,
1390
1410
  t.refraction,
1391
1411
  t.specularExp,
1392
- dI(t.waterColor),
1393
- dI(t.glowColor),
1412
+ bI(t.waterColor),
1413
+ bI(t.glowColor),
1394
1414
  t.shine,
1395
1415
  t.warpStrength ?? 0.015,
1396
- DI[t.algorithm] ?? 0,
1397
- I(this, Dg)
1416
+ _I[t.algorithm] ?? 0,
1417
+ I(this, fg)
1398
1418
  );
1399
- const n = C.createCommandEncoder(), w = (m, h) => C.createBindGroup({ layout: m.getBindGroupLayout(0), entries: h }), L = { binding: 1, resource: l };
1419
+ const Z = C.createCommandEncoder(), r = (B, K) => C.createBindGroup({ layout: B.getBindGroupLayout(0), entries: K }), b = { binding: 1, resource: l };
1400
1420
  {
1401
- const m = w(i.advection, [
1402
- { binding: 0, resource: { buffer: I(this, Kg) } },
1403
- L,
1404
- { binding: 2, resource: I(this, K).read.view },
1405
- { binding: 3, resource: I(this, K).read.view },
1406
- { binding: 4, resource: B.obstacleView }
1421
+ const B = r(i.advection, [
1422
+ { binding: 0, resource: { buffer: I(this, Xg) } },
1423
+ b,
1424
+ { binding: 2, resource: I(this, h).read.view },
1425
+ { binding: 3, resource: I(this, h).read.view },
1426
+ { binding: 4, resource: S.obstacleView }
1407
1427
  ]);
1408
- O(n, i.advection, m, s, I(this, K).write.view);
1428
+ O(Z, i.advection, B, s, I(this, h).write.view);
1409
1429
  }
1410
- I(this, K).swap();
1430
+ I(this, h).swap();
1411
1431
  {
1412
- UI(C, I(this, Hg), d, Z, Pg, t.densityDissipation);
1413
- const m = w(i.advection, [
1414
- { binding: 0, resource: { buffer: I(this, Hg) } },
1415
- L,
1416
- { binding: 2, resource: I(this, K).read.view },
1432
+ jI(C, I(this, vg), A, m, AI, t.densityDissipation);
1433
+ const B = r(i.advection, [
1434
+ { binding: 0, resource: { buffer: I(this, vg) } },
1435
+ b,
1436
+ { binding: 2, resource: I(this, h).read.view },
1417
1437
  { binding: 3, resource: I(this, M).read.view },
1418
- { binding: 4, resource: B.obstacleView }
1438
+ { binding: 4, resource: S.obstacleView }
1419
1439
  ]);
1420
- O(n, i.advection, m, s, I(this, M).write.view);
1440
+ O(Z, i.advection, B, s, I(this, M).write.view);
1421
1441
  }
1422
1442
  I(this, M).swap();
1423
1443
  {
1424
- const m = w(i.curl, [
1425
- { binding: 0, resource: { buffer: I(this, Wg) } },
1426
- L,
1427
- { binding: 2, resource: I(this, K).read.view }
1444
+ const B = r(i.curl, [
1445
+ { binding: 0, resource: { buffer: I(this, Ug) } },
1446
+ b,
1447
+ { binding: 2, resource: I(this, h).read.view }
1428
1448
  ]);
1429
- O(n, i.curl, m, s, I(this, mg).view);
1449
+ O(Z, i.curl, B, s, I(this, ng).view);
1430
1450
  }
1431
1451
  {
1432
- const m = w(i.vorticity, [
1433
- { binding: 0, resource: { buffer: I(this, Yg) } },
1434
- L,
1435
- { binding: 2, resource: I(this, K).read.view },
1436
- { binding: 3, resource: I(this, mg).view }
1452
+ const B = r(i.vorticity, [
1453
+ { binding: 0, resource: { buffer: I(this, xg) } },
1454
+ b,
1455
+ { binding: 2, resource: I(this, h).read.view },
1456
+ { binding: 3, resource: I(this, ng).view }
1437
1457
  ]);
1438
- O(n, i.vorticity, m, s, I(this, K).write.view);
1458
+ O(Z, i.vorticity, B, s, I(this, h).write.view);
1439
1459
  }
1440
- if (I(this, K).swap(), I(this, p).moved) {
1441
- const m = I(this, p).x * I(this, T) / u, h = I(this, p).y * I(this, T) / a;
1442
- AI(
1460
+ if (I(this, h).swap(), I(this, w).moved) {
1461
+ const B = I(this, w).x * I(this, F) / p, K = I(this, w).y * I(this, F) / a;
1462
+ LI(
1443
1463
  C,
1444
- I(this, tg),
1445
- d,
1446
- Z,
1447
- u / a,
1464
+ I(this, Ag),
1465
+ A,
1466
+ m,
1467
+ p / a,
1448
1468
  t.splatRadius,
1449
- I(this, p).dx * t.splatForce,
1450
- I(this, p).dy * t.splatForce,
1469
+ I(this, w).dx * t.splatForce,
1470
+ I(this, w).dy * t.splatForce,
1451
1471
  0,
1452
- m,
1453
- h
1472
+ B,
1473
+ K
1454
1474
  );
1455
1475
  {
1456
- const b = w(i.splat, [
1457
- { binding: 0, resource: { buffer: I(this, tg) } },
1458
- L,
1459
- { binding: 2, resource: I(this, K).read.view }
1476
+ const W = r(i.splat, [
1477
+ { binding: 0, resource: { buffer: I(this, Ag) } },
1478
+ b,
1479
+ { binding: 2, resource: I(this, h).read.view }
1460
1480
  ]);
1461
- O(n, i.splat, b, s, I(this, K).write.view);
1481
+ O(Z, i.splat, W, s, I(this, h).write.view);
1462
1482
  }
1463
- I(this, K).swap(), AI(
1483
+ I(this, h).swap(), LI(
1464
1484
  C,
1465
- I(this, og),
1466
- d,
1467
- Z,
1468
- u / a,
1485
+ I(this, cg),
1486
+ A,
1487
+ m,
1488
+ p / a,
1469
1489
  t.splatRadius,
1470
1490
  1,
1471
1491
  1,
1472
1492
  1,
1473
- m,
1474
- h
1493
+ B,
1494
+ K
1475
1495
  );
1476
1496
  {
1477
- const b = w(i.splat, [
1478
- { binding: 0, resource: { buffer: I(this, og) } },
1479
- L,
1497
+ const W = r(i.splat, [
1498
+ { binding: 0, resource: { buffer: I(this, cg) } },
1499
+ b,
1480
1500
  { binding: 2, resource: I(this, M).read.view }
1481
1501
  ]);
1482
- O(n, i.splat, b, s, I(this, M).write.view);
1502
+ O(Z, i.splat, W, s, I(this, M).write.view);
1483
1503
  }
1484
- I(this, M).swap(), I(this, p).moved = !1;
1504
+ I(this, M).swap(), I(this, w).moved = !1;
1485
1505
  }
1486
1506
  {
1487
- const m = w(i.divergence, [
1488
- { binding: 0, resource: { buffer: I(this, Xg) } },
1489
- L,
1490
- { binding: 2, resource: I(this, K).read.view },
1491
- { binding: 3, resource: B.obstacleView }
1507
+ const B = r(i.divergence, [
1508
+ { binding: 0, resource: { buffer: I(this, Rg) } },
1509
+ b,
1510
+ { binding: 2, resource: I(this, h).read.view },
1511
+ { binding: 3, resource: S.obstacleView }
1492
1512
  ]);
1493
- O(n, i.divergence, m, s, I(this, ng).view);
1513
+ O(Z, i.divergence, B, s, I(this, rg).view);
1494
1514
  }
1495
- for (let m = 0; m < t.pressureIterations; m++) {
1496
- const h = w(i.pressure, [
1497
- { binding: 0, resource: { buffer: I(this, vg) } },
1498
- L,
1499
- { binding: 2, resource: I(this, ig).read.view },
1500
- { binding: 3, resource: I(this, ng).view },
1501
- { binding: 4, resource: B.obstacleView }
1515
+ for (let B = 0; B < t.pressureIterations; B++) {
1516
+ const K = r(i.pressure, [
1517
+ { binding: 0, resource: { buffer: I(this, Wg) } },
1518
+ b,
1519
+ { binding: 2, resource: I(this, sg).read.view },
1520
+ { binding: 3, resource: I(this, rg).view },
1521
+ { binding: 4, resource: S.obstacleView }
1502
1522
  ]);
1503
- O(n, i.pressure, h, s, I(this, ig).write.view), I(this, ig).swap();
1523
+ O(Z, i.pressure, K, s, I(this, sg).write.view), I(this, sg).swap();
1504
1524
  }
1505
1525
  {
1506
- const m = w(i.gradientSubtract, [
1507
- { binding: 0, resource: { buffer: I(this, Rg) } },
1508
- L,
1509
- { binding: 2, resource: I(this, ig).read.view },
1510
- { binding: 3, resource: I(this, K).read.view },
1511
- { binding: 4, resource: B.obstacleView }
1526
+ const B = r(i.gradientSubtract, [
1527
+ { binding: 0, resource: { buffer: I(this, Yg) } },
1528
+ b,
1529
+ { binding: 2, resource: I(this, sg).read.view },
1530
+ { binding: 3, resource: I(this, h).read.view },
1531
+ { binding: 4, resource: S.obstacleView }
1512
1532
  ]);
1513
- O(n, i.gradientSubtract, m, s, I(this, K).write.view);
1533
+ O(Z, i.gradientSubtract, B, s, I(this, h).write.view);
1514
1534
  }
1515
- I(this, K).swap();
1535
+ I(this, h).swap();
1516
1536
  {
1517
- const m = g.context.getCurrentTexture().createView(), h = w(i.display, [
1518
- { binding: 0, resource: { buffer: I(this, Ug) } },
1519
- L,
1537
+ const B = g.context.getCurrentTexture().createView(), K = r(i.display, [
1538
+ { binding: 0, resource: { buffer: I(this, kg) } },
1539
+ b,
1520
1540
  { binding: 2, resource: I(this, M).read.view },
1521
- { binding: 3, resource: B.obstacleView },
1522
- { binding: 4, resource: B.backgroundView },
1523
- { binding: 5, resource: B.coverageView },
1524
- { binding: 6, resource: I(this, K).read.view }
1541
+ { binding: 3, resource: S.obstacleView },
1542
+ { binding: 4, resource: S.backgroundView },
1543
+ { binding: 5, resource: S.coverageView },
1544
+ { binding: 6, resource: I(this, h).read.view }
1525
1545
  ]);
1526
- WC(n, i.display, h, s, m);
1546
+ OC(Z, i.display, K, s, B);
1527
1547
  }
1528
- C.queue.submit([n.finish()]);
1529
- }, nI = new WeakSet(), OI = function(g, C, i, s, l) {
1530
- const B = I(this, F).device, S = I(this, Jg).splat, c = I(this, yg), u = I(this, Ng), a = I(this, cg), d = I(this, E), Z = I(this, j), n = 1 / d, w = 1 / Z, L = B.createCommandEncoder(), m = { binding: 1, resource: u }, h = (G) => B.createBindGroup({ layout: S.getBindGroupLayout(0), entries: G }), b = g * I(this, T) / I(this, H), U = C * I(this, T) / I(this, v);
1531
- AI(
1532
- B,
1533
- I(this, tg),
1534
- n,
1535
- w,
1536
- I(this, H) / I(this, v),
1548
+ C.queue.submit([Z.finish()]);
1549
+ }, vI = new WeakSet(), tC = function(g, C, i, s, l) {
1550
+ const S = I(this, D).device, u = I(this, jg).splat, c = I(this, Hg), p = I(this, Pg), a = I(this, Sg), A = I(this, P), m = I(this, _), Z = 1 / A, r = 1 / m, b = S.createCommandEncoder(), B = { binding: 1, resource: p }, K = (Q) => S.createBindGroup({ layout: u.getBindGroupLayout(0), entries: Q }), W = g * I(this, F) / I(this, V), x = C * I(this, F) / I(this, X);
1551
+ LI(
1552
+ S,
1553
+ I(this, Ag),
1554
+ Z,
1555
+ r,
1556
+ I(this, V) / I(this, X),
1537
1557
  a.splatRadius,
1538
1558
  i * a.splatForce * l,
1539
1559
  s * a.splatForce * l,
1540
1560
  0,
1541
- b,
1542
- U
1561
+ W,
1562
+ x
1543
1563
  );
1544
1564
  {
1545
- const G = h([
1546
- { binding: 0, resource: { buffer: I(this, tg) } },
1547
- m,
1548
- { binding: 2, resource: I(this, K).read.view }
1565
+ const Q = K([
1566
+ { binding: 0, resource: { buffer: I(this, Ag) } },
1567
+ B,
1568
+ { binding: 2, resource: I(this, h).read.view }
1549
1569
  ]);
1550
- O(L, S, G, c, I(this, K).write.view);
1570
+ O(b, u, Q, c, I(this, h).write.view);
1551
1571
  }
1552
- I(this, K).swap(), AI(
1553
- B,
1554
- I(this, og),
1555
- n,
1556
- w,
1557
- I(this, H) / I(this, v),
1572
+ I(this, h).swap(), LI(
1573
+ S,
1574
+ I(this, cg),
1575
+ Z,
1576
+ r,
1577
+ I(this, V) / I(this, X),
1558
1578
  a.splatRadius,
1559
1579
  l,
1560
1580
  l,
1561
1581
  l,
1562
- b,
1563
- U
1582
+ W,
1583
+ x
1564
1584
  );
1565
1585
  {
1566
- const G = h([
1567
- { binding: 0, resource: { buffer: I(this, og) } },
1568
- m,
1586
+ const Q = K([
1587
+ { binding: 0, resource: { buffer: I(this, cg) } },
1588
+ B,
1569
1589
  { binding: 2, resource: I(this, M).read.view }
1570
1590
  ]);
1571
- O(L, S, G, c, I(this, M).write.view);
1591
+ O(b, u, Q, c, I(this, M).write.view);
1572
1592
  }
1573
- I(this, M).swap(), B.queue.submit([L.finish()]);
1574
- }, mI = new WeakSet(), QI = function(g, C, i, s, l) {
1575
- const t = I(this, Q), B = I(this, cg), S = I(this, hg).splat, c = I(this, zg);
1576
- t.viewport(0, 0, I(this, E), I(this, j)), S.bind(), t.uniform1f(S.uniforms.aspectRatio, I(this, H) / I(this, v)), t.uniform2f(S.uniforms.point, g * I(this, T) / I(this, H), 1 - C * I(this, T) / I(this, v)), t.uniform1f(S.uniforms.radius, B.splatRadius), t.uniform1i(S.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, I(this, X).read.tex), t.uniform3f(S.uniforms.color, i * B.splatForce * l, -s * B.splatForce * l, 0), c(I(this, X).write.fbo), I(this, X).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, I(this, D).read.tex), t.uniform3f(S.uniforms.color, l, l, l), c(I(this, D).write.fbo), I(this, D).swap();
1577
- }, rI = new WeakSet(), EI = function() {
1578
- if (!I(this, D) || !I(this, X))
1593
+ I(this, M).swap(), S.queue.submit([b.finish()]);
1594
+ }, RI = new WeakSet(), oC = function(g, C, i, s, l) {
1595
+ const t = I(this, j), S = I(this, Sg), u = I(this, Vg).splat, c = I(this, Og);
1596
+ t.viewport(0, 0, I(this, P), I(this, _)), u.bind(), t.uniform1f(u.uniforms.aspectRatio, I(this, V) / I(this, X)), t.uniform2f(u.uniforms.point, g * I(this, F) / I(this, V), 1 - C * I(this, F) / I(this, X)), t.uniform1f(u.uniforms.radius, S.splatRadius), t.uniform1i(u.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, I(this, H).read.tex), t.uniform3f(u.uniforms.color, i * S.splatForce * l, -s * S.splatForce * l, 0), c(I(this, H).write.fbo), I(this, H).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, I(this, k).read.tex), t.uniform3f(u.uniforms.color, l, l, l), c(I(this, k).write.fbo), I(this, k).swap();
1597
+ }, WI = new WeakSet(), AC = function() {
1598
+ if (!I(this, k) || !I(this, H))
1579
1599
  return;
1580
- const g = I(this, Q), C = I(this, cg), { advection: i, divergence: s, pressure: l, gradientSubtract: t, splat: B, curl: S, vorticity: c, display: u } = I(this, hg);
1581
- I(this, p).x += (I(this, p).targetX - I(this, p).x) * 0.15, I(this, p).y += (I(this, p).targetY - I(this, p).y) * 0.15;
1582
- const a = I(this, E), d = I(this, j), Z = I(this, zg);
1583
- g.viewport(0, 0, a, d), i.bind(), g.uniform2f(i.uniforms.texelSize, 1 / a, 1 / d), g.uniform1f(i.uniforms.dt, Pg), g.uniform1i(i.uniforms.uObstacle, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, z)), 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), Z(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, D).read.tex), Z(I(this, D).write.fbo), I(this, D).swap(), S.bind(), g.uniform2f(S.uniforms.texelSize, 1 / a, 1 / d), g.uniform1i(S.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), Z(I(this, Ig).fbo), c.bind(), g.uniform2f(c.uniforms.texelSize, 1 / a, 1 / d), 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), Z(I(this, X).write.fbo), I(this, X).swap(), I(this, p).moved && (B.bind(), g.uniform1f(B.uniforms.aspectRatio, I(this, H) / I(this, v)), g.uniform2f(B.uniforms.point, I(this, p).x * I(this, T) / I(this, H), 1 - I(this, p).y * I(this, T) / I(this, v)), g.uniform1f(B.uniforms.radius, C.splatRadius), g.uniform1i(B.uniforms.uTarget, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, X).read.tex), g.uniform3f(B.uniforms.color, I(this, p).dx * C.splatForce, -I(this, p).dy * C.splatForce, 0), Z(I(this, X).write.fbo), I(this, X).swap(), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, D).read.tex), g.uniform3f(B.uniforms.color, 1, 1, 1), Z(I(this, D).write.fbo), I(this, D).swap(), I(this, p).moved = !1), s.bind(), g.uniform2f(s.uniforms.texelSize, 1 / a, 1 / d), 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, z)), Z(I(this, $).fbo), l.bind(), g.uniform2f(l.uniforms.texelSize, 1 / a, 1 / d), 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, z));
1584
- for (let n = 0; n < C.pressureIterations; n++)
1585
- g.uniform1i(l.uniforms.uPressure, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, gg).read.tex), Z(I(this, gg).write.fbo), I(this, gg).swap();
1586
- t.bind(), g.uniform2f(t.uniforms.texelSize, 1 / a, 1 / d), 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, z)), Z(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), u.bind(), g.uniform2f(u.uniforms.texelSize, 1 / I(this, H), 1 / I(this, v)), g.uniform3fv(u.uniforms.uWaterColor, dI(C.waterColor)), g.uniform3fv(u.uniforms.uGlowColor, dI(C.glowColor)), g.uniform1f(u.uniforms.uRefraction, C.refraction), g.uniform1f(u.uniforms.uSpecularExp, C.specularExp), g.uniform1f(u.uniforms.uShine, C.shine), g.uniform1f(u.uniforms.uWarpStrength, C.warpStrength ?? 0.015), g.uniform1i(u.uniforms.uAlgorithm, DI[C.algorithm] ?? 0), g.uniform1i(u.uniforms.uEnableAlpha, I(this, Dg) ? 1 : 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, D).read.tex), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, z)), 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(u.uniforms.uTexture, 0), g.uniform1i(u.uniforms.uObstacle, 1), g.uniform1i(u.uniforms.uBackground, 2), g.uniform1i(u.uniforms.uCoverage, 3), g.uniform1i(u.uniforms.uVelocity, 4), Z(null);
1600
+ const g = I(this, j), C = I(this, Sg), { advection: i, divergence: s, pressure: l, gradientSubtract: t, splat: S, curl: u, vorticity: c, display: p } = I(this, Vg);
1601
+ 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;
1602
+ const a = I(this, P), A = I(this, _), m = I(this, Og);
1603
+ g.viewport(0, 0, a, A), i.bind(), g.uniform2f(i.uniforms.texelSize, 1 / a, 1 / A), g.uniform1f(i.uniforms.dt, AI), g.uniform1i(i.uniforms.uObstacle, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, z)), g.uniform1f(i.uniforms.dissipation, C.velocityDissipation), g.uniform1i(i.uniforms.uVelocity, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, H).read.tex), g.uniform1i(i.uniforms.uSource, 1), m(I(this, H).write.fbo), I(this, H).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, k).read.tex), m(I(this, k).write.fbo), I(this, k).swap(), u.bind(), g.uniform2f(u.uniforms.texelSize, 1 / a, 1 / A), g.uniform1i(u.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, H).read.tex), m(I(this, ig).fbo), c.bind(), g.uniform2f(c.uniforms.texelSize, 1 / a, 1 / A), g.uniform1f(c.uniforms.curl, C.curl), g.uniform1f(c.uniforms.dt, AI), g.uniform1i(c.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, H).read.tex), g.uniform1i(c.uniforms.uCurl, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, ig).tex), m(I(this, H).write.fbo), I(this, H).swap(), I(this, w).moved && (S.bind(), g.uniform1f(S.uniforms.aspectRatio, I(this, V) / I(this, X)), g.uniform2f(S.uniforms.point, I(this, w).x * I(this, F) / I(this, V), 1 - I(this, w).y * I(this, F) / I(this, X)), g.uniform1f(S.uniforms.radius, C.splatRadius), g.uniform1i(S.uniforms.uTarget, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, H).read.tex), g.uniform3f(S.uniforms.color, I(this, w).dx * C.splatForce, -I(this, w).dy * C.splatForce, 0), m(I(this, H).write.fbo), I(this, H).swap(), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, k).read.tex), g.uniform3f(S.uniforms.color, 1, 1, 1), m(I(this, k).write.fbo), I(this, k).swap(), I(this, w).moved = !1), s.bind(), g.uniform2f(s.uniforms.texelSize, 1 / a, 1 / A), g.uniform1i(s.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, H).read.tex), g.uniform1i(s.uniforms.uObstacle, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, z)), m(I(this, Ig).fbo), l.bind(), g.uniform2f(l.uniforms.texelSize, 1 / a, 1 / A), g.uniform1i(l.uniforms.uDivergence, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, Ig).tex), g.uniform1i(l.uniforms.uObstacle, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, z));
1604
+ for (let Z = 0; Z < C.pressureIterations; Z++)
1605
+ g.uniform1i(l.uniforms.uPressure, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, Cg).read.tex), m(I(this, Cg).write.fbo), I(this, Cg).swap();
1606
+ t.bind(), g.uniform2f(t.uniforms.texelSize, 1 / a, 1 / A), g.uniform1i(t.uniforms.uPressure, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, Cg).read.tex), g.uniform1i(t.uniforms.uVelocity, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, H).read.tex), g.uniform1i(t.uniforms.uObstacle, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, z)), m(I(this, H).write.fbo), I(this, H).swap(), g.viewport(0, 0, I(this, V), I(this, X)), g.bindFramebuffer(g.FRAMEBUFFER, null), g.clear(g.COLOR_BUFFER_BIT), p.bind(), g.uniform2f(p.uniforms.texelSize, 1 / I(this, V), 1 / I(this, X)), g.uniform3fv(p.uniforms.uWaterColor, bI(C.waterColor)), g.uniform3fv(p.uniforms.uGlowColor, bI(C.glowColor)), g.uniform1f(p.uniforms.uRefraction, C.refraction), g.uniform1f(p.uniforms.uSpecularExp, C.specularExp), g.uniform1f(p.uniforms.uShine, C.shine), g.uniform1f(p.uniforms.uWarpStrength, C.warpStrength ?? 0.015), g.uniform1i(p.uniforms.uAlgorithm, _I[C.algorithm] ?? 0), g.uniform1i(p.uniforms.uEnableAlpha, I(this, fg) ? 1 : 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, k).read.tex), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, z)), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, og)), g.activeTexture(g.TEXTURE3), g.bindTexture(g.TEXTURE_2D, I(this, eg)), g.activeTexture(g.TEXTURE4), g.bindTexture(g.TEXTURE_2D, I(this, H).read.tex), g.uniform1i(p.uniforms.uTexture, 0), g.uniform1i(p.uniforms.uObstacle, 1), g.uniform1i(p.uniforms.uBackground, 2), g.uniform1i(p.uniforms.uCoverage, 3), g.uniform1i(p.uniforms.uVelocity, 4), m(null);
1587
1607
  };
1588
- let uI = vI;
1589
- const jI = "dmFyIFR0ID0gT2JqZWN0LmRlZmluZVByb3BlcnR5Owp2YXIgeXQgPSAoaSwgZSwgcikgPT4gZSBpbiBpID8gVHQoaSwgZSwgeyBlbnVtZXJhYmxlOiAhMCwgY29uZmlndXJhYmxlOiAhMCwgd3JpdGFibGU6ICEwLCB2YWx1ZTogciB9KSA6IGlbZV0gPSByOwp2YXIga2UgPSAoaSwgZSwgcikgPT4gKHl0KGksIHR5cGVvZiBlICE9ICJzeW1ib2wiID8gZSArICIiIDogZSwgciksIHIpLCBldCA9IChpLCBlLCByKSA9PiB7CiAgaWYgKCFlLmhhcyhpKSkKICAgIHRocm93IFR5cGVFcnJvcigiQ2Fubm90ICIgKyByKTsKfTsKdmFyIHQgPSAoaSwgZSwgcikgPT4gKGV0KGksIGUsICJyZWFkIGZyb20gcHJpdmF0ZSBmaWVsZCIpLCByID8gci5jYWxsKGkpIDogZS5nZXQoaSkpLCBmID0gKGksIGUsIHIpID0+IHsKICBpZiAoZS5oYXMoaSkpCiAgICB0aHJvdyBUeXBlRXJyb3IoIkNhbm5vdCBhZGQgdGhlIHNhbWUgcHJpdmF0ZSBtZW1iZXIgbW9yZSB0aGFuIG9uY2UiKTsKICBlIGluc3RhbmNlb2YgV2Vha1NldCA/IGUuYWRkKGkpIDogZS5zZXQoaSwgcik7Cn0sIGwgPSAoaSwgZSwgciwgcykgPT4gKGV0KGksIGUsICJ3cml0ZSB0byBwcml2YXRlIGZpZWxkIiksIHMgPyBzLmNhbGwoaSwgcikgOiBlLnNldChpLCByKSwgcik7CnZhciBTID0gKGksIGUsIHIpID0+IChldChpLCBlLCAiYWNjZXNzIHByaXZhdGUgbWV0aG9kIiksIHIpOwpjb25zdCB2dCA9IHsKICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTkyLAogIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgcHJlc3N1cmVJdGVyYXRpb25zOiAxLAogIGN1cmw6IDFlLTQsCiAgc3BsYXRSYWRpdXM6IDRlLTMsCiAgc3BsYXRGb3JjZTogMC45MSwKICByZWZyYWN0aW9uOiAwLjI1LAogIHNwZWN1bGFyRXhwOiAxLjAxLAogIHNoaW5lOiAwLjAxLAogIHdhdGVyQ29sb3I6ICIjMDAwMDAwIiwKICBnbG93Q29sb3I6ICIjYjNkOWZmIiwKICBhbGdvcml0aG06ICJzdGFuZGFyZCIsCiAgd2FycFN0cmVuZ3RoOiAwLjAxNQp9OwooewogIC4uLnZ0Cn0pOwpjb25zdCBTdCA9IHsKICBjYWxtOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk5LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45OCwKICAgIGN1cmw6IDFlLTQsCiAgICBzcGxhdFJhZGl1czogM2UtMywKICAgIHNwbGF0Rm9yY2U6IDAuNSwKICAgIHJlZnJhY3Rpb246IDAuMTUsCiAgICBzaGluZTogNWUtMywKICAgIGdsb3dDb2xvcjogIiM5OWQ5ZmYiLAogICAgd2F0ZXJDb2xvcjogIiMwMDA1MGQiCiAgfSwKICBzYW5kOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk3LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45OCwKICAgIGN1cmw6IDEsCiAgICBzcGxhdFJhZGl1czogMC4wMSwKICAgIHNwbGF0Rm9yY2U6IDAuOSwKICAgIHJlZnJhY3Rpb246IDAuOCwKICAgIHNwZWN1bGFyRXhwOiAwLjEsCiAgICBzaGluZTogMC4wNSwKICAgIGdsb3dDb2xvcjogIiMwNzA3MDciLAogICAgd2F0ZXJDb2xvcjogIiM3MzU0MjAiCiAgfSwKICB3YXZlOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTk0LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45MiwKICAgIGN1cmw6IDAuMiwKICAgIHNwbGF0UmFkaXVzOiA1ZS0zLAogICAgc3BsYXRGb3JjZTogMS4yLAogICAgcmVmcmFjdGlvbjogMC4zNSwKICAgIHNoaW5lOiAwLjAzLAogICAgZ2xvd0NvbG9yOiAiIzgwY2NmZiIsCiAgICB3YXRlckNvbG9yOiAiIzAwMDMwOCIKICB9LAogIG5lb246IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45ODUsCiAgICB2ZWxvY2l0eURpc3NpcGF0aW9uOiAwLjkzLAogICAgY3VybDogMC4wNSwKICAgIHNwbGF0UmFkaXVzOiA4ZS0zLAogICAgc3BsYXRGb3JjZTogMS41LAogICAgcmVmcmFjdGlvbjogMC4yNSwKICAgIHNwZWN1bGFyRXhwOiAwLjUsCiAgICBzaGluZTogMC4xNCwKICAgIGdsb3dDb2xvcjogIiNmZjMzY2MiLAogICAgd2F0ZXJDb2xvcjogIiMwZDAwMTQiCiAgfSwKICBzbW9rZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NiwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTcsCiAgICBjdXJsOiAwLjA0LAogICAgc3BsYXRSYWRpdXM6IDllLTMsCiAgICBzcGxhdEZvcmNlOiAwLjgsCiAgICByZWZyYWN0aW9uOiAwLjA4LAogICAgc2hpbmU6IDAsCiAgICBnbG93Q29sb3I6ICIjODA4MDgwIiwKICAgIHdhdGVyQ29sb3I6ICIjMGYwZjBmIgogIH0KfTsKZnVuY3Rpb24gV2UoaSkgewogIGlmIChBcnJheS5pc0FycmF5KGkpKQogICAgcmV0dXJuIGk7CiAgY29uc3QgZSA9IGkuc2xpY2UoMSwgNyk7CiAgcmV0dXJuIGUubGVuZ3RoID09PSAzID8gWwogICAgcGFyc2VJbnQoZVswXSArIGVbMF0sIDE2KSAvIDI1NSwKICAgIHBhcnNlSW50KGVbMV0gKyBlWzFdLCAxNikgLyAyNTUsCiAgICBwYXJzZUludChlWzJdICsgZVsyXSwgMTYpIC8gMjU1CiAgXSA6IFsKICAgIHBhcnNlSW50KGUuc2xpY2UoMCwgMiksIDE2KSAvIDI1NSwKICAgIHBhcnNlSW50KGUuc2xpY2UoMiwgNCksIDE2KSAvIDI1NSwKICAgIHBhcnNlSW50KGUuc2xpY2UoNCwgNiksIDE2KSAvIDI1NQogIF07Cn0KZnVuY3Rpb24gd3QoaSA9IHt9LCBlLCByID0gdnQpIHsKICByZXR1cm4geyAuLi5lID8geyAuLi5yLCAuLi5TdFtlXSB9IDogciwgLi4uaSB9Owp9CmNvbnN0IHJlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIGF0dHJpYnV0ZSB2ZWMyIGFQb3NpdGlvbjsKICB2YXJ5aW5nIHZlYzIgdlV2OwogIHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHZlYzIgdGV4ZWxTaXplOwogIHZvaWQgbWFpbiAoKSB7CiAgICB2VXYgPSBhUG9zaXRpb24gKiAwLjUgKyAwLjU7CiAgICB2TCA9IHZVdiAtIHZlYzIodGV4ZWxTaXplLngsIDAuMCk7CiAgICB2UiA9IHZVdiArIHZlYzIodGV4ZWxTaXplLngsIDAuMCk7CiAgICB2VCA9IHZVdiArIHZlYzIoMC4wLCB0ZXhlbFNpemUueSk7CiAgICB2QiA9IHZVdiAtIHZlYzIoMC4wLCB0ZXhlbFNpemUueSk7CiAgICBnbF9Qb3NpdGlvbiA9IHZlYzQoYVBvc2l0aW9uLCAwLjAsIDEuMCk7CiAgfQpgCiksIFJ0ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVTb3VyY2U7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHVuaWZvcm0gdmVjMiB0ZXhlbFNpemU7CiAgdW5pZm9ybSBmbG9hdCBkdDsKICB1bmlmb3JtIGZsb2F0IGRpc3NpcGF0aW9uOwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBvYnMgID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlV2KS5yOwogICAgdmVjMiBjb29yZCA9IHZVdiAtIGR0ICogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSAqIHRleGVsU2l6ZTsKICAgIC8vIFNtb290aCBkYW1waW5nOiBvYnM9MCBvdXRzaWRlIChmdWxsIGZsb3cpLCBvYnM9MSBpbnNpZGUgKGZ1bGwgc3RvcCksIGJsdXJyZWQKICAgIC8vIGJvdW5kYXJ5IGluIGJldHdlZW4uICBObyBicmFuY2hpbmcg4oCUIG11bHRpcGx5aW5nIGJ5ICgxLW9icykgaXMgZXF1aXZhbGVudCB0byB0aGUKICAgIC8vIGhhcmQgemVyby1pbnNpZGUgY2hlY2sgYnV0IHdpdGggYSBjb250aW51b3VzIGdyYWRpZW50IHRoYXQgYXZvaWRzIGdyaWQgYXJ0ZWZhY3RzLgogICAgZ2xfRnJhZ0NvbG9yID0gZGlzc2lwYXRpb24gKiB0ZXh0dXJlMkQodVNvdXJjZSwgY29vcmQpICogKDEuMCAtIG9icyk7CiAgfQpgCiksIEV0ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkwpLnggKiAoMS4wIC0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkwpLnIpOwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZSKS54ICogKDEuMCAtIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZSKS5yKTsKICAgIGZsb2F0IFQgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VCkueSAqICgxLjAgLSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VCkucik7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkIpLnkgKiAoMS4wIC0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkIpLnIpOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjUgKiAoUiAtIEwgKyBUIC0gQiksIDAuMCwgMC4wLCAxLjApOwogIH0KYAopLCBVdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OyB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVByZXNzdXJlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVEaXZlcmdlbmNlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgQyA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZVdikueDsKICAgIGZsb2F0IEwgPSBtaXgodGV4dHVyZTJEKHVQcmVzc3VyZSwgdkwpLngsIEMsIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZMKS5yKTsKICAgIGZsb2F0IFIgPSBtaXgodGV4dHVyZTJEKHVQcmVzc3VyZSwgdlIpLngsIEMsIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZSKS5yKTsKICAgIGZsb2F0IFQgPSBtaXgodGV4dHVyZTJEKHVQcmVzc3VyZSwgdlQpLngsIEMsIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZUKS5yKTsKICAgIGZsb2F0IEIgPSBtaXgodGV4dHVyZTJEKHVQcmVzc3VyZSwgdkIpLngsIEMsIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZCKS5yKTsKICAgIGZsb2F0IGRpdiA9IHRleHR1cmUyRCh1RGl2ZXJnZW5jZSwgdlV2KS54OwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCgoTCArIFIgKyBCICsgVCAtIGRpdikgKiAwLjI1LCAwLjAsIDAuMCwgMS4wKTsKICB9CmAKKSwgRHQgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVQcmVzc3VyZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBvYnMgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VXYpLnI7CiAgICBmbG9hdCBDICAgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2VXYpLng7CiAgICBmbG9hdCBMICAgPSBtaXgodGV4dHVyZTJEKHVQcmVzc3VyZSwgdkwpLngsIEMsIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZMKS5yKTsKICAgIGZsb2F0IFIgICA9IG1peCh0ZXh0dXJlMkQodVByZXNzdXJlLCB2UikueCwgQywgdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlIpLnIpOwogICAgZmxvYXQgVCAgID0gbWl4KHRleHR1cmUyRCh1UHJlc3N1cmUsIHZUKS54LCBDLCB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VCkucik7CiAgICBmbG9hdCBCICAgPSBtaXgodGV4dHVyZTJEKHVQcmVzc3VyZSwgdkIpLngsIEMsIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZCKS5yKTsKICAgIHZlYzIgdmVsICA9ICh0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5IC0gdmVjMihSIC0gTCwgVCAtIEIpKSAqICgxLjAgLSBvYnMpOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCh2ZWwsIDAuMCwgMS4wKTsKICB9CmAKKSwgX3QgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VGFyZ2V0OwogIHVuaWZvcm0gZmxvYXQgYXNwZWN0UmF0aW87CiAgdW5pZm9ybSB2ZWMzIGNvbG9yOwogIHVuaWZvcm0gdmVjMiBwb2ludDsKICB1bmlmb3JtIGZsb2F0IHJhZGl1czsKICB2b2lkIG1haW4gKCkgewogICAgdmVjMiBwID0gdlV2IC0gcG9pbnQueHk7CiAgICBwLnggKj0gYXNwZWN0UmF0aW87CiAgICB2ZWMzIHNwbGF0ID0gZXhwKC1kb3QocCwgcCkgLyByYWRpdXMpICogY29sb3I7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KHRleHR1cmUyRCh1VGFyZ2V0LCB2VXYpLnh5eiArIHNwbGF0LCAxLjApOwogIH0KYAopLCBDdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkwpLnk7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlIpLnk7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkIpLng7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuNSAqIChSIC0gTCAtIFQgKyBCKSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIEJ0ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdUN1cmw7CiAgdW5pZm9ybSBmbG9hdCBjdXJsOwogIHVuaWZvcm0gZmxvYXQgZHQ7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodUN1cmwsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1Q3VybCwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVDdXJsLCB2VCkueDsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodUN1cmwsIHZCKS54OwogICAgZmxvYXQgQyA9IHRleHR1cmUyRCh1Q3VybCwgdlV2KS54OwogICAgdmVjMiBmb3JjZSA9IDAuNSAqIHZlYzIoYWJzKFQpIC0gYWJzKEIpLCBhYnMoUikgLSBhYnMoTCkpOwogICAgZm9yY2UgLz0gbGVuZ3RoKGZvcmNlKSArIDAuMDAwMTsKICAgIGZvcmNlICo9IGN1cmwgKiAzMC4wICogQzsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQodGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSArIGZvcmNlICogZHQsIDAuMCwgMS4wKTsKICB9CmAKKSwgT3QgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKCiAgdW5pZm9ybSBzYW1wbGVyMkQgdVRleHR1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVCYWNrZ3JvdW5kOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVDb3ZlcmFnZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CgogIHVuaWZvcm0gdmVjMiAgdGV4ZWxTaXplOwogIHVuaWZvcm0gdmVjMyAgdVdhdGVyQ29sb3I7CiAgdW5pZm9ybSB2ZWMzICB1R2xvd0NvbG9yOwogIHVuaWZvcm0gZmxvYXQgdVJlZnJhY3Rpb247CiAgdW5pZm9ybSBmbG9hdCB1U3BlY3VsYXJFeHA7CiAgdW5pZm9ybSBmbG9hdCB1U2hpbmU7CiAgdW5pZm9ybSBmbG9hdCB1V2FycFN0cmVuZ3RoOwogIHVuaWZvcm0gaW50ICAgdUFsZ29yaXRobTsKICB1bmlmb3JtIGludCAgIHVFbmFibGVBbHBoYTsKCiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IG9icyAgICAgID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgIHZVdikucjsKICAgIC8vIFNtb290aCBmYWRlOiBkZW5zaXR5IGZhbGxzIG9mZiBvdmVyIHRoZSBibHVycmVkIG9ic3RhY2xlIGJvdW5kYXJ5IHpvbmUKICAgIC8vIHJhdGhlciB0aGFuIGN1dHRpbmcgb2ZmIGF0IGEgaGFyZCBzdGVwLCBlbGltaW5hdGluZyB0aGUgamFnZ2VkIGZyaW5nZS4KICAgIGZsb2F0IGRlbnNpdHkgID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2KS5yLCAwLjApICogKDEuMCAtIG9icyk7CiAgICBmbG9hdCBjb3ZlcmFnZSA9IHRleHR1cmUyRCh1Q292ZXJhZ2UsICB2VXYpLnI7CgogICAgLy8gOC10YXAgU29iZWwgbm9ybWFsIOKAlCBjb21wdXRlcyBncmFkaWVudCB2aWEgM8OXMyBrZXJuZWwgKG5vIGNlbnRyZSBzYW1wbGUgbmVlZGVkKS4KICAgIC8vIHRleGVsU2l6ZSA9IDEvZGlzcGxheVJlczsgZGVuc2l0eSBGQk8gaXMgYXQgc2ltU2NhbGUgKDAuNcOXKSwgc28gcz02IGRpc3BsYXkgcHgKICAgIC8vIOKJiCAzIHNpbSB0ZXhlbHMgcGVyIGF4aXMuICBUaGUgU29iZWwga2VybmVsIHByb3Blcmx5IGF2ZXJhZ2VzIHRoZSBncmFkaWVudCBpbgogICAgLy8gZXZlcnkgZGlyZWN0aW9uIOKAlCBubyA0LXRhcCBjcm9zcyBiaWFzIHRoYXQgY3JlYXRlcyA0NcKwIGNpcmN1aXQtYm9hcmQgYXJ0ZWZhY3RzLgogICAgZmxvYXQgc3ggPSB0ZXhlbFNpemUueCAqIDYuMCwgc3kgPSB0ZXhlbFNpemUueSAqIDYuMDsKICAgIGZsb2F0IGQwMCA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIoLXN4LCAtc3kpKS5yLCAwLjApOwogICAgZmxvYXQgZDEwID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2ICsgdmVjMigwLjAsIC1zeSkpLnIsIDAuMCk7CiAgICBmbG9hdCBkMjAgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKCBzeCwgLXN5KSkuciwgMC4wKTsKICAgIGZsb2F0IGQwMSA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIoLXN4LCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZDIxID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2ICsgdmVjMiggc3gsIDAuMCkpLnIsIDAuMCk7CiAgICBmbG9hdCBkMDIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKC1zeCwgIHN5KSkuciwgMC4wKTsKICAgIGZsb2F0IGQxMiA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIoMC4wLCAgc3kpKS5yLCAwLjApOwogICAgZmxvYXQgZDIyID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2ICsgdmVjMiggc3gsICBzeSkpLnIsIDAuMCk7CiAgICBmbG9hdCBneCAgPSAoZDIwICsgMi4wKmQyMSArIGQyMikgLSAoZDAwICsgMi4wKmQwMSArIGQwMik7CiAgICBmbG9hdCBneSAgPSAoZDAyICsgMi4wKmQxMiArIGQyMikgLSAoZDAwICsgMi4wKmQxMCArIGQyMCk7CgogICAgdmVjMyAgbm9ybWFsICAgPSBub3JtYWxpemUodmVjMyhneCwgZ3ksIDEuMikpOwogICAgdmVjMyAgbGlnaHREaXIgPSBub3JtYWxpemUodmVjMygwLjUsIDEuMCwgMC41KSk7CiAgICB2ZWMzICBoYWxmViAgICA9IG5vcm1hbGl6ZShsaWdodERpciArIHZlYzMoMC4wLCAwLjAsIDEuMCkpOwogICAgLy8gU3VwcHJlc3Mgc3BlY3VsYXIgYXQgbG93IC8gZmFkaW5nIGRlbnNpdHkg4oCUIHByZXZlbnRzIGhpZ2hsaWdodCByaW5ncyBmcm9tCiAgICAvLyBhcHBlYXJpbmcgYXQgdGhlIGRpc3NpcGF0aW5nIGVkZ2Ugb2YgYSBzdHJva2UgYXMgaXRzIGRlbnNpdHkgYXBwcm9hY2hlcyB6ZXJvLgogICAgZmxvYXQgc3BlY0RlbiAgPSBkZW5zaXR5ICogbWluKGRlbnNpdHkgKiA1LjAsIDEuMCk7CiAgICBmbG9hdCBzcGVjICAgICA9IHBvdyhtYXgoZG90KG5vcm1hbCwgaGFsZlYpLCAwLjApLCB1U3BlY3VsYXJFeHApICogdVNoaW5lICogc3BlY0RlbjsKCiAgICAvLyBJbiB0cmFuc3BhcmVudCAobm9uLWNvdmVyYWdlKSBhcmVhcyB0aGUgYmFja2dyb3VuZCB0ZXh0dXJlIGlzIGVtcHR5IGJsYWNrIGNhbnZhcy4KICAgIC8vIFJlcGxhY2UgaXQgd2l0aCB1V2F0ZXJDb2xvciBzbyBmbHVpZCBjb2xvdXIgaXMgbm90IGNvbnRhbWluYXRlZCBieSB0aGF0IGJsYWNrLAogICAgLy8gYWxsb3dpbmcgdGhlIENTUyBiYWNrZ3JvdW5kQ29sb3IgdG8gc2hvdyB0aHJvdWdoIGNvcnJlY3RseSB2aWEgcHJlbXVsdGlwbGllZCBhbHBoYS4KICAgIHZlYzMgYmdSYXcgPSB0ZXh0dXJlMkQodUJhY2tncm91bmQsIHZVdikucmdiOwogICAgdmVjMyBiZyAgICA9IG1peCh1V2F0ZXJDb2xvciwgYmdSYXcsIGNvdmVyYWdlKTsKICAgIHZlYzMgY29sb3IgPSBiZzsKCiAgICBpZiAodUFsZ29yaXRobSA9PSAxKSB7CiAgICAgIC8vIOKUgOKUgCBnbGFzcyDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gU3Ryb25nIFVWIGRpc3RvcnRpb24gb25seS4gSW1hZ2UgYmVuZHMgYnV0IG5vIGNvbG91ciBvdmVybGF5LgogICAgICB2ZWMyIHJlZnJVdiA9IGNsYW1wKHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eSAqIDMuMCwgMC4wLCAxLjApOwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciA9IHJlZnJCZyArIHNwZWMgKiB1R2xvd0NvbG9yICogMi41OwogICAgICBjb2xvciA9IG1peChjb2xvciwgYmcgKiAwLjYsIG9icyAqIDAuMyk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDIpIHsKICAgICAgLy8g4pSA4pSAIGluayDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gRGVuc2Ugb3BhcXVlIHBpZ21lbnQgdGhhdCBzdGFpbnMuIFN1YnRsZSByZWZyYWN0aW9uIHVuZGVybmVhdGguCiAgICAgIGZsb2F0IGlua0QgID0gbWluKGRlbnNpdHkgKiA0LjAsIDEuMCk7CiAgICAgIHZlYzIgcmVmclV2ID0gY2xhbXAodlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5ICogMC40LCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgcmVmckJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJlZnJVdiwgMS4wIC0gb2JzKSkucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yID0gbWl4KHJlZnJCZywgdVdhdGVyQ29sb3IgKyBzcGVjICogdUdsb3dDb2xvciwgaW5rRCk7CiAgICAgIGNvbG9yID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4xNSk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDMpIHsKICAgICAgLy8g4pSA4pSAIGF1cm9yYSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gVmVsb2NpdHkgZmllbGQgd2FycHMgYmFja2dyb3VuZCBVVnMg4oCUIGxpcXVpZCBtZXRhbCAvIGxhdmEtbGFtcCBmZWVsLgogICAgICB2ZWMyICB2ZWwgICAgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5OwogICAgICBmbG9hdCB2ZWxNYWcgPSBjbGFtcChsZW5ndGgodmVsKSAqIDIwLjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMiAgd2FycFV2ID0gY2xhbXAodlV2ICsgdmVsICogdVdhcnBTdHJlbmd0aCwgMC4wLCAxLjApOwogICAgICB2ZWMzICB3YXJwQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgd2FycFV2KS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgID0gbWl4KGJnLCB3YXJwQmcsIHZlbE1hZyAqICgxLjAgLSBvYnMpKTsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiB2ZWxNYWcgKiAxLjU7CiAgICAgIGNvbG9yICs9IHVXYXRlckNvbG9yICogZGVuc2l0eSAqIDAuMzsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKCiAgICB9IGVsc2UgaWYgKHVBbGdvcml0aG0gPT0gNCkgewogICAgICAvLyDilIDilIAgcmlwcGxlIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBFeGFnZ2VyYXRlZCBub3JtYWwgcGVydHVyYmF0aW9uICsgRnJlc25lbCByaW0g4oCUIGNhbG0gd2F0ZXIgc3VyZmFjZS4KICAgICAgdmVjMiAgcmlwcGxlVXYgPSBjbGFtcCh2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHkgKiA2LjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMyAgcmVmckJnICAgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmlwcGxlVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBmbG9hdCBmcmVzbmVsICA9IHBvdyhjbGFtcCgxLjAgLSBkb3Qobm9ybWFsLCB2ZWMzKDAuMCwgMC4wLCAxLjApKSwgMC4wLCAxLjApLCAzLjApICogZGVuc2l0eTsKICAgICAgY29sb3IgID0gcmVmckJnOwogICAgICBjb2xvciArPSBmcmVzbmVsICogdUdsb3dDb2xvciAqIDIuMDsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiBkZW5zaXR5ICogMi4wOwogICAgICBjb2xvciAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwoKICAgIH0gZWxzZSB7CiAgICAgIC8vIOKUgOKUgCBzdGFuZGFyZCAoMCkg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIE9yaWdpbmFsOiBjb2xvdXIgb3ZlcmxheSBibGVuZGVkIG92ZXIgcmVmcmFjdGVkIGJhY2tncm91bmQuCiAgICAgIHZlYzIgcmVmclV2ID0gdlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5OwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciAgPSBtaXgocmVmckJnLCB1V2F0ZXJDb2xvciwgbWluKGRlbnNpdHkgKiAxLjUsIDAuOCkpOwogICAgICBjb2xvciArPSBzcGVjICogdUdsb3dDb2xvcjsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICAgIH0KCiAgICAvLyBPdXRwdXQ6IHByZW11bHRpcGxpZWQgYWxwaGEgd2hlbiB0cmFuc3BhcmVuY3kgaXMgZW5hYmxlZCAobGV0cyBDU1MgYmFja2dyb3VuZENvbG9yCiAgICAvLyBzaG93IHRocm91Z2gpLCBvciBzdHJhaWdodCBvcGFxdWUgY29sb3VyIHdoZW4gZW5hYmxlQWxwaGEgaXMgb2ZmIChwZXJmIG1vZGUpLgogICAgZmxvYXQgYWxwaGEgPSBjbGFtcChtYXgoZGVuc2l0eSAqIDEuNSwgY292ZXJhZ2UpLCAwLjAsIDEuMCk7CiAgICBpZiAodUVuYWJsZUFscGhhID09IDEpIHsKICAgICAgZ2xfRnJhZ0NvbG9yID0gdmVjNChjb2xvciAqIGFscGhhLCBhbHBoYSk7CiAgICB9IGVsc2UgewogICAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KGNvbG9yLCAxLjApOwogICAgfQogIH0KYAopOwpmdW5jdGlvbiBWdChpLCBlID0gITApIHsKICBjb25zdCByID0geyBhbHBoYTogZSwgZGVwdGg6ICExLCBzdGVuY2lsOiAhMSwgYW50aWFsaWFzOiAhMCwgcHJlc2VydmVEcmF3aW5nQnVmZmVyOiAhMSB9OwogIGxldCBzID0gaS5nZXRDb250ZXh0KCJ3ZWJnbDIiLCByKTsKICBjb25zdCBvID0gISFzOwogIG8gfHwgKHMgPSBpLmdldENvbnRleHQoIndlYmdsIiwgciksIHMuZ2V0RXh0ZW5zaW9uKCJFWFRfY29sb3JfYnVmZmVyX2hhbGZfZmxvYXQiKSk7CiAgY29uc3QgYSA9IG8gPyBudWxsIDogcy5nZXRFeHRlbnNpb24oIk9FU190ZXh0dXJlX2hhbGZfZmxvYXQiKSwgdSA9IG8gPyBzLkhBTEZfRkxPQVQgOiBhLkhBTEZfRkxPQVRfT0VTOwogIHJldHVybiBzLmdldEV4dGVuc2lvbigiRVhUX2NvbG9yX2J1ZmZlcl9mbG9hdCIpLCBzLmdldEV4dGVuc2lvbigiT0VTX3RleHR1cmVfaGFsZl9mbG9hdF9saW5lYXIiKSwgewogICAgdHlwZTogbyA/ICJ3ZWJnbDIiIDogIndlYmdsMSIsCiAgICBnbDogcywKICAgIGlzV2ViR0wyOiBvLAogICAgZXh0OiB7CiAgICAgIGludGVybmFsRm9ybWF0OiBvID8gcy5SR0JBMTZGIDogcy5SR0JBLAogICAgICBmb3JtYXQ6IHMuUkdCQSwKICAgICAgdHlwZTogdQogICAgfQogIH07Cn0KYXN5bmMgZnVuY3Rpb24gUHQoaSwgZSA9ICEwKSB7CiAgaWYgKHR5cGVvZiBuYXZpZ2F0b3IgPiAidSIgfHwgIW5hdmlnYXRvci5ncHUpCiAgICByZXR1cm4gbnVsbDsKICB0cnkgewogICAgY29uc3QgciA9IGF3YWl0IG5hdmlnYXRvci5ncHUucmVxdWVzdEFkYXB0ZXIoKTsKICAgIGlmICghcikKICAgICAgcmV0dXJuIG51bGw7CiAgICBjb25zdCBzID0gYXdhaXQgci5yZXF1ZXN0RGV2aWNlKCksIG8gPSBpLmdldENvbnRleHQoIndlYmdwdSIpOwogICAgaWYgKCFvKQogICAgICByZXR1cm4gbnVsbDsKICAgIGNvbnN0IGEgPSBuYXZpZ2F0b3IuZ3B1LmdldFByZWZlcnJlZENhbnZhc0Zvcm1hdCgpOwogICAgcmV0dXJuIG8uY29uZmlndXJlKHsgZGV2aWNlOiBzLCBmb3JtYXQ6IGEsIGFscGhhTW9kZTogZSA/ICJwcmVtdWx0aXBsaWVkIiA6ICJvcGFxdWUiIH0pLCB7IHR5cGU6ICJ3ZWJncHUiLCBhZGFwdGVyOiByLCBkZXZpY2U6IHMsIGNvbnRleHQ6IG8sIGZvcm1hdDogYSB9OwogIH0gY2F0Y2ggewogICAgcmV0dXJuIG51bGw7CiAgfQp9CmNsYXNzIGllIHsKICBjb25zdHJ1Y3RvcihlLCByLCBzKSB7CiAgICBrZSh0aGlzLCAicHJvZ3JhbSIpOwogICAga2UodGhpcywgInVuaWZvcm1zIiwge30pOwogICAga2UodGhpcywgIl9nbCIpOwogICAgdGhpcy5fZ2wgPSBlLCB0aGlzLnByb2dyYW0gPSBlLmNyZWF0ZVByb2dyYW0oKSwgZS5hdHRhY2hTaGFkZXIodGhpcy5wcm9ncmFtLCB0aGlzLl9jb21waWxlKGUuVkVSVEVYX1NIQURFUiwgcikpLCBlLmF0dGFjaFNoYWRlcih0aGlzLnByb2dyYW0sIHRoaXMuX2NvbXBpbGUoZS5GUkFHTUVOVF9TSEFERVIsIHMpKSwgZS5saW5rUHJvZ3JhbSh0aGlzLnByb2dyYW0pOwogICAgY29uc3QgbyA9IGUuZ2V0UHJvZ3JhbVBhcmFtZXRlcih0aGlzLnByb2dyYW0sIGUuQUNUSVZFX1VOSUZPUk1TKTsKICAgIGZvciAobGV0IGEgPSAwOyBhIDwgbzsgYSsrKSB7CiAgICAgIGNvbnN0IHUgPSBlLmdldEFjdGl2ZVVuaWZvcm0odGhpcy5wcm9ncmFtLCBhKS5uYW1lOwogICAgICB0aGlzLnVuaWZvcm1zW3VdID0gZS5nZXRVbmlmb3JtTG9jYXRpb24odGhpcy5wcm9ncmFtLCB1KTsKICAgIH0KICB9CiAgX2NvbXBpbGUoZSwgcikgewogICAgY29uc3QgcyA9IHRoaXMuX2dsLCBvID0gcy5jcmVhdGVTaGFkZXIoZSk7CiAgICByZXR1cm4gcy5zaGFkZXJTb3VyY2UobywgciksIHMuY29tcGlsZVNoYWRlcihvKSwgbzsKICB9CiAgYmluZCgpIHsKICAgIHRoaXMuX2dsLnVzZVByb2dyYW0odGhpcy5wcm9ncmFtKTsKICB9CiAgZGlzcG9zZSgpIHsKICAgIHRoaXMuX2dsLmRlbGV0ZVByb2dyYW0odGhpcy5wcm9ncmFtKTsKICB9Cn0KZnVuY3Rpb24gRnQoaSkgewogIHJldHVybiB7CiAgICBhZHZlY3Rpb246IG5ldyBpZShpLCByZSwgUnQpLAogICAgZGl2ZXJnZW5jZTogbmV3IGllKGksIHJlLCBFdCksCiAgICBwcmVzc3VyZTogbmV3IGllKGksIHJlLCBVdCksCiAgICBncmFkaWVudFN1YnRyYWN0OiBuZXcgaWUoaSwgcmUsIER0KSwKICAgIHNwbGF0OiBuZXcgaWUoaSwgcmUsIF90KSwKICAgIGN1cmw6IG5ldyBpZShpLCByZSwgQ3QpLAogICAgdm9ydGljaXR5OiBuZXcgaWUoaSwgcmUsIEJ0KSwKICAgIGRpc3BsYXk6IG5ldyBpZShpLCByZSwgT3QpCiAgfTsKfQpmdW5jdGlvbiBxZShpLCBlLCByLCBzKSB7CiAgaS5hY3RpdmVUZXh0dXJlKGkuVEVYVFVSRTApOwogIGNvbnN0IG8gPSBpLmNyZWF0ZVRleHR1cmUoKTsKICBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgbyksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NSU5fRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NQUdfRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1MsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1QsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGUuaW50ZXJuYWxGb3JtYXQsIHIsIHMsIDAsIGUuZm9ybWF0LCBlLnR5cGUsIG51bGwpOwogIGNvbnN0IGEgPSBpLmNyZWF0ZUZyYW1lYnVmZmVyKCk7CiAgcmV0dXJuIGkuYmluZEZyYW1lYnVmZmVyKGkuRlJBTUVCVUZGRVIsIGEpLCBpLmZyYW1lYnVmZmVyVGV4dHVyZTJEKGkuRlJBTUVCVUZGRVIsIGkuQ09MT1JfQVRUQUNITUVOVDAsIGkuVEVYVFVSRV8yRCwgbywgMCksIHsgdGV4OiBvLCBmYm86IGEsIHdpZHRoOiByLCBoZWlnaHQ6IHMgfTsKfQpmdW5jdGlvbiB0dChpLCBlLCByLCBzKSB7CiAgbGV0IG8gPSBxZShpLCBlLCByLCBzKSwgYSA9IHFlKGksIGUsIHIsIHMpOwogIHJldHVybiB7CiAgICBnZXQgcmVhZCgpIHsKICAgICAgcmV0dXJuIG87CiAgICB9LAogICAgZ2V0IHdyaXRlKCkgewogICAgICByZXR1cm4gYTsKICAgIH0sCiAgICBzd2FwKCkgewogICAgICBbbywgYV0gPSBbYSwgb107CiAgICB9LAogICAgZGlzcG9zZSgpIHsKICAgICAgaS5kZWxldGVUZXh0dXJlKG8udGV4KSwgaS5kZWxldGVGcmFtZWJ1ZmZlcihvLmZibyksIGkuZGVsZXRlVGV4dHVyZShhLnRleCksIGkuZGVsZXRlRnJhbWVidWZmZXIoYS5mYm8pOwogICAgfQogIH07Cn0KZnVuY3Rpb24gTHQoaSkgewogIGNvbnN0IGUgPSBpLmNyZWF0ZUJ1ZmZlcigpOwogIHJldHVybiBpLmJpbmRCdWZmZXIoaS5BUlJBWV9CVUZGRVIsIGUpLCBpLmJ1ZmZlckRhdGEoaS5BUlJBWV9CVUZGRVIsIG5ldyBGbG9hdDMyQXJyYXkoWy0xLCAtMSwgLTEsIDEsIDEsIDEsIDEsIC0xXSksIGkuU1RBVElDX0RSQVcpLCBpLnZlcnRleEF0dHJpYlBvaW50ZXIoMCwgMiwgaS5GTE9BVCwgITEsIDAsIDApLCBpLmVuYWJsZVZlcnRleEF0dHJpYkFycmF5KDApLCBmdW5jdGlvbihzKSB7CiAgICBpLmJpbmRGcmFtZWJ1ZmZlcihpLkZSQU1FQlVGRkVSLCBzKSwgaS5kcmF3QXJyYXlzKGkuVFJJQU5HTEVfRkFOLCAwLCA0KTsKICB9Owp9CmNvbnN0IGxlID0gKAogIC8qIHdnc2wgKi8KICBgCnN0cnVjdCBWU091dCB7CiAgQGJ1aWx0aW4ocG9zaXRpb24pIHBvcyA6IHZlYzRmLAogIEBsb2NhdGlvbigwKSAgICAgICB1diAgOiB2ZWMyZiwKICBAbG9jYXRpb24oMSkgICAgICAgdkwgIDogdmVjMmYsCiAgQGxvY2F0aW9uKDIpICAgICAgIHZSICA6IHZlYzJmLAogIEBsb2NhdGlvbigzKSAgICAgICB2VCAgOiB2ZWMyZiwKICBAbG9jYXRpb24oNCkgICAgICAgdkIgIDogdmVjMmYsCn1gCiksIEF0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7CiAgdGV4ZWxTaXplICA6IHZlYzJmLAogIGR0ICAgICAgICAgOiBmMzIsCiAgZGlzc2lwYXRpb246IGYzMiwKfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgIDogVTsKQGdyb3VwKDApIEBiaW5kaW5nKDEpIHZhciAgICAgICAgICBzYW1wICA6IHNhbXBsZXI7CkBncm91cCgwKSBAYmluZGluZygyKSB2YXIgICAgICAgICAgdVZlbCAgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZygzKSB2YXIgICAgICAgICAgdVNyYyAgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZyg0KSB2YXIgICAgICAgICAgdU9icyAgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIGxldCBvYnMgICA9IHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS51dikucjsKICBsZXQgdmVsICAgPSB0ZXh0dXJlU2FtcGxlKHVWZWwsIHNhbXAsIGkudXYpLnh5OwogIGxldCBjb29yZCA9IGkudXYgLSB1LmR0ICogdmVsICogdS50ZXhlbFNpemU7CiAgbGV0IHNyYyAgID0gdGV4dHVyZVNhbXBsZSh1U3JjLCBzYW1wLCBjb29yZCk7CiAgcmV0dXJuIHUuZGlzc2lwYXRpb24gKiBzcmMgKiAoMS4wIC0gb2JzKTsKfQpgCiksIHp0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7IHRleGVsU2l6ZTogdmVjMmYsIF9wYWQ6IHZlYzJmIH0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgIDogVTsKQGdyb3VwKDApIEBiaW5kaW5nKDEpIHZhciAgICAgICAgICBzYW1wIDogc2FtcGxlcjsKQGdyb3VwKDApIEBiaW5kaW5nKDIpIHZhciAgICAgICAgICB1VmVsIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoMykgdmFyICAgICAgICAgIHVPYnMgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIGxldCBMID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZMKS54ICogKDEuMCAtIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52TCkucik7CiAgbGV0IFIgPSB0ZXh0dXJlU2FtcGxlKHVWZWwsIHNhbXAsIGkudlIpLnggKiAoMS4wIC0gdGV4dHVyZVNhbXBsZSh1T2JzLCBzYW1wLCBpLnZSKS5yKTsKICBsZXQgVCA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52VCkueSAqICgxLjAgLSB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlQpLnIpOwogIGxldCBCID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZCKS55ICogKDEuMCAtIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52Qikucik7CiAgcmV0dXJuIHZlYzRmKDAuNSAqIChSIC0gTCArIFQgLSBCKSwgMC4wLCAwLjAsIDEuMCk7Cn0KYAopLCBYdCA9ICgKICAvKiB3Z3NsICovCiAgYAoke2xlfQoKc3RydWN0IFUgeyB0ZXhlbFNpemU6IHZlYzJmLCBfcGFkOiB2ZWMyZiB9CkBncm91cCgwKSBAYmluZGluZygwKSB2YXI8dW5pZm9ybT4gdSAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCA6IHNhbXBsZXI7CkBncm91cCgwKSBAYmluZGluZygyKSB2YXIgICAgICAgICAgdVByZXM6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDMpIHZhciAgICAgICAgICB1RGl2IDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoNCkgdmFyICAgICAgICAgIHVPYnMgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIGxldCBDICA9IHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudXYpLng7CiAgbGV0IEwgID0gbWl4KHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudkwpLngsIEMsIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52TCkucik7CiAgbGV0IFIgID0gbWl4KHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudlIpLngsIEMsIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52Uikucik7CiAgbGV0IFQgID0gbWl4KHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudlQpLngsIEMsIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52VCkucik7CiAgbGV0IEIgID0gbWl4KHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudkIpLngsIEMsIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52Qikucik7CiAgbGV0IGR2ID0gdGV4dHVyZVNhbXBsZSh1RGl2LCBzYW1wLCBpLnV2KS54OwogIHJldHVybiB2ZWM0ZigoTCArIFIgKyBCICsgVCAtIGR2KSAqIDAuMjUsIDAuMCwgMC4wLCAxLjApOwp9CmAKKSwgR3QgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsgdGV4ZWxTaXplOiB2ZWMyZiwgX3BhZDogdmVjMmYgfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVQcmVzOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZygzKSB2YXIgICAgICAgICAgdVZlbCA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDQpIHZhciAgICAgICAgICB1T2JzIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgb2JzID0gdGV4dHVyZVNhbXBsZSh1T2JzLCBzYW1wLCBpLnV2KS5yOwogIGxldCBDICAgPSB0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnV2KS54OwogIGxldCBMICAgPSBtaXgodGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS52TCkueCwgQywgdGV4dHVyZVNhbXBsZSh1T2JzLCBzYW1wLCBpLnZMKS5yKTsKICBsZXQgUiAgID0gbWl4KHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudlIpLngsIEMsIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52Uikucik7CiAgbGV0IFQgICA9IG1peCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZUKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlQpLnIpOwogIGxldCBCICAgPSBtaXgodGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS52QikueCwgQywgdGV4dHVyZVNhbXBsZSh1T2JzLCBzYW1wLCBpLnZCKS5yKTsKICBsZXQgdmVsID0gKHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS51dikueHkgLSB2ZWMyZihSIC0gTCwgVCAtIEIpKSAqICgxLjAgLSBvYnMpOwogIHJldHVybiB2ZWM0Zih2ZWwsIDAuMCwgMS4wKTsKfQpgCiksIE10ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgovLyB0ZXhlbFNpemUgb2NjdXBpZXMgYnl0ZXMgMC03IGZvciB0aGUgc2hhcmVkIHZlcnRleCBzdGFnZTsgYXNwZWN0UmF0aW8vcmFkaXVzIGZpbGwgdGhlIHJlc3QuCnN0cnVjdCBVIHsKICB0ZXhlbFNpemUgIDogdmVjMmYsCiAgYXNwZWN0UmF0aW86IGYzMiwKICByYWRpdXMgICAgIDogZjMyLAogIGNvbG9yICAgICAgOiB2ZWM0ZiwgIC8vIHh5eiA9IGNvbG91ciwgdyB1bnVzZWQKICBwb2ludCAgICAgIDogdmVjMmYsCiAgX3BhZCAgICAgICA6IHZlYzJmLAp9CkBncm91cCgwKSBAYmluZGluZygwKSB2YXI8dW5pZm9ybT4gdSAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCA6IHNhbXBsZXI7CkBncm91cCgwKSBAYmluZGluZygyKSB2YXIgICAgICAgICAgdVRndCA6IHRleHR1cmVfMmQ8ZjMyPjsKCkB2ZXJ0ZXggZm4gdnMoQGxvY2F0aW9uKDApIGE6IHZlYzJmKSAtPiBWU091dCB7CiAgdmFyIG86IFZTT3V0OwogIG8udXYgPSB2ZWMyZihhLnggKiAwLjUgKyAwLjUsIDAuNSAtIGEueSAqIDAuNSk7CiAgby52TCA9IG8udXYgLSB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlIgPSBvLnV2ICsgdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZUID0gby51diArIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby52QiA9IG8udXYgLSB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8ucG9zID0gdmVjNGYoYSwgMC4wLCAxLjApOwogIHJldHVybiBvOwp9CgpAZnJhZ21lbnQgZm4gZnMoaTogVlNPdXQpIC0+IEBsb2NhdGlvbigwKSB2ZWM0ZiB7CiAgdmFyIHAgID0gaS51diAtIHUucG9pbnQ7CiAgcC54ICAgKj0gdS5hc3BlY3RSYXRpbzsKICBsZXQgc3AgPSBleHAoLWRvdChwLCBwKSAvIHUucmFkaXVzKSAqIHUuY29sb3IueHl6OwogIHJldHVybiB2ZWM0Zih0ZXh0dXJlU2FtcGxlKHVUZ3QsIHNhbXAsIGkudXYpLnh5eiArIHNwLCAxLjApOwp9CmAKKSwgSXQgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsgdGV4ZWxTaXplOiB2ZWMyZiwgX3BhZDogdmVjMmYgfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVWZWwgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIGxldCBMID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZMKS55OwogIGxldCBSID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZSKS55OwogIGxldCBUID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZUKS54OwogIGxldCBCID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZCKS54OwogIHJldHVybiB2ZWM0ZigwLjUgKiAoUiAtIEwgLSBUICsgQiksIDAuMCwgMC4wLCAxLjApOwp9CmAKKSwga3QgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsKICB0ZXhlbFNpemU6IHZlYzJmLAogIGN1cmwgICAgIDogZjMyLAogIGR0ICAgICAgIDogZjMyLAp9CkBncm91cCgwKSBAYmluZGluZygwKSB2YXI8dW5pZm9ybT4gdSAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCA6IHNhbXBsZXI7CkBncm91cCgwKSBAYmluZGluZygyKSB2YXIgICAgICAgICAgdVZlbCA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDMpIHZhciAgICAgICAgICB1Q3JsIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgTCAgICAgPSB0ZXh0dXJlU2FtcGxlKHVDcmwsIHNhbXAsIGkudkwpLng7CiAgbGV0IFIgICAgID0gdGV4dHVyZVNhbXBsZSh1Q3JsLCBzYW1wLCBpLnZSKS54OwogIGxldCBUICAgICA9IHRleHR1cmVTYW1wbGUodUNybCwgc2FtcCwgaS52VCkueDsKICBsZXQgQiAgICAgPSB0ZXh0dXJlU2FtcGxlKHVDcmwsIHNhbXAsIGkudkIpLng7CiAgbGV0IEMgICAgID0gdGV4dHVyZVNhbXBsZSh1Q3JsLCBzYW1wLCBpLnV2KS54OwogIHZhciBmb3JjZSA9IDAuNSAqIHZlYzJmKGFicyhUKSAtIGFicyhCKSwgYWJzKFIpIC0gYWJzKEwpKTsKICBmb3JjZSAgICAvPSBsZW5ndGgoZm9yY2UpICsgMC4wMDAxOwogIGZvcmNlICAgICo9IHUuY3VybCAqIDMwLjAgKiBDOwogIGxldCB2ZWwgICA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS51dikueHkgKyBmb3JjZSAqIHUuZHQ7CiAgcmV0dXJuIHZlYzRmKHZlbCwgMC4wLCAxLjApOwp9CmAKKSwgV3QgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsKICB0ZXhlbFNpemUgICA6IHZlYzJmLAogIHJlZnJhY3Rpb24gIDogZjMyLAogIHNwZWN1bGFyRXhwIDogZjMyLAogIHdhdGVyQ29sb3IgIDogdmVjNGYsCiAgZ2xvd0NvbG9yICAgOiB2ZWM0ZiwKICBzaGluZSAgICAgICA6IGYzMiwKICB3YXJwU3RyZW5ndGg6IGYzMiwKICBhbGdvcml0aG0gICA6IGkzMiwKICBlbmFibGVBbHBoYSA6IGkzMiwKfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVUZXggOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZygzKSB2YXIgICAgICAgICAgdU9icyA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDQpIHZhciAgICAgICAgICB1QmcgIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoNSkgdmFyICAgICAgICAgIHVDb3YgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZyg2KSB2YXIgICAgICAgICAgdVZlbCA6IHRleHR1cmVfMmQ8ZjMyPjsKCkB2ZXJ0ZXggZm4gdnMoQGxvY2F0aW9uKDApIGE6IHZlYzJmKSAtPiBWU091dCB7CiAgdmFyIG86IFZTT3V0OwogIG8udXYgPSB2ZWMyZihhLnggKiAwLjUgKyAwLjUsIDAuNSAtIGEueSAqIDAuNSk7CiAgby52TCA9IG8udXYgLSB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlIgPSBvLnV2ICsgdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZUID0gby51diArIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby52QiA9IG8udXYgLSB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8ucG9zID0gdmVjNGYoYSwgMC4wLCAxLjApOwogIHJldHVybiBvOwp9CgpAZnJhZ21lbnQgZm4gZnMoaTogVlNPdXQpIC0+IEBsb2NhdGlvbigwKSB2ZWM0ZiB7CiAgbGV0IG9icyAgICAgPSB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudXYpLnI7CiAgbGV0IGRlbnNpdHkgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2KS5yLCAwLjApICogKDEuMCAtIG9icyk7CiAgbGV0IGNvdiAgICAgPSB0ZXh0dXJlU2FtcGxlKHVDb3YsIHNhbXAsIGkudXYpLnI7CgogIGxldCBzeCAgPSB1LnRleGVsU2l6ZS54ICogNi4wOwogIGxldCBzeSAgPSB1LnRleGVsU2l6ZS55ICogNi4wOwogIGxldCBkMDAgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoLXN4LCAtc3kpKS5yLCAwLjApOwogIGxldCBkMTAgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoMC4wLCAtc3kpKS5yLCAwLjApOwogIGxldCBkMjAgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoIHN4LCAtc3kpKS5yLCAwLjApOwogIGxldCBkMDEgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoLXN4LCAwLjApKS5yLCAwLjApOwogIGxldCBkMjEgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoIHN4LCAwLjApKS5yLCAwLjApOwogIGxldCBkMDIgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoLXN4LCAgc3kpKS5yLCAwLjApOwogIGxldCBkMTIgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoMC4wLCAgc3kpKS5yLCAwLjApOwogIGxldCBkMjIgPSBtYXgodGV4dHVyZVNhbXBsZSh1VGV4LCBzYW1wLCBpLnV2ICsgdmVjMmYoIHN4LCAgc3kpKS5yLCAwLjApOwogIGxldCBneCAgPSAoZDIwICsgMi4wKmQyMSArIGQyMikgLSAoZDAwICsgMi4wKmQwMSArIGQwMik7CiAgbGV0IGd5ICA9IChkMDIgKyAyLjAqZDEyICsgZDIyKSAtIChkMDAgKyAyLjAqZDEwICsgZDIwKTsKCiAgbGV0IG5vcm0gICAgPSBub3JtYWxpemUodmVjM2YoZ3gsIGd5LCAxLjIpKTsKICBsZXQgbGRpciAgICA9IG5vcm1hbGl6ZSh2ZWMzZigwLjUsIDEuMCwgMC41KSk7CiAgbGV0IGhhbGZWICAgPSBub3JtYWxpemUobGRpciArIHZlYzNmKDAuMCwgMC4wLCAxLjApKTsKICBsZXQgc3BlY0RlbiA9IGRlbnNpdHkgKiBtaW4oZGVuc2l0eSAqIDUuMCwgMS4wKTsKICBsZXQgc3BlYyAgICA9IHBvdyhtYXgoZG90KG5vcm0sIGhhbGZWKSwgMC4wKSwgdS5zcGVjdWxhckV4cCkgKiB1LnNoaW5lICogc3BlY0RlbjsKCiAgbGV0IGJnUmF3ID0gdGV4dHVyZVNhbXBsZSh1QmcsIHNhbXAsIGkudXYpLnJnYjsKICBsZXQgd2MgICAgPSB1LndhdGVyQ29sb3IucmdiOwogIGxldCBnYyAgICA9IHUuZ2xvd0NvbG9yLnJnYjsKICBsZXQgYmcgICAgPSBtaXgod2MsIGJnUmF3LCBjb3YpOwogIHZhciBjb2xvciA9IGJnOwoKICBpZiAodS5hbGdvcml0aG0gPT0gMSkgewogICAgbGV0IHJ1diA9IGNsYW1wKGkudXYgKyBub3JtLnh5ICogdS5yZWZyYWN0aW9uICogZGVuc2l0eSAqIDMuMCwgdmVjMmYoMC4wKSwgdmVjMmYoMS4wKSk7CiAgICBsZXQgcmJnID0gbWl4KHdjLCB0ZXh0dXJlU2FtcGxlKHVCZywgc2FtcCwgbWl4KGkudXYsIHJ1diwgMS4wIC0gb2JzKSkucmdiLCBjb3YpOwogICAgY29sb3IgICA9IHJiZyArIHNwZWMgKiBnYyAqIDIuNTsKICAgIGNvbG9yICAgPSBtaXgoY29sb3IsIGJnICogMC42LCBvYnMgKiAwLjMpOwogIH0gZWxzZSBpZiAodS5hbGdvcml0aG0gPT0gMikgewogICAgbGV0IGlua0QgPSBtaW4oZGVuc2l0eSAqIDQuMCwgMS4wKTsKICAgIGxldCBydXYgID0gY2xhbXAoaS51diArIG5vcm0ueHkgKiB1LnJlZnJhY3Rpb24gKiBkZW5zaXR5ICogMC40LCB2ZWMyZigwLjApLCB2ZWMyZigxLjApKTsKICAgIGxldCByYmcgID0gbWl4KHdjLCB0ZXh0dXJlU2FtcGxlKHVCZywgc2FtcCwgbWl4KGkudXYsIHJ1diwgMS4wIC0gb2JzKSkucmdiLCBjb3YpOwogICAgY29sb3IgICAgPSBtaXgocmJnLCB3YyArIHNwZWMgKiBnYywgaW5rRCk7CiAgICBjb2xvciAgICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMTUpOwogIH0gZWxzZSBpZiAodS5hbGdvcml0aG0gPT0gMykgewogICAgbGV0IHZlbCAgICA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS51dikueHk7CiAgICBsZXQgdmVsTWFnID0gY2xhbXAobGVuZ3RoKHZlbCkgKiAyMC4wLCAwLjAsIDEuMCk7CiAgICBsZXQgd3V2ICAgID0gY2xhbXAoaS51diArIHZlbCAqIHUud2FycFN0cmVuZ3RoLCB2ZWMyZigwLjApLCB2ZWMyZigxLjApKTsKICAgIGxldCB3YmcgICAgPSBtaXgod2MsIHRleHR1cmVTYW1wbGUodUJnLCBzYW1wLCB3dXYpLnJnYiwgY292KTsKICAgIGNvbG9yICAgICAgPSBtaXgoYmcsIHdiZywgdmVsTWFnICogKDEuMCAtIG9icykpOwogICAgY29sb3IgICAgICs9IHNwZWMgKiBnYyAqIHZlbE1hZyAqIDEuNTsKICAgIGNvbG9yICAgICArPSB3YyAqIGRlbnNpdHkgKiAwLjM7CiAgICBjb2xvciAgICAgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICB9IGVsc2UgaWYgKHUuYWxnb3JpdGhtID09IDQpIHsKICAgIGxldCBydXYgICA9IGNsYW1wKGkudXYgKyBub3JtLnh5ICogdS5yZWZyYWN0aW9uICogZGVuc2l0eSAqIDYuMCwgdmVjMmYoMC4wKSwgdmVjMmYoMS4wKSk7CiAgICBsZXQgcmJnICAgPSBtaXgod2MsIHRleHR1cmVTYW1wbGUodUJnLCBzYW1wLCBtaXgoaS51diwgcnV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdik7CiAgICBsZXQgZnJlcyAgPSBwb3coY2xhbXAoMS4wIC0gZG90KG5vcm0sIHZlYzNmKDAuMCwgMC4wLCAxLjApKSwgMC4wLCAxLjApLCAzLjApICogZGVuc2l0eTsKICAgIGNvbG9yICAgICA9IHJiZzsKICAgIGNvbG9yICAgICs9IGZyZXMgKiBnYyAqIDIuMDsKICAgIGNvbG9yICAgICs9IHNwZWMgKiBnYyAqIGRlbnNpdHkgKiAyLjA7CiAgICBjb2xvciAgICAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwogIH0gZWxzZSB7CiAgICBsZXQgcnV2ID0gaS51diArIG5vcm0ueHkgKiB1LnJlZnJhY3Rpb24gKiBkZW5zaXR5OwogICAgbGV0IHJiZyA9IG1peCh3YywgdGV4dHVyZVNhbXBsZSh1QmcsIHNhbXAsIG1peChpLnV2LCBydXYsIDEuMCAtIG9icykpLnJnYiwgY292KTsKICAgIGNvbG9yICAgPSBtaXgocmJnLCB3YywgbWluKGRlbnNpdHkgKiAxLjUsIDAuOCkpOwogICAgY29sb3IgICs9IHNwZWMgKiBnYzsKICAgIGNvbG9yICAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwogIH0KCiAgbGV0IGFscGhhID0gY2xhbXAobWF4KGRlbnNpdHkgKiAxLjUsIGNvdiksIDAuMCwgMS4wKTsKICBpZiAodS5lbmFibGVBbHBoYSA9PSAxKSB7CiAgICByZXR1cm4gdmVjNGYoY29sb3IgKiBhbHBoYSwgYWxwaGEpOwogIH0KICByZXR1cm4gdmVjNGYoY29sb3IsIDEuMCk7Cn0KYAopLCBOdCA9IHsKICBhcnJheVN0cmlkZTogOCwKICBhdHRyaWJ1dGVzOiBbeyBzaGFkZXJMb2NhdGlvbjogMCwgb2Zmc2V0OiAwLCBmb3JtYXQ6ICJmbG9hdDMyeDIiIH1dCn0sIG50ID0gbmV3IEZsb2F0MzJBcnJheShbCiAgLTEsCiAgLTEsCiAgLTEsCiAgMSwKICAxLAogIC0xLAogIDEsCiAgLTEsCiAgLTEsCiAgMSwKICAxLAogIDEKXSk7CmZ1bmN0aW9uICR0KGkpIHsKICBjb25zdCBlID0gaS5jcmVhdGVCdWZmZXIoeyBzaXplOiBudC5ieXRlTGVuZ3RoLCB1c2FnZTogR1BVQnVmZmVyVXNhZ2UuVkVSVEVYIHwgR1BVQnVmZmVyVXNhZ2UuQ09QWV9EU1QgfSk7CiAgcmV0dXJuIGkucXVldWUud3JpdGVCdWZmZXIoZSwgMCwgbnQpLCBlOwp9CmZ1bmN0aW9uIEhlKGksIGUsIHIsIHMpIHsKICBjb25zdCBvID0gaS5jcmVhdGVUZXh0dXJlKHsKICAgIHNpemU6IFtyLCBzXSwKICAgIGZvcm1hdDogZSwKICAgIHVzYWdlOiBHUFVUZXh0dXJlVXNhZ2UuVEVYVFVSRV9CSU5ESU5HIHwgR1BVVGV4dHVyZVVzYWdlLlJFTkRFUl9BVFRBQ0hNRU5UIHwgR1BVVGV4dHVyZVVzYWdlLkNPUFlfU1JDCiAgfSk7CiAgcmV0dXJuIHsgdGV4OiBvLCB2aWV3OiBvLmNyZWF0ZVZpZXcoKSwgd2lkdGg6IHIsIGhlaWdodDogcyB9Owp9CmZ1bmN0aW9uIHJ0KGksIGUsIHIsIHMpIHsKICBsZXQgbyA9IEhlKGksIGUsIHIsIHMpLCBhID0gSGUoaSwgZSwgciwgcyk7CiAgcmV0dXJuIHsKICAgIGdldCByZWFkKCkgewogICAgICByZXR1cm4gbzsKICAgIH0sCiAgICBnZXQgd3JpdGUoKSB7CiAgICAgIHJldHVybiBhOwogICAgfSwKICAgIHN3YXAoKSB7CiAgICAgIFtvLCBhXSA9IFthLCBvXTsKICAgIH0sCiAgICBkaXNwb3NlKCkgewogICAgICBvLnRleC5kZXN0cm95KCksIGEudGV4LmRlc3Ryb3koKTsKICAgIH0KICB9Owp9CmZ1bmN0aW9uIHNlKGksIGUsIHIsIHMpIHsKICBjb25zdCBvID0gaS5jcmVhdGVTaGFkZXJNb2R1bGUoeyBjb2RlOiBlIH0pOwogIHJldHVybiBpLmNyZWF0ZVJlbmRlclBpcGVsaW5lKHsKICAgIGxheW91dDogImF1dG8iLAogICAgdmVydGV4OiB7IG1vZHVsZTogbywgZW50cnlQb2ludDogInZzIiwgYnVmZmVyczogW050XSB9LAogICAgZnJhZ21lbnQ6IHsgbW9kdWxlOiBvLCBlbnRyeVBvaW50OiAiZnMiLCB0YXJnZXRzOiBbeyBmb3JtYXQ6IHIsIC4uLnMgPyB7IGJsZW5kOiBzIH0gOiB7fSB9XSB9LAogICAgcHJpbWl0aXZlOiB7IHRvcG9sb2d5OiAidHJpYW5nbGUtbGlzdCIgfQogIH0pOwp9CmNvbnN0IHF0ID0gewogIGNvbG9yOiB7IG9wZXJhdGlvbjogImFkZCIsIHNyY0ZhY3RvcjogIm9uZSIsIGRzdEZhY3RvcjogInplcm8iIH0sCiAgYWxwaGE6IHsgb3BlcmF0aW9uOiAiYWRkIiwgc3JjRmFjdG9yOiAib25lIiwgZHN0RmFjdG9yOiAiemVybyIgfQp9OwpmdW5jdGlvbiBIdChpLCBlLCByID0gITApIHsKICBjb25zdCBzID0gInJnYmExNmZsb2F0IjsKICByZXR1cm4gewogICAgYWR2ZWN0aW9uOiBzZShpLCBBdCwgcyksCiAgICBkaXZlcmdlbmNlOiBzZShpLCB6dCwgcyksCiAgICBwcmVzc3VyZTogc2UoaSwgWHQsIHMpLAogICAgZ3JhZGllbnRTdWJ0cmFjdDogc2UoaSwgR3QsIHMpLAogICAgc3BsYXQ6IHNlKGksIE10LCBzKSwKICAgIGN1cmw6IHNlKGksIEl0LCBzKSwKICAgIHZvcnRpY2l0eTogc2UoaSwga3QsIHMpLAogICAgZGlzcGxheTogc2UoaSwgV3QsIGUsIHIgPyB2b2lkIDAgOiBxdCkKICB9Owp9CmZ1bmN0aW9uIFl0KGkpIHsKICByZXR1cm4gaS5jcmVhdGVTYW1wbGVyKHsgbWFnRmlsdGVyOiAibGluZWFyIiwgbWluRmlsdGVyOiAibGluZWFyIiwgYWRkcmVzc01vZGVVOiAiY2xhbXAtdG8tZWRnZSIsIGFkZHJlc3NNb2RlVjogImNsYW1wLXRvLWVkZ2UiIH0pOwp9CmZ1bmN0aW9uIFcoaSwgZSkgewogIHJldHVybiBpLmNyZWF0ZUJ1ZmZlcih7IHNpemU6IGUsIHVzYWdlOiBHUFVCdWZmZXJVc2FnZS5VTklGT1JNIHwgR1BVQnVmZmVyVXNhZ2UuQ09QWV9EU1QgfSk7Cn0KZnVuY3Rpb24gbHQoaSwgZSwgciwgcywgbywgYSkgewogIGNvbnN0IHUgPSBuZXcgRmxvYXQzMkFycmF5KFtyLCBzLCBvLCBhXSk7CiAgaS5xdWV1ZS53cml0ZUJ1ZmZlcihlLCAwLCB1KTsKfQpmdW5jdGlvbiBOZShpLCBlLCByLCBzKSB7CiAgY29uc3QgbyA9IG5ldyBGbG9hdDMyQXJyYXkoW3IsIHMsIDAsIDBdKTsKICBpLnF1ZXVlLndyaXRlQnVmZmVyKGUsIDAsIG8pOwp9CmZ1bmN0aW9uIFF0KGksIGUsIHIsIHMsIG8sIGEpIHsKICBjb25zdCB1ID0gbmV3IEZsb2F0MzJBcnJheShbciwgcywgbywgYV0pOwogIGkucXVldWUud3JpdGVCdWZmZXIoZSwgMCwgdSk7Cn0KZnVuY3Rpb24gJGUoaSwgZSwgciwgcywgbywgYSwgdSwgdiwgbSwgYywgcCkgewogIGNvbnN0IHggPSBuZXcgRmxvYXQzMkFycmF5KDEyKTsKICB4WzBdID0gciwgeFsxXSA9IHMsIHhbMl0gPSBvLCB4WzNdID0gYSwgeFs0XSA9IHUsIHhbNV0gPSB2LCB4WzZdID0gbSwgeFs3XSA9IDAsIHhbOF0gPSBjLCB4WzldID0gcCwgeFsxMF0gPSAwLCB4WzExXSA9IDAsIGkucXVldWUud3JpdGVCdWZmZXIoZSwgMCwgeCk7Cn0KZnVuY3Rpb24ganQoaSwgZSwgciwgcywgbywgYSwgdSwgdiwgbSwgYywgcCwgeCkgewogIGNvbnN0IG4gPSBuZXcgRmxvYXQzMkFycmF5KDE2KSwgZCA9IG5ldyBJbnQzMkFycmF5KG4uYnVmZmVyKTsKICBuWzBdID0gciwgblsxXSA9IHMsIG5bMl0gPSBvLCBuWzNdID0gYSwgbls0XSA9IHVbMF0sIG5bNV0gPSB1WzFdLCBuWzZdID0gdVsyXSwgbls3XSA9IDAsIG5bOF0gPSB2WzBdLCBuWzldID0gdlsxXSwgblsxMF0gPSB2WzJdLCBuWzExXSA9IDAsIG5bMTJdID0gbSwgblsxM10gPSBjLCBkWzE0XSA9IHAsIGRbMTVdID0geCA/IDEgOiAwLCBpLnF1ZXVlLndyaXRlQnVmZmVyKGUsIDAsIG4pOwp9CmZ1bmN0aW9uIFgoaSwgZSwgciwgcywgbykgewogIGNvbnN0IGEgPSBpLmJlZ2luUmVuZGVyUGFzcyh7CiAgICBjb2xvckF0dGFjaG1lbnRzOiBbewogICAgICB2aWV3OiBvLAogICAgICBjbGVhclZhbHVlOiBbMCwgMCwgMCwgMF0sCiAgICAgIGxvYWRPcDogImNsZWFyIiwKICAgICAgc3RvcmVPcDogInN0b3JlIgogICAgfV0KICB9KTsKICBhLnNldFBpcGVsaW5lKGUpLCBhLnNldEJpbmRHcm91cCgwLCByKSwgYS5zZXRWZXJ0ZXhCdWZmZXIoMCwgcyksIGEuZHJhdyg2KSwgYS5lbmQoKTsKfQpmdW5jdGlvbiBLdChpLCBlLCByLCBzLCBvKSB7CiAgY29uc3QgYSA9IGkuYmVnaW5SZW5kZXJQYXNzKHsKICAgIGNvbG9yQXR0YWNobWVudHM6IFt7CiAgICAgIHZpZXc6IG8sCiAgICAgIGNsZWFyVmFsdWU6IFswLCAwLCAwLCAwXSwKICAgICAgbG9hZE9wOiAiY2xlYXIiLAogICAgICBzdG9yZU9wOiAic3RvcmUiCiAgICB9XQogIH0pOwogIGEuc2V0UGlwZWxpbmUoZSksIGEuc2V0QmluZEdyb3VwKDAsIHIpLCBhLnNldFZlcnRleEJ1ZmZlcigwLCBzKSwgYS5kcmF3KDYpLCBhLmVuZCgpOwp9CmZ1bmN0aW9uIEJlKGksIGUsIHIsIHMsIG8gPSAiY292ZXIiKSB7CiAgbGV0IGE7CiAgbyA9PT0gImNvdmVyIiA/IGEgPSBNYXRoLm1heChyIC8gaSwgcyAvIGUpIDogbyA9PT0gImNvbnRhaW4iID8gYSA9IE1hdGgubWluKHIgLyBpLCBzIC8gZSkgOiB0eXBlb2YgbyA9PSAic3RyaW5nIiAmJiBvLmVuZHNXaXRoKCIlIikgPyBhID0gTWF0aC5taW4ociAvIGksIHMgLyBlKSAqIChwYXJzZUZsb2F0KG8pIC8gMTAwKSA6IHR5cGVvZiBvID09ICJzdHJpbmciICYmIG8uZW5kc1dpdGgoInB4IikgPyBhID0gcGFyc2VGbG9hdChvKSAvIE1hdGgubWF4KGksIGUpIDogdHlwZW9mIG8gPT0gIm51bWJlciIgPyBhID0gbyA6IGEgPSBNYXRoLm1heChyIC8gaSwgcyAvIGUpOwogIGNvbnN0IHUgPSBpICogYSwgdiA9IGUgKiBhOwogIHJldHVybiB7IHg6IChyIC0gdSkgLyAyLCB5OiAocyAtIHYpIC8gMiwgZHJhd1c6IHUsIGRyYXdIOiB2IH07Cn0KZnVuY3Rpb24gSnQoaSwgZSwgciwgcywgbyA9IG51bGwsIGEgPSAiY292ZXIiKSB7CiAgY29uc3QgeyB0ZXh0OiB1LCBmb250U2l6ZTogdiwgY29sb3I6IG0sIGZvbnRGYW1pbHk6IGMgPSAic2Fucy1zZXJpZiIsIGZvbnRXZWlnaHQ6IHAgPSA5MDAgfSA9IHMsIHggPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKGUsIHIpLCBuID0geC5nZXRDb250ZXh0KCIyZCIpOwogICgoRCkgPT4gewogICAgaWYgKG8pIHsKICAgICAgbi5jbGVhclJlY3QoMCwgMCwgZSwgciksIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKTsKICAgICAgY29uc3QgeyB4OiBnLCB5OiBfLCBkcmF3VzogRiwgZHJhd0g6IGsgfSA9IEJlKAogICAgICAgIG8ud2lkdGgsCiAgICAgICAgby5oZWlnaHQsCiAgICAgICAgZSwKICAgICAgICByLAogICAgICAgIGEKICAgICAgKTsKICAgICAgbi5kcmF3SW1hZ2UobywgZywgXywgRiwgayk7CiAgICB9IGVsc2UKICAgICAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpOwogICAgbi5maWxsU3R5bGUgPSBELCBuLmZvbnQgPSBgJHtwfSAke3Z9cHggJHtjfWAsIG4udGV4dEFsaWduID0gImNlbnRlciIsIG4udGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIG4uZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICB9KShtKTsKICBjb25zdCBiID0gTGUoaSwgeCk7CiAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpLCBuLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIG4uZm9udCA9IGAke3B9ICR7dn1weCAke2N9YCwgbi50ZXh0QWxpZ24gPSAiY2VudGVyIiwgbi50ZXh0QmFzZWxpbmUgPSAibWlkZGxlIiwgbi5maWxsVGV4dCh1LCBlIC8gMiwgciAvIDIpOwogIGNvbnN0IHkgPSBMZShpLCB4KTsKICByZXR1cm4geyBiYWNrZ3JvdW5kVGV4OiBiLCBvYnN0YWNsZVRleDogeSwgY292ZXJhZ2VUZXg6IHkgfTsKfQpmdW5jdGlvbiBadChpLCBlLCByLCBzLCBvID0gMCwgYSA9ICJjb3ZlciIsIHUgPSBudWxsLCB2ID0gImNvdmVyIikgewogIGNvbnN0IG0gPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKHIsIHMpLCBjID0gbS5nZXRDb250ZXh0KCIyZCIpLCB7IHg6IHAsIHk6IHgsIGRyYXdXOiBuLCBkcmF3SDogZCB9ID0gQmUoZS53aWR0aCwgZS5oZWlnaHQsIHIsIHMsIGEpOwogIGlmIChjLmNsZWFyUmVjdCgwLCAwLCByLCBzKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIHMpLCB1KSB7CiAgICBjb25zdCB7CiAgICAgIHg6IGcsCiAgICAgIHk6IF8sCiAgICAgIGRyYXdXOiBGLAogICAgICBkcmF3SDogawogICAgfSA9IEJlKHUud2lkdGgsIHUuaGVpZ2h0LCByLCBzLCB2KTsKICAgIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtvfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UodSwgZywgXywgRiwgayksIGMuZmlsdGVyID0gIm5vbmUiOwogIH0KICBjLmRyYXdJbWFnZShlLCBwLCB4LCBuLCBkKTsKICBjb25zdCBiID0gTGUoaSwgbSk7CiAgYy5jbGVhclJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBzKSwgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke299KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZShlLCBwLCB4LCBuLCBkKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgY29uc3QgeSA9IExlKGksIG0pOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gIndoaXRlIiwgYy5maWxsUmVjdCgKICAgIE1hdGgubWF4KDAsIHApLAogICAgTWF0aC5tYXgoMCwgeCksCiAgICBNYXRoLm1pbihuLCByIC0gTWF0aC5tYXgoMCwgcCkpLAogICAgTWF0aC5taW4oZCwgcyAtIE1hdGgubWF4KDAsIHgpKQogICk7CiAgY29uc3QgRCA9IExlKGksIG0pOwogIHJldHVybiB7IGJhY2tncm91bmRUZXg6IGIsIG9ic3RhY2xlVGV4OiB5LCBjb3ZlcmFnZVRleDogRCB9Owp9CmZ1bmN0aW9uIExlKGksIGUpIHsKICBjb25zdCByID0gaS5jcmVhdGVUZXh0dXJlKCk7CiAgcmV0dXJuIGkuYmluZFRleHR1cmUoaS5URVhUVVJFXzJELCByKSwgaS5waXhlbFN0b3JlaShpLlVOUEFDS19GTElQX1lfV0VCR0wsICEwKSwgaS50ZXhJbWFnZTJEKGkuVEVYVFVSRV8yRCwgMCwgaS5SR0JBLCBpLlJHQkEsIGkuVU5TSUdORURfQllURSwgZSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NSU5fRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NQUdfRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1MsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1QsIGkuQ0xBTVBfVE9fRURHRSksIHI7Cn0KZnVuY3Rpb24gZXIoaSwgZSwgciwgcywgbyA9IG51bGwsIGEgPSAiY292ZXIiKSB7CiAgY29uc3QgeyB0ZXh0OiB1LCBmb250U2l6ZTogdiwgY29sb3I6IG0sIGZvbnRGYW1pbHk6IGMgPSAic2Fucy1zZXJpZiIsIGZvbnRXZWlnaHQ6IHAgPSA5MDAgfSA9IHMsIHggPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKGUsIHIpLCBuID0geC5nZXRDb250ZXh0KCIyZCIpOwogICgoRCkgPT4gewogICAgaWYgKG8pIHsKICAgICAgbi5jbGVhclJlY3QoMCwgMCwgZSwgciksIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKTsKICAgICAgY29uc3QgeyB4OiBnLCB5OiBfLCBkcmF3VzogRiwgZHJhd0g6IGsgfSA9IEJlKAogICAgICAgIG8ud2lkdGgsCiAgICAgICAgby5oZWlnaHQsCiAgICAgICAgZSwKICAgICAgICByLAogICAgICAgIGEKICAgICAgKTsKICAgICAgbi5kcmF3SW1hZ2UobywgZywgXywgRiwgayk7CiAgICB9IGVsc2UKICAgICAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpOwogICAgbi5maWxsU3R5bGUgPSBELCBuLmZvbnQgPSBgJHtwfSAke3Z9cHggJHtjfWAsIG4udGV4dEFsaWduID0gImNlbnRlciIsIG4udGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIG4uZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICB9KShtKTsKICBjb25zdCBiID0gQWUoaSwgeCwgZSwgcik7CiAgbi5maWxsU3R5bGUgPSAiYmxhY2siLCBuLmZpbGxSZWN0KDAsIDAsIGUsIHIpLCBuLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIG4uZm9udCA9IGAke3B9ICR7dn1weCAke2N9YCwgbi50ZXh0QWxpZ24gPSAiY2VudGVyIiwgbi50ZXh0QmFzZWxpbmUgPSAibWlkZGxlIiwgbi5maWxsVGV4dCh1LCBlIC8gMiwgciAvIDIpOwogIGNvbnN0IHkgPSBBZShpLCB4LCBlLCByKTsKICByZXR1cm4gewogICAgYmFja2dyb3VuZFRleDogYiwKICAgIGJhY2tncm91bmRWaWV3OiBiLmNyZWF0ZVZpZXcoKSwKICAgIG9ic3RhY2xlVGV4OiB5LAogICAgb2JzdGFjbGVWaWV3OiB5LmNyZWF0ZVZpZXcoKSwKICAgIGNvdmVyYWdlVGV4OiB5LAogICAgY292ZXJhZ2VWaWV3OiB5LmNyZWF0ZVZpZXcoKSwKICAgIHNoYXJlZENvdmVyYWdlOiAhMAogIH07Cn0KZnVuY3Rpb24gdHIoaSwgZSwgciwgcywgbyA9IDAsIGEgPSAiY292ZXIiLCB1ID0gbnVsbCwgdiA9ICJjb3ZlciIpIHsKICBjb25zdCBtID0gbmV3IE9mZnNjcmVlbkNhbnZhcyhyLCBzKSwgYyA9IG0uZ2V0Q29udGV4dCgiMmQiKSwgeyB4OiBwLCB5OiB4LCBkcmF3VzogbiwgZHJhd0g6IGQgfSA9IEJlKGUud2lkdGgsIGUuaGVpZ2h0LCByLCBzLCBhKTsKICBpZiAoYy5jbGVhclJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBzKSwgdSkgewogICAgY29uc3QgeyB4OiBnLCB5OiBfLCBkcmF3VzogRiwgZHJhd0g6IGsgfSA9IEJlKAogICAgICB1LndpZHRoLAogICAgICB1LmhlaWdodCwKICAgICAgciwKICAgICAgcywKICAgICAgdgogICAgKTsKICAgIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtvfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UodSwgZywgXywgRiwgayksIGMuZmlsdGVyID0gIm5vbmUiOwogIH0KICBjLmRyYXdJbWFnZShlLCBwLCB4LCBuLCBkKTsKICBjb25zdCBiID0gQWUoaSwgbSwgciwgcyk7CiAgYy5jbGVhclJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBzKSwgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke299KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZShlLCBwLCB4LCBuLCBkKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgY29uc3QgeSA9IEFlKGksIG0sIHIsIHMpOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gIndoaXRlIiwgYy5maWxsUmVjdChNYXRoLm1heCgwLCBwKSwgTWF0aC5tYXgoMCwgeCksIE1hdGgubWluKG4sIHIgLSBNYXRoLm1heCgwLCBwKSksIE1hdGgubWluKGQsIHMgLSBNYXRoLm1heCgwLCB4KSkpOwogIGNvbnN0IEQgPSBBZShpLCBtLCByLCBzKTsKICByZXR1cm4gewogICAgYmFja2dyb3VuZFRleDogYiwKICAgIGJhY2tncm91bmRWaWV3OiBiLmNyZWF0ZVZpZXcoKSwKICAgIG9ic3RhY2xlVGV4OiB5LAogICAgb2JzdGFjbGVWaWV3OiB5LmNyZWF0ZVZpZXcoKSwKICAgIGNvdmVyYWdlVGV4OiBELAogICAgY292ZXJhZ2VWaWV3OiBELmNyZWF0ZVZpZXcoKSwKICAgIHNoYXJlZENvdmVyYWdlOiAhMQogIH07Cn0KZnVuY3Rpb24gQWUoaSwgZSwgciwgcykgewogIGNvbnN0IG8gPSBpLmNyZWF0ZVRleHR1cmUoewogICAgc2l6ZTogW3IsIHNdLAogICAgZm9ybWF0OiAicmdiYTh1bm9ybSIsCiAgICB1c2FnZTogR1BVVGV4dHVyZVVzYWdlLlRFWFRVUkVfQklORElORyB8IEdQVVRleHR1cmVVc2FnZS5DT1BZX0RTVCB8IEdQVVRleHR1cmVVc2FnZS5SRU5ERVJfQVRUQUNITUVOVAogIH0pOwogIHJldHVybiBpLnF1ZXVlLmNvcHlFeHRlcm5hbEltYWdlVG9UZXh0dXJlKAogICAgeyBzb3VyY2U6IGUgfSwKICAgIHsgdGV4dHVyZTogbyB9LAogICAgW3IsIHNdCiAgKSwgbzsKfQphc3luYyBmdW5jdGlvbiBycihpKSB7CiAgY29uc3QgZSA9IGF3YWl0IGZldGNoKGkpOwogIGlmICghZS5vaykKICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGZldGNoIGltYWdlOiAke2l9ICgke2Uuc3RhdHVzfSlgKTsKICBjb25zdCByID0gYXdhaXQgZS5ibG9iKCk7CiAgcmV0dXJuIGNyZWF0ZUltYWdlQml0bWFwKHIpOwp9CmNvbnN0IGN0ID0gdHlwZW9mIHJlcXVlc3RBbmltYXRpb25GcmFtZSA8ICJ1IiA/IHJlcXVlc3RBbmltYXRpb25GcmFtZS5iaW5kKGdsb2JhbFRoaXMpIDogKGkpID0+IHNldFRpbWVvdXQoaSwgMWUzIC8gNjApLCBpciA9IHR5cGVvZiBjYW5jZWxBbmltYXRpb25GcmFtZSA8ICJ1IiA/IGNhbmNlbEFuaW1hdGlvbkZyYW1lLmJpbmQoZ2xvYmFsVGhpcykgOiBjbGVhclRpbWVvdXQsIFZlID0gMC4wMTYsIGZ0ID0geyBzdGFuZGFyZDogMCwgZ2xhc3M6IDEsIGluazogMiwgYXVyb3JhOiAzLCByaXBwbGU6IDQgfTsKdmFyIGNlLCBHLCB6ZSwgZmUsIFVlLCBCLCBSLCAkLCBxLCBILCBLLCBMLCBZLCBWLCBEZSwgdmUsIF9lLCBPLCBULCBvZSwgUSwgYWUsIHosIHhlLCBwZSwgbWUsIGRlLCBoZSwgSiwgWiwgZ2UsIGJlLCBUZSwgdywgVSwgTSwgSSwgUCwgQ2UsIGVlLCBBLCB1ZSwgdGUsIGgsIEMsIGosIHllLCBYZSwgU2UsIFllLCB4dCwgd2UsIFBlLCBHZSwgc3QsIG5lLCBFZSwgUmUsIEZlLCBNZSwgb3QsIEllLCBhdCwgUWUsIHB0LCBqZSwgbXQsIEtlLCBkdCwgSmUsIGh0LCBaZSwgZ3Q7CmNvbnN0IHV0ID0gY2xhc3MgdXQgewogIC8vIOKUgOKUgCBDb25zdHJ1Y3RvciDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICBjb25zdHJ1Y3RvcihlLCByID0ge30sIHMgPSB7fSwgbywgYSA9ICEwKSB7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIEdQVSBpbml0aWFsaXNhdGlvbgogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIFllKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgc2hhcmVkIGhlbHBlcnMKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCB3ZSk7CiAgICBmKHRoaXMsIEdlKTsKICAgIGYodGhpcywgbmUpOwogICAgZih0aGlzLCBSZSk7CiAgICBmKHRoaXMsIE1lKTsKICAgIGYodGhpcywgSWUpOwogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIOKAlCBmcmFtZSBkaXNwYXRjaAogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIFFlKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgV2ViR1BVIHNpbXVsYXRpb24gc3RlcAogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIGplKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgV2ViR1BVIGRpcmVjdCBzcGxhdAogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIEtlKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgV2ViR0wgc3BsYXQKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCBKZSk7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIFdlYkdMIHNpbXVsYXRpb24gc3RlcCAodW5jaGFuZ2VkIGZyb20gb3JpZ2luYWwpCiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIGYodGhpcywgWmUpOwogICAgZih0aGlzLCBjZSwgdm9pZCAwKTsKICAgIC8vIOKUgOKUgCBXZWJHTCBwYXRoIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgZih0aGlzLCBHLCBudWxsKTsKICAgIGYodGhpcywgemUsIG51bGwpOwogICAgZih0aGlzLCBmZSwgbnVsbCk7CiAgICBmKHRoaXMsIFVlLCBudWxsKTsKICAgIGYodGhpcywgQiwgbnVsbCk7CiAgICBmKHRoaXMsIFIsIG51bGwpOwogICAgZih0aGlzLCAkLCBudWxsKTsKICAgIGYodGhpcywgcSwgbnVsbCk7CiAgICBmKHRoaXMsIEgsIG51bGwpOwogICAgZih0aGlzLCBLLCBudWxsKTsKICAgIGYodGhpcywgTCwgbnVsbCk7CiAgICBmKHRoaXMsIFksIG51bGwpOwogICAgLy8g4pSA4pSAIFdlYkdQVSBwYXRoIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgZih0aGlzLCBWLCBudWxsKTsKICAgIGYodGhpcywgRGUsIG51bGwpOwogICAgZih0aGlzLCB2ZSwgbnVsbCk7CiAgICBmKHRoaXMsIF9lLCBudWxsKTsKICAgIGYodGhpcywgTywgbnVsbCk7CiAgICBmKHRoaXMsIFQsIG51bGwpOwogICAgZih0aGlzLCBvZSwgbnVsbCk7CiAgICBmKHRoaXMsIFEsIG51bGwpOwogICAgZih0aGlzLCBhZSwgbnVsbCk7CiAgICBmKHRoaXMsIHosIG51bGwpOwogICAgLy8gUHJlLWFsbG9jYXRlZCB1bmlmb3JtIGJ1ZmZlcnMgKHNpemVzOiBzZWUgZ3B1LXV0aWxzIHdyaXRlWHh4IGRvY3MpCiAgICAvLyBWZWxvY2l0eS9kZW5zaXR5IGFkdmVjdGlvbiB1c2Ugc2VwYXJhdGUgYnVmZmVycyDigJQgd3JpdGVCdWZmZXIgaXMgYSBxdWV1ZSBvcDsKICAgIC8vIGEgc2Vjb25kIHdyaXRlIHRvIHRoZSBzYW1lIGJ1ZmZlciBiZWZvcmUgcXVldWUuc3VibWl0KCkgYWxpYXNlcyBib3RoIHBhc3Nlcy4KICAgIGYodGhpcywgeGUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMg4oCUIHZlbG9jaXR5IGFkdmVjdGlvbgogICAgZih0aGlzLCBwZSwgbnVsbCk7CiAgICAvLyAxNiBieXRlcyDigJQgZGVuc2l0eSBhZHZlY3Rpb24KICAgIGYodGhpcywgbWUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgZGUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgaGUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgSiwgbnVsbCk7CiAgICAvLyA0OCBieXRlcyDigJQgdmVsb2NpdHkgc3BsYXQKICAgIGYodGhpcywgWiwgbnVsbCk7CiAgICAvLyA0OCBieXRlcyDigJQgZGVuc2l0eSBzcGxhdAogICAgZih0aGlzLCBnZSwgbnVsbCk7CiAgICAvLyAxNiBieXRlcwogICAgZih0aGlzLCBiZSwgbnVsbCk7CiAgICAvLyAxNiBieXRlcwogICAgZih0aGlzLCBUZSwgbnVsbCk7CiAgICAvLyA2NCBieXRlcwogICAgLy8g4pSA4pSAIFNoYXJlZCBzdGF0ZSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgIGYodGhpcywgdywgMCk7CiAgICBmKHRoaXMsIFUsIDApOwogICAgZih0aGlzLCBNLCAwKTsKICAgIGYodGhpcywgSSwgMCk7CiAgICBmKHRoaXMsIFAsIDEpOwogICAgZih0aGlzLCBDZSwgMSk7CiAgICBmKHRoaXMsIGVlLCAwLjUpOwogICAgZih0aGlzLCBBLCBudWxsKTsKICAgIGYodGhpcywgdWUsICJjb3ZlciIpOwogICAgZih0aGlzLCB0ZSwgdm9pZCAwKTsKICAgIGYodGhpcywgaCwgeyB4OiAwLCB5OiAwLCBkeDogMCwgZHk6IDAsIHRhcmdldFg6IDAsIHRhcmdldFk6IDAsIG1vdmVkOiAhMSB9KTsKICAgIGYodGhpcywgQywgbnVsbCk7CiAgICBmKHRoaXMsIGosIG51bGwpOwogICAgZih0aGlzLCB5ZSwgITEpOwogICAgZih0aGlzLCBYZSwgITEpOwogICAgZih0aGlzLCBTZSwgITApOwogICAgaWYgKGwodGhpcywgY2UsIGUpLCBsKHRoaXMsIENlLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIHMuZHByID8/IDEpKSksIGwodGhpcywgZWUsIE1hdGgubWF4KDAuMSwgTWF0aC5taW4oMSwgcy5zaW0gPz8gMC41KSkpLCBsKHRoaXMsIHRlLCB3dChyKSksIGwodGhpcywgU2UsIGEpLCBvKQogICAgICBsKHRoaXMsIFYsIG8pLCBTKHRoaXMsIFllLCB4dCkuY2FsbCh0aGlzLCBvKTsKICAgIGVsc2UgewogICAgICBjb25zdCB7IGdsOiB1LCBleHQ6IHYgfSA9IFZ0KGUsIGEpOwogICAgICBsKHRoaXMsIEcsIHUpLCBsKHRoaXMsIHplLCB2KSwgbCh0aGlzLCBmZSwgRnQodSkpLCBsKHRoaXMsIFVlLCBMdCh1KSksIHUuY2xlYXJDb2xvcigwLCAwLCAwLCBhID8gMCA6IDEpOwogICAgfQogIH0KICAvKioKICAgKiBXZWJHUFUtZmlyc3QgZmFjdG9yeS4gVHJpZXMgV2ViR1BVLCBmYWxscyBiYWNrIHRvIFdlYkdMMiDihpIgV2ViR0wxLgogICAqIFRoaXMgaXMgdGhlIHJlY29tbWVuZGVkIGVudHJ5IHBvaW50IHdoZW4gV2ViR1BVIHN1cHBvcnQgaXMgZGVzaXJlZC4KICAgKi8KICBzdGF0aWMgYXN5bmMgY3JlYXRlKGUsIHIgPSB7fSwgcyA9IHt9LCBvID0gITAsIGEgPSAhMCkgewogICAgY29uc3QgdSA9IG8gPyBhd2FpdCBQdChlLCBhKSA6IG51bGw7CiAgICByZXR1cm4gbmV3IHV0KGUsIHIsIHMsIHUgPz8gdm9pZCAwLCBhKTsKICB9CiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgLy8gUHVibGljIEFQSQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIHNldFRleHRTb3VyY2UoZSkgewogICAgbCh0aGlzLCBDLCB7IHR5cGU6ICJ0ZXh0Iiwgb3B0czogZSB9KSwgUyh0aGlzLCB3ZSwgUGUpLmNhbGwodGhpcyksIFModGhpcywgbmUsIEVlKS5jYWxsKHRoaXMpLCBTKHRoaXMsIFJlLCBGZSkuY2FsbCh0aGlzKTsKICB9CiAgYXN5bmMgc2V0SW1hZ2VTb3VyY2UoZSwgciA9IDAsIHMgPSAiY292ZXIiKSB7CiAgICBjb25zdCBvID0gYXdhaXQgcnIoZSk7CiAgICBpZiAodCh0aGlzLCBYZSkpIHsKICAgICAgby5jbG9zZSgpOwogICAgICByZXR1cm47CiAgICB9CiAgICBsKHRoaXMsIEMsIHsgdHlwZTogImltYWdlIiwgYml0bWFwOiBvLCBlZmZlY3Q6IHIsIHNpemU6IHMgfSksIFModGhpcywgd2UsIFBlKS5jYWxsKHRoaXMpLCBTKHRoaXMsIG5lLCBFZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBSZSwgRmUpLmNhbGwodGhpcyk7CiAgfQogIHNldEltYWdlQml0bWFwKGUsIHIgPSAwLCBzID0gImNvdmVyIikgewogICAgbCh0aGlzLCBDLCB7IHR5cGU6ICJpbWFnZSIsIGJpdG1hcDogZSwgZWZmZWN0OiByLCBzaXplOiBzIH0pLCBTKHRoaXMsIHdlLCBQZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBuZSwgRWUpLmNhbGwodGhpcyksIFModGhpcywgUmUsIEZlKS5jYWxsKHRoaXMpOwogIH0KICBzZXRCYWNrZ3JvdW5kKGUsIHIgPSAiY292ZXIiKSB7CiAgICB0KHRoaXMsIEEpICYmIHQodGhpcywgQSkgIT09IGUgJiYgdCh0aGlzLCBBKS5jbG9zZSgpLCBsKHRoaXMsIEEsIGUpLCBsKHRoaXMsIHVlLCByID8/ICJjb3ZlciIpLCB0KHRoaXMsIEMpICYmIHQodGhpcywgdykgPiAwICYmIHQodGhpcywgVSkgPiAwICYmIFModGhpcywgbmUsIEVlKS5jYWxsKHRoaXMpOwogIH0KICBoYW5kbGVNb3ZlKGUsIHIsIHMgPSAxKSB7CiAgICB0KHRoaXMsIGgpLm1vdmVkID0gITAsIHQodGhpcywgaCkuZHggPSAoZSAtIHQodGhpcywgaCkudGFyZ2V0WCkgKiBzLCB0KHRoaXMsIGgpLmR5ID0gKHIgLSB0KHRoaXMsIGgpLnRhcmdldFkpICogcywgdCh0aGlzLCBoKS50YXJnZXRYID0gZSwgdCh0aGlzLCBoKS50YXJnZXRZID0gcjsKICB9CiAgLyoqCiAgICogSW1tZWRpYXRlbHkgYXBwbGllcyBvbmUgZmx1aWQgc3BsYXQgYXQgKHgsIHkpIHdpdGggZXhwbGljaXQgdmVsb2NpdHkgKHZ4LCB2eSkuCiAgICogU2FmZSB0byBjYWxsIG11bHRpcGxlIHRpbWVzIHBlciBmcmFtZSDigJQgZWFjaCBjYWxsIHdyaXRlcyBkaXJlY3RseSB0byB0aGUgRkJPcy4KICAgKiBEZXNpZ25lZCBmb3IgcHJvZ3JhbW1hdGljIHVzZSBjYXNlcyAoZS5nLiBwYXJ0aWNsZSBzeXN0ZW1zLCBhdHRyYWN0b3IgcGF0aHMpCiAgICogd2hlcmUgeW91IHdhbnQgTiBpbmRlcGVuZGVudCBpbmplY3Rpb24gcG9pbnRzIHBlciBmcmFtZSB3aXRob3V0IGZsb29kaW5nIHRoZQogICAqIG1vdXNlLXN0YXRlIG1hY2hpbmUgb3IgdGhlIHdvcmtlciBtZXNzYWdlIHF1ZXVlLgogICAqLwogIHNwbGF0KGUsIHIsIHMsIG8sIGEgPSAxKSB7CiAgICAhdCh0aGlzLCB5ZSkgfHwgdCh0aGlzLCB3KSA9PT0gMCB8fCAodCh0aGlzLCBWKSA/IFModGhpcywgS2UsIGR0KS5jYWxsKHRoaXMsIGUsIHIsIHMsIG8sIGEpIDogUyh0aGlzLCBKZSwgaHQpLmNhbGwodGhpcywgZSwgciwgcywgbywgYSkpOwogIH0KICB1cGRhdGVRdWFsaXR5KGUpIHsKICAgIGUuZHByICE9PSB2b2lkIDAgJiYgbCh0aGlzLCBDZSwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBlLmRwcikpKSwgZS5zaW0gIT09IHZvaWQgMCAmJiBsKHRoaXMsIGVlLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIGUuc2ltKSkpOwogIH0KICByZXNpemUoZSwgciwgcykgewogICAgaWYgKHMgIT09IHZvaWQgMCA/IGwodGhpcywgUCwgcykgOiB0eXBlb2Ygd2luZG93IDwgInUiICYmIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvICYmIGwodGhpcywgUCwgd2luZG93LmRldmljZVBpeGVsUmF0aW8pLCBlICE9PSB2b2lkIDAgJiYgZSA+IDApIHsKICAgICAgaWYgKHIgPT09IHZvaWQgMCB8fCByIDw9IDApCiAgICAgICAgcmV0dXJuOwogICAgICBsKHRoaXMsIHcsIHQodGhpcywgY2UpLndpZHRoID0gZSksIGwodGhpcywgVSwgdCh0aGlzLCBjZSkuaGVpZ2h0ID0gciksIGwodGhpcywgTSwgTWF0aC5tYXgoMSwgTWF0aC5yb3VuZChlICogdCh0aGlzLCBlZSkpKSksIGwodGhpcywgSSwgTWF0aC5tYXgoMSwgTWF0aC5yb3VuZChyICogdCh0aGlzLCBlZSkpKSksIFModGhpcywgR2UsIHN0KS5jYWxsKHRoaXMpOwogICAgfSBlbHNlCiAgICAgIFModGhpcywgd2UsIFBlKS5jYWxsKHRoaXMpOwogICAgdCh0aGlzLCBDKSAmJiBTKHRoaXMsIG5lLCBFZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBSZSwgRmUpLmNhbGwodGhpcyk7CiAgfQogIHVwZGF0ZUNvbmZpZyhlKSB7CiAgICBPYmplY3QuYXNzaWduKHQodGhpcywgdGUpLCBlKTsKICB9CiAgZGVzdHJveSgpIHsKICAgIHZhciBlLCByLCBzLCBvLCBhLCB1LCB2LCBtLCBjLCBwLCB4OwogICAgaWYgKGwodGhpcywgWGUsICEwKSwgdGhpcy5zdG9wKCksIFModGhpcywgTWUsIG90KS5jYWxsKHRoaXMpLCBTKHRoaXMsIEllLCBhdCkuY2FsbCh0aGlzKSwgdCh0aGlzLCBBKSAmJiAodCh0aGlzLCBBKS5jbG9zZSgpLCBsKHRoaXMsIEEsIG51bGwpKSwgdCh0aGlzLCBWKSkKICAgICAgKGUgPSB0KHRoaXMsIHhlKSkgPT0gbnVsbCB8fCBlLmRlc3Ryb3koKSwgKHIgPSB0KHRoaXMsIHBlKSkgPT0gbnVsbCB8fCByLmRlc3Ryb3koKSwgKHMgPSB0KHRoaXMsIG1lKSkgPT0gbnVsbCB8fCBzLmRlc3Ryb3koKSwgKG8gPSB0KHRoaXMsIGRlKSkgPT0gbnVsbCB8fCBvLmRlc3Ryb3koKSwgKGEgPSB0KHRoaXMsIGhlKSkgPT0gbnVsbCB8fCBhLmRlc3Ryb3koKSwgKHUgPSB0KHRoaXMsIEopKSA9PSBudWxsIHx8IHUuZGVzdHJveSgpLCAodiA9IHQodGhpcywgWikpID09IG51bGwgfHwgdi5kZXN0cm95KCksIChtID0gdCh0aGlzLCBnZSkpID09IG51bGwgfHwgbS5kZXN0cm95KCksIChjID0gdCh0aGlzLCBiZSkpID09IG51bGwgfHwgYy5kZXN0cm95KCksIChwID0gdCh0aGlzLCBUZSkpID09IG51bGwgfHwgcC5kZXN0cm95KCksICh4ID0gdCh0aGlzLCB2ZSkpID09IG51bGwgfHwgeC5kZXN0cm95KCksIHQodGhpcywgVikuZGV2aWNlLmRlc3Ryb3koKTsKICAgIGVsc2UgewogICAgICBjb25zdCBuID0gdCh0aGlzLCBHKTsKICAgICAgZm9yIChjb25zdCBiIG9mIE9iamVjdC52YWx1ZXModCh0aGlzLCBmZSkpKQogICAgICAgIGIuZGlzcG9zZSgpOwogICAgICBjb25zdCBkID0gbi5nZXRFeHRlbnNpb24oIldFQkdMX2xvc2VfY29udGV4dCIpOwogICAgICBkID09IG51bGwgfHwgZC5sb3NlQ29udGV4dCgpOwogICAgfQogIH0KICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAvLyBMb29wIGNvbnRyb2wKICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICBzdGFydCgpIHsKICAgIGlmICh0KHRoaXMsIGopICE9PSBudWxsKQogICAgICByZXR1cm47CiAgICBjb25zdCBlID0gKCkgPT4gewogICAgICBTKHRoaXMsIFFlLCBwdCkuY2FsbCh0aGlzKSwgbCh0aGlzLCBqLCBjdChlKSk7CiAgICB9OwogICAgbCh0aGlzLCBqLCBjdChlKSk7CiAgfQogIHN0b3AoKSB7CiAgICB0KHRoaXMsIGopICE9PSBudWxsICYmIChpcih0KHRoaXMsIGopKSwgbCh0aGlzLCBqLCBudWxsKSk7CiAgfQogIGdldCBpc1J1bm5pbmcoKSB7CiAgICByZXR1cm4gdCh0aGlzLCBqKSAhPT0gbnVsbDsKICB9Cn07CmNlID0gbmV3IFdlYWtNYXAoKSwgRyA9IG5ldyBXZWFrTWFwKCksIHplID0gbmV3IFdlYWtNYXAoKSwgZmUgPSBuZXcgV2Vha01hcCgpLCBVZSA9IG5ldyBXZWFrTWFwKCksIEIgPSBuZXcgV2Vha01hcCgpLCBSID0gbmV3IFdlYWtNYXAoKSwgJCA9IG5ldyBXZWFrTWFwKCksIHEgPSBuZXcgV2Vha01hcCgpLCBIID0gbmV3IFdlYWtNYXAoKSwgSyA9IG5ldyBXZWFrTWFwKCksIEwgPSBuZXcgV2Vha01hcCgpLCBZID0gbmV3IFdlYWtNYXAoKSwgViA9IG5ldyBXZWFrTWFwKCksIERlID0gbmV3IFdlYWtNYXAoKSwgdmUgPSBuZXcgV2Vha01hcCgpLCBfZSA9IG5ldyBXZWFrTWFwKCksIE8gPSBuZXcgV2Vha01hcCgpLCBUID0gbmV3IFdlYWtNYXAoKSwgb2UgPSBuZXcgV2Vha01hcCgpLCBRID0gbmV3IFdlYWtNYXAoKSwgYWUgPSBuZXcgV2Vha01hcCgpLCB6ID0gbmV3IFdlYWtNYXAoKSwgeGUgPSBuZXcgV2Vha01hcCgpLCBwZSA9IG5ldyBXZWFrTWFwKCksIG1lID0gbmV3IFdlYWtNYXAoKSwgZGUgPSBuZXcgV2Vha01hcCgpLCBoZSA9IG5ldyBXZWFrTWFwKCksIEogPSBuZXcgV2Vha01hcCgpLCBaID0gbmV3IFdlYWtNYXAoKSwgZ2UgPSBuZXcgV2Vha01hcCgpLCBiZSA9IG5ldyBXZWFrTWFwKCksIFRlID0gbmV3IFdlYWtNYXAoKSwgdyA9IG5ldyBXZWFrTWFwKCksIFUgPSBuZXcgV2Vha01hcCgpLCBNID0gbmV3IFdlYWtNYXAoKSwgSSA9IG5ldyBXZWFrTWFwKCksIFAgPSBuZXcgV2Vha01hcCgpLCBDZSA9IG5ldyBXZWFrTWFwKCksIGVlID0gbmV3IFdlYWtNYXAoKSwgQSA9IG5ldyBXZWFrTWFwKCksIHVlID0gbmV3IFdlYWtNYXAoKSwgdGUgPSBuZXcgV2Vha01hcCgpLCBoID0gbmV3IFdlYWtNYXAoKSwgQyA9IG5ldyBXZWFrTWFwKCksIGogPSBuZXcgV2Vha01hcCgpLCB5ZSA9IG5ldyBXZWFrTWFwKCksIFhlID0gbmV3IFdlYWtNYXAoKSwgU2UgPSBuZXcgV2Vha01hcCgpLCBZZSA9IG5ldyBXZWFrU2V0KCksIHh0ID0gZnVuY3Rpb24oZSkgewogIGNvbnN0IHsgZGV2aWNlOiByLCBmb3JtYXQ6IHMgfSA9IGU7CiAgbCh0aGlzLCBEZSwgSHQociwgcywgdCh0aGlzLCBTZSkpKSwgbCh0aGlzLCB2ZSwgJHQocikpLCBsKHRoaXMsIF9lLCBZdChyKSksIGwodGhpcywgeGUsIFcociwgMTYpKSwgbCh0aGlzLCBwZSwgVyhyLCAxNikpLCBsKHRoaXMsIG1lLCBXKHIsIDE2KSksIGwodGhpcywgZGUsIFcociwgMTYpKSwgbCh0aGlzLCBoZSwgVyhyLCAxNikpLCBsKHRoaXMsIEosIFcociwgNDgpKSwgbCh0aGlzLCBaLCBXKHIsIDQ4KSksIGwodGhpcywgZ2UsIFcociwgMTYpKSwgbCh0aGlzLCBiZSwgVyhyLCAxNikpLCBsKHRoaXMsIFRlLCBXKHIsIDY0KSk7Cn0sIHdlID0gbmV3IFdlYWtTZXQoKSwgUGUgPSBmdW5jdGlvbigpIHsKICBjb25zdCBlID0gdCh0aGlzLCBjZSk7CiAgImNsaWVudFdpZHRoIiBpbiBlICYmIGUuY2xpZW50V2lkdGggPiAwID8gKGwodGhpcywgUCwgKHR5cGVvZiB3aW5kb3cgPCAidSIgJiYgd2luZG93LmRldmljZVBpeGVsUmF0aW8gfHwgMSkgKiB0KHRoaXMsIENlKSksIGwodGhpcywgdywgZS53aWR0aCA9IE1hdGgucm91bmQoZS5jbGllbnRXaWR0aCAqIHQodGhpcywgUCkpKSwgbCh0aGlzLCBVLCBlLmhlaWdodCA9IE1hdGgucm91bmQoZS5jbGllbnRIZWlnaHQgKiB0KHRoaXMsIFApKSkpIDogKGwodGhpcywgdywgZS53aWR0aCksIGwodGhpcywgVSwgZS5oZWlnaHQpKSwgISh0KHRoaXMsIHcpID09PSAwIHx8IHQodGhpcywgVSkgPT09IDApICYmIChsKHRoaXMsIE0sIE1hdGgubWF4KDEsIE1hdGgucm91bmQodCh0aGlzLCB3KSAqIHQodGhpcywgZWUpKSkpLCBsKHRoaXMsIEksIE1hdGgubWF4KDEsIE1hdGgucm91bmQodCh0aGlzLCBVKSAqIHQodGhpcywgZWUpKSkpLCBTKHRoaXMsIEdlLCBzdCkuY2FsbCh0aGlzKSk7Cn0sIEdlID0gbmV3IFdlYWtTZXQoKSwgc3QgPSBmdW5jdGlvbigpIHsKICBpZiAoUyh0aGlzLCBNZSwgb3QpLmNhbGwodGhpcyksIHQodGhpcywgVikpIHsKICAgIGNvbnN0IHsgZGV2aWNlOiBlIH0gPSB0KHRoaXMsIFYpLCByID0gInJnYmExNmZsb2F0IiwgcyA9IHQodGhpcywgTSksIG8gPSB0KHRoaXMsIEkpOwogICAgbCh0aGlzLCBPLCBydChlLCByLCBzLCBvKSksIGwodGhpcywgVCwgcnQoZSwgciwgcywgbykpLCBsKHRoaXMsIFEsIHJ0KGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBvZSwgSGUoZSwgciwgcywgbykpLCBsKHRoaXMsIGFlLCBIZShlLCByLCBzLCBvKSk7CiAgfSBlbHNlIHsKICAgIGNvbnN0IGUgPSB0KHRoaXMsIEcpLCByID0gdCh0aGlzLCB6ZSksIHMgPSB0KHRoaXMsIE0pLCBvID0gdCh0aGlzLCBJKTsKICAgIGwodGhpcywgQiwgdHQoZSwgciwgcywgbykpLCBsKHRoaXMsIFIsIHR0KGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBxLCB0dChlLCByLCBzLCBvKSksIGwodGhpcywgJCwgcWUoZSwgciwgcywgbykpLCBsKHRoaXMsIEgsIHFlKGUsIHIsIHMsIG8pKTsKICB9Cn0sIG5lID0gbmV3IFdlYWtTZXQoKSwgRWUgPSBmdW5jdGlvbigpIHsKICBpZiAoISghdCh0aGlzLCBDKSB8fCB0KHRoaXMsIHcpID09PSAwIHx8IHQodGhpcywgVSkgPT09IDApKSB7CiAgICBpZiAoUyh0aGlzLCBJZSwgYXQpLmNhbGwodGhpcyksIHQodGhpcywgVikpIHsKICAgICAgY29uc3QgeyBkZXZpY2U6IGUgfSA9IHQodGhpcywgVik7CiAgICAgIHQodGhpcywgQykudHlwZSA9PT0gInRleHQiID8gbCh0aGlzLCB6LCBlcigKICAgICAgICBlLAogICAgICAgIHQodGhpcywgdyksCiAgICAgICAgdCh0aGlzLCBVKSwKICAgICAgICB0KHRoaXMsIEMpLm9wdHMsCiAgICAgICAgdCh0aGlzLCBBKSwKICAgICAgICB0KHRoaXMsIHVlKQogICAgICApKSA6IGwodGhpcywgeiwgdHIoCiAgICAgICAgZSwKICAgICAgICB0KHRoaXMsIEMpLmJpdG1hcCwKICAgICAgICB0KHRoaXMsIHcpLAogICAgICAgIHQodGhpcywgVSksCiAgICAgICAgdCh0aGlzLCBDKS5lZmZlY3QsCiAgICAgICAgdCh0aGlzLCBDKS5zaXplLAogICAgICAgIHQodGhpcywgQSksCiAgICAgICAgdCh0aGlzLCB1ZSkKICAgICAgKSk7CiAgICB9IGVsc2UgewogICAgICBjb25zdCBlID0gdCh0aGlzLCBHKTsKICAgICAgaWYgKHQodGhpcywgQykudHlwZSA9PT0gInRleHQiKSB7CiAgICAgICAgY29uc3QgeyBiYWNrZ3JvdW5kVGV4OiByLCBvYnN0YWNsZVRleDogcywgY292ZXJhZ2VUZXg6IG8gfSA9IEp0KAogICAgICAgICAgZSwKICAgICAgICAgIHQodGhpcywgdyksCiAgICAgICAgICB0KHRoaXMsIFUpLAogICAgICAgICAgdCh0aGlzLCBDKS5vcHRzLAogICAgICAgICAgdCh0aGlzLCBBKSwKICAgICAgICAgIHQodGhpcywgdWUpCiAgICAgICAgKTsKICAgICAgICBsKHRoaXMsIEssIHIpLCBsKHRoaXMsIEwsIHMpLCBsKHRoaXMsIFksIG8pOwogICAgICB9IGVsc2UgewogICAgICAgIGNvbnN0IHsgYmFja2dyb3VuZFRleDogciwgb2JzdGFjbGVUZXg6IHMsIGNvdmVyYWdlVGV4OiBvIH0gPSBadCgKICAgICAgICAgIGUsCiAgICAgICAgICB0KHRoaXMsIEMpLmJpdG1hcCwKICAgICAgICAgIHQodGhpcywgdyksCiAgICAgICAgICB0KHRoaXMsIFUpLAogICAgICAgICAgdCh0aGlzLCBDKS5lZmZlY3QsCiAgICAgICAgICB0KHRoaXMsIEMpLnNpemUsCiAgICAgICAgICB0KHRoaXMsIEEpLAogICAgICAgICAgdCh0aGlzLCB1ZSkKICAgICAgICApOwogICAgICAgIGwodGhpcywgSywgciksIGwodGhpcywgTCwgcyksIGwodGhpcywgWSwgbyk7CiAgICAgIH0KICAgIH0KICAgIGwodGhpcywgeWUsICEwKTsKICB9Cn0sIFJlID0gbmV3IFdlYWtTZXQoKSwgRmUgPSBmdW5jdGlvbigpIHsKICB0KHRoaXMsIHllKSAmJiAhdGhpcy5pc1J1bm5pbmcgJiYgdGhpcy5zdGFydCgpOwp9LCBNZSA9IG5ldyBXZWFrU2V0KCksIG90ID0gZnVuY3Rpb24oKSB7CiAgdmFyIGUsIHIsIHMsIG8sIGEsIHUsIHYsIG07CiAgaWYgKHQodGhpcywgVikpCiAgICAoZSA9IHQodGhpcywgTykpID09IG51bGwgfHwgZS5kaXNwb3NlKCksIChyID0gdCh0aGlzLCBUKSkgPT0gbnVsbCB8fCByLmRpc3Bvc2UoKSwgKHMgPSB0KHRoaXMsIFEpKSA9PSBudWxsIHx8IHMuZGlzcG9zZSgpLCAobyA9IHQodGhpcywgb2UpKSA9PSBudWxsIHx8IG8udGV4LmRlc3Ryb3koKSwgKGEgPSB0KHRoaXMsIGFlKSkgPT0gbnVsbCB8fCBhLnRleC5kZXN0cm95KCksIGwodGhpcywgTywgbCh0aGlzLCBULCBsKHRoaXMsIFEsIG51bGwpKSksIGwodGhpcywgb2UsIGwodGhpcywgYWUsIG51bGwpKTsKICBlbHNlIHsKICAgIGNvbnN0IGMgPSB0KHRoaXMsIEcpOwogICAgKHUgPSB0KHRoaXMsIEIpKSA9PSBudWxsIHx8IHUuZGlzcG9zZSgpLCAodiA9IHQodGhpcywgUikpID09IG51bGwgfHwgdi5kaXNwb3NlKCksIChtID0gdCh0aGlzLCBxKSkgPT0gbnVsbCB8fCBtLmRpc3Bvc2UoKSwgdCh0aGlzLCAkKSAmJiAoYy5kZWxldGVUZXh0dXJlKHQodGhpcywgJCkudGV4KSwgYy5kZWxldGVGcmFtZWJ1ZmZlcih0KHRoaXMsICQpLmZibykpLCB0KHRoaXMsIEgpICYmIChjLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBIKS50ZXgpLCBjLmRlbGV0ZUZyYW1lYnVmZmVyKHQodGhpcywgSCkuZmJvKSksIGwodGhpcywgQiwgbCh0aGlzLCBSLCBsKHRoaXMsIHEsIGwodGhpcywgJCwgbCh0aGlzLCBILCBudWxsKSkpKSk7CiAgfQp9LCBJZSA9IG5ldyBXZWFrU2V0KCksIGF0ID0gZnVuY3Rpb24oKSB7CiAgaWYgKHQodGhpcywgVikpCiAgICB0KHRoaXMsIHopICYmICh0KHRoaXMsIHopLmJhY2tncm91bmRUZXguZGVzdHJveSgpLCB0KHRoaXMsIHopLm9ic3RhY2xlVGV4LmRlc3Ryb3koKSwgdCh0aGlzLCB6KS5zaGFyZWRDb3ZlcmFnZSB8fCB0KHRoaXMsIHopLmNvdmVyYWdlVGV4LmRlc3Ryb3koKSwgbCh0aGlzLCB6LCBudWxsKSk7CiAgZWxzZSB7CiAgICBjb25zdCBlID0gdCh0aGlzLCBHKTsKICAgIHQodGhpcywgSykgJiYgZS5kZWxldGVUZXh0dXJlKHQodGhpcywgSykpLCB0KHRoaXMsIEwpICYmIGUuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIEwpKSwgdCh0aGlzLCBZKSAmJiB0KHRoaXMsIFkpICE9PSB0KHRoaXMsIEwpICYmIGUuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIFkpKSwgbCh0aGlzLCBLLCBsKHRoaXMsIEwsIGwodGhpcywgWSwgbnVsbCkpKTsKICB9Cn0sIFFlID0gbmV3IFdlYWtTZXQoKSwgcHQgPSBmdW5jdGlvbigpIHsKICAhdCh0aGlzLCB5ZSkgfHwgdCh0aGlzLCB3KSA9PT0gMCB8fCAodCh0aGlzLCBWKSA/IFModGhpcywgamUsIG10KS5jYWxsKHRoaXMpIDogUyh0aGlzLCBaZSwgZ3QpLmNhbGwodGhpcykpOwp9LCBqZSA9IG5ldyBXZWFrU2V0KCksIG10ID0gZnVuY3Rpb24oKSB7CiAgY29uc3QgZSA9IHQodGhpcywgViksIHIgPSBlLmRldmljZSwgcyA9IHQodGhpcywgRGUpLCBvID0gdCh0aGlzLCB2ZSksIGEgPSB0KHRoaXMsIF9lKSwgdSA9IHQodGhpcywgdGUpLCB2ID0gdCh0aGlzLCB6KTsKICBpZiAoIXQodGhpcywgTykgfHwgIXQodGhpcywgVCkpCiAgICByZXR1cm47CiAgdCh0aGlzLCBoKS54ICs9ICh0KHRoaXMsIGgpLnRhcmdldFggLSB0KHRoaXMsIGgpLngpICogMC4xNSwgdCh0aGlzLCBoKS55ICs9ICh0KHRoaXMsIGgpLnRhcmdldFkgLSB0KHRoaXMsIGgpLnkpICogMC4xNTsKICBjb25zdCBtID0gdCh0aGlzLCBNKSwgYyA9IHQodGhpcywgSSksIHAgPSB0KHRoaXMsIHcpLCB4ID0gdCh0aGlzLCBVKSwgbiA9IDEgLyBtLCBkID0gMSAvIGM7CiAgbHQociwgdCh0aGlzLCB4ZSksIG4sIGQsIFZlLCB1LnZlbG9jaXR5RGlzc2lwYXRpb24pLCBOZShyLCB0KHRoaXMsIG1lKSwgbiwgZCksIE5lKHIsIHQodGhpcywgZGUpLCBuLCBkKSwgTmUociwgdCh0aGlzLCBoZSksIG4sIGQpLCBOZShyLCB0KHRoaXMsIGdlKSwgbiwgZCksIFF0KHIsIHQodGhpcywgYmUpLCBuLCBkLCB1LmN1cmwsIFZlKSwganQoCiAgICByLAogICAgdCh0aGlzLCBUZSksCiAgICAxIC8gcCwKICAgIDEgLyB4LAogICAgdS5yZWZyYWN0aW9uLAogICAgdS5zcGVjdWxhckV4cCwKICAgIFdlKHUud2F0ZXJDb2xvciksCiAgICBXZSh1Lmdsb3dDb2xvciksCiAgICB1LnNoaW5lLAogICAgdS53YXJwU3RyZW5ndGggPz8gMC4wMTUsCiAgICBmdFt1LmFsZ29yaXRobV0gPz8gMCwKICAgIHQodGhpcywgU2UpCiAgKTsKICBjb25zdCBiID0gci5jcmVhdGVDb21tYW5kRW5jb2RlcigpLCB5ID0gKGcsIF8pID0+IHIuY3JlYXRlQmluZEdyb3VwKHsgbGF5b3V0OiBnLmdldEJpbmRHcm91cExheW91dCgwKSwgZW50cmllczogXyB9KSwgRCA9IHsgYmluZGluZzogMSwgcmVzb3VyY2U6IGEgfTsKICB7CiAgICBjb25zdCBnID0geShzLmFkdmVjdGlvbiwgWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCB4ZSkgfSB9LAogICAgICBELAogICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIFQpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDMsIHJlc291cmNlOiB0KHRoaXMsIFQpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDQsIHJlc291cmNlOiB2Lm9ic3RhY2xlVmlldyB9CiAgICBdKTsKICAgIFgoYiwgcy5hZHZlY3Rpb24sIGcsIG8sIHQodGhpcywgVCkud3JpdGUudmlldyk7CiAgfQogIHQodGhpcywgVCkuc3dhcCgpOwogIHsKICAgIGx0KHIsIHQodGhpcywgcGUpLCBuLCBkLCBWZSwgdS5kZW5zaXR5RGlzc2lwYXRpb24pOwogICAgY29uc3QgZyA9IHkocy5hZHZlY3Rpb24sIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgcGUpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiAzLCByZXNvdXJjZTogdCh0aGlzLCBPKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA0LCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuYWR2ZWN0aW9uLCBnLCBvLCB0KHRoaXMsIE8pLndyaXRlLnZpZXcpOwogIH0KICB0KHRoaXMsIE8pLnN3YXAoKTsKICB7CiAgICBjb25zdCBnID0geShzLmN1cmwsIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgZ2UpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuY3VybCwgZywgbywgdCh0aGlzLCBhZSkudmlldyk7CiAgfQogIHsKICAgIGNvbnN0IGcgPSB5KHMudm9ydGljaXR5LCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIGJlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHQodGhpcywgYWUpLnZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMudm9ydGljaXR5LCBnLCBvLCB0KHRoaXMsIFQpLndyaXRlLnZpZXcpOwogIH0KICBpZiAodCh0aGlzLCBUKS5zd2FwKCksIHQodGhpcywgaCkubW92ZWQpIHsKICAgIGNvbnN0IGcgPSB0KHRoaXMsIGgpLnggKiB0KHRoaXMsIFApIC8gcCwgXyA9IHQodGhpcywgaCkueSAqIHQodGhpcywgUCkgLyB4OwogICAgJGUoCiAgICAgIHIsCiAgICAgIHQodGhpcywgSiksCiAgICAgIG4sCiAgICAgIGQsCiAgICAgIHAgLyB4LAogICAgICB1LnNwbGF0UmFkaXVzLAogICAgICB0KHRoaXMsIGgpLmR4ICogdS5zcGxhdEZvcmNlLAogICAgICB0KHRoaXMsIGgpLmR5ICogdS5zcGxhdEZvcmNlLAogICAgICAwLAogICAgICBnLAogICAgICBfCiAgICApOwogICAgewogICAgICBjb25zdCBGID0geShzLnNwbGF0LCBbCiAgICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgSikgfSB9LAogICAgICAgIEQsCiAgICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgICBdKTsKICAgICAgWChiLCBzLnNwbGF0LCBGLCBvLCB0KHRoaXMsIFQpLndyaXRlLnZpZXcpOwogICAgfQogICAgdCh0aGlzLCBUKS5zd2FwKCksICRlKAogICAgICByLAogICAgICB0KHRoaXMsIFopLAogICAgICBuLAogICAgICBkLAogICAgICBwIC8geCwKICAgICAgdS5zcGxhdFJhZGl1cywKICAgICAgMSwKICAgICAgMSwKICAgICAgMSwKICAgICAgZywKICAgICAgXwogICAgKTsKICAgIHsKICAgICAgY29uc3QgRiA9IHkocy5zcGxhdCwgWwogICAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIFopIH0gfSwKICAgICAgICBELAogICAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgTykucmVhZC52aWV3IH0KICAgICAgXSk7CiAgICAgIFgoYiwgcy5zcGxhdCwgRiwgbywgdCh0aGlzLCBPKS53cml0ZS52aWV3KTsKICAgIH0KICAgIHQodGhpcywgTykuc3dhcCgpLCB0KHRoaXMsIGgpLm1vdmVkID0gITE7CiAgfQogIHsKICAgIGNvbnN0IGcgPSB5KHMuZGl2ZXJnZW5jZSwgWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBtZSkgfSB9LAogICAgICBELAogICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIFQpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDMsIHJlc291cmNlOiB2Lm9ic3RhY2xlVmlldyB9CiAgICBdKTsKICAgIFgoYiwgcy5kaXZlcmdlbmNlLCBnLCBvLCB0KHRoaXMsIG9lKS52aWV3KTsKICB9CiAgZm9yIChsZXQgZyA9IDA7IGcgPCB1LnByZXNzdXJlSXRlcmF0aW9uczsgZysrKSB7CiAgICBjb25zdCBfID0geShzLnByZXNzdXJlLCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIGRlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgUSkucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHQodGhpcywgb2UpLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA0LCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMucHJlc3N1cmUsIF8sIG8sIHQodGhpcywgUSkud3JpdGUudmlldyksIHQodGhpcywgUSkuc3dhcCgpOwogIH0KICB7CiAgICBjb25zdCBnID0geShzLmdyYWRpZW50U3VidHJhY3QsIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgaGUpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBRKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiAzLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA0LCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuZ3JhZGllbnRTdWJ0cmFjdCwgZywgbywgdCh0aGlzLCBUKS53cml0ZS52aWV3KTsKICB9CiAgdCh0aGlzLCBUKS5zd2FwKCk7CiAgewogICAgY29uc3QgZyA9IGUuY29udGV4dC5nZXRDdXJyZW50VGV4dHVyZSgpLmNyZWF0ZVZpZXcoKSwgXyA9IHkocy5kaXNwbGF5LCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIFRlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgTykucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHYub2JzdGFjbGVWaWV3IH0sCiAgICAgIHsgYmluZGluZzogNCwgcmVzb3VyY2U6IHYuYmFja2dyb3VuZFZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA1LCByZXNvdXJjZTogdi5jb3ZlcmFnZVZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA2LCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBLdChiLCBzLmRpc3BsYXksIF8sIG8sIGcpOwogIH0KICByLnF1ZXVlLnN1Ym1pdChbYi5maW5pc2goKV0pOwp9LCBLZSA9IG5ldyBXZWFrU2V0KCksIGR0ID0gZnVuY3Rpb24oZSwgciwgcywgbywgYSkgewogIGNvbnN0IHYgPSB0KHRoaXMsIFYpLmRldmljZSwgbSA9IHQodGhpcywgRGUpLnNwbGF0LCBjID0gdCh0aGlzLCB2ZSksIHAgPSB0KHRoaXMsIF9lKSwgeCA9IHQodGhpcywgdGUpLCBuID0gdCh0aGlzLCBNKSwgZCA9IHQodGhpcywgSSksIGIgPSAxIC8gbiwgeSA9IDEgLyBkLCBEID0gdi5jcmVhdGVDb21tYW5kRW5jb2RlcigpLCBnID0geyBiaW5kaW5nOiAxLCByZXNvdXJjZTogcCB9LCBfID0gKE9lKSA9PiB2LmNyZWF0ZUJpbmRHcm91cCh7IGxheW91dDogbS5nZXRCaW5kR3JvdXBMYXlvdXQoMCksIGVudHJpZXM6IE9lIH0pLCBGID0gZSAqIHQodGhpcywgUCkgLyB0KHRoaXMsIHcpLCBrID0gciAqIHQodGhpcywgUCkgLyB0KHRoaXMsIFUpOwogICRlKAogICAgdiwKICAgIHQodGhpcywgSiksCiAgICBiLAogICAgeSwKICAgIHQodGhpcywgdykgLyB0KHRoaXMsIFUpLAogICAgeC5zcGxhdFJhZGl1cywKICAgIHMgKiB4LnNwbGF0Rm9yY2UgKiBhLAogICAgbyAqIHguc3BsYXRGb3JjZSAqIGEsCiAgICAwLAogICAgRiwKICAgIGsKICApOwogIHsKICAgIGNvbnN0IE9lID0gXyhbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIEopIH0gfSwKICAgICAgZywKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBYKEQsIG0sIE9lLCBjLCB0KHRoaXMsIFQpLndyaXRlLnZpZXcpOwogIH0KICB0KHRoaXMsIFQpLnN3YXAoKSwgJGUoCiAgICB2LAogICAgdCh0aGlzLCBaKSwKICAgIGIsCiAgICB5LAogICAgdCh0aGlzLCB3KSAvIHQodGhpcywgVSksCiAgICB4LnNwbGF0UmFkaXVzLAogICAgYSwKICAgIGEsCiAgICBhLAogICAgRiwKICAgIGsKICApOwogIHsKICAgIGNvbnN0IE9lID0gXyhbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIFopIH0gfSwKICAgICAgZywKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBPKS5yZWFkLnZpZXcgfQogICAgXSk7CiAgICBYKEQsIG0sIE9lLCBjLCB0KHRoaXMsIE8pLndyaXRlLnZpZXcpOwogIH0KICB0KHRoaXMsIE8pLnN3YXAoKSwgdi5xdWV1ZS5zdWJtaXQoW0QuZmluaXNoKCldKTsKfSwgSmUgPSBuZXcgV2Vha1NldCgpLCBodCA9IGZ1bmN0aW9uKGUsIHIsIHMsIG8sIGEpIHsKICBjb25zdCB1ID0gdCh0aGlzLCBHKSwgdiA9IHQodGhpcywgdGUpLCBtID0gdCh0aGlzLCBmZSkuc3BsYXQsIGMgPSB0KHRoaXMsIFVlKTsKICB1LnZpZXdwb3J0KDAsIDAsIHQodGhpcywgTSksIHQodGhpcywgSSkpLCBtLmJpbmQoKSwgdS51bmlmb3JtMWYobS51bmlmb3Jtcy5hc3BlY3RSYXRpbywgdCh0aGlzLCB3KSAvIHQodGhpcywgVSkpLCB1LnVuaWZvcm0yZihtLnVuaWZvcm1zLnBvaW50LCBlICogdCh0aGlzLCBQKSAvIHQodGhpcywgdyksIDEgLSByICogdCh0aGlzLCBQKSAvIHQodGhpcywgVSkpLCB1LnVuaWZvcm0xZihtLnVuaWZvcm1zLnJhZGl1cywgdi5zcGxhdFJhZGl1cyksIHUudW5pZm9ybTFpKG0udW5pZm9ybXMudVRhcmdldCwgMCksIHUuYWN0aXZlVGV4dHVyZSh1LlRFWFRVUkUwKSwgdS5iaW5kVGV4dHVyZSh1LlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCB1LnVuaWZvcm0zZihtLnVuaWZvcm1zLmNvbG9yLCBzICogdi5zcGxhdEZvcmNlICogYSwgLW8gKiB2LnNwbGF0Rm9yY2UgKiBhLCAwKSwgYyh0KHRoaXMsIFIpLndyaXRlLmZibyksIHQodGhpcywgUikuc3dhcCgpLCB1LmFjdGl2ZVRleHR1cmUodS5URVhUVVJFMCksIHUuYmluZFRleHR1cmUodS5URVhUVVJFXzJELCB0KHRoaXMsIEIpLnJlYWQudGV4KSwgdS51bmlmb3JtM2YobS51bmlmb3Jtcy5jb2xvciwgYSwgYSwgYSksIGModCh0aGlzLCBCKS53cml0ZS5mYm8pLCB0KHRoaXMsIEIpLnN3YXAoKTsKfSwgWmUgPSBuZXcgV2Vha1NldCgpLCBndCA9IGZ1bmN0aW9uKCkgewogIGlmICghdCh0aGlzLCBCKSB8fCAhdCh0aGlzLCBSKSkKICAgIHJldHVybjsKICBjb25zdCBlID0gdCh0aGlzLCBHKSwgciA9IHQodGhpcywgdGUpLCB7IGFkdmVjdGlvbjogcywgZGl2ZXJnZW5jZTogbywgcHJlc3N1cmU6IGEsIGdyYWRpZW50U3VidHJhY3Q6IHUsIHNwbGF0OiB2LCBjdXJsOiBtLCB2b3J0aWNpdHk6IGMsIGRpc3BsYXk6IHAgfSA9IHQodGhpcywgZmUpOwogIHQodGhpcywgaCkueCArPSAodCh0aGlzLCBoKS50YXJnZXRYIC0gdCh0aGlzLCBoKS54KSAqIDAuMTUsIHQodGhpcywgaCkueSArPSAodCh0aGlzLCBoKS50YXJnZXRZIC0gdCh0aGlzLCBoKS55KSAqIDAuMTU7CiAgY29uc3QgeCA9IHQodGhpcywgTSksIG4gPSB0KHRoaXMsIEkpLCBkID0gdCh0aGlzLCBVZSk7CiAgZS52aWV3cG9ydCgwLCAwLCB4LCBuKSwgcy5iaW5kKCksIGUudW5pZm9ybTJmKHMudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geCwgMSAvIG4pLCBlLnVuaWZvcm0xZihzLnVuaWZvcm1zLmR0LCBWZSksIGUudW5pZm9ybTFpKHMudW5pZm9ybXMudU9ic3RhY2xlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBMKSksIGUudW5pZm9ybTFmKHMudW5pZm9ybXMuZGlzc2lwYXRpb24sIHIudmVsb2NpdHlEaXNzaXBhdGlvbiksIGUudW5pZm9ybTFpKHMudW5pZm9ybXMudVZlbG9jaXR5LCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBSKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKHMudW5pZm9ybXMudVNvdXJjZSwgMSksIGQodCh0aGlzLCBSKS53cml0ZS5mYm8pLCB0KHRoaXMsIFIpLnN3YXAoKSwgZS51bmlmb3JtMWYocy51bmlmb3Jtcy5kaXNzaXBhdGlvbiwgci5kZW5zaXR5RGlzc2lwYXRpb24pLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVTb3VyY2UsIDIpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEIpLnJlYWQudGV4KSwgZCh0KHRoaXMsIEIpLndyaXRlLmZibyksIHQodGhpcywgQikuc3dhcCgpLCBtLmJpbmQoKSwgZS51bmlmb3JtMmYobS51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB4LCAxIC8gbiksIGUudW5pZm9ybTFpKG0udW5pZm9ybXMudVZlbG9jaXR5LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBSKS5yZWFkLnRleCksIGQodCh0aGlzLCBIKS5mYm8pLCBjLmJpbmQoKSwgZS51bmlmb3JtMmYoYy51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB4LCAxIC8gbiksIGUudW5pZm9ybTFmKGMudW5pZm9ybXMuY3VybCwgci5jdXJsKSwgZS51bmlmb3JtMWYoYy51bmlmb3Jtcy5kdCwgVmUpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVWZWxvY2l0eSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVDdXJsLCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBIKS50ZXgpLCBkKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIHQodGhpcywgaCkubW92ZWQgJiYgKHYuYmluZCgpLCBlLnVuaWZvcm0xZih2LnVuaWZvcm1zLmFzcGVjdFJhdGlvLCB0KHRoaXMsIHcpIC8gdCh0aGlzLCBVKSksIGUudW5pZm9ybTJmKHYudW5pZm9ybXMucG9pbnQsIHQodGhpcywgaCkueCAqIHQodGhpcywgUCkgLyB0KHRoaXMsIHcpLCAxIC0gdCh0aGlzLCBoKS55ICogdCh0aGlzLCBQKSAvIHQodGhpcywgVSkpLCBlLnVuaWZvcm0xZih2LnVuaWZvcm1zLnJhZGl1cywgci5zcGxhdFJhZGl1cyksIGUudW5pZm9ybTFpKHYudW5pZm9ybXMudVRhcmdldCwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBlLnVuaWZvcm0zZih2LnVuaWZvcm1zLmNvbG9yLCB0KHRoaXMsIGgpLmR4ICogci5zcGxhdEZvcmNlLCAtdCh0aGlzLCBoKS5keSAqIHIuc3BsYXRGb3JjZSwgMCksIGQodCh0aGlzLCBSKS53cml0ZS5mYm8pLCB0KHRoaXMsIFIpLnN3YXAoKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBCKS5yZWFkLnRleCksIGUudW5pZm9ybTNmKHYudW5pZm9ybXMuY29sb3IsIDEsIDEsIDEpLCBkKHQodGhpcywgQikud3JpdGUuZmJvKSwgdCh0aGlzLCBCKS5zd2FwKCksIHQodGhpcywgaCkubW92ZWQgPSAhMSksIG8uYmluZCgpLCBlLnVuaWZvcm0yZihvLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHgsIDEgLyBuKSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51VmVsb2NpdHksIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkoby51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKSwgZCh0KHRoaXMsICQpLmZibyksIGEuYmluZCgpLCBlLnVuaWZvcm0yZihhLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHgsIDEgLyBuKSwgZS51bmlmb3JtMWkoYS51bmlmb3Jtcy51RGl2ZXJnZW5jZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgJCkudGV4KSwgZS51bmlmb3JtMWkoYS51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKTsKICBmb3IgKGxldCBiID0gMDsgYiA8IHIucHJlc3N1cmVJdGVyYXRpb25zOyBiKyspCiAgICBlLnVuaWZvcm0xaShhLnVuaWZvcm1zLnVQcmVzc3VyZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgcSkucmVhZC50ZXgpLCBkKHQodGhpcywgcSkud3JpdGUuZmJvKSwgdCh0aGlzLCBxKS5zd2FwKCk7CiAgdS5iaW5kKCksIGUudW5pZm9ybTJmKHUudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geCwgMSAvIG4pLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVQcmVzc3VyZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgcSkucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVWZWxvY2l0eSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVPYnN0YWNsZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgTCkpLCBkKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIGUudmlld3BvcnQoMCwgMCwgdCh0aGlzLCB3KSwgdCh0aGlzLCBVKSksIGUuYmluZEZyYW1lYnVmZmVyKGUuRlJBTUVCVUZGRVIsIG51bGwpLCBlLmNsZWFyKGUuQ09MT1JfQlVGRkVSX0JJVCksIHAuYmluZCgpLCBlLnVuaWZvcm0yZihwLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHQodGhpcywgdyksIDEgLyB0KHRoaXMsIFUpKSwgZS51bmlmb3JtM2Z2KHAudW5pZm9ybXMudVdhdGVyQ29sb3IsIFdlKHIud2F0ZXJDb2xvcikpLCBlLnVuaWZvcm0zZnYocC51bmlmb3Jtcy51R2xvd0NvbG9yLCBXZShyLmdsb3dDb2xvcikpLCBlLnVuaWZvcm0xZihwLnVuaWZvcm1zLnVSZWZyYWN0aW9uLCByLnJlZnJhY3Rpb24pLCBlLnVuaWZvcm0xZihwLnVuaWZvcm1zLnVTcGVjdWxhckV4cCwgci5zcGVjdWxhckV4cCksIGUudW5pZm9ybTFmKHAudW5pZm9ybXMudVNoaW5lLCByLnNoaW5lKSwgZS51bmlmb3JtMWYocC51bmlmb3Jtcy51V2FycFN0cmVuZ3RoLCByLndhcnBTdHJlbmd0aCA/PyAwLjAxNSksIGUudW5pZm9ybTFpKHAudW5pZm9ybXMudUFsZ29yaXRobSwgZnRbci5hbGdvcml0aG1dID8/IDApLCBlLnVuaWZvcm0xaShwLnVuaWZvcm1zLnVFbmFibGVBbHBoYSwgdCh0aGlzLCBTZSkgPyAxIDogMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgQikucmVhZC50ZXgpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTIpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBLKSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUzKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgWSkpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFNCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkocC51bmlmb3Jtcy51VGV4dHVyZSwgMCksIGUudW5pZm9ybTFpKHAudW5pZm9ybXMudU9ic3RhY2xlLCAxKSwgZS51bmlmb3JtMWkocC51bmlmb3Jtcy51QmFja2dyb3VuZCwgMiksIGUudW5pZm9ybTFpKHAudW5pZm9ybXMudUNvdmVyYWdlLCAzKSwgZS51bmlmb3JtMWkocC51bmlmb3Jtcy51VmVsb2NpdHksIDQpLCBkKG51bGwpOwp9OwpsZXQgaXQgPSB1dCwgRSA9IG51bGwsIGJ0Owpjb25zdCBOID0gbmV3IFByb21pc2UoKGkpID0+IHsKICBidCA9IGk7Cn0pOwpzZWxmLm9ubWVzc2FnZSA9IGFzeW5jIChpKSA9PiB7CiAgY29uc3QgeyB0eXBlOiBlLCAuLi5yIH0gPSBpLmRhdGE7CiAgdHJ5IHsKICAgIHN3aXRjaCAoZSkgewogICAgICBjYXNlICJpbml0IjogewogICAgICAgIGNvbnN0IHsgY2FudmFzOiBzLCB3aWR0aDogbywgaGVpZ2h0OiBhLCBjb25maWc6IHUsIGRwcjogdiwgcXVhbGl0eTogbSwgdXNlV2ViR1BVOiBjLCBlbmFibGVBbHBoYTogcCB9ID0gcjsKICAgICAgICBzLndpZHRoID0gbywgcy5oZWlnaHQgPSBhLCBFID0gYXdhaXQgaXQuY3JlYXRlKHMsIHUsIG0gPz8ge30sIGMgPz8gITAsIHAgPz8gITApLCBFLnJlc2l6ZShvLCBhLCB2IHx8IDEpLCBidCgpLCBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogInJlYWR5IiB9KTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRUZXh0U291cmNlIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnNldFRleHRTb3VyY2Uoci5vcHRzKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRJbWFnZVNvdXJjZSI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgYXdhaXQgRS5zZXRJbWFnZVNvdXJjZSgKICAgICAgICAgIHIuc3JjLAogICAgICAgICAgci5lZmZlY3QsCiAgICAgICAgICByLnNpemUKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNldEltYWdlQml0bWFwIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnNldEltYWdlQml0bWFwKAogICAgICAgICAgci5iaXRtYXAsCiAgICAgICAgICByLmVmZmVjdCwKICAgICAgICAgIHIuc2l6ZQogICAgICAgICk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0QmFja2dyb3VuZCI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS5zZXRCYWNrZ3JvdW5kKHIuYml0bWFwLCByLnNpemUpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNwbGF0IjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnNwbGF0KAogICAgICAgICAgci54LAogICAgICAgICAgci55LAogICAgICAgICAgci52eCwKICAgICAgICAgIHIudnksCiAgICAgICAgICByLnN0cmVuZ3RoID8/IDEKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgIm1vdmUiOiB7CiAgICAgICAgaWYgKGF3YWl0IE4sICFFKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIEUuaGFuZGxlTW92ZShyLngsIHIueSwgci5zdHJlbmd0aCA/PyAxKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJyZXNpemUiOiB7CiAgICAgICAgaWYgKGF3YWl0IE4sICFFKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIEUucmVzaXplKHIud2lkdGgsIHIuaGVpZ2h0LCByLmRwcik7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlUXVhbGl0eSI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS51cGRhdGVRdWFsaXR5KHIucXVhbGl0eSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAidXBkYXRlQ29uZmlnIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnVwZGF0ZUNvbmZpZyhyLmNvbmZpZyk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAiZGVzdHJveSI6IHsKICAgICAgICBhd2FpdCBOLCBFID09IG51bGwgfHwgRS5kZXN0cm95KCksIEUgPSBudWxsOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGRlZmF1bHQ6CiAgICAgICAgY29uc29sZS53YXJuKCJbZmx1aWRpdHktanMgd29ya2VyXSBVbmtub3duIG1lc3NhZ2UgdHlwZToiLCBlKTsKICAgIH0KICB9IGNhdGNoIChzKSB7CiAgICBzZWxmLnBvc3RNZXNzYWdlKHsgdHlwZTogImVycm9yIiwgbWVzc2FnZTogKHMgPT0gbnVsbCA/IHZvaWQgMCA6IHMubWVzc2FnZSkgPz8gU3RyaW5nKHMpIH0pOwogIH0KfTsK", MI = typeof window < "u" && window.Blob && new Blob([atob(jI)], { type: "text/javascript;charset=utf-8" });
1590
- function UC() {
1608
+ let yI = NI;
1609
+ const cC = "dmFyIFR0ID0gT2JqZWN0LmRlZmluZVByb3BlcnR5Owp2YXIgeXQgPSAoaSwgZSwgcikgPT4gZSBpbiBpID8gVHQoaSwgZSwgeyBlbnVtZXJhYmxlOiAhMCwgY29uZmlndXJhYmxlOiAhMCwgd3JpdGFibGU6ICEwLCB2YWx1ZTogciB9KSA6IGlbZV0gPSByOwp2YXIga2UgPSAoaSwgZSwgcikgPT4gKHl0KGksIHR5cGVvZiBlICE9ICJzeW1ib2wiID8gZSArICIiIDogZSwgciksIHIpLCBldCA9IChpLCBlLCByKSA9PiB7CiAgaWYgKCFlLmhhcyhpKSkKICAgIHRocm93IFR5cGVFcnJvcigiQ2Fubm90ICIgKyByKTsKfTsKdmFyIHQgPSAoaSwgZSwgcikgPT4gKGV0KGksIGUsICJyZWFkIGZyb20gcHJpdmF0ZSBmaWVsZCIpLCByID8gci5jYWxsKGkpIDogZS5nZXQoaSkpLCBmID0gKGksIGUsIHIpID0+IHsKICBpZiAoZS5oYXMoaSkpCiAgICB0aHJvdyBUeXBlRXJyb3IoIkNhbm5vdCBhZGQgdGhlIHNhbWUgcHJpdmF0ZSBtZW1iZXIgbW9yZSB0aGFuIG9uY2UiKTsKICBlIGluc3RhbmNlb2YgV2Vha1NldCA/IGUuYWRkKGkpIDogZS5zZXQoaSwgcik7Cn0sIGwgPSAoaSwgZSwgciwgcykgPT4gKGV0KGksIGUsICJ3cml0ZSB0byBwcml2YXRlIGZpZWxkIiksIHMgPyBzLmNhbGwoaSwgcikgOiBlLnNldChpLCByKSwgcik7CnZhciBTID0gKGksIGUsIHIpID0+IChldChpLCBlLCAiYWNjZXNzIHByaXZhdGUgbWV0aG9kIiksIHIpOwpjb25zdCB2dCA9IHsKICBkZW5zaXR5RGlzc2lwYXRpb246IDAuODMsCiAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC45MSwKICBwcmVzc3VyZUl0ZXJhdGlvbnM6IDEsCiAgY3VybDogMCwKICBzcGxhdFJhZGl1czogMC4xLAogIHNwbGF0Rm9yY2U6IDAuMDgsCiAgcmVmcmFjdGlvbjogMSwKICBzcGVjdWxhckV4cDogMCwKICBzaGluZTogMCwKICB3YXRlckNvbG9yOiAiIzAwMDAwMCIsCiAgZ2xvd0NvbG9yOiAiI2IzZDlmZiIsCiAgYWxnb3JpdGhtOiAiYXVyb3JhIiwKICB3YXJwU3RyZW5ndGg6IDAuMDQKfTsKKHsKICAuLi52dAp9KTsKY29uc3QgU3QgPSB7CiAgY2FsbTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk4LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC44MSwKICAgIGN1cmw6IDFlLTQsCiAgICBzcGxhdFJhZGl1czogMC4wNSwKICAgIHNwbGF0Rm9yY2U6IDAuMDgsCiAgICByZWZyYWN0aW9uOiAwLjE1LAogICAgc2hpbmU6IDAuMDMsCiAgICBnbG93Q29sb3I6ICIjOTlkOWZmIiwKICAgIHdhdGVyQ29sb3I6ICIjMDAwNTBkIgogIH0sCiAgc2FuZDogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk1LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC44MSwKICAgIGN1cmw6IDEsCiAgICBzcGxhdFJhZGl1czogMC4yMywKICAgIHNwbGF0Rm9yY2U6IDAuMTYsCiAgICByZWZyYWN0aW9uOiAwLjgsCiAgICBzcGVjdWxhckV4cDogMCwKICAgIHNoaW5lOiAwLjMzLAogICAgZ2xvd0NvbG9yOiAiIzA3MDcwNyIsCiAgICB3YXRlckNvbG9yOiAiIzczNTQyMCIKICB9LAogIHdhdmU6IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45LAogICAgdmVsb2NpdHlEaXNzaXBhdGlvbjogMC4yLAogICAgY3VybDogMC4yLAogICAgc3BsYXRSYWRpdXM6IDAuMSwKICAgIHNwbGF0Rm9yY2U6IDAuMjIsCiAgICByZWZyYWN0aW9uOiAwLjM1LAogICAgc2hpbmU6IDAuMiwKICAgIGdsb3dDb2xvcjogIiM4MGNjZmYiLAogICAgd2F0ZXJDb2xvcjogIiMwMDAzMDgiCiAgfSwKICBuZW9uOiB7CiAgICBkZW5zaXR5RGlzc2lwYXRpb246IDAuNzUsCiAgICB2ZWxvY2l0eURpc3NpcGF0aW9uOiAwLjMsCiAgICBjdXJsOiAwLjA1LAogICAgc3BsYXRSYWRpdXM6IDAuMTgsCiAgICBzcGxhdEZvcmNlOiAwLjI5LAogICAgcmVmcmFjdGlvbjogMC4yNSwKICAgIHNwZWN1bGFyRXhwOiAwLjA0LAogICAgc2hpbmU6IDAuOTMsCiAgICBnbG93Q29sb3I6ICIjZmYzM2NjIiwKICAgIHdhdGVyQ29sb3I6ICIjMGQwMDE0IgogIH0sCiAgc21va2U6IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45MywKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuNzEsCiAgICBjdXJsOiAwLjA0LAogICAgc3BsYXRSYWRpdXM6IDAuMjEsCiAgICBzcGxhdEZvcmNlOiAwLjE0LAogICAgcmVmcmFjdGlvbjogMC4wOCwKICAgIHNoaW5lOiAwLAogICAgZ2xvd0NvbG9yOiAiIzgwODA4MCIsCiAgICB3YXRlckNvbG9yOiAiIzBmMGYwZiIKICB9Cn07CmZ1bmN0aW9uIFdlKGkpIHsKICBpZiAoQXJyYXkuaXNBcnJheShpKSkKICAgIHJldHVybiBpOwogIGNvbnN0IGUgPSBpLnNsaWNlKDEsIDcpOwogIHJldHVybiBlLmxlbmd0aCA9PT0gMyA/IFsKICAgIHBhcnNlSW50KGVbMF0gKyBlWzBdLCAxNikgLyAyNTUsCiAgICBwYXJzZUludChlWzFdICsgZVsxXSwgMTYpIC8gMjU1LAogICAgcGFyc2VJbnQoZVsyXSArIGVbMl0sIDE2KSAvIDI1NQogIF0gOiBbCiAgICBwYXJzZUludChlLnNsaWNlKDAsIDIpLCAxNikgLyAyNTUsCiAgICBwYXJzZUludChlLnNsaWNlKDIsIDQpLCAxNikgLyAyNTUsCiAgICBwYXJzZUludChlLnNsaWNlKDQsIDYpLCAxNikgLyAyNTUKICBdOwp9CmZ1bmN0aW9uIHd0KGkgPSB7fSwgZSwgciA9IHZ0KSB7CiAgcmV0dXJuIHsgLi4uZSA/IHsgLi4uciwgLi4uU3RbZV0gfSA6IHIsIC4uLmkgfTsKfQpjb25zdCByZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICBhdHRyaWJ1dGUgdmVjMiBhUG9zaXRpb247CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSB2ZWMyIHRleGVsU2l6ZTsKICB2b2lkIG1haW4gKCkgewogICAgdlV2ID0gYVBvc2l0aW9uICogMC41ICsgMC41OwogICAgdkwgPSB2VXYgLSB2ZWMyKHRleGVsU2l6ZS54LCAwLjApOwogICAgdlIgPSB2VXYgKyB2ZWMyKHRleGVsU2l6ZS54LCAwLjApOwogICAgdlQgPSB2VXYgKyB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkpOwogICAgdkIgPSB2VXYgLSB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkpOwogICAgZ2xfUG9zaXRpb24gPSB2ZWM0KGFQb3NpdGlvbiwgMC4wLCAxLjApOwogIH0KYAopLCBSdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1U291cmNlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB1bmlmb3JtIHZlYzIgdGV4ZWxTaXplOwogIHVuaWZvcm0gZmxvYXQgZHQ7CiAgdW5pZm9ybSBmbG9hdCBkaXNzaXBhdGlvbjsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgb2JzICA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZVdikucjsKICAgIHZlYzIgY29vcmQgPSB2VXYgLSBkdCAqIHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHkgKiB0ZXhlbFNpemU7CiAgICAvLyBTbW9vdGggZGFtcGluZzogb2JzPTAgb3V0c2lkZSAoZnVsbCBmbG93KSwgb2JzPTEgaW5zaWRlIChmdWxsIHN0b3ApLCBibHVycmVkCiAgICAvLyBib3VuZGFyeSBpbiBiZXR3ZWVuLiAgTm8gYnJhbmNoaW5nIOKAlCBtdWx0aXBseWluZyBieSAoMS1vYnMpIGlzIGVxdWl2YWxlbnQgdG8gdGhlCiAgICAvLyBoYXJkIHplcm8taW5zaWRlIGNoZWNrIGJ1dCB3aXRoIGEgY29udGludW91cyBncmFkaWVudCB0aGF0IGF2b2lkcyBncmlkIGFydGVmYWN0cy4KICAgIGdsX0ZyYWdDb2xvciA9IGRpc3NpcGF0aW9uICogdGV4dHVyZTJEKHVTb3VyY2UsIGNvb3JkKSAqICgxLjAgLSBvYnMpOwogIH0KYAopLCBFdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZMKS54ICogKDEuMCAtIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZMKS5yKTsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2UikueCAqICgxLjAgLSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2Uikucik7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLnkgKiAoMS4wIC0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlQpLnIpOwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZCKS55ICogKDEuMCAtIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZCKS5yKTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoMC41ICogKFIgLSBMICsgVCAtIEIpLCAwLjAsIDAuMCwgMS4wKTsKICB9CmAKKSwgVXQgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVQcmVzc3VyZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1RGl2ZXJnZW5jZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEMgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2VXYpLng7CiAgICBmbG9hdCBMID0gbWl4KHRleHR1cmUyRCh1UHJlc3N1cmUsIHZMKS54LCBDLCB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2TCkucik7CiAgICBmbG9hdCBSID0gbWl4KHRleHR1cmUyRCh1UHJlc3N1cmUsIHZSKS54LCBDLCB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2Uikucik7CiAgICBmbG9hdCBUID0gbWl4KHRleHR1cmUyRCh1UHJlc3N1cmUsIHZUKS54LCBDLCB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VCkucik7CiAgICBmbG9hdCBCID0gbWl4KHRleHR1cmUyRCh1UHJlc3N1cmUsIHZCKS54LCBDLCB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2Qikucik7CiAgICBmbG9hdCBkaXYgPSB0ZXh0dXJlMkQodURpdmVyZ2VuY2UsIHZVdikueDsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoKEwgKyBSICsgQiArIFQgLSBkaXYpICogMC4yNSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIER0ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1UHJlc3N1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgb2JzID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlV2KS5yOwogICAgZmxvYXQgQyAgID0gdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlV2KS54OwogICAgZmxvYXQgTCAgID0gbWl4KHRleHR1cmUyRCh1UHJlc3N1cmUsIHZMKS54LCBDLCB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2TCkucik7CiAgICBmbG9hdCBSICAgPSBtaXgodGV4dHVyZTJEKHVQcmVzc3VyZSwgdlIpLngsIEMsIHRleHR1cmUyRCh1T2JzdGFjbGUsIHZSKS5yKTsKICAgIGZsb2F0IFQgICA9IG1peCh0ZXh0dXJlMkQodVByZXNzdXJlLCB2VCkueCwgQywgdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlQpLnIpOwogICAgZmxvYXQgQiAgID0gbWl4KHRleHR1cmUyRCh1UHJlc3N1cmUsIHZCKS54LCBDLCB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2Qikucik7CiAgICB2ZWMyIHZlbCAgPSAodGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSAtIHZlYzIoUiAtIEwsIFQgLSBCKSkgKiAoMS4wIC0gb2JzKTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQodmVsLCAwLjAsIDEuMCk7CiAgfQpgCiksIF90ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVRhcmdldDsKICB1bmlmb3JtIGZsb2F0IGFzcGVjdFJhdGlvOwogIHVuaWZvcm0gdmVjMyBjb2xvcjsKICB1bmlmb3JtIHZlYzIgcG9pbnQ7CiAgdW5pZm9ybSBmbG9hdCByYWRpdXM7CiAgdm9pZCBtYWluICgpIHsKICAgIHZlYzIgcCA9IHZVdiAtIHBvaW50Lnh5OwogICAgcC54ICo9IGFzcGVjdFJhdGlvOwogICAgdmVjMyBzcGxhdCA9IGV4cCgtZG90KHAsIHApIC8gcmFkaXVzKSAqIGNvbG9yOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCh0ZXh0dXJlMkQodVRhcmdldCwgdlV2KS54eXogKyBzcGxhdCwgMS4wKTsKICB9CmAKKSwgQ3QgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVWZWxvY2l0eTsKICB2b2lkIG1haW4gKCkgewogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZMKS55OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZSKS55OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZUKS54OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1VmVsb2NpdHksIHZCKS54OwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjUgKiAoUiAtIEwgLSBUICsgQiksIDAuMCwgMC4wLCAxLjApOwogIH0KYAopLCBCdCA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdlV2OyB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVDdXJsOwogIHVuaWZvcm0gZmxvYXQgY3VybDsKICB1bmlmb3JtIGZsb2F0IGR0OwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVDdXJsLCB2TCkueDsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodUN1cmwsIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1Q3VybCwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVDdXJsLCB2QikueDsKICAgIGZsb2F0IEMgPSB0ZXh0dXJlMkQodUN1cmwsIHZVdikueDsKICAgIHZlYzIgZm9yY2UgPSAwLjUgKiB2ZWMyKGFicyhUKSAtIGFicyhCKSwgYWJzKFIpIC0gYWJzKEwpKTsKICAgIGZvcmNlIC89IGxlbmd0aChmb3JjZSkgKyAwLjAwMDE7CiAgICBmb3JjZSAqPSBjdXJsICogMzAuMCAqIEM7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHkgKyBmb3JjZSAqIGR0LCAwLjAsIDEuMCk7CiAgfQpgCiksIE90ID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7CgogIHVuaWZvcm0gc2FtcGxlcjJEIHVUZXh0dXJlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1QmFja2dyb3VuZDsKICB1bmlmb3JtIHNhbXBsZXIyRCB1Q292ZXJhZ2U7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwoKICB1bmlmb3JtIHZlYzIgIHRleGVsU2l6ZTsKICB1bmlmb3JtIHZlYzMgIHVXYXRlckNvbG9yOwogIHVuaWZvcm0gdmVjMyAgdUdsb3dDb2xvcjsKICB1bmlmb3JtIGZsb2F0IHVSZWZyYWN0aW9uOwogIHVuaWZvcm0gZmxvYXQgdVNwZWN1bGFyRXhwOwogIHVuaWZvcm0gZmxvYXQgdVNoaW5lOwogIHVuaWZvcm0gZmxvYXQgdVdhcnBTdHJlbmd0aDsKICB1bmlmb3JtIGludCAgIHVBbGdvcml0aG07CiAgdW5pZm9ybSBpbnQgICB1RW5hYmxlQWxwaGE7CgogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBvYnMgICAgICA9IHRleHR1cmUyRCh1T2JzdGFjbGUsICB2VXYpLnI7CiAgICAvLyBTbW9vdGggZmFkZTogZGVuc2l0eSBmYWxscyBvZmYgb3ZlciB0aGUgYmx1cnJlZCBvYnN0YWNsZSBib3VuZGFyeSB6b25lCiAgICAvLyByYXRoZXIgdGhhbiBjdXR0aW5nIG9mZiBhdCBhIGhhcmQgc3RlcCwgZWxpbWluYXRpbmcgdGhlIGphZ2dlZCBmcmluZ2UuCiAgICBmbG9hdCBkZW5zaXR5ICA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdikuciwgMC4wKSAqICgxLjAgLSBvYnMpOwogICAgZmxvYXQgY292ZXJhZ2UgPSB0ZXh0dXJlMkQodUNvdmVyYWdlLCAgdlV2KS5yOwoKICAgIC8vIDgtdGFwIFNvYmVsIG5vcm1hbCDigJQgY29tcHV0ZXMgZ3JhZGllbnQgdmlhIDPDlzMga2VybmVsIChubyBjZW50cmUgc2FtcGxlIG5lZWRlZCkuCiAgICAvLyB0ZXhlbFNpemUgPSAxL2Rpc3BsYXlSZXM7IGRlbnNpdHkgRkJPIGlzIGF0IHNpbVNjYWxlICgwLjXDlyksIHNvIHM9NiBkaXNwbGF5IHB4CiAgICAvLyDiiYggMyBzaW0gdGV4ZWxzIHBlciBheGlzLiAgVGhlIFNvYmVsIGtlcm5lbCBwcm9wZXJseSBhdmVyYWdlcyB0aGUgZ3JhZGllbnQgaW4KICAgIC8vIGV2ZXJ5IGRpcmVjdGlvbiDigJQgbm8gNC10YXAgY3Jvc3MgYmlhcyB0aGF0IGNyZWF0ZXMgNDXCsCBjaXJjdWl0LWJvYXJkIGFydGVmYWN0cy4KICAgIGZsb2F0IHN4ID0gdGV4ZWxTaXplLnggKiA2LjAsIHN5ID0gdGV4ZWxTaXplLnkgKiA2LjA7CiAgICBmbG9hdCBkMDAgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKC1zeCwgLXN5KSkuciwgMC4wKTsKICAgIGZsb2F0IGQxMCA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIoMC4wLCAtc3kpKS5yLCAwLjApOwogICAgZmxvYXQgZDIwID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2ICsgdmVjMiggc3gsIC1zeSkpLnIsIDAuMCk7CiAgICBmbG9hdCBkMDEgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKC1zeCwgMC4wKSkuciwgMC4wKTsKICAgIGZsb2F0IGQyMSA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIoIHN4LCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZDAyID0gbWF4KHRleHR1cmUyRCh1VGV4dHVyZSwgdlV2ICsgdmVjMigtc3gsICBzeSkpLnIsIDAuMCk7CiAgICBmbG9hdCBkMTIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKDAuMCwgIHN5KSkuciwgMC4wKTsKICAgIGZsb2F0IGQyMiA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdiArIHZlYzIoIHN4LCAgc3kpKS5yLCAwLjApOwogICAgZmxvYXQgZ3ggID0gKGQyMCArIDIuMCpkMjEgKyBkMjIpIC0gKGQwMCArIDIuMCpkMDEgKyBkMDIpOwogICAgZmxvYXQgZ3kgID0gKGQwMiArIDIuMCpkMTIgKyBkMjIpIC0gKGQwMCArIDIuMCpkMTAgKyBkMjApOwoKICAgIHZlYzMgIG5vcm1hbCAgID0gbm9ybWFsaXplKHZlYzMoZ3gsIGd5LCAxLjIpKTsKICAgIHZlYzMgIGxpZ2h0RGlyID0gbm9ybWFsaXplKHZlYzMoMC41LCAxLjAsIDAuNSkpOwogICAgdmVjMyAgaGFsZlYgICAgPSBub3JtYWxpemUobGlnaHREaXIgKyB2ZWMzKDAuMCwgMC4wLCAxLjApKTsKICAgIC8vIFN1cHByZXNzIHNwZWN1bGFyIGF0IGxvdyAvIGZhZGluZyBkZW5zaXR5IOKAlCBwcmV2ZW50cyBoaWdobGlnaHQgcmluZ3MgZnJvbQogICAgLy8gYXBwZWFyaW5nIGF0IHRoZSBkaXNzaXBhdGluZyBlZGdlIG9mIGEgc3Ryb2tlIGFzIGl0cyBkZW5zaXR5IGFwcHJvYWNoZXMgemVyby4KICAgIGZsb2F0IHNwZWNEZW4gID0gZGVuc2l0eSAqIG1pbihkZW5zaXR5ICogNS4wLCAxLjApOwogICAgZmxvYXQgc3BlYyAgICAgPSBwb3cobWF4KGRvdChub3JtYWwsIGhhbGZWKSwgMC4wKSwgdVNwZWN1bGFyRXhwKSAqIHVTaGluZSAqIHNwZWNEZW47CgogICAgLy8gSW4gdHJhbnNwYXJlbnQgKG5vbi1jb3ZlcmFnZSkgYXJlYXMgdGhlIGJhY2tncm91bmQgdGV4dHVyZSBpcyBlbXB0eSBibGFjayBjYW52YXMuCiAgICAvLyBSZXBsYWNlIGl0IHdpdGggdVdhdGVyQ29sb3Igc28gZmx1aWQgY29sb3VyIGlzIG5vdCBjb250YW1pbmF0ZWQgYnkgdGhhdCBibGFjaywKICAgIC8vIGFsbG93aW5nIHRoZSBDU1MgYmFja2dyb3VuZENvbG9yIHRvIHNob3cgdGhyb3VnaCBjb3JyZWN0bHkgdmlhIHByZW11bHRpcGxpZWQgYWxwaGEuCiAgICB2ZWMzIGJnUmF3ID0gdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCB2VXYpLnJnYjsKICAgIHZlYzMgYmcgICAgPSBtaXgodVdhdGVyQ29sb3IsIGJnUmF3LCBjb3ZlcmFnZSk7CiAgICB2ZWMzIGNvbG9yID0gYmc7CgogICAgaWYgKHVBbGdvcml0aG0gPT0gMSkgewogICAgICAvLyDilIDilIAgZ2xhc3Mg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIFN0cm9uZyBVViBkaXN0b3J0aW9uIG9ubHkuIEltYWdlIGJlbmRzIGJ1dCBubyBjb2xvdXIgb3ZlcmxheS4KICAgICAgdmVjMiByZWZyVXYgPSBjbGFtcCh2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHkgKiAzLjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMyByZWZyQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmVmclV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgPSByZWZyQmcgKyBzcGVjICogdUdsb3dDb2xvciAqIDIuNTsKICAgICAgY29sb3IgPSBtaXgoY29sb3IsIGJnICogMC42LCBvYnMgKiAwLjMpOwoKICAgIH0gZWxzZSBpZiAodUFsZ29yaXRobSA9PSAyKSB7CiAgICAgIC8vIOKUgOKUgCBpbmsg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIERlbnNlIG9wYXF1ZSBwaWdtZW50IHRoYXQgc3RhaW5zLiBTdWJ0bGUgcmVmcmFjdGlvbiB1bmRlcm5lYXRoLgogICAgICBmbG9hdCBpbmtEICA9IG1pbihkZW5zaXR5ICogNC4wLCAxLjApOwogICAgICB2ZWMyIHJlZnJVdiA9IGNsYW1wKHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eSAqIDAuNCwgMC4wLCAxLjApOwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciA9IG1peChyZWZyQmcsIHVXYXRlckNvbG9yICsgc3BlYyAqIHVHbG93Q29sb3IsIGlua0QpOwogICAgICBjb2xvciA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMTUpOwoKICAgIH0gZWxzZSBpZiAodUFsZ29yaXRobSA9PSAzKSB7CiAgICAgIC8vIOKUgOKUgCBhdXJvcmEg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIFZlbG9jaXR5IGZpZWxkIHdhcnBzIGJhY2tncm91bmQgVVZzIOKAlCBsaXF1aWQgbWV0YWwgLyBsYXZhLWxhbXAgZmVlbC4KICAgICAgdmVjMiAgdmVsICAgID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eTsKICAgICAgZmxvYXQgdmVsTWFnID0gY2xhbXAobGVuZ3RoKHZlbCkgKiAyMC4wLCAwLjAsIDEuMCk7CiAgICAgIHZlYzIgIHdhcnBVdiA9IGNsYW1wKHZVdiArIHZlbCAqIHVXYXJwU3RyZW5ndGgsIDAuMCwgMS4wKTsKICAgICAgdmVjMyAgd2FycEJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIHdhcnBVdikucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yICA9IG1peChiZywgd2FycEJnLCB2ZWxNYWcgKiAoMS4wIC0gb2JzKSk7CiAgICAgIGNvbG9yICs9IHNwZWMgKiB1R2xvd0NvbG9yICogdmVsTWFnICogMS41OwogICAgICBjb2xvciArPSB1V2F0ZXJDb2xvciAqIGRlbnNpdHkgKiAwLjM7CiAgICAgIGNvbG9yICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMik7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDQpIHsKICAgICAgLy8g4pSA4pSAIHJpcHBsZSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gRXhhZ2dlcmF0ZWQgbm9ybWFsIHBlcnR1cmJhdGlvbiArIEZyZXNuZWwgcmltIOKAlCBjYWxtIHdhdGVyIHN1cmZhY2UuCiAgICAgIHZlYzIgIHJpcHBsZVV2ID0gY2xhbXAodlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5ICogNi4wLCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgIHJlZnJCZyAgID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJpcHBsZVV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgZmxvYXQgZnJlc25lbCAgPSBwb3coY2xhbXAoMS4wIC0gZG90KG5vcm1hbCwgdmVjMygwLjAsIDAuMCwgMS4wKSksIDAuMCwgMS4wKSwgMy4wKSAqIGRlbnNpdHk7CiAgICAgIGNvbG9yICA9IHJlZnJCZzsKICAgICAgY29sb3IgKz0gZnJlc25lbCAqIHVHbG93Q29sb3IgKiAyLjA7CiAgICAgIGNvbG9yICs9IHNwZWMgKiB1R2xvd0NvbG9yICogZGVuc2l0eSAqIDIuMDsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKCiAgICB9IGVsc2UgewogICAgICAvLyDilIDilIAgc3RhbmRhcmQgKDApIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBPcmlnaW5hbDogY29sb3VyIG92ZXJsYXkgYmxlbmRlZCBvdmVyIHJlZnJhY3RlZCBiYWNrZ3JvdW5kLgogICAgICB2ZWMyIHJlZnJVdiA9IHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eTsKICAgICAgdmVjMyByZWZyQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmVmclV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgID0gbWl4KHJlZnJCZywgdVdhdGVyQ29sb3IsIG1pbihkZW5zaXR5ICogMS41LCAwLjgpKTsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3I7CiAgICAgIGNvbG9yICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMik7CiAgICB9CgogICAgLy8gT3V0cHV0OiBwcmVtdWx0aXBsaWVkIGFscGhhIHdoZW4gdHJhbnNwYXJlbmN5IGlzIGVuYWJsZWQgKGxldHMgQ1NTIGJhY2tncm91bmRDb2xvcgogICAgLy8gc2hvdyB0aHJvdWdoKSwgb3Igc3RyYWlnaHQgb3BhcXVlIGNvbG91ciB3aGVuIGVuYWJsZUFscGhhIGlzIG9mZiAocGVyZiBtb2RlKS4KICAgIGZsb2F0IGFscGhhID0gY2xhbXAobWF4KGRlbnNpdHkgKiAxLjUsIGNvdmVyYWdlKSwgMC4wLCAxLjApOwogICAgaWYgKHVFbmFibGVBbHBoYSA9PSAxKSB7CiAgICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoY29sb3IgKiBhbHBoYSwgYWxwaGEpOwogICAgfSBlbHNlIHsKICAgICAgZ2xfRnJhZ0NvbG9yID0gdmVjNChjb2xvciwgMS4wKTsKICAgIH0KICB9CmAKKTsKZnVuY3Rpb24gVnQoaSwgZSA9ICEwKSB7CiAgY29uc3QgciA9IHsgYWxwaGE6IGUsIGRlcHRoOiAhMSwgc3RlbmNpbDogITEsIGFudGlhbGlhczogITAsIHByZXNlcnZlRHJhd2luZ0J1ZmZlcjogITEgfTsKICBsZXQgcyA9IGkuZ2V0Q29udGV4dCgid2ViZ2wyIiwgcik7CiAgY29uc3QgbyA9ICEhczsKICBvIHx8IChzID0gaS5nZXRDb250ZXh0KCJ3ZWJnbCIsIHIpLCBzLmdldEV4dGVuc2lvbigiRVhUX2NvbG9yX2J1ZmZlcl9oYWxmX2Zsb2F0IikpOwogIGNvbnN0IGEgPSBvID8gbnVsbCA6IHMuZ2V0RXh0ZW5zaW9uKCJPRVNfdGV4dHVyZV9oYWxmX2Zsb2F0IiksIHUgPSBvID8gcy5IQUxGX0ZMT0FUIDogYS5IQUxGX0ZMT0FUX09FUzsKICByZXR1cm4gcy5nZXRFeHRlbnNpb24oIkVYVF9jb2xvcl9idWZmZXJfZmxvYXQiKSwgcy5nZXRFeHRlbnNpb24oIk9FU190ZXh0dXJlX2hhbGZfZmxvYXRfbGluZWFyIiksIHsKICAgIHR5cGU6IG8gPyAid2ViZ2wyIiA6ICJ3ZWJnbDEiLAogICAgZ2w6IHMsCiAgICBpc1dlYkdMMjogbywKICAgIGV4dDogewogICAgICBpbnRlcm5hbEZvcm1hdDogbyA/IHMuUkdCQTE2RiA6IHMuUkdCQSwKICAgICAgZm9ybWF0OiBzLlJHQkEsCiAgICAgIHR5cGU6IHUKICAgIH0KICB9Owp9CmFzeW5jIGZ1bmN0aW9uIFB0KGksIGUgPSAhMCkgewogIGlmICh0eXBlb2YgbmF2aWdhdG9yID4gInUiIHx8ICFuYXZpZ2F0b3IuZ3B1KQogICAgcmV0dXJuIG51bGw7CiAgdHJ5IHsKICAgIGNvbnN0IHIgPSBhd2FpdCBuYXZpZ2F0b3IuZ3B1LnJlcXVlc3RBZGFwdGVyKCk7CiAgICBpZiAoIXIpCiAgICAgIHJldHVybiBudWxsOwogICAgY29uc3QgcyA9IGF3YWl0IHIucmVxdWVzdERldmljZSgpLCBvID0gaS5nZXRDb250ZXh0KCJ3ZWJncHUiKTsKICAgIGlmICghbykKICAgICAgcmV0dXJuIG51bGw7CiAgICBjb25zdCBhID0gbmF2aWdhdG9yLmdwdS5nZXRQcmVmZXJyZWRDYW52YXNGb3JtYXQoKTsKICAgIHJldHVybiBvLmNvbmZpZ3VyZSh7IGRldmljZTogcywgZm9ybWF0OiBhLCBhbHBoYU1vZGU6IGUgPyAicHJlbXVsdGlwbGllZCIgOiAib3BhcXVlIiB9KSwgeyB0eXBlOiAid2ViZ3B1IiwgYWRhcHRlcjogciwgZGV2aWNlOiBzLCBjb250ZXh0OiBvLCBmb3JtYXQ6IGEgfTsKICB9IGNhdGNoIHsKICAgIHJldHVybiBudWxsOwogIH0KfQpjbGFzcyBpZSB7CiAgY29uc3RydWN0b3IoZSwgciwgcykgewogICAga2UodGhpcywgInByb2dyYW0iKTsKICAgIGtlKHRoaXMsICJ1bmlmb3JtcyIsIHt9KTsKICAgIGtlKHRoaXMsICJfZ2wiKTsKICAgIHRoaXMuX2dsID0gZSwgdGhpcy5wcm9ncmFtID0gZS5jcmVhdGVQcm9ncmFtKCksIGUuYXR0YWNoU2hhZGVyKHRoaXMucHJvZ3JhbSwgdGhpcy5fY29tcGlsZShlLlZFUlRFWF9TSEFERVIsIHIpKSwgZS5hdHRhY2hTaGFkZXIodGhpcy5wcm9ncmFtLCB0aGlzLl9jb21waWxlKGUuRlJBR01FTlRfU0hBREVSLCBzKSksIGUubGlua1Byb2dyYW0odGhpcy5wcm9ncmFtKTsKICAgIGNvbnN0IG8gPSBlLmdldFByb2dyYW1QYXJhbWV0ZXIodGhpcy5wcm9ncmFtLCBlLkFDVElWRV9VTklGT1JNUyk7CiAgICBmb3IgKGxldCBhID0gMDsgYSA8IG87IGErKykgewogICAgICBjb25zdCB1ID0gZS5nZXRBY3RpdmVVbmlmb3JtKHRoaXMucHJvZ3JhbSwgYSkubmFtZTsKICAgICAgdGhpcy51bmlmb3Jtc1t1XSA9IGUuZ2V0VW5pZm9ybUxvY2F0aW9uKHRoaXMucHJvZ3JhbSwgdSk7CiAgICB9CiAgfQogIF9jb21waWxlKGUsIHIpIHsKICAgIGNvbnN0IHMgPSB0aGlzLl9nbCwgbyA9IHMuY3JlYXRlU2hhZGVyKGUpOwogICAgcmV0dXJuIHMuc2hhZGVyU291cmNlKG8sIHIpLCBzLmNvbXBpbGVTaGFkZXIobyksIG87CiAgfQogIGJpbmQoKSB7CiAgICB0aGlzLl9nbC51c2VQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQogIGRpc3Bvc2UoKSB7CiAgICB0aGlzLl9nbC5kZWxldGVQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQp9CmZ1bmN0aW9uIEZ0KGkpIHsKICByZXR1cm4gewogICAgYWR2ZWN0aW9uOiBuZXcgaWUoaSwgcmUsIFJ0KSwKICAgIGRpdmVyZ2VuY2U6IG5ldyBpZShpLCByZSwgRXQpLAogICAgcHJlc3N1cmU6IG5ldyBpZShpLCByZSwgVXQpLAogICAgZ3JhZGllbnRTdWJ0cmFjdDogbmV3IGllKGksIHJlLCBEdCksCiAgICBzcGxhdDogbmV3IGllKGksIHJlLCBfdCksCiAgICBjdXJsOiBuZXcgaWUoaSwgcmUsIEN0KSwKICAgIHZvcnRpY2l0eTogbmV3IGllKGksIHJlLCBCdCksCiAgICBkaXNwbGF5OiBuZXcgaWUoaSwgcmUsIE90KQogIH07Cn0KZnVuY3Rpb24gcWUoaSwgZSwgciwgcykgewogIGkuYWN0aXZlVGV4dHVyZShpLlRFWFRVUkUwKTsKICBjb25zdCBvID0gaS5jcmVhdGVUZXh0dXJlKCk7CiAgaS5iaW5kVGV4dHVyZShpLlRFWFRVUkVfMkQsIG8pLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUlOX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUFHX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9TLCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9ULCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleEltYWdlMkQoaS5URVhUVVJFXzJELCAwLCBlLmludGVybmFsRm9ybWF0LCByLCBzLCAwLCBlLmZvcm1hdCwgZS50eXBlLCBudWxsKTsKICBjb25zdCBhID0gaS5jcmVhdGVGcmFtZWJ1ZmZlcigpOwogIHJldHVybiBpLmJpbmRGcmFtZWJ1ZmZlcihpLkZSQU1FQlVGRkVSLCBhKSwgaS5mcmFtZWJ1ZmZlclRleHR1cmUyRChpLkZSQU1FQlVGRkVSLCBpLkNPTE9SX0FUVEFDSE1FTlQwLCBpLlRFWFRVUkVfMkQsIG8sIDApLCB7IHRleDogbywgZmJvOiBhLCB3aWR0aDogciwgaGVpZ2h0OiBzIH07Cn0KZnVuY3Rpb24gdHQoaSwgZSwgciwgcykgewogIGxldCBvID0gcWUoaSwgZSwgciwgcyksIGEgPSBxZShpLCBlLCByLCBzKTsKICByZXR1cm4gewogICAgZ2V0IHJlYWQoKSB7CiAgICAgIHJldHVybiBvOwogICAgfSwKICAgIGdldCB3cml0ZSgpIHsKICAgICAgcmV0dXJuIGE7CiAgICB9LAogICAgc3dhcCgpIHsKICAgICAgW28sIGFdID0gW2EsIG9dOwogICAgfSwKICAgIGRpc3Bvc2UoKSB7CiAgICAgIGkuZGVsZXRlVGV4dHVyZShvLnRleCksIGkuZGVsZXRlRnJhbWVidWZmZXIoby5mYm8pLCBpLmRlbGV0ZVRleHR1cmUoYS50ZXgpLCBpLmRlbGV0ZUZyYW1lYnVmZmVyKGEuZmJvKTsKICAgIH0KICB9Owp9CmZ1bmN0aW9uIEx0KGkpIHsKICBjb25zdCBlID0gaS5jcmVhdGVCdWZmZXIoKTsKICByZXR1cm4gaS5iaW5kQnVmZmVyKGkuQVJSQVlfQlVGRkVSLCBlKSwgaS5idWZmZXJEYXRhKGkuQVJSQVlfQlVGRkVSLCBuZXcgRmxvYXQzMkFycmF5KFstMSwgLTEsIC0xLCAxLCAxLCAxLCAxLCAtMV0pLCBpLlNUQVRJQ19EUkFXKSwgaS52ZXJ0ZXhBdHRyaWJQb2ludGVyKDAsIDIsIGkuRkxPQVQsICExLCAwLCAwKSwgaS5lbmFibGVWZXJ0ZXhBdHRyaWJBcnJheSgwKSwgZnVuY3Rpb24ocykgewogICAgaS5iaW5kRnJhbWVidWZmZXIoaS5GUkFNRUJVRkZFUiwgcyksIGkuZHJhd0FycmF5cyhpLlRSSUFOR0xFX0ZBTiwgMCwgNCk7CiAgfTsKfQpjb25zdCBsZSA9ICgKICAvKiB3Z3NsICovCiAgYApzdHJ1Y3QgVlNPdXQgewogIEBidWlsdGluKHBvc2l0aW9uKSBwb3MgOiB2ZWM0ZiwKICBAbG9jYXRpb24oMCkgICAgICAgdXYgIDogdmVjMmYsCiAgQGxvY2F0aW9uKDEpICAgICAgIHZMICA6IHZlYzJmLAogIEBsb2NhdGlvbigyKSAgICAgICB2UiAgOiB2ZWMyZiwKICBAbG9jYXRpb24oMykgICAgICAgdlQgIDogdmVjMmYsCiAgQGxvY2F0aW9uKDQpICAgICAgIHZCICA6IHZlYzJmLAp9YAopLCBBdCA9ICgKICAvKiB3Z3NsICovCiAgYAoke2xlfQoKc3RydWN0IFUgewogIHRleGVsU2l6ZSAgOiB2ZWMyZiwKICBkdCAgICAgICAgIDogZjMyLAogIGRpc3NpcGF0aW9uOiBmMzIsCn0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVWZWwgIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoMykgdmFyICAgICAgICAgIHVTcmMgIDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoNCkgdmFyICAgICAgICAgIHVPYnMgIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgb2JzICAgPSB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudXYpLnI7CiAgbGV0IHZlbCAgID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnV2KS54eTsKICBsZXQgY29vcmQgPSBpLnV2IC0gdS5kdCAqIHZlbCAqIHUudGV4ZWxTaXplOwogIGxldCBzcmMgICA9IHRleHR1cmVTYW1wbGUodVNyYywgc2FtcCwgY29vcmQpOwogIHJldHVybiB1LmRpc3NpcGF0aW9uICogc3JjICogKDEuMCAtIG9icyk7Cn0KYAopLCB6dCA9ICgKICAvKiB3Z3NsICovCiAgYAoke2xlfQoKc3RydWN0IFUgeyB0ZXhlbFNpemU6IHZlYzJmLCBfcGFkOiB2ZWMyZiB9CkBncm91cCgwKSBAYmluZGluZygwKSB2YXI8dW5pZm9ybT4gdSAgICA6IFU7CkBncm91cCgwKSBAYmluZGluZygxKSB2YXIgICAgICAgICAgc2FtcCA6IHNhbXBsZXI7CkBncm91cCgwKSBAYmluZGluZygyKSB2YXIgICAgICAgICAgdVZlbCA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDMpIHZhciAgICAgICAgICB1T2JzIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgTCA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52TCkueCAqICgxLjAgLSB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkwpLnIpOwogIGxldCBSID0gdGV4dHVyZVNhbXBsZSh1VmVsLCBzYW1wLCBpLnZSKS54ICogKDEuMCAtIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52Uikucik7CiAgbGV0IFQgPSB0ZXh0dXJlU2FtcGxlKHVWZWwsIHNhbXAsIGkudlQpLnkgKiAoMS4wIC0gdGV4dHVyZVNhbXBsZSh1T2JzLCBzYW1wLCBpLnZUKS5yKTsKICBsZXQgQiA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52QikueSAqICgxLjAgLSB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkIpLnIpOwogIHJldHVybiB2ZWM0ZigwLjUgKiAoUiAtIEwgKyBUIC0gQiksIDAuMCwgMC4wLCAxLjApOwp9CmAKKSwgWHQgPSAoCiAgLyogd2dzbCAqLwogIGAKJHtsZX0KCnN0cnVjdCBVIHsgdGV4ZWxTaXplOiB2ZWMyZiwgX3BhZDogdmVjMmYgfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVQcmVzOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZygzKSB2YXIgICAgICAgICAgdURpdiA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDQpIHZhciAgICAgICAgICB1T2JzIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgQyAgPSB0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnV2KS54OwogIGxldCBMICA9IG1peCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZMKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkwpLnIpOwogIGxldCBSICA9IG1peCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZSKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlIpLnIpOwogIGxldCBUICA9IG1peCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZUKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlQpLnIpOwogIGxldCBCICA9IG1peCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZCKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudkIpLnIpOwogIGxldCBkdiA9IHRleHR1cmVTYW1wbGUodURpdiwgc2FtcCwgaS51dikueDsKICByZXR1cm4gdmVjNGYoKEwgKyBSICsgQiArIFQgLSBkdikgKiAwLjI1LCAwLjAsIDAuMCwgMS4wKTsKfQpgCiksIEd0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7IHRleGVsU2l6ZTogdmVjMmYsIF9wYWQ6IHZlYzJmIH0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgIDogVTsKQGdyb3VwKDApIEBiaW5kaW5nKDEpIHZhciAgICAgICAgICBzYW1wIDogc2FtcGxlcjsKQGdyb3VwKDApIEBiaW5kaW5nKDIpIHZhciAgICAgICAgICB1UHJlczogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoMykgdmFyICAgICAgICAgIHVWZWwgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZyg0KSB2YXIgICAgICAgICAgdU9icyA6IHRleHR1cmVfMmQ8ZjMyPjsKCkB2ZXJ0ZXggZm4gdnMoQGxvY2F0aW9uKDApIGE6IHZlYzJmKSAtPiBWU091dCB7CiAgdmFyIG86IFZTT3V0OwogIG8udXYgPSB2ZWMyZihhLnggKiAwLjUgKyAwLjUsIDAuNSAtIGEueSAqIDAuNSk7CiAgby52TCA9IG8udXYgLSB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlIgPSBvLnV2ICsgdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZUID0gby51diArIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby52QiA9IG8udXYgLSB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8ucG9zID0gdmVjNGYoYSwgMC4wLCAxLjApOwogIHJldHVybiBvOwp9CgpAZnJhZ21lbnQgZm4gZnMoaTogVlNPdXQpIC0+IEBsb2NhdGlvbigwKSB2ZWM0ZiB7CiAgbGV0IG9icyA9IHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS51dikucjsKICBsZXQgQyAgID0gdGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS51dikueDsKICBsZXQgTCAgID0gbWl4KHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudkwpLngsIEMsIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52TCkucik7CiAgbGV0IFIgICA9IG1peCh0ZXh0dXJlU2FtcGxlKHVQcmVzLCBzYW1wLCBpLnZSKS54LCBDLCB0ZXh0dXJlU2FtcGxlKHVPYnMsIHNhbXAsIGkudlIpLnIpOwogIGxldCBUICAgPSBtaXgodGV4dHVyZVNhbXBsZSh1UHJlcywgc2FtcCwgaS52VCkueCwgQywgdGV4dHVyZVNhbXBsZSh1T2JzLCBzYW1wLCBpLnZUKS5yKTsKICBsZXQgQiAgID0gbWl4KHRleHR1cmVTYW1wbGUodVByZXMsIHNhbXAsIGkudkIpLngsIEMsIHRleHR1cmVTYW1wbGUodU9icywgc2FtcCwgaS52Qikucik7CiAgbGV0IHZlbCA9ICh0ZXh0dXJlU2FtcGxlKHVWZWwsIHNhbXAsIGkudXYpLnh5IC0gdmVjMmYoUiAtIEwsIFQgLSBCKSkgKiAoMS4wIC0gb2JzKTsKICByZXR1cm4gdmVjNGYodmVsLCAwLjAsIDEuMCk7Cn0KYAopLCBNdCA9ICgKICAvKiB3Z3NsICovCiAgYAoke2xlfQoKLy8gdGV4ZWxTaXplIG9jY3VwaWVzIGJ5dGVzIDAtNyBmb3IgdGhlIHNoYXJlZCB2ZXJ0ZXggc3RhZ2U7IGFzcGVjdFJhdGlvL3JhZGl1cyBmaWxsIHRoZSByZXN0LgpzdHJ1Y3QgVSB7CiAgdGV4ZWxTaXplICA6IHZlYzJmLAogIGFzcGVjdFJhdGlvOiBmMzIsCiAgcmFkaXVzICAgICA6IGYzMiwKICBjb2xvciAgICAgIDogdmVjNGYsICAvLyB4eXogPSBjb2xvdXIsIHcgdW51c2VkCiAgcG9pbnQgICAgICA6IHZlYzJmLAogIF9wYWQgICAgICAgOiB2ZWMyZiwKfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVUZ3QgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIHZhciBwICA9IGkudXYgLSB1LnBvaW50OwogIHAueCAgICo9IHUuYXNwZWN0UmF0aW87CiAgbGV0IHNwID0gZXhwKC1kb3QocCwgcCkgLyB1LnJhZGl1cykgKiB1LmNvbG9yLnh5ejsKICByZXR1cm4gdmVjNGYodGV4dHVyZVNhbXBsZSh1VGd0LCBzYW1wLCBpLnV2KS54eXogKyBzcCwgMS4wKTsKfQpgCiksIEl0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7IHRleGVsU2l6ZTogdmVjMmYsIF9wYWQ6IHZlYzJmIH0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgIDogVTsKQGdyb3VwKDApIEBiaW5kaW5nKDEpIHZhciAgICAgICAgICBzYW1wIDogc2FtcGxlcjsKQGdyb3VwKDApIEBiaW5kaW5nKDIpIHZhciAgICAgICAgICB1VmVsIDogdGV4dHVyZV8yZDxmMzI+OwoKQHZlcnRleCBmbiB2cyhAbG9jYXRpb24oMCkgYTogdmVjMmYpIC0+IFZTT3V0IHsKICB2YXIgbzogVlNPdXQ7CiAgby51diA9IHZlYzJmKGEueCAqIDAuNSArIDAuNSwgMC41IC0gYS55ICogMC41KTsKICBvLnZMID0gby51diAtIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52UiA9IG8udXYgKyB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlQgPSBvLnV2ICsgdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnZCID0gby51diAtIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby5wb3MgPSB2ZWM0ZihhLCAwLjAsIDEuMCk7CiAgcmV0dXJuIG87Cn0KCkBmcmFnbWVudCBmbiBmcyhpOiBWU091dCkgLT4gQGxvY2F0aW9uKDApIHZlYzRmIHsKICBsZXQgTCA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52TCkueTsKICBsZXQgUiA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52UikueTsKICBsZXQgVCA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52VCkueDsKICBsZXQgQiA9IHRleHR1cmVTYW1wbGUodVZlbCwgc2FtcCwgaS52QikueDsKICByZXR1cm4gdmVjNGYoMC41ICogKFIgLSBMIC0gVCArIEIpLCAwLjAsIDAuMCwgMS4wKTsKfQpgCiksIGt0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7CiAgdGV4ZWxTaXplOiB2ZWMyZiwKICBjdXJsICAgICA6IGYzMiwKICBkdCAgICAgICA6IGYzMiwKfQpAZ3JvdXAoMCkgQGJpbmRpbmcoMCkgdmFyPHVuaWZvcm0+IHUgICAgOiBVOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMSkgdmFyICAgICAgICAgIHNhbXAgOiBzYW1wbGVyOwpAZ3JvdXAoMCkgQGJpbmRpbmcoMikgdmFyICAgICAgICAgIHVWZWwgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZygzKSB2YXIgICAgICAgICAgdUNybCA6IHRleHR1cmVfMmQ8ZjMyPjsKCkB2ZXJ0ZXggZm4gdnMoQGxvY2F0aW9uKDApIGE6IHZlYzJmKSAtPiBWU091dCB7CiAgdmFyIG86IFZTT3V0OwogIG8udXYgPSB2ZWMyZihhLnggKiAwLjUgKyAwLjUsIDAuNSAtIGEueSAqIDAuNSk7CiAgby52TCA9IG8udXYgLSB2ZWMyZih1LnRleGVsU2l6ZS54LCAwLjApOwogIG8udlIgPSBvLnV2ICsgdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZUID0gby51diArIHZlYzJmKDAuMCwgdS50ZXhlbFNpemUueSk7CiAgby52QiA9IG8udXYgLSB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8ucG9zID0gdmVjNGYoYSwgMC4wLCAxLjApOwogIHJldHVybiBvOwp9CgpAZnJhZ21lbnQgZm4gZnMoaTogVlNPdXQpIC0+IEBsb2NhdGlvbigwKSB2ZWM0ZiB7CiAgbGV0IEwgICAgID0gdGV4dHVyZVNhbXBsZSh1Q3JsLCBzYW1wLCBpLnZMKS54OwogIGxldCBSICAgICA9IHRleHR1cmVTYW1wbGUodUNybCwgc2FtcCwgaS52UikueDsKICBsZXQgVCAgICAgPSB0ZXh0dXJlU2FtcGxlKHVDcmwsIHNhbXAsIGkudlQpLng7CiAgbGV0IEIgICAgID0gdGV4dHVyZVNhbXBsZSh1Q3JsLCBzYW1wLCBpLnZCKS54OwogIGxldCBDICAgICA9IHRleHR1cmVTYW1wbGUodUNybCwgc2FtcCwgaS51dikueDsKICB2YXIgZm9yY2UgPSAwLjUgKiB2ZWMyZihhYnMoVCkgLSBhYnMoQiksIGFicyhSKSAtIGFicyhMKSk7CiAgZm9yY2UgICAgLz0gbGVuZ3RoKGZvcmNlKSArIDAuMDAwMTsKICBmb3JjZSAgICAqPSB1LmN1cmwgKiAzMC4wICogQzsKICBsZXQgdmVsICAgPSB0ZXh0dXJlU2FtcGxlKHVWZWwsIHNhbXAsIGkudXYpLnh5ICsgZm9yY2UgKiB1LmR0OwogIHJldHVybiB2ZWM0Zih2ZWwsIDAuMCwgMS4wKTsKfQpgCiksIFd0ID0gKAogIC8qIHdnc2wgKi8KICBgCiR7bGV9CgpzdHJ1Y3QgVSB7CiAgdGV4ZWxTaXplICAgOiB2ZWMyZiwKICByZWZyYWN0aW9uICA6IGYzMiwKICBzcGVjdWxhckV4cCA6IGYzMiwKICB3YXRlckNvbG9yICA6IHZlYzRmLAogIGdsb3dDb2xvciAgIDogdmVjNGYsCiAgc2hpbmUgICAgICAgOiBmMzIsCiAgd2FycFN0cmVuZ3RoOiBmMzIsCiAgYWxnb3JpdGhtICAgOiBpMzIsCiAgZW5hYmxlQWxwaGEgOiBpMzIsCn0KQGdyb3VwKDApIEBiaW5kaW5nKDApIHZhcjx1bmlmb3JtPiB1ICAgIDogVTsKQGdyb3VwKDApIEBiaW5kaW5nKDEpIHZhciAgICAgICAgICBzYW1wIDogc2FtcGxlcjsKQGdyb3VwKDApIEBiaW5kaW5nKDIpIHZhciAgICAgICAgICB1VGV4IDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoMykgdmFyICAgICAgICAgIHVPYnMgOiB0ZXh0dXJlXzJkPGYzMj47CkBncm91cCgwKSBAYmluZGluZyg0KSB2YXIgICAgICAgICAgdUJnICA6IHRleHR1cmVfMmQ8ZjMyPjsKQGdyb3VwKDApIEBiaW5kaW5nKDUpIHZhciAgICAgICAgICB1Q292IDogdGV4dHVyZV8yZDxmMzI+OwpAZ3JvdXAoMCkgQGJpbmRpbmcoNikgdmFyICAgICAgICAgIHVWZWwgOiB0ZXh0dXJlXzJkPGYzMj47CgpAdmVydGV4IGZuIHZzKEBsb2NhdGlvbigwKSBhOiB2ZWMyZikgLT4gVlNPdXQgewogIHZhciBvOiBWU091dDsKICBvLnV2ID0gdmVjMmYoYS54ICogMC41ICsgMC41LCAwLjUgLSBhLnkgKiAwLjUpOwogIG8udkwgPSBvLnV2IC0gdmVjMmYodS50ZXhlbFNpemUueCwgMC4wKTsKICBvLnZSID0gby51diArIHZlYzJmKHUudGV4ZWxTaXplLngsIDAuMCk7CiAgby52VCA9IG8udXYgKyB2ZWMyZigwLjAsIHUudGV4ZWxTaXplLnkpOwogIG8udkIgPSBvLnV2IC0gdmVjMmYoMC4wLCB1LnRleGVsU2l6ZS55KTsKICBvLnBvcyA9IHZlYzRmKGEsIDAuMCwgMS4wKTsKICByZXR1cm4gbzsKfQoKQGZyYWdtZW50IGZuIGZzKGk6IFZTT3V0KSAtPiBAbG9jYXRpb24oMCkgdmVjNGYgewogIGxldCBvYnMgICAgID0gdGV4dHVyZVNhbXBsZSh1T2JzLCBzYW1wLCBpLnV2KS5yOwogIGxldCBkZW5zaXR5ID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51dikuciwgMC4wKSAqICgxLjAgLSBvYnMpOwogIGxldCBjb3YgICAgID0gdGV4dHVyZVNhbXBsZSh1Q292LCBzYW1wLCBpLnV2KS5yOwoKICBsZXQgc3ggID0gdS50ZXhlbFNpemUueCAqIDYuMDsKICBsZXQgc3kgID0gdS50ZXhlbFNpemUueSAqIDYuMDsKICBsZXQgZDAwID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKC1zeCwgLXN5KSkuciwgMC4wKTsKICBsZXQgZDEwID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKDAuMCwgLXN5KSkuciwgMC4wKTsKICBsZXQgZDIwID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKCBzeCwgLXN5KSkuciwgMC4wKTsKICBsZXQgZDAxID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKC1zeCwgMC4wKSkuciwgMC4wKTsKICBsZXQgZDIxID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKCBzeCwgMC4wKSkuciwgMC4wKTsKICBsZXQgZDAyID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKC1zeCwgIHN5KSkuciwgMC4wKTsKICBsZXQgZDEyID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKDAuMCwgIHN5KSkuciwgMC4wKTsKICBsZXQgZDIyID0gbWF4KHRleHR1cmVTYW1wbGUodVRleCwgc2FtcCwgaS51diArIHZlYzJmKCBzeCwgIHN5KSkuciwgMC4wKTsKICBsZXQgZ3ggID0gKGQyMCArIDIuMCpkMjEgKyBkMjIpIC0gKGQwMCArIDIuMCpkMDEgKyBkMDIpOwogIGxldCBneSAgPSAoZDAyICsgMi4wKmQxMiArIGQyMikgLSAoZDAwICsgMi4wKmQxMCArIGQyMCk7CgogIGxldCBub3JtICAgID0gbm9ybWFsaXplKHZlYzNmKGd4LCBneSwgMS4yKSk7CiAgbGV0IGxkaXIgICAgPSBub3JtYWxpemUodmVjM2YoMC41LCAxLjAsIDAuNSkpOwogIGxldCBoYWxmViAgID0gbm9ybWFsaXplKGxkaXIgKyB2ZWMzZigwLjAsIDAuMCwgMS4wKSk7CiAgbGV0IHNwZWNEZW4gPSBkZW5zaXR5ICogbWluKGRlbnNpdHkgKiA1LjAsIDEuMCk7CiAgbGV0IHNwZWMgICAgPSBwb3cobWF4KGRvdChub3JtLCBoYWxmViksIDAuMCksIHUuc3BlY3VsYXJFeHApICogdS5zaGluZSAqIHNwZWNEZW47CgogIGxldCBiZ1JhdyA9IHRleHR1cmVTYW1wbGUodUJnLCBzYW1wLCBpLnV2KS5yZ2I7CiAgbGV0IHdjICAgID0gdS53YXRlckNvbG9yLnJnYjsKICBsZXQgZ2MgICAgPSB1Lmdsb3dDb2xvci5yZ2I7CiAgbGV0IGJnICAgID0gbWl4KHdjLCBiZ1JhdywgY292KTsKICB2YXIgY29sb3IgPSBiZzsKCiAgaWYgKHUuYWxnb3JpdGhtID09IDEpIHsKICAgIGxldCBydXYgPSBjbGFtcChpLnV2ICsgbm9ybS54eSAqIHUucmVmcmFjdGlvbiAqIGRlbnNpdHkgKiAzLjAsIHZlYzJmKDAuMCksIHZlYzJmKDEuMCkpOwogICAgbGV0IHJiZyA9IG1peCh3YywgdGV4dHVyZVNhbXBsZSh1QmcsIHNhbXAsIG1peChpLnV2LCBydXYsIDEuMCAtIG9icykpLnJnYiwgY292KTsKICAgIGNvbG9yICAgPSByYmcgKyBzcGVjICogZ2MgKiAyLjU7CiAgICBjb2xvciAgID0gbWl4KGNvbG9yLCBiZyAqIDAuNiwgb2JzICogMC4zKTsKICB9IGVsc2UgaWYgKHUuYWxnb3JpdGhtID09IDIpIHsKICAgIGxldCBpbmtEID0gbWluKGRlbnNpdHkgKiA0LjAsIDEuMCk7CiAgICBsZXQgcnV2ICA9IGNsYW1wKGkudXYgKyBub3JtLnh5ICogdS5yZWZyYWN0aW9uICogZGVuc2l0eSAqIDAuNCwgdmVjMmYoMC4wKSwgdmVjMmYoMS4wKSk7CiAgICBsZXQgcmJnICA9IG1peCh3YywgdGV4dHVyZVNhbXBsZSh1QmcsIHNhbXAsIG1peChpLnV2LCBydXYsIDEuMCAtIG9icykpLnJnYiwgY292KTsKICAgIGNvbG9yICAgID0gbWl4KHJiZywgd2MgKyBzcGVjICogZ2MsIGlua0QpOwogICAgY29sb3IgICAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjE1KTsKICB9IGVsc2UgaWYgKHUuYWxnb3JpdGhtID09IDMpIHsKICAgIGxldCB2ZWwgICAgPSB0ZXh0dXJlU2FtcGxlKHVWZWwsIHNhbXAsIGkudXYpLnh5OwogICAgbGV0IHZlbE1hZyA9IGNsYW1wKGxlbmd0aCh2ZWwpICogMjAuMCwgMC4wLCAxLjApOwogICAgbGV0IHd1diAgICA9IGNsYW1wKGkudXYgKyB2ZWwgKiB1LndhcnBTdHJlbmd0aCwgdmVjMmYoMC4wKSwgdmVjMmYoMS4wKSk7CiAgICBsZXQgd2JnICAgID0gbWl4KHdjLCB0ZXh0dXJlU2FtcGxlKHVCZywgc2FtcCwgd3V2KS5yZ2IsIGNvdik7CiAgICBjb2xvciAgICAgID0gbWl4KGJnLCB3YmcsIHZlbE1hZyAqICgxLjAgLSBvYnMpKTsKICAgIGNvbG9yICAgICArPSBzcGVjICogZ2MgKiB2ZWxNYWcgKiAxLjU7CiAgICBjb2xvciAgICAgKz0gd2MgKiBkZW5zaXR5ICogMC4zOwogICAgY29sb3IgICAgICA9IG1peChjb2xvciwgYmcgKiAwLjUsIG9icyAqIDAuMik7CiAgfSBlbHNlIGlmICh1LmFsZ29yaXRobSA9PSA0KSB7CiAgICBsZXQgcnV2ICAgPSBjbGFtcChpLnV2ICsgbm9ybS54eSAqIHUucmVmcmFjdGlvbiAqIGRlbnNpdHkgKiA2LjAsIHZlYzJmKDAuMCksIHZlYzJmKDEuMCkpOwogICAgbGV0IHJiZyAgID0gbWl4KHdjLCB0ZXh0dXJlU2FtcGxlKHVCZywgc2FtcCwgbWl4KGkudXYsIHJ1diwgMS4wIC0gb2JzKSkucmdiLCBjb3YpOwogICAgbGV0IGZyZXMgID0gcG93KGNsYW1wKDEuMCAtIGRvdChub3JtLCB2ZWMzZigwLjAsIDAuMCwgMS4wKSksIDAuMCwgMS4wKSwgMy4wKSAqIGRlbnNpdHk7CiAgICBjb2xvciAgICAgPSByYmc7CiAgICBjb2xvciAgICArPSBmcmVzICogZ2MgKiAyLjA7CiAgICBjb2xvciAgICArPSBzcGVjICogZ2MgKiBkZW5zaXR5ICogMi4wOwogICAgY29sb3IgICAgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICB9IGVsc2UgewogICAgbGV0IHJ1diA9IGkudXYgKyBub3JtLnh5ICogdS5yZWZyYWN0aW9uICogZGVuc2l0eTsKICAgIGxldCByYmcgPSBtaXgod2MsIHRleHR1cmVTYW1wbGUodUJnLCBzYW1wLCBtaXgoaS51diwgcnV2LCAxLjAgLSBvYnMpKS5yZ2IsIGNvdik7CiAgICBjb2xvciAgID0gbWl4KHJiZywgd2MsIG1pbihkZW5zaXR5ICogMS41LCAwLjgpKTsKICAgIGNvbG9yICArPSBzcGVjICogZ2M7CiAgICBjb2xvciAgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICB9CgogIGxldCBhbHBoYSA9IGNsYW1wKG1heChkZW5zaXR5ICogMS41LCBjb3YpLCAwLjAsIDEuMCk7CiAgaWYgKHUuZW5hYmxlQWxwaGEgPT0gMSkgewogICAgcmV0dXJuIHZlYzRmKGNvbG9yICogYWxwaGEsIGFscGhhKTsKICB9CiAgcmV0dXJuIHZlYzRmKGNvbG9yLCAxLjApOwp9CmAKKSwgTnQgPSB7CiAgYXJyYXlTdHJpZGU6IDgsCiAgYXR0cmlidXRlczogW3sgc2hhZGVyTG9jYXRpb246IDAsIG9mZnNldDogMCwgZm9ybWF0OiAiZmxvYXQzMngyIiB9XQp9LCBudCA9IG5ldyBGbG9hdDMyQXJyYXkoWwogIC0xLAogIC0xLAogIC0xLAogIDEsCiAgMSwKICAtMSwKICAxLAogIC0xLAogIC0xLAogIDEsCiAgMSwKICAxCl0pOwpmdW5jdGlvbiAkdChpKSB7CiAgY29uc3QgZSA9IGkuY3JlYXRlQnVmZmVyKHsgc2l6ZTogbnQuYnl0ZUxlbmd0aCwgdXNhZ2U6IEdQVUJ1ZmZlclVzYWdlLlZFUlRFWCB8IEdQVUJ1ZmZlclVzYWdlLkNPUFlfRFNUIH0pOwogIHJldHVybiBpLnF1ZXVlLndyaXRlQnVmZmVyKGUsIDAsIG50KSwgZTsKfQpmdW5jdGlvbiBIZShpLCBlLCByLCBzKSB7CiAgY29uc3QgbyA9IGkuY3JlYXRlVGV4dHVyZSh7CiAgICBzaXplOiBbciwgc10sCiAgICBmb3JtYXQ6IGUsCiAgICB1c2FnZTogR1BVVGV4dHVyZVVzYWdlLlRFWFRVUkVfQklORElORyB8IEdQVVRleHR1cmVVc2FnZS5SRU5ERVJfQVRUQUNITUVOVCB8IEdQVVRleHR1cmVVc2FnZS5DT1BZX1NSQwogIH0pOwogIHJldHVybiB7IHRleDogbywgdmlldzogby5jcmVhdGVWaWV3KCksIHdpZHRoOiByLCBoZWlnaHQ6IHMgfTsKfQpmdW5jdGlvbiBydChpLCBlLCByLCBzKSB7CiAgbGV0IG8gPSBIZShpLCBlLCByLCBzKSwgYSA9IEhlKGksIGUsIHIsIHMpOwogIHJldHVybiB7CiAgICBnZXQgcmVhZCgpIHsKICAgICAgcmV0dXJuIG87CiAgICB9LAogICAgZ2V0IHdyaXRlKCkgewogICAgICByZXR1cm4gYTsKICAgIH0sCiAgICBzd2FwKCkgewogICAgICBbbywgYV0gPSBbYSwgb107CiAgICB9LAogICAgZGlzcG9zZSgpIHsKICAgICAgby50ZXguZGVzdHJveSgpLCBhLnRleC5kZXN0cm95KCk7CiAgICB9CiAgfTsKfQpmdW5jdGlvbiBzZShpLCBlLCByLCBzKSB7CiAgY29uc3QgbyA9IGkuY3JlYXRlU2hhZGVyTW9kdWxlKHsgY29kZTogZSB9KTsKICByZXR1cm4gaS5jcmVhdGVSZW5kZXJQaXBlbGluZSh7CiAgICBsYXlvdXQ6ICJhdXRvIiwKICAgIHZlcnRleDogeyBtb2R1bGU6IG8sIGVudHJ5UG9pbnQ6ICJ2cyIsIGJ1ZmZlcnM6IFtOdF0gfSwKICAgIGZyYWdtZW50OiB7IG1vZHVsZTogbywgZW50cnlQb2ludDogImZzIiwgdGFyZ2V0czogW3sgZm9ybWF0OiByLCAuLi5zID8geyBibGVuZDogcyB9IDoge30gfV0gfSwKICAgIHByaW1pdGl2ZTogeyB0b3BvbG9neTogInRyaWFuZ2xlLWxpc3QiIH0KICB9KTsKfQpjb25zdCBxdCA9IHsKICBjb2xvcjogeyBvcGVyYXRpb246ICJhZGQiLCBzcmNGYWN0b3I6ICJvbmUiLCBkc3RGYWN0b3I6ICJ6ZXJvIiB9LAogIGFscGhhOiB7IG9wZXJhdGlvbjogImFkZCIsIHNyY0ZhY3RvcjogIm9uZSIsIGRzdEZhY3RvcjogInplcm8iIH0KfTsKZnVuY3Rpb24gSHQoaSwgZSwgciA9ICEwKSB7CiAgY29uc3QgcyA9ICJyZ2JhMTZmbG9hdCI7CiAgcmV0dXJuIHsKICAgIGFkdmVjdGlvbjogc2UoaSwgQXQsIHMpLAogICAgZGl2ZXJnZW5jZTogc2UoaSwgenQsIHMpLAogICAgcHJlc3N1cmU6IHNlKGksIFh0LCBzKSwKICAgIGdyYWRpZW50U3VidHJhY3Q6IHNlKGksIEd0LCBzKSwKICAgIHNwbGF0OiBzZShpLCBNdCwgcyksCiAgICBjdXJsOiBzZShpLCBJdCwgcyksCiAgICB2b3J0aWNpdHk6IHNlKGksIGt0LCBzKSwKICAgIGRpc3BsYXk6IHNlKGksIFd0LCBlLCByID8gdm9pZCAwIDogcXQpCiAgfTsKfQpmdW5jdGlvbiBZdChpKSB7CiAgcmV0dXJuIGkuY3JlYXRlU2FtcGxlcih7IG1hZ0ZpbHRlcjogImxpbmVhciIsIG1pbkZpbHRlcjogImxpbmVhciIsIGFkZHJlc3NNb2RlVTogImNsYW1wLXRvLWVkZ2UiLCBhZGRyZXNzTW9kZVY6ICJjbGFtcC10by1lZGdlIiB9KTsKfQpmdW5jdGlvbiBXKGksIGUpIHsKICByZXR1cm4gaS5jcmVhdGVCdWZmZXIoeyBzaXplOiBlLCB1c2FnZTogR1BVQnVmZmVyVXNhZ2UuVU5JRk9STSB8IEdQVUJ1ZmZlclVzYWdlLkNPUFlfRFNUIH0pOwp9CmZ1bmN0aW9uIGx0KGksIGUsIHIsIHMsIG8sIGEpIHsKICBjb25zdCB1ID0gbmV3IEZsb2F0MzJBcnJheShbciwgcywgbywgYV0pOwogIGkucXVldWUud3JpdGVCdWZmZXIoZSwgMCwgdSk7Cn0KZnVuY3Rpb24gTmUoaSwgZSwgciwgcykgewogIGNvbnN0IG8gPSBuZXcgRmxvYXQzMkFycmF5KFtyLCBzLCAwLCAwXSk7CiAgaS5xdWV1ZS53cml0ZUJ1ZmZlcihlLCAwLCBvKTsKfQpmdW5jdGlvbiBRdChpLCBlLCByLCBzLCBvLCBhKSB7CiAgY29uc3QgdSA9IG5ldyBGbG9hdDMyQXJyYXkoW3IsIHMsIG8sIGFdKTsKICBpLnF1ZXVlLndyaXRlQnVmZmVyKGUsIDAsIHUpOwp9CmZ1bmN0aW9uICRlKGksIGUsIHIsIHMsIG8sIGEsIHUsIHYsIG0sIGMsIHApIHsKICBjb25zdCB4ID0gbmV3IEZsb2F0MzJBcnJheSgxMik7CiAgeFswXSA9IHIsIHhbMV0gPSBzLCB4WzJdID0gbywgeFszXSA9IGEsIHhbNF0gPSB1LCB4WzVdID0gdiwgeFs2XSA9IG0sIHhbN10gPSAwLCB4WzhdID0gYywgeFs5XSA9IHAsIHhbMTBdID0gMCwgeFsxMV0gPSAwLCBpLnF1ZXVlLndyaXRlQnVmZmVyKGUsIDAsIHgpOwp9CmZ1bmN0aW9uIGp0KGksIGUsIHIsIHMsIG8sIGEsIHUsIHYsIG0sIGMsIHAsIHgpIHsKICBjb25zdCBuID0gbmV3IEZsb2F0MzJBcnJheSgxNiksIGQgPSBuZXcgSW50MzJBcnJheShuLmJ1ZmZlcik7CiAgblswXSA9IHIsIG5bMV0gPSBzLCBuWzJdID0gbywgblszXSA9IGEsIG5bNF0gPSB1WzBdLCBuWzVdID0gdVsxXSwgbls2XSA9IHVbMl0sIG5bN10gPSAwLCBuWzhdID0gdlswXSwgbls5XSA9IHZbMV0sIG5bMTBdID0gdlsyXSwgblsxMV0gPSAwLCBuWzEyXSA9IG0sIG5bMTNdID0gYywgZFsxNF0gPSBwLCBkWzE1XSA9IHggPyAxIDogMCwgaS5xdWV1ZS53cml0ZUJ1ZmZlcihlLCAwLCBuKTsKfQpmdW5jdGlvbiBYKGksIGUsIHIsIHMsIG8pIHsKICBjb25zdCBhID0gaS5iZWdpblJlbmRlclBhc3MoewogICAgY29sb3JBdHRhY2htZW50czogW3sKICAgICAgdmlldzogbywKICAgICAgY2xlYXJWYWx1ZTogWzAsIDAsIDAsIDBdLAogICAgICBsb2FkT3A6ICJjbGVhciIsCiAgICAgIHN0b3JlT3A6ICJzdG9yZSIKICAgIH1dCiAgfSk7CiAgYS5zZXRQaXBlbGluZShlKSwgYS5zZXRCaW5kR3JvdXAoMCwgciksIGEuc2V0VmVydGV4QnVmZmVyKDAsIHMpLCBhLmRyYXcoNiksIGEuZW5kKCk7Cn0KZnVuY3Rpb24gS3QoaSwgZSwgciwgcywgbykgewogIGNvbnN0IGEgPSBpLmJlZ2luUmVuZGVyUGFzcyh7CiAgICBjb2xvckF0dGFjaG1lbnRzOiBbewogICAgICB2aWV3OiBvLAogICAgICBjbGVhclZhbHVlOiBbMCwgMCwgMCwgMF0sCiAgICAgIGxvYWRPcDogImNsZWFyIiwKICAgICAgc3RvcmVPcDogInN0b3JlIgogICAgfV0KICB9KTsKICBhLnNldFBpcGVsaW5lKGUpLCBhLnNldEJpbmRHcm91cCgwLCByKSwgYS5zZXRWZXJ0ZXhCdWZmZXIoMCwgcyksIGEuZHJhdyg2KSwgYS5lbmQoKTsKfQpmdW5jdGlvbiBCZShpLCBlLCByLCBzLCBvID0gImNvdmVyIikgewogIGxldCBhOwogIG8gPT09ICJjb3ZlciIgPyBhID0gTWF0aC5tYXgociAvIGksIHMgLyBlKSA6IG8gPT09ICJjb250YWluIiA/IGEgPSBNYXRoLm1pbihyIC8gaSwgcyAvIGUpIDogdHlwZW9mIG8gPT0gInN0cmluZyIgJiYgby5lbmRzV2l0aCgiJSIpID8gYSA9IE1hdGgubWluKHIgLyBpLCBzIC8gZSkgKiAocGFyc2VGbG9hdChvKSAvIDEwMCkgOiB0eXBlb2YgbyA9PSAic3RyaW5nIiAmJiBvLmVuZHNXaXRoKCJweCIpID8gYSA9IHBhcnNlRmxvYXQobykgLyBNYXRoLm1heChpLCBlKSA6IHR5cGVvZiBvID09ICJudW1iZXIiID8gYSA9IG8gOiBhID0gTWF0aC5tYXgociAvIGksIHMgLyBlKTsKICBjb25zdCB1ID0gaSAqIGEsIHYgPSBlICogYTsKICByZXR1cm4geyB4OiAociAtIHUpIC8gMiwgeTogKHMgLSB2KSAvIDIsIGRyYXdXOiB1LCBkcmF3SDogdiB9Owp9CmZ1bmN0aW9uIEp0KGksIGUsIHIsIHMsIG8gPSBudWxsLCBhID0gImNvdmVyIikgewogIGNvbnN0IHsgdGV4dDogdSwgZm9udFNpemU6IHYsIGNvbG9yOiBtLCBmb250RmFtaWx5OiBjID0gInNhbnMtc2VyaWYiLCBmb250V2VpZ2h0OiBwID0gOTAwIH0gPSBzLCB4ID0gbmV3IE9mZnNjcmVlbkNhbnZhcyhlLCByKSwgbiA9IHguZ2V0Q29udGV4dCgiMmQiKTsKICAoKEQpID0+IHsKICAgIGlmIChvKSB7CiAgICAgIG4uY2xlYXJSZWN0KDAsIDAsIGUsIHIpLCBuLmZpbGxTdHlsZSA9ICJibGFjayIsIG4uZmlsbFJlY3QoMCwgMCwgZSwgcik7CiAgICAgIGNvbnN0IHsgeDogZywgeTogXywgZHJhd1c6IEYsIGRyYXdIOiBrIH0gPSBCZSgKICAgICAgICBvLndpZHRoLAogICAgICAgIG8uaGVpZ2h0LAogICAgICAgIGUsCiAgICAgICAgciwKICAgICAgICBhCiAgICAgICk7CiAgICAgIG4uZHJhd0ltYWdlKG8sIGcsIF8sIEYsIGspOwogICAgfSBlbHNlCiAgICAgIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKTsKICAgIG4uZmlsbFN0eWxlID0gRCwgbi5mb250ID0gYCR7cH0gJHt2fXB4ICR7Y31gLCBuLnRleHRBbGlnbiA9ICJjZW50ZXIiLCBuLnRleHRCYXNlbGluZSA9ICJtaWRkbGUiLCBuLmZpbGxUZXh0KHUsIGUgLyAyLCByIC8gMik7CiAgfSkobSk7CiAgY29uc3QgYiA9IExlKGksIHgpOwogIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKSwgbi5maWxsU3R5bGUgPSAid2hpdGUiLCBuLmZvbnQgPSBgJHtwfSAke3Z9cHggJHtjfWAsIG4udGV4dEFsaWduID0gImNlbnRlciIsIG4udGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIG4uZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICBjb25zdCB5ID0gTGUoaSwgeCk7CiAgcmV0dXJuIHsgYmFja2dyb3VuZFRleDogYiwgb2JzdGFjbGVUZXg6IHksIGNvdmVyYWdlVGV4OiB5IH07Cn0KZnVuY3Rpb24gWnQoaSwgZSwgciwgcywgbyA9IDAsIGEgPSAiY292ZXIiLCB1ID0gbnVsbCwgdiA9ICJjb3ZlciIpIHsKICBjb25zdCBtID0gbmV3IE9mZnNjcmVlbkNhbnZhcyhyLCBzKSwgYyA9IG0uZ2V0Q29udGV4dCgiMmQiKSwgeyB4OiBwLCB5OiB4LCBkcmF3VzogbiwgZHJhd0g6IGQgfSA9IEJlKGUud2lkdGgsIGUuaGVpZ2h0LCByLCBzLCBhKTsKICBpZiAoYy5jbGVhclJlY3QoMCwgMCwgciwgcyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBzKSwgdSkgewogICAgY29uc3QgewogICAgICB4OiBnLAogICAgICB5OiBfLAogICAgICBkcmF3VzogRiwKICAgICAgZHJhd0g6IGsKICAgIH0gPSBCZSh1LndpZHRoLCB1LmhlaWdodCwgciwgcywgdik7CiAgICBjLmZpbHRlciA9IGBicmlnaHRuZXNzKCR7b30pIGJsdXIoOHB4KWAsIGMuZHJhd0ltYWdlKHUsIGcsIF8sIEYsIGspLCBjLmZpbHRlciA9ICJub25lIjsKICB9CiAgYy5kcmF3SW1hZ2UoZSwgcCwgeCwgbiwgZCk7CiAgY29uc3QgYiA9IExlKGksIG0pOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgcyksIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtvfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UoZSwgcCwgeCwgbiwgZCksIGMuZmlsdGVyID0gIm5vbmUiOwogIGNvbnN0IHkgPSBMZShpLCBtKTsKICBjLmNsZWFyUmVjdCgwLCAwLCByLCBzKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIGMuZmlsbFJlY3QoCiAgICBNYXRoLm1heCgwLCBwKSwKICAgIE1hdGgubWF4KDAsIHgpLAogICAgTWF0aC5taW4obiwgciAtIE1hdGgubWF4KDAsIHApKSwKICAgIE1hdGgubWluKGQsIHMgLSBNYXRoLm1heCgwLCB4KSkKICApOwogIGNvbnN0IEQgPSBMZShpLCBtKTsKICByZXR1cm4geyBiYWNrZ3JvdW5kVGV4OiBiLCBvYnN0YWNsZVRleDogeSwgY292ZXJhZ2VUZXg6IEQgfTsKfQpmdW5jdGlvbiBMZShpLCBlKSB7CiAgY29uc3QgciA9IGkuY3JlYXRlVGV4dHVyZSgpOwogIHJldHVybiBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgciksIGkucGl4ZWxTdG9yZWkoaS5VTlBBQ0tfRkxJUF9ZX1dFQkdMLCAhMCksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGkuUkdCQSwgaS5SR0JBLCBpLlVOU0lHTkVEX0JZVEUsIGUpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUlOX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUFHX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9TLCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9ULCBpLkNMQU1QX1RPX0VER0UpLCByOwp9CmZ1bmN0aW9uIGVyKGksIGUsIHIsIHMsIG8gPSBudWxsLCBhID0gImNvdmVyIikgewogIGNvbnN0IHsgdGV4dDogdSwgZm9udFNpemU6IHYsIGNvbG9yOiBtLCBmb250RmFtaWx5OiBjID0gInNhbnMtc2VyaWYiLCBmb250V2VpZ2h0OiBwID0gOTAwIH0gPSBzLCB4ID0gbmV3IE9mZnNjcmVlbkNhbnZhcyhlLCByKSwgbiA9IHguZ2V0Q29udGV4dCgiMmQiKTsKICAoKEQpID0+IHsKICAgIGlmIChvKSB7CiAgICAgIG4uY2xlYXJSZWN0KDAsIDAsIGUsIHIpLCBuLmZpbGxTdHlsZSA9ICJibGFjayIsIG4uZmlsbFJlY3QoMCwgMCwgZSwgcik7CiAgICAgIGNvbnN0IHsgeDogZywgeTogXywgZHJhd1c6IEYsIGRyYXdIOiBrIH0gPSBCZSgKICAgICAgICBvLndpZHRoLAogICAgICAgIG8uaGVpZ2h0LAogICAgICAgIGUsCiAgICAgICAgciwKICAgICAgICBhCiAgICAgICk7CiAgICAgIG4uZHJhd0ltYWdlKG8sIGcsIF8sIEYsIGspOwogICAgfSBlbHNlCiAgICAgIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKTsKICAgIG4uZmlsbFN0eWxlID0gRCwgbi5mb250ID0gYCR7cH0gJHt2fXB4ICR7Y31gLCBuLnRleHRBbGlnbiA9ICJjZW50ZXIiLCBuLnRleHRCYXNlbGluZSA9ICJtaWRkbGUiLCBuLmZpbGxUZXh0KHUsIGUgLyAyLCByIC8gMik7CiAgfSkobSk7CiAgY29uc3QgYiA9IEFlKGksIHgsIGUsIHIpOwogIG4uZmlsbFN0eWxlID0gImJsYWNrIiwgbi5maWxsUmVjdCgwLCAwLCBlLCByKSwgbi5maWxsU3R5bGUgPSAid2hpdGUiLCBuLmZvbnQgPSBgJHtwfSAke3Z9cHggJHtjfWAsIG4udGV4dEFsaWduID0gImNlbnRlciIsIG4udGV4dEJhc2VsaW5lID0gIm1pZGRsZSIsIG4uZmlsbFRleHQodSwgZSAvIDIsIHIgLyAyKTsKICBjb25zdCB5ID0gQWUoaSwgeCwgZSwgcik7CiAgcmV0dXJuIHsKICAgIGJhY2tncm91bmRUZXg6IGIsCiAgICBiYWNrZ3JvdW5kVmlldzogYi5jcmVhdGVWaWV3KCksCiAgICBvYnN0YWNsZVRleDogeSwKICAgIG9ic3RhY2xlVmlldzogeS5jcmVhdGVWaWV3KCksCiAgICBjb3ZlcmFnZVRleDogeSwKICAgIGNvdmVyYWdlVmlldzogeS5jcmVhdGVWaWV3KCksCiAgICBzaGFyZWRDb3ZlcmFnZTogITAKICB9Owp9CmZ1bmN0aW9uIHRyKGksIGUsIHIsIHMsIG8gPSAwLCBhID0gImNvdmVyIiwgdSA9IG51bGwsIHYgPSAiY292ZXIiKSB7CiAgY29uc3QgbSA9IG5ldyBPZmZzY3JlZW5DYW52YXMociwgcyksIGMgPSBtLmdldENvbnRleHQoIjJkIiksIHsgeDogcCwgeTogeCwgZHJhd1c6IG4sIGRyYXdIOiBkIH0gPSBCZShlLndpZHRoLCBlLmhlaWdodCwgciwgcywgYSk7CiAgaWYgKGMuY2xlYXJSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgcyksIHUpIHsKICAgIGNvbnN0IHsgeDogZywgeTogXywgZHJhd1c6IEYsIGRyYXdIOiBrIH0gPSBCZSgKICAgICAgdS53aWR0aCwKICAgICAgdS5oZWlnaHQsCiAgICAgIHIsCiAgICAgIHMsCiAgICAgIHYKICAgICk7CiAgICBjLmZpbHRlciA9IGBicmlnaHRuZXNzKCR7b30pIGJsdXIoOHB4KWAsIGMuZHJhd0ltYWdlKHUsIGcsIF8sIEYsIGspLCBjLmZpbHRlciA9ICJub25lIjsKICB9CiAgYy5kcmF3SW1hZ2UoZSwgcCwgeCwgbiwgZCk7CiAgY29uc3QgYiA9IEFlKGksIG0sIHIsIHMpOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgcyksIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtvfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UoZSwgcCwgeCwgbiwgZCksIGMuZmlsdGVyID0gIm5vbmUiOwogIGNvbnN0IHkgPSBBZShpLCBtLCByLCBzKTsKICBjLmNsZWFyUmVjdCgwLCAwLCByLCBzKSwgYy5maWxsU3R5bGUgPSAiYmxhY2siLCBjLmZpbGxSZWN0KDAsIDAsIHIsIHMpLCBjLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIGMuZmlsbFJlY3QoTWF0aC5tYXgoMCwgcCksIE1hdGgubWF4KDAsIHgpLCBNYXRoLm1pbihuLCByIC0gTWF0aC5tYXgoMCwgcCkpLCBNYXRoLm1pbihkLCBzIC0gTWF0aC5tYXgoMCwgeCkpKTsKICBjb25zdCBEID0gQWUoaSwgbSwgciwgcyk7CiAgcmV0dXJuIHsKICAgIGJhY2tncm91bmRUZXg6IGIsCiAgICBiYWNrZ3JvdW5kVmlldzogYi5jcmVhdGVWaWV3KCksCiAgICBvYnN0YWNsZVRleDogeSwKICAgIG9ic3RhY2xlVmlldzogeS5jcmVhdGVWaWV3KCksCiAgICBjb3ZlcmFnZVRleDogRCwKICAgIGNvdmVyYWdlVmlldzogRC5jcmVhdGVWaWV3KCksCiAgICBzaGFyZWRDb3ZlcmFnZTogITEKICB9Owp9CmZ1bmN0aW9uIEFlKGksIGUsIHIsIHMpIHsKICBjb25zdCBvID0gaS5jcmVhdGVUZXh0dXJlKHsKICAgIHNpemU6IFtyLCBzXSwKICAgIGZvcm1hdDogInJnYmE4dW5vcm0iLAogICAgdXNhZ2U6IEdQVVRleHR1cmVVc2FnZS5URVhUVVJFX0JJTkRJTkcgfCBHUFVUZXh0dXJlVXNhZ2UuQ09QWV9EU1QgfCBHUFVUZXh0dXJlVXNhZ2UuUkVOREVSX0FUVEFDSE1FTlQKICB9KTsKICByZXR1cm4gaS5xdWV1ZS5jb3B5RXh0ZXJuYWxJbWFnZVRvVGV4dHVyZSgKICAgIHsgc291cmNlOiBlIH0sCiAgICB7IHRleHR1cmU6IG8gfSwKICAgIFtyLCBzXQogICksIG87Cn0KYXN5bmMgZnVuY3Rpb24gcnIoaSkgewogIGNvbnN0IGUgPSBhd2FpdCBmZXRjaChpKTsKICBpZiAoIWUub2spCiAgICB0aHJvdyBuZXcgRXJyb3IoYEZhaWxlZCB0byBmZXRjaCBpbWFnZTogJHtpfSAoJHtlLnN0YXR1c30pYCk7CiAgY29uc3QgciA9IGF3YWl0IGUuYmxvYigpOwogIHJldHVybiBjcmVhdGVJbWFnZUJpdG1hcChyKTsKfQpjb25zdCBjdCA9IHR5cGVvZiByZXF1ZXN0QW5pbWF0aW9uRnJhbWUgPCAidSIgPyByZXF1ZXN0QW5pbWF0aW9uRnJhbWUuYmluZChnbG9iYWxUaGlzKSA6IChpKSA9PiBzZXRUaW1lb3V0KGksIDFlMyAvIDYwKSwgaXIgPSB0eXBlb2YgY2FuY2VsQW5pbWF0aW9uRnJhbWUgPCAidSIgPyBjYW5jZWxBbmltYXRpb25GcmFtZS5iaW5kKGdsb2JhbFRoaXMpIDogY2xlYXJUaW1lb3V0LCBWZSA9IDAuMDE2LCBmdCA9IHsgc3RhbmRhcmQ6IDAsIGdsYXNzOiAxLCBpbms6IDIsIGF1cm9yYTogMywgcmlwcGxlOiA0IH07CnZhciBjZSwgRywgemUsIGZlLCBVZSwgQiwgUiwgJCwgcSwgSCwgSywgTCwgWSwgViwgRGUsIHZlLCBfZSwgTywgVCwgb2UsIFEsIGFlLCB6LCB4ZSwgcGUsIG1lLCBkZSwgaGUsIEosIFosIGdlLCBiZSwgVGUsIHcsIFUsIE0sIEksIFAsIENlLCBlZSwgQSwgdWUsIHRlLCBoLCBDLCBqLCB5ZSwgWGUsIFNlLCBZZSwgeHQsIHdlLCBQZSwgR2UsIHN0LCBuZSwgRWUsIFJlLCBGZSwgTWUsIG90LCBJZSwgYXQsIFFlLCBwdCwgamUsIG10LCBLZSwgZHQsIEplLCBodCwgWmUsIGd0Owpjb25zdCB1dCA9IGNsYXNzIHV0IHsKICAvLyDilIDilIAgQ29uc3RydWN0b3Ig4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgY29uc3RydWN0b3IoZSwgciA9IHt9LCBzID0ge30sIG8sIGEgPSAhMCkgewogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIOKAlCBHUFUgaW5pdGlhbGlzYXRpb24KICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCBZZSk7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIHNoYXJlZCBoZWxwZXJzCiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIGYodGhpcywgd2UpOwogICAgZih0aGlzLCBHZSk7CiAgICBmKHRoaXMsIG5lKTsKICAgIGYodGhpcywgUmUpOwogICAgZih0aGlzLCBNZSk7CiAgICBmKHRoaXMsIEllKTsKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgLy8gUHJpdmF0ZSDigJQgZnJhbWUgZGlzcGF0Y2gKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCBRZSk7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIFdlYkdQVSBzaW11bGF0aW9uIHN0ZXAKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCBqZSk7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIFdlYkdQVSBkaXJlY3Qgc3BsYXQKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgZih0aGlzLCBLZSk7CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIC8vIFByaXZhdGUg4oCUIFdlYkdMIHNwbGF0CiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAgIGYodGhpcywgSmUpOwogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIOKAlCBXZWJHTCBzaW11bGF0aW9uIHN0ZXAgKHVuY2hhbmdlZCBmcm9tIG9yaWdpbmFsKQogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICBmKHRoaXMsIFplKTsKICAgIGYodGhpcywgY2UsIHZvaWQgMCk7CiAgICAvLyDilIDilIAgV2ViR0wgcGF0aCDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgIGYodGhpcywgRywgbnVsbCk7CiAgICBmKHRoaXMsIHplLCBudWxsKTsKICAgIGYodGhpcywgZmUsIG51bGwpOwogICAgZih0aGlzLCBVZSwgbnVsbCk7CiAgICBmKHRoaXMsIEIsIG51bGwpOwogICAgZih0aGlzLCBSLCBudWxsKTsKICAgIGYodGhpcywgJCwgbnVsbCk7CiAgICBmKHRoaXMsIHEsIG51bGwpOwogICAgZih0aGlzLCBILCBudWxsKTsKICAgIGYodGhpcywgSywgbnVsbCk7CiAgICBmKHRoaXMsIEwsIG51bGwpOwogICAgZih0aGlzLCBZLCBudWxsKTsKICAgIC8vIOKUgOKUgCBXZWJHUFUgcGF0aCDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgIGYodGhpcywgViwgbnVsbCk7CiAgICBmKHRoaXMsIERlLCBudWxsKTsKICAgIGYodGhpcywgdmUsIG51bGwpOwogICAgZih0aGlzLCBfZSwgbnVsbCk7CiAgICBmKHRoaXMsIE8sIG51bGwpOwogICAgZih0aGlzLCBULCBudWxsKTsKICAgIGYodGhpcywgb2UsIG51bGwpOwogICAgZih0aGlzLCBRLCBudWxsKTsKICAgIGYodGhpcywgYWUsIG51bGwpOwogICAgZih0aGlzLCB6LCBudWxsKTsKICAgIC8vIFByZS1hbGxvY2F0ZWQgdW5pZm9ybSBidWZmZXJzIChzaXplczogc2VlIGdwdS11dGlscyB3cml0ZVh4eCBkb2NzKQogICAgLy8gVmVsb2NpdHkvZGVuc2l0eSBhZHZlY3Rpb24gdXNlIHNlcGFyYXRlIGJ1ZmZlcnMg4oCUIHdyaXRlQnVmZmVyIGlzIGEgcXVldWUgb3A7CiAgICAvLyBhIHNlY29uZCB3cml0ZSB0byB0aGUgc2FtZSBidWZmZXIgYmVmb3JlIHF1ZXVlLnN1Ym1pdCgpIGFsaWFzZXMgYm90aCBwYXNzZXMuCiAgICBmKHRoaXMsIHhlLCBudWxsKTsKICAgIC8vIDE2IGJ5dGVzIOKAlCB2ZWxvY2l0eSBhZHZlY3Rpb24KICAgIGYodGhpcywgcGUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMg4oCUIGRlbnNpdHkgYWR2ZWN0aW9uCiAgICBmKHRoaXMsIG1lLCBudWxsKTsKICAgIC8vIDE2IGJ5dGVzCiAgICBmKHRoaXMsIGRlLCBudWxsKTsKICAgIC8vIDE2IGJ5dGVzCiAgICBmKHRoaXMsIGhlLCBudWxsKTsKICAgIC8vIDE2IGJ5dGVzCiAgICBmKHRoaXMsIEosIG51bGwpOwogICAgLy8gNDggYnl0ZXMg4oCUIHZlbG9jaXR5IHNwbGF0CiAgICBmKHRoaXMsIFosIG51bGwpOwogICAgLy8gNDggYnl0ZXMg4oCUIGRlbnNpdHkgc3BsYXQKICAgIGYodGhpcywgZ2UsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgYmUsIG51bGwpOwogICAgLy8gMTYgYnl0ZXMKICAgIGYodGhpcywgVGUsIG51bGwpOwogICAgLy8gNjQgYnl0ZXMKICAgIC8vIOKUgOKUgCBTaGFyZWQgc3RhdGUg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICBmKHRoaXMsIHcsIDApOwogICAgZih0aGlzLCBVLCAwKTsKICAgIGYodGhpcywgTSwgMCk7CiAgICBmKHRoaXMsIEksIDApOwogICAgZih0aGlzLCBQLCAxKTsKICAgIGYodGhpcywgQ2UsIDEpOwogICAgZih0aGlzLCBlZSwgMC41KTsKICAgIGYodGhpcywgQSwgbnVsbCk7CiAgICBmKHRoaXMsIHVlLCAiY292ZXIiKTsKICAgIGYodGhpcywgdGUsIHZvaWQgMCk7CiAgICBmKHRoaXMsIGgsIHsgeDogMCwgeTogMCwgZHg6IDAsIGR5OiAwLCB0YXJnZXRYOiAwLCB0YXJnZXRZOiAwLCBtb3ZlZDogITEgfSk7CiAgICBmKHRoaXMsIEMsIG51bGwpOwogICAgZih0aGlzLCBqLCBudWxsKTsKICAgIGYodGhpcywgeWUsICExKTsKICAgIGYodGhpcywgWGUsICExKTsKICAgIGYodGhpcywgU2UsICEwKTsKICAgIGlmIChsKHRoaXMsIGNlLCBlKSwgbCh0aGlzLCBDZSwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBzLmRwciA/PyAxKSkpLCBsKHRoaXMsIGVlLCBNYXRoLm1heCgwLjEsIE1hdGgubWluKDEsIHMuc2ltID8/IDAuNSkpKSwgbCh0aGlzLCB0ZSwgd3QocikpLCBsKHRoaXMsIFNlLCBhKSwgbykKICAgICAgbCh0aGlzLCBWLCBvKSwgUyh0aGlzLCBZZSwgeHQpLmNhbGwodGhpcywgbyk7CiAgICBlbHNlIHsKICAgICAgY29uc3QgeyBnbDogdSwgZXh0OiB2IH0gPSBWdChlLCBhKTsKICAgICAgbCh0aGlzLCBHLCB1KSwgbCh0aGlzLCB6ZSwgdiksIGwodGhpcywgZmUsIEZ0KHUpKSwgbCh0aGlzLCBVZSwgTHQodSkpLCB1LmNsZWFyQ29sb3IoMCwgMCwgMCwgYSA/IDAgOiAxKTsKICAgIH0KICB9CiAgLyoqCiAgICogV2ViR1BVLWZpcnN0IGZhY3RvcnkuIFRyaWVzIFdlYkdQVSwgZmFsbHMgYmFjayB0byBXZWJHTDIg4oaSIFdlYkdMMS4KICAgKiBUaGlzIGlzIHRoZSByZWNvbW1lbmRlZCBlbnRyeSBwb2ludCB3aGVuIFdlYkdQVSBzdXBwb3J0IGlzIGRlc2lyZWQuCiAgICovCiAgc3RhdGljIGFzeW5jIGNyZWF0ZShlLCByID0ge30sIHMgPSB7fSwgbyA9ICEwLCBhID0gITApIHsKICAgIGNvbnN0IHUgPSBvID8gYXdhaXQgUHQoZSwgYSkgOiBudWxsOwogICAgcmV0dXJuIG5ldyB1dChlLCByLCBzLCB1ID8/IHZvaWQgMCwgYSk7CiAgfQogIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogIC8vIFB1YmxpYyBBUEkKICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICBzZXRUZXh0U291cmNlKGUpIHsKICAgIGwodGhpcywgQywgeyB0eXBlOiAidGV4dCIsIG9wdHM6IGUgfSksIFModGhpcywgd2UsIFBlKS5jYWxsKHRoaXMpLCBTKHRoaXMsIG5lLCBFZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBSZSwgRmUpLmNhbGwodGhpcyk7CiAgfQogIGFzeW5jIHNldEltYWdlU291cmNlKGUsIHIgPSAwLCBzID0gImNvdmVyIikgewogICAgY29uc3QgbyA9IGF3YWl0IHJyKGUpOwogICAgaWYgKHQodGhpcywgWGUpKSB7CiAgICAgIG8uY2xvc2UoKTsKICAgICAgcmV0dXJuOwogICAgfQogICAgbCh0aGlzLCBDLCB7IHR5cGU6ICJpbWFnZSIsIGJpdG1hcDogbywgZWZmZWN0OiByLCBzaXplOiBzIH0pLCBTKHRoaXMsIHdlLCBQZSkuY2FsbCh0aGlzKSwgUyh0aGlzLCBuZSwgRWUpLmNhbGwodGhpcyksIFModGhpcywgUmUsIEZlKS5jYWxsKHRoaXMpOwogIH0KICBzZXRJbWFnZUJpdG1hcChlLCByID0gMCwgcyA9ICJjb3ZlciIpIHsKICAgIGwodGhpcywgQywgeyB0eXBlOiAiaW1hZ2UiLCBiaXRtYXA6IGUsIGVmZmVjdDogciwgc2l6ZTogcyB9KSwgUyh0aGlzLCB3ZSwgUGUpLmNhbGwodGhpcyksIFModGhpcywgbmUsIEVlKS5jYWxsKHRoaXMpLCBTKHRoaXMsIFJlLCBGZSkuY2FsbCh0aGlzKTsKICB9CiAgc2V0QmFja2dyb3VuZChlLCByID0gImNvdmVyIikgewogICAgdCh0aGlzLCBBKSAmJiB0KHRoaXMsIEEpICE9PSBlICYmIHQodGhpcywgQSkuY2xvc2UoKSwgbCh0aGlzLCBBLCBlKSwgbCh0aGlzLCB1ZSwgciA/PyAiY292ZXIiKSwgdCh0aGlzLCBDKSAmJiB0KHRoaXMsIHcpID4gMCAmJiB0KHRoaXMsIFUpID4gMCAmJiBTKHRoaXMsIG5lLCBFZSkuY2FsbCh0aGlzKTsKICB9CiAgaGFuZGxlTW92ZShlLCByLCBzID0gMSkgewogICAgdCh0aGlzLCBoKS5tb3ZlZCA9ICEwLCB0KHRoaXMsIGgpLmR4ID0gKGUgLSB0KHRoaXMsIGgpLnRhcmdldFgpICogcywgdCh0aGlzLCBoKS5keSA9IChyIC0gdCh0aGlzLCBoKS50YXJnZXRZKSAqIHMsIHQodGhpcywgaCkudGFyZ2V0WCA9IGUsIHQodGhpcywgaCkudGFyZ2V0WSA9IHI7CiAgfQogIC8qKgogICAqIEltbWVkaWF0ZWx5IGFwcGxpZXMgb25lIGZsdWlkIHNwbGF0IGF0ICh4LCB5KSB3aXRoIGV4cGxpY2l0IHZlbG9jaXR5ICh2eCwgdnkpLgogICAqIFNhZmUgdG8gY2FsbCBtdWx0aXBsZSB0aW1lcyBwZXIgZnJhbWUg4oCUIGVhY2ggY2FsbCB3cml0ZXMgZGlyZWN0bHkgdG8gdGhlIEZCT3MuCiAgICogRGVzaWduZWQgZm9yIHByb2dyYW1tYXRpYyB1c2UgY2FzZXMgKGUuZy4gcGFydGljbGUgc3lzdGVtcywgYXR0cmFjdG9yIHBhdGhzKQogICAqIHdoZXJlIHlvdSB3YW50IE4gaW5kZXBlbmRlbnQgaW5qZWN0aW9uIHBvaW50cyBwZXIgZnJhbWUgd2l0aG91dCBmbG9vZGluZyB0aGUKICAgKiBtb3VzZS1zdGF0ZSBtYWNoaW5lIG9yIHRoZSB3b3JrZXIgbWVzc2FnZSBxdWV1ZS4KICAgKi8KICBzcGxhdChlLCByLCBzLCBvLCBhID0gMSkgewogICAgIXQodGhpcywgeWUpIHx8IHQodGhpcywgdykgPT09IDAgfHwgKHQodGhpcywgVikgPyBTKHRoaXMsIEtlLCBkdCkuY2FsbCh0aGlzLCBlLCByLCBzLCBvLCBhKSA6IFModGhpcywgSmUsIGh0KS5jYWxsKHRoaXMsIGUsIHIsIHMsIG8sIGEpKTsKICB9CiAgdXBkYXRlUXVhbGl0eShlKSB7CiAgICBlLmRwciAhPT0gdm9pZCAwICYmIGwodGhpcywgQ2UsIE1hdGgubWF4KDAuMSwgTWF0aC5taW4oMSwgZS5kcHIpKSksIGUuc2ltICE9PSB2b2lkIDAgJiYgbCh0aGlzLCBlZSwgTWF0aC5tYXgoMC4xLCBNYXRoLm1pbigxLCBlLnNpbSkpKTsKICB9CiAgcmVzaXplKGUsIHIsIHMpIHsKICAgIGlmIChzICE9PSB2b2lkIDAgPyBsKHRoaXMsIFAsIHMpIDogdHlwZW9mIHdpbmRvdyA8ICJ1IiAmJiB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpbyAmJiBsKHRoaXMsIFAsIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvKSwgZSAhPT0gdm9pZCAwICYmIGUgPiAwKSB7CiAgICAgIGlmIChyID09PSB2b2lkIDAgfHwgciA8PSAwKQogICAgICAgIHJldHVybjsKICAgICAgbCh0aGlzLCB3LCB0KHRoaXMsIGNlKS53aWR0aCA9IGUpLCBsKHRoaXMsIFUsIHQodGhpcywgY2UpLmhlaWdodCA9IHIpLCBsKHRoaXMsIE0sIE1hdGgubWF4KDEsIE1hdGgucm91bmQoZSAqIHQodGhpcywgZWUpKSkpLCBsKHRoaXMsIEksIE1hdGgubWF4KDEsIE1hdGgucm91bmQociAqIHQodGhpcywgZWUpKSkpLCBTKHRoaXMsIEdlLCBzdCkuY2FsbCh0aGlzKTsKICAgIH0gZWxzZQogICAgICBTKHRoaXMsIHdlLCBQZSkuY2FsbCh0aGlzKTsKICAgIHQodGhpcywgQykgJiYgUyh0aGlzLCBuZSwgRWUpLmNhbGwodGhpcyksIFModGhpcywgUmUsIEZlKS5jYWxsKHRoaXMpOwogIH0KICB1cGRhdGVDb25maWcoZSkgewogICAgT2JqZWN0LmFzc2lnbih0KHRoaXMsIHRlKSwgZSk7CiAgfQogIGRlc3Ryb3koKSB7CiAgICB2YXIgZSwgciwgcywgbywgYSwgdSwgdiwgbSwgYywgcCwgeDsKICAgIGlmIChsKHRoaXMsIFhlLCAhMCksIHRoaXMuc3RvcCgpLCBTKHRoaXMsIE1lLCBvdCkuY2FsbCh0aGlzKSwgUyh0aGlzLCBJZSwgYXQpLmNhbGwodGhpcyksIHQodGhpcywgQSkgJiYgKHQodGhpcywgQSkuY2xvc2UoKSwgbCh0aGlzLCBBLCBudWxsKSksIHQodGhpcywgVikpCiAgICAgIChlID0gdCh0aGlzLCB4ZSkpID09IG51bGwgfHwgZS5kZXN0cm95KCksIChyID0gdCh0aGlzLCBwZSkpID09IG51bGwgfHwgci5kZXN0cm95KCksIChzID0gdCh0aGlzLCBtZSkpID09IG51bGwgfHwgcy5kZXN0cm95KCksIChvID0gdCh0aGlzLCBkZSkpID09IG51bGwgfHwgby5kZXN0cm95KCksIChhID0gdCh0aGlzLCBoZSkpID09IG51bGwgfHwgYS5kZXN0cm95KCksICh1ID0gdCh0aGlzLCBKKSkgPT0gbnVsbCB8fCB1LmRlc3Ryb3koKSwgKHYgPSB0KHRoaXMsIFopKSA9PSBudWxsIHx8IHYuZGVzdHJveSgpLCAobSA9IHQodGhpcywgZ2UpKSA9PSBudWxsIHx8IG0uZGVzdHJveSgpLCAoYyA9IHQodGhpcywgYmUpKSA9PSBudWxsIHx8IGMuZGVzdHJveSgpLCAocCA9IHQodGhpcywgVGUpKSA9PSBudWxsIHx8IHAuZGVzdHJveSgpLCAoeCA9IHQodGhpcywgdmUpKSA9PSBudWxsIHx8IHguZGVzdHJveSgpLCB0KHRoaXMsIFYpLmRldmljZS5kZXN0cm95KCk7CiAgICBlbHNlIHsKICAgICAgY29uc3QgbiA9IHQodGhpcywgRyk7CiAgICAgIGZvciAoY29uc3QgYiBvZiBPYmplY3QudmFsdWVzKHQodGhpcywgZmUpKSkKICAgICAgICBiLmRpc3Bvc2UoKTsKICAgICAgY29uc3QgZCA9IG4uZ2V0RXh0ZW5zaW9uKCJXRUJHTF9sb3NlX2NvbnRleHQiKTsKICAgICAgZCA9PSBudWxsIHx8IGQubG9zZUNvbnRleHQoKTsKICAgIH0KICB9CiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgLy8gTG9vcCBjb250cm9sCiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgc3RhcnQoKSB7CiAgICBpZiAodCh0aGlzLCBqKSAhPT0gbnVsbCkKICAgICAgcmV0dXJuOwogICAgY29uc3QgZSA9ICgpID0+IHsKICAgICAgUyh0aGlzLCBRZSwgcHQpLmNhbGwodGhpcyksIGwodGhpcywgaiwgY3QoZSkpOwogICAgfTsKICAgIGwodGhpcywgaiwgY3QoZSkpOwogIH0KICBzdG9wKCkgewogICAgdCh0aGlzLCBqKSAhPT0gbnVsbCAmJiAoaXIodCh0aGlzLCBqKSksIGwodGhpcywgaiwgbnVsbCkpOwogIH0KICBnZXQgaXNSdW5uaW5nKCkgewogICAgcmV0dXJuIHQodGhpcywgaikgIT09IG51bGw7CiAgfQp9OwpjZSA9IG5ldyBXZWFrTWFwKCksIEcgPSBuZXcgV2Vha01hcCgpLCB6ZSA9IG5ldyBXZWFrTWFwKCksIGZlID0gbmV3IFdlYWtNYXAoKSwgVWUgPSBuZXcgV2Vha01hcCgpLCBCID0gbmV3IFdlYWtNYXAoKSwgUiA9IG5ldyBXZWFrTWFwKCksICQgPSBuZXcgV2Vha01hcCgpLCBxID0gbmV3IFdlYWtNYXAoKSwgSCA9IG5ldyBXZWFrTWFwKCksIEsgPSBuZXcgV2Vha01hcCgpLCBMID0gbmV3IFdlYWtNYXAoKSwgWSA9IG5ldyBXZWFrTWFwKCksIFYgPSBuZXcgV2Vha01hcCgpLCBEZSA9IG5ldyBXZWFrTWFwKCksIHZlID0gbmV3IFdlYWtNYXAoKSwgX2UgPSBuZXcgV2Vha01hcCgpLCBPID0gbmV3IFdlYWtNYXAoKSwgVCA9IG5ldyBXZWFrTWFwKCksIG9lID0gbmV3IFdlYWtNYXAoKSwgUSA9IG5ldyBXZWFrTWFwKCksIGFlID0gbmV3IFdlYWtNYXAoKSwgeiA9IG5ldyBXZWFrTWFwKCksIHhlID0gbmV3IFdlYWtNYXAoKSwgcGUgPSBuZXcgV2Vha01hcCgpLCBtZSA9IG5ldyBXZWFrTWFwKCksIGRlID0gbmV3IFdlYWtNYXAoKSwgaGUgPSBuZXcgV2Vha01hcCgpLCBKID0gbmV3IFdlYWtNYXAoKSwgWiA9IG5ldyBXZWFrTWFwKCksIGdlID0gbmV3IFdlYWtNYXAoKSwgYmUgPSBuZXcgV2Vha01hcCgpLCBUZSA9IG5ldyBXZWFrTWFwKCksIHcgPSBuZXcgV2Vha01hcCgpLCBVID0gbmV3IFdlYWtNYXAoKSwgTSA9IG5ldyBXZWFrTWFwKCksIEkgPSBuZXcgV2Vha01hcCgpLCBQID0gbmV3IFdlYWtNYXAoKSwgQ2UgPSBuZXcgV2Vha01hcCgpLCBlZSA9IG5ldyBXZWFrTWFwKCksIEEgPSBuZXcgV2Vha01hcCgpLCB1ZSA9IG5ldyBXZWFrTWFwKCksIHRlID0gbmV3IFdlYWtNYXAoKSwgaCA9IG5ldyBXZWFrTWFwKCksIEMgPSBuZXcgV2Vha01hcCgpLCBqID0gbmV3IFdlYWtNYXAoKSwgeWUgPSBuZXcgV2Vha01hcCgpLCBYZSA9IG5ldyBXZWFrTWFwKCksIFNlID0gbmV3IFdlYWtNYXAoKSwgWWUgPSBuZXcgV2Vha1NldCgpLCB4dCA9IGZ1bmN0aW9uKGUpIHsKICBjb25zdCB7IGRldmljZTogciwgZm9ybWF0OiBzIH0gPSBlOwogIGwodGhpcywgRGUsIEh0KHIsIHMsIHQodGhpcywgU2UpKSksIGwodGhpcywgdmUsICR0KHIpKSwgbCh0aGlzLCBfZSwgWXQocikpLCBsKHRoaXMsIHhlLCBXKHIsIDE2KSksIGwodGhpcywgcGUsIFcociwgMTYpKSwgbCh0aGlzLCBtZSwgVyhyLCAxNikpLCBsKHRoaXMsIGRlLCBXKHIsIDE2KSksIGwodGhpcywgaGUsIFcociwgMTYpKSwgbCh0aGlzLCBKLCBXKHIsIDQ4KSksIGwodGhpcywgWiwgVyhyLCA0OCkpLCBsKHRoaXMsIGdlLCBXKHIsIDE2KSksIGwodGhpcywgYmUsIFcociwgMTYpKSwgbCh0aGlzLCBUZSwgVyhyLCA2NCkpOwp9LCB3ZSA9IG5ldyBXZWFrU2V0KCksIFBlID0gZnVuY3Rpb24oKSB7CiAgY29uc3QgZSA9IHQodGhpcywgY2UpOwogICJjbGllbnRXaWR0aCIgaW4gZSAmJiBlLmNsaWVudFdpZHRoID4gMCA/IChsKHRoaXMsIFAsICh0eXBlb2Ygd2luZG93IDwgInUiICYmIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvIHx8IDEpICogdCh0aGlzLCBDZSkpLCBsKHRoaXMsIHcsIGUud2lkdGggPSBNYXRoLnJvdW5kKGUuY2xpZW50V2lkdGggKiB0KHRoaXMsIFApKSksIGwodGhpcywgVSwgZS5oZWlnaHQgPSBNYXRoLnJvdW5kKGUuY2xpZW50SGVpZ2h0ICogdCh0aGlzLCBQKSkpKSA6IChsKHRoaXMsIHcsIGUud2lkdGgpLCBsKHRoaXMsIFUsIGUuaGVpZ2h0KSksICEodCh0aGlzLCB3KSA9PT0gMCB8fCB0KHRoaXMsIFUpID09PSAwKSAmJiAobCh0aGlzLCBNLCBNYXRoLm1heCgxLCBNYXRoLnJvdW5kKHQodGhpcywgdykgKiB0KHRoaXMsIGVlKSkpKSwgbCh0aGlzLCBJLCBNYXRoLm1heCgxLCBNYXRoLnJvdW5kKHQodGhpcywgVSkgKiB0KHRoaXMsIGVlKSkpKSwgUyh0aGlzLCBHZSwgc3QpLmNhbGwodGhpcykpOwp9LCBHZSA9IG5ldyBXZWFrU2V0KCksIHN0ID0gZnVuY3Rpb24oKSB7CiAgaWYgKFModGhpcywgTWUsIG90KS5jYWxsKHRoaXMpLCB0KHRoaXMsIFYpKSB7CiAgICBjb25zdCB7IGRldmljZTogZSB9ID0gdCh0aGlzLCBWKSwgciA9ICJyZ2JhMTZmbG9hdCIsIHMgPSB0KHRoaXMsIE0pLCBvID0gdCh0aGlzLCBJKTsKICAgIGwodGhpcywgTywgcnQoZSwgciwgcywgbykpLCBsKHRoaXMsIFQsIHJ0KGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBRLCBydChlLCByLCBzLCBvKSksIGwodGhpcywgb2UsIEhlKGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBhZSwgSGUoZSwgciwgcywgbykpOwogIH0gZWxzZSB7CiAgICBjb25zdCBlID0gdCh0aGlzLCBHKSwgciA9IHQodGhpcywgemUpLCBzID0gdCh0aGlzLCBNKSwgbyA9IHQodGhpcywgSSk7CiAgICBsKHRoaXMsIEIsIHR0KGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBSLCB0dChlLCByLCBzLCBvKSksIGwodGhpcywgcSwgdHQoZSwgciwgcywgbykpLCBsKHRoaXMsICQsIHFlKGUsIHIsIHMsIG8pKSwgbCh0aGlzLCBILCBxZShlLCByLCBzLCBvKSk7CiAgfQp9LCBuZSA9IG5ldyBXZWFrU2V0KCksIEVlID0gZnVuY3Rpb24oKSB7CiAgaWYgKCEoIXQodGhpcywgQykgfHwgdCh0aGlzLCB3KSA9PT0gMCB8fCB0KHRoaXMsIFUpID09PSAwKSkgewogICAgaWYgKFModGhpcywgSWUsIGF0KS5jYWxsKHRoaXMpLCB0KHRoaXMsIFYpKSB7CiAgICAgIGNvbnN0IHsgZGV2aWNlOiBlIH0gPSB0KHRoaXMsIFYpOwogICAgICB0KHRoaXMsIEMpLnR5cGUgPT09ICJ0ZXh0IiA/IGwodGhpcywgeiwgZXIoCiAgICAgICAgZSwKICAgICAgICB0KHRoaXMsIHcpLAogICAgICAgIHQodGhpcywgVSksCiAgICAgICAgdCh0aGlzLCBDKS5vcHRzLAogICAgICAgIHQodGhpcywgQSksCiAgICAgICAgdCh0aGlzLCB1ZSkKICAgICAgKSkgOiBsKHRoaXMsIHosIHRyKAogICAgICAgIGUsCiAgICAgICAgdCh0aGlzLCBDKS5iaXRtYXAsCiAgICAgICAgdCh0aGlzLCB3KSwKICAgICAgICB0KHRoaXMsIFUpLAogICAgICAgIHQodGhpcywgQykuZWZmZWN0LAogICAgICAgIHQodGhpcywgQykuc2l6ZSwKICAgICAgICB0KHRoaXMsIEEpLAogICAgICAgIHQodGhpcywgdWUpCiAgICAgICkpOwogICAgfSBlbHNlIHsKICAgICAgY29uc3QgZSA9IHQodGhpcywgRyk7CiAgICAgIGlmICh0KHRoaXMsIEMpLnR5cGUgPT09ICJ0ZXh0IikgewogICAgICAgIGNvbnN0IHsgYmFja2dyb3VuZFRleDogciwgb2JzdGFjbGVUZXg6IHMsIGNvdmVyYWdlVGV4OiBvIH0gPSBKdCgKICAgICAgICAgIGUsCiAgICAgICAgICB0KHRoaXMsIHcpLAogICAgICAgICAgdCh0aGlzLCBVKSwKICAgICAgICAgIHQodGhpcywgQykub3B0cywKICAgICAgICAgIHQodGhpcywgQSksCiAgICAgICAgICB0KHRoaXMsIHVlKQogICAgICAgICk7CiAgICAgICAgbCh0aGlzLCBLLCByKSwgbCh0aGlzLCBMLCBzKSwgbCh0aGlzLCBZLCBvKTsKICAgICAgfSBlbHNlIHsKICAgICAgICBjb25zdCB7IGJhY2tncm91bmRUZXg6IHIsIG9ic3RhY2xlVGV4OiBzLCBjb3ZlcmFnZVRleDogbyB9ID0gWnQoCiAgICAgICAgICBlLAogICAgICAgICAgdCh0aGlzLCBDKS5iaXRtYXAsCiAgICAgICAgICB0KHRoaXMsIHcpLAogICAgICAgICAgdCh0aGlzLCBVKSwKICAgICAgICAgIHQodGhpcywgQykuZWZmZWN0LAogICAgICAgICAgdCh0aGlzLCBDKS5zaXplLAogICAgICAgICAgdCh0aGlzLCBBKSwKICAgICAgICAgIHQodGhpcywgdWUpCiAgICAgICAgKTsKICAgICAgICBsKHRoaXMsIEssIHIpLCBsKHRoaXMsIEwsIHMpLCBsKHRoaXMsIFksIG8pOwogICAgICB9CiAgICB9CiAgICBsKHRoaXMsIHllLCAhMCk7CiAgfQp9LCBSZSA9IG5ldyBXZWFrU2V0KCksIEZlID0gZnVuY3Rpb24oKSB7CiAgdCh0aGlzLCB5ZSkgJiYgIXRoaXMuaXNSdW5uaW5nICYmIHRoaXMuc3RhcnQoKTsKfSwgTWUgPSBuZXcgV2Vha1NldCgpLCBvdCA9IGZ1bmN0aW9uKCkgewogIHZhciBlLCByLCBzLCBvLCBhLCB1LCB2LCBtOwogIGlmICh0KHRoaXMsIFYpKQogICAgKGUgPSB0KHRoaXMsIE8pKSA9PSBudWxsIHx8IGUuZGlzcG9zZSgpLCAociA9IHQodGhpcywgVCkpID09IG51bGwgfHwgci5kaXNwb3NlKCksIChzID0gdCh0aGlzLCBRKSkgPT0gbnVsbCB8fCBzLmRpc3Bvc2UoKSwgKG8gPSB0KHRoaXMsIG9lKSkgPT0gbnVsbCB8fCBvLnRleC5kZXN0cm95KCksIChhID0gdCh0aGlzLCBhZSkpID09IG51bGwgfHwgYS50ZXguZGVzdHJveSgpLCBsKHRoaXMsIE8sIGwodGhpcywgVCwgbCh0aGlzLCBRLCBudWxsKSkpLCBsKHRoaXMsIG9lLCBsKHRoaXMsIGFlLCBudWxsKSk7CiAgZWxzZSB7CiAgICBjb25zdCBjID0gdCh0aGlzLCBHKTsKICAgICh1ID0gdCh0aGlzLCBCKSkgPT0gbnVsbCB8fCB1LmRpc3Bvc2UoKSwgKHYgPSB0KHRoaXMsIFIpKSA9PSBudWxsIHx8IHYuZGlzcG9zZSgpLCAobSA9IHQodGhpcywgcSkpID09IG51bGwgfHwgbS5kaXNwb3NlKCksIHQodGhpcywgJCkgJiYgKGMuZGVsZXRlVGV4dHVyZSh0KHRoaXMsICQpLnRleCksIGMuZGVsZXRlRnJhbWVidWZmZXIodCh0aGlzLCAkKS5mYm8pKSwgdCh0aGlzLCBIKSAmJiAoYy5kZWxldGVUZXh0dXJlKHQodGhpcywgSCkudGV4KSwgYy5kZWxldGVGcmFtZWJ1ZmZlcih0KHRoaXMsIEgpLmZibykpLCBsKHRoaXMsIEIsIGwodGhpcywgUiwgbCh0aGlzLCBxLCBsKHRoaXMsICQsIGwodGhpcywgSCwgbnVsbCkpKSkpOwogIH0KfSwgSWUgPSBuZXcgV2Vha1NldCgpLCBhdCA9IGZ1bmN0aW9uKCkgewogIGlmICh0KHRoaXMsIFYpKQogICAgdCh0aGlzLCB6KSAmJiAodCh0aGlzLCB6KS5iYWNrZ3JvdW5kVGV4LmRlc3Ryb3koKSwgdCh0aGlzLCB6KS5vYnN0YWNsZVRleC5kZXN0cm95KCksIHQodGhpcywgeikuc2hhcmVkQ292ZXJhZ2UgfHwgdCh0aGlzLCB6KS5jb3ZlcmFnZVRleC5kZXN0cm95KCksIGwodGhpcywgeiwgbnVsbCkpOwogIGVsc2UgewogICAgY29uc3QgZSA9IHQodGhpcywgRyk7CiAgICB0KHRoaXMsIEspICYmIGUuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIEspKSwgdCh0aGlzLCBMKSAmJiBlLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBMKSksIHQodGhpcywgWSkgJiYgdCh0aGlzLCBZKSAhPT0gdCh0aGlzLCBMKSAmJiBlLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBZKSksIGwodGhpcywgSywgbCh0aGlzLCBMLCBsKHRoaXMsIFksIG51bGwpKSk7CiAgfQp9LCBRZSA9IG5ldyBXZWFrU2V0KCksIHB0ID0gZnVuY3Rpb24oKSB7CiAgIXQodGhpcywgeWUpIHx8IHQodGhpcywgdykgPT09IDAgfHwgKHQodGhpcywgVikgPyBTKHRoaXMsIGplLCBtdCkuY2FsbCh0aGlzKSA6IFModGhpcywgWmUsIGd0KS5jYWxsKHRoaXMpKTsKfSwgamUgPSBuZXcgV2Vha1NldCgpLCBtdCA9IGZ1bmN0aW9uKCkgewogIGNvbnN0IGUgPSB0KHRoaXMsIFYpLCByID0gZS5kZXZpY2UsIHMgPSB0KHRoaXMsIERlKSwgbyA9IHQodGhpcywgdmUpLCBhID0gdCh0aGlzLCBfZSksIHUgPSB0KHRoaXMsIHRlKSwgdiA9IHQodGhpcywgeik7CiAgaWYgKCF0KHRoaXMsIE8pIHx8ICF0KHRoaXMsIFQpKQogICAgcmV0dXJuOwogIHQodGhpcywgaCkueCArPSAodCh0aGlzLCBoKS50YXJnZXRYIC0gdCh0aGlzLCBoKS54KSAqIDAuMTUsIHQodGhpcywgaCkueSArPSAodCh0aGlzLCBoKS50YXJnZXRZIC0gdCh0aGlzLCBoKS55KSAqIDAuMTU7CiAgY29uc3QgbSA9IHQodGhpcywgTSksIGMgPSB0KHRoaXMsIEkpLCBwID0gdCh0aGlzLCB3KSwgeCA9IHQodGhpcywgVSksIG4gPSAxIC8gbSwgZCA9IDEgLyBjOwogIGx0KHIsIHQodGhpcywgeGUpLCBuLCBkLCBWZSwgdS52ZWxvY2l0eURpc3NpcGF0aW9uKSwgTmUociwgdCh0aGlzLCBtZSksIG4sIGQpLCBOZShyLCB0KHRoaXMsIGRlKSwgbiwgZCksIE5lKHIsIHQodGhpcywgaGUpLCBuLCBkKSwgTmUociwgdCh0aGlzLCBnZSksIG4sIGQpLCBRdChyLCB0KHRoaXMsIGJlKSwgbiwgZCwgdS5jdXJsLCBWZSksIGp0KAogICAgciwKICAgIHQodGhpcywgVGUpLAogICAgMSAvIHAsCiAgICAxIC8geCwKICAgIHUucmVmcmFjdGlvbiwKICAgIHUuc3BlY3VsYXJFeHAsCiAgICBXZSh1LndhdGVyQ29sb3IpLAogICAgV2UodS5nbG93Q29sb3IpLAogICAgdS5zaGluZSwKICAgIHUud2FycFN0cmVuZ3RoID8/IDAuMDE1LAogICAgZnRbdS5hbGdvcml0aG1dID8/IDAsCiAgICB0KHRoaXMsIFNlKQogICk7CiAgY29uc3QgYiA9IHIuY3JlYXRlQ29tbWFuZEVuY29kZXIoKSwgeSA9IChnLCBfKSA9PiByLmNyZWF0ZUJpbmRHcm91cCh7IGxheW91dDogZy5nZXRCaW5kR3JvdXBMYXlvdXQoMCksIGVudHJpZXM6IF8gfSksIEQgPSB7IGJpbmRpbmc6IDEsIHJlc291cmNlOiBhIH07CiAgewogICAgY29uc3QgZyA9IHkocy5hZHZlY3Rpb24sIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgeGUpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiAzLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiA0LCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuYWR2ZWN0aW9uLCBnLCBvLCB0KHRoaXMsIFQpLndyaXRlLnZpZXcpOwogIH0KICB0KHRoaXMsIFQpLnN3YXAoKTsKICB7CiAgICBsdChyLCB0KHRoaXMsIHBlKSwgbiwgZCwgVmUsIHUuZGVuc2l0eURpc3NpcGF0aW9uKTsKICAgIGNvbnN0IGcgPSB5KHMuYWR2ZWN0aW9uLCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIHBlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHQodGhpcywgTykucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogNCwgcmVzb3VyY2U6IHYub2JzdGFjbGVWaWV3IH0KICAgIF0pOwogICAgWChiLCBzLmFkdmVjdGlvbiwgZywgbywgdCh0aGlzLCBPKS53cml0ZS52aWV3KTsKICB9CiAgdCh0aGlzLCBPKS5zd2FwKCk7CiAgewogICAgY29uc3QgZyA9IHkocy5jdXJsLCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIGdlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0KICAgIF0pOwogICAgWChiLCBzLmN1cmwsIGcsIG8sIHQodGhpcywgYWUpLnZpZXcpOwogIH0KICB7CiAgICBjb25zdCBnID0geShzLnZvcnRpY2l0eSwgWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBiZSkgfSB9LAogICAgICBELAogICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIFQpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDMsIHJlc291cmNlOiB0KHRoaXMsIGFlKS52aWV3IH0KICAgIF0pOwogICAgWChiLCBzLnZvcnRpY2l0eSwgZywgbywgdCh0aGlzLCBUKS53cml0ZS52aWV3KTsKICB9CiAgaWYgKHQodGhpcywgVCkuc3dhcCgpLCB0KHRoaXMsIGgpLm1vdmVkKSB7CiAgICBjb25zdCBnID0gdCh0aGlzLCBoKS54ICogdCh0aGlzLCBQKSAvIHAsIF8gPSB0KHRoaXMsIGgpLnkgKiB0KHRoaXMsIFApIC8geDsKICAgICRlKAogICAgICByLAogICAgICB0KHRoaXMsIEopLAogICAgICBuLAogICAgICBkLAogICAgICBwIC8geCwKICAgICAgdS5zcGxhdFJhZGl1cywKICAgICAgdCh0aGlzLCBoKS5keCAqIHUuc3BsYXRGb3JjZSwKICAgICAgdCh0aGlzLCBoKS5keSAqIHUuc3BsYXRGb3JjZSwKICAgICAgMCwKICAgICAgZywKICAgICAgXwogICAgKTsKICAgIHsKICAgICAgY29uc3QgRiA9IHkocy5zcGxhdCwgWwogICAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIEopIH0gfSwKICAgICAgICBELAogICAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0KICAgICAgXSk7CiAgICAgIFgoYiwgcy5zcGxhdCwgRiwgbywgdCh0aGlzLCBUKS53cml0ZS52aWV3KTsKICAgIH0KICAgIHQodGhpcywgVCkuc3dhcCgpLCAkZSgKICAgICAgciwKICAgICAgdCh0aGlzLCBaKSwKICAgICAgbiwKICAgICAgZCwKICAgICAgcCAvIHgsCiAgICAgIHUuc3BsYXRSYWRpdXMsCiAgICAgIDEsCiAgICAgIDEsCiAgICAgIDEsCiAgICAgIGcsCiAgICAgIF8KICAgICk7CiAgICB7CiAgICAgIGNvbnN0IEYgPSB5KHMuc3BsYXQsIFsKICAgICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBaKSB9IH0sCiAgICAgICAgRCwKICAgICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIE8pLnJlYWQudmlldyB9CiAgICAgIF0pOwogICAgICBYKGIsIHMuc3BsYXQsIEYsIG8sIHQodGhpcywgTykud3JpdGUudmlldyk7CiAgICB9CiAgICB0KHRoaXMsIE8pLnN3YXAoKSwgdCh0aGlzLCBoKS5tb3ZlZCA9ICExOwogIH0KICB7CiAgICBjb25zdCBnID0geShzLmRpdmVyZ2VuY2UsIFsKICAgICAgeyBiaW5kaW5nOiAwLCByZXNvdXJjZTogeyBidWZmZXI6IHQodGhpcywgbWUpIH0gfSwKICAgICAgRCwKICAgICAgeyBiaW5kaW5nOiAyLCByZXNvdXJjZTogdCh0aGlzLCBUKS5yZWFkLnZpZXcgfSwKICAgICAgeyBiaW5kaW5nOiAzLCByZXNvdXJjZTogdi5vYnN0YWNsZVZpZXcgfQogICAgXSk7CiAgICBYKGIsIHMuZGl2ZXJnZW5jZSwgZywgbywgdCh0aGlzLCBvZSkudmlldyk7CiAgfQogIGZvciAobGV0IGcgPSAwOyBnIDwgdS5wcmVzc3VyZUl0ZXJhdGlvbnM7IGcrKykgewogICAgY29uc3QgXyA9IHkocy5wcmVzc3VyZSwgWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBkZSkgfSB9LAogICAgICBELAogICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIFEpLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDMsIHJlc291cmNlOiB0KHRoaXMsIG9lKS52aWV3IH0sCiAgICAgIHsgYmluZGluZzogNCwgcmVzb3VyY2U6IHYub2JzdGFjbGVWaWV3IH0KICAgIF0pOwogICAgWChiLCBzLnByZXNzdXJlLCBfLCBvLCB0KHRoaXMsIFEpLndyaXRlLnZpZXcpLCB0KHRoaXMsIFEpLnN3YXAoKTsKICB9CiAgewogICAgY29uc3QgZyA9IHkocy5ncmFkaWVudFN1YnRyYWN0LCBbCiAgICAgIHsgYmluZGluZzogMCwgcmVzb3VyY2U6IHsgYnVmZmVyOiB0KHRoaXMsIGhlKSB9IH0sCiAgICAgIEQsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgUSkucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogMywgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0sCiAgICAgIHsgYmluZGluZzogNCwgcmVzb3VyY2U6IHYub2JzdGFjbGVWaWV3IH0KICAgIF0pOwogICAgWChiLCBzLmdyYWRpZW50U3VidHJhY3QsIGcsIG8sIHQodGhpcywgVCkud3JpdGUudmlldyk7CiAgfQogIHQodGhpcywgVCkuc3dhcCgpOwogIHsKICAgIGNvbnN0IGcgPSBlLmNvbnRleHQuZ2V0Q3VycmVudFRleHR1cmUoKS5jcmVhdGVWaWV3KCksIF8gPSB5KHMuZGlzcGxheSwgWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBUZSkgfSB9LAogICAgICBELAogICAgICB7IGJpbmRpbmc6IDIsIHJlc291cmNlOiB0KHRoaXMsIE8pLnJlYWQudmlldyB9LAogICAgICB7IGJpbmRpbmc6IDMsIHJlc291cmNlOiB2Lm9ic3RhY2xlVmlldyB9LAogICAgICB7IGJpbmRpbmc6IDQsIHJlc291cmNlOiB2LmJhY2tncm91bmRWaWV3IH0sCiAgICAgIHsgYmluZGluZzogNSwgcmVzb3VyY2U6IHYuY292ZXJhZ2VWaWV3IH0sCiAgICAgIHsgYmluZGluZzogNiwgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0KICAgIF0pOwogICAgS3QoYiwgcy5kaXNwbGF5LCBfLCBvLCBnKTsKICB9CiAgci5xdWV1ZS5zdWJtaXQoW2IuZmluaXNoKCldKTsKfSwgS2UgPSBuZXcgV2Vha1NldCgpLCBkdCA9IGZ1bmN0aW9uKGUsIHIsIHMsIG8sIGEpIHsKICBjb25zdCB2ID0gdCh0aGlzLCBWKS5kZXZpY2UsIG0gPSB0KHRoaXMsIERlKS5zcGxhdCwgYyA9IHQodGhpcywgdmUpLCBwID0gdCh0aGlzLCBfZSksIHggPSB0KHRoaXMsIHRlKSwgbiA9IHQodGhpcywgTSksIGQgPSB0KHRoaXMsIEkpLCBiID0gMSAvIG4sIHkgPSAxIC8gZCwgRCA9IHYuY3JlYXRlQ29tbWFuZEVuY29kZXIoKSwgZyA9IHsgYmluZGluZzogMSwgcmVzb3VyY2U6IHAgfSwgXyA9IChPZSkgPT4gdi5jcmVhdGVCaW5kR3JvdXAoeyBsYXlvdXQ6IG0uZ2V0QmluZEdyb3VwTGF5b3V0KDApLCBlbnRyaWVzOiBPZSB9KSwgRiA9IGUgKiB0KHRoaXMsIFApIC8gdCh0aGlzLCB3KSwgayA9IHIgKiB0KHRoaXMsIFApIC8gdCh0aGlzLCBVKTsKICAkZSgKICAgIHYsCiAgICB0KHRoaXMsIEopLAogICAgYiwKICAgIHksCiAgICB0KHRoaXMsIHcpIC8gdCh0aGlzLCBVKSwKICAgIHguc3BsYXRSYWRpdXMsCiAgICBzICogeC5zcGxhdEZvcmNlICogYSwKICAgIG8gKiB4LnNwbGF0Rm9yY2UgKiBhLAogICAgMCwKICAgIEYsCiAgICBrCiAgKTsKICB7CiAgICBjb25zdCBPZSA9IF8oWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBKKSB9IH0sCiAgICAgIGcsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgVCkucmVhZC52aWV3IH0KICAgIF0pOwogICAgWChELCBtLCBPZSwgYywgdCh0aGlzLCBUKS53cml0ZS52aWV3KTsKICB9CiAgdCh0aGlzLCBUKS5zd2FwKCksICRlKAogICAgdiwKICAgIHQodGhpcywgWiksCiAgICBiLAogICAgeSwKICAgIHQodGhpcywgdykgLyB0KHRoaXMsIFUpLAogICAgeC5zcGxhdFJhZGl1cywKICAgIGEsCiAgICBhLAogICAgYSwKICAgIEYsCiAgICBrCiAgKTsKICB7CiAgICBjb25zdCBPZSA9IF8oWwogICAgICB7IGJpbmRpbmc6IDAsIHJlc291cmNlOiB7IGJ1ZmZlcjogdCh0aGlzLCBaKSB9IH0sCiAgICAgIGcsCiAgICAgIHsgYmluZGluZzogMiwgcmVzb3VyY2U6IHQodGhpcywgTykucmVhZC52aWV3IH0KICAgIF0pOwogICAgWChELCBtLCBPZSwgYywgdCh0aGlzLCBPKS53cml0ZS52aWV3KTsKICB9CiAgdCh0aGlzLCBPKS5zd2FwKCksIHYucXVldWUuc3VibWl0KFtELmZpbmlzaCgpXSk7Cn0sIEplID0gbmV3IFdlYWtTZXQoKSwgaHQgPSBmdW5jdGlvbihlLCByLCBzLCBvLCBhKSB7CiAgY29uc3QgdSA9IHQodGhpcywgRyksIHYgPSB0KHRoaXMsIHRlKSwgbSA9IHQodGhpcywgZmUpLnNwbGF0LCBjID0gdCh0aGlzLCBVZSk7CiAgdS52aWV3cG9ydCgwLCAwLCB0KHRoaXMsIE0pLCB0KHRoaXMsIEkpKSwgbS5iaW5kKCksIHUudW5pZm9ybTFmKG0udW5pZm9ybXMuYXNwZWN0UmF0aW8sIHQodGhpcywgdykgLyB0KHRoaXMsIFUpKSwgdS51bmlmb3JtMmYobS51bmlmb3Jtcy5wb2ludCwgZSAqIHQodGhpcywgUCkgLyB0KHRoaXMsIHcpLCAxIC0gciAqIHQodGhpcywgUCkgLyB0KHRoaXMsIFUpKSwgdS51bmlmb3JtMWYobS51bmlmb3Jtcy5yYWRpdXMsIHYuc3BsYXRSYWRpdXMpLCB1LnVuaWZvcm0xaShtLnVuaWZvcm1zLnVUYXJnZXQsIDApLCB1LmFjdGl2ZVRleHR1cmUodS5URVhUVVJFMCksIHUuYmluZFRleHR1cmUodS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgdS51bmlmb3JtM2YobS51bmlmb3Jtcy5jb2xvciwgcyAqIHYuc3BsYXRGb3JjZSAqIGEsIC1vICogdi5zcGxhdEZvcmNlICogYSwgMCksIGModCh0aGlzLCBSKS53cml0ZS5mYm8pLCB0KHRoaXMsIFIpLnN3YXAoKSwgdS5hY3RpdmVUZXh0dXJlKHUuVEVYVFVSRTApLCB1LmJpbmRUZXh0dXJlKHUuVEVYVFVSRV8yRCwgdCh0aGlzLCBCKS5yZWFkLnRleCksIHUudW5pZm9ybTNmKG0udW5pZm9ybXMuY29sb3IsIGEsIGEsIGEpLCBjKHQodGhpcywgQikud3JpdGUuZmJvKSwgdCh0aGlzLCBCKS5zd2FwKCk7Cn0sIFplID0gbmV3IFdlYWtTZXQoKSwgZ3QgPSBmdW5jdGlvbigpIHsKICBpZiAoIXQodGhpcywgQikgfHwgIXQodGhpcywgUikpCiAgICByZXR1cm47CiAgY29uc3QgZSA9IHQodGhpcywgRyksIHIgPSB0KHRoaXMsIHRlKSwgeyBhZHZlY3Rpb246IHMsIGRpdmVyZ2VuY2U6IG8sIHByZXNzdXJlOiBhLCBncmFkaWVudFN1YnRyYWN0OiB1LCBzcGxhdDogdiwgY3VybDogbSwgdm9ydGljaXR5OiBjLCBkaXNwbGF5OiBwIH0gPSB0KHRoaXMsIGZlKTsKICB0KHRoaXMsIGgpLnggKz0gKHQodGhpcywgaCkudGFyZ2V0WCAtIHQodGhpcywgaCkueCkgKiAwLjE1LCB0KHRoaXMsIGgpLnkgKz0gKHQodGhpcywgaCkudGFyZ2V0WSAtIHQodGhpcywgaCkueSkgKiAwLjE1OwogIGNvbnN0IHggPSB0KHRoaXMsIE0pLCBuID0gdCh0aGlzLCBJKSwgZCA9IHQodGhpcywgVWUpOwogIGUudmlld3BvcnQoMCwgMCwgeCwgbiksIHMuYmluZCgpLCBlLnVuaWZvcm0yZihzLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHgsIDEgLyBuKSwgZS51bmlmb3JtMWYocy51bmlmb3Jtcy5kdCwgVmUpLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVPYnN0YWNsZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgTCkpLCBlLnVuaWZvcm0xZihzLnVuaWZvcm1zLmRpc3NpcGF0aW9uLCByLnZlbG9jaXR5RGlzc2lwYXRpb24pLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVWZWxvY2l0eSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShzLnVuaWZvcm1zLnVTb3VyY2UsIDEpLCBkKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIGUudW5pZm9ybTFmKHMudW5pZm9ybXMuZGlzc2lwYXRpb24sIHIuZGVuc2l0eURpc3NpcGF0aW9uKSwgZS51bmlmb3JtMWkocy51bmlmb3Jtcy51U291cmNlLCAyKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTIpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBCKS5yZWFkLnRleCksIGQodCh0aGlzLCBCKS53cml0ZS5mYm8pLCB0KHRoaXMsIEIpLnN3YXAoKSwgbS5iaW5kKCksIGUudW5pZm9ybTJmKG0udW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geCwgMSAvIG4pLCBlLnVuaWZvcm0xaShtLnVuaWZvcm1zLnVWZWxvY2l0eSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUikucmVhZC50ZXgpLCBkKHQodGhpcywgSCkuZmJvKSwgYy5iaW5kKCksIGUudW5pZm9ybTJmKGMudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8geCwgMSAvIG4pLCBlLnVuaWZvcm0xZihjLnVuaWZvcm1zLmN1cmwsIHIuY3VybCksIGUudW5pZm9ybTFmKGMudW5pZm9ybXMuZHQsIFZlKSwgZS51bmlmb3JtMWkoYy51bmlmb3Jtcy51VmVsb2NpdHksIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkoYy51bmlmb3Jtcy51Q3VybCwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgSCkudGV4KSwgZCh0KHRoaXMsIFIpLndyaXRlLmZibyksIHQodGhpcywgUikuc3dhcCgpLCB0KHRoaXMsIGgpLm1vdmVkICYmICh2LmJpbmQoKSwgZS51bmlmb3JtMWYodi51bmlmb3Jtcy5hc3BlY3RSYXRpbywgdCh0aGlzLCB3KSAvIHQodGhpcywgVSkpLCBlLnVuaWZvcm0yZih2LnVuaWZvcm1zLnBvaW50LCB0KHRoaXMsIGgpLnggKiB0KHRoaXMsIFApIC8gdCh0aGlzLCB3KSwgMSAtIHQodGhpcywgaCkueSAqIHQodGhpcywgUCkgLyB0KHRoaXMsIFUpKSwgZS51bmlmb3JtMWYodi51bmlmb3Jtcy5yYWRpdXMsIHIuc3BsYXRSYWRpdXMpLCBlLnVuaWZvcm0xaSh2LnVuaWZvcm1zLnVUYXJnZXQsIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtM2Yodi51bmlmb3Jtcy5jb2xvciwgdCh0aGlzLCBoKS5keCAqIHIuc3BsYXRGb3JjZSwgLXQodGhpcywgaCkuZHkgKiByLnNwbGF0Rm9yY2UsIDApLCBkKHQodGhpcywgUikud3JpdGUuZmJvKSwgdCh0aGlzLCBSKS5zd2FwKCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgQikucmVhZC50ZXgpLCBlLnVuaWZvcm0zZih2LnVuaWZvcm1zLmNvbG9yLCAxLCAxLCAxKSwgZCh0KHRoaXMsIEIpLndyaXRlLmZibyksIHQodGhpcywgQikuc3dhcCgpLCB0KHRoaXMsIGgpLm1vdmVkID0gITEpLCBvLmJpbmQoKSwgZS51bmlmb3JtMmYoby51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB4LCAxIC8gbiksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudVZlbG9jaXR5LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBSKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudU9ic3RhY2xlLCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBMKSksIGQodCh0aGlzLCAkKS5mYm8pLCBhLmJpbmQoKSwgZS51bmlmb3JtMmYoYS51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB4LCAxIC8gbiksIGUudW5pZm9ybTFpKGEudW5pZm9ybXMudURpdmVyZ2VuY2UsIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsICQpLnRleCksIGUudW5pZm9ybTFpKGEudW5pZm9ybXMudU9ic3RhY2xlLCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBMKSk7CiAgZm9yIChsZXQgYiA9IDA7IGIgPCByLnByZXNzdXJlSXRlcmF0aW9uczsgYisrKQogICAgZS51bmlmb3JtMWkoYS51bmlmb3Jtcy51UHJlc3N1cmUsIDIpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIHEpLnJlYWQudGV4KSwgZCh0KHRoaXMsIHEpLndyaXRlLmZibyksIHQodGhpcywgcSkuc3dhcCgpOwogIHUuYmluZCgpLCBlLnVuaWZvcm0yZih1LnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHgsIDEgLyBuKSwgZS51bmlmb3JtMWkodS51bmlmb3Jtcy51UHJlc3N1cmUsIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIHEpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkodS51bmlmb3Jtcy51VmVsb2NpdHksIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFIpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkodS51bmlmb3Jtcy51T2JzdGFjbGUsIDIpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKSwgZCh0KHRoaXMsIFIpLndyaXRlLmZibyksIHQodGhpcywgUikuc3dhcCgpLCBlLnZpZXdwb3J0KDAsIDAsIHQodGhpcywgdyksIHQodGhpcywgVSkpLCBlLmJpbmRGcmFtZWJ1ZmZlcihlLkZSQU1FQlVGRkVSLCBudWxsKSwgZS5jbGVhcihlLkNPTE9SX0JVRkZFUl9CSVQpLCBwLmJpbmQoKSwgZS51bmlmb3JtMmYocC51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyB0KHRoaXMsIHcpLCAxIC8gdCh0aGlzLCBVKSksIGUudW5pZm9ybTNmdihwLnVuaWZvcm1zLnVXYXRlckNvbG9yLCBXZShyLndhdGVyQ29sb3IpKSwgZS51bmlmb3JtM2Z2KHAudW5pZm9ybXMudUdsb3dDb2xvciwgV2Uoci5nbG93Q29sb3IpKSwgZS51bmlmb3JtMWYocC51bmlmb3Jtcy51UmVmcmFjdGlvbiwgci5yZWZyYWN0aW9uKSwgZS51bmlmb3JtMWYocC51bmlmb3Jtcy51U3BlY3VsYXJFeHAsIHIuc3BlY3VsYXJFeHApLCBlLnVuaWZvcm0xZihwLnVuaWZvcm1zLnVTaGluZSwgci5zaGluZSksIGUudW5pZm9ybTFmKHAudW5pZm9ybXMudVdhcnBTdHJlbmd0aCwgci53YXJwU3RyZW5ndGggPz8gMC4wMTUpLCBlLnVuaWZvcm0xaShwLnVuaWZvcm1zLnVBbGdvcml0aG0sIGZ0W3IuYWxnb3JpdGhtXSA/PyAwKSwgZS51bmlmb3JtMWkocC51bmlmb3Jtcy51RW5hYmxlQWxwaGEsIHQodGhpcywgU2UpID8gMSA6IDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEIpLnJlYWQudGV4KSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBMKSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgSykpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMyksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFkpKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTQpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBSKS5yZWFkLnRleCksIGUudW5pZm9ybTFpKHAudW5pZm9ybXMudVRleHR1cmUsIDApLCBlLnVuaWZvcm0xaShwLnVuaWZvcm1zLnVPYnN0YWNsZSwgMSksIGUudW5pZm9ybTFpKHAudW5pZm9ybXMudUJhY2tncm91bmQsIDIpLCBlLnVuaWZvcm0xaShwLnVuaWZvcm1zLnVDb3ZlcmFnZSwgMyksIGUudW5pZm9ybTFpKHAudW5pZm9ybXMudVZlbG9jaXR5LCA0KSwgZChudWxsKTsKfTsKbGV0IGl0ID0gdXQsIEUgPSBudWxsLCBidDsKY29uc3QgTiA9IG5ldyBQcm9taXNlKChpKSA9PiB7CiAgYnQgPSBpOwp9KTsKc2VsZi5vbm1lc3NhZ2UgPSBhc3luYyAoaSkgPT4gewogIGNvbnN0IHsgdHlwZTogZSwgLi4uciB9ID0gaS5kYXRhOwogIHRyeSB7CiAgICBzd2l0Y2ggKGUpIHsKICAgICAgY2FzZSAiaW5pdCI6IHsKICAgICAgICBjb25zdCB7IGNhbnZhczogcywgd2lkdGg6IG8sIGhlaWdodDogYSwgY29uZmlnOiB1LCBkcHI6IHYsIHF1YWxpdHk6IG0sIHVzZVdlYkdQVTogYywgZW5hYmxlQWxwaGE6IHAgfSA9IHI7CiAgICAgICAgcy53aWR0aCA9IG8sIHMuaGVpZ2h0ID0gYSwgRSA9IGF3YWl0IGl0LmNyZWF0ZShzLCB1LCBtID8/IHt9LCBjID8/ICEwLCBwID8/ICEwKSwgRS5yZXNpemUobywgYSwgdiB8fCAxKSwgYnQoKSwgc2VsZi5wb3N0TWVzc2FnZSh7IHR5cGU6ICJyZWFkeSIgfSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0VGV4dFNvdXJjZSI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS5zZXRUZXh0U291cmNlKHIub3B0cyk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0SW1hZ2VTb3VyY2UiOiB7CiAgICAgICAgaWYgKGF3YWl0IE4sICFFKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIGF3YWl0IEUuc2V0SW1hZ2VTb3VyY2UoCiAgICAgICAgICByLnNyYywKICAgICAgICAgIHIuZWZmZWN0LAogICAgICAgICAgci5zaXplCiAgICAgICAgKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRJbWFnZUJpdG1hcCI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS5zZXRJbWFnZUJpdG1hcCgKICAgICAgICAgIHIuYml0bWFwLAogICAgICAgICAgci5lZmZlY3QsCiAgICAgICAgICByLnNpemUKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNldEJhY2tncm91bmQiOiB7CiAgICAgICAgaWYgKGF3YWl0IE4sICFFKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIEUuc2V0QmFja2dyb3VuZChyLmJpdG1hcCwgci5zaXplKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzcGxhdCI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS5zcGxhdCgKICAgICAgICAgIHIueCwKICAgICAgICAgIHIueSwKICAgICAgICAgIHIudngsCiAgICAgICAgICByLnZ5LAogICAgICAgICAgci5zdHJlbmd0aCA/PyAxCiAgICAgICAgKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJtb3ZlIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLmhhbmRsZU1vdmUoci54LCByLnksIHIuc3RyZW5ndGggPz8gMSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAicmVzaXplIjogewogICAgICAgIGlmIChhd2FpdCBOLCAhRSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBFLnJlc2l6ZShyLndpZHRoLCByLmhlaWdodCwgci5kcHIpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInVwZGF0ZVF1YWxpdHkiOiB7CiAgICAgICAgaWYgKGF3YWl0IE4sICFFKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIEUudXBkYXRlUXVhbGl0eShyLnF1YWxpdHkpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInVwZGF0ZUNvbmZpZyI6IHsKICAgICAgICBpZiAoYXdhaXQgTiwgIUUpCiAgICAgICAgICByZXR1cm47CiAgICAgICAgRS51cGRhdGVDb25maWcoci5jb25maWcpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgImRlc3Ryb3kiOiB7CiAgICAgICAgYXdhaXQgTiwgRSA9PSBudWxsIHx8IEUuZGVzdHJveSgpLCBFID0gbnVsbDsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBkZWZhdWx0OgogICAgICAgIGNvbnNvbGUud2FybigiW2ZsdWlkaXR5LWpzIHdvcmtlcl0gVW5rbm93biBtZXNzYWdlIHR5cGU6IiwgZSk7CiAgICB9CiAgfSBjYXRjaCAocykgewogICAgc2VsZi5wb3N0TWVzc2FnZSh7IHR5cGU6ICJlcnJvciIsIG1lc3NhZ2U6IChzID09IG51bGwgPyB2b2lkIDAgOiBzLm1lc3NhZ2UpID8/IFN0cmluZyhzKSB9KTsKICB9Cn07Cg==", qI = typeof window < "u" && window.Blob && new Blob([atob(cC)], { type: "text/javascript;charset=utf-8" });
1610
+ function PC() {
1591
1611
  let e;
1592
1612
  try {
1593
- if (e = MI && (window.URL || window.webkitURL).createObjectURL(MI), !e)
1613
+ if (e = qI && (window.URL || window.webkitURL).createObjectURL(qI), !e)
1594
1614
  throw "";
1595
1615
  return new Worker(e);
1596
1616
  } catch {
1597
- return new Worker("data:application/javascript;base64," + jI, { type: "module" });
1617
+ return new Worker("data:application/javascript;base64," + cC, { type: "module" });
1598
1618
  } finally {
1599
1619
  e && (window.URL || window.webkitURL).revokeObjectURL(e);
1600
1620
  }
1601
1621
  }
1602
- const kC = typeof Worker < "u" && typeof OffscreenCanvas < "u";
1603
- var R, x, Qg, Eg, fg, P, Ag, pg, Lg, tI, HI, wI, PI;
1604
- class DC {
1622
+ const _C = typeof Worker < "u" && typeof OffscreenCanvas < "u";
1623
+ var v, f, qg, $g, Jg, q, ag, Lg, hg, rI, TI, YI, dC;
1624
+ class qC {
1605
1625
  constructor(g, {
1606
- isWorkerEnabled: C = !0,
1607
- useWebGPU: i = !0,
1608
- enableAlpha: s = !0,
1626
+ workerEnabled: C = !0,
1627
+ webGPUEnabled: i = !0,
1628
+ alphaEnabled: s = !0,
1609
1629
  quality: l = {},
1610
1630
  config: t = {}
1611
1631
  } = {}) {
@@ -1622,40 +1642,40 @@ class DC {
1622
1642
  * this is the common path in jsdom/test environments and keeps the
1623
1643
  * constructor behaviour synchronous where possible.
1624
1644
  */
1625
- A(this, tI);
1626
- A(this, wI);
1627
- A(this, R, null);
1628
- A(this, x, null);
1629
- A(this, Qg, void 0);
1630
- A(this, Eg, void 0);
1631
- A(this, fg, void 0);
1632
- A(this, P, void 0);
1633
- A(this, Ag, void 0);
1645
+ d(this, rI);
1646
+ d(this, YI);
1647
+ d(this, v, null);
1648
+ d(this, f, null);
1649
+ d(this, qg, void 0);
1650
+ d(this, $g, void 0);
1651
+ d(this, Jg, void 0);
1652
+ d(this, q, void 0);
1653
+ d(this, ag, void 0);
1634
1654
  // Pending source calls queued while WebGPU async init is in progress (main-thread only)
1635
- A(this, pg, null);
1636
- A(this, Lg, null);
1637
- o(this, P, Math.max(0.1, Math.min(1, l.dpr ?? 1))), o(this, Ag, Math.max(0.1, Math.min(1, l.sim ?? 0.5))), o(this, Eg, i), o(this, fg, s), o(this, Qg, C && kC), I(this, Qg) ? V(this, wI, PI).call(this, g, t) : V(this, tI, HI).call(this, g, t);
1655
+ d(this, Lg, null);
1656
+ d(this, hg, null);
1657
+ o(this, q, Math.max(0.1, Math.min(1, l.dpr ?? 1))), o(this, ag, Math.max(0.1, Math.min(1, l.sim ?? 0.5))), o(this, $g, i), o(this, Jg, s), o(this, qg, C && _C), I(this, qg) ? L(this, YI, dC).call(this, g, t) : L(this, rI, TI).call(this, g, t);
1638
1658
  }
1639
1659
  // ---------------------------------------------------------------------------
1640
1660
  // Source setters
1641
1661
  // ---------------------------------------------------------------------------
1642
1662
  setTextSource(g) {
1643
- I(this, R) ? I(this, R).postMessage({ type: "setTextSource", opts: g }) : I(this, x) ? I(this, x).setTextSource(g) : (o(this, pg, g), o(this, Lg, null));
1663
+ I(this, v) ? I(this, v).postMessage({ type: "setTextSource", opts: g }) : I(this, f) ? I(this, f).setTextSource(g) : (o(this, Lg, g), o(this, hg, null));
1644
1664
  }
1645
1665
  setImageSource(g, C = Gg.effect, i = Gg.imageSize) {
1646
- if (I(this, R)) {
1666
+ if (I(this, v)) {
1647
1667
  const s = new URL(g, location.href).href;
1648
- I(this, R).postMessage({ type: "setImageSource", src: s, effect: C, size: i });
1668
+ I(this, v).postMessage({ type: "setImageSource", src: s, effect: C, size: i });
1649
1669
  } else
1650
- I(this, x) ? I(this, x).setImageSource(g, C, i) : (o(this, Lg, { src: g, effect: C, size: i }), o(this, pg, null));
1670
+ I(this, f) ? I(this, f).setImageSource(g, C, i) : (o(this, hg, { src: g, effect: C, size: i }), o(this, Lg, null));
1651
1671
  }
1652
1672
  setBackground(g, C = "cover") {
1653
1673
  var i;
1654
- if (I(this, R)) {
1674
+ if (I(this, v)) {
1655
1675
  const s = g ? [g] : [];
1656
- I(this, R).postMessage({ type: "setBackground", bitmap: g ?? null, size: C }, s);
1676
+ I(this, v).postMessage({ type: "setBackground", bitmap: g ?? null, size: C }, s);
1657
1677
  } else
1658
- (i = I(this, x)) == null || i.setBackground(g ?? null, C);
1678
+ (i = I(this, f)) == null || i.setBackground(g ?? null, C);
1659
1679
  }
1660
1680
  // ---------------------------------------------------------------------------
1661
1681
  // Interaction
@@ -1665,47 +1685,47 @@ class DC {
1665
1685
  * Safe to call multiple times per frame. See FluidSimulation.splat for details.
1666
1686
  */
1667
1687
  splat(g, C, i, s, l = 1) {
1668
- 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);
1688
+ I(this, v) ? I(this, v).postMessage({ type: "splat", x: g, y: C, vx: i, vy: s, strength: l }) : I(this, f).splat(g, C, i, s, l);
1669
1689
  }
1670
1690
  handleMove(g, C, i = 1) {
1671
- I(this, R) ? I(this, R).postMessage({ type: "move", x: g, y: C, strength: i }) : I(this, x).handleMove(g, C, i);
1691
+ I(this, v) ? I(this, v).postMessage({ type: "move", x: g, y: C, strength: i }) : I(this, f).handleMove(g, C, i);
1672
1692
  }
1673
1693
  // ---------------------------------------------------------------------------
1674
1694
  // Config + control
1675
1695
  // ---------------------------------------------------------------------------
1676
1696
  updateQuality(g) {
1677
- o(this, P, Math.max(0.1, Math.min(1, g.dpr ?? I(this, P)))), o(this, Ag, Math.max(0.1, Math.min(1, g.sim ?? I(this, Ag)))), I(this, R) ? I(this, R).postMessage({ type: "updateQuality", quality: { dpr: I(this, P), sim: I(this, Ag) } }) : I(this, x).updateQuality(g);
1697
+ o(this, q, Math.max(0.1, Math.min(1, g.dpr ?? I(this, q)))), o(this, ag, Math.max(0.1, Math.min(1, g.sim ?? I(this, ag)))), I(this, v) ? I(this, v).postMessage({ type: "updateQuality", quality: { dpr: I(this, q), sim: I(this, ag) } }) : I(this, f).updateQuality(g);
1678
1698
  }
1679
1699
  updateConfig(g) {
1680
- I(this, R) ? I(this, R).postMessage({ type: "updateConfig", config: g }) : I(this, x).updateConfig(g);
1700
+ I(this, v) ? I(this, v).postMessage({ type: "updateConfig", config: g }) : I(this, f).updateConfig(g);
1681
1701
  }
1682
1702
  resize(g, C) {
1683
- const i = (typeof window < "u" && window.devicePixelRatio || 1) * I(this, P);
1684
- I(this, R) ? I(this, R).postMessage({ type: "resize", width: g, height: C, dpr: i }) : I(this, x).resize(g, C, i);
1703
+ const i = (typeof window < "u" && window.devicePixelRatio || 1) * I(this, q);
1704
+ I(this, v) ? I(this, v).postMessage({ type: "resize", width: g, height: C, dpr: i }) : I(this, f).resize(g, C, i);
1685
1705
  }
1686
1706
  destroy() {
1687
1707
  var g;
1688
- if (I(this, R)) {
1689
- const C = I(this, R);
1690
- o(this, R, null), C.postMessage({ type: "destroy" }), setTimeout(() => C.terminate(), 50);
1708
+ if (I(this, v)) {
1709
+ const C = I(this, v);
1710
+ o(this, v, null), C.postMessage({ type: "destroy" }), setTimeout(() => C.terminate(), 50);
1691
1711
  } else
1692
- (g = I(this, x)) == null || g.destroy(), o(this, x, null);
1712
+ (g = I(this, f)) == null || g.destroy(), o(this, f, null);
1693
1713
  }
1694
1714
  }
1695
- R = new WeakMap(), x = new WeakMap(), Qg = new WeakMap(), Eg = new WeakMap(), fg = new WeakMap(), P = new WeakMap(), Ag = new WeakMap(), pg = new WeakMap(), Lg = new WeakMap(), tI = new WeakSet(), HI = function(g, C) {
1696
- const i = { dpr: I(this, P), sim: I(this, Ag) };
1697
- I(this, Eg) && typeof navigator < "u" && !!navigator.gpu ? uI.create(g, C, i, !0, I(this, fg)).then((l) => {
1698
- if (o(this, x, l), I(this, pg))
1699
- l.setTextSource(I(this, pg)), o(this, pg, null);
1700
- else if (I(this, Lg)) {
1701
- const { src: t, effect: B, size: S } = I(this, Lg);
1702
- l.setImageSource(t, B, S), o(this, Lg, null);
1715
+ v = new WeakMap(), f = new WeakMap(), qg = new WeakMap(), $g = new WeakMap(), Jg = new WeakMap(), q = new WeakMap(), ag = new WeakMap(), Lg = new WeakMap(), hg = new WeakMap(), rI = new WeakSet(), TI = function(g, C) {
1716
+ const i = { dpr: I(this, q), sim: I(this, ag) };
1717
+ I(this, $g) && typeof navigator < "u" && !!navigator.gpu ? yI.create(g, C, i, !0, I(this, Jg)).then((l) => {
1718
+ if (o(this, f, l), I(this, Lg))
1719
+ l.setTextSource(I(this, Lg)), o(this, Lg, null);
1720
+ else if (I(this, hg)) {
1721
+ const { src: t, effect: S, size: u } = I(this, hg);
1722
+ l.setImageSource(t, S, u), o(this, hg, null);
1703
1723
  }
1704
1724
  }).catch((l) => {
1705
1725
  console.error("[fluidity-js] Renderer init failed:", l);
1706
- }) : o(this, x, new uI(g, C, i, void 0, I(this, fg)));
1707
- }, wI = new WeakSet(), PI = function(g, C) {
1708
- const i = (typeof window < "u" && window.devicePixelRatio || 1) * I(this, P), s = Math.round(g.clientWidth * i), l = Math.round(g.clientHeight * i);
1726
+ }) : o(this, f, new yI(g, C, i, void 0, I(this, Jg)));
1727
+ }, YI = new WeakSet(), dC = function(g, C) {
1728
+ const i = (typeof window < "u" && window.devicePixelRatio || 1) * I(this, q), s = Math.round(g.clientWidth * i), l = Math.round(g.clientHeight * i);
1709
1729
  g.width = s, g.height = l;
1710
1730
  let t;
1711
1731
  try {
@@ -1713,299 +1733,334 @@ R = new WeakMap(), x = new WeakMap(), Qg = new WeakMap(), Eg = new WeakMap(), fg
1713
1733
  } catch {
1714
1734
  console.warn(
1715
1735
  "[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
1716
- ), o(this, Qg, !1), V(this, tI, HI).call(this, g, C);
1736
+ ), o(this, qg, !1), L(this, rI, TI).call(this, g, C);
1717
1737
  return;
1718
1738
  }
1719
- const B = o(this, R, new UC());
1720
- B.onerror = (S) => {
1721
- console.error("[fluidity-js] Worker error:", S.message);
1722
- }, B.onmessage = (S) => {
1723
- S.data.type === "error" && console.error("[fluidity-js] Simulation error:", S.data.message);
1724
- }, B.postMessage(
1725
- { type: "init", canvas: t, width: s, height: l, config: C, dpr: i, quality: { dpr: I(this, P), sim: I(this, Ag) }, useWebGPU: I(this, Eg), enableAlpha: I(this, fg) },
1739
+ const S = o(this, v, new PC());
1740
+ S.onerror = (u) => {
1741
+ console.error("[fluidity-js] Worker error:", u.message);
1742
+ }, S.onmessage = (u) => {
1743
+ u.data.type === "error" && console.error("[fluidity-js] Simulation error:", u.data.message);
1744
+ }, S.postMessage(
1745
+ { type: "init", canvas: t, width: s, height: l, config: C, dpr: i, quality: { dpr: I(this, q), sim: I(this, ag) }, useWebGPU: I(this, $g), enableAlpha: I(this, Jg) },
1726
1746
  [t]
1727
1747
  );
1728
1748
  };
1729
- function _I(e, {
1730
- isWorkerEnabled: g = !0,
1731
- useWebGPU: C = !0,
1732
- enableAlpha: i = !0,
1733
- quality: s = {},
1734
- config: l = {}
1749
+ function SC(e, {
1750
+ workerEnabled: g = !0,
1751
+ webGPUEnabled: C = !0,
1752
+ alphaEnabled: i = !0,
1753
+ pixelRatio: s,
1754
+ simResolution: l,
1755
+ config: t = {}
1735
1756
  } = {}) {
1736
- const t = Tg(null), B = Tg({ isWorkerEnabled: g, quality: s, config: l }), S = Tg(Math.max(0.1, Math.min(1, s.dpr ?? 1))), c = Tg({
1737
- dpr: s.dpr,
1738
- sim: s.sim
1757
+ const S = { dpr: s, sim: l }, u = Qg(null), c = Qg({ workerEnabled: g, quality: S, config: t }), p = Qg(Math.max(0.1, Math.min(1, s ?? gI.dpr ?? 1))), a = Qg({
1758
+ pixelRatio: s,
1759
+ simResolution: l
1739
1760
  });
1740
- return sg(() => {
1741
- const u = e.current;
1742
- if (!u)
1761
+ return tg(() => {
1762
+ const A = e.current;
1763
+ if (!A)
1743
1764
  return;
1744
- const a = document.createElement("canvas");
1745
- a.id = `fluid_canvas_${Date.now()}`, a.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", u.appendChild(a);
1746
- const { isWorkerEnabled: d, quality: Z, config: n } = B.current, w = (window.devicePixelRatio || 1) * S.current, L = u.getBoundingClientRect(), m = Math.round((L.width || u.clientWidth) * w) || 0, h = Math.round((L.height || u.clientHeight) * w) || 0;
1747
- m > 0 && (a.width = m, a.height = h), h === 0 && console.warn(
1765
+ const m = document.createElement("canvas");
1766
+ m.id = `fluid_canvas_${Date.now()}`, m.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", A.appendChild(m);
1767
+ const { workerEnabled: Z, quality: r, config: b } = c.current, B = (window.devicePixelRatio || 1) * p.current, K = A.getBoundingClientRect(), W = Math.round((K.width || A.clientWidth) * B) || 0, x = Math.round((K.height || A.clientHeight) * B) || 0;
1768
+ W > 0 && (m.width = W, m.height = x), x === 0 && console.warn(
1748
1769
  "[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."
1749
1770
  );
1750
- const b = new DC(a, {
1751
- isWorkerEnabled: d,
1752
- useWebGPU: C,
1753
- enableAlpha: i,
1754
- quality: Z,
1755
- config: n
1771
+ const Q = new qC(m, {
1772
+ workerEnabled: Z,
1773
+ webGPUEnabled: C,
1774
+ alphaEnabled: i,
1775
+ quality: r,
1776
+ config: b
1756
1777
  });
1757
- t.current = b;
1758
- const U = new ResizeObserver((G) => {
1759
- for (const f of G) {
1760
- const r = (window.devicePixelRatio || 1) * S.current, { inlineSize: y, blockSize: Y } = f.contentBoxSize[0];
1761
- b.resize(Math.round(y * r), Math.round(Y * r));
1778
+ u.current = Q;
1779
+ const Tg = new ResizeObserver((CI) => {
1780
+ for (const iI of CI) {
1781
+ const zg = (window.devicePixelRatio || 1) * p.current, { inlineSize: eI, blockSize: sI } = iI.contentBoxSize[0];
1782
+ Q.resize(Math.round(eI * zg), Math.round(sI * zg));
1762
1783
  }
1763
1784
  });
1764
- return U.observe(u), () => {
1765
- U.disconnect(), b.destroy(), a.remove(), t.current = null;
1785
+ return Tg.observe(A), () => {
1786
+ Tg.disconnect(), Q.destroy(), m.remove(), u.current = null;
1766
1787
  };
1767
- }, [C, i]), sg(() => {
1768
- S.current = Math.max(0.1, Math.min(1, s.dpr ?? 1));
1769
- const u = c.current;
1770
- c.current = { dpr: s.dpr, sim: s.sim };
1771
- const a = t.current, d = e.current;
1772
- if (!a || !d || u.dpr === s.dpr && u.sim === s.sim)
1788
+ }, [C, i]), tg(() => {
1789
+ p.current = Math.max(0.1, Math.min(1, s ?? gI.dpr ?? 1));
1790
+ const A = a.current;
1791
+ a.current = { pixelRatio: s, simResolution: l };
1792
+ const m = u.current, Z = e.current;
1793
+ if (!m || !Z || A.pixelRatio === s && A.simResolution === l)
1773
1794
  return;
1774
- a.updateQuality(s);
1775
- const Z = (window.devicePixelRatio || 1) * S.current, n = d.clientWidth, w = d.clientHeight;
1776
- n > 0 && w > 0 && a.resize(Math.round(n * Z), Math.round(w * Z));
1777
- }, [s.dpr, s.sim, C, i]), t;
1795
+ m.updateQuality({ dpr: s, sim: l });
1796
+ const r = (window.devicePixelRatio || 1) * p.current, b = Z.clientWidth, B = Z.clientHeight;
1797
+ b > 0 && B > 0 && m.resize(Math.round(b * r), Math.round(B * r));
1798
+ }, [s, l, C, i]), u;
1778
1799
  }
1779
- const FC = fI(function({
1800
+ const Ci = gC(function({
1780
1801
  text: g,
1781
- fontSize: C = Bg.fontSize,
1782
- color: i = Bg.color,
1783
- fontFamily: s = Bg.fontFamily,
1784
- fontWeight: l = Bg.fontWeight,
1802
+ fontSize: C = mg.fontSize,
1803
+ color: i = mg.color,
1804
+ fontFamily: s = mg.fontFamily,
1805
+ fontWeight: l = mg.fontWeight,
1785
1806
  className: t,
1786
- style: B,
1787
- config: S,
1788
- preset: c,
1789
- algorithm: u,
1790
- backgroundColor: a = Bg.backgroundColor,
1791
- backgroundSrc: d,
1792
- backgroundSize: Z = Bg.backgroundSize,
1793
- isMouseEnabled: n = Bg.isMouseEnabled,
1794
- isWorkerEnabled: w = Bg.isWorkerEnabled,
1795
- useWebGPU: L = !0,
1796
- enableAlpha: m = !0,
1797
- quality: h = pI.quality
1798
- }, b) {
1799
- const U = Tg(null), G = _I(U, {
1800
- isWorkerEnabled: w,
1801
- useWebGPU: L,
1802
- enableAlpha: m,
1803
- quality: h,
1804
- config: II({ ...S, ...u ? { algorithm: u } : {} }, c, WI)
1807
+ style: S,
1808
+ preset: u,
1809
+ algorithm: c,
1810
+ backgroundColor: p = mg.backgroundColor,
1811
+ backgroundSrc: a,
1812
+ backgroundSize: A = mg.backgroundSize,
1813
+ mouseEnabled: m = mg.mouseEnabled,
1814
+ workerEnabled: Z = mg.workerEnabled,
1815
+ webGPUEnabled: r = !0,
1816
+ alphaEnabled: b = !0,
1817
+ pixelRatio: B = gI.dpr,
1818
+ simResolution: K = gI.sim,
1819
+ // FluidConfig flat props
1820
+ densityDissipation: W,
1821
+ velocityDissipation: x,
1822
+ pressureIterations: Q,
1823
+ curl: Tg,
1824
+ splatRadius: CI,
1825
+ splatForce: iI,
1826
+ refraction: zg,
1827
+ specularExp: eI,
1828
+ shine: sI,
1829
+ waterColor: UI,
1830
+ glowColor: xI,
1831
+ warpStrength: lI
1832
+ }, tI) {
1833
+ const J = Qg(null), oI = Object.fromEntries(
1834
+ Object.entries({ densityDissipation: W, velocityDissipation: x, pressureIterations: Q, curl: Tg, splatRadius: CI, splatForce: iI, refraction: zg, specularExp: eI, shine: sI, waterColor: UI, glowColor: xI, algorithm: c, warpStrength: lI }).filter(([, G]) => G !== void 0)
1835
+ ), n = SC(J, {
1836
+ workerEnabled: Z,
1837
+ webGPUEnabled: r,
1838
+ alphaEnabled: b,
1839
+ pixelRatio: B,
1840
+ simResolution: K,
1841
+ config: Eg(uI(oI, u, EI))
1805
1842
  });
1806
- FI(
1807
- b,
1843
+ IC(
1844
+ tI,
1808
1845
  () => ({
1809
1846
  reset() {
1810
- var r;
1811
- (r = G.current) == null || r.setTextSource({ text: g, fontSize: C, color: i, fontFamily: s, fontWeight: l });
1847
+ var G;
1848
+ (G = n.current) == null || G.setTextSource({ text: g, fontSize: C, color: i, fontFamily: s, fontWeight: l });
1812
1849
  },
1813
- move(r, y, Y = 1) {
1814
- var W;
1815
- (W = G.current) == null || W.handleMove(r, y, Y);
1850
+ move(G, y, Y = 1) {
1851
+ var R;
1852
+ (R = n.current) == null || R.handleMove(G, y, Y);
1816
1853
  },
1817
- splat(r, y, Y, W, _ = 1) {
1818
- var ag;
1819
- (ag = G.current) == null || ag.splat(r, y, Y, W, _);
1854
+ splat(G, y, Y, R, $ = 1) {
1855
+ var ug;
1856
+ (ug = n.current) == null || ug.splat(G, y, Y, R, $);
1820
1857
  },
1821
- updateConfig(r) {
1858
+ updateConfig(G) {
1822
1859
  var y;
1823
- (y = G.current) == null || y.updateConfig(r);
1860
+ (y = n.current) == null || y.updateConfig(Eg(G));
1824
1861
  }
1825
1862
  }),
1826
1863
  [g, C, i, s, l]
1827
- ), sg(() => {
1828
- var r;
1829
- (r = G.current) == null || r.setTextSource({ text: g, fontSize: C, color: i, fontFamily: s, fontWeight: l });
1830
- }, [g, C, i, s, l, L, m]);
1831
- const f = JSON.stringify(S);
1832
- return sg(() => {
1833
- var r;
1834
- (r = G.current) == null || r.updateConfig(
1835
- II({ ...S, ...u !== void 0 ? { algorithm: u } : {} }, c, WI)
1864
+ ), tg(() => {
1865
+ var G;
1866
+ (G = n.current) == null || G.setTextSource({ text: g, fontSize: C, color: i, fontFamily: s, fontWeight: l });
1867
+ }, [g, C, i, s, l, r, b]);
1868
+ const T = JSON.stringify(oI);
1869
+ return tg(() => {
1870
+ var G;
1871
+ (G = n.current) == null || G.updateConfig(
1872
+ Eg(uI(oI, u, EI))
1836
1873
  );
1837
- }, [c, u, f, L, m]), sg(() => {
1874
+ }, [u, T, r, b]), tg(() => {
1838
1875
  var y;
1839
- if (!d) {
1840
- (y = G.current) == null || y.setBackground(null);
1876
+ if (!a) {
1877
+ (y = n.current) == null || y.setBackground(null);
1841
1878
  return;
1842
1879
  }
1843
- let r = !1;
1844
- return XI(d).then((Y) => {
1845
- var W;
1846
- if (r) {
1880
+ let G = !1;
1881
+ return zI(a).then((Y) => {
1882
+ var R;
1883
+ if (G) {
1847
1884
  Y.close();
1848
1885
  return;
1849
1886
  }
1850
- (W = G.current) == null || W.setBackground(Y, Z);
1887
+ (R = n.current) == null || R.setBackground(Y, A);
1851
1888
  }).catch((Y) => console.error("[fluidity-js] backgroundSrc load failed:", Y)), () => {
1852
- r = !0;
1889
+ G = !0;
1853
1890
  };
1854
- }, [d, Z, L, m]), sg(() => {
1855
- if (!n)
1891
+ }, [a, A, r, b]), tg(() => {
1892
+ if (!m)
1856
1893
  return;
1857
- const r = U.current;
1858
- if (!r)
1894
+ const G = J.current;
1895
+ if (!G)
1859
1896
  return;
1860
- const y = (W) => {
1861
- var ag;
1862
- const _ = r.getBoundingClientRect();
1863
- (ag = G.current) == null || ag.handleMove(W.clientX - _.left, W.clientY - _.top, 2);
1864
- }, Y = (W) => {
1865
- var RI;
1866
- W.preventDefault();
1867
- const _ = r.getBoundingClientRect(), ag = W.touches[0];
1868
- (RI = G.current) == null || RI.handleMove(ag.clientX - _.left, ag.clientY - _.top, 1);
1897
+ const y = (R) => {
1898
+ var ug;
1899
+ const $ = G.getBoundingClientRect();
1900
+ (ug = n.current) == null || ug.handleMove(R.clientX - $.left, R.clientY - $.top, 2);
1901
+ }, Y = (R) => {
1902
+ var QI;
1903
+ R.preventDefault();
1904
+ const $ = G.getBoundingClientRect(), ug = R.touches[0];
1905
+ (QI = n.current) == null || QI.handleMove(ug.clientX - $.left, ug.clientY - $.top, 1);
1869
1906
  };
1870
- return r.addEventListener("mousemove", y), r.addEventListener("touchmove", Y, { passive: !1 }), () => {
1871
- r.removeEventListener("mousemove", y), r.removeEventListener("touchmove", Y);
1907
+ return G.addEventListener("mousemove", y), G.addEventListener("touchmove", Y, { passive: !1 }), () => {
1908
+ G.removeEventListener("mousemove", y), G.removeEventListener("touchmove", Y);
1872
1909
  };
1873
- }, [n]), /* @__PURE__ */ xI(
1910
+ }, [m]), /* @__PURE__ */ $I(
1874
1911
  "div",
1875
1912
  {
1876
- ref: U,
1913
+ ref: J,
1877
1914
  className: t,
1878
1915
  style: {
1879
1916
  position: "relative",
1880
1917
  display: "block",
1881
1918
  width: "100%",
1882
1919
  height: "100%",
1883
- background: a,
1884
- ...B
1920
+ background: p,
1921
+ ...S
1885
1922
  }
1886
1923
  }
1887
1924
  );
1888
- }), TC = fI(function({
1925
+ }), ii = gC(function({
1889
1926
  src: g,
1890
1927
  effect: C = Gg.effect,
1891
1928
  imageSize: i = Gg.imageSize,
1892
1929
  className: s,
1893
1930
  style: l,
1894
- config: t,
1895
- preset: B,
1931
+ preset: t,
1896
1932
  algorithm: S,
1897
- backgroundColor: c = Gg.backgroundColor,
1898
- backgroundSrc: u,
1899
- backgroundSize: a = Gg.backgroundSize,
1900
- isMouseEnabled: d = Gg.isMouseEnabled,
1901
- isWorkerEnabled: Z = Gg.isWorkerEnabled,
1902
- useWebGPU: n = !0,
1903
- enableAlpha: w = !0,
1904
- quality: L = pI.quality
1905
- }, m) {
1906
- const h = Tg(null), b = _I(h, {
1907
- isWorkerEnabled: Z,
1908
- useWebGPU: n,
1909
- enableAlpha: w,
1910
- quality: L,
1911
- config: II({ ...t, ...S ? { algorithm: S } : {} }, B)
1933
+ backgroundColor: u = Gg.backgroundColor,
1934
+ backgroundSrc: c,
1935
+ backgroundSize: p = Gg.backgroundSize,
1936
+ mouseEnabled: a = Gg.mouseEnabled,
1937
+ workerEnabled: A = Gg.workerEnabled,
1938
+ webGPUEnabled: m = !0,
1939
+ alphaEnabled: Z = !0,
1940
+ pixelRatio: r = gI.dpr,
1941
+ simResolution: b = gI.sim,
1942
+ // FluidConfig flat props
1943
+ densityDissipation: B,
1944
+ velocityDissipation: K,
1945
+ pressureIterations: W,
1946
+ curl: x,
1947
+ splatRadius: Q,
1948
+ splatForce: Tg,
1949
+ refraction: CI,
1950
+ specularExp: iI,
1951
+ shine: zg,
1952
+ waterColor: eI,
1953
+ glowColor: sI,
1954
+ warpStrength: UI
1955
+ }, xI) {
1956
+ const lI = Qg(null), tI = Object.fromEntries(
1957
+ Object.entries({ densityDissipation: B, velocityDissipation: K, pressureIterations: W, curl: x, splatRadius: Q, splatForce: Tg, refraction: CI, specularExp: iI, shine: zg, waterColor: eI, glowColor: sI, algorithm: S, warpStrength: UI }).filter(([, n]) => n !== void 0)
1958
+ ), J = SC(lI, {
1959
+ workerEnabled: A,
1960
+ webGPUEnabled: m,
1961
+ alphaEnabled: Z,
1962
+ pixelRatio: r,
1963
+ simResolution: b,
1964
+ config: Eg(uI(tI, t))
1912
1965
  });
1913
- FI(
1914
- m,
1966
+ IC(
1967
+ xI,
1915
1968
  () => ({
1916
1969
  reset() {
1917
- var G;
1918
- g && ((G = b.current) == null || G.setImageSource(g, C, i));
1970
+ var n;
1971
+ g && ((n = J.current) == null || n.setImageSource(g, C, i));
1919
1972
  },
1920
- move(G, f, r = 1) {
1973
+ move(n, T, G = 1) {
1921
1974
  var y;
1922
- (y = b.current) == null || y.handleMove(G, f, r);
1975
+ (y = J.current) == null || y.handleMove(n, T, G);
1923
1976
  },
1924
- splat(G, f, r, y, Y = 1) {
1925
- var W;
1926
- (W = b.current) == null || W.splat(G, f, r, y, Y);
1977
+ splat(n, T, G, y, Y = 1) {
1978
+ var R;
1979
+ (R = J.current) == null || R.splat(n, T, G, y, Y);
1927
1980
  },
1928
- updateConfig(G) {
1929
- var f;
1930
- (f = b.current) == null || f.updateConfig(G);
1981
+ updateConfig(n) {
1982
+ var T;
1983
+ (T = J.current) == null || T.updateConfig(Eg(n));
1931
1984
  }
1932
1985
  }),
1933
1986
  [g, C, i]
1934
- ), sg(() => {
1935
- var G;
1936
- g && ((G = b.current) == null || G.setImageSource(g, C, i));
1937
- }, [g, C, i, n, w]);
1938
- const U = JSON.stringify(t);
1939
- return sg(() => {
1940
- var G;
1941
- (G = b.current) == null || G.updateConfig(
1942
- II({ ...t, ...S !== void 0 ? { algorithm: S } : {} }, B)
1987
+ ), tg(() => {
1988
+ var n;
1989
+ g && ((n = J.current) == null || n.setImageSource(g, C, i));
1990
+ }, [g, C, i, m, Z]);
1991
+ const oI = JSON.stringify(tI);
1992
+ return tg(() => {
1993
+ var n;
1994
+ (n = J.current) == null || n.updateConfig(
1995
+ Eg(uI(tI, t))
1943
1996
  );
1944
- }, [B, S, U, n, w]), sg(() => {
1945
- var f;
1946
- if (!u) {
1947
- (f = b.current) == null || f.setBackground(null);
1997
+ }, [t, oI, m, Z]), tg(() => {
1998
+ var T;
1999
+ if (!c) {
2000
+ (T = J.current) == null || T.setBackground(null);
1948
2001
  return;
1949
2002
  }
1950
- let G = !1;
1951
- return XI(u).then((r) => {
2003
+ let n = !1;
2004
+ return zI(c).then((G) => {
1952
2005
  var y;
1953
- if (G) {
1954
- r.close();
2006
+ if (n) {
2007
+ G.close();
1955
2008
  return;
1956
2009
  }
1957
- (y = b.current) == null || y.setBackground(r, a);
1958
- }).catch((r) => console.error("[fluidity-js] backgroundSrc load failed:", r)), () => {
1959
- G = !0;
2010
+ (y = J.current) == null || y.setBackground(G, p);
2011
+ }).catch((G) => console.error("[fluidity-js] backgroundSrc load failed:", G)), () => {
2012
+ n = !0;
1960
2013
  };
1961
- }, [u, a, n, w]), sg(() => {
1962
- if (!d)
2014
+ }, [c, p, m, Z]), tg(() => {
2015
+ if (!a)
1963
2016
  return;
1964
- const G = h.current;
1965
- if (!G)
2017
+ const n = lI.current;
2018
+ if (!n)
1966
2019
  return;
1967
- const f = (y) => {
1968
- var W;
1969
- const Y = G.getBoundingClientRect();
1970
- (W = b.current) == null || W.handleMove(y.clientX - Y.left, y.clientY - Y.top, 2);
1971
- }, r = (y) => {
1972
- var _;
2020
+ const T = (y) => {
2021
+ var R;
2022
+ const Y = n.getBoundingClientRect();
2023
+ (R = J.current) == null || R.handleMove(y.clientX - Y.left, y.clientY - Y.top, 2);
2024
+ }, G = (y) => {
2025
+ var $;
1973
2026
  y.preventDefault();
1974
- const Y = G.getBoundingClientRect(), W = y.touches[0];
1975
- (_ = b.current) == null || _.handleMove(W.clientX - Y.left, W.clientY - Y.top, 1);
2027
+ const Y = n.getBoundingClientRect(), R = y.touches[0];
2028
+ ($ = J.current) == null || $.handleMove(R.clientX - Y.left, R.clientY - Y.top, 1);
1976
2029
  };
1977
- return G.addEventListener("mousemove", f), G.addEventListener("touchmove", r, { passive: !1 }), () => {
1978
- G.removeEventListener("mousemove", f), G.removeEventListener("touchmove", r);
2030
+ return n.addEventListener("mousemove", T), n.addEventListener("touchmove", G, { passive: !1 }), () => {
2031
+ n.removeEventListener("mousemove", T), n.removeEventListener("touchmove", G);
1979
2032
  };
1980
- }, [d]), /* @__PURE__ */ xI(
2033
+ }, [a]), /* @__PURE__ */ $I(
1981
2034
  "div",
1982
2035
  {
1983
- ref: h,
2036
+ ref: lI,
1984
2037
  className: s,
1985
2038
  style: {
1986
2039
  position: "relative",
1987
2040
  display: "block",
1988
2041
  width: "100%",
1989
2042
  height: "100%",
1990
- background: c,
2043
+ background: u,
1991
2044
  ...l
1992
2045
  }
1993
2046
  }
1994
2047
  );
1995
2048
  });
1996
2049
  export {
1997
- TI as DEFAULT_CONFIG,
1998
- WI as DEFAULT_CONFIG_TEXT,
2050
+ CC as DEFAULT_CONFIG,
2051
+ EI as DEFAULT_CONFIG_TEXT,
1999
2052
  Gg as DEFAULT_PROPS_IMAGE,
2000
- pI as DEFAULT_PROPS_SHARED,
2001
- Bg as DEFAULT_PROPS_TEXT,
2002
- DC as FluidController,
2003
- TC as FluidImage,
2004
- uI as FluidSimulation,
2005
- FC as FluidText,
2006
- IC as PRESETS,
2007
- XI as loadImageBitmap,
2008
- II as mergeConfig,
2009
- dI as parseColor,
2010
- _I as useFluid
2053
+ iC as DEFAULT_PROPS_SHARED,
2054
+ mg as DEFAULT_PROPS_TEXT,
2055
+ qC as FluidController,
2056
+ ii as FluidImage,
2057
+ yI as FluidSimulation,
2058
+ Ci as FluidText,
2059
+ pC as PRESETS,
2060
+ mC as PROP_RANGES,
2061
+ zI as loadImageBitmap,
2062
+ uI as mergeConfig,
2063
+ Eg as normalizeConfig,
2064
+ bI as parseColor,
2065
+ SC as useFluid
2011
2066
  };