@macrostrat/cesium-martini 1.2.3 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.babelrc +1 -6
- package/.env.example +1 -0
- package/.gitmodules +1 -1
- package/.npmrc +1 -0
- package/README.md +49 -12
- package/dist/index.cjs +1455 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.js +580 -1590
- package/dist/index.js.map +1 -1
- package/package.json +20 -28
- package/rollup.config.js +13 -6
- package/tsconfig.json +3 -3
- package/webpack.config.js +0 -69
package/dist/index.js
CHANGED
|
@@ -1,35 +1,328 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var cesium = require('cesium');
|
|
6
|
-
|
|
7
|
-
function ownKeys(object, enumerableOnly) {
|
|
8
|
-
var keys = Object.keys(object);
|
|
1
|
+
import { Resource, Credit, Event, Math as Math$1, Ellipsoid, Rectangle, Cartographic, OrientedBoundingBox, BoundingSphere, QuantizedMeshTerrainData, TerrainProvider, WebMercatorTilingScheme } from 'cesium';
|
|
2
|
+
import ndarray from 'ndarray';
|
|
9
3
|
|
|
4
|
+
function ownKeys(e, r) {
|
|
5
|
+
var t = Object.keys(e);
|
|
10
6
|
if (Object.getOwnPropertySymbols) {
|
|
11
|
-
var
|
|
12
|
-
|
|
13
|
-
return Object.getOwnPropertyDescriptor(
|
|
14
|
-
})),
|
|
7
|
+
var o = Object.getOwnPropertySymbols(e);
|
|
8
|
+
r && (o = o.filter(function (r) {
|
|
9
|
+
return Object.getOwnPropertyDescriptor(e, r).enumerable;
|
|
10
|
+
})), t.push.apply(t, o);
|
|
15
11
|
}
|
|
16
|
-
|
|
17
|
-
return keys;
|
|
12
|
+
return t;
|
|
18
13
|
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
14
|
+
function _objectSpread2(e) {
|
|
15
|
+
for (var r = 1; r < arguments.length; r++) {
|
|
16
|
+
var t = null != arguments[r] ? arguments[r] : {};
|
|
17
|
+
r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {
|
|
18
|
+
_defineProperty(e, r, t[r]);
|
|
19
|
+
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {
|
|
20
|
+
Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));
|
|
27
21
|
});
|
|
28
22
|
}
|
|
29
|
-
|
|
30
|
-
|
|
23
|
+
return e;
|
|
24
|
+
}
|
|
25
|
+
function _regeneratorRuntime() {
|
|
26
|
+
_regeneratorRuntime = function () {
|
|
27
|
+
return e;
|
|
28
|
+
};
|
|
29
|
+
var t,
|
|
30
|
+
e = {},
|
|
31
|
+
r = Object.prototype,
|
|
32
|
+
n = r.hasOwnProperty,
|
|
33
|
+
o = Object.defineProperty || function (t, e, r) {
|
|
34
|
+
t[e] = r.value;
|
|
35
|
+
},
|
|
36
|
+
i = "function" == typeof Symbol ? Symbol : {},
|
|
37
|
+
a = i.iterator || "@@iterator",
|
|
38
|
+
c = i.asyncIterator || "@@asyncIterator",
|
|
39
|
+
u = i.toStringTag || "@@toStringTag";
|
|
40
|
+
function define(t, e, r) {
|
|
41
|
+
return Object.defineProperty(t, e, {
|
|
42
|
+
value: r,
|
|
43
|
+
enumerable: !0,
|
|
44
|
+
configurable: !0,
|
|
45
|
+
writable: !0
|
|
46
|
+
}), t[e];
|
|
47
|
+
}
|
|
48
|
+
try {
|
|
49
|
+
define({}, "");
|
|
50
|
+
} catch (t) {
|
|
51
|
+
define = function (t, e, r) {
|
|
52
|
+
return t[e] = r;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
function wrap(t, e, r, n) {
|
|
56
|
+
var i = e && e.prototype instanceof Generator ? e : Generator,
|
|
57
|
+
a = Object.create(i.prototype),
|
|
58
|
+
c = new Context(n || []);
|
|
59
|
+
return o(a, "_invoke", {
|
|
60
|
+
value: makeInvokeMethod(t, r, c)
|
|
61
|
+
}), a;
|
|
62
|
+
}
|
|
63
|
+
function tryCatch(t, e, r) {
|
|
64
|
+
try {
|
|
65
|
+
return {
|
|
66
|
+
type: "normal",
|
|
67
|
+
arg: t.call(e, r)
|
|
68
|
+
};
|
|
69
|
+
} catch (t) {
|
|
70
|
+
return {
|
|
71
|
+
type: "throw",
|
|
72
|
+
arg: t
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
e.wrap = wrap;
|
|
77
|
+
var h = "suspendedStart",
|
|
78
|
+
l = "suspendedYield",
|
|
79
|
+
f = "executing",
|
|
80
|
+
s = "completed",
|
|
81
|
+
y = {};
|
|
82
|
+
function Generator() {}
|
|
83
|
+
function GeneratorFunction() {}
|
|
84
|
+
function GeneratorFunctionPrototype() {}
|
|
85
|
+
var p = {};
|
|
86
|
+
define(p, a, function () {
|
|
87
|
+
return this;
|
|
88
|
+
});
|
|
89
|
+
var d = Object.getPrototypeOf,
|
|
90
|
+
v = d && d(d(values([])));
|
|
91
|
+
v && v !== r && n.call(v, a) && (p = v);
|
|
92
|
+
var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
|
|
93
|
+
function defineIteratorMethods(t) {
|
|
94
|
+
["next", "throw", "return"].forEach(function (e) {
|
|
95
|
+
define(t, e, function (t) {
|
|
96
|
+
return this._invoke(e, t);
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
function AsyncIterator(t, e) {
|
|
101
|
+
function invoke(r, o, i, a) {
|
|
102
|
+
var c = tryCatch(t[r], t, o);
|
|
103
|
+
if ("throw" !== c.type) {
|
|
104
|
+
var u = c.arg,
|
|
105
|
+
h = u.value;
|
|
106
|
+
return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
|
|
107
|
+
invoke("next", t, i, a);
|
|
108
|
+
}, function (t) {
|
|
109
|
+
invoke("throw", t, i, a);
|
|
110
|
+
}) : e.resolve(h).then(function (t) {
|
|
111
|
+
u.value = t, i(u);
|
|
112
|
+
}, function (t) {
|
|
113
|
+
return invoke("throw", t, i, a);
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
a(c.arg);
|
|
117
|
+
}
|
|
118
|
+
var r;
|
|
119
|
+
o(this, "_invoke", {
|
|
120
|
+
value: function (t, n) {
|
|
121
|
+
function callInvokeWithMethodAndArg() {
|
|
122
|
+
return new e(function (e, r) {
|
|
123
|
+
invoke(t, n, e, r);
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
function makeInvokeMethod(e, r, n) {
|
|
131
|
+
var o = h;
|
|
132
|
+
return function (i, a) {
|
|
133
|
+
if (o === f) throw new Error("Generator is already running");
|
|
134
|
+
if (o === s) {
|
|
135
|
+
if ("throw" === i) throw a;
|
|
136
|
+
return {
|
|
137
|
+
value: t,
|
|
138
|
+
done: !0
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
for (n.method = i, n.arg = a;;) {
|
|
142
|
+
var c = n.delegate;
|
|
143
|
+
if (c) {
|
|
144
|
+
var u = maybeInvokeDelegate(c, n);
|
|
145
|
+
if (u) {
|
|
146
|
+
if (u === y) continue;
|
|
147
|
+
return u;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
|
|
151
|
+
if (o === h) throw o = s, n.arg;
|
|
152
|
+
n.dispatchException(n.arg);
|
|
153
|
+
} else "return" === n.method && n.abrupt("return", n.arg);
|
|
154
|
+
o = f;
|
|
155
|
+
var p = tryCatch(e, r, n);
|
|
156
|
+
if ("normal" === p.type) {
|
|
157
|
+
if (o = n.done ? s : l, p.arg === y) continue;
|
|
158
|
+
return {
|
|
159
|
+
value: p.arg,
|
|
160
|
+
done: n.done
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
"throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
function maybeInvokeDelegate(e, r) {
|
|
168
|
+
var n = r.method,
|
|
169
|
+
o = e.iterator[n];
|
|
170
|
+
if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y;
|
|
171
|
+
var i = tryCatch(o, e.iterator, r.arg);
|
|
172
|
+
if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
|
|
173
|
+
var a = i.arg;
|
|
174
|
+
return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y);
|
|
175
|
+
}
|
|
176
|
+
function pushTryEntry(t) {
|
|
177
|
+
var e = {
|
|
178
|
+
tryLoc: t[0]
|
|
179
|
+
};
|
|
180
|
+
1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
|
|
181
|
+
}
|
|
182
|
+
function resetTryEntry(t) {
|
|
183
|
+
var e = t.completion || {};
|
|
184
|
+
e.type = "normal", delete e.arg, t.completion = e;
|
|
185
|
+
}
|
|
186
|
+
function Context(t) {
|
|
187
|
+
this.tryEntries = [{
|
|
188
|
+
tryLoc: "root"
|
|
189
|
+
}], t.forEach(pushTryEntry, this), this.reset(!0);
|
|
190
|
+
}
|
|
191
|
+
function values(e) {
|
|
192
|
+
if (e || "" === e) {
|
|
193
|
+
var r = e[a];
|
|
194
|
+
if (r) return r.call(e);
|
|
195
|
+
if ("function" == typeof e.next) return e;
|
|
196
|
+
if (!isNaN(e.length)) {
|
|
197
|
+
var o = -1,
|
|
198
|
+
i = function next() {
|
|
199
|
+
for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next;
|
|
200
|
+
return next.value = t, next.done = !0, next;
|
|
201
|
+
};
|
|
202
|
+
return i.next = i;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
throw new TypeError(typeof e + " is not iterable");
|
|
206
|
+
}
|
|
207
|
+
return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", {
|
|
208
|
+
value: GeneratorFunctionPrototype,
|
|
209
|
+
configurable: !0
|
|
210
|
+
}), o(GeneratorFunctionPrototype, "constructor", {
|
|
211
|
+
value: GeneratorFunction,
|
|
212
|
+
configurable: !0
|
|
213
|
+
}), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
|
|
214
|
+
var e = "function" == typeof t && t.constructor;
|
|
215
|
+
return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
|
|
216
|
+
}, e.mark = function (t) {
|
|
217
|
+
return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
|
|
218
|
+
}, e.awrap = function (t) {
|
|
219
|
+
return {
|
|
220
|
+
__await: t
|
|
221
|
+
};
|
|
222
|
+
}, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
|
|
223
|
+
return this;
|
|
224
|
+
}), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
|
|
225
|
+
void 0 === i && (i = Promise);
|
|
226
|
+
var a = new AsyncIterator(wrap(t, r, n, o), i);
|
|
227
|
+
return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
|
|
228
|
+
return t.done ? t.value : a.next();
|
|
229
|
+
});
|
|
230
|
+
}, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
|
|
231
|
+
return this;
|
|
232
|
+
}), define(g, "toString", function () {
|
|
233
|
+
return "[object Generator]";
|
|
234
|
+
}), e.keys = function (t) {
|
|
235
|
+
var e = Object(t),
|
|
236
|
+
r = [];
|
|
237
|
+
for (var n in e) r.push(n);
|
|
238
|
+
return r.reverse(), function next() {
|
|
239
|
+
for (; r.length;) {
|
|
240
|
+
var t = r.pop();
|
|
241
|
+
if (t in e) return next.value = t, next.done = !1, next;
|
|
242
|
+
}
|
|
243
|
+
return next.done = !0, next;
|
|
244
|
+
};
|
|
245
|
+
}, e.values = values, Context.prototype = {
|
|
246
|
+
constructor: Context,
|
|
247
|
+
reset: function (e) {
|
|
248
|
+
if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t);
|
|
249
|
+
},
|
|
250
|
+
stop: function () {
|
|
251
|
+
this.done = !0;
|
|
252
|
+
var t = this.tryEntries[0].completion;
|
|
253
|
+
if ("throw" === t.type) throw t.arg;
|
|
254
|
+
return this.rval;
|
|
255
|
+
},
|
|
256
|
+
dispatchException: function (e) {
|
|
257
|
+
if (this.done) throw e;
|
|
258
|
+
var r = this;
|
|
259
|
+
function handle(n, o) {
|
|
260
|
+
return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
|
|
261
|
+
}
|
|
262
|
+
for (var o = this.tryEntries.length - 1; o >= 0; --o) {
|
|
263
|
+
var i = this.tryEntries[o],
|
|
264
|
+
a = i.completion;
|
|
265
|
+
if ("root" === i.tryLoc) return handle("end");
|
|
266
|
+
if (i.tryLoc <= this.prev) {
|
|
267
|
+
var c = n.call(i, "catchLoc"),
|
|
268
|
+
u = n.call(i, "finallyLoc");
|
|
269
|
+
if (c && u) {
|
|
270
|
+
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
271
|
+
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
272
|
+
} else if (c) {
|
|
273
|
+
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
274
|
+
} else {
|
|
275
|
+
if (!u) throw new Error("try statement without catch or finally");
|
|
276
|
+
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
},
|
|
281
|
+
abrupt: function (t, e) {
|
|
282
|
+
for (var r = this.tryEntries.length - 1; r >= 0; --r) {
|
|
283
|
+
var o = this.tryEntries[r];
|
|
284
|
+
if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
|
|
285
|
+
var i = o;
|
|
286
|
+
break;
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
|
|
290
|
+
var a = i ? i.completion : {};
|
|
291
|
+
return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
|
|
292
|
+
},
|
|
293
|
+
complete: function (t, e) {
|
|
294
|
+
if ("throw" === t.type) throw t.arg;
|
|
295
|
+
return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y;
|
|
296
|
+
},
|
|
297
|
+
finish: function (t) {
|
|
298
|
+
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
299
|
+
var r = this.tryEntries[e];
|
|
300
|
+
if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
|
|
301
|
+
}
|
|
302
|
+
},
|
|
303
|
+
catch: function (t) {
|
|
304
|
+
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
305
|
+
var r = this.tryEntries[e];
|
|
306
|
+
if (r.tryLoc === t) {
|
|
307
|
+
var n = r.completion;
|
|
308
|
+
if ("throw" === n.type) {
|
|
309
|
+
var o = n.arg;
|
|
310
|
+
resetTryEntry(r);
|
|
311
|
+
}
|
|
312
|
+
return o;
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
throw new Error("illegal catch attempt");
|
|
316
|
+
},
|
|
317
|
+
delegateYield: function (e, r, n) {
|
|
318
|
+
return this.delegate = {
|
|
319
|
+
iterator: values(e),
|
|
320
|
+
resultName: r,
|
|
321
|
+
nextLoc: n
|
|
322
|
+
}, "next" === this.method && (this.arg = t), y;
|
|
323
|
+
}
|
|
324
|
+
}, e;
|
|
31
325
|
}
|
|
32
|
-
|
|
33
326
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
34
327
|
try {
|
|
35
328
|
var info = gen[key](arg);
|
|
@@ -38,50 +331,42 @@ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
|
38
331
|
reject(error);
|
|
39
332
|
return;
|
|
40
333
|
}
|
|
41
|
-
|
|
42
334
|
if (info.done) {
|
|
43
335
|
resolve(value);
|
|
44
336
|
} else {
|
|
45
337
|
Promise.resolve(value).then(_next, _throw);
|
|
46
338
|
}
|
|
47
339
|
}
|
|
48
|
-
|
|
49
340
|
function _asyncToGenerator(fn) {
|
|
50
341
|
return function () {
|
|
51
342
|
var self = this,
|
|
52
|
-
|
|
343
|
+
args = arguments;
|
|
53
344
|
return new Promise(function (resolve, reject) {
|
|
54
345
|
var gen = fn.apply(self, args);
|
|
55
|
-
|
|
56
346
|
function _next(value) {
|
|
57
347
|
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
58
348
|
}
|
|
59
|
-
|
|
60
349
|
function _throw(err) {
|
|
61
350
|
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
62
351
|
}
|
|
63
|
-
|
|
64
352
|
_next(undefined);
|
|
65
353
|
});
|
|
66
354
|
};
|
|
67
355
|
}
|
|
68
|
-
|
|
69
356
|
function _classCallCheck(instance, Constructor) {
|
|
70
357
|
if (!(instance instanceof Constructor)) {
|
|
71
358
|
throw new TypeError("Cannot call a class as a function");
|
|
72
359
|
}
|
|
73
360
|
}
|
|
74
|
-
|
|
75
361
|
function _defineProperties(target, props) {
|
|
76
362
|
for (var i = 0; i < props.length; i++) {
|
|
77
363
|
var descriptor = props[i];
|
|
78
364
|
descriptor.enumerable = descriptor.enumerable || false;
|
|
79
365
|
descriptor.configurable = true;
|
|
80
366
|
if ("value" in descriptor) descriptor.writable = true;
|
|
81
|
-
Object.defineProperty(target, descriptor.key, descriptor);
|
|
367
|
+
Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);
|
|
82
368
|
}
|
|
83
369
|
}
|
|
84
|
-
|
|
85
370
|
function _createClass(Constructor, protoProps, staticProps) {
|
|
86
371
|
if (protoProps) _defineProperties(Constructor.prototype, protoProps);
|
|
87
372
|
if (staticProps) _defineProperties(Constructor, staticProps);
|
|
@@ -90,8 +375,8 @@ function _createClass(Constructor, protoProps, staticProps) {
|
|
|
90
375
|
});
|
|
91
376
|
return Constructor;
|
|
92
377
|
}
|
|
93
|
-
|
|
94
378
|
function _defineProperty(obj, key, value) {
|
|
379
|
+
key = _toPropertyKey(key);
|
|
95
380
|
if (key in obj) {
|
|
96
381
|
Object.defineProperty(obj, key, {
|
|
97
382
|
value: value,
|
|
@@ -102,49 +387,41 @@ function _defineProperty(obj, key, value) {
|
|
|
102
387
|
} else {
|
|
103
388
|
obj[key] = value;
|
|
104
389
|
}
|
|
105
|
-
|
|
106
390
|
return obj;
|
|
107
391
|
}
|
|
108
|
-
|
|
109
392
|
function _inherits(subClass, superClass) {
|
|
110
393
|
if (typeof superClass !== "function" && superClass !== null) {
|
|
111
394
|
throw new TypeError("Super expression must either be null or a function");
|
|
112
395
|
}
|
|
113
|
-
|
|
396
|
+
subClass.prototype = Object.create(superClass && superClass.prototype, {
|
|
397
|
+
constructor: {
|
|
398
|
+
value: subClass,
|
|
399
|
+
writable: true,
|
|
400
|
+
configurable: true
|
|
401
|
+
}
|
|
402
|
+
});
|
|
114
403
|
Object.defineProperty(subClass, "prototype", {
|
|
115
|
-
value: Object.create(superClass && superClass.prototype, {
|
|
116
|
-
constructor: {
|
|
117
|
-
value: subClass,
|
|
118
|
-
writable: true,
|
|
119
|
-
configurable: true
|
|
120
|
-
}
|
|
121
|
-
}),
|
|
122
404
|
writable: false
|
|
123
405
|
});
|
|
124
406
|
if (superClass) _setPrototypeOf(subClass, superClass);
|
|
125
407
|
}
|
|
126
|
-
|
|
127
408
|
function _getPrototypeOf(o) {
|
|
128
|
-
_getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
|
|
409
|
+
_getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {
|
|
129
410
|
return o.__proto__ || Object.getPrototypeOf(o);
|
|
130
411
|
};
|
|
131
412
|
return _getPrototypeOf(o);
|
|
132
413
|
}
|
|
133
|
-
|
|
134
414
|
function _setPrototypeOf(o, p) {
|
|
135
|
-
_setPrototypeOf = Object.setPrototypeOf
|
|
415
|
+
_setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {
|
|
136
416
|
o.__proto__ = p;
|
|
137
417
|
return o;
|
|
138
418
|
};
|
|
139
|
-
|
|
140
419
|
return _setPrototypeOf(o, p);
|
|
141
420
|
}
|
|
142
|
-
|
|
143
421
|
function _isNativeReflectConstruct() {
|
|
144
422
|
if (typeof Reflect === "undefined" || !Reflect.construct) return false;
|
|
145
423
|
if (Reflect.construct.sham) return false;
|
|
146
424
|
if (typeof Proxy === "function") return true;
|
|
147
|
-
|
|
148
425
|
try {
|
|
149
426
|
Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));
|
|
150
427
|
return true;
|
|
@@ -152,86 +429,66 @@ function _isNativeReflectConstruct() {
|
|
|
152
429
|
return false;
|
|
153
430
|
}
|
|
154
431
|
}
|
|
155
|
-
|
|
156
432
|
function _assertThisInitialized(self) {
|
|
157
433
|
if (self === void 0) {
|
|
158
434
|
throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
|
|
159
435
|
}
|
|
160
|
-
|
|
161
436
|
return self;
|
|
162
437
|
}
|
|
163
|
-
|
|
164
438
|
function _possibleConstructorReturn(self, call) {
|
|
165
439
|
if (call && (typeof call === "object" || typeof call === "function")) {
|
|
166
440
|
return call;
|
|
167
441
|
} else if (call !== void 0) {
|
|
168
442
|
throw new TypeError("Derived constructors may only return object or undefined");
|
|
169
443
|
}
|
|
170
|
-
|
|
171
444
|
return _assertThisInitialized(self);
|
|
172
445
|
}
|
|
173
|
-
|
|
174
446
|
function _createSuper(Derived) {
|
|
175
447
|
var hasNativeReflectConstruct = _isNativeReflectConstruct();
|
|
176
|
-
|
|
177
448
|
return function _createSuperInternal() {
|
|
178
449
|
var Super = _getPrototypeOf(Derived),
|
|
179
|
-
|
|
180
|
-
|
|
450
|
+
result;
|
|
181
451
|
if (hasNativeReflectConstruct) {
|
|
182
452
|
var NewTarget = _getPrototypeOf(this).constructor;
|
|
183
|
-
|
|
184
453
|
result = Reflect.construct(Super, arguments, NewTarget);
|
|
185
454
|
} else {
|
|
186
455
|
result = Super.apply(this, arguments);
|
|
187
456
|
}
|
|
188
|
-
|
|
189
457
|
return _possibleConstructorReturn(this, result);
|
|
190
458
|
};
|
|
191
459
|
}
|
|
192
|
-
|
|
193
460
|
function _superPropBase(object, property) {
|
|
194
461
|
while (!Object.prototype.hasOwnProperty.call(object, property)) {
|
|
195
462
|
object = _getPrototypeOf(object);
|
|
196
463
|
if (object === null) break;
|
|
197
464
|
}
|
|
198
|
-
|
|
199
465
|
return object;
|
|
200
466
|
}
|
|
201
|
-
|
|
202
467
|
function _get() {
|
|
203
468
|
if (typeof Reflect !== "undefined" && Reflect.get) {
|
|
204
|
-
_get = Reflect.get;
|
|
469
|
+
_get = Reflect.get.bind();
|
|
205
470
|
} else {
|
|
206
471
|
_get = function _get(target, property, receiver) {
|
|
207
472
|
var base = _superPropBase(target, property);
|
|
208
|
-
|
|
209
473
|
if (!base) return;
|
|
210
474
|
var desc = Object.getOwnPropertyDescriptor(base, property);
|
|
211
|
-
|
|
212
475
|
if (desc.get) {
|
|
213
476
|
return desc.get.call(arguments.length < 3 ? target : receiver);
|
|
214
477
|
}
|
|
215
|
-
|
|
216
478
|
return desc.value;
|
|
217
479
|
};
|
|
218
480
|
}
|
|
219
|
-
|
|
220
481
|
return _get.apply(this, arguments);
|
|
221
482
|
}
|
|
222
|
-
|
|
223
483
|
function _toConsumableArray(arr) {
|
|
224
484
|
return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
|
|
225
485
|
}
|
|
226
|
-
|
|
227
486
|
function _arrayWithoutHoles(arr) {
|
|
228
487
|
if (Array.isArray(arr)) return _arrayLikeToArray(arr);
|
|
229
488
|
}
|
|
230
|
-
|
|
231
489
|
function _iterableToArray(iter) {
|
|
232
490
|
if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
|
|
233
491
|
}
|
|
234
|
-
|
|
235
492
|
function _unsupportedIterableToArray(o, minLen) {
|
|
236
493
|
if (!o) return;
|
|
237
494
|
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
|
|
@@ -240,18 +497,28 @@ function _unsupportedIterableToArray(o, minLen) {
|
|
|
240
497
|
if (n === "Map" || n === "Set") return Array.from(o);
|
|
241
498
|
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
|
|
242
499
|
}
|
|
243
|
-
|
|
244
500
|
function _arrayLikeToArray(arr, len) {
|
|
245
501
|
if (len == null || len > arr.length) len = arr.length;
|
|
246
|
-
|
|
247
502
|
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
|
|
248
|
-
|
|
249
503
|
return arr2;
|
|
250
504
|
}
|
|
251
|
-
|
|
252
505
|
function _nonIterableSpread() {
|
|
253
506
|
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
254
507
|
}
|
|
508
|
+
function _toPrimitive(input, hint) {
|
|
509
|
+
if (typeof input !== "object" || input === null) return input;
|
|
510
|
+
var prim = input[Symbol.toPrimitive];
|
|
511
|
+
if (prim !== undefined) {
|
|
512
|
+
var res = prim.call(input, hint || "default");
|
|
513
|
+
if (typeof res !== "object") return res;
|
|
514
|
+
throw new TypeError("@@toPrimitive must return a primitive value.");
|
|
515
|
+
}
|
|
516
|
+
return (hint === "string" ? String : Number)(input);
|
|
517
|
+
}
|
|
518
|
+
function _toPropertyKey(arg) {
|
|
519
|
+
var key = _toPrimitive(arg, "string");
|
|
520
|
+
return typeof key === "symbol" ? key : String(key);
|
|
521
|
+
}
|
|
255
522
|
|
|
256
523
|
var loadImage = function loadImage(url) {
|
|
257
524
|
return new Promise(function (resolve, reject) {
|
|
@@ -266,71 +533,51 @@ var loadImage = function loadImage(url) {
|
|
|
266
533
|
img.src = url;
|
|
267
534
|
});
|
|
268
535
|
};
|
|
269
|
-
|
|
270
536
|
var DefaultHeightmapResource = /*#__PURE__*/function () {
|
|
271
537
|
function DefaultHeightmapResource() {
|
|
272
538
|
var _this = this,
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
539
|
+
_opts$skipOddLevels,
|
|
540
|
+
_opts$tileSize,
|
|
541
|
+
_opts$maxZoom;
|
|
277
542
|
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
278
|
-
|
|
279
543
|
_classCallCheck(this, DefaultHeightmapResource);
|
|
280
|
-
|
|
281
544
|
_defineProperty(this, "resource", null);
|
|
282
|
-
|
|
283
545
|
_defineProperty(this, "tileSize", 256);
|
|
284
|
-
|
|
285
|
-
_defineProperty(this, "maxZoom", void 0);
|
|
286
|
-
|
|
287
546
|
_defineProperty(this, "skipOddLevels", false);
|
|
288
|
-
|
|
289
|
-
_defineProperty(this, "contextQueue", void 0);
|
|
290
|
-
|
|
291
547
|
_defineProperty(this, "getTilePixels", /*#__PURE__*/function () {
|
|
292
|
-
var _ref = _asyncToGenerator( /*#__PURE__*/
|
|
548
|
+
var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(coords) {
|
|
293
549
|
var url, img;
|
|
294
|
-
return
|
|
295
|
-
while (1) {
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
case 5:
|
|
307
|
-
case "end":
|
|
308
|
-
return _context.stop();
|
|
309
|
-
}
|
|
550
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
551
|
+
while (1) switch (_context.prev = _context.next) {
|
|
552
|
+
case 0:
|
|
553
|
+
url = _this.buildTileURL(coords);
|
|
554
|
+
_context.next = 3;
|
|
555
|
+
return loadImage(url);
|
|
556
|
+
case 3:
|
|
557
|
+
img = _context.sent;
|
|
558
|
+
return _context.abrupt("return", _this.getPixels(img));
|
|
559
|
+
case 5:
|
|
560
|
+
case "end":
|
|
561
|
+
return _context.stop();
|
|
310
562
|
}
|
|
311
563
|
}, _callee);
|
|
312
564
|
}));
|
|
313
|
-
|
|
314
565
|
return function (_x) {
|
|
315
566
|
return _ref.apply(this, arguments);
|
|
316
567
|
};
|
|
317
568
|
}());
|
|
318
|
-
|
|
319
569
|
if (opts.url) {
|
|
320
|
-
this.resource =
|
|
570
|
+
this.resource = Resource.createIfNeeded(opts.url);
|
|
321
571
|
}
|
|
322
|
-
|
|
323
572
|
this.skipOddLevels = (_opts$skipOddLevels = opts.skipOddLevels) !== null && _opts$skipOddLevels !== void 0 ? _opts$skipOddLevels : false;
|
|
324
573
|
this.tileSize = (_opts$tileSize = opts.tileSize) !== null && _opts$tileSize !== void 0 ? _opts$tileSize : 256;
|
|
325
574
|
this.maxZoom = (_opts$maxZoom = opts.maxZoom) !== null && _opts$maxZoom !== void 0 ? _opts$maxZoom : 15;
|
|
326
575
|
this.contextQueue = [];
|
|
327
576
|
}
|
|
328
|
-
|
|
329
577
|
_createClass(DefaultHeightmapResource, [{
|
|
330
578
|
key: "getCanvas",
|
|
331
579
|
value: function getCanvas() {
|
|
332
580
|
var ctx = this.contextQueue.pop();
|
|
333
|
-
|
|
334
581
|
if (ctx == null) {
|
|
335
582
|
var canvas = document.createElement("canvas");
|
|
336
583
|
canvas.width = this.tileSize;
|
|
@@ -341,17 +588,16 @@ var DefaultHeightmapResource = /*#__PURE__*/function () {
|
|
|
341
588
|
context: context
|
|
342
589
|
};
|
|
343
590
|
}
|
|
344
|
-
|
|
345
591
|
return ctx;
|
|
346
592
|
}
|
|
347
593
|
}, {
|
|
348
594
|
key: "getPixels",
|
|
349
595
|
value: function getPixels(img) {
|
|
350
596
|
var canvasRef = this.getCanvas();
|
|
351
|
-
var context = canvasRef.context;
|
|
597
|
+
var context = canvasRef.context;
|
|
598
|
+
//context.scale(1, -1);
|
|
352
599
|
// Chrome appears to vertically flip the image for reasons that are unclear
|
|
353
600
|
// We can make it work in Chrome by drawing the image upside-down at this step.
|
|
354
|
-
|
|
355
601
|
context.drawImage(img, 0, 0, this.tileSize, this.tileSize);
|
|
356
602
|
var pixels = context.getImageData(0, 0, this.tileSize, this.tileSize);
|
|
357
603
|
context.clearRect(0, 0, this.tileSize, this.tileSize);
|
|
@@ -362,11 +608,10 @@ var DefaultHeightmapResource = /*#__PURE__*/function () {
|
|
|
362
608
|
key: "buildTileURL",
|
|
363
609
|
value: function buildTileURL(tileCoords) {
|
|
364
610
|
var _this$resource;
|
|
365
|
-
|
|
366
611
|
// reverseY for TMS tiling (https://gist.github.com/tmcw/4954720)
|
|
367
612
|
// See tiling schemes here: https://www.maptiler.com/google-maps-coordinates-tile-bounds-projection/
|
|
368
613
|
var z = tileCoords.z,
|
|
369
|
-
|
|
614
|
+
y = tileCoords.y;
|
|
370
615
|
return (_this$resource = this.resource) === null || _this$resource === void 0 ? void 0 : _this$resource.getDerivedResource({
|
|
371
616
|
templateValues: _objectSpread2(_objectSpread2({}, tileCoords), {}, {
|
|
372
617
|
reverseY: Math.pow(2, z) - y - 1
|
|
@@ -384,60 +629,45 @@ var DefaultHeightmapResource = /*#__PURE__*/function () {
|
|
|
384
629
|
return true;
|
|
385
630
|
}
|
|
386
631
|
}]);
|
|
387
|
-
|
|
388
632
|
return DefaultHeightmapResource;
|
|
389
633
|
}();
|
|
390
634
|
|
|
391
|
-
var ImageFormat
|
|
392
|
-
|
|
393
|
-
(function (ImageFormat) {
|
|
635
|
+
var ImageFormat = /*#__PURE__*/function (ImageFormat) {
|
|
394
636
|
ImageFormat["WEBP"] = "webp";
|
|
395
637
|
ImageFormat["PNG"] = "png";
|
|
396
638
|
ImageFormat["PNGRAW"] = "pngraw";
|
|
397
|
-
|
|
398
|
-
|
|
639
|
+
return ImageFormat;
|
|
640
|
+
}({});
|
|
399
641
|
var MapboxTerrainResource = /*#__PURE__*/function (_DefaultHeightmapReso) {
|
|
400
642
|
_inherits(MapboxTerrainResource, _DefaultHeightmapReso);
|
|
401
|
-
|
|
402
643
|
var _super = _createSuper(MapboxTerrainResource);
|
|
403
|
-
|
|
404
644
|
function MapboxTerrainResource() {
|
|
405
645
|
var _opts$highResolution, _opts$imageFormat;
|
|
406
|
-
|
|
407
646
|
var _this;
|
|
408
|
-
|
|
409
647
|
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
410
|
-
|
|
411
648
|
_classCallCheck(this, MapboxTerrainResource);
|
|
412
|
-
|
|
413
649
|
_this = _super.call(this, opts);
|
|
414
|
-
|
|
415
650
|
_defineProperty(_assertThisInitialized(_this), "resource", null);
|
|
416
|
-
|
|
417
651
|
var highResolution = (_opts$highResolution = opts.highResolution) !== null && _opts$highResolution !== void 0 ? _opts$highResolution : false;
|
|
418
|
-
var format = (_opts$imageFormat = opts.imageFormat) !== null && _opts$imageFormat !== void 0 ? _opts$imageFormat : ImageFormat.WEBP;
|
|
652
|
+
var format = (_opts$imageFormat = opts.imageFormat) !== null && _opts$imageFormat !== void 0 ? _opts$imageFormat : ImageFormat.WEBP;
|
|
419
653
|
|
|
654
|
+
// overrides based on highResolution flag
|
|
420
655
|
if (highResolution) {
|
|
421
656
|
if (opts.maxZoom === undefined) {
|
|
422
657
|
_this.maxZoom = 14;
|
|
423
658
|
}
|
|
424
|
-
|
|
425
659
|
if (opts.tileSize === undefined) {
|
|
426
660
|
_this.tileSize = 512;
|
|
427
661
|
}
|
|
428
662
|
}
|
|
429
|
-
|
|
430
|
-
_this.resource = cesium.Resource.createIfNeeded("https://api.mapbox.com/v4/mapbox.terrain-rgb/{z}/{x}/{y}".concat(highResolution ? "@2x" : "", ".").concat(format));
|
|
431
|
-
|
|
663
|
+
_this.resource = Resource.createIfNeeded("https://api.mapbox.com/v4/mapbox.terrain-rgb/{z}/{x}/{y}".concat(highResolution ? "@2x" : "", ".").concat(format));
|
|
432
664
|
if (opts.accessToken) {
|
|
433
665
|
_this.resource.setQueryParameters({
|
|
434
666
|
access_token: opts.accessToken
|
|
435
667
|
});
|
|
436
668
|
}
|
|
437
|
-
|
|
438
669
|
return _this;
|
|
439
670
|
}
|
|
440
|
-
|
|
441
671
|
return _createClass(MapboxTerrainResource);
|
|
442
672
|
}(DefaultHeightmapResource);
|
|
443
673
|
|
|
@@ -471,63 +701,53 @@ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
|
|
|
471
701
|
};
|
|
472
702
|
}
|
|
473
703
|
|
|
474
|
-
var WorkerFactory = createBase64WorkerFactory('Lyogcm9sbHVwLXBsdWdpbi13ZWItd29ya2VyLWxvYWRlciAqLwp2YXIgd29ya2VyX2NvZGUgPSAoZnVuY3Rpb24gKGV4cG9ydHMpIHsKICAndXNlIHN0cmljdCc7CgogIGZ1bmN0aW9uIF90b0NvbnN1bWFibGVBcnJheShhcnIpIHsKICAgIHJldHVybiBfYXJyYXlXaXRob3V0SG9sZXMoYXJyKSB8fCBfaXRlcmFibGVUb0FycmF5KGFycikgfHwgX3Vuc3VwcG9ydGVkSXRlcmFibGVUb0FycmF5KGFycikgfHwgX25vbkl0ZXJhYmxlU3ByZWFkKCk7CiAgfQoKICBmdW5jdGlvbiBfYXJyYXlXaXRob3V0SG9sZXMoYXJyKSB7CiAgICBpZiAoQXJyYXkuaXNBcnJheShhcnIpKSByZXR1cm4gX2FycmF5TGlrZVRvQXJyYXkoYXJyKTsKICB9CgogIGZ1bmN0aW9uIF9pdGVyYWJsZVRvQXJyYXkoaXRlcikgewogICAgaWYgKHR5cGVvZiBTeW1ib2wgIT09ICJ1bmRlZmluZWQiICYmIGl0ZXJbU3ltYm9sLml0ZXJhdG9yXSAhPSBudWxsIHx8IGl0ZXJbIkBAaXRlcmF0b3IiXSAhPSBudWxsKSByZXR1cm4gQXJyYXkuZnJvbShpdGVyKTsKICB9CgogIGZ1bmN0aW9uIF91bnN1cHBvcnRlZEl0ZXJhYmxlVG9BcnJheShvLCBtaW5MZW4pIHsKICAgIGlmICghbykgcmV0dXJuOwogICAgaWYgKHR5cGVvZiBvID09PSAic3RyaW5nIikgcmV0dXJuIF9hcnJheUxpa2VUb0FycmF5KG8sIG1pbkxlbik7CiAgICB2YXIgbiA9IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChvKS5zbGljZSg4LCAtMSk7CiAgICBpZiAobiA9PT0gIk9iamVjdCIgJiYgby5jb25zdHJ1Y3RvcikgbiA9IG8uY29uc3RydWN0b3IubmFtZTsKICAgIGlmIChuID09PSAiTWFwIiB8fCBuID09PSAiU2V0IikgcmV0dXJuIEFycmF5LmZyb20obyk7CiAgICBpZiAobiA9PT0gIkFyZ3VtZW50cyIgfHwgL14oPzpVaXxJKW50KD86OHwxNnwzMikoPzpDbGFtcGVkKT9BcnJheSQvLnRlc3QobikpIHJldHVybiBfYXJyYXlMaWtlVG9BcnJheShvLCBtaW5MZW4pOwogIH0KCiAgZnVuY3Rpb24gX2FycmF5TGlrZVRvQXJyYXkoYXJyLCBsZW4pIHsKICAgIGlmIChsZW4gPT0gbnVsbCB8fCBsZW4gPiBhcnIubGVuZ3RoKSBsZW4gPSBhcnIubGVuZ3RoOwoKICAgIGZvciAodmFyIGkgPSAwLCBhcnIyID0gbmV3IEFycmF5KGxlbik7IGkgPCBsZW47IGkrKykgYXJyMltpXSA9IGFycltpXTsKCiAgICByZXR1cm4gYXJyMjsKICB9CgogIGZ1bmN0aW9uIF9ub25JdGVyYWJsZVNwcmVhZCgpIHsKICAgIHRocm93IG5ldyBUeXBlRXJyb3IoIkludmFsaWQgYXR0ZW1wdCB0byBzcHJlYWQgbm9uLWl0ZXJhYmxlIGluc3RhbmNlLlxuSW4gb3JkZXIgdG8gYmUgaXRlcmFibGUsIG5vbi1hcnJheSBvYmplY3RzIG11c3QgaGF2ZSBhIFtTeW1ib2wuaXRlcmF0b3JdKCkgbWV0aG9kLiIpOwogIH0KCiAgLy8gV2Ugc2hvdWxkIHNhdmUgdGhlc2UKICAvL2NvbnN0IGNhbnZhcyA9IG5ldyBPZmZzY3JlZW5DYW52YXMoMjU2LCAyNTYpOwogIC8vY29uc3QgY3R4ID0gY2FudmFzLmdldENvbnRleHQoIjJkIik7CiAgZnVuY3Rpb24gbWFwYm94VGVycmFpblRvR3JpZChwbmcsIGludGVydmFsLCBvZmZzZXQpIHsKICAgIHZhciBfaW50ZXJ2YWwsIF9vZmZzZXQ7CgogICAgLy8gbWF5YmUgd2Ugc2hvdWxkIGRvIHRoaXMgb24gdGhlIEdQVSB1c2luZyBSRUdMPwogICAgLy8gYnV0IHRoYXQgd291bGQgcmVxdWlyZSBHUFUgLT4gQ1BVIC0+IEdQVQogICAgdmFyIGdyaWRTaXplID0gcG5nLnNoYXBlWzBdICsgMTsKICAgIHZhciB0ZXJyYWluID0gbmV3IEZsb2F0MzJBcnJheShncmlkU2l6ZSAqIGdyaWRTaXplKTsKICAgIHZhciB0aWxlU2l6ZSA9IHBuZy5zaGFwZVswXTsKICAgIGludGVydmFsID0gKF9pbnRlcnZhbCA9IGludGVydmFsKSAhPT0gbnVsbCAmJiBfaW50ZXJ2YWwgIT09IHZvaWQgMCA/IF9pbnRlcnZhbCA6IDAuMTsKICAgIG9mZnNldCA9IChfb2Zmc2V0ID0gb2Zmc2V0KSAhPT0gbnVsbCAmJiBfb2Zmc2V0ICE9PSB2b2lkIDAgPyBfb2Zmc2V0IDogLTEwMDAwOyAvLyBkZWNvZGUgdGVycmFpbiB2YWx1ZXMKCiAgICBmb3IgKHZhciB5ID0gMDsgeSA8IHRpbGVTaXplOyB5KyspIHsKICAgICAgZm9yICh2YXIgeCA9IDA7IHggPCB0aWxlU2l6ZTsgeCsrKSB7CiAgICAgICAgdmFyIHljID0geTsKICAgICAgICB2YXIgciA9IHBuZy5nZXQoeCwgeWMsIDApOwogICAgICAgIHZhciBnID0gcG5nLmdldCh4LCB5YywgMSk7CiAgICAgICAgdmFyIGIgPSBwbmcuZ2V0KHgsIHljLCAyKTsKICAgICAgICB0ZXJyYWluW3kgKiBncmlkU2l6ZSArIHhdID0gciAqIDI1NiAqIDI1NiAqIGludGVydmFsICsgZyAqIDI1Ni4wICogaW50ZXJ2YWwgKyBiICogaW50ZXJ2YWwgKyBvZmZzZXQ7CiAgICAgIH0KICAgIH0gLy8gYmFja2ZpbGwgcmlnaHQgYW5kIGJvdHRvbSBib3JkZXJzCgoKICAgIGZvciAodmFyIF94ID0gMDsgX3ggPCBncmlkU2l6ZSAtIDE7IF94KyspIHsKICAgICAgdGVycmFpbltncmlkU2l6ZSAqIChncmlkU2l6ZSAtIDEpICsgX3hdID0gdGVycmFpbltncmlkU2l6ZSAqIChncmlkU2l6ZSAtIDIpICsgX3hdOwogICAgfQoKICAgIGZvciAodmFyIF95ID0gMDsgX3kgPCBncmlkU2l6ZTsgX3krKykgewogICAgICB0ZXJyYWluW2dyaWRTaXplICogX3kgKyBncmlkU2l6ZSAtIDFdID0gdGVycmFpbltncmlkU2l6ZSAqIF95ICsgZ3JpZFNpemUgLSAyXTsKICAgIH0KCiAgICByZXR1cm4gdGVycmFpbjsKICB9CgogIGZ1bmN0aW9uIGNyZWF0ZVF1YW50aXplZE1lc2hEYXRhKHRpbGUsIG1lc2gsIHRpbGVTaXplKSB7CiAgICB2YXIgeHZhbHMgPSBbXTsKICAgIHZhciB5dmFscyA9IFtdOwogICAgdmFyIGhlaWdodE1ldGVycyA9IFtdOwogICAgdmFyIG5vcnRoSW5kaWNlcyA9IFtdOwogICAgdmFyIHNvdXRoSW5kaWNlcyA9IFtdOwogICAgdmFyIGVhc3RJbmRpY2VzID0gW107CiAgICB2YXIgd2VzdEluZGljZXMgPSBbXTsKICAgIHZhciBtaW5pbXVtSGVpZ2h0ID0gSW5maW5pdHk7CiAgICB2YXIgbWF4aW11bUhlaWdodCA9IC1JbmZpbml0eTsKICAgIHZhciBzY2FsYXIgPSAzMjc2OC4wIC8gdGlsZVNpemU7CgogICAgZm9yICh2YXIgaXggPSAwOyBpeCA8IG1lc2gudmVydGljZXMubGVuZ3RoIC8gMjsgaXgrKykgewogICAgICB2YXIgdmVydGV4SXggPSBpeDsKICAgICAgdmFyIHB4ID0gbWVzaC52ZXJ0aWNlc1tpeCAqIDJdOwogICAgICB2YXIgcHkgPSBtZXNoLnZlcnRpY2VzW2l4ICogMiArIDFdOwogICAgICB2YXIgaGVpZ2h0ID0gdGlsZS50ZXJyYWluW3B5ICogKHRpbGVTaXplICsgMSkgKyBweF07CiAgICAgIGlmIChoZWlnaHQgPiBtYXhpbXVtSGVpZ2h0KSBtYXhpbXVtSGVpZ2h0ID0gaGVpZ2h0OwogICAgICBpZiAoaGVpZ2h0IDwgbWluaW11bUhlaWdodCkgbWluaW11bUhlaWdodCA9IGhlaWdodDsKICAgICAgaGVpZ2h0TWV0ZXJzLnB1c2goaGVpZ2h0KTsKICAgICAgaWYgKHB5ID09IDApIG5vcnRoSW5kaWNlcy5wdXNoKHZlcnRleEl4KTsKICAgICAgaWYgKHB5ID09IHRpbGVTaXplKSBzb3V0aEluZGljZXMucHVzaCh2ZXJ0ZXhJeCk7CiAgICAgIGlmIChweCA9PSAwKSB3ZXN0SW5kaWNlcy5wdXNoKHZlcnRleEl4KTsKICAgICAgaWYgKHB4ID09IHRpbGVTaXplKSBlYXN0SW5kaWNlcy5wdXNoKHZlcnRleEl4KTsKICAgICAgdmFyIHh2ID0gcHggKiBzY2FsYXI7CiAgICAgIHZhciB5diA9ICh0aWxlU2l6ZSAtIHB5KSAqIHNjYWxhcjsKICAgICAgeHZhbHMucHVzaCh4dik7CiAgICAgIHl2YWxzLnB1c2goeXYpOwogICAgfQoKICAgIHZhciBoZWlnaHRSYW5nZSA9IG1heGltdW1IZWlnaHQgLSBtaW5pbXVtSGVpZ2h0OwogICAgdmFyIGhlaWdodHMgPSBoZWlnaHRNZXRlcnMubWFwKGZ1bmN0aW9uIChkKSB7CiAgICAgIGlmIChoZWlnaHRSYW5nZSA8IDEpIHJldHVybiAwOwogICAgICByZXR1cm4gKGQgLSBtaW5pbXVtSGVpZ2h0KSAqICgzMjc2Ny4wIC8gaGVpZ2h0UmFuZ2UpOwogICAgfSk7CiAgICB2YXIgdHJpYW5nbGVzID0gbmV3IFVpbnQxNkFycmF5KG1lc2gudHJpYW5nbGVzKTsKICAgIHZhciBxdWFudGl6ZWRWZXJ0aWNlcyA9IG5ldyBVaW50MTZBcnJheSggLy92ZXJ0cwogICAgW10uY29uY2F0KHh2YWxzLCB5dmFscywgX3RvQ29uc3VtYWJsZUFycmF5KGhlaWdodHMpKSk7IC8vIFNFIE5XIE5FCiAgICAvLyBORSBOVyBTRQoKICAgIHJldHVybiB7CiAgICAgIG1pbmltdW1IZWlnaHQ6IG1pbmltdW1IZWlnaHQsCiAgICAgIG1heGltdW1IZWlnaHQ6IG1heGltdW1IZWlnaHQsCiAgICAgIHF1YW50aXplZFZlcnRpY2VzOiBxdWFudGl6ZWRWZXJ0aWNlcywKICAgICAgaW5kaWNlczogdHJpYW5nbGVzLAogICAgICB3ZXN0SW5kaWNlczogd2VzdEluZGljZXMsCiAgICAgIHNvdXRoSW5kaWNlczogc291dGhJbmRpY2VzLAogICAgICBlYXN0SW5kaWNlczogZWFzdEluZGljZXMsCiAgICAgIG5vcnRoSW5kaWNlczogbm9ydGhJbmRpY2VzCiAgICB9OwogIH0KCiAgZnVuY3Rpb24gaW90YShuKSB7CiAgICB2YXIgcmVzdWx0ID0gbmV3IEFycmF5KG4pOwogICAgZm9yKHZhciBpPTA7IGk8bjsgKytpKSB7CiAgICAgIHJlc3VsdFtpXSA9IGk7CiAgICB9CiAgICByZXR1cm4gcmVzdWx0CiAgfQoKICB2YXIgaW90YV8xID0gaW90YTsKCiAgLyohCiAgICogRGV0ZXJtaW5lIGlmIGFuIG9iamVjdCBpcyBhIEJ1ZmZlcgogICAqCiAgICogQGF1dGhvciAgIEZlcm9zcyBBYm91a2hhZGlqZWggPGh0dHBzOi8vZmVyb3NzLm9yZz4KICAgKiBAbGljZW5zZSAgTUlUCiAgICovCiAgLy8gVGhlIF9pc0J1ZmZlciBjaGVjayBpcyBmb3IgU2FmYXJpIDUtNyBzdXBwb3J0LCBiZWNhdXNlIGl0J3MgbWlzc2luZwogIC8vIE9iamVjdC5wcm90b3R5cGUuY29uc3RydWN0b3IuIFJlbW92ZSB0aGlzIGV2ZW50dWFsbHkKICB2YXIgaXNCdWZmZXJfMSA9IGZ1bmN0aW9uIChvYmopIHsKICAgIHJldHVybiBvYmogIT0gbnVsbCAmJiAoaXNCdWZmZXIob2JqKSB8fCBpc1Nsb3dCdWZmZXIob2JqKSB8fCAhIW9iai5faXNCdWZmZXIpCiAgfTsKCiAgZnVuY3Rpb24gaXNCdWZmZXIgKG9iaikgewogICAgcmV0dXJuICEhb2JqLmNvbnN0cnVjdG9yICYmIHR5cGVvZiBvYmouY29uc3RydWN0b3IuaXNCdWZmZXIgPT09ICdmdW5jdGlvbicgJiYgb2JqLmNvbnN0cnVjdG9yLmlzQnVmZmVyKG9iaikKICB9CgogIC8vIEZvciBOb2RlIHYwLjEwIHN1cHBvcnQuIFJlbW92ZSB0aGlzIGV2ZW50dWFsbHkuCiAgZnVuY3Rpb24gaXNTbG93QnVmZmVyIChvYmopIHsKICAgIHJldHVybiB0eXBlb2Ygb2JqLnJlYWRGbG9hdExFID09PSAnZnVuY3Rpb24nICYmIHR5cGVvZiBvYmouc2xpY2UgPT09ICdmdW5jdGlvbicgJiYgaXNCdWZmZXIob2JqLnNsaWNlKDAsIDApKQogIH0KCiAgdmFyIGhhc1R5cGVkQXJyYXlzICA9ICgodHlwZW9mIEZsb2F0NjRBcnJheSkgIT09ICJ1bmRlZmluZWQiKTsKCiAgZnVuY3Rpb24gY29tcGFyZTFzdChhLCBiKSB7CiAgICByZXR1cm4gYVswXSAtIGJbMF0KICB9CgogIGZ1bmN0aW9uIG9yZGVyKCkgewogICAgdmFyIHN0cmlkZSA9IHRoaXMuc3RyaWRlOwogICAgdmFyIHRlcm1zID0gbmV3IEFycmF5KHN0cmlkZS5sZW5ndGgpOwogICAgdmFyIGk7CiAgICBmb3IoaT0wOyBpPHRlcm1zLmxlbmd0aDsgKytpKSB7CiAgICAgIHRlcm1zW2ldID0gW01hdGguYWJzKHN0cmlkZVtpXSksIGldOwogICAgfQogICAgdGVybXMuc29ydChjb21wYXJlMXN0KTsKICAgIHZhciByZXN1bHQgPSBuZXcgQXJyYXkodGVybXMubGVuZ3RoKTsKICAgIGZvcihpPTA7IGk8cmVzdWx0Lmxlbmd0aDsgKytpKSB7CiAgICAgIHJlc3VsdFtpXSA9IHRlcm1zW2ldWzFdOwogICAgfQogICAgcmV0dXJuIHJlc3VsdAogIH0KCiAgZnVuY3Rpb24gY29tcGlsZUNvbnN0cnVjdG9yKGR0eXBlLCBkaW1lbnNpb24pIHsKICAgIHZhciBjbGFzc05hbWUgPSBbIlZpZXciLCBkaW1lbnNpb24sICJkIiwgZHR5cGVdLmpvaW4oIiIpOwogICAgaWYoZGltZW5zaW9uIDwgMCkgewogICAgICBjbGFzc05hbWUgPSAiVmlld19OaWwiICsgZHR5cGU7CiAgICB9CiAgICB2YXIgdXNlR2V0dGVycyA9IChkdHlwZSA9PT0gImdlbmVyaWMiKTsKCiAgICBpZihkaW1lbnNpb24gPT09IC0xKSB7CiAgICAgIC8vU3BlY2lhbCBjYXNlIGZvciB0cml2aWFsIGFycmF5cwogICAgICB2YXIgY29kZSA9CiAgICAgICAgImZ1bmN0aW9uICIrY2xhc3NOYW1lKyIoYSl7dGhpcy5kYXRhPWE7fTtcCnZhciBwcm90bz0iK2NsYXNzTmFtZSsiLnByb3RvdHlwZTtcCnByb3RvLmR0eXBlPSciK2R0eXBlKyInO1wKcHJvdG8uaW5kZXg9ZnVuY3Rpb24oKXtyZXR1cm4gLTF9O1wKcHJvdG8uc2l6ZT0wO1wKcHJvdG8uZGltZW5zaW9uPS0xO1wKcHJvdG8uc2hhcGU9cHJvdG8uc3RyaWRlPXByb3RvLm9yZGVyPVtdO1wKcHJvdG8ubG89cHJvdG8uaGk9cHJvdG8udHJhbnNwb3NlPXByb3RvLnN0ZXA9XApmdW5jdGlvbigpe3JldHVybiBuZXcgIitjbGFzc05hbWUrIih0aGlzLmRhdGEpO307XApwcm90by5nZXQ9cHJvdG8uc2V0PWZ1bmN0aW9uKCl7fTtcCnByb3RvLnBpY2s9ZnVuY3Rpb24oKXtyZXR1cm4gbnVsbH07XApyZXR1cm4gZnVuY3Rpb24gY29uc3RydWN0XyIrY2xhc3NOYW1lKyIoYSl7cmV0dXJuIG5ldyAiK2NsYXNzTmFtZSsiKGEpO30iOwogICAgICB2YXIgcHJvY2VkdXJlID0gbmV3IEZ1bmN0aW9uKGNvZGUpOwogICAgICByZXR1cm4gcHJvY2VkdXJlKCkKICAgIH0gZWxzZSBpZihkaW1lbnNpb24gPT09IDApIHsKICAgICAgLy9TcGVjaWFsIGNhc2UgZm9yIDBkIGFycmF5cwogICAgICB2YXIgY29kZSA9CiAgICAgICAgImZ1bmN0aW9uICIrY2xhc3NOYW1lKyIoYSxkKSB7XAp0aGlzLmRhdGEgPSBhO1wKdGhpcy5vZmZzZXQgPSBkXAp9O1wKdmFyIHByb3RvPSIrY2xhc3NOYW1lKyIucHJvdG90eXBlO1wKcHJvdG8uZHR5cGU9JyIrZHR5cGUrIic7XApwcm90by5pbmRleD1mdW5jdGlvbigpe3JldHVybiB0aGlzLm9mZnNldH07XApwcm90by5kaW1lbnNpb249MDtcCnByb3RvLnNpemU9MTtcCnByb3RvLnNoYXBlPVwKcHJvdG8uc3RyaWRlPVwKcHJvdG8ub3JkZXI9W107XApwcm90by5sbz1cCnByb3RvLmhpPVwKcHJvdG8udHJhbnNwb3NlPVwKcHJvdG8uc3RlcD1mdW5jdGlvbiAiK2NsYXNzTmFtZSsiX2NvcHkoKSB7XApyZXR1cm4gbmV3ICIrY2xhc3NOYW1lKyIodGhpcy5kYXRhLHRoaXMub2Zmc2V0KVwKfTtcCnByb3RvLnBpY2s9ZnVuY3Rpb24gIitjbGFzc05hbWUrIl9waWNrKCl7XApyZXR1cm4gVHJpdmlhbEFycmF5KHRoaXMuZGF0YSk7XAp9O1wKcHJvdG8udmFsdWVPZj1wcm90by5nZXQ9ZnVuY3Rpb24gIitjbGFzc05hbWUrIl9nZXQoKXtcCnJldHVybiAiKyh1c2VHZXR0ZXJzID8gInRoaXMuZGF0YS5nZXQodGhpcy5vZmZzZXQpIiA6ICJ0aGlzLmRhdGFbdGhpcy5vZmZzZXRdIikrCiAgIn07XApwcm90by5zZXQ9ZnVuY3Rpb24gIitjbGFzc05hbWUrIl9zZXQodil7XApyZXR1cm4gIisodXNlR2V0dGVycyA/ICJ0aGlzLmRhdGEuc2V0KHRoaXMub2Zmc2V0LHYpIiA6ICJ0aGlzLmRhdGFbdGhpcy5vZmZzZXRdPXYiKSsiXAp9O1wKcmV0dXJuIGZ1bmN0aW9uIGNvbnN0cnVjdF8iK2NsYXNzTmFtZSsiKGEsYixjLGQpe3JldHVybiBuZXcgIitjbGFzc05hbWUrIihhLGQpfSI7CiAgICAgIHZhciBwcm9jZWR1cmUgPSBuZXcgRnVuY3Rpb24oIlRyaXZpYWxBcnJheSIsIGNvZGUpOwogICAgICByZXR1cm4gcHJvY2VkdXJlKENBQ0hFRF9DT05TVFJVQ1RPUlNbZHR5cGVdWzBdKQogICAgfQoKICAgIHZhciBjb2RlID0gWyIndXNlIHN0cmljdCciXTsKCiAgICAvL0NyZWF0ZSBjb25zdHJ1Y3RvciBmb3IgdmlldwogICAgdmFyIGluZGljZXMgPSBpb3RhXzEoZGltZW5zaW9uKTsKICAgIHZhciBhcmdzID0gaW5kaWNlcy5tYXAoZnVuY3Rpb24oaSkgeyByZXR1cm4gImkiK2kgfSk7CiAgICB2YXIgaW5kZXhfc3RyID0gInRoaXMub2Zmc2V0KyIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbihpKSB7CiAgICAgICAgICByZXR1cm4gInRoaXMuc3RyaWRlWyIgKyBpICsgIl0qaSIgKyBpCiAgICAgICAgfSkuam9pbigiKyIpOwogICAgdmFyIHNoYXBlQXJnID0gaW5kaWNlcy5tYXAoZnVuY3Rpb24oaSkgewogICAgICAgIHJldHVybiAiYiIraQogICAgICB9KS5qb2luKCIsIik7CiAgICB2YXIgc3RyaWRlQXJnID0gaW5kaWNlcy5tYXAoZnVuY3Rpb24oaSkgewogICAgICAgIHJldHVybiAiYyIraQogICAgICB9KS5qb2luKCIsIik7CiAgICBjb2RlLnB1c2goCiAgICAgICJmdW5jdGlvbiAiK2NsYXNzTmFtZSsiKGEsIiArIHNoYXBlQXJnICsgIiwiICsgc3RyaWRlQXJnICsgIixkKXt0aGlzLmRhdGE9YSIsCiAgICAgICAgInRoaXMuc2hhcGU9WyIgKyBzaGFwZUFyZyArICJdIiwKICAgICAgICAidGhpcy5zdHJpZGU9WyIgKyBzdHJpZGVBcmcgKyAiXSIsCiAgICAgICAgInRoaXMub2Zmc2V0PWR8MH0iLAogICAgICAidmFyIHByb3RvPSIrY2xhc3NOYW1lKyIucHJvdG90eXBlIiwKICAgICAgInByb3RvLmR0eXBlPSciK2R0eXBlKyInIiwKICAgICAgInByb3RvLmRpbWVuc2lvbj0iK2RpbWVuc2lvbik7CgogICAgLy92aWV3LnNpemU6CiAgICBjb2RlLnB1c2goIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShwcm90bywnc2l6ZScse2dldDpmdW5jdGlvbiAiK2NsYXNzTmFtZSsiX3NpemUoKXtcCnJldHVybiAiK2luZGljZXMubWFwKGZ1bmN0aW9uKGkpIHsgcmV0dXJuICJ0aGlzLnNoYXBlWyIraSsiXSIgfSkuam9pbigiKiIpLAogICJ9fSkiKTsKCiAgICAvL3ZpZXcub3JkZXI6CiAgICBpZihkaW1lbnNpb24gPT09IDEpIHsKICAgICAgY29kZS5wdXNoKCJwcm90by5vcmRlcj1bMF0iKTsKICAgIH0gZWxzZSB7CiAgICAgIGNvZGUucHVzaCgiT2JqZWN0LmRlZmluZVByb3BlcnR5KHByb3RvLCdvcmRlcicse2dldDoiKTsKICAgICAgaWYoZGltZW5zaW9uIDwgNCkgewogICAgICAgIGNvZGUucHVzaCgiZnVuY3Rpb24gIitjbGFzc05hbWUrIl9vcmRlcigpeyIpOwogICAgICAgIGlmKGRpbWVuc2lvbiA9PT0gMikgewogICAgICAgICAgY29kZS5wdXNoKCJyZXR1cm4gKE1hdGguYWJzKHRoaXMuc3RyaWRlWzBdKT5NYXRoLmFicyh0aGlzLnN0cmlkZVsxXSkpP1sxLDBdOlswLDFdfX0pIik7CiAgICAgICAgfSBlbHNlIGlmKGRpbWVuc2lvbiA9PT0gMykgewogICAgICAgICAgY29kZS5wdXNoKAogICJ2YXIgczA9TWF0aC5hYnModGhpcy5zdHJpZGVbMF0pLHMxPU1hdGguYWJzKHRoaXMuc3RyaWRlWzFdKSxzMj1NYXRoLmFicyh0aGlzLnN0cmlkZVsyXSk7XAppZihzMD5zMSl7XAppZihzMT5zMil7XApyZXR1cm4gWzIsMSwwXTtcCn1lbHNlIGlmKHMwPnMyKXtcCnJldHVybiBbMSwyLDBdO1wKfWVsc2V7XApyZXR1cm4gWzEsMCwyXTtcCn1cCn1lbHNlIGlmKHMwPnMyKXtcCnJldHVybiBbMiwwLDFdO1wKfWVsc2UgaWYoczI+czEpe1wKcmV0dXJuIFswLDEsMl07XAp9ZWxzZXtcCnJldHVybiBbMCwyLDFdO1wKfX19KSIpOwogICAgICAgIH0KICAgICAgfSBlbHNlIHsKICAgICAgICBjb2RlLnB1c2goIk9SREVSfSkiKTsKICAgICAgfQogICAgfQoKICAgIC8vdmlldy5zZXQoaTAsIC4uLiwgdik6CiAgICBjb2RlLnB1c2goCiAgInByb3RvLnNldD1mdW5jdGlvbiAiK2NsYXNzTmFtZSsiX3NldCgiK2FyZ3Muam9pbigiLCIpKyIsdil7Iik7CiAgICBpZih1c2VHZXR0ZXJzKSB7CiAgICAgIGNvZGUucHVzaCgicmV0dXJuIHRoaXMuZGF0YS5zZXQoIitpbmRleF9zdHIrIix2KX0iKTsKICAgIH0gZWxzZSB7CiAgICAgIGNvZGUucHVzaCgicmV0dXJuIHRoaXMuZGF0YVsiK2luZGV4X3N0cisiXT12fSIpOwogICAgfQoKICAgIC8vdmlldy5nZXQoaTAsIC4uLik6CiAgICBjb2RlLnB1c2goInByb3RvLmdldD1mdW5jdGlvbiAiK2NsYXNzTmFtZSsiX2dldCgiK2FyZ3Muam9pbigiLCIpKyIpeyIpOwogICAgaWYodXNlR2V0dGVycykgewogICAgICBjb2RlLnB1c2goInJldHVybiB0aGlzLmRhdGEuZ2V0KCIraW5kZXhfc3RyKyIpfSIpOwogICAgfSBlbHNlIHsKICAgICAgY29kZS5wdXNoKCJyZXR1cm4gdGhpcy5kYXRhWyIraW5kZXhfc3RyKyJdfSIpOwogICAgfQoKICAgIC8vdmlldy5pbmRleDoKICAgIGNvZGUucHVzaCgKICAgICAgInByb3RvLmluZGV4PWZ1bmN0aW9uICIrY2xhc3NOYW1lKyJfaW5kZXgoIiwgYXJncy5qb2luKCksICIpe3JldHVybiAiK2luZGV4X3N0cisifSIpOwoKICAgIC8vdmlldy5oaSgpOgogICAgY29kZS5wdXNoKCJwcm90by5oaT1mdW5jdGlvbiAiK2NsYXNzTmFtZSsiX2hpKCIrYXJncy5qb2luKCIsIikrIil7cmV0dXJuIG5ldyAiK2NsYXNzTmFtZSsiKHRoaXMuZGF0YSwiKwogICAgICBpbmRpY2VzLm1hcChmdW5jdGlvbihpKSB7CiAgICAgICAgcmV0dXJuIFsiKHR5cGVvZiBpIixpLCIhPT0nbnVtYmVyJ3x8aSIsaSwiPDApP3RoaXMuc2hhcGVbIiwgaSwgIl06aSIsIGksInwwIl0uam9pbigiIikKICAgICAgfSkuam9pbigiLCIpKyIsIisKICAgICAgaW5kaWNlcy5tYXAoZnVuY3Rpb24oaSkgewogICAgICAgIHJldHVybiAidGhpcy5zdHJpZGVbIitpICsgIl0iCiAgICAgIH0pLmpvaW4oIiwiKSsiLHRoaXMub2Zmc2V0KX0iKTsKCiAgICAvL3ZpZXcubG8oKToKICAgIHZhciBhX3ZhcnMgPSBpbmRpY2VzLm1hcChmdW5jdGlvbihpKSB7IHJldHVybiAiYSIraSsiPXRoaXMuc2hhcGVbIitpKyJdIiB9KTsKICAgIHZhciBjX3ZhcnMgPSBpbmRpY2VzLm1hcChmdW5jdGlvbihpKSB7IHJldHVybiAiYyIraSsiPXRoaXMuc3RyaWRlWyIraSsiXSIgfSk7CiAgICBjb2RlLnB1c2goInByb3RvLmxvPWZ1bmN0aW9uICIrY2xhc3NOYW1lKyJfbG8oIithcmdzLmpvaW4oIiwiKSsiKXt2YXIgYj10aGlzLm9mZnNldCxkPTAsIithX3ZhcnMuam9pbigiLCIpKyIsIitjX3ZhcnMuam9pbigiLCIpKTsKICAgIGZvcih2YXIgaT0wOyBpPGRpbWVuc2lvbjsgKytpKSB7CiAgICAgIGNvZGUucHVzaCgKICAiaWYodHlwZW9mIGkiK2krIj09PSdudW1iZXInJiZpIitpKyI+PTApe1wKZD1pIitpKyJ8MDtcCmIrPWMiK2krIipkO1wKYSIraSsiLT1kfSIpOwogICAgfQogICAgY29kZS5wdXNoKCJyZXR1cm4gbmV3ICIrY2xhc3NOYW1lKyIodGhpcy5kYXRhLCIrCiAgICAgIGluZGljZXMubWFwKGZ1bmN0aW9uKGkpIHsKICAgICAgICByZXR1cm4gImEiK2kKICAgICAgfSkuam9pbigiLCIpKyIsIisKICAgICAgaW5kaWNlcy5tYXAoZnVuY3Rpb24oaSkgewogICAgICAgIHJldHVybiAiYyIraQogICAgICB9KS5qb2luKCIsIikrIixiKX0iKTsKCiAgICAvL3ZpZXcuc3RlcCgpOgogICAgY29kZS5wdXNoKCJwcm90by5zdGVwPWZ1bmN0aW9uICIrY2xhc3NOYW1lKyJfc3RlcCgiK2FyZ3Muam9pbigiLCIpKyIpe3ZhciAiKwogICAgICBpbmRpY2VzLm1hcChmdW5jdGlvbihpKSB7CiAgICAgICAgcmV0dXJuICJhIitpKyI9dGhpcy5zaGFwZVsiK2krIl0iCiAgICAgIH0pLmpvaW4oIiwiKSsiLCIrCiAgICAgIGluZGljZXMubWFwKGZ1bmN0aW9uKGkpIHsKICAgICAgICByZXR1cm4gImIiK2krIj10aGlzLnN0cmlkZVsiK2krIl0iCiAgICAgIH0pLmpvaW4oIiwiKSsiLGM9dGhpcy5vZmZzZXQsZD0wLGNlaWw9TWF0aC5jZWlsIik7CiAgICBmb3IodmFyIGk9MDsgaTxkaW1lbnNpb247ICsraSkgewogICAgICBjb2RlLnB1c2goCiAgImlmKHR5cGVvZiBpIitpKyI9PT0nbnVtYmVyJyl7XApkPWkiK2krInwwO1wKaWYoZDwwKXtcCmMrPWIiK2krIiooYSIraSsiLTEpO1wKYSIraSsiPWNlaWwoLWEiK2krIi9kKVwKfWVsc2V7XAphIitpKyI9Y2VpbChhIitpKyIvZClcCn1cCmIiK2krIio9ZFwKfSIpOwogICAgfQogICAgY29kZS5wdXNoKCJyZXR1cm4gbmV3ICIrY2xhc3NOYW1lKyIodGhpcy5kYXRhLCIrCiAgICAgIGluZGljZXMubWFwKGZ1bmN0aW9uKGkpIHsKICAgICAgICByZXR1cm4gImEiICsgaQogICAgICB9KS5qb2luKCIsIikrIiwiKwogICAgICBpbmRpY2VzLm1hcChmdW5jdGlvbihpKSB7CiAgICAgICAgcmV0dXJuICJiIiArIGkKICAgICAgfSkuam9pbigiLCIpKyIsYyl9Iik7CgogICAgLy92aWV3LnRyYW5zcG9zZSgpOgogICAgdmFyIHRTaGFwZSA9IG5ldyBBcnJheShkaW1lbnNpb24pOwogICAgdmFyIHRTdHJpZGUgPSBuZXcgQXJyYXkoZGltZW5zaW9uKTsKICAgIGZvcih2YXIgaT0wOyBpPGRpbWVuc2lvbjsgKytpKSB7CiAgICAgIHRTaGFwZVtpXSA9ICJhW2kiK2krIl0iOwogICAgICB0U3RyaWRlW2ldID0gImJbaSIraSsiXSI7CiAgICB9CiAgICBjb2RlLnB1c2goInByb3RvLnRyYW5zcG9zZT1mdW5jdGlvbiAiK2NsYXNzTmFtZSsiX3RyYW5zcG9zZSgiK2FyZ3MrIil7IisKICAgICAgYXJncy5tYXAoZnVuY3Rpb24obixpZHgpIHsgcmV0dXJuIG4gKyAiPSgiICsgbiArICI9PT11bmRlZmluZWQ/IiArIGlkeCArICI6IiArIG4gKyAifDApIn0pLmpvaW4oIjsiKSwKICAgICAgInZhciBhPXRoaXMuc2hhcGUsYj10aGlzLnN0cmlkZTtyZXR1cm4gbmV3ICIrY2xhc3NOYW1lKyIodGhpcy5kYXRhLCIrdFNoYXBlLmpvaW4oIiwiKSsiLCIrdFN0cmlkZS5qb2luKCIsIikrIix0aGlzLm9mZnNldCl9Iik7CgogICAgLy92aWV3LnBpY2soKToKICAgIGNvZGUucHVzaCgicHJvdG8ucGljaz1mdW5jdGlvbiAiK2NsYXNzTmFtZSsiX3BpY2soIithcmdzKyIpe3ZhciBhPVtdLGI9W10sYz10aGlzLm9mZnNldCIpOwogICAgZm9yKHZhciBpPTA7IGk8ZGltZW5zaW9uOyArK2kpIHsKICAgICAgY29kZS5wdXNoKCJpZih0eXBlb2YgaSIraSsiPT09J251bWJlcicmJmkiK2krIj49MCl7Yz0oYyt0aGlzLnN0cmlkZVsiK2krIl0qaSIraSsiKXwwfWVsc2V7YS5wdXNoKHRoaXMuc2hhcGVbIitpKyJdKTtiLnB1c2godGhpcy5zdHJpZGVbIitpKyJdKX0iKTsKICAgIH0KICAgIGNvZGUucHVzaCgidmFyIGN0b3I9Q1RPUl9MSVNUW2EubGVuZ3RoKzFdO3JldHVybiBjdG9yKHRoaXMuZGF0YSxhLGIsYyl9Iik7CgogICAgLy9BZGQgcmV0dXJuIHN0YXRlbWVudAogICAgY29kZS5wdXNoKCJyZXR1cm4gZnVuY3Rpb24gY29uc3RydWN0XyIrY2xhc3NOYW1lKyIoZGF0YSxzaGFwZSxzdHJpZGUsb2Zmc2V0KXtyZXR1cm4gbmV3ICIrY2xhc3NOYW1lKyIoZGF0YSwiKwogICAgICBpbmRpY2VzLm1hcChmdW5jdGlvbihpKSB7CiAgICAgICAgcmV0dXJuICJzaGFwZVsiK2krIl0iCiAgICAgIH0pLmpvaW4oIiwiKSsiLCIrCiAgICAgIGluZGljZXMubWFwKGZ1bmN0aW9uKGkpIHsKICAgICAgICByZXR1cm4gInN0cmlkZVsiK2krIl0iCiAgICAgIH0pLmpvaW4oIiwiKSsiLG9mZnNldCl9Iik7CgogICAgLy9Db21waWxlIHByb2NlZHVyZQogICAgdmFyIHByb2NlZHVyZSA9IG5ldyBGdW5jdGlvbigiQ1RPUl9MSVNUIiwgIk9SREVSIiwgY29kZS5qb2luKCJcbiIpKTsKICAgIHJldHVybiBwcm9jZWR1cmUoQ0FDSEVEX0NPTlNUUlVDVE9SU1tkdHlwZV0sIG9yZGVyKQogIH0KCiAgZnVuY3Rpb24gYXJyYXlEVHlwZShkYXRhKSB7CiAgICBpZihpc0J1ZmZlcl8xKGRhdGEpKSB7CiAgICAgIHJldHVybiAiYnVmZmVyIgogICAgfQogICAgaWYoaGFzVHlwZWRBcnJheXMpIHsKICAgICAgc3dpdGNoKE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChkYXRhKSkgewogICAgICAgIGNhc2UgIltvYmplY3QgRmxvYXQ2NEFycmF5XSI6CiAgICAgICAgICByZXR1cm4gImZsb2F0NjQiCiAgICAgICAgY2FzZSAiW29iamVjdCBGbG9hdDMyQXJyYXldIjoKICAgICAgICAgIHJldHVybiAiZmxvYXQzMiIKICAgICAgICBjYXNlICJbb2JqZWN0IEludDhBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJpbnQ4IgogICAgICAgIGNhc2UgIltvYmplY3QgSW50MTZBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJpbnQxNiIKICAgICAgICBjYXNlICJbb2JqZWN0IEludDMyQXJyYXldIjoKICAgICAgICAgIHJldHVybiAiaW50MzIiCiAgICAgICAgY2FzZSAiW29iamVjdCBVaW50OEFycmF5XSI6CiAgICAgICAgICByZXR1cm4gInVpbnQ4IgogICAgICAgIGNhc2UgIltvYmplY3QgVWludDE2QXJyYXldIjoKICAgICAgICAgIHJldHVybiAidWludDE2IgogICAgICAgIGNhc2UgIltvYmplY3QgVWludDMyQXJyYXldIjoKICAgICAgICAgIHJldHVybiAidWludDMyIgogICAgICAgIGNhc2UgIltvYmplY3QgVWludDhDbGFtcGVkQXJyYXldIjoKICAgICAgICAgIHJldHVybiAidWludDhfY2xhbXBlZCIKICAgICAgICBjYXNlICJbb2JqZWN0IEJpZ0ludDY0QXJyYXldIjoKICAgICAgICAgIHJldHVybiAiYmlnaW50NjQiCiAgICAgICAgY2FzZSAiW29iamVjdCBCaWdVaW50NjRBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJiaWd1aW50NjQiCiAgICAgIH0KICAgIH0KICAgIGlmKEFycmF5LmlzQXJyYXkoZGF0YSkpIHsKICAgICAgcmV0dXJuICJhcnJheSIKICAgIH0KICAgIHJldHVybiAiZ2VuZXJpYyIKICB9CgogIHZhciBDQUNIRURfQ09OU1RSVUNUT1JTID0gewogICAgImZsb2F0MzIiOltdLAogICAgImZsb2F0NjQiOltdLAogICAgImludDgiOltdLAogICAgImludDE2IjpbXSwKICAgICJpbnQzMiI6W10sCiAgICAidWludDgiOltdLAogICAgInVpbnQxNiI6W10sCiAgICAidWludDMyIjpbXSwKICAgICJhcnJheSI6W10sCiAgICAidWludDhfY2xhbXBlZCI6W10sCiAgICAiYmlnaW50NjQiOiBbXSwKICAgICJiaWd1aW50NjQiOiBbXSwKICAgICJidWZmZXIiOltdLAogICAgImdlbmVyaWMiOltdCiAgfQoKICA7CiAgZnVuY3Rpb24gd3JhcHBlZE5EQXJyYXlDdG9yKGRhdGEsIHNoYXBlLCBzdHJpZGUsIG9mZnNldCkgewogICAgaWYoZGF0YSA9PT0gdW5kZWZpbmVkKSB7CiAgICAgIHZhciBjdG9yID0gQ0FDSEVEX0NPTlNUUlVDVE9SUy5hcnJheVswXTsKICAgICAgcmV0dXJuIGN0b3IoW10pCiAgICB9IGVsc2UgaWYodHlwZW9mIGRhdGEgPT09ICJudW1iZXIiKSB7CiAgICAgIGRhdGEgPSBbZGF0YV07CiAgICB9CiAgICBpZihzaGFwZSA9PT0gdW5kZWZpbmVkKSB7CiAgICAgIHNoYXBlID0gWyBkYXRhLmxlbmd0aCBdOwogICAgfQogICAgdmFyIGQgPSBzaGFwZS5sZW5ndGg7CiAgICBpZihzdHJpZGUgPT09IHVuZGVmaW5lZCkgewogICAgICBzdHJpZGUgPSBuZXcgQXJyYXkoZCk7CiAgICAgIGZvcih2YXIgaT1kLTEsIHN6PTE7IGk+PTA7IC0taSkgewogICAgICAgIHN0cmlkZVtpXSA9IHN6OwogICAgICAgIHN6ICo9IHNoYXBlW2ldOwogICAgICB9CiAgICB9CiAgICBpZihvZmZzZXQgPT09IHVuZGVmaW5lZCkgewogICAgICBvZmZzZXQgPSAwOwogICAgICBmb3IodmFyIGk9MDsgaTxkOyArK2kpIHsKICAgICAgICBpZihzdHJpZGVbaV0gPCAwKSB7CiAgICAgICAgICBvZmZzZXQgLT0gKHNoYXBlW2ldLTEpKnN0cmlkZVtpXTsKICAgICAgICB9CiAgICAgIH0KICAgIH0KICAgIHZhciBkdHlwZSA9IGFycmF5RFR5cGUoZGF0YSk7CiAgICB2YXIgY3Rvcl9saXN0ID0gQ0FDSEVEX0NPTlNUUlVDVE9SU1tkdHlwZV07CiAgICB3aGlsZShjdG9yX2xpc3QubGVuZ3RoIDw9IGQrMSkgewogICAgICBjdG9yX2xpc3QucHVzaChjb21waWxlQ29uc3RydWN0b3IoZHR5cGUsIGN0b3JfbGlzdC5sZW5ndGgtMSkpOwogICAgfQogICAgdmFyIGN0b3IgPSBjdG9yX2xpc3RbZCsxXTsKICAgIHJldHVybiBjdG9yKGRhdGEsIHNoYXBlLCBzdHJpZGUsIG9mZnNldCkKICB9CgogIHZhciBuZGFycmF5ID0gd3JhcHBlZE5EQXJyYXlDdG9yOwoKICBjbGFzcyBNYXJ0aW5pIHsKICAgIGNvbnN0cnVjdG9yKGdyaWRTaXplID0gMjU3KSB7CiAgICAgIHRoaXMuZ3JpZFNpemUgPSBncmlkU2l6ZTsKICAgICAgY29uc3QgdGlsZVNpemUgPSBncmlkU2l6ZSAtIDE7CiAgICAgIGlmICh0aWxlU2l6ZSAmIHRpbGVTaXplIC0gMSkgdGhyb3cgbmV3IEVycm9yKGBFeHBlY3RlZCBncmlkIHNpemUgdG8gYmUgMl5uKzEsIGdvdCAke2dyaWRTaXplfS5gKTsKICAgICAgdGhpcy5udW1UcmlhbmdsZXMgPSB0aWxlU2l6ZSAqIHRpbGVTaXplICogMiAtIDI7CiAgICAgIHRoaXMubnVtUGFyZW50VHJpYW5nbGVzID0gdGhpcy5udW1UcmlhbmdsZXMgLSB0aWxlU2l6ZSAqIHRpbGVTaXplOwogICAgICB0aGlzLmluZGljZXMgPSBuZXcgVWludDMyQXJyYXkodGhpcy5ncmlkU2l6ZSAqIHRoaXMuZ3JpZFNpemUpOyAvLyBjb29yZGluYXRlcyBmb3IgYWxsIHBvc3NpYmxlIHRyaWFuZ2xlcyBpbiBhbiBSVElOIHRpbGUKCiAgICAgIHRoaXMuY29vcmRzID0gbmV3IFVpbnQxNkFycmF5KHRoaXMubnVtVHJpYW5nbGVzICogNCk7IC8vIGdldCB0cmlhbmdsZSBjb29yZGluYXRlcyBmcm9tIGl0cyBpbmRleCBpbiBhbiBpbXBsaWNpdCBiaW5hcnkgdHJlZQoKICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLm51bVRyaWFuZ2xlczsgaSsrKSB7CiAgICAgICAgbGV0IGlkID0gaSArIDI7CiAgICAgICAgbGV0IGF4ID0gMCwKICAgICAgICAgICAgYXkgPSAwLAogICAgICAgICAgICBieCA9IDAsCiAgICAgICAgICAgIGJ5ID0gMCwKICAgICAgICAgICAgY3ggPSAwLAogICAgICAgICAgICBjeSA9IDA7CgogICAgICAgIGlmIChpZCAmIDEpIHsKICAgICAgICAgIGJ4ID0gYnkgPSBjeCA9IHRpbGVTaXplOyAvLyBib3R0b20tbGVmdCB0cmlhbmdsZQogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICBheCA9IGF5ID0gY3kgPSB0aWxlU2l6ZTsgLy8gdG9wLXJpZ2h0IHRyaWFuZ2xlCiAgICAgICAgfQoKICAgICAgICB3aGlsZSAoKGlkID4+PSAxKSA+IDEpIHsKICAgICAgICAgIGNvbnN0IG14ID0gYXggKyBieCA+PiAxOwogICAgICAgICAgY29uc3QgbXkgPSBheSArIGJ5ID4+IDE7CgogICAgICAgICAgaWYgKGlkICYgMSkgewogICAgICAgICAgICAvLyBsZWZ0IGhhbGYKICAgICAgICAgICAgYnggPSBheDsKICAgICAgICAgICAgYnkgPSBheTsKICAgICAgICAgICAgYXggPSBjeDsKICAgICAgICAgICAgYXkgPSBjeTsKICAgICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAgIC8vIHJpZ2h0IGhhbGYKICAgICAgICAgICAgYXggPSBieDsKICAgICAgICAgICAgYXkgPSBieTsKICAgICAgICAgICAgYnggPSBjeDsKICAgICAgICAgICAgYnkgPSBjeTsKICAgICAgICAgIH0KCiAgICAgICAgICBjeCA9IG14OwogICAgICAgICAgY3kgPSBteTsKICAgICAgICB9CgogICAgICAgIGNvbnN0IGsgPSBpICogNDsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgMF0gPSBheDsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgMV0gPSBheTsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgMl0gPSBieDsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgM10gPSBieTsKICAgICAgfQogICAgfQoKICAgIGNyZWF0ZVRpbGUodGVycmFpbikgewogICAgICByZXR1cm4gbmV3IFRpbGUodGVycmFpbiwgdGhpcyk7CiAgICB9CgogIH0KCiAgY2xhc3MgVGlsZSB7CiAgICBjb25zdHJ1Y3Rvcih0ZXJyYWluLCBtYXJ0aW5pKSB7CiAgICAgIGNvbnN0IHNpemUgPSBtYXJ0aW5pLmdyaWRTaXplOwogICAgICBpZiAodGVycmFpbi5sZW5ndGggIT09IHNpemUgKiBzaXplKSB0aHJvdyBuZXcgRXJyb3IoYEV4cGVjdGVkIHRlcnJhaW4gZGF0YSBvZiBsZW5ndGggJHtzaXplICogc2l6ZX0gKCR7c2l6ZX0geCAke3NpemV9KSwgZ290ICR7dGVycmFpbi5sZW5ndGh9LmApOwogICAgICB0aGlzLnRlcnJhaW4gPSB0ZXJyYWluOwogICAgICB0aGlzLm1hcnRpbmkgPSBtYXJ0aW5pOwogICAgICB0aGlzLmVycm9ycyA9IG5ldyBGbG9hdDMyQXJyYXkodGVycmFpbi5sZW5ndGgpOwogICAgICB0aGlzLnVwZGF0ZSgpOwogICAgfQoKICAgIHVwZGF0ZSgpIHsKICAgICAgY29uc3QgewogICAgICAgIG51bVRyaWFuZ2xlcywKICAgICAgICBudW1QYXJlbnRUcmlhbmdsZXMsCiAgICAgICAgY29vcmRzLAogICAgICAgIGdyaWRTaXplOiBzaXplCiAgICAgIH0gPSB0aGlzLm1hcnRpbmk7CiAgICAgIGNvbnN0IHsKICAgICAgICB0ZXJyYWluLAogICAgICAgIGVycm9ycwogICAgICB9ID0gdGhpczsgLy8gaXRlcmF0ZSBvdmVyIGFsbCBwb3NzaWJsZSB0cmlhbmdsZXMsIHN0YXJ0aW5nIGZyb20gdGhlIHNtYWxsZXN0IGxldmVsCgogICAgICBmb3IgKGxldCBpID0gbnVtVHJpYW5nbGVzIC0gMTsgaSA+PSAwOyBpLS0pIHsKICAgICAgICBjb25zdCBrID0gaSAqIDQ7CiAgICAgICAgY29uc3QgYXggPSBjb29yZHNbayArIDBdOwogICAgICAgIGNvbnN0IGF5ID0gY29vcmRzW2sgKyAxXTsKICAgICAgICBjb25zdCBieCA9IGNvb3Jkc1trICsgMl07CiAgICAgICAgY29uc3QgYnkgPSBjb29yZHNbayArIDNdOwogICAgICAgIGNvbnN0IG14ID0gYXggKyBieCA+PiAxOwogICAgICAgIGNvbnN0IG15ID0gYXkgKyBieSA+PiAxOwogICAgICAgIGNvbnN0IGN4ID0gbXggKyBteSAtIGF5OwogICAgICAgIGNvbnN0IGN5ID0gbXkgKyBheCAtIG14OyAvLyBjYWxjdWxhdGUgZXJyb3IgaW4gdGhlIG1pZGRsZSBvZiB0aGUgbG9uZyBlZGdlIG9mIHRoZSB0cmlhbmdsZQoKICAgICAgICBjb25zdCBpbnRlcnBvbGF0ZWRIZWlnaHQgPSAodGVycmFpbltheSAqIHNpemUgKyBheF0gKyB0ZXJyYWluW2J5ICogc2l6ZSArIGJ4XSkgLyAyOwogICAgICAgIGNvbnN0IG1pZGRsZUluZGV4ID0gbXkgKiBzaXplICsgbXg7CiAgICAgICAgY29uc3QgbWlkZGxlRXJyb3IgPSBNYXRoLmFicyhpbnRlcnBvbGF0ZWRIZWlnaHQgLSB0ZXJyYWluW21pZGRsZUluZGV4XSk7CiAgICAgICAgZXJyb3JzW21pZGRsZUluZGV4XSA9IE1hdGgubWF4KGVycm9yc1ttaWRkbGVJbmRleF0sIG1pZGRsZUVycm9yKTsKCiAgICAgICAgaWYgKGkgPCBudW1QYXJlbnRUcmlhbmdsZXMpIHsKICAgICAgICAgIC8vIGJpZ2dlciB0cmlhbmdsZXM7IGFjY3VtdWxhdGUgZXJyb3Igd2l0aCBjaGlsZHJlbgogICAgICAgICAgY29uc3QgbGVmdENoaWxkSW5kZXggPSAoYXkgKyBjeSA+PiAxKSAqIHNpemUgKyAoYXggKyBjeCA+PiAxKTsKICAgICAgICAgIGNvbnN0IHJpZ2h0Q2hpbGRJbmRleCA9IChieSArIGN5ID4+IDEpICogc2l6ZSArIChieCArIGN4ID4+IDEpOwogICAgICAgICAgZXJyb3JzW21pZGRsZUluZGV4XSA9IE1hdGgubWF4KGVycm9yc1ttaWRkbGVJbmRleF0sIGVycm9yc1tsZWZ0Q2hpbGRJbmRleF0sIGVycm9yc1tyaWdodENoaWxkSW5kZXhdKTsKICAgICAgICB9CiAgICAgIH0KICAgIH0KCiAgICBnZXRNZXNoKG1heEVycm9yID0gMCwgbWF4TGVuZ3RoID0gbnVsbCkgewogICAgICBjb25zdCB7CiAgICAgICAgZ3JpZFNpemU6IHNpemUsCiAgICAgICAgaW5kaWNlcwogICAgICB9ID0gdGhpcy5tYXJ0aW5pOwogICAgICBjb25zdCB7CiAgICAgICAgZXJyb3JzCiAgICAgIH0gPSB0aGlzOwogICAgICBsZXQgbnVtVmVydGljZXMgPSAwOwogICAgICBsZXQgbnVtVHJpYW5nbGVzID0gMDsKICAgICAgY29uc3QgbWF4ID0gc2l6ZSAtIDE7IC8vIFRoZSBtYXhMZW5ndGggcGFyYW1ldGVyIHdpbGwgY2F1c2UgdHJpYW5nbGVzIHRvIGJlIGdlbmVyYXRlZCB1bnRpbCB0aGUgbGVncyBhcmUgYmVsb3cgdGhpcyBsZW5ndGgKICAgICAgLy8gSXQgaXMgbWVhbnQgdG8gc3VwcG9ydCBjYXNlcyB3aGVyZSBhIGNlcnRhaW4gbWVzaCBkZW5zaXR5IGlzIHJlcXVpcmVkIHRvIGRvIHNwaGVyaWNhbCBtYXRoIG9uIGRpZ2l0YWwgZ2xvYmVzCgogICAgICBjb25zdCBtYXhTY2FsZSA9IG1heExlbmd0aCB8fCBzaXplOyAvLyB1c2UgYW4gaW5kZXggZ3JpZCB0byBrZWVwIHRyYWNrIG9mIHZlcnRpY2VzIHRoYXQgd2VyZSBhbHJlYWR5IHVzZWQgdG8gYXZvaWQgZHVwbGljYXRpb24KCiAgICAgIGluZGljZXMuZmlsbCgwKTsgLy8gcmV0cmlldmUgbWVzaCBpbiB0d28gc3RhZ2VzIHRoYXQgYm90aCB0cmF2ZXJzZSB0aGUgZXJyb3IgbWFwOgogICAgICAvLyAtIGNvdW50RWxlbWVudHM6IGZpbmQgdXNlZCB2ZXJ0aWNlcyAoYW5kIGFzc2lnbiBlYWNoIGFuIGluZGV4KSwgYW5kIGNvdW50IHRyaWFuZ2xlcyAoZm9yIG1pbmltdW0gYWxsb2NhdGlvbikKICAgICAgLy8gLSBwcm9jZXNzVHJpYW5nbGU6IGZpbGwgdGhlIGFsbG9jYXRlZCB2ZXJ0aWNlcyAmIHRyaWFuZ2xlcyB0eXBlZCBhcnJheXMKCiAgICAgIGZ1bmN0aW9uIGNvdW50RWxlbWVudHMoYXgsIGF5LCBieCwgYnksIGN4LCBjeSkgewogICAgICAgIGNvbnN0IG14ID0gYXggKyBieCA+PiAxOwogICAgICAgIGNvbnN0IG15ID0gYXkgKyBieSA+PiAxOwogICAgICAgIGNvbnN0IGxlZ0xlbmd0aCA9IE1hdGguYWJzKGF4IC0gY3gpICsgTWF0aC5hYnMoYXkgLSBjeSk7CgogICAgICAgIGlmIChsZWdMZW5ndGggPiAxICYmIGVycm9yc1tteSAqIHNpemUgKyBteF0gPiBtYXhFcnJvciB8fCBsZWdMZW5ndGggPiBtYXhTY2FsZSkgewogICAgICAgICAgY291bnRFbGVtZW50cyhjeCwgY3ksIGF4LCBheSwgbXgsIG15KTsKICAgICAgICAgIGNvdW50RWxlbWVudHMoYngsIGJ5LCBjeCwgY3ksIG14LCBteSk7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgIGluZGljZXNbYXkgKiBzaXplICsgYXhdID0gaW5kaWNlc1theSAqIHNpemUgKyBheF0gfHwgKytudW1WZXJ0aWNlczsKICAgICAgICAgIGluZGljZXNbYnkgKiBzaXplICsgYnhdID0gaW5kaWNlc1tieSAqIHNpemUgKyBieF0gfHwgKytudW1WZXJ0aWNlczsKICAgICAgICAgIGluZGljZXNbY3kgKiBzaXplICsgY3hdID0gaW5kaWNlc1tjeSAqIHNpemUgKyBjeF0gfHwgKytudW1WZXJ0aWNlczsKICAgICAgICAgIG51bVRyaWFuZ2xlcysrOwogICAgICAgIH0KICAgICAgfQoKICAgICAgY291bnRFbGVtZW50cygwLCAwLCBtYXgsIG1heCwgbWF4LCAwKTsKICAgICAgY291bnRFbGVtZW50cyhtYXgsIG1heCwgMCwgMCwgMCwgbWF4KTsKICAgICAgY29uc3QgdmVydGljZXMgPSBuZXcgVWludDE2QXJyYXkobnVtVmVydGljZXMgKiAyKTsKICAgICAgY29uc3QgdHJpYW5nbGVzID0gbmV3IFVpbnQzMkFycmF5KG51bVRyaWFuZ2xlcyAqIDMpOwogICAgICBsZXQgdHJpSW5kZXggPSAwOwoKICAgICAgZnVuY3Rpb24gcHJvY2Vzc1RyaWFuZ2xlKGF4LCBheSwgYngsIGJ5LCBjeCwgY3kpIHsKICAgICAgICBjb25zdCBteCA9IGF4ICsgYnggPj4gMTsKICAgICAgICBjb25zdCBteSA9IGF5ICsgYnkgPj4gMTsKICAgICAgICBjb25zdCBsZWdMZW5ndGggPSBNYXRoLmFicyhheCAtIGN4KSArIE1hdGguYWJzKGF5IC0gY3kpOwoKICAgICAgICBpZiAobGVnTGVuZ3RoID4gMSAmJiBlcnJvcnNbbXkgKiBzaXplICsgbXhdID4gbWF4RXJyb3IgfHwgbGVnTGVuZ3RoID4gbWF4U2NhbGUpIHsKICAgICAgICAgIC8vIHRyaWFuZ2xlIGRvZXNuJ3QgYXBwcm94aW1hdGUgdGhlIHN1cmZhY2Ugd2VsbCBlbm91Z2g7IGRyaWxsIGRvd24gZnVydGhlcgogICAgICAgICAgcHJvY2Vzc1RyaWFuZ2xlKGN4LCBjeSwgYXgsIGF5LCBteCwgbXkpOwogICAgICAgICAgcHJvY2Vzc1RyaWFuZ2xlKGJ4LCBieSwgY3gsIGN5LCBteCwgbXkpOwogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAvLyBhZGQgYSB0cmlhbmdsZQogICAgICAgICAgY29uc3QgYSA9IGluZGljZXNbYXkgKiBzaXplICsgYXhdIC0gMTsKICAgICAgICAgIGNvbnN0IGIgPSBpbmRpY2VzW2J5ICogc2l6ZSArIGJ4XSAtIDE7CiAgICAgICAgICBjb25zdCBjID0gaW5kaWNlc1tjeSAqIHNpemUgKyBjeF0gLSAxOwogICAgICAgICAgdmVydGljZXNbMiAqIGFdID0gYXg7CiAgICAgICAgICB2ZXJ0aWNlc1syICogYSArIDFdID0gYXk7CiAgICAgICAgICB2ZXJ0aWNlc1syICogYl0gPSBieDsKICAgICAgICAgIHZlcnRpY2VzWzIgKiBiICsgMV0gPSBieTsKICAgICAgICAgIHZlcnRpY2VzWzIgKiBjXSA9IGN4OwogICAgICAgICAgdmVydGljZXNbMiAqIGMgKyAxXSA9IGN5OwogICAgICAgICAgdHJpYW5nbGVzW3RyaUluZGV4KytdID0gYTsKICAgICAgICAgIHRyaWFuZ2xlc1t0cmlJbmRleCsrXSA9IGI7CiAgICAgICAgICB0cmlhbmdsZXNbdHJpSW5kZXgrK10gPSBjOwogICAgICAgIH0KICAgICAgfQoKICAgICAgcHJvY2Vzc1RyaWFuZ2xlKDAsIDAsIG1heCwgbWF4LCBtYXgsIDApOwogICAgICBwcm9jZXNzVHJpYW5nbGUobWF4LCBtYXgsIDAsIDAsIDAsIG1heCk7CiAgICAgIHJldHVybiB7CiAgICAgICAgdmVydGljZXMsCiAgICAgICAgdHJpYW5nbGVzCiAgICAgIH07CiAgICB9CgogIH0KCiAgZnVuY3Rpb24gY3JlYXRlQ29tbW9uanNNb2R1bGUoZm4pIHsKICAgIHZhciBtb2R1bGUgPSB7IGV4cG9ydHM6IHt9IH07CiAgCXJldHVybiBmbihtb2R1bGUsIG1vZHVsZS5leHBvcnRzKSwgbW9kdWxlLmV4cG9ydHM7CiAgfQoKICAvKioKICAgKiBDb3B5cmlnaHQgKGMpIDIwMTQtcHJlc2VudCwgRmFjZWJvb2ssIEluYy4KICAgKgogICAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlIGZvdW5kIGluIHRoZQogICAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS4KICAgKi8KCiAgY3JlYXRlQ29tbW9uanNNb2R1bGUoZnVuY3Rpb24gKG1vZHVsZSkgewogIHZhciBydW50aW1lID0gKGZ1bmN0aW9uIChleHBvcnRzKSB7CgogICAgdmFyIE9wID0gT2JqZWN0LnByb3RvdHlwZTsKICAgIHZhciBoYXNPd24gPSBPcC5oYXNPd25Qcm9wZXJ0eTsKICAgIHZhciB1bmRlZmluZWQkMTsgLy8gTW9yZSBjb21wcmVzc2libGUgdGhhbiB2b2lkIDAuCiAgICB2YXIgJFN5bWJvbCA9IHR5cGVvZiBTeW1ib2wgPT09ICJmdW5jdGlvbiIgPyBTeW1ib2wgOiB7fTsKICAgIHZhciBpdGVyYXRvclN5bWJvbCA9ICRTeW1ib2wuaXRlcmF0b3IgfHwgIkBAaXRlcmF0b3IiOwogICAgdmFyIGFzeW5jSXRlcmF0b3JTeW1ib2wgPSAkU3ltYm9sLmFzeW5jSXRlcmF0b3IgfHwgIkBAYXN5bmNJdGVyYXRvciI7CiAgICB2YXIgdG9TdHJpbmdUYWdTeW1ib2wgPSAkU3ltYm9sLnRvU3RyaW5nVGFnIHx8ICJAQHRvU3RyaW5nVGFnIjsKCiAgICBmdW5jdGlvbiBkZWZpbmUob2JqLCBrZXksIHZhbHVlKSB7CiAgICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgewogICAgICAgIHZhbHVlOiB2YWx1ZSwKICAgICAgICBlbnVtZXJhYmxlOiB0cnVlLAogICAgICAgIGNvbmZpZ3VyYWJsZTogdHJ1ZSwKICAgICAgICB3cml0YWJsZTogdHJ1ZQogICAgICB9KTsKICAgICAgcmV0dXJuIG9ialtrZXldOwogICAgfQogICAgdHJ5IHsKICAgICAgLy8gSUUgOCBoYXMgYSBicm9rZW4gT2JqZWN0LmRlZmluZVByb3BlcnR5IHRoYXQgb25seSB3b3JrcyBvbiBET00gb2JqZWN0cy4KICAgICAgZGVmaW5lKHt9LCAiIik7CiAgICB9IGNhdGNoIChlcnIpIHsKICAgICAgZGVmaW5lID0gZnVuY3Rpb24ob2JqLCBrZXksIHZhbHVlKSB7CiAgICAgICAgcmV0dXJuIG9ialtrZXldID0gdmFsdWU7CiAgICAgIH07CiAgICB9CgogICAgZnVuY3Rpb24gd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCkgewogICAgICAvLyBJZiBvdXRlckZuIHByb3ZpZGVkIGFuZCBvdXRlckZuLnByb3RvdHlwZSBpcyBhIEdlbmVyYXRvciwgdGhlbiBvdXRlckZuLnByb3RvdHlwZSBpbnN0YW5jZW9mIEdlbmVyYXRvci4KICAgICAgdmFyIHByb3RvR2VuZXJhdG9yID0gb3V0ZXJGbiAmJiBvdXRlckZuLnByb3RvdHlwZSBpbnN0YW5jZW9mIEdlbmVyYXRvciA/IG91dGVyRm4gOiBHZW5lcmF0b3I7CiAgICAgIHZhciBnZW5lcmF0b3IgPSBPYmplY3QuY3JlYXRlKHByb3RvR2VuZXJhdG9yLnByb3RvdHlwZSk7CiAgICAgIHZhciBjb250ZXh0ID0gbmV3IENvbnRleHQodHJ5TG9jc0xpc3QgfHwgW10pOwoKICAgICAgLy8gVGhlIC5faW52b2tlIG1ldGhvZCB1bmlmaWVzIHRoZSBpbXBsZW1lbnRhdGlvbnMgb2YgdGhlIC5uZXh0LAogICAgICAvLyAudGhyb3csIGFuZCAucmV0dXJuIG1ldGhvZHMuCiAgICAgIGdlbmVyYXRvci5faW52b2tlID0gbWFrZUludm9rZU1ldGhvZChpbm5lckZuLCBzZWxmLCBjb250ZXh0KTsKCiAgICAgIHJldHVybiBnZW5lcmF0b3I7CiAgICB9CiAgICBleHBvcnRzLndyYXAgPSB3cmFwOwoKICAgIC8vIFRyeS9jYXRjaCBoZWxwZXIgdG8gbWluaW1pemUgZGVvcHRpbWl6YXRpb25zLiBSZXR1cm5zIGEgY29tcGxldGlvbgogICAgLy8gcmVjb3JkIGxpa2UgY29udGV4dC50cnlFbnRyaWVzW2ldLmNvbXBsZXRpb24uIFRoaXMgaW50ZXJmYWNlIGNvdWxkCiAgICAvLyBoYXZlIGJlZW4gKGFuZCB3YXMgcHJldmlvdXNseSkgZGVzaWduZWQgdG8gdGFrZSBhIGNsb3N1cmUgdG8gYmUKICAgIC8vIGludm9rZWQgd2l0aG91dCBhcmd1bWVudHMsIGJ1dCBpbiBhbGwgdGhlIGNhc2VzIHdlIGNhcmUgYWJvdXQgd2UKICAgIC8vIGFscmVhZHkgaGF2ZSBhbiBleGlzdGluZyBtZXRob2Qgd2Ugd2FudCB0byBjYWxsLCBzbyB0aGVyZSdzIG5vIG5lZWQKICAgIC8vIHRvIGNyZWF0ZSBhIG5ldyBmdW5jdGlvbiBvYmplY3QuIFdlIGNhbiBldmVuIGdldCBhd2F5IHdpdGggYXNzdW1pbmcKICAgIC8vIHRoZSBtZXRob2QgdGFrZXMgZXhhY3RseSBvbmUgYXJndW1lbnQsIHNpbmNlIHRoYXQgaGFwcGVucyB0byBiZSB0cnVlCiAgICAvLyBpbiBldmVyeSBjYXNlLCBzbyB3ZSBkb24ndCBoYXZlIHRvIHRvdWNoIHRoZSBhcmd1bWVudHMgb2JqZWN0LiBUaGUKICAgIC8vIG9ubHkgYWRkaXRpb25hbCBhbGxvY2F0aW9uIHJlcXVpcmVkIGlzIHRoZSBjb21wbGV0aW9uIHJlY29yZCwgd2hpY2gKICAgIC8vIGhhcyBhIHN0YWJsZSBzaGFwZSBhbmQgc28gaG9wZWZ1bGx5IHNob3VsZCBiZSBjaGVhcCB0byBhbGxvY2F0ZS4KICAgIGZ1bmN0aW9uIHRyeUNhdGNoKGZuLCBvYmosIGFyZykgewogICAgICB0cnkgewogICAgICAgIHJldHVybiB7IHR5cGU6ICJub3JtYWwiLCBhcmc6IGZuLmNhbGwob2JqLCBhcmcpIH07CiAgICAgIH0gY2F0Y2ggKGVycikgewogICAgICAgIHJldHVybiB7IHR5cGU6ICJ0aHJvdyIsIGFyZzogZXJyIH07CiAgICAgIH0KICAgIH0KCiAgICB2YXIgR2VuU3RhdGVTdXNwZW5kZWRTdGFydCA9ICJzdXNwZW5kZWRTdGFydCI7CiAgICB2YXIgR2VuU3RhdGVTdXNwZW5kZWRZaWVsZCA9ICJzdXNwZW5kZWRZaWVsZCI7CiAgICB2YXIgR2VuU3RhdGVFeGVjdXRpbmcgPSAiZXhlY3V0aW5nIjsKICAgIHZhciBHZW5TdGF0ZUNvbXBsZXRlZCA9ICJjb21wbGV0ZWQiOwoKICAgIC8vIFJldHVybmluZyB0aGlzIG9iamVjdCBmcm9tIHRoZSBpbm5lckZuIGhhcyB0aGUgc2FtZSBlZmZlY3QgYXMKICAgIC8vIGJyZWFraW5nIG91dCBvZiB0aGUgZGlzcGF0Y2ggc3dpdGNoIHN0YXRlbWVudC4KICAgIHZhciBDb250aW51ZVNlbnRpbmVsID0ge307CgogICAgLy8gRHVtbXkgY29uc3RydWN0b3IgZnVuY3Rpb25zIHRoYXQgd2UgdXNlIGFzIHRoZSAuY29uc3RydWN0b3IgYW5kCiAgICAvLyAuY29uc3RydWN0b3IucHJvdG90eXBlIHByb3BlcnRpZXMgZm9yIGZ1bmN0aW9ucyB0aGF0IHJldHVybiBHZW5lcmF0b3IKICAgIC8vIG9iamVjdHMuIEZvciBmdWxsIHNwZWMgY29tcGxpYW5jZSwgeW91IG1heSB3aXNoIHRvIGNvbmZpZ3VyZSB5b3VyCiAgICAvLyBtaW5pZmllciBub3QgdG8gbWFuZ2xlIHRoZSBuYW1lcyBvZiB0aGVzZSB0d28gZnVuY3Rpb25zLgogICAgZnVuY3Rpb24gR2VuZXJhdG9yKCkge30KICAgIGZ1bmN0aW9uIEdlbmVyYXRvckZ1bmN0aW9uKCkge30KICAgIGZ1bmN0aW9uIEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlKCkge30KCiAgICAvLyBUaGlzIGlzIGEgcG9seWZpbGwgZm9yICVJdGVyYXRvclByb3RvdHlwZSUgZm9yIGVudmlyb25tZW50cyB0aGF0CiAgICAvLyBkb24ndCBuYXRpdmVseSBzdXBwb3J0IGl0LgogICAgdmFyIEl0ZXJhdG9yUHJvdG90eXBlID0ge307CiAgICBkZWZpbmUoSXRlcmF0b3JQcm90b3R5cGUsIGl0ZXJhdG9yU3ltYm9sLCBmdW5jdGlvbiAoKSB7CiAgICAgIHJldHVybiB0aGlzOwogICAgfSk7CgogICAgdmFyIGdldFByb3RvID0gT2JqZWN0LmdldFByb3RvdHlwZU9mOwogICAgdmFyIE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlID0gZ2V0UHJvdG8gJiYgZ2V0UHJvdG8oZ2V0UHJvdG8odmFsdWVzKFtdKSkpOwogICAgaWYgKE5hdGl2ZUl0ZXJhdG9yUHJvdG90eXBlICYmCiAgICAgICAgTmF0aXZlSXRlcmF0b3JQcm90b3R5cGUgIT09IE9wICYmCiAgICAgICAgaGFzT3duLmNhbGwoTmF0aXZlSXRlcmF0b3JQcm90b3R5cGUsIGl0ZXJhdG9yU3ltYm9sKSkgewogICAgICAvLyBUaGlzIGVudmlyb25tZW50IGhhcyBhIG5hdGl2ZSAlSXRlcmF0b3JQcm90b3R5cGUlOyB1c2UgaXQgaW5zdGVhZAogICAgICAvLyBvZiB0aGUgcG9seWZpbGwuCiAgICAgIEl0ZXJhdG9yUHJvdG90eXBlID0gTmF0aXZlSXRlcmF0b3JQcm90b3R5cGU7CiAgICB9CgogICAgdmFyIEdwID0gR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUucHJvdG90eXBlID0KICAgICAgR2VuZXJhdG9yLnByb3RvdHlwZSA9IE9iamVjdC5jcmVhdGUoSXRlcmF0b3JQcm90b3R5cGUpOwogICAgR2VuZXJhdG9yRnVuY3Rpb24ucHJvdG90eXBlID0gR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGU7CiAgICBkZWZpbmUoR3AsICJjb25zdHJ1Y3RvciIsIEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlKTsKICAgIGRlZmluZShHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZSwgImNvbnN0cnVjdG9yIiwgR2VuZXJhdG9yRnVuY3Rpb24pOwogICAgR2VuZXJhdG9yRnVuY3Rpb24uZGlzcGxheU5hbWUgPSBkZWZpbmUoCiAgICAgIEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlLAogICAgICB0b1N0cmluZ1RhZ1N5bWJvbCwKICAgICAgIkdlbmVyYXRvckZ1bmN0aW9uIgogICAgKTsKCiAgICAvLyBIZWxwZXIgZm9yIGRlZmluaW5nIHRoZSAubmV4dCwgLnRocm93LCBhbmQgLnJldHVybiBtZXRob2RzIG9mIHRoZQogICAgLy8gSXRlcmF0b3IgaW50ZXJmYWNlIGluIHRlcm1zIG9mIGEgc2luZ2xlIC5faW52b2tlIG1ldGhvZC4KICAgIGZ1bmN0aW9uIGRlZmluZUl0ZXJhdG9yTWV0aG9kcyhwcm90b3R5cGUpIHsKICAgICAgWyJuZXh0IiwgInRocm93IiwgInJldHVybiJdLmZvckVhY2goZnVuY3Rpb24obWV0aG9kKSB7CiAgICAgICAgZGVmaW5lKHByb3RvdHlwZSwgbWV0aG9kLCBmdW5jdGlvbihhcmcpIHsKICAgICAgICAgIHJldHVybiB0aGlzLl9pbnZva2UobWV0aG9kLCBhcmcpOwogICAgICAgIH0pOwogICAgICB9KTsKICAgIH0KCiAgICBleHBvcnRzLmlzR2VuZXJhdG9yRnVuY3Rpb24gPSBmdW5jdGlvbihnZW5GdW4pIHsKICAgICAgdmFyIGN0b3IgPSB0eXBlb2YgZ2VuRnVuID09PSAiZnVuY3Rpb24iICYmIGdlbkZ1bi5jb25zdHJ1Y3RvcjsKICAgICAgcmV0dXJuIGN0b3IKICAgICAgICA/IGN0b3IgPT09IEdlbmVyYXRvckZ1bmN0aW9uIHx8CiAgICAgICAgICAvLyBGb3IgdGhlIG5hdGl2ZSBHZW5lcmF0b3JGdW5jdGlvbiBjb25zdHJ1Y3RvciwgdGhlIGJlc3Qgd2UgY2FuCiAgICAgICAgICAvLyBkbyBpcyB0byBjaGVjayBpdHMgLm5hbWUgcHJvcGVydHkuCiAgICAgICAgICAoY3Rvci5kaXNwbGF5TmFtZSB8fCBjdG9yLm5hbWUpID09PSAiR2VuZXJhdG9yRnVuY3Rpb24iCiAgICAgICAgOiBmYWxzZTsKICAgIH07CgogICAgZXhwb3J0cy5tYXJrID0gZnVuY3Rpb24oZ2VuRnVuKSB7CiAgICAgIGlmIChPYmplY3Quc2V0UHJvdG90eXBlT2YpIHsKICAgICAgICBPYmplY3Quc2V0UHJvdG90eXBlT2YoZ2VuRnVuLCBHZW5lcmF0b3JGdW5jdGlvblByb3RvdHlwZSk7CiAgICAgIH0gZWxzZSB7CiAgICAgICAgZ2VuRnVuLl9fcHJvdG9fXyA9IEdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlOwogICAgICAgIGRlZmluZShnZW5GdW4sIHRvU3RyaW5nVGFnU3ltYm9sLCAiR2VuZXJhdG9yRnVuY3Rpb24iKTsKICAgICAgfQogICAgICBnZW5GdW4ucHJvdG90eXBlID0gT2JqZWN0LmNyZWF0ZShHcCk7CiAgICAgIHJldHVybiBnZW5GdW47CiAgICB9OwoKICAgIC8vIFdpdGhpbiB0aGUgYm9keSBvZiBhbnkgYXN5bmMgZnVuY3Rpb24sIGBhd2FpdCB4YCBpcyB0cmFuc2Zvcm1lZCB0bwogICAgLy8gYHlpZWxkIHJlZ2VuZXJhdG9yUnVudGltZS5hd3JhcCh4KWAsIHNvIHRoYXQgdGhlIHJ1bnRpbWUgY2FuIHRlc3QKICAgIC8vIGBoYXNPd24uY2FsbCh2YWx1ZSwgIl9fYXdhaXQiKWAgdG8gZGV0ZXJtaW5lIGlmIHRoZSB5aWVsZGVkIHZhbHVlIGlzCiAgICAvLyBtZWFudCB0byBiZSBhd2FpdGVkLgogICAgZXhwb3J0cy5hd3JhcCA9IGZ1bmN0aW9uKGFyZykgewogICAgICByZXR1cm4geyBfX2F3YWl0OiBhcmcgfTsKICAgIH07CgogICAgZnVuY3Rpb24gQXN5bmNJdGVyYXRvcihnZW5lcmF0b3IsIFByb21pc2VJbXBsKSB7CiAgICAgIGZ1bmN0aW9uIGludm9rZShtZXRob2QsIGFyZywgcmVzb2x2ZSwgcmVqZWN0KSB7CiAgICAgICAgdmFyIHJlY29yZCA9IHRyeUNhdGNoKGdlbmVyYXRvclttZXRob2RdLCBnZW5lcmF0b3IsIGFyZyk7CiAgICAgICAgaWYgKHJlY29yZC50eXBlID09PSAidGhyb3ciKSB7CiAgICAgICAgICByZWplY3QocmVjb3JkLmFyZyk7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgIHZhciByZXN1bHQgPSByZWNvcmQuYXJnOwogICAgICAgICAgdmFyIHZhbHVlID0gcmVzdWx0LnZhbHVlOwogICAgICAgICAgaWYgKHZhbHVlICYmCiAgICAgICAgICAgICAgdHlwZW9mIHZhbHVlID09PSAib2JqZWN0IiAmJgogICAgICAgICAgICAgIGhhc093bi5jYWxsKHZhbHVlLCAiX19hd2FpdCIpKSB7CiAgICAgICAgICAgIHJldHVybiBQcm9taXNlSW1wbC5yZXNvbHZlKHZhbHVlLl9fYXdhaXQpLnRoZW4oZnVuY3Rpb24odmFsdWUpIHsKICAgICAgICAgICAgICBpbnZva2UoIm5leHQiLCB2YWx1ZSwgcmVzb2x2ZSwgcmVqZWN0KTsKICAgICAgICAgICAgfSwgZnVuY3Rpb24oZXJyKSB7CiAgICAgICAgICAgICAgaW52b2tlKCJ0aHJvdyIsIGVyciwgcmVzb2x2ZSwgcmVqZWN0KTsKICAgICAgICAgICAgfSk7CiAgICAgICAgICB9CgogICAgICAgICAgcmV0dXJuIFByb21pc2VJbXBsLnJlc29sdmUodmFsdWUpLnRoZW4oZnVuY3Rpb24odW53cmFwcGVkKSB7CiAgICAgICAgICAgIC8vIFdoZW4gYSB5aWVsZGVkIFByb21pc2UgaXMgcmVzb2x2ZWQsIGl0cyBmaW5hbCB2YWx1ZSBiZWNvbWVzCiAgICAgICAgICAgIC8vIHRoZSAudmFsdWUgb2YgdGhlIFByb21pc2U8e3ZhbHVlLGRvbmV9PiByZXN1bHQgZm9yIHRoZQogICAgICAgICAgICAvLyBjdXJyZW50IGl0ZXJhdGlvbi4KICAgICAgICAgICAgcmVzdWx0LnZhbHVlID0gdW53cmFwcGVkOwogICAgICAgICAgICByZXNvbHZlKHJlc3VsdCk7CiAgICAgICAgICB9LCBmdW5jdGlvbihlcnJvcikgewogICAgICAgICAgICAvLyBJZiBhIHJlamVjdGVkIFByb21pc2Ugd2FzIHlpZWxkZWQsIHRocm93IHRoZSByZWplY3Rpb24gYmFjawogICAgICAgICAgICAvLyBpbnRvIHRoZSBhc3luYyBnZW5lcmF0b3IgZnVuY3Rpb24gc28gaXQgY2FuIGJlIGhhbmRsZWQgdGhlcmUuCiAgICAgICAgICAgIHJldHVybiBpbnZva2UoInRocm93IiwgZXJyb3IsIHJlc29sdmUsIHJlamVjdCk7CiAgICAgICAgICB9KTsKICAgICAgICB9CiAgICAgIH0KCiAgICAgIHZhciBwcmV2aW91c1Byb21pc2U7CgogICAgICBmdW5jdGlvbiBlbnF1ZXVlKG1ldGhvZCwgYXJnKSB7CiAgICAgICAgZnVuY3Rpb24gY2FsbEludm9rZVdpdGhNZXRob2RBbmRBcmcoKSB7CiAgICAgICAgICByZXR1cm4gbmV3IFByb21pc2VJbXBsKGZ1bmN0aW9uKHJlc29sdmUsIHJlamVjdCkgewogICAgICAgICAgICBpbnZva2UobWV0aG9kLCBhcmcsIHJlc29sdmUsIHJlamVjdCk7CiAgICAgICAgICB9KTsKICAgICAgICB9CgogICAgICAgIHJldHVybiBwcmV2aW91c1Byb21pc2UgPQogICAgICAgICAgLy8gSWYgZW5xdWV1ZSBoYXMgYmVlbiBjYWxsZWQgYmVmb3JlLCB0aGVuIHdlIHdhbnQgdG8gd2FpdCB1bnRpbAogICAgICAgICAgLy8gYWxsIHByZXZpb3VzIFByb21pc2VzIGhhdmUgYmVlbiByZXNvbHZlZCBiZWZvcmUgY2FsbGluZyBpbnZva2UsCiAgICAgICAgICAvLyBzbyB0aGF0IHJlc3VsdHMgYXJlIGFsd2F5cyBkZWxpdmVyZWQgaW4gdGhlIGNvcnJlY3Qgb3JkZXIuIElmCiAgICAgICAgICAvLyBlbnF1ZXVlIGhhcyBub3QgYmVlbiBjYWxsZWQgYmVmb3JlLCB0aGVuIGl0IGlzIGltcG9ydGFudCB0bwogICAgICAgICAgLy8gY2FsbCBpbnZva2UgaW1tZWRpYXRlbHksIHdpdGhvdXQgd2FpdGluZyBvbiBhIGNhbGxiYWNrIHRvIGZpcmUsCiAgICAgICAgICAvLyBzbyB0aGF0IHRoZSBhc3luYyBnZW5lcmF0b3IgZnVuY3Rpb24gaGFzIHRoZSBvcHBvcnR1bml0eSB0byBkbwogICAgICAgICAgLy8gYW55IG5lY2Vzc2FyeSBzZXR1cCBpbiBhIHByZWRpY3RhYmxlIHdheS4gVGhpcyBwcmVkaWN0YWJpbGl0eQogICAgICAgICAgLy8gaXMgd2h5IHRoZSBQcm9taXNlIGNvbnN0cnVjdG9yIHN5bmNocm9ub3VzbHkgaW52b2tlcyBpdHMKICAgICAgICAgIC8vIGV4ZWN1dG9yIGNhbGxiYWNrLCBhbmQgd2h5IGFzeW5jIGZ1bmN0aW9ucyBzeW5jaHJvbm91c2x5CiAgICAgICAgICAvLyBleGVjdXRlIGNvZGUgYmVmb3JlIHRoZSBmaXJzdCBhd2FpdC4gU2luY2Ugd2UgaW1wbGVtZW50IHNpbXBsZQogICAgICAgICAgLy8gYXN5bmMgZnVuY3Rpb25zIGluIHRlcm1zIG9mIGFzeW5jIGdlbmVyYXRvcnMsIGl0IGlzIGVzcGVjaWFsbHkKICAgICAgICAgIC8vIGltcG9ydGFudCB0byBnZXQgdGhpcyByaWdodCwgZXZlbiB0aG91Z2ggaXQgcmVxdWlyZXMgY2FyZS4KICAgICAgICAgIHByZXZpb3VzUHJvbWlzZSA/IHByZXZpb3VzUHJvbWlzZS50aGVuKAogICAgICAgICAgICBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZywKICAgICAgICAgICAgLy8gQXZvaWQgcHJvcGFnYXRpbmcgZmFpbHVyZXMgdG8gUHJvbWlzZXMgcmV0dXJuZWQgYnkgbGF0ZXIKICAgICAgICAgICAgLy8gaW52b2NhdGlvbnMgb2YgdGhlIGl0ZXJhdG9yLgogICAgICAgICAgICBjYWxsSW52b2tlV2l0aE1ldGhvZEFuZEFyZwogICAgICAgICAgKSA6IGNhbGxJbnZva2VXaXRoTWV0aG9kQW5kQXJnKCk7CiAgICAgIH0KCiAgICAgIC8vIERlZmluZSB0aGUgdW5pZmllZCBoZWxwZXIgbWV0aG9kIHRoYXQgaXMgdXNlZCB0byBpbXBsZW1lbnQgLm5leHQsCiAgICAgIC8vIC50aHJvdywgYW5kIC5yZXR1cm4gKHNlZSBkZWZpbmVJdGVyYXRvck1ldGhvZHMpLgogICAgICB0aGlzLl9pbnZva2UgPSBlbnF1ZXVlOwogICAgfQoKICAgIGRlZmluZUl0ZXJhdG9yTWV0aG9kcyhBc3luY0l0ZXJhdG9yLnByb3RvdHlwZSk7CiAgICBkZWZpbmUoQXN5bmNJdGVyYXRvci5wcm90b3R5cGUsIGFzeW5jSXRlcmF0b3JTeW1ib2wsIGZ1bmN0aW9uICgpIHsKICAgICAgcmV0dXJuIHRoaXM7CiAgICB9KTsKICAgIGV4cG9ydHMuQXN5bmNJdGVyYXRvciA9IEFzeW5jSXRlcmF0b3I7CgogICAgLy8gTm90ZSB0aGF0IHNpbXBsZSBhc3luYyBmdW5jdGlvbnMgYXJlIGltcGxlbWVudGVkIG9uIHRvcCBvZgogICAgLy8gQXN5bmNJdGVyYXRvciBvYmplY3RzOyB0aGV5IGp1c3QgcmV0dXJuIGEgUHJvbWlzZSBmb3IgdGhlIHZhbHVlIG9mCiAgICAvLyB0aGUgZmluYWwgcmVzdWx0IHByb2R1Y2VkIGJ5IHRoZSBpdGVyYXRvci4KICAgIGV4cG9ydHMuYXN5bmMgPSBmdW5jdGlvbihpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCwgUHJvbWlzZUltcGwpIHsKICAgICAgaWYgKFByb21pc2VJbXBsID09PSB2b2lkIDApIFByb21pc2VJbXBsID0gUHJvbWlzZTsKCiAgICAgIHZhciBpdGVyID0gbmV3IEFzeW5jSXRlcmF0b3IoCiAgICAgICAgd3JhcChpbm5lckZuLCBvdXRlckZuLCBzZWxmLCB0cnlMb2NzTGlzdCksCiAgICAgICAgUHJvbWlzZUltcGwKICAgICAgKTsKCiAgICAgIHJldHVybiBleHBvcnRzLmlzR2VuZXJhdG9yRnVuY3Rpb24ob3V0ZXJGbikKICAgICAgICA/IGl0ZXIgLy8gSWYgb3V0ZXJGbiBpcyBhIGdlbmVyYXRvciwgcmV0dXJuIHRoZSBmdWxsIGl0ZXJhdG9yLgogICAgICAgIDogaXRlci5uZXh0KCkudGhlbihmdW5jdGlvbihyZXN1bHQpIHsKICAgICAgICAgICAgcmV0dXJuIHJlc3VsdC5kb25lID8gcmVzdWx0LnZhbHVlIDogaXRlci5uZXh0KCk7CiAgICAgICAgICB9KTsKICAgIH07CgogICAgZnVuY3Rpb24gbWFrZUludm9rZU1ldGhvZChpbm5lckZuLCBzZWxmLCBjb250ZXh0KSB7CiAgICAgIHZhciBzdGF0ZSA9IEdlblN0YXRlU3VzcGVuZGVkU3RhcnQ7CgogICAgICByZXR1cm4gZnVuY3Rpb24gaW52b2tlKG1ldGhvZCwgYXJnKSB7CiAgICAgICAgaWYgKHN0YXRlID09PSBHZW5TdGF0ZUV4ZWN1dGluZykgewogICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCJHZW5lcmF0b3IgaXMgYWxyZWFkeSBydW5uaW5nIik7CiAgICAgICAgfQoKICAgICAgICBpZiAoc3RhdGUgPT09IEdlblN0YXRlQ29tcGxldGVkKSB7CiAgICAgICAgICBpZiAobWV0aG9kID09PSAidGhyb3ciKSB7CiAgICAgICAgICAgIHRocm93IGFyZzsKICAgICAgICAgIH0KCiAgICAgICAgICAvLyBCZSBmb3JnaXZpbmcsIHBlciAyNS4zLjMuMy4zIG9mIHRoZSBzcGVjOgogICAgICAgICAgLy8gaHR0cHM6Ly9wZW9wbGUubW96aWxsYS5vcmcvfmpvcmVuZG9yZmYvZXM2LWRyYWZ0Lmh0bWwjc2VjLWdlbmVyYXRvcnJlc3VtZQogICAgICAgICAgcmV0dXJuIGRvbmVSZXN1bHQoKTsKICAgICAgICB9CgogICAgICAgIGNvbnRleHQubWV0aG9kID0gbWV0aG9kOwogICAgICAgIGNvbnRleHQuYXJnID0gYXJnOwoKICAgICAgICB3aGlsZSAodHJ1ZSkgewogICAgICAgICAgdmFyIGRlbGVnYXRlID0gY29udGV4dC5kZWxlZ2F0ZTsKICAgICAgICAgIGlmIChkZWxlZ2F0ZSkgewogICAgICAgICAgICB2YXIgZGVsZWdhdGVSZXN1bHQgPSBtYXliZUludm9rZURlbGVnYXRlKGRlbGVnYXRlLCBjb250ZXh0KTsKICAgICAgICAgICAgaWYgKGRlbGVnYXRlUmVzdWx0KSB7CiAgICAgICAgICAgICAgaWYgKGRlbGVnYXRlUmVzdWx0ID09PSBDb250aW51ZVNlbnRpbmVsKSBjb250aW51ZTsKICAgICAgICAgICAgICByZXR1cm4gZGVsZWdhdGVSZXN1bHQ7CiAgICAgICAgICAgIH0KICAgICAgICAgIH0KCiAgICAgICAgICBpZiAoY29udGV4dC5tZXRob2QgPT09ICJuZXh0IikgewogICAgICAgICAgICAvLyBTZXR0aW5nIGNvbnRleHQuX3NlbnQgZm9yIGxlZ2FjeSBzdXBwb3J0IG9mIEJhYmVsJ3MKICAgICAgICAgICAgLy8gZnVuY3Rpb24uc2VudCBpbXBsZW1lbnRhdGlvbi4KICAgICAgICAgICAgY29udGV4dC5zZW50ID0gY29udGV4dC5fc2VudCA9IGNvbnRleHQuYXJnOwoKICAgICAgICAgIH0gZWxzZSBpZiAoY29udGV4dC5tZXRob2QgPT09ICJ0aHJvdyIpIHsKICAgICAgICAgICAgaWYgKHN0YXRlID09PSBHZW5TdGF0ZVN1c3BlbmRlZFN0YXJ0KSB7CiAgICAgICAgICAgICAgc3RhdGUgPSBHZW5TdGF0ZUNvbXBsZXRlZDsKICAgICAgICAgICAgICB0aHJvdyBjb250ZXh0LmFyZzsKICAgICAgICAgICAgfQoKICAgICAgICAgICAgY29udGV4dC5kaXNwYXRjaEV4Y2VwdGlvbihjb250ZXh0LmFyZyk7CgogICAgICAgICAgfSBlbHNlIGlmIChjb250ZXh0Lm1ldGhvZCA9PT0gInJldHVybiIpIHsKICAgICAgICAgICAgY29udGV4dC5hYnJ1cHQoInJldHVybiIsIGNvbnRleHQuYXJnKTsKICAgICAgICAgIH0KCiAgICAgICAgICBzdGF0ZSA9IEdlblN0YXRlRXhlY3V0aW5nOwoKICAgICAgICAgIHZhciByZWNvcmQgPSB0cnlDYXRjaChpbm5lckZuLCBzZWxmLCBjb250ZXh0KTsKICAgICAgICAgIGlmIChyZWNvcmQudHlwZSA9PT0gIm5vcm1hbCIpIHsKICAgICAgICAgICAgLy8gSWYgYW4gZXhjZXB0aW9uIGlzIHRocm93biBmcm9tIGlubmVyRm4sIHdlIGxlYXZlIHN0YXRlID09PQogICAgICAgICAgICAvLyBHZW5TdGF0ZUV4ZWN1dGluZyBhbmQgbG9vcCBiYWNrIGZvciBhbm90aGVyIGludm9jYXRpb24uCiAgICAgICAgICAgIHN0YXRlID0gY29udGV4dC5kb25lCiAgICAgICAgICAgICAgPyBHZW5TdGF0ZUNvbXBsZXRlZAogICAgICAgICAgICAgIDogR2VuU3RhdGVTdXNwZW5kZWRZaWVsZDsKCiAgICAgICAgICAgIGlmIChyZWNvcmQuYXJnID09PSBDb250aW51ZVNlbnRpbmVsKSB7CiAgICAgICAgICAgICAgY29udGludWU7CiAgICAgICAgICAgIH0KCiAgICAgICAgICAgIHJldHVybiB7CiAgICAgICAgICAgICAgdmFsdWU6IHJlY29yZC5hcmcsCiAgICAgICAgICAgICAgZG9uZTogY29udGV4dC5kb25lCiAgICAgICAgICAgIH07CgogICAgICAgICAgfSBlbHNlIGlmIChyZWNvcmQudHlwZSA9PT0gInRocm93IikgewogICAgICAgICAgICBzdGF0ZSA9IEdlblN0YXRlQ29tcGxldGVkOwogICAgICAgICAgICAvLyBEaXNwYXRjaCB0aGUgZXhjZXB0aW9uIGJ5IGxvb3BpbmcgYmFjayBhcm91bmQgdG8gdGhlCiAgICAgICAgICAgIC8vIGNvbnRleHQuZGlzcGF0Y2hFeGNlcHRpb24oY29udGV4dC5hcmcpIGNhbGwgYWJvdmUuCiAgICAgICAgICAgIGNvbnRleHQubWV0aG9kID0gInRocm93IjsKICAgICAgICAgICAgY29udGV4dC5hcmcgPSByZWNvcmQuYXJnOwogICAgICAgICAgfQogICAgICAgIH0KICAgICAgfTsKICAgIH0KCiAgICAvLyBDYWxsIGRlbGVnYXRlLml0ZXJhdG9yW2NvbnRleHQubWV0aG9kXShjb250ZXh0LmFyZykgYW5kIGhhbmRsZSB0aGUKICAgIC8vIHJlc3VsdCwgZWl0aGVyIGJ5IHJldHVybmluZyBhIHsgdmFsdWUsIGRvbmUgfSByZXN1bHQgZnJvbSB0aGUKICAgIC8vIGRlbGVnYXRlIGl0ZXJhdG9yLCBvciBieSBtb2RpZnlpbmcgY29udGV4dC5tZXRob2QgYW5kIGNvbnRleHQuYXJnLAogICAgLy8gc2V0dGluZyBjb250ZXh0LmRlbGVnYXRlIHRvIG51bGwsIGFuZCByZXR1cm5pbmcgdGhlIENvbnRpbnVlU2VudGluZWwuCiAgICBmdW5jdGlvbiBtYXliZUludm9rZURlbGVnYXRlKGRlbGVnYXRlLCBjb250ZXh0KSB7CiAgICAgIHZhciBtZXRob2QgPSBkZWxlZ2F0ZS5pdGVyYXRvcltjb250ZXh0Lm1ldGhvZF07CiAgICAgIGlmIChtZXRob2QgPT09IHVuZGVmaW5lZCQxKSB7CiAgICAgICAgLy8gQSAudGhyb3cgb3IgLnJldHVybiB3aGVuIHRoZSBkZWxlZ2F0ZSBpdGVyYXRvciBoYXMgbm8gLnRocm93CiAgICAgICAgLy8gbWV0aG9kIGFsd2F5cyB0ZXJtaW5hdGVzIHRoZSB5aWVsZCogbG9vcC4KICAgICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDsKCiAgICAgICAgaWYgKGNvbnRleHQubWV0aG9kID09PSAidGhyb3ciKSB7CiAgICAgICAgICAvLyBOb3RlOiBbInJldHVybiJdIG11c3QgYmUgdXNlZCBmb3IgRVMzIHBhcnNpbmcgY29tcGF0aWJpbGl0eS4KICAgICAgICAgIGlmIChkZWxlZ2F0ZS5pdGVyYXRvclsicmV0dXJuIl0pIHsKICAgICAgICAgICAgLy8gSWYgdGhlIGRlbGVnYXRlIGl0ZXJhdG9yIGhhcyBhIHJldHVybiBtZXRob2QsIGdpdmUgaXQgYQogICAgICAgICAgICAvLyBjaGFuY2UgdG8gY2xlYW4gdXAuCiAgICAgICAgICAgIGNvbnRleHQubWV0aG9kID0gInJldHVybiI7CiAgICAgICAgICAgIGNvbnRleHQuYXJnID0gdW5kZWZpbmVkJDE7CiAgICAgICAgICAgIG1heWJlSW52b2tlRGVsZWdhdGUoZGVsZWdhdGUsIGNvbnRleHQpOwoKICAgICAgICAgICAgaWYgKGNvbnRleHQubWV0aG9kID09PSAidGhyb3ciKSB7CiAgICAgICAgICAgICAgLy8gSWYgbWF5YmVJbnZva2VEZWxlZ2F0ZShjb250ZXh0KSBjaGFuZ2VkIGNvbnRleHQubWV0aG9kIGZyb20KICAgICAgICAgICAgICAvLyAicmV0dXJuIiB0byAidGhyb3ciLCBsZXQgdGhhdCBvdmVycmlkZSB0aGUgVHlwZUVycm9yIGJlbG93LgogICAgICAgICAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsOwogICAgICAgICAgICB9CiAgICAgICAgICB9CgogICAgICAgICAgY29udGV4dC5tZXRob2QgPSAidGhyb3ciOwogICAgICAgICAgY29udGV4dC5hcmcgPSBuZXcgVHlwZUVycm9yKAogICAgICAgICAgICAiVGhlIGl0ZXJhdG9yIGRvZXMgbm90IHByb3ZpZGUgYSAndGhyb3cnIG1ldGhvZCIpOwogICAgICAgIH0KCiAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7CiAgICAgIH0KCiAgICAgIHZhciByZWNvcmQgPSB0cnlDYXRjaChtZXRob2QsIGRlbGVnYXRlLml0ZXJhdG9yLCBjb250ZXh0LmFyZyk7CgogICAgICBpZiAocmVjb3JkLnR5cGUgPT09ICJ0aHJvdyIpIHsKICAgICAgICBjb250ZXh0Lm1ldGhvZCA9ICJ0aHJvdyI7CiAgICAgICAgY29udGV4dC5hcmcgPSByZWNvcmQuYXJnOwogICAgICAgIGNvbnRleHQuZGVsZWdhdGUgPSBudWxsOwogICAgICAgIHJldHVybiBDb250aW51ZVNlbnRpbmVsOwogICAgICB9CgogICAgICB2YXIgaW5mbyA9IHJlY29yZC5hcmc7CgogICAgICBpZiAoISBpbmZvKSB7CiAgICAgICAgY29udGV4dC5tZXRob2QgPSAidGhyb3ciOwogICAgICAgIGNvbnRleHQuYXJnID0gbmV3IFR5cGVFcnJvcigiaXRlcmF0b3IgcmVzdWx0IGlzIG5vdCBhbiBvYmplY3QiKTsKICAgICAgICBjb250ZXh0LmRlbGVnYXRlID0gbnVsbDsKICAgICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDsKICAgICAgfQoKICAgICAgaWYgKGluZm8uZG9uZSkgewogICAgICAgIC8vIEFzc2lnbiB0aGUgcmVzdWx0IG9mIHRoZSBmaW5pc2hlZCBkZWxlZ2F0ZSB0byB0aGUgdGVtcG9yYXJ5CiAgICAgICAgLy8gdmFyaWFibGUgc3BlY2lmaWVkIGJ5IGRlbGVnYXRlLnJlc3VsdE5hbWUgKHNlZSBkZWxlZ2F0ZVlpZWxkKS4KICAgICAgICBjb250ZXh0W2RlbGVnYXRlLnJlc3VsdE5hbWVdID0gaW5mby52YWx1ZTsKCiAgICAgICAgLy8gUmVzdW1lIGV4ZWN1dGlvbiBhdCB0aGUgZGVzaXJlZCBsb2NhdGlvbiAoc2VlIGRlbGVnYXRlWWllbGQpLgogICAgICAgIGNvbnRleHQubmV4dCA9IGRlbGVnYXRlLm5leHRMb2M7CgogICAgICAgIC8vIElmIGNvbnRleHQubWV0aG9kIHdhcyAidGhyb3ciIGJ1dCB0aGUgZGVsZWdhdGUgaGFuZGxlZCB0aGUKICAgICAgICAvLyBleGNlcHRpb24sIGxldCB0aGUgb3V0ZXIgZ2VuZXJhdG9yIHByb2NlZWQgbm9ybWFsbHkuIElmCiAgICAgICAgLy8gY29udGV4dC5tZXRob2Qgd2FzICJuZXh0IiwgZm9yZ2V0IGNvbnRleHQuYXJnIHNpbmNlIGl0IGhhcyBiZWVuCiAgICAgICAgLy8gImNvbnN1bWVkIiBieSB0aGUgZGVsZWdhdGUgaXRlcmF0b3IuIElmIGNvbnRleHQubWV0aG9kIHdhcwogICAgICAgIC8vICJyZXR1cm4iLCBhbGxvdyB0aGUgb3JpZ2luYWwgLnJldHVybiBjYWxsIHRvIGNvbnRpbnVlIGluIHRoZQogICAgICAgIC8vIG91dGVyIGdlbmVyYXRvci4KICAgICAgICBpZiAoY29udGV4dC5tZXRob2QgIT09ICJyZXR1cm4iKSB7CiAgICAgICAgICBjb250ZXh0Lm1ldGhvZCA9ICJuZXh0IjsKICAgICAgICAgIGNvbnRleHQuYXJnID0gdW5kZWZpbmVkJDE7CiAgICAgICAgfQoKICAgICAgfSBlbHNlIHsKICAgICAgICAvLyBSZS15aWVsZCB0aGUgcmVzdWx0IHJldHVybmVkIGJ5IHRoZSBkZWxlZ2F0ZSBtZXRob2QuCiAgICAgICAgcmV0dXJuIGluZm87CiAgICAgIH0KCiAgICAgIC8vIFRoZSBkZWxlZ2F0ZSBpdGVyYXRvciBpcyBmaW5pc2hlZCwgc28gZm9yZ2V0IGl0IGFuZCBjb250aW51ZSB3aXRoCiAgICAgIC8vIHRoZSBvdXRlciBnZW5lcmF0b3IuCiAgICAgIGNvbnRleHQuZGVsZWdhdGUgPSBudWxsOwogICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDsKICAgIH0KCiAgICAvLyBEZWZpbmUgR2VuZXJhdG9yLnByb3RvdHlwZS57bmV4dCx0aHJvdyxyZXR1cm59IGluIHRlcm1zIG9mIHRoZQogICAgLy8gdW5pZmllZCAuX2ludm9rZSBoZWxwZXIgbWV0aG9kLgogICAgZGVmaW5lSXRlcmF0b3JNZXRob2RzKEdwKTsKCiAgICBkZWZpbmUoR3AsIHRvU3RyaW5nVGFnU3ltYm9sLCAiR2VuZXJhdG9yIik7CgogICAgLy8gQSBHZW5lcmF0b3Igc2hvdWxkIGFsd2F5cyByZXR1cm4gaXRzZWxmIGFzIHRoZSBpdGVyYXRvciBvYmplY3Qgd2hlbiB0aGUKICAgIC8vIEBAaXRlcmF0b3IgZnVuY3Rpb24gaXMgY2FsbGVkIG9uIGl0LiBTb21lIGJyb3dzZXJzJyBpbXBsZW1lbnRhdGlvbnMgb2YgdGhlCiAgICAvLyBpdGVyYXRvciBwcm90b3R5cGUgY2hhaW4gaW5jb3JyZWN0bHkgaW1wbGVtZW50IHRoaXMsIGNhdXNpbmcgdGhlIEdlbmVyYXRvcgogICAgLy8gb2JqZWN0IHRvIG5vdCBiZSByZXR1cm5lZCBmcm9tIHRoaXMgY2FsbC4gVGhpcyBlbnN1cmVzIHRoYXQgZG9lc24ndCBoYXBwZW4uCiAgICAvLyBTZWUgaHR0cHM6Ly9naXRodWIuY29tL2ZhY2Vib29rL3JlZ2VuZXJhdG9yL2lzc3Vlcy8yNzQgZm9yIG1vcmUgZGV0YWlscy4KICAgIGRlZmluZShHcCwgaXRlcmF0b3JTeW1ib2wsIGZ1bmN0aW9uKCkgewogICAgICByZXR1cm4gdGhpczsKICAgIH0pOwoKICAgIGRlZmluZShHcCwgInRvU3RyaW5nIiwgZnVuY3Rpb24oKSB7CiAgICAgIHJldHVybiAiW29iamVjdCBHZW5lcmF0b3JdIjsKICAgIH0pOwoKICAgIGZ1bmN0aW9uIHB1c2hUcnlFbnRyeShsb2NzKSB7CiAgICAgIHZhciBlbnRyeSA9IHsgdHJ5TG9jOiBsb2NzWzBdIH07CgogICAgICBpZiAoMSBpbiBsb2NzKSB7CiAgICAgICAgZW50cnkuY2F0Y2hMb2MgPSBsb2NzWzFdOwogICAgICB9CgogICAgICBpZiAoMiBpbiBsb2NzKSB7CiAgICAgICAgZW50cnkuZmluYWxseUxvYyA9IGxvY3NbMl07CiAgICAgICAgZW50cnkuYWZ0ZXJMb2MgPSBsb2NzWzNdOwogICAgICB9CgogICAgICB0aGlzLnRyeUVudHJpZXMucHVzaChlbnRyeSk7CiAgICB9CgogICAgZnVuY3Rpb24gcmVzZXRUcnlFbnRyeShlbnRyeSkgewogICAgICB2YXIgcmVjb3JkID0gZW50cnkuY29tcGxldGlvbiB8fCB7fTsKICAgICAgcmVjb3JkLnR5cGUgPSAibm9ybWFsIjsKICAgICAgZGVsZXRlIHJlY29yZC5hcmc7CiAgICAgIGVudHJ5LmNvbXBsZXRpb24gPSByZWNvcmQ7CiAgICB9CgogICAgZnVuY3Rpb24gQ29udGV4dCh0cnlMb2NzTGlzdCkgewogICAgICAvLyBUaGUgcm9vdCBlbnRyeSBvYmplY3QgKGVmZmVjdGl2ZWx5IGEgdHJ5IHN0YXRlbWVudCB3aXRob3V0IGEgY2F0Y2gKICAgICAgLy8gb3IgYSBmaW5hbGx5IGJsb2NrKSBnaXZlcyB1cyBhIHBsYWNlIHRvIHN0b3JlIHZhbHVlcyB0aHJvd24gZnJvbQogICAgICAvLyBsb2NhdGlvbnMgd2hlcmUgdGhlcmUgaXMgbm8gZW5jbG9zaW5nIHRyeSBzdGF0ZW1lbnQuCiAgICAgIHRoaXMudHJ5RW50cmllcyA9IFt7IHRyeUxvYzogInJvb3QiIH1dOwogICAgICB0cnlMb2NzTGlzdC5mb3JFYWNoKHB1c2hUcnlFbnRyeSwgdGhpcyk7CiAgICAgIHRoaXMucmVzZXQodHJ1ZSk7CiAgICB9CgogICAgZXhwb3J0cy5rZXlzID0gZnVuY3Rpb24ob2JqZWN0KSB7CiAgICAgIHZhciBrZXlzID0gW107CiAgICAgIGZvciAodmFyIGtleSBpbiBvYmplY3QpIHsKICAgICAgICBrZXlzLnB1c2goa2V5KTsKICAgICAgfQogICAgICBrZXlzLnJldmVyc2UoKTsKCiAgICAgIC8vIFJhdGhlciB0aGFuIHJldHVybmluZyBhbiBvYmplY3Qgd2l0aCBhIG5leHQgbWV0aG9kLCB3ZSBrZWVwCiAgICAgIC8vIHRoaW5ncyBzaW1wbGUgYW5kIHJldHVybiB0aGUgbmV4dCBmdW5jdGlvbiBpdHNlbGYuCiAgICAgIHJldHVybiBmdW5jdGlvbiBuZXh0KCkgewogICAgICAgIHdoaWxlIChrZXlzLmxlbmd0aCkgewogICAgICAgICAgdmFyIGtleSA9IGtleXMucG9wKCk7CiAgICAgICAgICBpZiAoa2V5IGluIG9iamVjdCkgewogICAgICAgICAgICBuZXh0LnZhbHVlID0ga2V5OwogICAgICAgICAgICBuZXh0LmRvbmUgPSBmYWxzZTsKICAgICAgICAgICAgcmV0dXJuIG5leHQ7CiAgICAgICAgICB9CiAgICAgICAgfQoKICAgICAgICAvLyBUbyBhdm9pZCBjcmVhdGluZyBhbiBhZGRpdGlvbmFsIG9iamVjdCwgd2UganVzdCBoYW5nIHRoZSAudmFsdWUKICAgICAgICAvLyBhbmQgLmRvbmUgcHJvcGVydGllcyBvZmYgdGhlIG5leHQgZnVuY3Rpb24gb2JqZWN0IGl0c2VsZi4gVGhpcwogICAgICAgIC8vIGFsc28gZW5zdXJlcyB0aGF0IHRoZSBtaW5pZmllciB3aWxsIG5vdCBhbm9ueW1pemUgdGhlIGZ1bmN0aW9uLgogICAgICAgIG5leHQuZG9uZSA9IHRydWU7CiAgICAgICAgcmV0dXJuIG5leHQ7CiAgICAgIH07CiAgICB9OwoKICAgIGZ1bmN0aW9uIHZhbHVlcyhpdGVyYWJsZSkgewogICAgICBpZiAoaXRlcmFibGUpIHsKICAgICAgICB2YXIgaXRlcmF0b3JNZXRob2QgPSBpdGVyYWJsZVtpdGVyYXRvclN5bWJvbF07CiAgICAgICAgaWYgKGl0ZXJhdG9yTWV0aG9kKSB7CiAgICAgICAgICByZXR1cm4gaXRlcmF0b3JNZXRob2QuY2FsbChpdGVyYWJsZSk7CiAgICAgICAgfQoKICAgICAgICBpZiAodHlwZW9mIGl0ZXJhYmxlLm5leHQgPT09ICJmdW5jdGlvbiIpIHsKICAgICAgICAgIHJldHVybiBpdGVyYWJsZTsKICAgICAgICB9CgogICAgICAgIGlmICghaXNOYU4oaXRlcmFibGUubGVuZ3RoKSkgewogICAgICAgICAgdmFyIGkgPSAtMSwgbmV4dCA9IGZ1bmN0aW9uIG5leHQoKSB7CiAgICAgICAgICAgIHdoaWxlICgrK2kgPCBpdGVyYWJsZS5sZW5ndGgpIHsKICAgICAgICAgICAgICBpZiAoaGFzT3duLmNhbGwoaXRlcmFibGUsIGkpKSB7CiAgICAgICAgICAgICAgICBuZXh0LnZhbHVlID0gaXRlcmFibGVbaV07CiAgICAgICAgICAgICAgICBuZXh0LmRvbmUgPSBmYWxzZTsKICAgICAgICAgICAgICAgIHJldHVybiBuZXh0OwogICAgICAgICAgICAgIH0KICAgICAgICAgICAgfQoKICAgICAgICAgICAgbmV4dC52YWx1ZSA9IHVuZGVmaW5lZCQxOwogICAgICAgICAgICBuZXh0LmRvbmUgPSB0cnVlOwoKICAgICAgICAgICAgcmV0dXJuIG5leHQ7CiAgICAgICAgICB9OwoKICAgICAgICAgIHJldHVybiBuZXh0Lm5leHQgPSBuZXh0OwogICAgICAgIH0KICAgICAgfQoKICAgICAgLy8gUmV0dXJuIGFuIGl0ZXJhdG9yIHdpdGggbm8gdmFsdWVzLgogICAgICByZXR1cm4geyBuZXh0OiBkb25lUmVzdWx0IH07CiAgICB9CiAgICBleHBvcnRzLnZhbHVlcyA9IHZhbHVlczsKCiAgICBmdW5jdGlvbiBkb25lUmVzdWx0KCkgewogICAgICByZXR1cm4geyB2YWx1ZTogdW5kZWZpbmVkJDEsIGRvbmU6IHRydWUgfTsKICAgIH0KCiAgICBDb250ZXh0LnByb3RvdHlwZSA9IHsKICAgICAgY29uc3RydWN0b3I6IENvbnRleHQsCgogICAgICByZXNldDogZnVuY3Rpb24oc2tpcFRlbXBSZXNldCkgewogICAgICAgIHRoaXMucHJldiA9IDA7CiAgICAgICAgdGhpcy5uZXh0ID0gMDsKICAgICAgICAvLyBSZXNldHRpbmcgY29udGV4dC5fc2VudCBmb3IgbGVnYWN5IHN1cHBvcnQgb2YgQmFiZWwncwogICAgICAgIC8vIGZ1bmN0aW9uLnNlbnQgaW1wbGVtZW50YXRpb24uCiAgICAgICAgdGhpcy5zZW50ID0gdGhpcy5fc2VudCA9IHVuZGVmaW5lZCQxOwogICAgICAgIHRoaXMuZG9uZSA9IGZhbHNlOwogICAgICAgIHRoaXMuZGVsZWdhdGUgPSBudWxsOwoKICAgICAgICB0aGlzLm1ldGhvZCA9ICJuZXh0IjsKICAgICAgICB0aGlzLmFyZyA9IHVuZGVmaW5lZCQxOwoKICAgICAgICB0aGlzLnRyeUVudHJpZXMuZm9yRWFjaChyZXNldFRyeUVudHJ5KTsKCiAgICAgICAgaWYgKCFza2lwVGVtcFJlc2V0KSB7CiAgICAgICAgICBmb3IgKHZhciBuYW1lIGluIHRoaXMpIHsKICAgICAgICAgICAgLy8gTm90IHN1cmUgYWJvdXQgdGhlIG9wdGltYWwgb3JkZXIgb2YgdGhlc2UgY29uZGl0aW9uczoKICAgICAgICAgICAgaWYgKG5hbWUuY2hhckF0KDApID09PSAidCIgJiYKICAgICAgICAgICAgICAgIGhhc093bi5jYWxsKHRoaXMsIG5hbWUpICYmCiAgICAgICAgICAgICAgICAhaXNOYU4oK25hbWUuc2xpY2UoMSkpKSB7CiAgICAgICAgICAgICAgdGhpc1tuYW1lXSA9IHVuZGVmaW5lZCQxOwogICAgICAgICAgICB9CiAgICAgICAgICB9CiAgICAgICAgfQogICAgICB9LAoKICAgICAgc3RvcDogZnVuY3Rpb24oKSB7CiAgICAgICAgdGhpcy5kb25lID0gdHJ1ZTsKCiAgICAgICAgdmFyIHJvb3RFbnRyeSA9IHRoaXMudHJ5RW50cmllc1swXTsKICAgICAgICB2YXIgcm9vdFJlY29yZCA9IHJvb3RFbnRyeS5jb21wbGV0aW9uOwogICAgICAgIGlmIChyb290UmVjb3JkLnR5cGUgPT09ICJ0aHJvdyIpIHsKICAgICAgICAgIHRocm93IHJvb3RSZWNvcmQuYXJnOwogICAgICAgIH0KCiAgICAgICAgcmV0dXJuIHRoaXMucnZhbDsKICAgICAgfSwKCiAgICAgIGRpc3BhdGNoRXhjZXB0aW9uOiBmdW5jdGlvbihleGNlcHRpb24pIHsKICAgICAgICBpZiAodGhpcy5kb25lKSB7CiAgICAgICAgICB0aHJvdyBleGNlcHRpb247CiAgICAgICAgfQoKICAgICAgICB2YXIgY29udGV4dCA9IHRoaXM7CiAgICAgICAgZnVuY3Rpb24gaGFuZGxlKGxvYywgY2F1Z2h0KSB7CiAgICAgICAgICByZWNvcmQudHlwZSA9ICJ0aHJvdyI7CiAgICAgICAgICByZWNvcmQuYXJnID0gZXhjZXB0aW9uOwogICAgICAgICAgY29udGV4dC5uZXh0ID0gbG9jOwoKICAgICAgICAgIGlmIChjYXVnaHQpIHsKICAgICAgICAgICAgLy8gSWYgdGhlIGRpc3BhdGNoZWQgZXhjZXB0aW9uIHdhcyBjYXVnaHQgYnkgYSBjYXRjaCBibG9jaywKICAgICAgICAgICAgLy8gdGhlbiBsZXQgdGhhdCBjYXRjaCBibG9jayBoYW5kbGUgdGhlIGV4Y2VwdGlvbiBub3JtYWxseS4KICAgICAgICAgICAgY29udGV4dC5tZXRob2QgPSAibmV4dCI7CiAgICAgICAgICAgIGNvbnRleHQuYXJnID0gdW5kZWZpbmVkJDE7CiAgICAgICAgICB9CgogICAgICAgICAgcmV0dXJuICEhIGNhdWdodDsKICAgICAgICB9CgogICAgICAgIGZvciAodmFyIGkgPSB0aGlzLnRyeUVudHJpZXMubGVuZ3RoIC0gMTsgaSA+PSAwOyAtLWkpIHsKICAgICAgICAgIHZhciBlbnRyeSA9IHRoaXMudHJ5RW50cmllc1tpXTsKICAgICAgICAgIHZhciByZWNvcmQgPSBlbnRyeS5jb21wbGV0aW9uOwoKICAgICAgICAgIGlmIChlbnRyeS50cnlMb2MgPT09ICJyb290IikgewogICAgICAgICAgICAvLyBFeGNlcHRpb24gdGhyb3duIG91dHNpZGUgb2YgYW55IHRyeSBibG9jayB0aGF0IGNvdWxkIGhhbmRsZQogICAgICAgICAgICAvLyBpdCwgc28gc2V0IHRoZSBjb21wbGV0aW9uIHZhbHVlIG9mIHRoZSBlbnRpcmUgZnVuY3Rpb24gdG8KICAgICAgICAgICAgLy8gdGhyb3cgdGhlIGV4Y2VwdGlvbi4KICAgICAgICAgICAgcmV0dXJuIGhhbmRsZSgiZW5kIik7CiAgICAgICAgICB9CgogICAgICAgICAgaWYgKGVudHJ5LnRyeUxvYyA8PSB0aGlzLnByZXYpIHsKICAgICAgICAgICAgdmFyIGhhc0NhdGNoID0gaGFzT3duLmNhbGwoZW50cnksICJjYXRjaExvYyIpOwogICAgICAgICAgICB2YXIgaGFzRmluYWxseSA9IGhhc093bi5jYWxsKGVudHJ5LCAiZmluYWxseUxvYyIpOwoKICAgICAgICAgICAgaWYgKGhhc0NhdGNoICYmIGhhc0ZpbmFsbHkpIHsKICAgICAgICAgICAgICBpZiAodGhpcy5wcmV2IDwgZW50cnkuY2F0Y2hMb2MpIHsKICAgICAgICAgICAgICAgIHJldHVybiBoYW5kbGUoZW50cnkuY2F0Y2hMb2MsIHRydWUpOwogICAgICAgICAgICAgIH0gZWxzZSBpZiAodGhpcy5wcmV2IDwgZW50cnkuZmluYWxseUxvYykgewogICAgICAgICAgICAgICAgcmV0dXJuIGhhbmRsZShlbnRyeS5maW5hbGx5TG9jKTsKICAgICAgICAgICAgICB9CgogICAgICAgICAgICB9IGVsc2UgaWYgKGhhc0NhdGNoKSB7CiAgICAgICAgICAgICAgaWYgKHRoaXMucHJldiA8IGVudHJ5LmNhdGNoTG9jKSB7CiAgICAgICAgICAgICAgICByZXR1cm4gaGFuZGxlKGVudHJ5LmNhdGNoTG9jLCB0cnVlKTsKICAgICAgICAgICAgICB9CgogICAgICAgICAgICB9IGVsc2UgaWYgKGhhc0ZpbmFsbHkpIHsKICAgICAgICAgICAgICBpZiAodGhpcy5wcmV2IDwgZW50cnkuZmluYWxseUxvYykgewogICAgICAgICAgICAgICAgcmV0dXJuIGhhbmRsZShlbnRyeS5maW5hbGx5TG9jKTsKICAgICAgICAgICAgICB9CgogICAgICAgICAgICB9IGVsc2UgewogICAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcigidHJ5IHN0YXRlbWVudCB3aXRob3V0IGNhdGNoIG9yIGZpbmFsbHkiKTsKICAgICAgICAgICAgfQogICAgICAgICAgfQogICAgICAgIH0KICAgICAgfSwKCiAgICAgIGFicnVwdDogZnVuY3Rpb24odHlwZSwgYXJnKSB7CiAgICAgICAgZm9yICh2YXIgaSA9IHRoaXMudHJ5RW50cmllcy5sZW5ndGggLSAxOyBpID49IDA7IC0taSkgewogICAgICAgICAgdmFyIGVudHJ5ID0gdGhpcy50cnlFbnRyaWVzW2ldOwogICAgICAgICAgaWYgKGVudHJ5LnRyeUxvYyA8PSB0aGlzLnByZXYgJiYKICAgICAgICAgICAgICBoYXNPd24uY2FsbChlbnRyeSwgImZpbmFsbHlMb2MiKSAmJgogICAgICAgICAgICAgIHRoaXMucHJldiA8IGVudHJ5LmZpbmFsbHlMb2MpIHsKICAgICAgICAgICAgdmFyIGZpbmFsbHlFbnRyeSA9IGVudHJ5OwogICAgICAgICAgICBicmVhazsKICAgICAgICAgIH0KICAgICAgICB9CgogICAgICAgIGlmIChmaW5hbGx5RW50cnkgJiYKICAgICAgICAgICAgKHR5cGUgPT09ICJicmVhayIgfHwKICAgICAgICAgICAgIHR5cGUgPT09ICJjb250aW51ZSIpICYmCiAgICAgICAgICAgIGZpbmFsbHlFbnRyeS50cnlMb2MgPD0gYXJnICYmCiAgICAgICAgICAgIGFyZyA8PSBmaW5hbGx5RW50cnkuZmluYWxseUxvYykgewogICAgICAgICAgLy8gSWdub3JlIHRoZSBmaW5hbGx5IGVudHJ5IGlmIGNvbnRyb2wgaXMgbm90IGp1bXBpbmcgdG8gYQogICAgICAgICAgLy8gbG9jYXRpb24gb3V0c2lkZSB0aGUgdHJ5L2NhdGNoIGJsb2NrLgogICAgICAgICAgZmluYWxseUVudHJ5ID0gbnVsbDsKICAgICAgICB9CgogICAgICAgIHZhciByZWNvcmQgPSBmaW5hbGx5RW50cnkgPyBmaW5hbGx5RW50cnkuY29tcGxldGlvbiA6IHt9OwogICAgICAgIHJlY29yZC50eXBlID0gdHlwZTsKICAgICAgICByZWNvcmQuYXJnID0gYXJnOwoKICAgICAgICBpZiAoZmluYWxseUVudHJ5KSB7CiAgICAgICAgICB0aGlzLm1ldGhvZCA9ICJuZXh0IjsKICAgICAgICAgIHRoaXMubmV4dCA9IGZpbmFsbHlFbnRyeS5maW5hbGx5TG9jOwogICAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7CiAgICAgICAgfQoKICAgICAgICByZXR1cm4gdGhpcy5jb21wbGV0ZShyZWNvcmQpOwogICAgICB9LAoKICAgICAgY29tcGxldGU6IGZ1bmN0aW9uKHJlY29yZCwgYWZ0ZXJMb2MpIHsKICAgICAgICBpZiAocmVjb3JkLnR5cGUgPT09ICJ0aHJvdyIpIHsKICAgICAgICAgIHRocm93IHJlY29yZC5hcmc7CiAgICAgICAgfQoKICAgICAgICBpZiAocmVjb3JkLnR5cGUgPT09ICJicmVhayIgfHwKICAgICAgICAgICAgcmVjb3JkLnR5cGUgPT09ICJjb250aW51ZSIpIHsKICAgICAgICAgIHRoaXMubmV4dCA9IHJlY29yZC5hcmc7CiAgICAgICAgfSBlbHNlIGlmIChyZWNvcmQudHlwZSA9PT0gInJldHVybiIpIHsKICAgICAgICAgIHRoaXMucnZhbCA9IHRoaXMuYXJnID0gcmVjb3JkLmFyZzsKICAgICAgICAgIHRoaXMubWV0aG9kID0gInJldHVybiI7CiAgICAgICAgICB0aGlzLm5leHQgPSAiZW5kIjsKICAgICAgICB9IGVsc2UgaWYgKHJlY29yZC50eXBlID09PSAibm9ybWFsIiAmJiBhZnRlckxvYykgewogICAgICAgICAgdGhpcy5uZXh0ID0gYWZ0ZXJMb2M7CiAgICAgICAgfQoKICAgICAgICByZXR1cm4gQ29udGludWVTZW50aW5lbDsKICAgICAgfSwKCiAgICAgIGZpbmlzaDogZnVuY3Rpb24oZmluYWxseUxvYykgewogICAgICAgIGZvciAodmFyIGkgPSB0aGlzLnRyeUVudHJpZXMubGVuZ3RoIC0gMTsgaSA+PSAwOyAtLWkpIHsKICAgICAgICAgIHZhciBlbnRyeSA9IHRoaXMudHJ5RW50cmllc1tpXTsKICAgICAgICAgIGlmIChlbnRyeS5maW5hbGx5TG9jID09PSBmaW5hbGx5TG9jKSB7CiAgICAgICAgICAgIHRoaXMuY29tcGxldGUoZW50cnkuY29tcGxldGlvbiwgZW50cnkuYWZ0ZXJMb2MpOwogICAgICAgICAgICByZXNldFRyeUVudHJ5KGVudHJ5KTsKICAgICAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7CiAgICAgICAgICB9CiAgICAgICAgfQogICAgICB9LAoKICAgICAgImNhdGNoIjogZnVuY3Rpb24odHJ5TG9jKSB7CiAgICAgICAgZm9yICh2YXIgaSA9IHRoaXMudHJ5RW50cmllcy5sZW5ndGggLSAxOyBpID49IDA7IC0taSkgewogICAgICAgICAgdmFyIGVudHJ5ID0gdGhpcy50cnlFbnRyaWVzW2ldOwogICAgICAgICAgaWYgKGVudHJ5LnRyeUxvYyA9PT0gdHJ5TG9jKSB7CiAgICAgICAgICAgIHZhciByZWNvcmQgPSBlbnRyeS5jb21wbGV0aW9uOwogICAgICAgICAgICBpZiAocmVjb3JkLnR5cGUgPT09ICJ0aHJvdyIpIHsKICAgICAgICAgICAgICB2YXIgdGhyb3duID0gcmVjb3JkLmFyZzsKICAgICAgICAgICAgICByZXNldFRyeUVudHJ5KGVudHJ5KTsKICAgICAgICAgICAgfQogICAgICAgICAgICByZXR1cm4gdGhyb3duOwogICAgICAgICAgfQogICAgICAgIH0KCiAgICAgICAgLy8gVGhlIGNvbnRleHQuY2F0Y2ggbWV0aG9kIG11c3Qgb25seSBiZSBjYWxsZWQgd2l0aCBhIGxvY2F0aW9uCiAgICAgICAgLy8gYXJndW1lbnQgdGhhdCBjb3JyZXNwb25kcyB0byBhIGtub3duIGNhdGNoIGJsb2NrLgogICAgICAgIHRocm93IG5ldyBFcnJvcigiaWxsZWdhbCBjYXRjaCBhdHRlbXB0Iik7CiAgICAgIH0sCgogICAgICBkZWxlZ2F0ZVlpZWxkOiBmdW5jdGlvbihpdGVyYWJsZSwgcmVzdWx0TmFtZSwgbmV4dExvYykgewogICAgICAgIHRoaXMuZGVsZWdhdGUgPSB7CiAgICAgICAgICBpdGVyYXRvcjogdmFsdWVzKGl0ZXJhYmxlKSwKICAgICAgICAgIHJlc3VsdE5hbWU6IHJlc3VsdE5hbWUsCiAgICAgICAgICBuZXh0TG9jOiBuZXh0TG9jCiAgICAgICAgfTsKCiAgICAgICAgaWYgKHRoaXMubWV0aG9kID09PSAibmV4dCIpIHsKICAgICAgICAgIC8vIERlbGliZXJhdGVseSBmb3JnZXQgdGhlIGxhc3Qgc2VudCB2YWx1ZSBzbyB0aGF0IHdlIGRvbid0CiAgICAgICAgICAvLyBhY2NpZGVudGFsbHkgcGFzcyBpdCBvbiB0byB0aGUgZGVsZWdhdGUuCiAgICAgICAgICB0aGlzLmFyZyA9IHVuZGVmaW5lZCQxOwogICAgICAgIH0KCiAgICAgICAgcmV0dXJuIENvbnRpbnVlU2VudGluZWw7CiAgICAgIH0KICAgIH07CgogICAgLy8gUmVnYXJkbGVzcyBvZiB3aGV0aGVyIHRoaXMgc2NyaXB0IGlzIGV4ZWN1dGluZyBhcyBhIENvbW1vbkpTIG1vZHVsZQogICAgLy8gb3Igbm90LCByZXR1cm4gdGhlIHJ1bnRpbWUgb2JqZWN0IHNvIHRoYXQgd2UgY2FuIGRlY2xhcmUgdGhlIHZhcmlhYmxlCiAgICAvLyByZWdlbmVyYXRvclJ1bnRpbWUgaW4gdGhlIG91dGVyIHNjb3BlLCB3aGljaCBhbGxvd3MgdGhpcyBtb2R1bGUgdG8gYmUKICAgIC8vIGluamVjdGVkIGVhc2lseSBieSBgYmluL3JlZ2VuZXJhdG9yIC0taW5jbHVkZS1ydW50aW1lIHNjcmlwdC5qc2AuCiAgICByZXR1cm4gZXhwb3J0czsKCiAgfSgKICAgIC8vIElmIHRoaXMgc2NyaXB0IGlzIGV4ZWN1dGluZyBhcyBhIENvbW1vbkpTIG1vZHVsZSwgdXNlIG1vZHVsZS5leHBvcnRzCiAgICAvLyBhcyB0aGUgcmVnZW5lcmF0b3JSdW50aW1lIG5hbWVzcGFjZS4gT3RoZXJ3aXNlIGNyZWF0ZSBhIG5ldyBlbXB0eQogICAgLy8gb2JqZWN0LiBFaXRoZXIgd2F5LCB0aGUgcmVzdWx0aW5nIG9iamVjdCB3aWxsIGJlIHVzZWQgdG8gaW5pdGlhbGl6ZQogICAgLy8gdGhlIHJlZ2VuZXJhdG9yUnVudGltZSB2YXJpYWJsZSBhdCB0aGUgdG9wIG9mIHRoaXMgZmlsZS4KICAgIG1vZHVsZS5leHBvcnRzIAogICkpOwoKICB0cnkgewogICAgcmVnZW5lcmF0b3JSdW50aW1lID0gcnVudGltZTsKICB9IGNhdGNoIChhY2NpZGVudGFsU3RyaWN0TW9kZSkgewogICAgLy8gVGhpcyBtb2R1bGUgc2hvdWxkIG5vdCBiZSBydW5uaW5nIGluIHN0cmljdCBtb2RlLCBzbyB0aGUgYWJvdmUKICAgIC8vIGFzc2lnbm1lbnQgc2hvdWxkIGFsd2F5cyB3b3JrIHVubGVzcyBzb21ldGhpbmcgaXMgbWlzY29uZmlndXJlZC4gSnVzdAogICAgLy8gaW4gY2FzZSBydW50aW1lLmpzIGFjY2lkZW50YWxseSBydW5zIGluIHN0cmljdCBtb2RlLCBpbiBtb2Rlcm4gZW5naW5lcwogICAgLy8gd2UgY2FuIGV4cGxpY2l0bHkgYWNjZXNzIGdsb2JhbFRoaXMuIEluIG9sZGVyIGVuZ2luZXMgd2UgY2FuIGVzY2FwZQogICAgLy8gc3RyaWN0IG1vZGUgdXNpbmcgYSBnbG9iYWwgRnVuY3Rpb24gY2FsbC4gVGhpcyBjb3VsZCBjb25jZWl2YWJseSBmYWlsCiAgICAvLyBpZiBhIENvbnRlbnQgU2VjdXJpdHkgUG9saWN5IGZvcmJpZHMgdXNpbmcgRnVuY3Rpb24sIGJ1dCBpbiB0aGF0IGNhc2UKICAgIC8vIHRoZSBwcm9wZXIgc29sdXRpb24gaXMgdG8gZml4IHRoZSBhY2NpZGVudGFsIHN0cmljdCBtb2RlIHByb2JsZW0uIElmCiAgICAvLyB5b3UndmUgbWlzY29uZmlndXJlZCB5b3VyIGJ1bmRsZXIgdG8gZm9yY2Ugc3RyaWN0IG1vZGUgYW5kIGFwcGxpZWQgYQogICAgLy8gQ1NQIHRvIGZvcmJpZCBGdW5jdGlvbiwgYW5kIHlvdSdyZSBub3Qgd2lsbGluZyB0byBmaXggZWl0aGVyIG9mIHRob3NlCiAgICAvLyBwcm9ibGVtcywgcGxlYXNlIGRldGFpbCB5b3VyIHVuaXF1ZSBwcmVkaWNhbWVudCBpbiBhIEdpdEh1YiBpc3N1ZS4KICAgIGlmICh0eXBlb2YgZ2xvYmFsVGhpcyA9PT0gIm9iamVjdCIpIHsKICAgICAgZ2xvYmFsVGhpcy5yZWdlbmVyYXRvclJ1bnRpbWUgPSBydW50aW1lOwogICAgfSBlbHNlIHsKICAgICAgRnVuY3Rpb24oInIiLCAicmVnZW5lcmF0b3JSdW50aW1lID0gciIpKHJ1bnRpbWUpOwogICAgfQogIH0KICB9KTsKCiAgdmFyIG1hcnRpbmkgPSBudWxsOwoKICBmdW5jdGlvbiBkZWNvZGVUZXJyYWluKHBhcmFtZXRlcnMsIHRyYW5zZmVyYWJsZU9iamVjdHMpIHsKICAgIHZhciBfbWFydGluaTsKCiAgICB2YXIgaW1hZ2VEYXRhID0gcGFyYW1ldGVycy5pbWFnZURhdGEsCiAgICAgICAgX3BhcmFtZXRlcnMkdGlsZVNpemUgPSBwYXJhbWV0ZXJzLnRpbGVTaXplLAogICAgICAgIHRpbGVTaXplID0gX3BhcmFtZXRlcnMkdGlsZVNpemUgPT09IHZvaWQgMCA/IDI1NiA6IF9wYXJhbWV0ZXJzJHRpbGVTaXplLAogICAgICAgIGVycm9yTGV2ZWwgPSBwYXJhbWV0ZXJzLmVycm9yTGV2ZWwsCiAgICAgICAgaW50ZXJ2YWwgPSBwYXJhbWV0ZXJzLmludGVydmFsLAogICAgICAgIG9mZnNldCA9IHBhcmFtZXRlcnMub2Zmc2V0OwogICAgdmFyIHBpeGVscyA9IG5kYXJyYXkobmV3IFVpbnQ4QXJyYXkoaW1hZ2VEYXRhKSwgW3RpbGVTaXplLCB0aWxlU2l6ZSwgNF0sIFs0LCA0ICogdGlsZVNpemUsIDFdLCAwKTsgLy8gVGlsZSBzaXplIG11c3QgYmUgbWFpbnRhaW5lZCB0aHJvdWdoIHRoZSBsaWZlIG9mIHRoZSB3b3JrZXIKCiAgICAoX21hcnRpbmkgPSBtYXJ0aW5pKSAhPT0gbnVsbCAmJiBfbWFydGluaSAhPT0gdm9pZCAwID8gX21hcnRpbmkgOiBtYXJ0aW5pID0gbmV3IE1hcnRpbmkodGlsZVNpemUgKyAxKTsKICAgIHZhciB0ZXJyYWluID0gbWFwYm94VGVycmFpblRvR3JpZChwaXhlbHMsIGludGVydmFsLCBvZmZzZXQpOwogICAgdmFyIHRpbGUgPSBtYXJ0aW5pLmNyZWF0ZVRpbGUodGVycmFpbik7IC8vIGdldCBhIG1lc2ggKHZlcnRpY2VzIGFuZCB0cmlhbmdsZXMgaW5kaWNlcykgZm9yIGEgMTBtIGVycm9yCgogICAgdmFyIG1lc2ggPSB0aWxlLmdldE1lc2goZXJyb3JMZXZlbCwgcGFyYW1ldGVycy5tYXhMZW5ndGgpOwogICAgcmV0dXJuIGNyZWF0ZVF1YW50aXplZE1lc2hEYXRhKHRpbGUsIG1lc2gsIHRpbGVTaXplKTsKICB9CgogIHNlbGYub25tZXNzYWdlID0gZnVuY3Rpb24gKG1zZykgewogICAgdmFyIF9tc2ckZGF0YSA9IG1zZy5kYXRhLAogICAgICAgIGlkID0gX21zZyRkYXRhLmlkLAogICAgICAgIHBheWxvYWQgPSBfbXNnJGRhdGEucGF5bG9hZDsKICAgIGlmIChpZCA9PSBudWxsKSByZXR1cm47CiAgICB2YXIgb2JqZWN0cyA9IFtdOwogICAgdmFyIHJlcyA9IG51bGw7CgogICAgdHJ5IHsKICAgICAgcmVzID0gZGVjb2RlVGVycmFpbihwYXlsb2FkKTsKICAgICAgb2JqZWN0cy5wdXNoKHJlcy5pbmRpY2VzLmJ1ZmZlcik7CiAgICAgIG9iamVjdHMucHVzaChyZXMucXVhbnRpemVkVmVydGljZXMuYnVmZmVyKTsKICAgICAgc2VsZi5wb3N0TWVzc2FnZSh7CiAgICAgICAgaWQ6IGlkLAogICAgICAgIHBheWxvYWQ6IHJlcwogICAgICB9LCBvYmplY3RzKTsKICAgIH0gY2F0Y2ggKGVycikgewogICAgICBzZWxmLnBvc3RNZXNzYWdlKHsKICAgICAgICBpZDogaWQsCiAgICAgICAgZXJyOiBlcnIudG9TdHJpbmcoKQogICAgICB9KTsKICAgIH0gZmluYWxseSB7CiAgICAgIHJlcyA9IG51bGw7CiAgICAgIG9iamVjdHMgPSBudWxsOwogICAgfQogIH07CgogIGV4cG9ydHMuZGVjb2RlVGVycmFpbiA9IGRlY29kZVRlcnJhaW47CgogIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCAnX19lc01vZHVsZScsIHsgdmFsdWU6IHRydWUgfSk7CgogIHJldHVybiBleHBvcnRzOwoKfSkoe30pOwoK', null, false);
|
|
704
|
+
var WorkerFactory = createBase64WorkerFactory('Lyogcm9sbHVwLXBsdWdpbi13ZWItd29ya2VyLWxvYWRlciAqLwp2YXIgd29ya2VyX2NvZGUgPSAoZnVuY3Rpb24gKGV4cG9ydHMpIHsKICAndXNlIHN0cmljdCc7CgogIGZ1bmN0aW9uIF90b0NvbnN1bWFibGVBcnJheShhcnIpIHsKICAgIHJldHVybiBfYXJyYXlXaXRob3V0SG9sZXMoYXJyKSB8fCBfaXRlcmFibGVUb0FycmF5KGFycikgfHwgX3Vuc3VwcG9ydGVkSXRlcmFibGVUb0FycmF5KGFycikgfHwgX25vbkl0ZXJhYmxlU3ByZWFkKCk7CiAgfQogIGZ1bmN0aW9uIF9hcnJheVdpdGhvdXRIb2xlcyhhcnIpIHsKICAgIGlmIChBcnJheS5pc0FycmF5KGFycikpIHJldHVybiBfYXJyYXlMaWtlVG9BcnJheShhcnIpOwogIH0KICBmdW5jdGlvbiBfaXRlcmFibGVUb0FycmF5KGl0ZXIpIHsKICAgIGlmICh0eXBlb2YgU3ltYm9sICE9PSAidW5kZWZpbmVkIiAmJiBpdGVyW1N5bWJvbC5pdGVyYXRvcl0gIT0gbnVsbCB8fCBpdGVyWyJAQGl0ZXJhdG9yIl0gIT0gbnVsbCkgcmV0dXJuIEFycmF5LmZyb20oaXRlcik7CiAgfQogIGZ1bmN0aW9uIF91bnN1cHBvcnRlZEl0ZXJhYmxlVG9BcnJheShvLCBtaW5MZW4pIHsKICAgIGlmICghbykgcmV0dXJuOwogICAgaWYgKHR5cGVvZiBvID09PSAic3RyaW5nIikgcmV0dXJuIF9hcnJheUxpa2VUb0FycmF5KG8sIG1pbkxlbik7CiAgICB2YXIgbiA9IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChvKS5zbGljZSg4LCAtMSk7CiAgICBpZiAobiA9PT0gIk9iamVjdCIgJiYgby5jb25zdHJ1Y3RvcikgbiA9IG8uY29uc3RydWN0b3IubmFtZTsKICAgIGlmIChuID09PSAiTWFwIiB8fCBuID09PSAiU2V0IikgcmV0dXJuIEFycmF5LmZyb20obyk7CiAgICBpZiAobiA9PT0gIkFyZ3VtZW50cyIgfHwgL14oPzpVaXxJKW50KD86OHwxNnwzMikoPzpDbGFtcGVkKT9BcnJheSQvLnRlc3QobikpIHJldHVybiBfYXJyYXlMaWtlVG9BcnJheShvLCBtaW5MZW4pOwogIH0KICBmdW5jdGlvbiBfYXJyYXlMaWtlVG9BcnJheShhcnIsIGxlbikgewogICAgaWYgKGxlbiA9PSBudWxsIHx8IGxlbiA+IGFyci5sZW5ndGgpIGxlbiA9IGFyci5sZW5ndGg7CiAgICBmb3IgKHZhciBpID0gMCwgYXJyMiA9IG5ldyBBcnJheShsZW4pOyBpIDwgbGVuOyBpKyspIGFycjJbaV0gPSBhcnJbaV07CiAgICByZXR1cm4gYXJyMjsKICB9CiAgZnVuY3Rpb24gX25vbkl0ZXJhYmxlU3ByZWFkKCkgewogICAgdGhyb3cgbmV3IFR5cGVFcnJvcigiSW52YWxpZCBhdHRlbXB0IHRvIHNwcmVhZCBub24taXRlcmFibGUgaW5zdGFuY2UuXG5JbiBvcmRlciB0byBiZSBpdGVyYWJsZSwgbm9uLWFycmF5IG9iamVjdHMgbXVzdCBoYXZlIGEgW1N5bWJvbC5pdGVyYXRvcl0oKSBtZXRob2QuIik7CiAgfQoKICAvLyBXZSBzaG91bGQgc2F2ZSB0aGVzZQogIC8vY29uc3QgY2FudmFzID0gbmV3IE9mZnNjcmVlbkNhbnZhcygyNTYsIDI1Nik7CiAgLy9jb25zdCBjdHggPSBjYW52YXMuZ2V0Q29udGV4dCgiMmQiKTsKCiAgZnVuY3Rpb24gbWFwYm94VGVycmFpblRvR3JpZChwbmcsIGludGVydmFsLCBvZmZzZXQpIHsKICAgIHZhciBfaW50ZXJ2YWwsIF9vZmZzZXQ7CiAgICAvLyBtYXliZSB3ZSBzaG91bGQgZG8gdGhpcyBvbiB0aGUgR1BVIHVzaW5nIFJFR0w/CiAgICAvLyBidXQgdGhhdCB3b3VsZCByZXF1aXJlIEdQVSAtPiBDUFUgLT4gR1BVCiAgICB2YXIgZ3JpZFNpemUgPSBwbmcuc2hhcGVbMF0gKyAxOwogICAgdmFyIHRlcnJhaW4gPSBuZXcgRmxvYXQzMkFycmF5KGdyaWRTaXplICogZ3JpZFNpemUpOwogICAgdmFyIHRpbGVTaXplID0gcG5nLnNoYXBlWzBdOwogICAgaW50ZXJ2YWwgPSAoX2ludGVydmFsID0gaW50ZXJ2YWwpICE9PSBudWxsICYmIF9pbnRlcnZhbCAhPT0gdm9pZCAwID8gX2ludGVydmFsIDogMC4xOwogICAgb2Zmc2V0ID0gKF9vZmZzZXQgPSBvZmZzZXQpICE9PSBudWxsICYmIF9vZmZzZXQgIT09IHZvaWQgMCA/IF9vZmZzZXQgOiAtMTAwMDA7CgogICAgLy8gZGVjb2RlIHRlcnJhaW4gdmFsdWVzCiAgICBmb3IgKHZhciB5ID0gMDsgeSA8IHRpbGVTaXplOyB5KyspIHsKICAgICAgZm9yICh2YXIgeCA9IDA7IHggPCB0aWxlU2l6ZTsgeCsrKSB7CiAgICAgICAgdmFyIHljID0geTsKICAgICAgICB2YXIgciA9IHBuZy5nZXQoeCwgeWMsIDApOwogICAgICAgIHZhciBnID0gcG5nLmdldCh4LCB5YywgMSk7CiAgICAgICAgdmFyIGIgPSBwbmcuZ2V0KHgsIHljLCAyKTsKICAgICAgICB0ZXJyYWluW3kgKiBncmlkU2l6ZSArIHhdID0gciAqIDI1NiAqIDI1NiAqIGludGVydmFsICsgZyAqIDI1Ni4wICogaW50ZXJ2YWwgKyBiICogaW50ZXJ2YWwgKyBvZmZzZXQ7CiAgICAgIH0KICAgIH0KICAgIC8vIGJhY2tmaWxsIHJpZ2h0IGFuZCBib3R0b20gYm9yZGVycwogICAgZm9yICh2YXIgX3ggPSAwOyBfeCA8IGdyaWRTaXplIC0gMTsgX3grKykgewogICAgICB0ZXJyYWluW2dyaWRTaXplICogKGdyaWRTaXplIC0gMSkgKyBfeF0gPSB0ZXJyYWluW2dyaWRTaXplICogKGdyaWRTaXplIC0gMikgKyBfeF07CiAgICB9CiAgICBmb3IgKHZhciBfeSA9IDA7IF95IDwgZ3JpZFNpemU7IF95KyspIHsKICAgICAgdGVycmFpbltncmlkU2l6ZSAqIF95ICsgZ3JpZFNpemUgLSAxXSA9IHRlcnJhaW5bZ3JpZFNpemUgKiBfeSArIGdyaWRTaXplIC0gMl07CiAgICB9CiAgICByZXR1cm4gdGVycmFpbjsKICB9CiAgZnVuY3Rpb24gY3JlYXRlUXVhbnRpemVkTWVzaERhdGEodGlsZSwgbWVzaCwgdGlsZVNpemUpIHsKICAgIHZhciB4dmFscyA9IFtdOwogICAgdmFyIHl2YWxzID0gW107CiAgICB2YXIgaGVpZ2h0TWV0ZXJzID0gW107CiAgICB2YXIgbm9ydGhJbmRpY2VzID0gW107CiAgICB2YXIgc291dGhJbmRpY2VzID0gW107CiAgICB2YXIgZWFzdEluZGljZXMgPSBbXTsKICAgIHZhciB3ZXN0SW5kaWNlcyA9IFtdOwogICAgdmFyIG1pbmltdW1IZWlnaHQgPSBJbmZpbml0eTsKICAgIHZhciBtYXhpbXVtSGVpZ2h0ID0gLUluZmluaXR5OwogICAgdmFyIHNjYWxhciA9IDMyNzY4LjAgLyB0aWxlU2l6ZTsKICAgIGZvciAodmFyIGl4ID0gMDsgaXggPCBtZXNoLnZlcnRpY2VzLmxlbmd0aCAvIDI7IGl4KyspIHsKICAgICAgdmFyIHZlcnRleEl4ID0gaXg7CiAgICAgIHZhciBweCA9IG1lc2gudmVydGljZXNbaXggKiAyXTsKICAgICAgdmFyIHB5ID0gbWVzaC52ZXJ0aWNlc1tpeCAqIDIgKyAxXTsKICAgICAgdmFyIGhlaWdodCA9IHRpbGUudGVycmFpbltweSAqICh0aWxlU2l6ZSArIDEpICsgcHhdOwogICAgICBpZiAoaGVpZ2h0ID4gbWF4aW11bUhlaWdodCkgbWF4aW11bUhlaWdodCA9IGhlaWdodDsKICAgICAgaWYgKGhlaWdodCA8IG1pbmltdW1IZWlnaHQpIG1pbmltdW1IZWlnaHQgPSBoZWlnaHQ7CiAgICAgIGhlaWdodE1ldGVycy5wdXNoKGhlaWdodCk7CiAgICAgIGlmIChweSA9PSAwKSBub3J0aEluZGljZXMucHVzaCh2ZXJ0ZXhJeCk7CiAgICAgIGlmIChweSA9PSB0aWxlU2l6ZSkgc291dGhJbmRpY2VzLnB1c2godmVydGV4SXgpOwogICAgICBpZiAocHggPT0gMCkgd2VzdEluZGljZXMucHVzaCh2ZXJ0ZXhJeCk7CiAgICAgIGlmIChweCA9PSB0aWxlU2l6ZSkgZWFzdEluZGljZXMucHVzaCh2ZXJ0ZXhJeCk7CiAgICAgIHZhciB4diA9IHB4ICogc2NhbGFyOwogICAgICB2YXIgeXYgPSAodGlsZVNpemUgLSBweSkgKiBzY2FsYXI7CiAgICAgIHh2YWxzLnB1c2goeHYpOwogICAgICB5dmFscy5wdXNoKHl2KTsKICAgIH0KICAgIHZhciBoZWlnaHRSYW5nZSA9IG1heGltdW1IZWlnaHQgLSBtaW5pbXVtSGVpZ2h0OwogICAgdmFyIGhlaWdodHMgPSBoZWlnaHRNZXRlcnMubWFwKGZ1bmN0aW9uIChkKSB7CiAgICAgIGlmIChoZWlnaHRSYW5nZSA8IDEpIHJldHVybiAwOwogICAgICByZXR1cm4gKGQgLSBtaW5pbXVtSGVpZ2h0KSAqICgzMjc2Ny4wIC8gaGVpZ2h0UmFuZ2UpOwogICAgfSk7CiAgICB2YXIgdHJpYW5nbGVzID0gbmV3IFVpbnQxNkFycmF5KG1lc2gudHJpYW5nbGVzKTsKICAgIHZhciBxdWFudGl6ZWRWZXJ0aWNlcyA9IG5ldyBVaW50MTZBcnJheSggLy92ZXJ0cwogICAgW10uY29uY2F0KHh2YWxzLCB5dmFscywgX3RvQ29uc3VtYWJsZUFycmF5KGhlaWdodHMpKSk7CgogICAgLy8gU0UgTlcgTkUKICAgIC8vIE5FIE5XIFNFCgogICAgcmV0dXJuIHsKICAgICAgbWluaW11bUhlaWdodDogbWluaW11bUhlaWdodCwKICAgICAgbWF4aW11bUhlaWdodDogbWF4aW11bUhlaWdodCwKICAgICAgcXVhbnRpemVkVmVydGljZXM6IHF1YW50aXplZFZlcnRpY2VzLAogICAgICBpbmRpY2VzOiB0cmlhbmdsZXMsCiAgICAgIHdlc3RJbmRpY2VzOiB3ZXN0SW5kaWNlcywKICAgICAgc291dGhJbmRpY2VzOiBzb3V0aEluZGljZXMsCiAgICAgIGVhc3RJbmRpY2VzOiBlYXN0SW5kaWNlcywKICAgICAgbm9ydGhJbmRpY2VzOiBub3J0aEluZGljZXMKICAgIH07CiAgfQoKICBmdW5jdGlvbiBpb3RhKG4pIHsKICAgIHZhciByZXN1bHQgPSBuZXcgQXJyYXkobik7CiAgICBmb3IgKHZhciBpID0gMDsgaSA8IG47ICsraSkgewogICAgICByZXN1bHRbaV0gPSBpOwogICAgfQogICAgcmV0dXJuIHJlc3VsdDsKICB9CiAgdmFyIGlvdGFfMSA9IGlvdGE7CgogIC8qIQogICAqIERldGVybWluZSBpZiBhbiBvYmplY3QgaXMgYSBCdWZmZXIKICAgKgogICAqIEBhdXRob3IgICBGZXJvc3MgQWJvdWtoYWRpamVoIDxodHRwczovL2Zlcm9zcy5vcmc+CiAgICogQGxpY2Vuc2UgIE1JVAogICAqLwogIC8vIFRoZSBfaXNCdWZmZXIgY2hlY2sgaXMgZm9yIFNhZmFyaSA1LTcgc3VwcG9ydCwgYmVjYXVzZSBpdCdzIG1pc3NpbmcKICAvLyBPYmplY3QucHJvdG90eXBlLmNvbnN0cnVjdG9yLiBSZW1vdmUgdGhpcyBldmVudHVhbGx5CiAgdmFyIGlzQnVmZmVyXzEgPSBmdW5jdGlvbiAob2JqKSB7CiAgICByZXR1cm4gb2JqICE9IG51bGwgJiYgKGlzQnVmZmVyKG9iaikgfHwgaXNTbG93QnVmZmVyKG9iaikgfHwgISFvYmouX2lzQnVmZmVyKTsKICB9OwogIGZ1bmN0aW9uIGlzQnVmZmVyKG9iaikgewogICAgcmV0dXJuICEhb2JqLmNvbnN0cnVjdG9yICYmIHR5cGVvZiBvYmouY29uc3RydWN0b3IuaXNCdWZmZXIgPT09ICdmdW5jdGlvbicgJiYgb2JqLmNvbnN0cnVjdG9yLmlzQnVmZmVyKG9iaik7CiAgfQoKICAvLyBGb3IgTm9kZSB2MC4xMCBzdXBwb3J0LiBSZW1vdmUgdGhpcyBldmVudHVhbGx5LgogIGZ1bmN0aW9uIGlzU2xvd0J1ZmZlcihvYmopIHsKICAgIHJldHVybiB0eXBlb2Ygb2JqLnJlYWRGbG9hdExFID09PSAnZnVuY3Rpb24nICYmIHR5cGVvZiBvYmouc2xpY2UgPT09ICdmdW5jdGlvbicgJiYgaXNCdWZmZXIob2JqLnNsaWNlKDAsIDApKTsKICB9CgogIHZhciBoYXNUeXBlZEFycmF5cyA9IHR5cGVvZiBGbG9hdDY0QXJyYXkgIT09ICJ1bmRlZmluZWQiOwogIGZ1bmN0aW9uIGNvbXBhcmUxc3QoYSwgYikgewogICAgcmV0dXJuIGFbMF0gLSBiWzBdOwogIH0KICBmdW5jdGlvbiBvcmRlcigpIHsKICAgIHZhciBzdHJpZGUgPSB0aGlzLnN0cmlkZTsKICAgIHZhciB0ZXJtcyA9IG5ldyBBcnJheShzdHJpZGUubGVuZ3RoKTsKICAgIHZhciBpOwogICAgZm9yIChpID0gMDsgaSA8IHRlcm1zLmxlbmd0aDsgKytpKSB7CiAgICAgIHRlcm1zW2ldID0gW01hdGguYWJzKHN0cmlkZVtpXSksIGldOwogICAgfQogICAgdGVybXMuc29ydChjb21wYXJlMXN0KTsKICAgIHZhciByZXN1bHQgPSBuZXcgQXJyYXkodGVybXMubGVuZ3RoKTsKICAgIGZvciAoaSA9IDA7IGkgPCByZXN1bHQubGVuZ3RoOyArK2kpIHsKICAgICAgcmVzdWx0W2ldID0gdGVybXNbaV1bMV07CiAgICB9CiAgICByZXR1cm4gcmVzdWx0OwogIH0KICBmdW5jdGlvbiBjb21waWxlQ29uc3RydWN0b3IoZHR5cGUsIGRpbWVuc2lvbikgewogICAgdmFyIGNsYXNzTmFtZSA9IFsiVmlldyIsIGRpbWVuc2lvbiwgImQiLCBkdHlwZV0uam9pbigiIik7CiAgICBpZiAoZGltZW5zaW9uIDwgMCkgewogICAgICBjbGFzc05hbWUgPSAiVmlld19OaWwiICsgZHR5cGU7CiAgICB9CiAgICB2YXIgdXNlR2V0dGVycyA9IGR0eXBlID09PSAiZ2VuZXJpYyI7CiAgICBpZiAoZGltZW5zaW9uID09PSAtMSkgewogICAgICAvL1NwZWNpYWwgY2FzZSBmb3IgdHJpdmlhbCBhcnJheXMKICAgICAgdmFyIGNvZGUgPSAiZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICIoYSl7dGhpcy5kYXRhPWE7fTtcCnZhciBwcm90bz0iICsgY2xhc3NOYW1lICsgIi5wcm90b3R5cGU7XApwcm90by5kdHlwZT0nIiArIGR0eXBlICsgIic7XApwcm90by5pbmRleD1mdW5jdGlvbigpe3JldHVybiAtMX07XApwcm90by5zaXplPTA7XApwcm90by5kaW1lbnNpb249LTE7XApwcm90by5zaGFwZT1wcm90by5zdHJpZGU9cHJvdG8ub3JkZXI9W107XApwcm90by5sbz1wcm90by5oaT1wcm90by50cmFuc3Bvc2U9cHJvdG8uc3RlcD1cCmZ1bmN0aW9uKCl7cmV0dXJuIG5ldyAiICsgY2xhc3NOYW1lICsgIih0aGlzLmRhdGEpO307XApwcm90by5nZXQ9cHJvdG8uc2V0PWZ1bmN0aW9uKCl7fTtcCnByb3RvLnBpY2s9ZnVuY3Rpb24oKXtyZXR1cm4gbnVsbH07XApyZXR1cm4gZnVuY3Rpb24gY29uc3RydWN0XyIgKyBjbGFzc05hbWUgKyAiKGEpe3JldHVybiBuZXcgIiArIGNsYXNzTmFtZSArICIoYSk7fSI7CiAgICAgIHZhciBwcm9jZWR1cmUgPSBuZXcgRnVuY3Rpb24oY29kZSk7CiAgICAgIHJldHVybiBwcm9jZWR1cmUoKTsKICAgIH0gZWxzZSBpZiAoZGltZW5zaW9uID09PSAwKSB7CiAgICAgIC8vU3BlY2lhbCBjYXNlIGZvciAwZCBhcnJheXMKICAgICAgdmFyIGNvZGUgPSAiZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICIoYSxkKSB7XAp0aGlzLmRhdGEgPSBhO1wKdGhpcy5vZmZzZXQgPSBkXAp9O1wKdmFyIHByb3RvPSIgKyBjbGFzc05hbWUgKyAiLnByb3RvdHlwZTtcCnByb3RvLmR0eXBlPSciICsgZHR5cGUgKyAiJztcCnByb3RvLmluZGV4PWZ1bmN0aW9uKCl7cmV0dXJuIHRoaXMub2Zmc2V0fTtcCnByb3RvLmRpbWVuc2lvbj0wO1wKcHJvdG8uc2l6ZT0xO1wKcHJvdG8uc2hhcGU9XApwcm90by5zdHJpZGU9XApwcm90by5vcmRlcj1bXTtcCnByb3RvLmxvPVwKcHJvdG8uaGk9XApwcm90by50cmFuc3Bvc2U9XApwcm90by5zdGVwPWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX2NvcHkoKSB7XApyZXR1cm4gbmV3ICIgKyBjbGFzc05hbWUgKyAiKHRoaXMuZGF0YSx0aGlzLm9mZnNldClcCn07XApwcm90by5waWNrPWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX3BpY2soKXtcCnJldHVybiBUcml2aWFsQXJyYXkodGhpcy5kYXRhKTtcCn07XApwcm90by52YWx1ZU9mPXByb3RvLmdldD1mdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIl9nZXQoKXtcCnJldHVybiAiICsgKHVzZUdldHRlcnMgPyAidGhpcy5kYXRhLmdldCh0aGlzLm9mZnNldCkiIDogInRoaXMuZGF0YVt0aGlzLm9mZnNldF0iKSArICJ9O1wKcHJvdG8uc2V0PWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX3NldCh2KXtcCnJldHVybiAiICsgKHVzZUdldHRlcnMgPyAidGhpcy5kYXRhLnNldCh0aGlzLm9mZnNldCx2KSIgOiAidGhpcy5kYXRhW3RoaXMub2Zmc2V0XT12IikgKyAiXAp9O1wKcmV0dXJuIGZ1bmN0aW9uIGNvbnN0cnVjdF8iICsgY2xhc3NOYW1lICsgIihhLGIsYyxkKXtyZXR1cm4gbmV3ICIgKyBjbGFzc05hbWUgKyAiKGEsZCl9IjsKICAgICAgdmFyIHByb2NlZHVyZSA9IG5ldyBGdW5jdGlvbigiVHJpdmlhbEFycmF5IiwgY29kZSk7CiAgICAgIHJldHVybiBwcm9jZWR1cmUoQ0FDSEVEX0NPTlNUUlVDVE9SU1tkdHlwZV1bMF0pOwogICAgfQogICAgdmFyIGNvZGUgPSBbIid1c2Ugc3RyaWN0JyJdOwoKICAgIC8vQ3JlYXRlIGNvbnN0cnVjdG9yIGZvciB2aWV3CiAgICB2YXIgaW5kaWNlcyA9IGlvdGFfMShkaW1lbnNpb24pOwogICAgdmFyIGFyZ3MgPSBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gImkiICsgaTsKICAgIH0pOwogICAgdmFyIGluZGV4X3N0ciA9ICJ0aGlzLm9mZnNldCsiICsgaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJ0aGlzLnN0cmlkZVsiICsgaSArICJdKmkiICsgaTsKICAgIH0pLmpvaW4oIisiKTsKICAgIHZhciBzaGFwZUFyZyA9IGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiYiIgKyBpOwogICAgfSkuam9pbigiLCIpOwogICAgdmFyIHN0cmlkZUFyZyA9IGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiYyIgKyBpOwogICAgfSkuam9pbigiLCIpOwogICAgY29kZS5wdXNoKCJmdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIihhLCIgKyBzaGFwZUFyZyArICIsIiArIHN0cmlkZUFyZyArICIsZCl7dGhpcy5kYXRhPWEiLCAidGhpcy5zaGFwZT1bIiArIHNoYXBlQXJnICsgIl0iLCAidGhpcy5zdHJpZGU9WyIgKyBzdHJpZGVBcmcgKyAiXSIsICJ0aGlzLm9mZnNldD1kfDB9IiwgInZhciBwcm90bz0iICsgY2xhc3NOYW1lICsgIi5wcm90b3R5cGUiLCAicHJvdG8uZHR5cGU9JyIgKyBkdHlwZSArICInIiwgInByb3RvLmRpbWVuc2lvbj0iICsgZGltZW5zaW9uKTsKCiAgICAvL3ZpZXcuc2l6ZToKICAgIGNvZGUucHVzaCgiT2JqZWN0LmRlZmluZVByb3BlcnR5KHByb3RvLCdzaXplJyx7Z2V0OmZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX3NpemUoKXtcCnJldHVybiAiICsgaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJ0aGlzLnNoYXBlWyIgKyBpICsgIl0iOwogICAgfSkuam9pbigiKiIpLCAifX0pIik7CgogICAgLy92aWV3Lm9yZGVyOgogICAgaWYgKGRpbWVuc2lvbiA9PT0gMSkgewogICAgICBjb2RlLnB1c2goInByb3RvLm9yZGVyPVswXSIpOwogICAgfSBlbHNlIHsKICAgICAgY29kZS5wdXNoKCJPYmplY3QuZGVmaW5lUHJvcGVydHkocHJvdG8sJ29yZGVyJyx7Z2V0OiIpOwogICAgICBpZiAoZGltZW5zaW9uIDwgNCkgewogICAgICAgIGNvZGUucHVzaCgiZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfb3JkZXIoKXsiKTsKICAgICAgICBpZiAoZGltZW5zaW9uID09PSAyKSB7CiAgICAgICAgICBjb2RlLnB1c2goInJldHVybiAoTWF0aC5hYnModGhpcy5zdHJpZGVbMF0pPk1hdGguYWJzKHRoaXMuc3RyaWRlWzFdKSk/WzEsMF06WzAsMV19fSkiKTsKICAgICAgICB9IGVsc2UgaWYgKGRpbWVuc2lvbiA9PT0gMykgewogICAgICAgICAgY29kZS5wdXNoKCJ2YXIgczA9TWF0aC5hYnModGhpcy5zdHJpZGVbMF0pLHMxPU1hdGguYWJzKHRoaXMuc3RyaWRlWzFdKSxzMj1NYXRoLmFicyh0aGlzLnN0cmlkZVsyXSk7XAppZihzMD5zMSl7XAppZihzMT5zMil7XApyZXR1cm4gWzIsMSwwXTtcCn1lbHNlIGlmKHMwPnMyKXtcCnJldHVybiBbMSwyLDBdO1wKfWVsc2V7XApyZXR1cm4gWzEsMCwyXTtcCn1cCn1lbHNlIGlmKHMwPnMyKXtcCnJldHVybiBbMiwwLDFdO1wKfWVsc2UgaWYoczI+czEpe1wKcmV0dXJuIFswLDEsMl07XAp9ZWxzZXtcCnJldHVybiBbMCwyLDFdO1wKfX19KSIpOwogICAgICAgIH0KICAgICAgfSBlbHNlIHsKICAgICAgICBjb2RlLnB1c2goIk9SREVSfSkiKTsKICAgICAgfQogICAgfQoKICAgIC8vdmlldy5zZXQoaTAsIC4uLiwgdik6CiAgICBjb2RlLnB1c2goInByb3RvLnNldD1mdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIl9zZXQoIiArIGFyZ3Muam9pbigiLCIpICsgIix2KXsiKTsKICAgIGlmICh1c2VHZXR0ZXJzKSB7CiAgICAgIGNvZGUucHVzaCgicmV0dXJuIHRoaXMuZGF0YS5zZXQoIiArIGluZGV4X3N0ciArICIsdil9Iik7CiAgICB9IGVsc2UgewogICAgICBjb2RlLnB1c2goInJldHVybiB0aGlzLmRhdGFbIiArIGluZGV4X3N0ciArICJdPXZ9Iik7CiAgICB9CgogICAgLy92aWV3LmdldChpMCwgLi4uKToKICAgIGNvZGUucHVzaCgicHJvdG8uZ2V0PWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX2dldCgiICsgYXJncy5qb2luKCIsIikgKyAiKXsiKTsKICAgIGlmICh1c2VHZXR0ZXJzKSB7CiAgICAgIGNvZGUucHVzaCgicmV0dXJuIHRoaXMuZGF0YS5nZXQoIiArIGluZGV4X3N0ciArICIpfSIpOwogICAgfSBlbHNlIHsKICAgICAgY29kZS5wdXNoKCJyZXR1cm4gdGhpcy5kYXRhWyIgKyBpbmRleF9zdHIgKyAiXX0iKTsKICAgIH0KCiAgICAvL3ZpZXcuaW5kZXg6CiAgICBjb2RlLnB1c2goInByb3RvLmluZGV4PWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX2luZGV4KCIsIGFyZ3Muam9pbigpLCAiKXtyZXR1cm4gIiArIGluZGV4X3N0ciArICJ9Iik7CgogICAgLy92aWV3LmhpKCk6CiAgICBjb2RlLnB1c2goInByb3RvLmhpPWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX2hpKCIgKyBhcmdzLmpvaW4oIiwiKSArICIpe3JldHVybiBuZXcgIiArIGNsYXNzTmFtZSArICIodGhpcy5kYXRhLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gWyIodHlwZW9mIGkiLCBpLCAiIT09J251bWJlcid8fGkiLCBpLCAiPDApP3RoaXMuc2hhcGVbIiwgaSwgIl06aSIsIGksICJ8MCJdLmpvaW4oIiIpOwogICAgfSkuam9pbigiLCIpICsgIiwiICsgaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJ0aGlzLnN0cmlkZVsiICsgaSArICJdIjsKICAgIH0pLmpvaW4oIiwiKSArICIsdGhpcy5vZmZzZXQpfSIpOwoKICAgIC8vdmlldy5sbygpOgogICAgdmFyIGFfdmFycyA9IGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiYSIgKyBpICsgIj10aGlzLnNoYXBlWyIgKyBpICsgIl0iOwogICAgfSk7CiAgICB2YXIgY192YXJzID0gaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJjIiArIGkgKyAiPXRoaXMuc3RyaWRlWyIgKyBpICsgIl0iOwogICAgfSk7CiAgICBjb2RlLnB1c2goInByb3RvLmxvPWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX2xvKCIgKyBhcmdzLmpvaW4oIiwiKSArICIpe3ZhciBiPXRoaXMub2Zmc2V0LGQ9MCwiICsgYV92YXJzLmpvaW4oIiwiKSArICIsIiArIGNfdmFycy5qb2luKCIsIikpOwogICAgZm9yICh2YXIgaSA9IDA7IGkgPCBkaW1lbnNpb247ICsraSkgewogICAgICBjb2RlLnB1c2goImlmKHR5cGVvZiBpIiArIGkgKyAiPT09J251bWJlcicmJmkiICsgaSArICI+PTApe1wKZD1pIiArIGkgKyAifDA7XApiKz1jIiArIGkgKyAiKmQ7XAphIiArIGkgKyAiLT1kfSIpOwogICAgfQogICAgY29kZS5wdXNoKCJyZXR1cm4gbmV3ICIgKyBjbGFzc05hbWUgKyAiKHRoaXMuZGF0YSwiICsgaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJhIiArIGk7CiAgICB9KS5qb2luKCIsIikgKyAiLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gImMiICsgaTsKICAgIH0pLmpvaW4oIiwiKSArICIsYil9Iik7CgogICAgLy92aWV3LnN0ZXAoKToKICAgIGNvZGUucHVzaCgicHJvdG8uc3RlcD1mdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIl9zdGVwKCIgKyBhcmdzLmpvaW4oIiwiKSArICIpe3ZhciAiICsgaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJhIiArIGkgKyAiPXRoaXMuc2hhcGVbIiArIGkgKyAiXSI7CiAgICB9KS5qb2luKCIsIikgKyAiLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gImIiICsgaSArICI9dGhpcy5zdHJpZGVbIiArIGkgKyAiXSI7CiAgICB9KS5qb2luKCIsIikgKyAiLGM9dGhpcy5vZmZzZXQsZD0wLGNlaWw9TWF0aC5jZWlsIik7CiAgICBmb3IgKHZhciBpID0gMDsgaSA8IGRpbWVuc2lvbjsgKytpKSB7CiAgICAgIGNvZGUucHVzaCgiaWYodHlwZW9mIGkiICsgaSArICI9PT0nbnVtYmVyJyl7XApkPWkiICsgaSArICJ8MDtcCmlmKGQ8MCl7XApjKz1iIiArIGkgKyAiKihhIiArIGkgKyAiLTEpO1wKYSIgKyBpICsgIj1jZWlsKC1hIiArIGkgKyAiL2QpXAp9ZWxzZXtcCmEiICsgaSArICI9Y2VpbChhIiArIGkgKyAiL2QpXAp9XApiIiArIGkgKyAiKj1kXAp9Iik7CiAgICB9CiAgICBjb2RlLnB1c2goInJldHVybiBuZXcgIiArIGNsYXNzTmFtZSArICIodGhpcy5kYXRhLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gImEiICsgaTsKICAgIH0pLmpvaW4oIiwiKSArICIsIiArIGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiYiIgKyBpOwogICAgfSkuam9pbigiLCIpICsgIixjKX0iKTsKCiAgICAvL3ZpZXcudHJhbnNwb3NlKCk6CiAgICB2YXIgdFNoYXBlID0gbmV3IEFycmF5KGRpbWVuc2lvbik7CiAgICB2YXIgdFN0cmlkZSA9IG5ldyBBcnJheShkaW1lbnNpb24pOwogICAgZm9yICh2YXIgaSA9IDA7IGkgPCBkaW1lbnNpb247ICsraSkgewogICAgICB0U2hhcGVbaV0gPSAiYVtpIiArIGkgKyAiXSI7CiAgICAgIHRTdHJpZGVbaV0gPSAiYltpIiArIGkgKyAiXSI7CiAgICB9CiAgICBjb2RlLnB1c2goInByb3RvLnRyYW5zcG9zZT1mdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIl90cmFuc3Bvc2UoIiArIGFyZ3MgKyAiKXsiICsgYXJncy5tYXAoZnVuY3Rpb24gKG4sIGlkeCkgewogICAgICByZXR1cm4gbiArICI9KCIgKyBuICsgIj09PXVuZGVmaW5lZD8iICsgaWR4ICsgIjoiICsgbiArICJ8MCkiOwogICAgfSkuam9pbigiOyIpLCAidmFyIGE9dGhpcy5zaGFwZSxiPXRoaXMuc3RyaWRlO3JldHVybiBuZXcgIiArIGNsYXNzTmFtZSArICIodGhpcy5kYXRhLCIgKyB0U2hhcGUuam9pbigiLCIpICsgIiwiICsgdFN0cmlkZS5qb2luKCIsIikgKyAiLHRoaXMub2Zmc2V0KX0iKTsKCiAgICAvL3ZpZXcucGljaygpOgogICAgY29kZS5wdXNoKCJwcm90by5waWNrPWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX3BpY2soIiArIGFyZ3MgKyAiKXt2YXIgYT1bXSxiPVtdLGM9dGhpcy5vZmZzZXQiKTsKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgZGltZW5zaW9uOyArK2kpIHsKICAgICAgY29kZS5wdXNoKCJpZih0eXBlb2YgaSIgKyBpICsgIj09PSdudW1iZXInJiZpIiArIGkgKyAiPj0wKXtjPShjK3RoaXMuc3RyaWRlWyIgKyBpICsgIl0qaSIgKyBpICsgIil8MH1lbHNle2EucHVzaCh0aGlzLnNoYXBlWyIgKyBpICsgIl0pO2IucHVzaCh0aGlzLnN0cmlkZVsiICsgaSArICJdKX0iKTsKICAgIH0KICAgIGNvZGUucHVzaCgidmFyIGN0b3I9Q1RPUl9MSVNUW2EubGVuZ3RoKzFdO3JldHVybiBjdG9yKHRoaXMuZGF0YSxhLGIsYyl9Iik7CgogICAgLy9BZGQgcmV0dXJuIHN0YXRlbWVudAogICAgY29kZS5wdXNoKCJyZXR1cm4gZnVuY3Rpb24gY29uc3RydWN0XyIgKyBjbGFzc05hbWUgKyAiKGRhdGEsc2hhcGUsc3RyaWRlLG9mZnNldCl7cmV0dXJuIG5ldyAiICsgY2xhc3NOYW1lICsgIihkYXRhLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gInNoYXBlWyIgKyBpICsgIl0iOwogICAgfSkuam9pbigiLCIpICsgIiwiICsgaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJzdHJpZGVbIiArIGkgKyAiXSI7CiAgICB9KS5qb2luKCIsIikgKyAiLG9mZnNldCl9Iik7CgogICAgLy9Db21waWxlIHByb2NlZHVyZQogICAgdmFyIHByb2NlZHVyZSA9IG5ldyBGdW5jdGlvbigiQ1RPUl9MSVNUIiwgIk9SREVSIiwgY29kZS5qb2luKCJcbiIpKTsKICAgIHJldHVybiBwcm9jZWR1cmUoQ0FDSEVEX0NPTlNUUlVDVE9SU1tkdHlwZV0sIG9yZGVyKTsKICB9CiAgZnVuY3Rpb24gYXJyYXlEVHlwZShkYXRhKSB7CiAgICBpZiAoaXNCdWZmZXJfMShkYXRhKSkgewogICAgICByZXR1cm4gImJ1ZmZlciI7CiAgICB9CiAgICBpZiAoaGFzVHlwZWRBcnJheXMpIHsKICAgICAgc3dpdGNoIChPYmplY3QucHJvdG90eXBlLnRvU3RyaW5nLmNhbGwoZGF0YSkpIHsKICAgICAgICBjYXNlICJbb2JqZWN0IEZsb2F0NjRBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJmbG9hdDY0IjsKICAgICAgICBjYXNlICJbb2JqZWN0IEZsb2F0MzJBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJmbG9hdDMyIjsKICAgICAgICBjYXNlICJbb2JqZWN0IEludDhBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJpbnQ4IjsKICAgICAgICBjYXNlICJbb2JqZWN0IEludDE2QXJyYXldIjoKICAgICAgICAgIHJldHVybiAiaW50MTYiOwogICAgICAgIGNhc2UgIltvYmplY3QgSW50MzJBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJpbnQzMiI7CiAgICAgICAgY2FzZSAiW29iamVjdCBVaW50OEFycmF5XSI6CiAgICAgICAgICByZXR1cm4gInVpbnQ4IjsKICAgICAgICBjYXNlICJbb2JqZWN0IFVpbnQxNkFycmF5XSI6CiAgICAgICAgICByZXR1cm4gInVpbnQxNiI7CiAgICAgICAgY2FzZSAiW29iamVjdCBVaW50MzJBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJ1aW50MzIiOwogICAgICAgIGNhc2UgIltvYmplY3QgVWludDhDbGFtcGVkQXJyYXldIjoKICAgICAgICAgIHJldHVybiAidWludDhfY2xhbXBlZCI7CiAgICAgICAgY2FzZSAiW29iamVjdCBCaWdJbnQ2NEFycmF5XSI6CiAgICAgICAgICByZXR1cm4gImJpZ2ludDY0IjsKICAgICAgICBjYXNlICJbb2JqZWN0IEJpZ1VpbnQ2NEFycmF5XSI6CiAgICAgICAgICByZXR1cm4gImJpZ3VpbnQ2NCI7CiAgICAgIH0KICAgIH0KICAgIGlmIChBcnJheS5pc0FycmF5KGRhdGEpKSB7CiAgICAgIHJldHVybiAiYXJyYXkiOwogICAgfQogICAgcmV0dXJuICJnZW5lcmljIjsKICB9CiAgdmFyIENBQ0hFRF9DT05TVFJVQ1RPUlMgPSB7CiAgICAiZmxvYXQzMiI6IFtdLAogICAgImZsb2F0NjQiOiBbXSwKICAgICJpbnQ4IjogW10sCiAgICAiaW50MTYiOiBbXSwKICAgICJpbnQzMiI6IFtdLAogICAgInVpbnQ4IjogW10sCiAgICAidWludDE2IjogW10sCiAgICAidWludDMyIjogW10sCiAgICAiYXJyYXkiOiBbXSwKICAgICJ1aW50OF9jbGFtcGVkIjogW10sCiAgICAiYmlnaW50NjQiOiBbXSwKICAgICJiaWd1aW50NjQiOiBbXSwKICAgICJidWZmZXIiOiBbXSwKICAgICJnZW5lcmljIjogW10KICB9OwogIGZ1bmN0aW9uIHdyYXBwZWROREFycmF5Q3RvcihkYXRhLCBzaGFwZSwgc3RyaWRlLCBvZmZzZXQpIHsKICAgIGlmIChkYXRhID09PSB1bmRlZmluZWQpIHsKICAgICAgdmFyIGN0b3IgPSBDQUNIRURfQ09OU1RSVUNUT1JTLmFycmF5WzBdOwogICAgICByZXR1cm4gY3RvcihbXSk7CiAgICB9IGVsc2UgaWYgKHR5cGVvZiBkYXRhID09PSAibnVtYmVyIikgewogICAgICBkYXRhID0gW2RhdGFdOwogICAgfQogICAgaWYgKHNoYXBlID09PSB1bmRlZmluZWQpIHsKICAgICAgc2hhcGUgPSBbZGF0YS5sZW5ndGhdOwogICAgfQogICAgdmFyIGQgPSBzaGFwZS5sZW5ndGg7CiAgICBpZiAoc3RyaWRlID09PSB1bmRlZmluZWQpIHsKICAgICAgc3RyaWRlID0gbmV3IEFycmF5KGQpOwogICAgICBmb3IgKHZhciBpID0gZCAtIDEsIHN6ID0gMTsgaSA+PSAwOyAtLWkpIHsKICAgICAgICBzdHJpZGVbaV0gPSBzejsKICAgICAgICBzeiAqPSBzaGFwZVtpXTsKICAgICAgfQogICAgfQogICAgaWYgKG9mZnNldCA9PT0gdW5kZWZpbmVkKSB7CiAgICAgIG9mZnNldCA9IDA7CiAgICAgIGZvciAodmFyIGkgPSAwOyBpIDwgZDsgKytpKSB7CiAgICAgICAgaWYgKHN0cmlkZVtpXSA8IDApIHsKICAgICAgICAgIG9mZnNldCAtPSAoc2hhcGVbaV0gLSAxKSAqIHN0cmlkZVtpXTsKICAgICAgICB9CiAgICAgIH0KICAgIH0KICAgIHZhciBkdHlwZSA9IGFycmF5RFR5cGUoZGF0YSk7CiAgICB2YXIgY3Rvcl9saXN0ID0gQ0FDSEVEX0NPTlNUUlVDVE9SU1tkdHlwZV07CiAgICB3aGlsZSAoY3Rvcl9saXN0Lmxlbmd0aCA8PSBkICsgMSkgewogICAgICBjdG9yX2xpc3QucHVzaChjb21waWxlQ29uc3RydWN0b3IoZHR5cGUsIGN0b3JfbGlzdC5sZW5ndGggLSAxKSk7CiAgICB9CiAgICB2YXIgY3RvciA9IGN0b3JfbGlzdFtkICsgMV07CiAgICByZXR1cm4gY3RvcihkYXRhLCBzaGFwZSwgc3RyaWRlLCBvZmZzZXQpOwogIH0KICB2YXIgbmRhcnJheSA9IHdyYXBwZWROREFycmF5Q3RvcjsKCiAgY2xhc3MgTWFydGluaSB7CiAgICBjb25zdHJ1Y3RvcihncmlkU2l6ZSA9IDI1NykgewogICAgICB0aGlzLmdyaWRTaXplID0gZ3JpZFNpemU7CiAgICAgIGNvbnN0IHRpbGVTaXplID0gZ3JpZFNpemUgLSAxOwogICAgICBpZiAodGlsZVNpemUgJiB0aWxlU2l6ZSAtIDEpIHRocm93IG5ldyBFcnJvcihgRXhwZWN0ZWQgZ3JpZCBzaXplIHRvIGJlIDJebisxLCBnb3QgJHtncmlkU2l6ZX0uYCk7CiAgICAgIHRoaXMubnVtVHJpYW5nbGVzID0gdGlsZVNpemUgKiB0aWxlU2l6ZSAqIDIgLSAyOwogICAgICB0aGlzLm51bVBhcmVudFRyaWFuZ2xlcyA9IHRoaXMubnVtVHJpYW5nbGVzIC0gdGlsZVNpemUgKiB0aWxlU2l6ZTsKICAgICAgdGhpcy5pbmRpY2VzID0gbmV3IFVpbnQzMkFycmF5KHRoaXMuZ3JpZFNpemUgKiB0aGlzLmdyaWRTaXplKTsKCiAgICAgIC8vIGNvb3JkaW5hdGVzIGZvciBhbGwgcG9zc2libGUgdHJpYW5nbGVzIGluIGFuIFJUSU4gdGlsZQogICAgICB0aGlzLmNvb3JkcyA9IG5ldyBVaW50MTZBcnJheSh0aGlzLm51bVRyaWFuZ2xlcyAqIDQpOwoKICAgICAgLy8gZ2V0IHRyaWFuZ2xlIGNvb3JkaW5hdGVzIGZyb20gaXRzIGluZGV4IGluIGFuIGltcGxpY2l0IGJpbmFyeSB0cmVlCiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5udW1UcmlhbmdsZXM7IGkrKykgewogICAgICAgIGxldCBpZCA9IGkgKyAyOwogICAgICAgIGxldCBheCA9IDAsCiAgICAgICAgICBheSA9IDAsCiAgICAgICAgICBieCA9IDAsCiAgICAgICAgICBieSA9IDAsCiAgICAgICAgICBjeCA9IDAsCiAgICAgICAgICBjeSA9IDA7CiAgICAgICAgaWYgKGlkICYgMSkgewogICAgICAgICAgYnggPSBieSA9IGN4ID0gdGlsZVNpemU7IC8vIGJvdHRvbS1sZWZ0IHRyaWFuZ2xlCiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgIGF4ID0gYXkgPSBjeSA9IHRpbGVTaXplOyAvLyB0b3AtcmlnaHQgdHJpYW5nbGUKICAgICAgICB9CgogICAgICAgIHdoaWxlICgoaWQgPj49IDEpID4gMSkgewogICAgICAgICAgY29uc3QgbXggPSBheCArIGJ4ID4+IDE7CiAgICAgICAgICBjb25zdCBteSA9IGF5ICsgYnkgPj4gMTsKICAgICAgICAgIGlmIChpZCAmIDEpIHsKICAgICAgICAgICAgLy8gbGVmdCBoYWxmCiAgICAgICAgICAgIGJ4ID0gYXg7CiAgICAgICAgICAgIGJ5ID0gYXk7CiAgICAgICAgICAgIGF4ID0gY3g7CiAgICAgICAgICAgIGF5ID0gY3k7CiAgICAgICAgICB9IGVsc2UgewogICAgICAgICAgICAvLyByaWdodCBoYWxmCiAgICAgICAgICAgIGF4ID0gYng7CiAgICAgICAgICAgIGF5ID0gYnk7CiAgICAgICAgICAgIGJ4ID0gY3g7CiAgICAgICAgICAgIGJ5ID0gY3k7CiAgICAgICAgICB9CiAgICAgICAgICBjeCA9IG14OwogICAgICAgICAgY3kgPSBteTsKICAgICAgICB9CiAgICAgICAgY29uc3QgayA9IGkgKiA0OwogICAgICAgIHRoaXMuY29vcmRzW2sgKyAwXSA9IGF4OwogICAgICAgIHRoaXMuY29vcmRzW2sgKyAxXSA9IGF5OwogICAgICAgIHRoaXMuY29vcmRzW2sgKyAyXSA9IGJ4OwogICAgICAgIHRoaXMuY29vcmRzW2sgKyAzXSA9IGJ5OwogICAgICB9CiAgICB9CiAgICBjcmVhdGVUaWxlKHRlcnJhaW4pIHsKICAgICAgcmV0dXJuIG5ldyBUaWxlKHRlcnJhaW4sIHRoaXMpOwogICAgfQogIH0KICBjbGFzcyBUaWxlIHsKICAgIGNvbnN0cnVjdG9yKHRlcnJhaW4sIG1hcnRpbmkpIHsKICAgICAgY29uc3Qgc2l6ZSA9IG1hcnRpbmkuZ3JpZFNpemU7CiAgICAgIGlmICh0ZXJyYWluLmxlbmd0aCAhPT0gc2l6ZSAqIHNpemUpIHRocm93IG5ldyBFcnJvcihgRXhwZWN0ZWQgdGVycmFpbiBkYXRhIG9mIGxlbmd0aCAke3NpemUgKiBzaXplfSAoJHtzaXplfSB4ICR7c2l6ZX0pLCBnb3QgJHt0ZXJyYWluLmxlbmd0aH0uYCk7CiAgICAgIHRoaXMudGVycmFpbiA9IHRlcnJhaW47CiAgICAgIHRoaXMubWFydGluaSA9IG1hcnRpbmk7CiAgICAgIHRoaXMuZXJyb3JzID0gbmV3IEZsb2F0MzJBcnJheSh0ZXJyYWluLmxlbmd0aCk7CiAgICAgIHRoaXMudXBkYXRlKCk7CiAgICB9CiAgICB1cGRhdGUoKSB7CiAgICAgIGNvbnN0IHsKICAgICAgICBudW1UcmlhbmdsZXMsCiAgICAgICAgbnVtUGFyZW50VHJpYW5nbGVzLAogICAgICAgIGNvb3JkcywKICAgICAgICBncmlkU2l6ZTogc2l6ZQogICAgICB9ID0gdGhpcy5tYXJ0aW5pOwogICAgICBjb25zdCB7CiAgICAgICAgdGVycmFpbiwKICAgICAgICBlcnJvcnMKICAgICAgfSA9IHRoaXM7CgogICAgICAvLyBpdGVyYXRlIG92ZXIgYWxsIHBvc3NpYmxlIHRyaWFuZ2xlcywgc3RhcnRpbmcgZnJvbSB0aGUgc21hbGxlc3QgbGV2ZWwKICAgICAgZm9yIChsZXQgaSA9IG51bVRyaWFuZ2xlcyAtIDE7IGkgPj0gMDsgaS0tKSB7CiAgICAgICAgY29uc3QgayA9IGkgKiA0OwogICAgICAgIGNvbnN0IGF4ID0gY29vcmRzW2sgKyAwXTsKICAgICAgICBjb25zdCBheSA9IGNvb3Jkc1trICsgMV07CiAgICAgICAgY29uc3QgYnggPSBjb29yZHNbayArIDJdOwogICAgICAgIGNvbnN0IGJ5ID0gY29vcmRzW2sgKyAzXTsKICAgICAgICBjb25zdCBteCA9IGF4ICsgYnggPj4gMTsKICAgICAgICBjb25zdCBteSA9IGF5ICsgYnkgPj4gMTsKICAgICAgICBjb25zdCBjeCA9IG14ICsgbXkgLSBheTsKICAgICAgICBjb25zdCBjeSA9IG15ICsgYXggLSBteDsKCiAgICAgICAgLy8gY2FsY3VsYXRlIGVycm9yIGluIHRoZSBtaWRkbGUgb2YgdGhlIGxvbmcgZWRnZSBvZiB0aGUgdHJpYW5nbGUKICAgICAgICBjb25zdCBpbnRlcnBvbGF0ZWRIZWlnaHQgPSAodGVycmFpbltheSAqIHNpemUgKyBheF0gKyB0ZXJyYWluW2J5ICogc2l6ZSArIGJ4XSkgLyAyOwogICAgICAgIGNvbnN0IG1pZGRsZUluZGV4ID0gbXkgKiBzaXplICsgbXg7CiAgICAgICAgY29uc3QgbWlkZGxlRXJyb3IgPSBNYXRoLmFicyhpbnRlcnBvbGF0ZWRIZWlnaHQgLSB0ZXJyYWluW21pZGRsZUluZGV4XSk7CiAgICAgICAgZXJyb3JzW21pZGRsZUluZGV4XSA9IE1hdGgubWF4KGVycm9yc1ttaWRkbGVJbmRleF0sIG1pZGRsZUVycm9yKTsKICAgICAgICBpZiAoaSA8IG51bVBhcmVudFRyaWFuZ2xlcykgewogICAgICAgICAgLy8gYmlnZ2VyIHRyaWFuZ2xlczsgYWNjdW11bGF0ZSBlcnJvciB3aXRoIGNoaWxkcmVuCiAgICAgICAgICBjb25zdCBsZWZ0Q2hpbGRJbmRleCA9IChheSArIGN5ID4+IDEpICogc2l6ZSArIChheCArIGN4ID4+IDEpOwogICAgICAgICAgY29uc3QgcmlnaHRDaGlsZEluZGV4ID0gKGJ5ICsgY3kgPj4gMSkgKiBzaXplICsgKGJ4ICsgY3ggPj4gMSk7CiAgICAgICAgICBlcnJvcnNbbWlkZGxlSW5kZXhdID0gTWF0aC5tYXgoZXJyb3JzW21pZGRsZUluZGV4XSwgZXJyb3JzW2xlZnRDaGlsZEluZGV4XSwgZXJyb3JzW3JpZ2h0Q2hpbGRJbmRleF0pOwogICAgICAgIH0KICAgICAgfQogICAgfQogICAgZ2V0TWVzaChtYXhFcnJvciA9IDAsIG1heExlbmd0aCA9IG51bGwpIHsKICAgICAgY29uc3QgewogICAgICAgIGdyaWRTaXplOiBzaXplLAogICAgICAgIGluZGljZXMKICAgICAgfSA9IHRoaXMubWFydGluaTsKICAgICAgY29uc3QgewogICAgICAgIGVycm9ycwogICAgICB9ID0gdGhpczsKICAgICAgbGV0IG51bVZlcnRpY2VzID0gMDsKICAgICAgbGV0IG51bVRyaWFuZ2xlcyA9IDA7CiAgICAgIGNvbnN0IG1heCA9IHNpemUgLSAxOwoKICAgICAgLy8gVGhlIG1heExlbmd0aCBwYXJhbWV0ZXIgd2lsbCBjYXVzZSB0cmlhbmdsZXMgdG8gYmUgZ2VuZXJhdGVkIHVudGlsIHRoZSBsZWdzIGFyZSBiZWxvdyB0aGlzIGxlbmd0aAogICAgICAvLyBJdCBpcyBtZWFudCB0byBzdXBwb3J0IGNhc2VzIHdoZXJlIGEgY2VydGFpbiBtZXNoIGRlbnNpdHkgaXMgcmVxdWlyZWQgdG8gZG8gc3BoZXJpY2FsIG1hdGggb24gZGlnaXRhbCBnbG9iZXMKICAgICAgY29uc3QgbWF4U2NhbGUgPSBtYXhMZW5ndGggfHwgc2l6ZTsKCiAgICAgIC8vIHVzZSBhbiBpbmRleCBncmlkIHRvIGtlZXAgdHJhY2sgb2YgdmVydGljZXMgdGhhdCB3ZXJlIGFscmVhZHkgdXNlZCB0byBhdm9pZCBkdXBsaWNhdGlvbgogICAgICBpbmRpY2VzLmZpbGwoMCk7CgogICAgICAvLyByZXRyaWV2ZSBtZXNoIGluIHR3byBzdGFnZXMgdGhhdCBib3RoIHRyYXZlcnNlIHRoZSBlcnJvciBtYXA6CiAgICAgIC8vIC0gY291bnRFbGVtZW50czogZmluZCB1c2VkIHZlcnRpY2VzIChhbmQgYXNzaWduIGVhY2ggYW4gaW5kZXgpLCBhbmQgY291bnQgdHJpYW5nbGVzIChmb3IgbWluaW11bSBhbGxvY2F0aW9uKQogICAgICAvLyAtIHByb2Nlc3NUcmlhbmdsZTogZmlsbCB0aGUgYWxsb2NhdGVkIHZlcnRpY2VzICYgdHJpYW5nbGVzIHR5cGVkIGFycmF5cwoKICAgICAgZnVuY3Rpb24gY291bnRFbGVtZW50cyhheCwgYXksIGJ4LCBieSwgY3gsIGN5KSB7CiAgICAgICAgY29uc3QgbXggPSBheCArIGJ4ID4+IDE7CiAgICAgICAgY29uc3QgbXkgPSBheSArIGJ5ID4+IDE7CiAgICAgICAgY29uc3QgbGVnTGVuZ3RoID0gTWF0aC5hYnMoYXggLSBjeCkgKyBNYXRoLmFicyhheSAtIGN5KTsKICAgICAgICBpZiAobGVnTGVuZ3RoID4gMSAmJiBlcnJvcnNbbXkgKiBzaXplICsgbXhdID4gbWF4RXJyb3IgfHwgbGVnTGVuZ3RoID4gbWF4U2NhbGUpIHsKICAgICAgICAgIGNvdW50RWxlbWVudHMoY3gsIGN5LCBheCwgYXksIG14LCBteSk7CiAgICAgICAgICBjb3VudEVsZW1lbnRzKGJ4LCBieSwgY3gsIGN5LCBteCwgbXkpOwogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICBpbmRpY2VzW2F5ICogc2l6ZSArIGF4XSA9IGluZGljZXNbYXkgKiBzaXplICsgYXhdIHx8ICsrbnVtVmVydGljZXM7CiAgICAgICAgICBpbmRpY2VzW2J5ICogc2l6ZSArIGJ4XSA9IGluZGljZXNbYnkgKiBzaXplICsgYnhdIHx8ICsrbnVtVmVydGljZXM7CiAgICAgICAgICBpbmRpY2VzW2N5ICogc2l6ZSArIGN4XSA9IGluZGljZXNbY3kgKiBzaXplICsgY3hdIHx8ICsrbnVtVmVydGljZXM7CiAgICAgICAgICBudW1UcmlhbmdsZXMrKzsKICAgICAgICB9CiAgICAgIH0KICAgICAgY291bnRFbGVtZW50cygwLCAwLCBtYXgsIG1heCwgbWF4LCAwKTsKICAgICAgY291bnRFbGVtZW50cyhtYXgsIG1heCwgMCwgMCwgMCwgbWF4KTsKICAgICAgY29uc3QgdmVydGljZXMgPSBuZXcgVWludDE2QXJyYXkobnVtVmVydGljZXMgKiAyKTsKICAgICAgY29uc3QgdHJpYW5nbGVzID0gbmV3IFVpbnQzMkFycmF5KG51bVRyaWFuZ2xlcyAqIDMpOwogICAgICBsZXQgdHJpSW5kZXggPSAwOwogICAgICBmdW5jdGlvbiBwcm9jZXNzVHJpYW5nbGUoYXgsIGF5LCBieCwgYnksIGN4LCBjeSkgewogICAgICAgIGNvbnN0IG14ID0gYXggKyBieCA+PiAxOwogICAgICAgIGNvbnN0IG15ID0gYXkgKyBieSA+PiAxOwogICAgICAgIGNvbnN0IGxlZ0xlbmd0aCA9IE1hdGguYWJzKGF4IC0gY3gpICsgTWF0aC5hYnMoYXkgLSBjeSk7CiAgICAgICAgaWYgKGxlZ0xlbmd0aCA+IDEgJiYgZXJyb3JzW215ICogc2l6ZSArIG14XSA+IG1heEVycm9yIHx8IGxlZ0xlbmd0aCA+IG1heFNjYWxlKSB7CiAgICAgICAgICAvLyB0cmlhbmdsZSBkb2Vzbid0IGFwcHJveGltYXRlIHRoZSBzdXJmYWNlIHdlbGwgZW5vdWdoOyBkcmlsbCBkb3duIGZ1cnRoZXIKICAgICAgICAgIHByb2Nlc3NUcmlhbmdsZShjeCwgY3ksIGF4LCBheSwgbXgsIG15KTsKICAgICAgICAgIHByb2Nlc3NUcmlhbmdsZShieCwgYnksIGN4LCBjeSwgbXgsIG15KTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgLy8gYWRkIGEgdHJpYW5nbGUKICAgICAgICAgIGNvbnN0IGEgPSBpbmRpY2VzW2F5ICogc2l6ZSArIGF4XSAtIDE7CiAgICAgICAgICBjb25zdCBiID0gaW5kaWNlc1tieSAqIHNpemUgKyBieF0gLSAxOwogICAgICAgICAgY29uc3QgYyA9IGluZGljZXNbY3kgKiBzaXplICsgY3hdIC0gMTsKICAgICAgICAgIHZlcnRpY2VzWzIgKiBhXSA9IGF4OwogICAgICAgICAgdmVydGljZXNbMiAqIGEgKyAxXSA9IGF5OwogICAgICAgICAgdmVydGljZXNbMiAqIGJdID0gYng7CiAgICAgICAgICB2ZXJ0aWNlc1syICogYiArIDFdID0gYnk7CiAgICAgICAgICB2ZXJ0aWNlc1syICogY10gPSBjeDsKICAgICAgICAgIHZlcnRpY2VzWzIgKiBjICsgMV0gPSBjeTsKICAgICAgICAgIHRyaWFuZ2xlc1t0cmlJbmRleCsrXSA9IGE7CiAgICAgICAgICB0cmlhbmdsZXNbdHJpSW5kZXgrK10gPSBiOwogICAgICAgICAgdHJpYW5nbGVzW3RyaUluZGV4KytdID0gYzsKICAgICAgICB9CiAgICAgIH0KICAgICAgcHJvY2Vzc1RyaWFuZ2xlKDAsIDAsIG1heCwgbWF4LCBtYXgsIDApOwogICAgICBwcm9jZXNzVHJpYW5nbGUobWF4LCBtYXgsIDAsIDAsIDAsIG1heCk7CiAgICAgIHJldHVybiB7CiAgICAgICAgdmVydGljZXMsCiAgICAgICAgdHJpYW5nbGVzCiAgICAgIH07CiAgICB9CiAgfQoKICAvLyBodHRwczovL2dpdGh1Yi5jb20vQ2VzaXVtR1MvY2VzaXVtL2Jsb2IvMS43Ni9Tb3VyY2UvV29ya2Vyc0VTNi9jcmVhdGVWZXJ0aWNlc0Zyb21RdWFudGl6ZWRUZXJyYWluTWVzaC5qcwoKICB2YXIgbWFydGluaSA9IG51bGw7CiAgZnVuY3Rpb24gZGVjb2RlVGVycmFpbihwYXJhbWV0ZXJzLCB0cmFuc2ZlcmFibGVPYmplY3RzKSB7CiAgICB2YXIgX21hcnRpbmk7CiAgICB2YXIgaW1hZ2VEYXRhID0gcGFyYW1ldGVycy5pbWFnZURhdGEsCiAgICAgIF9wYXJhbWV0ZXJzJHRpbGVTaXplID0gcGFyYW1ldGVycy50aWxlU2l6ZSwKICAgICAgdGlsZVNpemUgPSBfcGFyYW1ldGVycyR0aWxlU2l6ZSA9PT0gdm9pZCAwID8gMjU2IDogX3BhcmFtZXRlcnMkdGlsZVNpemUsCiAgICAgIGVycm9yTGV2ZWwgPSBwYXJhbWV0ZXJzLmVycm9yTGV2ZWwsCiAgICAgIGludGVydmFsID0gcGFyYW1ldGVycy5pbnRlcnZhbCwKICAgICAgb2Zmc2V0ID0gcGFyYW1ldGVycy5vZmZzZXQ7CiAgICB2YXIgcGl4ZWxzID0gbmRhcnJheShuZXcgVWludDhBcnJheShpbWFnZURhdGEpLCBbdGlsZVNpemUsIHRpbGVTaXplLCA0XSwgWzQsIDQgKiB0aWxlU2l6ZSwgMV0sIDApOwoKICAgIC8vIFRpbGUgc2l6ZSBtdXN0IGJlIG1haW50YWluZWQgdGhyb3VnaCB0aGUgbGlmZSBvZiB0aGUgd29ya2VyCiAgICAoX21hcnRpbmkgPSBtYXJ0aW5pKSAhPT0gbnVsbCAmJiBfbWFydGluaSAhPT0gdm9pZCAwID8gX21hcnRpbmkgOiBtYXJ0aW5pID0gbmV3IE1hcnRpbmkodGlsZVNpemUgKyAxKTsKICAgIHZhciB0ZXJyYWluID0gbWFwYm94VGVycmFpblRvR3JpZChwaXhlbHMsIGludGVydmFsLCBvZmZzZXQpOwogICAgdmFyIHRpbGUgPSBtYXJ0aW5pLmNyZWF0ZVRpbGUodGVycmFpbik7CgogICAgLy8gZ2V0IGEgbWVzaCAodmVydGljZXMgYW5kIHRyaWFuZ2xlcyBpbmRpY2VzKSBmb3IgYSAxMG0gZXJyb3IKICAgIHZhciBtZXNoID0gdGlsZS5nZXRNZXNoKGVycm9yTGV2ZWwsIHBhcmFtZXRlcnMubWF4TGVuZ3RoKTsKICAgIHJldHVybiBjcmVhdGVRdWFudGl6ZWRNZXNoRGF0YSh0aWxlLCBtZXNoLCB0aWxlU2l6ZSk7CiAgfQogIHNlbGYub25tZXNzYWdlID0gZnVuY3Rpb24gKG1zZykgewogICAgdmFyIF9tc2ckZGF0YSA9IG1zZy5kYXRhLAogICAgICBpZCA9IF9tc2ckZGF0YS5pZCwKICAgICAgcGF5bG9hZCA9IF9tc2ckZGF0YS5wYXlsb2FkOwogICAgaWYgKGlkID09IG51bGwpIHJldHVybjsKICAgIHZhciBvYmplY3RzID0gW107CiAgICB2YXIgcmVzID0gbnVsbDsKICAgIHRyeSB7CiAgICAgIHJlcyA9IGRlY29kZVRlcnJhaW4ocGF5bG9hZCk7CiAgICAgIG9iamVjdHMucHVzaChyZXMuaW5kaWNlcy5idWZmZXIpOwogICAgICBvYmplY3RzLnB1c2gocmVzLnF1YW50aXplZFZlcnRpY2VzLmJ1ZmZlcik7CiAgICAgIHNlbGYucG9zdE1lc3NhZ2UoewogICAgICAgIGlkOiBpZCwKICAgICAgICBwYXlsb2FkOiByZXMKICAgICAgfSwgb2JqZWN0cyk7CiAgICB9IGNhdGNoIChlcnIpIHsKICAgICAgc2VsZi5wb3N0TWVzc2FnZSh7CiAgICAgICAgaWQ6IGlkLAogICAgICAgIGVycjogZXJyLnRvU3RyaW5nKCkKICAgICAgfSk7CiAgICB9IGZpbmFsbHkgewogICAgICByZXMgPSBudWxsOwogICAgICBvYmplY3RzID0gbnVsbDsKICAgIH0KICB9OwoKICBleHBvcnRzLmRlY29kZVRlcnJhaW4gPSBkZWNvZGVUZXJyYWluOwoKICBPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgJ19fZXNNb2R1bGUnLCB7IHZhbHVlOiB0cnVlIH0pOwoKICByZXR1cm4gZXhwb3J0czsKCn0pKHt9KTsKCg==', null, false);
|
|
475
705
|
/* eslint-enable */
|
|
476
706
|
|
|
477
707
|
var resolves = {};
|
|
478
708
|
var rejects = {};
|
|
479
709
|
var globalMsgId = 0; // Activate calculation in the worker, returning a promise
|
|
480
|
-
|
|
481
710
|
function sendMessage(_x, _x2, _x3) {
|
|
482
711
|
return _sendMessage.apply(this, arguments);
|
|
483
712
|
} // Handle incoming calculation result
|
|
484
|
-
|
|
485
|
-
|
|
486
713
|
function _sendMessage() {
|
|
487
|
-
_sendMessage = _asyncToGenerator( /*#__PURE__*/
|
|
714
|
+
_sendMessage = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(worker, payload, transferableObjects) {
|
|
488
715
|
var msgId, msg;
|
|
489
|
-
return
|
|
490
|
-
while (1) {
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
case "end":
|
|
507
|
-
return _context2.stop();
|
|
508
|
-
}
|
|
716
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
717
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
718
|
+
case 0:
|
|
719
|
+
msgId = globalMsgId++;
|
|
720
|
+
msg = {
|
|
721
|
+
id: msgId,
|
|
722
|
+
payload: payload
|
|
723
|
+
};
|
|
724
|
+
return _context2.abrupt("return", new Promise(function (resolve, reject) {
|
|
725
|
+
// save callbacks for later
|
|
726
|
+
resolves[msgId] = resolve;
|
|
727
|
+
rejects[msgId] = reject;
|
|
728
|
+
worker.postMessage(msg, transferableObjects);
|
|
729
|
+
}));
|
|
730
|
+
case 3:
|
|
731
|
+
case "end":
|
|
732
|
+
return _context2.stop();
|
|
509
733
|
}
|
|
510
734
|
}, _callee2);
|
|
511
735
|
}));
|
|
512
736
|
return _sendMessage.apply(this, arguments);
|
|
513
737
|
}
|
|
514
|
-
|
|
515
738
|
function handleMessage(msg) {
|
|
516
739
|
var _msg$data = msg.data,
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
740
|
+
id = _msg$data.id,
|
|
741
|
+
err = _msg$data.err,
|
|
742
|
+
payload = _msg$data.payload;
|
|
521
743
|
if (payload) {
|
|
522
744
|
var resolve = resolves[id];
|
|
523
|
-
|
|
524
745
|
if (resolve) {
|
|
525
746
|
resolve(payload);
|
|
526
747
|
}
|
|
527
748
|
} else {
|
|
528
749
|
// error condition
|
|
529
750
|
var reject = rejects[id];
|
|
530
|
-
|
|
531
751
|
if (reject) {
|
|
532
752
|
if (err) {
|
|
533
753
|
reject(err);
|
|
@@ -535,70 +755,59 @@ function handleMessage(msg) {
|
|
|
535
755
|
reject("Got nothing");
|
|
536
756
|
}
|
|
537
757
|
}
|
|
538
|
-
}
|
|
539
|
-
|
|
758
|
+
}
|
|
540
759
|
|
|
760
|
+
// purge used callbacks
|
|
541
761
|
delete resolves[id];
|
|
542
762
|
delete rejects[id];
|
|
543
763
|
}
|
|
544
|
-
|
|
545
764
|
var WorkerFarm = /*#__PURE__*/function () {
|
|
546
765
|
function WorkerFarm() {
|
|
547
766
|
_classCallCheck(this, WorkerFarm);
|
|
548
|
-
|
|
549
|
-
_defineProperty(this, "worker", void 0);
|
|
550
|
-
|
|
551
767
|
this.worker = new WorkerFactory();
|
|
552
768
|
this.worker.onmessage = handleMessage;
|
|
553
769
|
}
|
|
554
|
-
|
|
555
770
|
_createClass(WorkerFarm, [{
|
|
556
771
|
key: "scheduleTask",
|
|
557
772
|
value: function () {
|
|
558
|
-
var _scheduleTask = _asyncToGenerator( /*#__PURE__*/
|
|
559
|
-
return
|
|
560
|
-
while (1) {
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
case 3:
|
|
570
|
-
case "end":
|
|
571
|
-
return _context.stop();
|
|
572
|
-
}
|
|
773
|
+
var _scheduleTask = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(params, transferableObjects) {
|
|
774
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
775
|
+
while (1) switch (_context.prev = _context.next) {
|
|
776
|
+
case 0:
|
|
777
|
+
_context.next = 2;
|
|
778
|
+
return sendMessage(this.worker, params, transferableObjects);
|
|
779
|
+
case 2:
|
|
780
|
+
return _context.abrupt("return", _context.sent);
|
|
781
|
+
case 3:
|
|
782
|
+
case "end":
|
|
783
|
+
return _context.stop();
|
|
573
784
|
}
|
|
574
785
|
}, _callee, this);
|
|
575
786
|
}));
|
|
576
|
-
|
|
577
787
|
function scheduleTask(_x4, _x5) {
|
|
578
788
|
return _scheduleTask.apply(this, arguments);
|
|
579
789
|
}
|
|
580
|
-
|
|
581
790
|
return scheduleTask;
|
|
582
791
|
}()
|
|
583
792
|
}]);
|
|
584
|
-
|
|
585
793
|
return WorkerFarm;
|
|
586
794
|
}();
|
|
587
795
|
|
|
588
796
|
// We should save these
|
|
589
797
|
//const canvas = new OffscreenCanvas(256, 256);
|
|
590
798
|
//const ctx = canvas.getContext("2d");
|
|
799
|
+
|
|
591
800
|
function mapboxTerrainToGrid(png, interval, offset) {
|
|
592
801
|
var _interval, _offset;
|
|
593
|
-
|
|
594
802
|
// maybe we should do this on the GPU using REGL?
|
|
595
803
|
// but that would require GPU -> CPU -> GPU
|
|
596
804
|
var gridSize = png.shape[0] + 1;
|
|
597
805
|
var terrain = new Float32Array(gridSize * gridSize);
|
|
598
806
|
var tileSize = png.shape[0];
|
|
599
807
|
interval = (_interval = interval) !== null && _interval !== void 0 ? _interval : 0.1;
|
|
600
|
-
offset = (_offset = offset) !== null && _offset !== void 0 ? _offset : -10000;
|
|
808
|
+
offset = (_offset = offset) !== null && _offset !== void 0 ? _offset : -10000;
|
|
601
809
|
|
|
810
|
+
// decode terrain values
|
|
602
811
|
for (var y = 0; y < tileSize; y++) {
|
|
603
812
|
for (var x = 0; x < tileSize; x++) {
|
|
604
813
|
var yc = y;
|
|
@@ -607,20 +816,16 @@ function mapboxTerrainToGrid(png, interval, offset) {
|
|
|
607
816
|
var b = png.get(x, yc, 2);
|
|
608
817
|
terrain[y * gridSize + x] = r * 256 * 256 * interval + g * 256.0 * interval + b * interval + offset;
|
|
609
818
|
}
|
|
610
|
-
}
|
|
611
|
-
|
|
612
|
-
|
|
819
|
+
}
|
|
820
|
+
// backfill right and bottom borders
|
|
613
821
|
for (var _x = 0; _x < gridSize - 1; _x++) {
|
|
614
822
|
terrain[gridSize * (gridSize - 1) + _x] = terrain[gridSize * (gridSize - 2) + _x];
|
|
615
823
|
}
|
|
616
|
-
|
|
617
824
|
for (var _y = 0; _y < gridSize; _y++) {
|
|
618
825
|
terrain[gridSize * _y + gridSize - 1] = terrain[gridSize * _y + gridSize - 2];
|
|
619
826
|
}
|
|
620
|
-
|
|
621
827
|
return terrain;
|
|
622
828
|
}
|
|
623
|
-
|
|
624
829
|
function _emptyMesh(n) {
|
|
625
830
|
n = Math.max(n, 2);
|
|
626
831
|
var nTriangles = Math.pow(n - 1, 2) * 2;
|
|
@@ -632,12 +837,9 @@ function _emptyMesh(n) {
|
|
|
632
837
|
var eastIndices = [];
|
|
633
838
|
var northIndices = [];
|
|
634
839
|
var tix = 0;
|
|
635
|
-
|
|
636
840
|
for (var i = 0; i < nVertices; i++) {
|
|
637
841
|
var rx = i % n; //* 32767) / (n - 1);
|
|
638
|
-
|
|
639
842
|
var ry = Math.floor(i / n); //* 32767) / (n - 1);
|
|
640
|
-
|
|
641
843
|
var ix = n * rx + ry;
|
|
642
844
|
quantizedVertices[ix] = rx * 32768 / (n - 1);
|
|
643
845
|
quantizedVertices[nVertices + ix] = ry * 32768 / (n - 1);
|
|
@@ -645,17 +847,16 @@ function _emptyMesh(n) {
|
|
|
645
847
|
if (ry == 0) westIndices.push(ix);
|
|
646
848
|
if (rx == 0) southIndices.push(ix);
|
|
647
849
|
if (rx == n - 1) eastIndices.push(ix);
|
|
648
|
-
if (ry == n - 1) northIndices.push(ix);
|
|
850
|
+
if (ry == n - 1) northIndices.push(ix);
|
|
649
851
|
|
|
852
|
+
// Add triangles
|
|
650
853
|
var rix = i - ry * n;
|
|
651
|
-
|
|
652
854
|
if (rix != n - 1) {
|
|
653
855
|
indices[tix * 3] = i;
|
|
654
856
|
indices[tix * 3 + 1] = i + n + 1;
|
|
655
857
|
indices[tix * 3 + 2] = i + 1;
|
|
656
858
|
tix++;
|
|
657
859
|
}
|
|
658
|
-
|
|
659
860
|
if (rix != 0) {
|
|
660
861
|
indices[tix * 3] = i - 1;
|
|
661
862
|
indices[tix * 3 + 1] = i + n - 1;
|
|
@@ -663,7 +864,6 @@ function _emptyMesh(n) {
|
|
|
663
864
|
tix++;
|
|
664
865
|
}
|
|
665
866
|
}
|
|
666
|
-
|
|
667
867
|
return {
|
|
668
868
|
minimumHeight: 0,
|
|
669
869
|
maximumHeight: 0,
|
|
@@ -675,7 +875,6 @@ function _emptyMesh(n) {
|
|
|
675
875
|
northIndices: northIndices
|
|
676
876
|
};
|
|
677
877
|
}
|
|
678
|
-
|
|
679
878
|
var _meshCache = [];
|
|
680
879
|
function emptyMesh(n) {
|
|
681
880
|
// A memoized function to return empty meshes
|
|
@@ -683,12 +882,10 @@ function emptyMesh(n) {
|
|
|
683
882
|
return _meshCache[n];
|
|
684
883
|
} else {
|
|
685
884
|
var result = _emptyMesh(n);
|
|
686
|
-
|
|
687
885
|
_meshCache[n] = result;
|
|
688
886
|
return result;
|
|
689
887
|
}
|
|
690
888
|
}
|
|
691
|
-
|
|
692
889
|
function createQuantizedMeshData(tile, mesh, tileSize) {
|
|
693
890
|
var xvals = [];
|
|
694
891
|
var yvals = [];
|
|
@@ -700,7 +897,6 @@ function createQuantizedMeshData(tile, mesh, tileSize) {
|
|
|
700
897
|
var minimumHeight = Infinity;
|
|
701
898
|
var maximumHeight = -Infinity;
|
|
702
899
|
var scalar = 32768.0 / tileSize;
|
|
703
|
-
|
|
704
900
|
for (var ix = 0; ix < mesh.vertices.length / 2; ix++) {
|
|
705
901
|
var vertexIx = ix;
|
|
706
902
|
var px = mesh.vertices[ix * 2];
|
|
@@ -718,7 +914,6 @@ function createQuantizedMeshData(tile, mesh, tileSize) {
|
|
|
718
914
|
xvals.push(xv);
|
|
719
915
|
yvals.push(yv);
|
|
720
916
|
}
|
|
721
|
-
|
|
722
917
|
var heightRange = maximumHeight - minimumHeight;
|
|
723
918
|
var heights = heightMeters.map(function (d) {
|
|
724
919
|
if (heightRange < 1) return 0;
|
|
@@ -726,7 +921,9 @@ function createQuantizedMeshData(tile, mesh, tileSize) {
|
|
|
726
921
|
});
|
|
727
922
|
var triangles = new Uint16Array(mesh.triangles);
|
|
728
923
|
var quantizedVertices = new Uint16Array( //verts
|
|
729
|
-
[].concat(xvals, yvals, _toConsumableArray(heights)));
|
|
924
|
+
[].concat(xvals, yvals, _toConsumableArray(heights)));
|
|
925
|
+
|
|
926
|
+
// SE NW NE
|
|
730
927
|
// NE NW SE
|
|
731
928
|
|
|
732
929
|
return {
|
|
@@ -741,441 +938,63 @@ function createQuantizedMeshData(tile, mesh, tileSize) {
|
|
|
741
938
|
};
|
|
742
939
|
}
|
|
743
940
|
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
var iota_1 = iota;
|
|
753
|
-
|
|
754
|
-
/*!
|
|
755
|
-
* Determine if an object is a Buffer
|
|
756
|
-
*
|
|
757
|
-
* @author Feross Aboukhadijeh <https://feross.org>
|
|
758
|
-
* @license MIT
|
|
759
|
-
*/
|
|
760
|
-
// The _isBuffer check is for Safari 5-7 support, because it's missing
|
|
761
|
-
// Object.prototype.constructor. Remove this eventually
|
|
762
|
-
var isBuffer_1 = function (obj) {
|
|
763
|
-
return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer)
|
|
764
|
-
};
|
|
765
|
-
|
|
766
|
-
function isBuffer (obj) {
|
|
767
|
-
return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)
|
|
768
|
-
}
|
|
769
|
-
|
|
770
|
-
// For Node v0.10 support. Remove this eventually.
|
|
771
|
-
function isSlowBuffer (obj) {
|
|
772
|
-
return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0))
|
|
773
|
-
}
|
|
941
|
+
class Martini {
|
|
942
|
+
constructor(gridSize = 257) {
|
|
943
|
+
this.gridSize = gridSize;
|
|
944
|
+
const tileSize = gridSize - 1;
|
|
945
|
+
if (tileSize & tileSize - 1) throw new Error(`Expected grid size to be 2^n+1, got ${gridSize}.`);
|
|
946
|
+
this.numTriangles = tileSize * tileSize * 2 - 2;
|
|
947
|
+
this.numParentTriangles = this.numTriangles - tileSize * tileSize;
|
|
948
|
+
this.indices = new Uint32Array(this.gridSize * this.gridSize);
|
|
774
949
|
|
|
775
|
-
|
|
950
|
+
// coordinates for all possible triangles in an RTIN tile
|
|
951
|
+
this.coords = new Uint16Array(this.numTriangles * 4);
|
|
776
952
|
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
953
|
+
// get triangle coordinates from its index in an implicit binary tree
|
|
954
|
+
for (let i = 0; i < this.numTriangles; i++) {
|
|
955
|
+
let id = i + 2;
|
|
956
|
+
let ax = 0,
|
|
957
|
+
ay = 0,
|
|
958
|
+
bx = 0,
|
|
959
|
+
by = 0,
|
|
960
|
+
cx = 0,
|
|
961
|
+
cy = 0;
|
|
962
|
+
if (id & 1) {
|
|
963
|
+
bx = by = cx = tileSize; // bottom-left triangle
|
|
964
|
+
} else {
|
|
965
|
+
ax = ay = cy = tileSize; // top-right triangle
|
|
966
|
+
}
|
|
780
967
|
|
|
781
|
-
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
968
|
+
while ((id >>= 1) > 1) {
|
|
969
|
+
const mx = ax + bx >> 1;
|
|
970
|
+
const my = ay + by >> 1;
|
|
971
|
+
if (id & 1) {
|
|
972
|
+
// left half
|
|
973
|
+
bx = ax;
|
|
974
|
+
by = ay;
|
|
975
|
+
ax = cx;
|
|
976
|
+
ay = cy;
|
|
977
|
+
} else {
|
|
978
|
+
// right half
|
|
979
|
+
ax = bx;
|
|
980
|
+
ay = by;
|
|
981
|
+
bx = cx;
|
|
982
|
+
by = cy;
|
|
983
|
+
}
|
|
984
|
+
cx = mx;
|
|
985
|
+
cy = my;
|
|
986
|
+
}
|
|
987
|
+
const k = i * 4;
|
|
988
|
+
this.coords[k + 0] = ax;
|
|
989
|
+
this.coords[k + 1] = ay;
|
|
990
|
+
this.coords[k + 2] = bx;
|
|
991
|
+
this.coords[k + 3] = by;
|
|
992
|
+
}
|
|
787
993
|
}
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
for(i=0; i<result.length; ++i) {
|
|
791
|
-
result[i] = terms[i][1];
|
|
994
|
+
createTile(terrain) {
|
|
995
|
+
return new Tile(terrain, this);
|
|
792
996
|
}
|
|
793
|
-
return result
|
|
794
997
|
}
|
|
795
|
-
|
|
796
|
-
function compileConstructor(dtype, dimension) {
|
|
797
|
-
var className = ["View", dimension, "d", dtype].join("");
|
|
798
|
-
if(dimension < 0) {
|
|
799
|
-
className = "View_Nil" + dtype;
|
|
800
|
-
}
|
|
801
|
-
var useGetters = (dtype === "generic");
|
|
802
|
-
|
|
803
|
-
if(dimension === -1) {
|
|
804
|
-
//Special case for trivial arrays
|
|
805
|
-
var code =
|
|
806
|
-
"function "+className+"(a){this.data=a;};\
|
|
807
|
-
var proto="+className+".prototype;\
|
|
808
|
-
proto.dtype='"+dtype+"';\
|
|
809
|
-
proto.index=function(){return -1};\
|
|
810
|
-
proto.size=0;\
|
|
811
|
-
proto.dimension=-1;\
|
|
812
|
-
proto.shape=proto.stride=proto.order=[];\
|
|
813
|
-
proto.lo=proto.hi=proto.transpose=proto.step=\
|
|
814
|
-
function(){return new "+className+"(this.data);};\
|
|
815
|
-
proto.get=proto.set=function(){};\
|
|
816
|
-
proto.pick=function(){return null};\
|
|
817
|
-
return function construct_"+className+"(a){return new "+className+"(a);}";
|
|
818
|
-
var procedure = new Function(code);
|
|
819
|
-
return procedure()
|
|
820
|
-
} else if(dimension === 0) {
|
|
821
|
-
//Special case for 0d arrays
|
|
822
|
-
var code =
|
|
823
|
-
"function "+className+"(a,d) {\
|
|
824
|
-
this.data = a;\
|
|
825
|
-
this.offset = d\
|
|
826
|
-
};\
|
|
827
|
-
var proto="+className+".prototype;\
|
|
828
|
-
proto.dtype='"+dtype+"';\
|
|
829
|
-
proto.index=function(){return this.offset};\
|
|
830
|
-
proto.dimension=0;\
|
|
831
|
-
proto.size=1;\
|
|
832
|
-
proto.shape=\
|
|
833
|
-
proto.stride=\
|
|
834
|
-
proto.order=[];\
|
|
835
|
-
proto.lo=\
|
|
836
|
-
proto.hi=\
|
|
837
|
-
proto.transpose=\
|
|
838
|
-
proto.step=function "+className+"_copy() {\
|
|
839
|
-
return new "+className+"(this.data,this.offset)\
|
|
840
|
-
};\
|
|
841
|
-
proto.pick=function "+className+"_pick(){\
|
|
842
|
-
return TrivialArray(this.data);\
|
|
843
|
-
};\
|
|
844
|
-
proto.valueOf=proto.get=function "+className+"_get(){\
|
|
845
|
-
return "+(useGetters ? "this.data.get(this.offset)" : "this.data[this.offset]")+
|
|
846
|
-
"};\
|
|
847
|
-
proto.set=function "+className+"_set(v){\
|
|
848
|
-
return "+(useGetters ? "this.data.set(this.offset,v)" : "this.data[this.offset]=v")+"\
|
|
849
|
-
};\
|
|
850
|
-
return function construct_"+className+"(a,b,c,d){return new "+className+"(a,d)}";
|
|
851
|
-
var procedure = new Function("TrivialArray", code);
|
|
852
|
-
return procedure(CACHED_CONSTRUCTORS[dtype][0])
|
|
853
|
-
}
|
|
854
|
-
|
|
855
|
-
var code = ["'use strict'"];
|
|
856
|
-
|
|
857
|
-
//Create constructor for view
|
|
858
|
-
var indices = iota_1(dimension);
|
|
859
|
-
var args = indices.map(function(i) { return "i"+i });
|
|
860
|
-
var index_str = "this.offset+" + indices.map(function(i) {
|
|
861
|
-
return "this.stride[" + i + "]*i" + i
|
|
862
|
-
}).join("+");
|
|
863
|
-
var shapeArg = indices.map(function(i) {
|
|
864
|
-
return "b"+i
|
|
865
|
-
}).join(",");
|
|
866
|
-
var strideArg = indices.map(function(i) {
|
|
867
|
-
return "c"+i
|
|
868
|
-
}).join(",");
|
|
869
|
-
code.push(
|
|
870
|
-
"function "+className+"(a," + shapeArg + "," + strideArg + ",d){this.data=a",
|
|
871
|
-
"this.shape=[" + shapeArg + "]",
|
|
872
|
-
"this.stride=[" + strideArg + "]",
|
|
873
|
-
"this.offset=d|0}",
|
|
874
|
-
"var proto="+className+".prototype",
|
|
875
|
-
"proto.dtype='"+dtype+"'",
|
|
876
|
-
"proto.dimension="+dimension);
|
|
877
|
-
|
|
878
|
-
//view.size:
|
|
879
|
-
code.push("Object.defineProperty(proto,'size',{get:function "+className+"_size(){\
|
|
880
|
-
return "+indices.map(function(i) { return "this.shape["+i+"]" }).join("*"),
|
|
881
|
-
"}})");
|
|
882
|
-
|
|
883
|
-
//view.order:
|
|
884
|
-
if(dimension === 1) {
|
|
885
|
-
code.push("proto.order=[0]");
|
|
886
|
-
} else {
|
|
887
|
-
code.push("Object.defineProperty(proto,'order',{get:");
|
|
888
|
-
if(dimension < 4) {
|
|
889
|
-
code.push("function "+className+"_order(){");
|
|
890
|
-
if(dimension === 2) {
|
|
891
|
-
code.push("return (Math.abs(this.stride[0])>Math.abs(this.stride[1]))?[1,0]:[0,1]}})");
|
|
892
|
-
} else if(dimension === 3) {
|
|
893
|
-
code.push(
|
|
894
|
-
"var s0=Math.abs(this.stride[0]),s1=Math.abs(this.stride[1]),s2=Math.abs(this.stride[2]);\
|
|
895
|
-
if(s0>s1){\
|
|
896
|
-
if(s1>s2){\
|
|
897
|
-
return [2,1,0];\
|
|
898
|
-
}else if(s0>s2){\
|
|
899
|
-
return [1,2,0];\
|
|
900
|
-
}else{\
|
|
901
|
-
return [1,0,2];\
|
|
902
|
-
}\
|
|
903
|
-
}else if(s0>s2){\
|
|
904
|
-
return [2,0,1];\
|
|
905
|
-
}else if(s2>s1){\
|
|
906
|
-
return [0,1,2];\
|
|
907
|
-
}else{\
|
|
908
|
-
return [0,2,1];\
|
|
909
|
-
}}})");
|
|
910
|
-
}
|
|
911
|
-
} else {
|
|
912
|
-
code.push("ORDER})");
|
|
913
|
-
}
|
|
914
|
-
}
|
|
915
|
-
|
|
916
|
-
//view.set(i0, ..., v):
|
|
917
|
-
code.push(
|
|
918
|
-
"proto.set=function "+className+"_set("+args.join(",")+",v){");
|
|
919
|
-
if(useGetters) {
|
|
920
|
-
code.push("return this.data.set("+index_str+",v)}");
|
|
921
|
-
} else {
|
|
922
|
-
code.push("return this.data["+index_str+"]=v}");
|
|
923
|
-
}
|
|
924
|
-
|
|
925
|
-
//view.get(i0, ...):
|
|
926
|
-
code.push("proto.get=function "+className+"_get("+args.join(",")+"){");
|
|
927
|
-
if(useGetters) {
|
|
928
|
-
code.push("return this.data.get("+index_str+")}");
|
|
929
|
-
} else {
|
|
930
|
-
code.push("return this.data["+index_str+"]}");
|
|
931
|
-
}
|
|
932
|
-
|
|
933
|
-
//view.index:
|
|
934
|
-
code.push(
|
|
935
|
-
"proto.index=function "+className+"_index(", args.join(), "){return "+index_str+"}");
|
|
936
|
-
|
|
937
|
-
//view.hi():
|
|
938
|
-
code.push("proto.hi=function "+className+"_hi("+args.join(",")+"){return new "+className+"(this.data,"+
|
|
939
|
-
indices.map(function(i) {
|
|
940
|
-
return ["(typeof i",i,"!=='number'||i",i,"<0)?this.shape[", i, "]:i", i,"|0"].join("")
|
|
941
|
-
}).join(",")+","+
|
|
942
|
-
indices.map(function(i) {
|
|
943
|
-
return "this.stride["+i + "]"
|
|
944
|
-
}).join(",")+",this.offset)}");
|
|
945
|
-
|
|
946
|
-
//view.lo():
|
|
947
|
-
var a_vars = indices.map(function(i) { return "a"+i+"=this.shape["+i+"]" });
|
|
948
|
-
var c_vars = indices.map(function(i) { return "c"+i+"=this.stride["+i+"]" });
|
|
949
|
-
code.push("proto.lo=function "+className+"_lo("+args.join(",")+"){var b=this.offset,d=0,"+a_vars.join(",")+","+c_vars.join(","));
|
|
950
|
-
for(var i=0; i<dimension; ++i) {
|
|
951
|
-
code.push(
|
|
952
|
-
"if(typeof i"+i+"==='number'&&i"+i+">=0){\
|
|
953
|
-
d=i"+i+"|0;\
|
|
954
|
-
b+=c"+i+"*d;\
|
|
955
|
-
a"+i+"-=d}");
|
|
956
|
-
}
|
|
957
|
-
code.push("return new "+className+"(this.data,"+
|
|
958
|
-
indices.map(function(i) {
|
|
959
|
-
return "a"+i
|
|
960
|
-
}).join(",")+","+
|
|
961
|
-
indices.map(function(i) {
|
|
962
|
-
return "c"+i
|
|
963
|
-
}).join(",")+",b)}");
|
|
964
|
-
|
|
965
|
-
//view.step():
|
|
966
|
-
code.push("proto.step=function "+className+"_step("+args.join(",")+"){var "+
|
|
967
|
-
indices.map(function(i) {
|
|
968
|
-
return "a"+i+"=this.shape["+i+"]"
|
|
969
|
-
}).join(",")+","+
|
|
970
|
-
indices.map(function(i) {
|
|
971
|
-
return "b"+i+"=this.stride["+i+"]"
|
|
972
|
-
}).join(",")+",c=this.offset,d=0,ceil=Math.ceil");
|
|
973
|
-
for(var i=0; i<dimension; ++i) {
|
|
974
|
-
code.push(
|
|
975
|
-
"if(typeof i"+i+"==='number'){\
|
|
976
|
-
d=i"+i+"|0;\
|
|
977
|
-
if(d<0){\
|
|
978
|
-
c+=b"+i+"*(a"+i+"-1);\
|
|
979
|
-
a"+i+"=ceil(-a"+i+"/d)\
|
|
980
|
-
}else{\
|
|
981
|
-
a"+i+"=ceil(a"+i+"/d)\
|
|
982
|
-
}\
|
|
983
|
-
b"+i+"*=d\
|
|
984
|
-
}");
|
|
985
|
-
}
|
|
986
|
-
code.push("return new "+className+"(this.data,"+
|
|
987
|
-
indices.map(function(i) {
|
|
988
|
-
return "a" + i
|
|
989
|
-
}).join(",")+","+
|
|
990
|
-
indices.map(function(i) {
|
|
991
|
-
return "b" + i
|
|
992
|
-
}).join(",")+",c)}");
|
|
993
|
-
|
|
994
|
-
//view.transpose():
|
|
995
|
-
var tShape = new Array(dimension);
|
|
996
|
-
var tStride = new Array(dimension);
|
|
997
|
-
for(var i=0; i<dimension; ++i) {
|
|
998
|
-
tShape[i] = "a[i"+i+"]";
|
|
999
|
-
tStride[i] = "b[i"+i+"]";
|
|
1000
|
-
}
|
|
1001
|
-
code.push("proto.transpose=function "+className+"_transpose("+args+"){"+
|
|
1002
|
-
args.map(function(n,idx) { return n + "=(" + n + "===undefined?" + idx + ":" + n + "|0)"}).join(";"),
|
|
1003
|
-
"var a=this.shape,b=this.stride;return new "+className+"(this.data,"+tShape.join(",")+","+tStride.join(",")+",this.offset)}");
|
|
1004
|
-
|
|
1005
|
-
//view.pick():
|
|
1006
|
-
code.push("proto.pick=function "+className+"_pick("+args+"){var a=[],b=[],c=this.offset");
|
|
1007
|
-
for(var i=0; i<dimension; ++i) {
|
|
1008
|
-
code.push("if(typeof i"+i+"==='number'&&i"+i+">=0){c=(c+this.stride["+i+"]*i"+i+")|0}else{a.push(this.shape["+i+"]);b.push(this.stride["+i+"])}");
|
|
1009
|
-
}
|
|
1010
|
-
code.push("var ctor=CTOR_LIST[a.length+1];return ctor(this.data,a,b,c)}");
|
|
1011
|
-
|
|
1012
|
-
//Add return statement
|
|
1013
|
-
code.push("return function construct_"+className+"(data,shape,stride,offset){return new "+className+"(data,"+
|
|
1014
|
-
indices.map(function(i) {
|
|
1015
|
-
return "shape["+i+"]"
|
|
1016
|
-
}).join(",")+","+
|
|
1017
|
-
indices.map(function(i) {
|
|
1018
|
-
return "stride["+i+"]"
|
|
1019
|
-
}).join(",")+",offset)}");
|
|
1020
|
-
|
|
1021
|
-
//Compile procedure
|
|
1022
|
-
var procedure = new Function("CTOR_LIST", "ORDER", code.join("\n"));
|
|
1023
|
-
return procedure(CACHED_CONSTRUCTORS[dtype], order)
|
|
1024
|
-
}
|
|
1025
|
-
|
|
1026
|
-
function arrayDType(data) {
|
|
1027
|
-
if(isBuffer_1(data)) {
|
|
1028
|
-
return "buffer"
|
|
1029
|
-
}
|
|
1030
|
-
if(hasTypedArrays) {
|
|
1031
|
-
switch(Object.prototype.toString.call(data)) {
|
|
1032
|
-
case "[object Float64Array]":
|
|
1033
|
-
return "float64"
|
|
1034
|
-
case "[object Float32Array]":
|
|
1035
|
-
return "float32"
|
|
1036
|
-
case "[object Int8Array]":
|
|
1037
|
-
return "int8"
|
|
1038
|
-
case "[object Int16Array]":
|
|
1039
|
-
return "int16"
|
|
1040
|
-
case "[object Int32Array]":
|
|
1041
|
-
return "int32"
|
|
1042
|
-
case "[object Uint8Array]":
|
|
1043
|
-
return "uint8"
|
|
1044
|
-
case "[object Uint16Array]":
|
|
1045
|
-
return "uint16"
|
|
1046
|
-
case "[object Uint32Array]":
|
|
1047
|
-
return "uint32"
|
|
1048
|
-
case "[object Uint8ClampedArray]":
|
|
1049
|
-
return "uint8_clamped"
|
|
1050
|
-
case "[object BigInt64Array]":
|
|
1051
|
-
return "bigint64"
|
|
1052
|
-
case "[object BigUint64Array]":
|
|
1053
|
-
return "biguint64"
|
|
1054
|
-
}
|
|
1055
|
-
}
|
|
1056
|
-
if(Array.isArray(data)) {
|
|
1057
|
-
return "array"
|
|
1058
|
-
}
|
|
1059
|
-
return "generic"
|
|
1060
|
-
}
|
|
1061
|
-
|
|
1062
|
-
var CACHED_CONSTRUCTORS = {
|
|
1063
|
-
"float32":[],
|
|
1064
|
-
"float64":[],
|
|
1065
|
-
"int8":[],
|
|
1066
|
-
"int16":[],
|
|
1067
|
-
"int32":[],
|
|
1068
|
-
"uint8":[],
|
|
1069
|
-
"uint16":[],
|
|
1070
|
-
"uint32":[],
|
|
1071
|
-
"array":[],
|
|
1072
|
-
"uint8_clamped":[],
|
|
1073
|
-
"bigint64": [],
|
|
1074
|
-
"biguint64": [],
|
|
1075
|
-
"buffer":[],
|
|
1076
|
-
"generic":[]
|
|
1077
|
-
}
|
|
1078
|
-
|
|
1079
|
-
;
|
|
1080
|
-
function wrappedNDArrayCtor(data, shape, stride, offset) {
|
|
1081
|
-
if(data === undefined) {
|
|
1082
|
-
var ctor = CACHED_CONSTRUCTORS.array[0];
|
|
1083
|
-
return ctor([])
|
|
1084
|
-
} else if(typeof data === "number") {
|
|
1085
|
-
data = [data];
|
|
1086
|
-
}
|
|
1087
|
-
if(shape === undefined) {
|
|
1088
|
-
shape = [ data.length ];
|
|
1089
|
-
}
|
|
1090
|
-
var d = shape.length;
|
|
1091
|
-
if(stride === undefined) {
|
|
1092
|
-
stride = new Array(d);
|
|
1093
|
-
for(var i=d-1, sz=1; i>=0; --i) {
|
|
1094
|
-
stride[i] = sz;
|
|
1095
|
-
sz *= shape[i];
|
|
1096
|
-
}
|
|
1097
|
-
}
|
|
1098
|
-
if(offset === undefined) {
|
|
1099
|
-
offset = 0;
|
|
1100
|
-
for(var i=0; i<d; ++i) {
|
|
1101
|
-
if(stride[i] < 0) {
|
|
1102
|
-
offset -= (shape[i]-1)*stride[i];
|
|
1103
|
-
}
|
|
1104
|
-
}
|
|
1105
|
-
}
|
|
1106
|
-
var dtype = arrayDType(data);
|
|
1107
|
-
var ctor_list = CACHED_CONSTRUCTORS[dtype];
|
|
1108
|
-
while(ctor_list.length <= d+1) {
|
|
1109
|
-
ctor_list.push(compileConstructor(dtype, ctor_list.length-1));
|
|
1110
|
-
}
|
|
1111
|
-
var ctor = ctor_list[d+1];
|
|
1112
|
-
return ctor(data, shape, stride, offset)
|
|
1113
|
-
}
|
|
1114
|
-
|
|
1115
|
-
var ndarray = wrappedNDArrayCtor;
|
|
1116
|
-
|
|
1117
|
-
class Martini {
|
|
1118
|
-
constructor(gridSize = 257) {
|
|
1119
|
-
this.gridSize = gridSize;
|
|
1120
|
-
const tileSize = gridSize - 1;
|
|
1121
|
-
if (tileSize & tileSize - 1) throw new Error(`Expected grid size to be 2^n+1, got ${gridSize}.`);
|
|
1122
|
-
this.numTriangles = tileSize * tileSize * 2 - 2;
|
|
1123
|
-
this.numParentTriangles = this.numTriangles - tileSize * tileSize;
|
|
1124
|
-
this.indices = new Uint32Array(this.gridSize * this.gridSize); // coordinates for all possible triangles in an RTIN tile
|
|
1125
|
-
|
|
1126
|
-
this.coords = new Uint16Array(this.numTriangles * 4); // get triangle coordinates from its index in an implicit binary tree
|
|
1127
|
-
|
|
1128
|
-
for (let i = 0; i < this.numTriangles; i++) {
|
|
1129
|
-
let id = i + 2;
|
|
1130
|
-
let ax = 0,
|
|
1131
|
-
ay = 0,
|
|
1132
|
-
bx = 0,
|
|
1133
|
-
by = 0,
|
|
1134
|
-
cx = 0,
|
|
1135
|
-
cy = 0;
|
|
1136
|
-
|
|
1137
|
-
if (id & 1) {
|
|
1138
|
-
bx = by = cx = tileSize; // bottom-left triangle
|
|
1139
|
-
} else {
|
|
1140
|
-
ax = ay = cy = tileSize; // top-right triangle
|
|
1141
|
-
}
|
|
1142
|
-
|
|
1143
|
-
while ((id >>= 1) > 1) {
|
|
1144
|
-
const mx = ax + bx >> 1;
|
|
1145
|
-
const my = ay + by >> 1;
|
|
1146
|
-
|
|
1147
|
-
if (id & 1) {
|
|
1148
|
-
// left half
|
|
1149
|
-
bx = ax;
|
|
1150
|
-
by = ay;
|
|
1151
|
-
ax = cx;
|
|
1152
|
-
ay = cy;
|
|
1153
|
-
} else {
|
|
1154
|
-
// right half
|
|
1155
|
-
ax = bx;
|
|
1156
|
-
ay = by;
|
|
1157
|
-
bx = cx;
|
|
1158
|
-
by = cy;
|
|
1159
|
-
}
|
|
1160
|
-
|
|
1161
|
-
cx = mx;
|
|
1162
|
-
cy = my;
|
|
1163
|
-
}
|
|
1164
|
-
|
|
1165
|
-
const k = i * 4;
|
|
1166
|
-
this.coords[k + 0] = ax;
|
|
1167
|
-
this.coords[k + 1] = ay;
|
|
1168
|
-
this.coords[k + 2] = bx;
|
|
1169
|
-
this.coords[k + 3] = by;
|
|
1170
|
-
}
|
|
1171
|
-
}
|
|
1172
|
-
|
|
1173
|
-
createTile(terrain) {
|
|
1174
|
-
return new Tile(terrain, this);
|
|
1175
|
-
}
|
|
1176
|
-
|
|
1177
|
-
}
|
|
1178
|
-
|
|
1179
998
|
class Tile {
|
|
1180
999
|
constructor(terrain, martini) {
|
|
1181
1000
|
const size = martini.gridSize;
|
|
@@ -1185,7 +1004,6 @@ class Tile {
|
|
|
1185
1004
|
this.errors = new Float32Array(terrain.length);
|
|
1186
1005
|
this.update();
|
|
1187
1006
|
}
|
|
1188
|
-
|
|
1189
1007
|
update() {
|
|
1190
1008
|
const {
|
|
1191
1009
|
numTriangles,
|
|
@@ -1196,8 +1014,9 @@ class Tile {
|
|
|
1196
1014
|
const {
|
|
1197
1015
|
terrain,
|
|
1198
1016
|
errors
|
|
1199
|
-
} = this;
|
|
1017
|
+
} = this;
|
|
1200
1018
|
|
|
1019
|
+
// iterate over all possible triangles, starting from the smallest level
|
|
1201
1020
|
for (let i = numTriangles - 1; i >= 0; i--) {
|
|
1202
1021
|
const k = i * 4;
|
|
1203
1022
|
const ax = coords[k + 0];
|
|
@@ -1207,13 +1026,13 @@ class Tile {
|
|
|
1207
1026
|
const mx = ax + bx >> 1;
|
|
1208
1027
|
const my = ay + by >> 1;
|
|
1209
1028
|
const cx = mx + my - ay;
|
|
1210
|
-
const cy = my + ax - mx;
|
|
1029
|
+
const cy = my + ax - mx;
|
|
1211
1030
|
|
|
1031
|
+
// calculate error in the middle of the long edge of the triangle
|
|
1212
1032
|
const interpolatedHeight = (terrain[ay * size + ax] + terrain[by * size + bx]) / 2;
|
|
1213
1033
|
const middleIndex = my * size + mx;
|
|
1214
1034
|
const middleError = Math.abs(interpolatedHeight - terrain[middleIndex]);
|
|
1215
1035
|
errors[middleIndex] = Math.max(errors[middleIndex], middleError);
|
|
1216
|
-
|
|
1217
1036
|
if (i < numParentTriangles) {
|
|
1218
1037
|
// bigger triangles; accumulate error with children
|
|
1219
1038
|
const leftChildIndex = (ay + cy >> 1) * size + (ax + cx >> 1);
|
|
@@ -1222,7 +1041,6 @@ class Tile {
|
|
|
1222
1041
|
}
|
|
1223
1042
|
}
|
|
1224
1043
|
}
|
|
1225
|
-
|
|
1226
1044
|
getMesh(maxError = 0, maxLength = null) {
|
|
1227
1045
|
const {
|
|
1228
1046
|
gridSize: size,
|
|
@@ -1233,12 +1051,16 @@ class Tile {
|
|
|
1233
1051
|
} = this;
|
|
1234
1052
|
let numVertices = 0;
|
|
1235
1053
|
let numTriangles = 0;
|
|
1236
|
-
const max = size - 1;
|
|
1054
|
+
const max = size - 1;
|
|
1055
|
+
|
|
1056
|
+
// The maxLength parameter will cause triangles to be generated until the legs are below this length
|
|
1237
1057
|
// It is meant to support cases where a certain mesh density is required to do spherical math on digital globes
|
|
1058
|
+
const maxScale = maxLength || size;
|
|
1238
1059
|
|
|
1239
|
-
|
|
1060
|
+
// use an index grid to keep track of vertices that were already used to avoid duplication
|
|
1061
|
+
indices.fill(0);
|
|
1240
1062
|
|
|
1241
|
-
|
|
1063
|
+
// retrieve mesh in two stages that both traverse the error map:
|
|
1242
1064
|
// - countElements: find used vertices (and assign each an index), and count triangles (for minimum allocation)
|
|
1243
1065
|
// - processTriangle: fill the allocated vertices & triangles typed arrays
|
|
1244
1066
|
|
|
@@ -1246,7 +1068,6 @@ class Tile {
|
|
|
1246
1068
|
const mx = ax + bx >> 1;
|
|
1247
1069
|
const my = ay + by >> 1;
|
|
1248
1070
|
const legLength = Math.abs(ax - cx) + Math.abs(ay - cy);
|
|
1249
|
-
|
|
1250
1071
|
if (legLength > 1 && errors[my * size + mx] > maxError || legLength > maxScale) {
|
|
1251
1072
|
countElements(cx, cy, ax, ay, mx, my);
|
|
1252
1073
|
countElements(bx, by, cx, cy, mx, my);
|
|
@@ -1257,18 +1078,15 @@ class Tile {
|
|
|
1257
1078
|
numTriangles++;
|
|
1258
1079
|
}
|
|
1259
1080
|
}
|
|
1260
|
-
|
|
1261
1081
|
countElements(0, 0, max, max, max, 0);
|
|
1262
1082
|
countElements(max, max, 0, 0, 0, max);
|
|
1263
1083
|
const vertices = new Uint16Array(numVertices * 2);
|
|
1264
1084
|
const triangles = new Uint32Array(numTriangles * 3);
|
|
1265
1085
|
let triIndex = 0;
|
|
1266
|
-
|
|
1267
1086
|
function processTriangle(ax, ay, bx, by, cx, cy) {
|
|
1268
1087
|
const mx = ax + bx >> 1;
|
|
1269
1088
|
const my = ay + by >> 1;
|
|
1270
1089
|
const legLength = Math.abs(ax - cx) + Math.abs(ay - cy);
|
|
1271
|
-
|
|
1272
1090
|
if (legLength > 1 && errors[my * size + mx] > maxError || legLength > maxScale) {
|
|
1273
1091
|
// triangle doesn't approximate the surface well enough; drill down further
|
|
1274
1092
|
processTriangle(cx, cy, ax, ay, mx, my);
|
|
@@ -1289,7 +1107,6 @@ class Tile {
|
|
|
1289
1107
|
triangles[triIndex++] = c;
|
|
1290
1108
|
}
|
|
1291
1109
|
}
|
|
1292
|
-
|
|
1293
1110
|
processTriangle(0, 0, max, max, max, 0);
|
|
1294
1111
|
processTriangle(max, max, 0, 0, 0, max);
|
|
1295
1112
|
return {
|
|
@@ -1297,799 +1114,37 @@ class Tile {
|
|
|
1297
1114
|
triangles
|
|
1298
1115
|
};
|
|
1299
1116
|
}
|
|
1300
|
-
|
|
1301
|
-
}
|
|
1302
|
-
|
|
1303
|
-
function createCommonjsModule(fn) {
|
|
1304
|
-
var module = { exports: {} };
|
|
1305
|
-
return fn(module, module.exports), module.exports;
|
|
1306
1117
|
}
|
|
1307
1118
|
|
|
1308
|
-
|
|
1309
|
-
* Copyright (c) 2014-present, Facebook, Inc.
|
|
1310
|
-
*
|
|
1311
|
-
* This source code is licensed under the MIT license found in the
|
|
1312
|
-
* LICENSE file in the root directory of this source tree.
|
|
1313
|
-
*/
|
|
1314
|
-
|
|
1315
|
-
createCommonjsModule(function (module) {
|
|
1316
|
-
var runtime = (function (exports) {
|
|
1317
|
-
|
|
1318
|
-
var Op = Object.prototype;
|
|
1319
|
-
var hasOwn = Op.hasOwnProperty;
|
|
1320
|
-
var undefined$1; // More compressible than void 0.
|
|
1321
|
-
var $Symbol = typeof Symbol === "function" ? Symbol : {};
|
|
1322
|
-
var iteratorSymbol = $Symbol.iterator || "@@iterator";
|
|
1323
|
-
var asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator";
|
|
1324
|
-
var toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag";
|
|
1325
|
-
|
|
1326
|
-
function define(obj, key, value) {
|
|
1327
|
-
Object.defineProperty(obj, key, {
|
|
1328
|
-
value: value,
|
|
1329
|
-
enumerable: true,
|
|
1330
|
-
configurable: true,
|
|
1331
|
-
writable: true
|
|
1332
|
-
});
|
|
1333
|
-
return obj[key];
|
|
1334
|
-
}
|
|
1335
|
-
try {
|
|
1336
|
-
// IE 8 has a broken Object.defineProperty that only works on DOM objects.
|
|
1337
|
-
define({}, "");
|
|
1338
|
-
} catch (err) {
|
|
1339
|
-
define = function(obj, key, value) {
|
|
1340
|
-
return obj[key] = value;
|
|
1341
|
-
};
|
|
1342
|
-
}
|
|
1343
|
-
|
|
1344
|
-
function wrap(innerFn, outerFn, self, tryLocsList) {
|
|
1345
|
-
// If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.
|
|
1346
|
-
var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;
|
|
1347
|
-
var generator = Object.create(protoGenerator.prototype);
|
|
1348
|
-
var context = new Context(tryLocsList || []);
|
|
1349
|
-
|
|
1350
|
-
// The ._invoke method unifies the implementations of the .next,
|
|
1351
|
-
// .throw, and .return methods.
|
|
1352
|
-
generator._invoke = makeInvokeMethod(innerFn, self, context);
|
|
1353
|
-
|
|
1354
|
-
return generator;
|
|
1355
|
-
}
|
|
1356
|
-
exports.wrap = wrap;
|
|
1357
|
-
|
|
1358
|
-
// Try/catch helper to minimize deoptimizations. Returns a completion
|
|
1359
|
-
// record like context.tryEntries[i].completion. This interface could
|
|
1360
|
-
// have been (and was previously) designed to take a closure to be
|
|
1361
|
-
// invoked without arguments, but in all the cases we care about we
|
|
1362
|
-
// already have an existing method we want to call, so there's no need
|
|
1363
|
-
// to create a new function object. We can even get away with assuming
|
|
1364
|
-
// the method takes exactly one argument, since that happens to be true
|
|
1365
|
-
// in every case, so we don't have to touch the arguments object. The
|
|
1366
|
-
// only additional allocation required is the completion record, which
|
|
1367
|
-
// has a stable shape and so hopefully should be cheap to allocate.
|
|
1368
|
-
function tryCatch(fn, obj, arg) {
|
|
1369
|
-
try {
|
|
1370
|
-
return { type: "normal", arg: fn.call(obj, arg) };
|
|
1371
|
-
} catch (err) {
|
|
1372
|
-
return { type: "throw", arg: err };
|
|
1373
|
-
}
|
|
1374
|
-
}
|
|
1375
|
-
|
|
1376
|
-
var GenStateSuspendedStart = "suspendedStart";
|
|
1377
|
-
var GenStateSuspendedYield = "suspendedYield";
|
|
1378
|
-
var GenStateExecuting = "executing";
|
|
1379
|
-
var GenStateCompleted = "completed";
|
|
1380
|
-
|
|
1381
|
-
// Returning this object from the innerFn has the same effect as
|
|
1382
|
-
// breaking out of the dispatch switch statement.
|
|
1383
|
-
var ContinueSentinel = {};
|
|
1384
|
-
|
|
1385
|
-
// Dummy constructor functions that we use as the .constructor and
|
|
1386
|
-
// .constructor.prototype properties for functions that return Generator
|
|
1387
|
-
// objects. For full spec compliance, you may wish to configure your
|
|
1388
|
-
// minifier not to mangle the names of these two functions.
|
|
1389
|
-
function Generator() {}
|
|
1390
|
-
function GeneratorFunction() {}
|
|
1391
|
-
function GeneratorFunctionPrototype() {}
|
|
1392
|
-
|
|
1393
|
-
// This is a polyfill for %IteratorPrototype% for environments that
|
|
1394
|
-
// don't natively support it.
|
|
1395
|
-
var IteratorPrototype = {};
|
|
1396
|
-
define(IteratorPrototype, iteratorSymbol, function () {
|
|
1397
|
-
return this;
|
|
1398
|
-
});
|
|
1399
|
-
|
|
1400
|
-
var getProto = Object.getPrototypeOf;
|
|
1401
|
-
var NativeIteratorPrototype = getProto && getProto(getProto(values([])));
|
|
1402
|
-
if (NativeIteratorPrototype &&
|
|
1403
|
-
NativeIteratorPrototype !== Op &&
|
|
1404
|
-
hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {
|
|
1405
|
-
// This environment has a native %IteratorPrototype%; use it instead
|
|
1406
|
-
// of the polyfill.
|
|
1407
|
-
IteratorPrototype = NativeIteratorPrototype;
|
|
1408
|
-
}
|
|
1409
|
-
|
|
1410
|
-
var Gp = GeneratorFunctionPrototype.prototype =
|
|
1411
|
-
Generator.prototype = Object.create(IteratorPrototype);
|
|
1412
|
-
GeneratorFunction.prototype = GeneratorFunctionPrototype;
|
|
1413
|
-
define(Gp, "constructor", GeneratorFunctionPrototype);
|
|
1414
|
-
define(GeneratorFunctionPrototype, "constructor", GeneratorFunction);
|
|
1415
|
-
GeneratorFunction.displayName = define(
|
|
1416
|
-
GeneratorFunctionPrototype,
|
|
1417
|
-
toStringTagSymbol,
|
|
1418
|
-
"GeneratorFunction"
|
|
1419
|
-
);
|
|
1420
|
-
|
|
1421
|
-
// Helper for defining the .next, .throw, and .return methods of the
|
|
1422
|
-
// Iterator interface in terms of a single ._invoke method.
|
|
1423
|
-
function defineIteratorMethods(prototype) {
|
|
1424
|
-
["next", "throw", "return"].forEach(function(method) {
|
|
1425
|
-
define(prototype, method, function(arg) {
|
|
1426
|
-
return this._invoke(method, arg);
|
|
1427
|
-
});
|
|
1428
|
-
});
|
|
1429
|
-
}
|
|
1430
|
-
|
|
1431
|
-
exports.isGeneratorFunction = function(genFun) {
|
|
1432
|
-
var ctor = typeof genFun === "function" && genFun.constructor;
|
|
1433
|
-
return ctor
|
|
1434
|
-
? ctor === GeneratorFunction ||
|
|
1435
|
-
// For the native GeneratorFunction constructor, the best we can
|
|
1436
|
-
// do is to check its .name property.
|
|
1437
|
-
(ctor.displayName || ctor.name) === "GeneratorFunction"
|
|
1438
|
-
: false;
|
|
1439
|
-
};
|
|
1440
|
-
|
|
1441
|
-
exports.mark = function(genFun) {
|
|
1442
|
-
if (Object.setPrototypeOf) {
|
|
1443
|
-
Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);
|
|
1444
|
-
} else {
|
|
1445
|
-
genFun.__proto__ = GeneratorFunctionPrototype;
|
|
1446
|
-
define(genFun, toStringTagSymbol, "GeneratorFunction");
|
|
1447
|
-
}
|
|
1448
|
-
genFun.prototype = Object.create(Gp);
|
|
1449
|
-
return genFun;
|
|
1450
|
-
};
|
|
1451
|
-
|
|
1452
|
-
// Within the body of any async function, `await x` is transformed to
|
|
1453
|
-
// `yield regeneratorRuntime.awrap(x)`, so that the runtime can test
|
|
1454
|
-
// `hasOwn.call(value, "__await")` to determine if the yielded value is
|
|
1455
|
-
// meant to be awaited.
|
|
1456
|
-
exports.awrap = function(arg) {
|
|
1457
|
-
return { __await: arg };
|
|
1458
|
-
};
|
|
1459
|
-
|
|
1460
|
-
function AsyncIterator(generator, PromiseImpl) {
|
|
1461
|
-
function invoke(method, arg, resolve, reject) {
|
|
1462
|
-
var record = tryCatch(generator[method], generator, arg);
|
|
1463
|
-
if (record.type === "throw") {
|
|
1464
|
-
reject(record.arg);
|
|
1465
|
-
} else {
|
|
1466
|
-
var result = record.arg;
|
|
1467
|
-
var value = result.value;
|
|
1468
|
-
if (value &&
|
|
1469
|
-
typeof value === "object" &&
|
|
1470
|
-
hasOwn.call(value, "__await")) {
|
|
1471
|
-
return PromiseImpl.resolve(value.__await).then(function(value) {
|
|
1472
|
-
invoke("next", value, resolve, reject);
|
|
1473
|
-
}, function(err) {
|
|
1474
|
-
invoke("throw", err, resolve, reject);
|
|
1475
|
-
});
|
|
1476
|
-
}
|
|
1477
|
-
|
|
1478
|
-
return PromiseImpl.resolve(value).then(function(unwrapped) {
|
|
1479
|
-
// When a yielded Promise is resolved, its final value becomes
|
|
1480
|
-
// the .value of the Promise<{value,done}> result for the
|
|
1481
|
-
// current iteration.
|
|
1482
|
-
result.value = unwrapped;
|
|
1483
|
-
resolve(result);
|
|
1484
|
-
}, function(error) {
|
|
1485
|
-
// If a rejected Promise was yielded, throw the rejection back
|
|
1486
|
-
// into the async generator function so it can be handled there.
|
|
1487
|
-
return invoke("throw", error, resolve, reject);
|
|
1488
|
-
});
|
|
1489
|
-
}
|
|
1490
|
-
}
|
|
1491
|
-
|
|
1492
|
-
var previousPromise;
|
|
1493
|
-
|
|
1494
|
-
function enqueue(method, arg) {
|
|
1495
|
-
function callInvokeWithMethodAndArg() {
|
|
1496
|
-
return new PromiseImpl(function(resolve, reject) {
|
|
1497
|
-
invoke(method, arg, resolve, reject);
|
|
1498
|
-
});
|
|
1499
|
-
}
|
|
1500
|
-
|
|
1501
|
-
return previousPromise =
|
|
1502
|
-
// If enqueue has been called before, then we want to wait until
|
|
1503
|
-
// all previous Promises have been resolved before calling invoke,
|
|
1504
|
-
// so that results are always delivered in the correct order. If
|
|
1505
|
-
// enqueue has not been called before, then it is important to
|
|
1506
|
-
// call invoke immediately, without waiting on a callback to fire,
|
|
1507
|
-
// so that the async generator function has the opportunity to do
|
|
1508
|
-
// any necessary setup in a predictable way. This predictability
|
|
1509
|
-
// is why the Promise constructor synchronously invokes its
|
|
1510
|
-
// executor callback, and why async functions synchronously
|
|
1511
|
-
// execute code before the first await. Since we implement simple
|
|
1512
|
-
// async functions in terms of async generators, it is especially
|
|
1513
|
-
// important to get this right, even though it requires care.
|
|
1514
|
-
previousPromise ? previousPromise.then(
|
|
1515
|
-
callInvokeWithMethodAndArg,
|
|
1516
|
-
// Avoid propagating failures to Promises returned by later
|
|
1517
|
-
// invocations of the iterator.
|
|
1518
|
-
callInvokeWithMethodAndArg
|
|
1519
|
-
) : callInvokeWithMethodAndArg();
|
|
1520
|
-
}
|
|
1521
|
-
|
|
1522
|
-
// Define the unified helper method that is used to implement .next,
|
|
1523
|
-
// .throw, and .return (see defineIteratorMethods).
|
|
1524
|
-
this._invoke = enqueue;
|
|
1525
|
-
}
|
|
1526
|
-
|
|
1527
|
-
defineIteratorMethods(AsyncIterator.prototype);
|
|
1528
|
-
define(AsyncIterator.prototype, asyncIteratorSymbol, function () {
|
|
1529
|
-
return this;
|
|
1530
|
-
});
|
|
1531
|
-
exports.AsyncIterator = AsyncIterator;
|
|
1532
|
-
|
|
1533
|
-
// Note that simple async functions are implemented on top of
|
|
1534
|
-
// AsyncIterator objects; they just return a Promise for the value of
|
|
1535
|
-
// the final result produced by the iterator.
|
|
1536
|
-
exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {
|
|
1537
|
-
if (PromiseImpl === void 0) PromiseImpl = Promise;
|
|
1538
|
-
|
|
1539
|
-
var iter = new AsyncIterator(
|
|
1540
|
-
wrap(innerFn, outerFn, self, tryLocsList),
|
|
1541
|
-
PromiseImpl
|
|
1542
|
-
);
|
|
1543
|
-
|
|
1544
|
-
return exports.isGeneratorFunction(outerFn)
|
|
1545
|
-
? iter // If outerFn is a generator, return the full iterator.
|
|
1546
|
-
: iter.next().then(function(result) {
|
|
1547
|
-
return result.done ? result.value : iter.next();
|
|
1548
|
-
});
|
|
1549
|
-
};
|
|
1550
|
-
|
|
1551
|
-
function makeInvokeMethod(innerFn, self, context) {
|
|
1552
|
-
var state = GenStateSuspendedStart;
|
|
1553
|
-
|
|
1554
|
-
return function invoke(method, arg) {
|
|
1555
|
-
if (state === GenStateExecuting) {
|
|
1556
|
-
throw new Error("Generator is already running");
|
|
1557
|
-
}
|
|
1558
|
-
|
|
1559
|
-
if (state === GenStateCompleted) {
|
|
1560
|
-
if (method === "throw") {
|
|
1561
|
-
throw arg;
|
|
1562
|
-
}
|
|
1563
|
-
|
|
1564
|
-
// Be forgiving, per 25.3.3.3.3 of the spec:
|
|
1565
|
-
// https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume
|
|
1566
|
-
return doneResult();
|
|
1567
|
-
}
|
|
1568
|
-
|
|
1569
|
-
context.method = method;
|
|
1570
|
-
context.arg = arg;
|
|
1571
|
-
|
|
1572
|
-
while (true) {
|
|
1573
|
-
var delegate = context.delegate;
|
|
1574
|
-
if (delegate) {
|
|
1575
|
-
var delegateResult = maybeInvokeDelegate(delegate, context);
|
|
1576
|
-
if (delegateResult) {
|
|
1577
|
-
if (delegateResult === ContinueSentinel) continue;
|
|
1578
|
-
return delegateResult;
|
|
1579
|
-
}
|
|
1580
|
-
}
|
|
1581
|
-
|
|
1582
|
-
if (context.method === "next") {
|
|
1583
|
-
// Setting context._sent for legacy support of Babel's
|
|
1584
|
-
// function.sent implementation.
|
|
1585
|
-
context.sent = context._sent = context.arg;
|
|
1586
|
-
|
|
1587
|
-
} else if (context.method === "throw") {
|
|
1588
|
-
if (state === GenStateSuspendedStart) {
|
|
1589
|
-
state = GenStateCompleted;
|
|
1590
|
-
throw context.arg;
|
|
1591
|
-
}
|
|
1592
|
-
|
|
1593
|
-
context.dispatchException(context.arg);
|
|
1594
|
-
|
|
1595
|
-
} else if (context.method === "return") {
|
|
1596
|
-
context.abrupt("return", context.arg);
|
|
1597
|
-
}
|
|
1598
|
-
|
|
1599
|
-
state = GenStateExecuting;
|
|
1600
|
-
|
|
1601
|
-
var record = tryCatch(innerFn, self, context);
|
|
1602
|
-
if (record.type === "normal") {
|
|
1603
|
-
// If an exception is thrown from innerFn, we leave state ===
|
|
1604
|
-
// GenStateExecuting and loop back for another invocation.
|
|
1605
|
-
state = context.done
|
|
1606
|
-
? GenStateCompleted
|
|
1607
|
-
: GenStateSuspendedYield;
|
|
1608
|
-
|
|
1609
|
-
if (record.arg === ContinueSentinel) {
|
|
1610
|
-
continue;
|
|
1611
|
-
}
|
|
1612
|
-
|
|
1613
|
-
return {
|
|
1614
|
-
value: record.arg,
|
|
1615
|
-
done: context.done
|
|
1616
|
-
};
|
|
1617
|
-
|
|
1618
|
-
} else if (record.type === "throw") {
|
|
1619
|
-
state = GenStateCompleted;
|
|
1620
|
-
// Dispatch the exception by looping back around to the
|
|
1621
|
-
// context.dispatchException(context.arg) call above.
|
|
1622
|
-
context.method = "throw";
|
|
1623
|
-
context.arg = record.arg;
|
|
1624
|
-
}
|
|
1625
|
-
}
|
|
1626
|
-
};
|
|
1627
|
-
}
|
|
1628
|
-
|
|
1629
|
-
// Call delegate.iterator[context.method](context.arg) and handle the
|
|
1630
|
-
// result, either by returning a { value, done } result from the
|
|
1631
|
-
// delegate iterator, or by modifying context.method and context.arg,
|
|
1632
|
-
// setting context.delegate to null, and returning the ContinueSentinel.
|
|
1633
|
-
function maybeInvokeDelegate(delegate, context) {
|
|
1634
|
-
var method = delegate.iterator[context.method];
|
|
1635
|
-
if (method === undefined$1) {
|
|
1636
|
-
// A .throw or .return when the delegate iterator has no .throw
|
|
1637
|
-
// method always terminates the yield* loop.
|
|
1638
|
-
context.delegate = null;
|
|
1639
|
-
|
|
1640
|
-
if (context.method === "throw") {
|
|
1641
|
-
// Note: ["return"] must be used for ES3 parsing compatibility.
|
|
1642
|
-
if (delegate.iterator["return"]) {
|
|
1643
|
-
// If the delegate iterator has a return method, give it a
|
|
1644
|
-
// chance to clean up.
|
|
1645
|
-
context.method = "return";
|
|
1646
|
-
context.arg = undefined$1;
|
|
1647
|
-
maybeInvokeDelegate(delegate, context);
|
|
1648
|
-
|
|
1649
|
-
if (context.method === "throw") {
|
|
1650
|
-
// If maybeInvokeDelegate(context) changed context.method from
|
|
1651
|
-
// "return" to "throw", let that override the TypeError below.
|
|
1652
|
-
return ContinueSentinel;
|
|
1653
|
-
}
|
|
1654
|
-
}
|
|
1655
|
-
|
|
1656
|
-
context.method = "throw";
|
|
1657
|
-
context.arg = new TypeError(
|
|
1658
|
-
"The iterator does not provide a 'throw' method");
|
|
1659
|
-
}
|
|
1660
|
-
|
|
1661
|
-
return ContinueSentinel;
|
|
1662
|
-
}
|
|
1663
|
-
|
|
1664
|
-
var record = tryCatch(method, delegate.iterator, context.arg);
|
|
1665
|
-
|
|
1666
|
-
if (record.type === "throw") {
|
|
1667
|
-
context.method = "throw";
|
|
1668
|
-
context.arg = record.arg;
|
|
1669
|
-
context.delegate = null;
|
|
1670
|
-
return ContinueSentinel;
|
|
1671
|
-
}
|
|
1672
|
-
|
|
1673
|
-
var info = record.arg;
|
|
1674
|
-
|
|
1675
|
-
if (! info) {
|
|
1676
|
-
context.method = "throw";
|
|
1677
|
-
context.arg = new TypeError("iterator result is not an object");
|
|
1678
|
-
context.delegate = null;
|
|
1679
|
-
return ContinueSentinel;
|
|
1680
|
-
}
|
|
1681
|
-
|
|
1682
|
-
if (info.done) {
|
|
1683
|
-
// Assign the result of the finished delegate to the temporary
|
|
1684
|
-
// variable specified by delegate.resultName (see delegateYield).
|
|
1685
|
-
context[delegate.resultName] = info.value;
|
|
1686
|
-
|
|
1687
|
-
// Resume execution at the desired location (see delegateYield).
|
|
1688
|
-
context.next = delegate.nextLoc;
|
|
1689
|
-
|
|
1690
|
-
// If context.method was "throw" but the delegate handled the
|
|
1691
|
-
// exception, let the outer generator proceed normally. If
|
|
1692
|
-
// context.method was "next", forget context.arg since it has been
|
|
1693
|
-
// "consumed" by the delegate iterator. If context.method was
|
|
1694
|
-
// "return", allow the original .return call to continue in the
|
|
1695
|
-
// outer generator.
|
|
1696
|
-
if (context.method !== "return") {
|
|
1697
|
-
context.method = "next";
|
|
1698
|
-
context.arg = undefined$1;
|
|
1699
|
-
}
|
|
1700
|
-
|
|
1701
|
-
} else {
|
|
1702
|
-
// Re-yield the result returned by the delegate method.
|
|
1703
|
-
return info;
|
|
1704
|
-
}
|
|
1705
|
-
|
|
1706
|
-
// The delegate iterator is finished, so forget it and continue with
|
|
1707
|
-
// the outer generator.
|
|
1708
|
-
context.delegate = null;
|
|
1709
|
-
return ContinueSentinel;
|
|
1710
|
-
}
|
|
1711
|
-
|
|
1712
|
-
// Define Generator.prototype.{next,throw,return} in terms of the
|
|
1713
|
-
// unified ._invoke helper method.
|
|
1714
|
-
defineIteratorMethods(Gp);
|
|
1715
|
-
|
|
1716
|
-
define(Gp, toStringTagSymbol, "Generator");
|
|
1717
|
-
|
|
1718
|
-
// A Generator should always return itself as the iterator object when the
|
|
1719
|
-
// @@iterator function is called on it. Some browsers' implementations of the
|
|
1720
|
-
// iterator prototype chain incorrectly implement this, causing the Generator
|
|
1721
|
-
// object to not be returned from this call. This ensures that doesn't happen.
|
|
1722
|
-
// See https://github.com/facebook/regenerator/issues/274 for more details.
|
|
1723
|
-
define(Gp, iteratorSymbol, function() {
|
|
1724
|
-
return this;
|
|
1725
|
-
});
|
|
1726
|
-
|
|
1727
|
-
define(Gp, "toString", function() {
|
|
1728
|
-
return "[object Generator]";
|
|
1729
|
-
});
|
|
1730
|
-
|
|
1731
|
-
function pushTryEntry(locs) {
|
|
1732
|
-
var entry = { tryLoc: locs[0] };
|
|
1733
|
-
|
|
1734
|
-
if (1 in locs) {
|
|
1735
|
-
entry.catchLoc = locs[1];
|
|
1736
|
-
}
|
|
1737
|
-
|
|
1738
|
-
if (2 in locs) {
|
|
1739
|
-
entry.finallyLoc = locs[2];
|
|
1740
|
-
entry.afterLoc = locs[3];
|
|
1741
|
-
}
|
|
1742
|
-
|
|
1743
|
-
this.tryEntries.push(entry);
|
|
1744
|
-
}
|
|
1745
|
-
|
|
1746
|
-
function resetTryEntry(entry) {
|
|
1747
|
-
var record = entry.completion || {};
|
|
1748
|
-
record.type = "normal";
|
|
1749
|
-
delete record.arg;
|
|
1750
|
-
entry.completion = record;
|
|
1751
|
-
}
|
|
1752
|
-
|
|
1753
|
-
function Context(tryLocsList) {
|
|
1754
|
-
// The root entry object (effectively a try statement without a catch
|
|
1755
|
-
// or a finally block) gives us a place to store values thrown from
|
|
1756
|
-
// locations where there is no enclosing try statement.
|
|
1757
|
-
this.tryEntries = [{ tryLoc: "root" }];
|
|
1758
|
-
tryLocsList.forEach(pushTryEntry, this);
|
|
1759
|
-
this.reset(true);
|
|
1760
|
-
}
|
|
1761
|
-
|
|
1762
|
-
exports.keys = function(object) {
|
|
1763
|
-
var keys = [];
|
|
1764
|
-
for (var key in object) {
|
|
1765
|
-
keys.push(key);
|
|
1766
|
-
}
|
|
1767
|
-
keys.reverse();
|
|
1768
|
-
|
|
1769
|
-
// Rather than returning an object with a next method, we keep
|
|
1770
|
-
// things simple and return the next function itself.
|
|
1771
|
-
return function next() {
|
|
1772
|
-
while (keys.length) {
|
|
1773
|
-
var key = keys.pop();
|
|
1774
|
-
if (key in object) {
|
|
1775
|
-
next.value = key;
|
|
1776
|
-
next.done = false;
|
|
1777
|
-
return next;
|
|
1778
|
-
}
|
|
1779
|
-
}
|
|
1780
|
-
|
|
1781
|
-
// To avoid creating an additional object, we just hang the .value
|
|
1782
|
-
// and .done properties off the next function object itself. This
|
|
1783
|
-
// also ensures that the minifier will not anonymize the function.
|
|
1784
|
-
next.done = true;
|
|
1785
|
-
return next;
|
|
1786
|
-
};
|
|
1787
|
-
};
|
|
1788
|
-
|
|
1789
|
-
function values(iterable) {
|
|
1790
|
-
if (iterable) {
|
|
1791
|
-
var iteratorMethod = iterable[iteratorSymbol];
|
|
1792
|
-
if (iteratorMethod) {
|
|
1793
|
-
return iteratorMethod.call(iterable);
|
|
1794
|
-
}
|
|
1795
|
-
|
|
1796
|
-
if (typeof iterable.next === "function") {
|
|
1797
|
-
return iterable;
|
|
1798
|
-
}
|
|
1799
|
-
|
|
1800
|
-
if (!isNaN(iterable.length)) {
|
|
1801
|
-
var i = -1, next = function next() {
|
|
1802
|
-
while (++i < iterable.length) {
|
|
1803
|
-
if (hasOwn.call(iterable, i)) {
|
|
1804
|
-
next.value = iterable[i];
|
|
1805
|
-
next.done = false;
|
|
1806
|
-
return next;
|
|
1807
|
-
}
|
|
1808
|
-
}
|
|
1809
|
-
|
|
1810
|
-
next.value = undefined$1;
|
|
1811
|
-
next.done = true;
|
|
1812
|
-
|
|
1813
|
-
return next;
|
|
1814
|
-
};
|
|
1815
|
-
|
|
1816
|
-
return next.next = next;
|
|
1817
|
-
}
|
|
1818
|
-
}
|
|
1819
|
-
|
|
1820
|
-
// Return an iterator with no values.
|
|
1821
|
-
return { next: doneResult };
|
|
1822
|
-
}
|
|
1823
|
-
exports.values = values;
|
|
1824
|
-
|
|
1825
|
-
function doneResult() {
|
|
1826
|
-
return { value: undefined$1, done: true };
|
|
1827
|
-
}
|
|
1828
|
-
|
|
1829
|
-
Context.prototype = {
|
|
1830
|
-
constructor: Context,
|
|
1831
|
-
|
|
1832
|
-
reset: function(skipTempReset) {
|
|
1833
|
-
this.prev = 0;
|
|
1834
|
-
this.next = 0;
|
|
1835
|
-
// Resetting context._sent for legacy support of Babel's
|
|
1836
|
-
// function.sent implementation.
|
|
1837
|
-
this.sent = this._sent = undefined$1;
|
|
1838
|
-
this.done = false;
|
|
1839
|
-
this.delegate = null;
|
|
1840
|
-
|
|
1841
|
-
this.method = "next";
|
|
1842
|
-
this.arg = undefined$1;
|
|
1843
|
-
|
|
1844
|
-
this.tryEntries.forEach(resetTryEntry);
|
|
1845
|
-
|
|
1846
|
-
if (!skipTempReset) {
|
|
1847
|
-
for (var name in this) {
|
|
1848
|
-
// Not sure about the optimal order of these conditions:
|
|
1849
|
-
if (name.charAt(0) === "t" &&
|
|
1850
|
-
hasOwn.call(this, name) &&
|
|
1851
|
-
!isNaN(+name.slice(1))) {
|
|
1852
|
-
this[name] = undefined$1;
|
|
1853
|
-
}
|
|
1854
|
-
}
|
|
1855
|
-
}
|
|
1856
|
-
},
|
|
1857
|
-
|
|
1858
|
-
stop: function() {
|
|
1859
|
-
this.done = true;
|
|
1860
|
-
|
|
1861
|
-
var rootEntry = this.tryEntries[0];
|
|
1862
|
-
var rootRecord = rootEntry.completion;
|
|
1863
|
-
if (rootRecord.type === "throw") {
|
|
1864
|
-
throw rootRecord.arg;
|
|
1865
|
-
}
|
|
1866
|
-
|
|
1867
|
-
return this.rval;
|
|
1868
|
-
},
|
|
1869
|
-
|
|
1870
|
-
dispatchException: function(exception) {
|
|
1871
|
-
if (this.done) {
|
|
1872
|
-
throw exception;
|
|
1873
|
-
}
|
|
1874
|
-
|
|
1875
|
-
var context = this;
|
|
1876
|
-
function handle(loc, caught) {
|
|
1877
|
-
record.type = "throw";
|
|
1878
|
-
record.arg = exception;
|
|
1879
|
-
context.next = loc;
|
|
1880
|
-
|
|
1881
|
-
if (caught) {
|
|
1882
|
-
// If the dispatched exception was caught by a catch block,
|
|
1883
|
-
// then let that catch block handle the exception normally.
|
|
1884
|
-
context.method = "next";
|
|
1885
|
-
context.arg = undefined$1;
|
|
1886
|
-
}
|
|
1887
|
-
|
|
1888
|
-
return !! caught;
|
|
1889
|
-
}
|
|
1890
|
-
|
|
1891
|
-
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
1892
|
-
var entry = this.tryEntries[i];
|
|
1893
|
-
var record = entry.completion;
|
|
1894
|
-
|
|
1895
|
-
if (entry.tryLoc === "root") {
|
|
1896
|
-
// Exception thrown outside of any try block that could handle
|
|
1897
|
-
// it, so set the completion value of the entire function to
|
|
1898
|
-
// throw the exception.
|
|
1899
|
-
return handle("end");
|
|
1900
|
-
}
|
|
1901
|
-
|
|
1902
|
-
if (entry.tryLoc <= this.prev) {
|
|
1903
|
-
var hasCatch = hasOwn.call(entry, "catchLoc");
|
|
1904
|
-
var hasFinally = hasOwn.call(entry, "finallyLoc");
|
|
1905
|
-
|
|
1906
|
-
if (hasCatch && hasFinally) {
|
|
1907
|
-
if (this.prev < entry.catchLoc) {
|
|
1908
|
-
return handle(entry.catchLoc, true);
|
|
1909
|
-
} else if (this.prev < entry.finallyLoc) {
|
|
1910
|
-
return handle(entry.finallyLoc);
|
|
1911
|
-
}
|
|
1912
|
-
|
|
1913
|
-
} else if (hasCatch) {
|
|
1914
|
-
if (this.prev < entry.catchLoc) {
|
|
1915
|
-
return handle(entry.catchLoc, true);
|
|
1916
|
-
}
|
|
1917
|
-
|
|
1918
|
-
} else if (hasFinally) {
|
|
1919
|
-
if (this.prev < entry.finallyLoc) {
|
|
1920
|
-
return handle(entry.finallyLoc);
|
|
1921
|
-
}
|
|
1922
|
-
|
|
1923
|
-
} else {
|
|
1924
|
-
throw new Error("try statement without catch or finally");
|
|
1925
|
-
}
|
|
1926
|
-
}
|
|
1927
|
-
}
|
|
1928
|
-
},
|
|
1929
|
-
|
|
1930
|
-
abrupt: function(type, arg) {
|
|
1931
|
-
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
1932
|
-
var entry = this.tryEntries[i];
|
|
1933
|
-
if (entry.tryLoc <= this.prev &&
|
|
1934
|
-
hasOwn.call(entry, "finallyLoc") &&
|
|
1935
|
-
this.prev < entry.finallyLoc) {
|
|
1936
|
-
var finallyEntry = entry;
|
|
1937
|
-
break;
|
|
1938
|
-
}
|
|
1939
|
-
}
|
|
1940
|
-
|
|
1941
|
-
if (finallyEntry &&
|
|
1942
|
-
(type === "break" ||
|
|
1943
|
-
type === "continue") &&
|
|
1944
|
-
finallyEntry.tryLoc <= arg &&
|
|
1945
|
-
arg <= finallyEntry.finallyLoc) {
|
|
1946
|
-
// Ignore the finally entry if control is not jumping to a
|
|
1947
|
-
// location outside the try/catch block.
|
|
1948
|
-
finallyEntry = null;
|
|
1949
|
-
}
|
|
1950
|
-
|
|
1951
|
-
var record = finallyEntry ? finallyEntry.completion : {};
|
|
1952
|
-
record.type = type;
|
|
1953
|
-
record.arg = arg;
|
|
1954
|
-
|
|
1955
|
-
if (finallyEntry) {
|
|
1956
|
-
this.method = "next";
|
|
1957
|
-
this.next = finallyEntry.finallyLoc;
|
|
1958
|
-
return ContinueSentinel;
|
|
1959
|
-
}
|
|
1960
|
-
|
|
1961
|
-
return this.complete(record);
|
|
1962
|
-
},
|
|
1963
|
-
|
|
1964
|
-
complete: function(record, afterLoc) {
|
|
1965
|
-
if (record.type === "throw") {
|
|
1966
|
-
throw record.arg;
|
|
1967
|
-
}
|
|
1968
|
-
|
|
1969
|
-
if (record.type === "break" ||
|
|
1970
|
-
record.type === "continue") {
|
|
1971
|
-
this.next = record.arg;
|
|
1972
|
-
} else if (record.type === "return") {
|
|
1973
|
-
this.rval = this.arg = record.arg;
|
|
1974
|
-
this.method = "return";
|
|
1975
|
-
this.next = "end";
|
|
1976
|
-
} else if (record.type === "normal" && afterLoc) {
|
|
1977
|
-
this.next = afterLoc;
|
|
1978
|
-
}
|
|
1979
|
-
|
|
1980
|
-
return ContinueSentinel;
|
|
1981
|
-
},
|
|
1982
|
-
|
|
1983
|
-
finish: function(finallyLoc) {
|
|
1984
|
-
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
1985
|
-
var entry = this.tryEntries[i];
|
|
1986
|
-
if (entry.finallyLoc === finallyLoc) {
|
|
1987
|
-
this.complete(entry.completion, entry.afterLoc);
|
|
1988
|
-
resetTryEntry(entry);
|
|
1989
|
-
return ContinueSentinel;
|
|
1990
|
-
}
|
|
1991
|
-
}
|
|
1992
|
-
},
|
|
1993
|
-
|
|
1994
|
-
"catch": function(tryLoc) {
|
|
1995
|
-
for (var i = this.tryEntries.length - 1; i >= 0; --i) {
|
|
1996
|
-
var entry = this.tryEntries[i];
|
|
1997
|
-
if (entry.tryLoc === tryLoc) {
|
|
1998
|
-
var record = entry.completion;
|
|
1999
|
-
if (record.type === "throw") {
|
|
2000
|
-
var thrown = record.arg;
|
|
2001
|
-
resetTryEntry(entry);
|
|
2002
|
-
}
|
|
2003
|
-
return thrown;
|
|
2004
|
-
}
|
|
2005
|
-
}
|
|
2006
|
-
|
|
2007
|
-
// The context.catch method must only be called with a location
|
|
2008
|
-
// argument that corresponds to a known catch block.
|
|
2009
|
-
throw new Error("illegal catch attempt");
|
|
2010
|
-
},
|
|
2011
|
-
|
|
2012
|
-
delegateYield: function(iterable, resultName, nextLoc) {
|
|
2013
|
-
this.delegate = {
|
|
2014
|
-
iterator: values(iterable),
|
|
2015
|
-
resultName: resultName,
|
|
2016
|
-
nextLoc: nextLoc
|
|
2017
|
-
};
|
|
2018
|
-
|
|
2019
|
-
if (this.method === "next") {
|
|
2020
|
-
// Deliberately forget the last sent value so that we don't
|
|
2021
|
-
// accidentally pass it on to the delegate.
|
|
2022
|
-
this.arg = undefined$1;
|
|
2023
|
-
}
|
|
2024
|
-
|
|
2025
|
-
return ContinueSentinel;
|
|
2026
|
-
}
|
|
2027
|
-
};
|
|
2028
|
-
|
|
2029
|
-
// Regardless of whether this script is executing as a CommonJS module
|
|
2030
|
-
// or not, return the runtime object so that we can declare the variable
|
|
2031
|
-
// regeneratorRuntime in the outer scope, which allows this module to be
|
|
2032
|
-
// injected easily by `bin/regenerator --include-runtime script.js`.
|
|
2033
|
-
return exports;
|
|
2034
|
-
|
|
2035
|
-
}(
|
|
2036
|
-
// If this script is executing as a CommonJS module, use module.exports
|
|
2037
|
-
// as the regeneratorRuntime namespace. Otherwise create a new empty
|
|
2038
|
-
// object. Either way, the resulting object will be used to initialize
|
|
2039
|
-
// the regeneratorRuntime variable at the top of this file.
|
|
2040
|
-
module.exports
|
|
2041
|
-
));
|
|
2042
|
-
|
|
2043
|
-
try {
|
|
2044
|
-
regeneratorRuntime = runtime;
|
|
2045
|
-
} catch (accidentalStrictMode) {
|
|
2046
|
-
// This module should not be running in strict mode, so the above
|
|
2047
|
-
// assignment should always work unless something is misconfigured. Just
|
|
2048
|
-
// in case runtime.js accidentally runs in strict mode, in modern engines
|
|
2049
|
-
// we can explicitly access globalThis. In older engines we can escape
|
|
2050
|
-
// strict mode using a global Function call. This could conceivably fail
|
|
2051
|
-
// if a Content Security Policy forbids using Function, but in that case
|
|
2052
|
-
// the proper solution is to fix the accidental strict mode problem. If
|
|
2053
|
-
// you've misconfigured your bundler to force strict mode and applied a
|
|
2054
|
-
// CSP to forbid Function, and you're not willing to fix either of those
|
|
2055
|
-
// problems, please detail your unique predicament in a GitHub issue.
|
|
2056
|
-
if (typeof globalThis === "object") {
|
|
2057
|
-
globalThis.regeneratorRuntime = runtime;
|
|
2058
|
-
} else {
|
|
2059
|
-
Function("r", "regeneratorRuntime = r")(runtime);
|
|
2060
|
-
}
|
|
2061
|
-
}
|
|
2062
|
-
});
|
|
1119
|
+
// https://github.com/CesiumGS/cesium/blob/1.76/Source/WorkersES6/createVerticesFromQuantizedTerrainMesh.js
|
|
2063
1120
|
|
|
2064
1121
|
var martini = null;
|
|
2065
|
-
|
|
2066
1122
|
function decodeTerrain(parameters, transferableObjects) {
|
|
2067
1123
|
var _martini;
|
|
2068
|
-
|
|
2069
1124
|
var imageData = parameters.imageData,
|
|
2070
|
-
|
|
2071
|
-
|
|
2072
|
-
|
|
2073
|
-
|
|
2074
|
-
|
|
2075
|
-
var pixels = ndarray(new Uint8Array(imageData), [tileSize, tileSize, 4], [4, 4 * tileSize, 1], 0);
|
|
2076
|
-
|
|
1125
|
+
_parameters$tileSize = parameters.tileSize,
|
|
1126
|
+
tileSize = _parameters$tileSize === void 0 ? 256 : _parameters$tileSize,
|
|
1127
|
+
errorLevel = parameters.errorLevel,
|
|
1128
|
+
interval = parameters.interval,
|
|
1129
|
+
offset = parameters.offset;
|
|
1130
|
+
var pixels = ndarray(new Uint8Array(imageData), [tileSize, tileSize, 4], [4, 4 * tileSize, 1], 0);
|
|
1131
|
+
|
|
1132
|
+
// Tile size must be maintained through the life of the worker
|
|
2077
1133
|
(_martini = martini) !== null && _martini !== void 0 ? _martini : martini = new Martini(tileSize + 1);
|
|
2078
1134
|
var terrain = mapboxTerrainToGrid(pixels, interval, offset);
|
|
2079
|
-
var tile = martini.createTile(terrain);
|
|
1135
|
+
var tile = martini.createTile(terrain);
|
|
2080
1136
|
|
|
1137
|
+
// get a mesh (vertices and triangles indices) for a 10m error
|
|
2081
1138
|
var mesh = tile.getMesh(errorLevel, parameters.maxLength);
|
|
2082
1139
|
return createQuantizedMeshData(tile, mesh, tileSize);
|
|
2083
1140
|
}
|
|
2084
|
-
|
|
2085
1141
|
self.onmessage = function (msg) {
|
|
2086
1142
|
var _msg$data = msg.data,
|
|
2087
|
-
|
|
2088
|
-
|
|
1143
|
+
id = _msg$data.id,
|
|
1144
|
+
payload = _msg$data.payload;
|
|
2089
1145
|
if (id == null) return;
|
|
2090
1146
|
var objects = [];
|
|
2091
1147
|
var res = null;
|
|
2092
|
-
|
|
2093
1148
|
try {
|
|
2094
1149
|
res = decodeTerrain(payload);
|
|
2095
1150
|
objects.push(res.indices.buffer);
|
|
@@ -2109,89 +1164,50 @@ self.onmessage = function (msg) {
|
|
|
2109
1164
|
}
|
|
2110
1165
|
};
|
|
2111
1166
|
|
|
1167
|
+
// https://github.com/CesiumGS/cesium/blob/1.68/Source/Scene/MapboxImageryProvider.js#L42
|
|
2112
1168
|
var StretchedTilingScheme = /*#__PURE__*/function (_WebMercatorTilingSch) {
|
|
2113
1169
|
_inherits(StretchedTilingScheme, _WebMercatorTilingSch);
|
|
2114
|
-
|
|
2115
1170
|
var _super = _createSuper(StretchedTilingScheme);
|
|
2116
|
-
|
|
2117
1171
|
function StretchedTilingScheme() {
|
|
2118
1172
|
_classCallCheck(this, StretchedTilingScheme);
|
|
2119
|
-
|
|
2120
1173
|
return _super.apply(this, arguments);
|
|
2121
1174
|
}
|
|
2122
|
-
|
|
2123
1175
|
_createClass(StretchedTilingScheme, [{
|
|
2124
1176
|
key: "tileXYToRectangle",
|
|
2125
1177
|
value: function tileXYToRectangle(x, y, level, res) {
|
|
2126
1178
|
var result = _get(_getPrototypeOf(StretchedTilingScheme.prototype), "tileXYToRectangle", this).call(this, x, y, level);
|
|
2127
|
-
|
|
2128
1179
|
if (y == 0) {
|
|
2129
1180
|
//console.log("Top row", res, y, level);
|
|
2130
1181
|
result.north = Math.PI / 2;
|
|
2131
1182
|
}
|
|
2132
|
-
|
|
2133
1183
|
if (y + 1 == Math.pow(2, level)) {
|
|
2134
1184
|
result.south = -Math.PI / 2;
|
|
2135
1185
|
}
|
|
2136
|
-
|
|
2137
1186
|
return result;
|
|
2138
1187
|
}
|
|
2139
1188
|
}]);
|
|
2140
|
-
|
|
2141
1189
|
return StretchedTilingScheme;
|
|
2142
|
-
}(
|
|
2143
|
-
|
|
1190
|
+
}(WebMercatorTilingScheme);
|
|
2144
1191
|
var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
2145
1192
|
// @ts-ignore
|
|
2146
1193
|
function MartiniTerrainProvider() {
|
|
2147
1194
|
var _opts$interval, _opts$offset, _opts$maxWorkers, _opts$minZoomLevel, _opts$fillPoles, _opts$detailScalar, _opts$minimumErrorLev, _opts$ellipsoid;
|
|
2148
|
-
|
|
2149
1195
|
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
2150
|
-
|
|
2151
1196
|
_classCallCheck(this, MartiniTerrainProvider);
|
|
2152
|
-
|
|
2153
1197
|
_defineProperty(this, "hasWaterMask", false);
|
|
2154
|
-
|
|
2155
1198
|
_defineProperty(this, "hasVertexNormals", false);
|
|
2156
|
-
|
|
2157
|
-
_defineProperty(this, "credit", new cesium.Credit("Mapbox"));
|
|
2158
|
-
|
|
2159
|
-
_defineProperty(this, "ready", void 0);
|
|
2160
|
-
|
|
2161
|
-
_defineProperty(this, "readyPromise", void 0);
|
|
2162
|
-
|
|
1199
|
+
_defineProperty(this, "credit", new Credit("Mapbox"));
|
|
2163
1200
|
_defineProperty(this, "availability", null);
|
|
2164
|
-
|
|
2165
|
-
_defineProperty(this, "errorEvent", new cesium.Event());
|
|
2166
|
-
|
|
2167
|
-
_defineProperty(this, "tilingScheme", void 0);
|
|
2168
|
-
|
|
2169
|
-
_defineProperty(this, "ellipsoid", void 0);
|
|
2170
|
-
|
|
1201
|
+
_defineProperty(this, "errorEvent", new Event());
|
|
2171
1202
|
_defineProperty(this, "workerFarm", null);
|
|
2172
|
-
|
|
2173
1203
|
_defineProperty(this, "inProgressWorkers", 0);
|
|
2174
|
-
|
|
2175
1204
|
_defineProperty(this, "levelOfDetailScalar", null);
|
|
2176
|
-
|
|
2177
1205
|
_defineProperty(this, "maxWorkers", 5);
|
|
2178
|
-
|
|
2179
1206
|
_defineProperty(this, "minError", 0.1);
|
|
2180
|
-
|
|
2181
|
-
_defineProperty(this, "minZoomLevel", void 0);
|
|
2182
|
-
|
|
2183
1207
|
_defineProperty(this, "fillPoles", true);
|
|
2184
|
-
|
|
2185
1208
|
_defineProperty(this, "_errorAtMinZoom", 1000);
|
|
2186
|
-
|
|
2187
1209
|
_defineProperty(this, "resource", null);
|
|
2188
|
-
|
|
2189
|
-
_defineProperty(this, "interval", void 0);
|
|
2190
|
-
|
|
2191
|
-
_defineProperty(this, "offset", void 0);
|
|
2192
|
-
|
|
2193
1210
|
_defineProperty(this, "RADIUS_SCALAR", 1.0);
|
|
2194
|
-
|
|
2195
1211
|
//this.martini = new Martini(257);
|
|
2196
1212
|
this.resource = opts.resource;
|
|
2197
1213
|
this.interval = (_opts$interval = opts.interval) !== null && _opts$interval !== void 0 ? _opts$interval : 0.1;
|
|
@@ -2200,23 +1216,19 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2200
1216
|
this.minZoomLevel = (_opts$minZoomLevel = opts.minZoomLevel) !== null && _opts$minZoomLevel !== void 0 ? _opts$minZoomLevel : 3;
|
|
2201
1217
|
this.fillPoles = (_opts$fillPoles = opts.fillPoles) !== null && _opts$fillPoles !== void 0 ? _opts$fillPoles : true;
|
|
2202
1218
|
console.log("fillPoles", this.fillPoles);
|
|
2203
|
-
this.levelOfDetailScalar = ((_opts$detailScalar = opts.detailScalar) !== null && _opts$detailScalar !== void 0 ? _opts$detailScalar : 4.0) +
|
|
1219
|
+
this.levelOfDetailScalar = ((_opts$detailScalar = opts.detailScalar) !== null && _opts$detailScalar !== void 0 ? _opts$detailScalar : 4.0) + Math$1.EPSILON5;
|
|
2204
1220
|
this.ready = true;
|
|
2205
1221
|
this.readyPromise = Promise.resolve(true);
|
|
2206
1222
|
this.minError = (_opts$minimumErrorLev = opts.minimumErrorLevel) !== null && _opts$minimumErrorLev !== void 0 ? _opts$minimumErrorLev : 0.1;
|
|
2207
1223
|
this.errorEvent.addEventListener(console.log, this);
|
|
2208
|
-
this.ellipsoid = (_opts$ellipsoid = opts.ellipsoid) !== null && _opts$ellipsoid !== void 0 ? _opts$ellipsoid :
|
|
2209
|
-
|
|
1224
|
+
this.ellipsoid = (_opts$ellipsoid = opts.ellipsoid) !== null && _opts$ellipsoid !== void 0 ? _opts$ellipsoid : Ellipsoid.WGS84;
|
|
2210
1225
|
if (this.maxWorkers > 0) {
|
|
2211
1226
|
this.workerFarm = new WorkerFarm();
|
|
2212
1227
|
}
|
|
2213
|
-
|
|
2214
|
-
var scheme = cesium.WebMercatorTilingScheme;
|
|
2215
|
-
|
|
1228
|
+
var scheme = WebMercatorTilingScheme;
|
|
2216
1229
|
if (this.fillPoles) {
|
|
2217
1230
|
scheme = StretchedTilingScheme;
|
|
2218
1231
|
}
|
|
2219
|
-
|
|
2220
1232
|
this.tilingScheme = new scheme({
|
|
2221
1233
|
numberOfLevelZeroTilesX: 1,
|
|
2222
1234
|
numberOfLevelZeroTilesY: 1,
|
|
@@ -2224,19 +1236,19 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2224
1236
|
});
|
|
2225
1237
|
this._errorAtMinZoom = this.errorAtZoom(this.minZoomLevel);
|
|
2226
1238
|
}
|
|
2227
|
-
|
|
2228
1239
|
_createClass(MartiniTerrainProvider, [{
|
|
2229
1240
|
key: "requestTileGeometry",
|
|
2230
1241
|
value: function requestTileGeometry(x, y, z, request) {
|
|
2231
1242
|
var _this = this;
|
|
2232
|
-
|
|
2233
1243
|
// Look for tiles both below the zoom level and below the error threshold for the zoom level at the equator...
|
|
1244
|
+
|
|
2234
1245
|
if (z < this.minZoomLevel || this.scaledErrorForTile(x, y, z) > this._errorAtMinZoom) {
|
|
2235
1246
|
// If we are below the minimum zoom level, we return empty heightmaps
|
|
2236
1247
|
// to avoid unnecessary requests for low-resolution data.
|
|
2237
1248
|
return Promise.resolve(this.emptyMesh(x, y, z));
|
|
2238
|
-
}
|
|
1249
|
+
}
|
|
2239
1250
|
|
|
1251
|
+
// Note: we still load a TON of tiles near the poles. We might need to do some overzooming here...
|
|
2240
1252
|
|
|
2241
1253
|
if (this.inProgressWorkers > this.maxWorkers) return undefined;
|
|
2242
1254
|
this.inProgressWorkers += 1;
|
|
@@ -2247,81 +1259,67 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2247
1259
|
}, {
|
|
2248
1260
|
key: "processTile",
|
|
2249
1261
|
value: function () {
|
|
2250
|
-
var _processTile = _asyncToGenerator( /*#__PURE__*/
|
|
1262
|
+
var _processTile = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(x, y, z) {
|
|
2251
1263
|
var _this$resource, tileSize, getTilePixels, px, pixelData, tileRect, err, maxLength, params, res;
|
|
2252
|
-
|
|
2253
|
-
|
|
2254
|
-
|
|
2255
|
-
|
|
2256
|
-
|
|
2257
|
-
|
|
2258
|
-
|
|
2259
|
-
|
|
2260
|
-
|
|
2261
|
-
|
|
2262
|
-
|
|
2263
|
-
|
|
2264
|
-
|
|
2265
|
-
|
|
2266
|
-
|
|
2267
|
-
|
|
2268
|
-
|
|
2269
|
-
|
|
2270
|
-
|
|
2271
|
-
|
|
2272
|
-
|
|
2273
|
-
|
|
2274
|
-
|
|
2275
|
-
|
|
2276
|
-
|
|
2277
|
-
|
|
2278
|
-
|
|
2279
|
-
|
|
2280
|
-
|
|
2281
|
-
|
|
2282
|
-
|
|
2283
|
-
offset: this.offset
|
|
2284
|
-
};
|
|
2285
|
-
|
|
2286
|
-
if (!(this.workerFarm != null)) {
|
|
2287
|
-
_context.next = 16;
|
|
2288
|
-
break;
|
|
2289
|
-
}
|
|
2290
|
-
|
|
2291
|
-
_context.next = 13;
|
|
2292
|
-
return this.workerFarm.scheduleTask(params, [pixelData.buffer]);
|
|
2293
|
-
|
|
2294
|
-
case 13:
|
|
2295
|
-
res = _context.sent;
|
|
2296
|
-
_context.next = 17;
|
|
1264
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
1265
|
+
while (1) switch (_context.prev = _context.next) {
|
|
1266
|
+
case 0:
|
|
1267
|
+
_context.prev = 0;
|
|
1268
|
+
_this$resource = this.resource, tileSize = _this$resource.tileSize, getTilePixels = _this$resource.getTilePixels;
|
|
1269
|
+
_context.next = 4;
|
|
1270
|
+
return getTilePixels({
|
|
1271
|
+
x: x,
|
|
1272
|
+
y: y,
|
|
1273
|
+
z: z
|
|
1274
|
+
});
|
|
1275
|
+
case 4:
|
|
1276
|
+
px = _context.sent;
|
|
1277
|
+
pixelData = px.data;
|
|
1278
|
+
tileRect = this.tilingScheme.tileXYToRectangle(x, y, z); ///const center = Rectangle.center(tileRect);
|
|
1279
|
+
err = this.errorAtZoom(z);
|
|
1280
|
+
maxLength = this.maxVertexDistance(tileRect);
|
|
1281
|
+
params = {
|
|
1282
|
+
imageData: pixelData,
|
|
1283
|
+
maxLength: maxLength,
|
|
1284
|
+
x: x,
|
|
1285
|
+
y: y,
|
|
1286
|
+
z: z,
|
|
1287
|
+
errorLevel: err,
|
|
1288
|
+
ellipsoidRadius: this.ellipsoid.maximumRadius,
|
|
1289
|
+
tileSize: tileSize,
|
|
1290
|
+
interval: this.interval,
|
|
1291
|
+
offset: this.offset
|
|
1292
|
+
};
|
|
1293
|
+
if (!(this.workerFarm != null)) {
|
|
1294
|
+
_context.next = 16;
|
|
2297
1295
|
break;
|
|
2298
|
-
|
|
2299
|
-
|
|
2300
|
-
|
|
2301
|
-
|
|
2302
|
-
|
|
2303
|
-
|
|
2304
|
-
|
|
2305
|
-
|
|
2306
|
-
|
|
2307
|
-
|
|
2308
|
-
|
|
2309
|
-
|
|
2310
|
-
|
|
2311
|
-
|
|
2312
|
-
|
|
2313
|
-
|
|
2314
|
-
|
|
2315
|
-
|
|
2316
|
-
|
|
1296
|
+
}
|
|
1297
|
+
_context.next = 13;
|
|
1298
|
+
return this.workerFarm.scheduleTask(params, [pixelData.buffer]);
|
|
1299
|
+
case 13:
|
|
1300
|
+
res = _context.sent;
|
|
1301
|
+
_context.next = 17;
|
|
1302
|
+
break;
|
|
1303
|
+
case 16:
|
|
1304
|
+
res = decodeTerrain(params);
|
|
1305
|
+
case 17:
|
|
1306
|
+
pixelData = undefined;
|
|
1307
|
+
px = undefined;
|
|
1308
|
+
return _context.abrupt("return", this.createQuantizedMeshData(tileRect, err, res));
|
|
1309
|
+
case 22:
|
|
1310
|
+
_context.prev = 22;
|
|
1311
|
+
_context.t0 = _context["catch"](0);
|
|
1312
|
+
console.log(_context.t0);
|
|
1313
|
+
return _context.abrupt("return", this.emptyMesh(x, y, z));
|
|
1314
|
+
case 26:
|
|
1315
|
+
case "end":
|
|
1316
|
+
return _context.stop();
|
|
2317
1317
|
}
|
|
2318
1318
|
}, _callee, this, [[0, 22]]);
|
|
2319
1319
|
}));
|
|
2320
|
-
|
|
2321
1320
|
function processTile(_x, _x2, _x3) {
|
|
2322
1321
|
return _processTile.apply(this, arguments);
|
|
2323
1322
|
}
|
|
2324
|
-
|
|
2325
1323
|
return processTile;
|
|
2326
1324
|
}()
|
|
2327
1325
|
}, {
|
|
@@ -2333,8 +1331,8 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2333
1331
|
key: "scaledErrorForTile",
|
|
2334
1332
|
value: function scaledErrorForTile(x, y, z) {
|
|
2335
1333
|
var tileRect = this.tilingScheme.tileXYToRectangle(x, y, z);
|
|
2336
|
-
var center =
|
|
2337
|
-
return this.errorAtZoom(z) / (1 - Math.sin(center.latitude));
|
|
1334
|
+
var center = Rectangle.center(tileRect);
|
|
1335
|
+
return this.errorAtZoom(z) / Math.pow(1 - Math.sin(center.latitude), 2);
|
|
2338
1336
|
}
|
|
2339
1337
|
}, {
|
|
2340
1338
|
key: "maxVertexDistance",
|
|
@@ -2345,12 +1343,10 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2345
1343
|
key: "emptyMesh",
|
|
2346
1344
|
value: function emptyMesh$1(x, y, z) {
|
|
2347
1345
|
var tileRect = this.tilingScheme.tileXYToRectangle(x, y, z);
|
|
2348
|
-
var center =
|
|
1346
|
+
var center = Rectangle.center(tileRect);
|
|
2349
1347
|
var latScalar = Math.min(Math.abs(Math.sin(center.latitude)), 0.995);
|
|
2350
1348
|
var v = Math.max(Math.ceil(200 / (z + 1) * Math.pow(1 - latScalar, 0.25)), 4);
|
|
2351
|
-
|
|
2352
1349
|
var output = emptyMesh(v);
|
|
2353
|
-
|
|
2354
1350
|
var err = this.errorAtZoom(z);
|
|
2355
1351
|
return this.createQuantizedMeshData(tileRect, err, output);
|
|
2356
1352
|
}
|
|
@@ -2358,34 +1354,37 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2358
1354
|
key: "createQuantizedMeshData",
|
|
2359
1355
|
value: function createQuantizedMeshData(tileRect, errorLevel, workerOutput) {
|
|
2360
1356
|
var minimumHeight = workerOutput.minimumHeight,
|
|
2361
|
-
|
|
2362
|
-
|
|
2363
|
-
|
|
2364
|
-
|
|
2365
|
-
|
|
2366
|
-
|
|
2367
|
-
|
|
1357
|
+
maximumHeight = workerOutput.maximumHeight,
|
|
1358
|
+
quantizedVertices = workerOutput.quantizedVertices,
|
|
1359
|
+
indices = workerOutput.indices,
|
|
1360
|
+
westIndices = workerOutput.westIndices,
|
|
1361
|
+
southIndices = workerOutput.southIndices,
|
|
1362
|
+
eastIndices = workerOutput.eastIndices,
|
|
1363
|
+
northIndices = workerOutput.northIndices;
|
|
2368
1364
|
var err = errorLevel;
|
|
2369
1365
|
var skirtHeight = err * 20;
|
|
2370
|
-
var center =
|
|
1366
|
+
var center = Rectangle.center(tileRect);
|
|
2371
1367
|
|
|
1368
|
+
// Calculating occlusion height is kind of messy currently, but it definitely works
|
|
2372
1369
|
var halfAngle = tileRect.width / 2;
|
|
2373
1370
|
var dr = Math.cos(halfAngle); // half tile width since our ref point is at the center
|
|
2374
1371
|
|
|
2375
1372
|
var occlusionHeight = dr * this.ellipsoid.maximumRadius + maximumHeight;
|
|
2376
|
-
|
|
2377
1373
|
if (halfAngle > Math.PI / 4) {
|
|
2378
1374
|
occlusionHeight = (1 + halfAngle) * this.ellipsoid.maximumRadius;
|
|
2379
1375
|
}
|
|
2380
|
-
|
|
2381
|
-
|
|
1376
|
+
var occlusionPoint = new Cartographic(center.longitude, center.latitude, occlusionHeight
|
|
1377
|
+
// Scaling factor of two just to be sure.
|
|
2382
1378
|
);
|
|
2383
|
-
|
|
2384
|
-
var
|
|
2385
|
-
var
|
|
1379
|
+
|
|
1380
|
+
var horizonOcclusionPoint = this.ellipsoid.transformPositionToScaledSpace(Cartographic.toCartesian(occlusionPoint));
|
|
1381
|
+
var orientedBoundingBox = OrientedBoundingBox.fromRectangle(tileRect, minimumHeight, maximumHeight, this.tilingScheme.ellipsoid);
|
|
1382
|
+
var boundingSphere = BoundingSphere.fromOrientedBoundingBox(orientedBoundingBox);
|
|
1383
|
+
|
|
1384
|
+
// SE NW NE
|
|
2386
1385
|
// NE NW SE
|
|
2387
1386
|
|
|
2388
|
-
var result = new
|
|
1387
|
+
var result = new QuantizedMeshTerrainData({
|
|
2389
1388
|
minimumHeight: minimumHeight,
|
|
2390
1389
|
maximumHeight: maximumHeight,
|
|
2391
1390
|
quantizedVertices: quantizedVertices,
|
|
@@ -2408,9 +1407,10 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2408
1407
|
}, {
|
|
2409
1408
|
key: "getLevelMaximumGeometricError",
|
|
2410
1409
|
value: function getLevelMaximumGeometricError(level) {
|
|
2411
|
-
var levelZeroMaximumGeometricError =
|
|
2412
|
-
// also seems to control zooming for imagery layers
|
|
1410
|
+
var levelZeroMaximumGeometricError = TerrainProvider.getEstimatedLevelZeroGeometricErrorForAHeightmap(this.tilingScheme.ellipsoid, 65, this.tilingScheme.getNumberOfXTilesAtLevel(0));
|
|
2413
1411
|
|
|
1412
|
+
// Scalar to control overzooming
|
|
1413
|
+
// also seems to control zooming for imagery layers
|
|
2414
1414
|
var scalar = this.resource.tileSize / 256;
|
|
2415
1415
|
return levelZeroMaximumGeometricError / scalar / (1 << level);
|
|
2416
1416
|
}
|
|
@@ -2424,31 +1424,21 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
|
|
|
2424
1424
|
});
|
|
2425
1425
|
}
|
|
2426
1426
|
}]);
|
|
2427
|
-
|
|
2428
1427
|
return MartiniTerrainProvider;
|
|
2429
1428
|
}();
|
|
2430
|
-
|
|
2431
1429
|
var MapboxTerrainProvider = /*#__PURE__*/function (_MartiniTerrainProvid) {
|
|
2432
1430
|
_inherits(MapboxTerrainProvider, _MartiniTerrainProvid);
|
|
2433
|
-
|
|
2434
1431
|
var _super2 = _createSuper(MapboxTerrainProvider);
|
|
2435
|
-
|
|
2436
1432
|
function MapboxTerrainProvider() {
|
|
2437
1433
|
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
2438
|
-
|
|
2439
1434
|
_classCallCheck(this, MapboxTerrainProvider);
|
|
2440
|
-
|
|
2441
1435
|
var resource = new MapboxTerrainResource(opts);
|
|
2442
1436
|
return _super2.call(this, _objectSpread2(_objectSpread2({}, opts), {}, {
|
|
2443
1437
|
resource: resource
|
|
2444
1438
|
}));
|
|
2445
1439
|
}
|
|
2446
|
-
|
|
2447
1440
|
return _createClass(MapboxTerrainProvider);
|
|
2448
1441
|
}(MartiniTerrainProvider);
|
|
2449
1442
|
|
|
2450
|
-
|
|
2451
|
-
exports.MapboxTerrainResource = MapboxTerrainResource;
|
|
2452
|
-
exports.MartiniTerrainProvider = MartiniTerrainProvider;
|
|
2453
|
-
exports["default"] = MapboxTerrainProvider;
|
|
1443
|
+
export { DefaultHeightmapResource, MapboxTerrainResource, MartiniTerrainProvider, MapboxTerrainProvider as default };
|
|
2454
1444
|
//# sourceMappingURL=index.js.map
|