@macrostrat/cesium-martini 1.2.3 → 1.4.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/dist/index.js CHANGED
@@ -1,256 +1,448 @@
1
- 'use strict';
1
+ import { Resource, Credit, Rectangle, Cartographic, OrientedBoundingBox, BoundingSphere, QuantizedMeshTerrainData, TerrainProvider, Event, Math as Math$1, Ellipsoid, WebMercatorTilingScheme } from 'cesium';
2
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);
9
-
10
- if (Object.getOwnPropertySymbols) {
11
- var symbols = Object.getOwnPropertySymbols(object);
12
- enumerableOnly && (symbols = symbols.filter(function (sym) {
13
- return Object.getOwnPropertyDescriptor(object, sym).enumerable;
14
- })), keys.push.apply(keys, symbols);
15
- }
16
-
17
- return keys;
18
- }
19
-
20
- function _objectSpread2(target) {
21
- for (var i = 1; i < arguments.length; i++) {
22
- var source = null != arguments[i] ? arguments[i] : {};
23
- i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {
24
- _defineProperty(target, key, source[key]);
25
- }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {
26
- Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
27
- });
28
- }
29
-
30
- return target;
3
+ function _assertThisInitialized(e) {
4
+ if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
5
+ return e;
31
6
  }
32
-
33
- function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
7
+ function asyncGeneratorStep(n, t, e, r, o, a, c) {
34
8
  try {
35
- var info = gen[key](arg);
36
- var value = info.value;
37
- } catch (error) {
38
- reject(error);
39
- return;
40
- }
41
-
42
- if (info.done) {
43
- resolve(value);
44
- } else {
45
- Promise.resolve(value).then(_next, _throw);
9
+ var i = n[a](c),
10
+ u = i.value;
11
+ } catch (n) {
12
+ return void e(n);
46
13
  }
14
+ i.done ? t(u) : Promise.resolve(u).then(r, o);
47
15
  }
48
-
49
- function _asyncToGenerator(fn) {
16
+ function _asyncToGenerator(n) {
50
17
  return function () {
51
- var self = this,
52
- args = arguments;
53
- return new Promise(function (resolve, reject) {
54
- var gen = fn.apply(self, args);
55
-
56
- function _next(value) {
57
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
18
+ var t = this,
19
+ e = arguments;
20
+ return new Promise(function (r, o) {
21
+ var a = n.apply(t, e);
22
+ function _next(n) {
23
+ asyncGeneratorStep(a, r, o, _next, _throw, "next", n);
58
24
  }
59
-
60
- function _throw(err) {
61
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
25
+ function _throw(n) {
26
+ asyncGeneratorStep(a, r, o, _next, _throw, "throw", n);
62
27
  }
63
-
64
- _next(undefined);
28
+ _next(void 0);
65
29
  });
66
30
  };
67
31
  }
68
-
69
- function _classCallCheck(instance, Constructor) {
70
- if (!(instance instanceof Constructor)) {
71
- throw new TypeError("Cannot call a class as a function");
72
- }
32
+ function _callSuper(t, o, e) {
33
+ return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e));
73
34
  }
74
-
75
- function _defineProperties(target, props) {
76
- for (var i = 0; i < props.length; i++) {
77
- var descriptor = props[i];
78
- descriptor.enumerable = descriptor.enumerable || false;
79
- descriptor.configurable = true;
80
- if ("value" in descriptor) descriptor.writable = true;
81
- Object.defineProperty(target, descriptor.key, descriptor);
35
+ function _classCallCheck(a, n) {
36
+ if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function");
37
+ }
38
+ function _defineProperties(e, r) {
39
+ for (var t = 0; t < r.length; t++) {
40
+ var o = r[t];
41
+ o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o);
82
42
  }
83
43
  }
84
-
85
- function _createClass(Constructor, protoProps, staticProps) {
86
- if (protoProps) _defineProperties(Constructor.prototype, protoProps);
87
- if (staticProps) _defineProperties(Constructor, staticProps);
88
- Object.defineProperty(Constructor, "prototype", {
89
- writable: false
90
- });
91
- return Constructor;
44
+ function _createClass(e, r, t) {
45
+ return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", {
46
+ writable: !1
47
+ }), e;
92
48
  }
93
-
94
- function _defineProperty(obj, key, value) {
95
- if (key in obj) {
96
- Object.defineProperty(obj, key, {
97
- value: value,
98
- enumerable: true,
99
- configurable: true,
100
- writable: true
101
- });
102
- } else {
103
- obj[key] = value;
104
- }
105
-
106
- return obj;
49
+ function _defineProperty(e, r, t) {
50
+ return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, {
51
+ value: t,
52
+ enumerable: !0,
53
+ configurable: !0,
54
+ writable: !0
55
+ }) : e[r] = t, e;
107
56
  }
108
-
109
- function _inherits(subClass, superClass) {
110
- if (typeof superClass !== "function" && superClass !== null) {
111
- throw new TypeError("Super expression must either be null or a function");
112
- }
113
-
114
- 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
- writable: false
123
- });
124
- if (superClass) _setPrototypeOf(subClass, superClass);
57
+ function _get() {
58
+ return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) {
59
+ var p = _superPropBase(e, t);
60
+ if (p) {
61
+ var n = Object.getOwnPropertyDescriptor(p, t);
62
+ return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value;
63
+ }
64
+ }, _get.apply(null, arguments);
125
65
  }
126
-
127
- function _getPrototypeOf(o) {
128
- _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
129
- return o.__proto__ || Object.getPrototypeOf(o);
130
- };
131
- return _getPrototypeOf(o);
66
+ function _getPrototypeOf(t) {
67
+ return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) {
68
+ return t.__proto__ || Object.getPrototypeOf(t);
69
+ }, _getPrototypeOf(t);
132
70
  }
133
-
134
- function _setPrototypeOf(o, p) {
135
- _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
136
- o.__proto__ = p;
137
- return o;
138
- };
139
-
140
- return _setPrototypeOf(o, p);
71
+ function _inherits(t, e) {
72
+ if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function");
73
+ t.prototype = Object.create(e && e.prototype, {
74
+ constructor: {
75
+ value: t,
76
+ writable: !0,
77
+ configurable: !0
78
+ }
79
+ }), Object.defineProperty(t, "prototype", {
80
+ writable: !1
81
+ }), e && _setPrototypeOf(t, e);
141
82
  }
142
-
143
83
  function _isNativeReflectConstruct() {
144
- if (typeof Reflect === "undefined" || !Reflect.construct) return false;
145
- if (Reflect.construct.sham) return false;
146
- if (typeof Proxy === "function") return true;
147
-
148
84
  try {
149
- Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));
150
- return true;
151
- } catch (e) {
152
- return false;
153
- }
85
+ var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));
86
+ } catch (t) {}
87
+ return (_isNativeReflectConstruct = function () {
88
+ return !!t;
89
+ })();
154
90
  }
155
-
156
- function _assertThisInitialized(self) {
157
- if (self === void 0) {
158
- throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
91
+ function ownKeys(e, r) {
92
+ var t = Object.keys(e);
93
+ if (Object.getOwnPropertySymbols) {
94
+ var o = Object.getOwnPropertySymbols(e);
95
+ r && (o = o.filter(function (r) {
96
+ return Object.getOwnPropertyDescriptor(e, r).enumerable;
97
+ })), t.push.apply(t, o);
159
98
  }
160
-
161
- return self;
99
+ return t;
162
100
  }
163
-
164
- function _possibleConstructorReturn(self, call) {
165
- if (call && (typeof call === "object" || typeof call === "function")) {
166
- return call;
167
- } else if (call !== void 0) {
168
- throw new TypeError("Derived constructors may only return object or undefined");
101
+ function _objectSpread2(e) {
102
+ for (var r = 1; r < arguments.length; r++) {
103
+ var t = null != arguments[r] ? arguments[r] : {};
104
+ r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {
105
+ _defineProperty(e, r, t[r]);
106
+ }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {
107
+ Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));
108
+ });
169
109
  }
170
-
171
- return _assertThisInitialized(self);
110
+ return e;
172
111
  }
173
-
174
- function _createSuper(Derived) {
175
- var hasNativeReflectConstruct = _isNativeReflectConstruct();
176
-
177
- return function _createSuperInternal() {
178
- var Super = _getPrototypeOf(Derived),
179
- result;
180
-
181
- if (hasNativeReflectConstruct) {
182
- var NewTarget = _getPrototypeOf(this).constructor;
183
-
184
- result = Reflect.construct(Super, arguments, NewTarget);
185
- } else {
186
- result = Super.apply(this, arguments);
187
- }
188
-
189
- return _possibleConstructorReturn(this, result);
190
- };
112
+ function _possibleConstructorReturn(t, e) {
113
+ if (e && ("object" == typeof e || "function" == typeof e)) return e;
114
+ if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined");
115
+ return _assertThisInitialized(t);
191
116
  }
192
-
193
- function _superPropBase(object, property) {
194
- while (!Object.prototype.hasOwnProperty.call(object, property)) {
195
- object = _getPrototypeOf(object);
196
- if (object === null) break;
117
+ function _regeneratorRuntime() {
118
+ _regeneratorRuntime = function () {
119
+ return e;
120
+ };
121
+ var t,
122
+ e = {},
123
+ r = Object.prototype,
124
+ n = r.hasOwnProperty,
125
+ o = Object.defineProperty || function (t, e, r) {
126
+ t[e] = r.value;
127
+ },
128
+ i = "function" == typeof Symbol ? Symbol : {},
129
+ a = i.iterator || "@@iterator",
130
+ c = i.asyncIterator || "@@asyncIterator",
131
+ u = i.toStringTag || "@@toStringTag";
132
+ function define(t, e, r) {
133
+ return Object.defineProperty(t, e, {
134
+ value: r,
135
+ enumerable: !0,
136
+ configurable: !0,
137
+ writable: !0
138
+ }), t[e];
197
139
  }
198
-
199
- return object;
200
- }
201
-
202
- function _get() {
203
- if (typeof Reflect !== "undefined" && Reflect.get) {
204
- _get = Reflect.get;
205
- } else {
206
- _get = function _get(target, property, receiver) {
207
- var base = _superPropBase(target, property);
208
-
209
- if (!base) return;
210
- var desc = Object.getOwnPropertyDescriptor(base, property);
211
-
212
- if (desc.get) {
213
- return desc.get.call(arguments.length < 3 ? target : receiver);
140
+ try {
141
+ define({}, "");
142
+ } catch (t) {
143
+ define = function (t, e, r) {
144
+ return t[e] = r;
145
+ };
146
+ }
147
+ function wrap(t, e, r, n) {
148
+ var i = e && e.prototype instanceof Generator ? e : Generator,
149
+ a = Object.create(i.prototype),
150
+ c = new Context(n || []);
151
+ return o(a, "_invoke", {
152
+ value: makeInvokeMethod(t, r, c)
153
+ }), a;
154
+ }
155
+ function tryCatch(t, e, r) {
156
+ try {
157
+ return {
158
+ type: "normal",
159
+ arg: t.call(e, r)
160
+ };
161
+ } catch (t) {
162
+ return {
163
+ type: "throw",
164
+ arg: t
165
+ };
166
+ }
167
+ }
168
+ e.wrap = wrap;
169
+ var h = "suspendedStart",
170
+ l = "suspendedYield",
171
+ f = "executing",
172
+ s = "completed",
173
+ y = {};
174
+ function Generator() {}
175
+ function GeneratorFunction() {}
176
+ function GeneratorFunctionPrototype() {}
177
+ var p = {};
178
+ define(p, a, function () {
179
+ return this;
180
+ });
181
+ var d = Object.getPrototypeOf,
182
+ v = d && d(d(values([])));
183
+ v && v !== r && n.call(v, a) && (p = v);
184
+ var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
185
+ function defineIteratorMethods(t) {
186
+ ["next", "throw", "return"].forEach(function (e) {
187
+ define(t, e, function (t) {
188
+ return this._invoke(e, t);
189
+ });
190
+ });
191
+ }
192
+ function AsyncIterator(t, e) {
193
+ function invoke(r, o, i, a) {
194
+ var c = tryCatch(t[r], t, o);
195
+ if ("throw" !== c.type) {
196
+ var u = c.arg,
197
+ h = u.value;
198
+ return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
199
+ invoke("next", t, i, a);
200
+ }, function (t) {
201
+ invoke("throw", t, i, a);
202
+ }) : e.resolve(h).then(function (t) {
203
+ u.value = t, i(u);
204
+ }, function (t) {
205
+ return invoke("throw", t, i, a);
206
+ });
207
+ }
208
+ a(c.arg);
209
+ }
210
+ var r;
211
+ o(this, "_invoke", {
212
+ value: function (t, n) {
213
+ function callInvokeWithMethodAndArg() {
214
+ return new e(function (e, r) {
215
+ invoke(t, n, e, r);
216
+ });
217
+ }
218
+ return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
219
+ }
220
+ });
221
+ }
222
+ function makeInvokeMethod(e, r, n) {
223
+ var o = h;
224
+ return function (i, a) {
225
+ if (o === f) throw Error("Generator is already running");
226
+ if (o === s) {
227
+ if ("throw" === i) throw a;
228
+ return {
229
+ value: t,
230
+ done: !0
231
+ };
232
+ }
233
+ for (n.method = i, n.arg = a;;) {
234
+ var c = n.delegate;
235
+ if (c) {
236
+ var u = maybeInvokeDelegate(c, n);
237
+ if (u) {
238
+ if (u === y) continue;
239
+ return u;
240
+ }
241
+ }
242
+ if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
243
+ if (o === h) throw o = s, n.arg;
244
+ n.dispatchException(n.arg);
245
+ } else "return" === n.method && n.abrupt("return", n.arg);
246
+ o = f;
247
+ var p = tryCatch(e, r, n);
248
+ if ("normal" === p.type) {
249
+ if (o = n.done ? s : l, p.arg === y) continue;
250
+ return {
251
+ value: p.arg,
252
+ done: n.done
253
+ };
254
+ }
255
+ "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
214
256
  }
215
-
216
- return desc.value;
217
257
  };
218
258
  }
219
-
220
- return _get.apply(this, arguments);
221
- }
222
-
223
- function _toConsumableArray(arr) {
224
- return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
259
+ function maybeInvokeDelegate(e, r) {
260
+ var n = r.method,
261
+ o = e.iterator[n];
262
+ 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;
263
+ var i = tryCatch(o, e.iterator, r.arg);
264
+ if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
265
+ var a = i.arg;
266
+ 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);
267
+ }
268
+ function pushTryEntry(t) {
269
+ var e = {
270
+ tryLoc: t[0]
271
+ };
272
+ 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
273
+ }
274
+ function resetTryEntry(t) {
275
+ var e = t.completion || {};
276
+ e.type = "normal", delete e.arg, t.completion = e;
277
+ }
278
+ function Context(t) {
279
+ this.tryEntries = [{
280
+ tryLoc: "root"
281
+ }], t.forEach(pushTryEntry, this), this.reset(!0);
282
+ }
283
+ function values(e) {
284
+ if (e || "" === e) {
285
+ var r = e[a];
286
+ if (r) return r.call(e);
287
+ if ("function" == typeof e.next) return e;
288
+ if (!isNaN(e.length)) {
289
+ var o = -1,
290
+ i = function next() {
291
+ for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next;
292
+ return next.value = t, next.done = !0, next;
293
+ };
294
+ return i.next = i;
295
+ }
296
+ }
297
+ throw new TypeError(typeof e + " is not iterable");
298
+ }
299
+ return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", {
300
+ value: GeneratorFunctionPrototype,
301
+ configurable: !0
302
+ }), o(GeneratorFunctionPrototype, "constructor", {
303
+ value: GeneratorFunction,
304
+ configurable: !0
305
+ }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
306
+ var e = "function" == typeof t && t.constructor;
307
+ return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
308
+ }, e.mark = function (t) {
309
+ return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
310
+ }, e.awrap = function (t) {
311
+ return {
312
+ __await: t
313
+ };
314
+ }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
315
+ return this;
316
+ }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
317
+ void 0 === i && (i = Promise);
318
+ var a = new AsyncIterator(wrap(t, r, n, o), i);
319
+ return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
320
+ return t.done ? t.value : a.next();
321
+ });
322
+ }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
323
+ return this;
324
+ }), define(g, "toString", function () {
325
+ return "[object Generator]";
326
+ }), e.keys = function (t) {
327
+ var e = Object(t),
328
+ r = [];
329
+ for (var n in e) r.push(n);
330
+ return r.reverse(), function next() {
331
+ for (; r.length;) {
332
+ var t = r.pop();
333
+ if (t in e) return next.value = t, next.done = !1, next;
334
+ }
335
+ return next.done = !0, next;
336
+ };
337
+ }, e.values = values, Context.prototype = {
338
+ constructor: Context,
339
+ reset: function (e) {
340
+ 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);
341
+ },
342
+ stop: function () {
343
+ this.done = !0;
344
+ var t = this.tryEntries[0].completion;
345
+ if ("throw" === t.type) throw t.arg;
346
+ return this.rval;
347
+ },
348
+ dispatchException: function (e) {
349
+ if (this.done) throw e;
350
+ var r = this;
351
+ function handle(n, o) {
352
+ return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
353
+ }
354
+ for (var o = this.tryEntries.length - 1; o >= 0; --o) {
355
+ var i = this.tryEntries[o],
356
+ a = i.completion;
357
+ if ("root" === i.tryLoc) return handle("end");
358
+ if (i.tryLoc <= this.prev) {
359
+ var c = n.call(i, "catchLoc"),
360
+ u = n.call(i, "finallyLoc");
361
+ if (c && u) {
362
+ if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
363
+ if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
364
+ } else if (c) {
365
+ if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
366
+ } else {
367
+ if (!u) throw Error("try statement without catch or finally");
368
+ if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
369
+ }
370
+ }
371
+ }
372
+ },
373
+ abrupt: function (t, e) {
374
+ for (var r = this.tryEntries.length - 1; r >= 0; --r) {
375
+ var o = this.tryEntries[r];
376
+ if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
377
+ var i = o;
378
+ break;
379
+ }
380
+ }
381
+ i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
382
+ var a = i ? i.completion : {};
383
+ return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
384
+ },
385
+ complete: function (t, e) {
386
+ if ("throw" === t.type) throw t.arg;
387
+ 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;
388
+ },
389
+ finish: function (t) {
390
+ for (var e = this.tryEntries.length - 1; e >= 0; --e) {
391
+ var r = this.tryEntries[e];
392
+ if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
393
+ }
394
+ },
395
+ catch: function (t) {
396
+ for (var e = this.tryEntries.length - 1; e >= 0; --e) {
397
+ var r = this.tryEntries[e];
398
+ if (r.tryLoc === t) {
399
+ var n = r.completion;
400
+ if ("throw" === n.type) {
401
+ var o = n.arg;
402
+ resetTryEntry(r);
403
+ }
404
+ return o;
405
+ }
406
+ }
407
+ throw Error("illegal catch attempt");
408
+ },
409
+ delegateYield: function (e, r, n) {
410
+ return this.delegate = {
411
+ iterator: values(e),
412
+ resultName: r,
413
+ nextLoc: n
414
+ }, "next" === this.method && (this.arg = t), y;
415
+ }
416
+ }, e;
225
417
  }
226
-
227
- function _arrayWithoutHoles(arr) {
228
- if (Array.isArray(arr)) return _arrayLikeToArray(arr);
418
+ function _setPrototypeOf(t, e) {
419
+ return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {
420
+ return t.__proto__ = e, t;
421
+ }, _setPrototypeOf(t, e);
229
422
  }
230
-
231
- function _iterableToArray(iter) {
232
- if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
423
+ function _superPropBase(t, o) {
424
+ for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t)););
425
+ return t;
233
426
  }
234
-
235
- function _unsupportedIterableToArray(o, minLen) {
236
- if (!o) return;
237
- if (typeof o === "string") return _arrayLikeToArray(o, minLen);
238
- var n = Object.prototype.toString.call(o).slice(8, -1);
239
- if (n === "Object" && o.constructor) n = o.constructor.name;
240
- if (n === "Map" || n === "Set") return Array.from(o);
241
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
427
+ function _superPropGet(t, o, e, r) {
428
+ var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e);
429
+ return 2 & r && "function" == typeof p ? function (t) {
430
+ return p.apply(e, t);
431
+ } : p;
242
432
  }
243
-
244
- function _arrayLikeToArray(arr, len) {
245
- if (len == null || len > arr.length) len = arr.length;
246
-
247
- for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
248
-
249
- return arr2;
433
+ function _toPrimitive(t, r) {
434
+ if ("object" != typeof t || !t) return t;
435
+ var e = t[Symbol.toPrimitive];
436
+ if (void 0 !== e) {
437
+ var i = e.call(t, r || "default");
438
+ if ("object" != typeof i) return i;
439
+ throw new TypeError("@@toPrimitive must return a primitive value.");
440
+ }
441
+ return ("string" === r ? String : Number)(t);
250
442
  }
251
-
252
- function _nonIterableSpread() {
253
- throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
443
+ function _toPropertyKey(t) {
444
+ var i = _toPrimitive(t, "string");
445
+ return "symbol" == typeof i ? i : i + "";
254
446
  }
255
447
 
256
448
  var loadImage = function loadImage(url) {
@@ -266,71 +458,51 @@ var loadImage = function loadImage(url) {
266
458
  img.src = url;
267
459
  });
268
460
  };
269
-
270
461
  var DefaultHeightmapResource = /*#__PURE__*/function () {
271
462
  function DefaultHeightmapResource() {
272
463
  var _this = this,
273
- _opts$skipOddLevels,
274
- _opts$tileSize,
275
- _opts$maxZoom;
276
-
464
+ _opts$skipOddLevels,
465
+ _opts$tileSize,
466
+ _opts$maxZoom;
277
467
  var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
278
-
279
468
  _classCallCheck(this, DefaultHeightmapResource);
280
-
281
469
  _defineProperty(this, "resource", null);
282
-
283
470
  _defineProperty(this, "tileSize", 256);
284
-
285
- _defineProperty(this, "maxZoom", void 0);
286
-
287
471
  _defineProperty(this, "skipOddLevels", false);
288
-
289
- _defineProperty(this, "contextQueue", void 0);
290
-
291
472
  _defineProperty(this, "getTilePixels", /*#__PURE__*/function () {
292
- var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(coords) {
473
+ var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(coords) {
293
474
  var url, img;
294
- return regeneratorRuntime.wrap(function _callee$(_context) {
295
- while (1) {
296
- switch (_context.prev = _context.next) {
297
- case 0:
298
- url = _this.buildTileURL(coords);
299
- _context.next = 3;
300
- return loadImage(url);
301
-
302
- case 3:
303
- img = _context.sent;
304
- return _context.abrupt("return", _this.getPixels(img));
305
-
306
- case 5:
307
- case "end":
308
- return _context.stop();
309
- }
475
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
476
+ while (1) switch (_context.prev = _context.next) {
477
+ case 0:
478
+ url = _this.buildTileURL(coords);
479
+ _context.next = 3;
480
+ return loadImage(url);
481
+ case 3:
482
+ img = _context.sent;
483
+ return _context.abrupt("return", _this.getPixels(img));
484
+ case 5:
485
+ case "end":
486
+ return _context.stop();
310
487
  }
311
488
  }, _callee);
312
489
  }));
313
-
314
490
  return function (_x) {
315
491
  return _ref.apply(this, arguments);
316
492
  };
317
493
  }());
318
-
319
494
  if (opts.url) {
320
- this.resource = cesium.Resource.createIfNeeded(opts.url);
495
+ this.resource = Resource.createIfNeeded(opts.url);
321
496
  }
322
-
323
497
  this.skipOddLevels = (_opts$skipOddLevels = opts.skipOddLevels) !== null && _opts$skipOddLevels !== void 0 ? _opts$skipOddLevels : false;
324
498
  this.tileSize = (_opts$tileSize = opts.tileSize) !== null && _opts$tileSize !== void 0 ? _opts$tileSize : 256;
325
499
  this.maxZoom = (_opts$maxZoom = opts.maxZoom) !== null && _opts$maxZoom !== void 0 ? _opts$maxZoom : 15;
326
500
  this.contextQueue = [];
327
501
  }
328
-
329
- _createClass(DefaultHeightmapResource, [{
502
+ return _createClass(DefaultHeightmapResource, [{
330
503
  key: "getCanvas",
331
504
  value: function getCanvas() {
332
505
  var ctx = this.contextQueue.pop();
333
-
334
506
  if (ctx == null) {
335
507
  var canvas = document.createElement("canvas");
336
508
  canvas.width = this.tileSize;
@@ -341,17 +513,16 @@ var DefaultHeightmapResource = /*#__PURE__*/function () {
341
513
  context: context
342
514
  };
343
515
  }
344
-
345
516
  return ctx;
346
517
  }
347
518
  }, {
348
519
  key: "getPixels",
349
520
  value: function getPixels(img) {
350
521
  var canvasRef = this.getCanvas();
351
- var context = canvasRef.context; //context.scale(1, -1);
522
+ var context = canvasRef.context;
523
+ //context.scale(1, -1);
352
524
  // Chrome appears to vertically flip the image for reasons that are unclear
353
525
  // We can make it work in Chrome by drawing the image upside-down at this step.
354
-
355
526
  context.drawImage(img, 0, 0, this.tileSize, this.tileSize);
356
527
  var pixels = context.getImageData(0, 0, this.tileSize, this.tileSize);
357
528
  context.clearRect(0, 0, this.tileSize, this.tileSize);
@@ -362,11 +533,10 @@ var DefaultHeightmapResource = /*#__PURE__*/function () {
362
533
  key: "buildTileURL",
363
534
  value: function buildTileURL(tileCoords) {
364
535
  var _this$resource;
365
-
366
536
  // reverseY for TMS tiling (https://gist.github.com/tmcw/4954720)
367
537
  // See tiling schemes here: https://www.maptiler.com/google-maps-coordinates-tile-bounds-projection/
368
538
  var z = tileCoords.z,
369
- y = tileCoords.y;
539
+ y = tileCoords.y;
370
540
  return (_this$resource = this.resource) === null || _this$resource === void 0 ? void 0 : _this$resource.getDerivedResource({
371
541
  templateValues: _objectSpread2(_objectSpread2({}, tileCoords), {}, {
372
542
  reverseY: Math.pow(2, z) - y - 1
@@ -384,1839 +554,307 @@ var DefaultHeightmapResource = /*#__PURE__*/function () {
384
554
  return true;
385
555
  }
386
556
  }]);
387
-
388
- return DefaultHeightmapResource;
389
557
  }();
390
558
 
391
- var ImageFormat;
392
-
393
- (function (ImageFormat) {
559
+ var ImageFormat = /*#__PURE__*/function (ImageFormat) {
394
560
  ImageFormat["WEBP"] = "webp";
395
561
  ImageFormat["PNG"] = "png";
396
562
  ImageFormat["PNGRAW"] = "pngraw";
397
- })(ImageFormat || (ImageFormat = {}));
398
-
563
+ return ImageFormat;
564
+ }({});
399
565
  var MapboxTerrainResource = /*#__PURE__*/function (_DefaultHeightmapReso) {
400
- _inherits(MapboxTerrainResource, _DefaultHeightmapReso);
401
-
402
- var _super = _createSuper(MapboxTerrainResource);
403
-
404
566
  function MapboxTerrainResource() {
405
567
  var _opts$highResolution, _opts$imageFormat;
406
-
407
568
  var _this;
569
+ var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
570
+ _classCallCheck(this, MapboxTerrainResource);
571
+ _this = _callSuper(this, MapboxTerrainResource, [opts]);
572
+ _defineProperty(_this, "resource", null);
573
+ _defineProperty(_this, "credit", new Credit("Mapbox"));
574
+ var highResolution = (_opts$highResolution = opts.highResolution) !== null && _opts$highResolution !== void 0 ? _opts$highResolution : false;
575
+ var format = (_opts$imageFormat = opts.imageFormat) !== null && _opts$imageFormat !== void 0 ? _opts$imageFormat : ImageFormat.WEBP;
408
576
 
409
- var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
410
-
411
- _classCallCheck(this, MapboxTerrainResource);
412
-
413
- _this = _super.call(this, opts);
414
-
415
- _defineProperty(_assertThisInitialized(_this), "resource", null);
416
-
417
- 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; // overrides based on highResolution flag
419
-
420
- if (highResolution) {
421
- if (opts.maxZoom === undefined) {
422
- _this.maxZoom = 14;
423
- }
424
-
425
- if (opts.tileSize === undefined) {
426
- _this.tileSize = 512;
427
- }
428
- }
429
-
430
- _this.resource = cesium.Resource.createIfNeeded("https://api.mapbox.com/v4/mapbox.terrain-rgb/{z}/{x}/{y}".concat(highResolution ? "@2x" : "", ".").concat(format));
431
-
432
- if (opts.accessToken) {
433
- _this.resource.setQueryParameters({
434
- access_token: opts.accessToken
435
- });
436
- }
437
-
438
- return _this;
439
- }
440
-
441
- return _createClass(MapboxTerrainResource);
442
- }(DefaultHeightmapResource);
443
-
444
- function decodeBase64(base64, enableUnicode) {
445
- var binaryString = atob(base64);
446
- if (enableUnicode) {
447
- var binaryView = new Uint8Array(binaryString.length);
448
- for (var i = 0, n = binaryString.length; i < n; ++i) {
449
- binaryView[i] = binaryString.charCodeAt(i);
450
- }
451
- return String.fromCharCode.apply(null, new Uint16Array(binaryView.buffer));
452
- }
453
- return binaryString;
454
- }
455
-
456
- function createURL(base64, sourcemapArg, enableUnicodeArg) {
457
- var sourcemap = sourcemapArg === undefined ? null : sourcemapArg;
458
- var enableUnicode = enableUnicodeArg === undefined ? false : enableUnicodeArg;
459
- var source = decodeBase64(base64, enableUnicode);
460
- var start = source.indexOf('\n', 10) + 1;
461
- var body = source.substring(start) + (sourcemap ? '\/\/# sourceMappingURL=' + sourcemap : '');
462
- var blob = new Blob([body], { type: 'application/javascript' });
463
- return URL.createObjectURL(blob);
464
- }
465
-
466
- function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
467
- var url;
468
- return function WorkerFactory(options) {
469
- url = url || createURL(base64, sourcemapArg, enableUnicodeArg);
470
- return new Worker(url, options);
471
- };
472
- }
473
-
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);
475
- /* eslint-enable */
476
-
477
- var resolves = {};
478
- var rejects = {};
479
- var globalMsgId = 0; // Activate calculation in the worker, returning a promise
480
-
481
- function sendMessage(_x, _x2, _x3) {
482
- return _sendMessage.apply(this, arguments);
483
- } // Handle incoming calculation result
484
-
485
-
486
- function _sendMessage() {
487
- _sendMessage = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(worker, payload, transferableObjects) {
488
- var msgId, msg;
489
- return regeneratorRuntime.wrap(function _callee2$(_context2) {
490
- while (1) {
491
- switch (_context2.prev = _context2.next) {
492
- case 0:
493
- msgId = globalMsgId++;
494
- msg = {
495
- id: msgId,
496
- payload: payload
497
- };
498
- return _context2.abrupt("return", new Promise(function (resolve, reject) {
499
- // save callbacks for later
500
- resolves[msgId] = resolve;
501
- rejects[msgId] = reject;
502
- worker.postMessage(msg, transferableObjects);
503
- }));
504
-
505
- case 3:
506
- case "end":
507
- return _context2.stop();
508
- }
509
- }
510
- }, _callee2);
511
- }));
512
- return _sendMessage.apply(this, arguments);
513
- }
514
-
515
- function handleMessage(msg) {
516
- var _msg$data = msg.data,
517
- id = _msg$data.id,
518
- err = _msg$data.err,
519
- payload = _msg$data.payload;
520
-
521
- if (payload) {
522
- var resolve = resolves[id];
523
-
524
- if (resolve) {
525
- resolve(payload);
526
- }
527
- } else {
528
- // error condition
529
- var reject = rejects[id];
530
-
531
- if (reject) {
532
- if (err) {
533
- reject(err);
534
- } else {
535
- reject("Got nothing");
536
- }
537
- }
538
- } // purge used callbacks
539
-
540
-
541
- delete resolves[id];
542
- delete rejects[id];
543
- }
544
-
545
- var WorkerFarm = /*#__PURE__*/function () {
546
- function WorkerFarm() {
547
- _classCallCheck(this, WorkerFarm);
548
-
549
- _defineProperty(this, "worker", void 0);
550
-
551
- this.worker = new WorkerFactory();
552
- this.worker.onmessage = handleMessage;
553
- }
554
-
555
- _createClass(WorkerFarm, [{
556
- key: "scheduleTask",
557
- value: function () {
558
- var _scheduleTask = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(params, transferableObjects) {
559
- return regeneratorRuntime.wrap(function _callee$(_context) {
560
- while (1) {
561
- switch (_context.prev = _context.next) {
562
- case 0:
563
- _context.next = 2;
564
- return sendMessage(this.worker, params, transferableObjects);
565
-
566
- case 2:
567
- return _context.abrupt("return", _context.sent);
568
-
569
- case 3:
570
- case "end":
571
- return _context.stop();
572
- }
573
- }
574
- }, _callee, this);
575
- }));
576
-
577
- function scheduleTask(_x4, _x5) {
578
- return _scheduleTask.apply(this, arguments);
579
- }
580
-
581
- return scheduleTask;
582
- }()
583
- }]);
584
-
585
- return WorkerFarm;
586
- }();
587
-
588
- // We should save these
589
- //const canvas = new OffscreenCanvas(256, 256);
590
- //const ctx = canvas.getContext("2d");
591
- function mapboxTerrainToGrid(png, interval, offset) {
592
- var _interval, _offset;
593
-
594
- // maybe we should do this on the GPU using REGL?
595
- // but that would require GPU -> CPU -> GPU
596
- var gridSize = png.shape[0] + 1;
597
- var terrain = new Float32Array(gridSize * gridSize);
598
- var tileSize = png.shape[0];
599
- interval = (_interval = interval) !== null && _interval !== void 0 ? _interval : 0.1;
600
- offset = (_offset = offset) !== null && _offset !== void 0 ? _offset : -10000; // decode terrain values
601
-
602
- for (var y = 0; y < tileSize; y++) {
603
- for (var x = 0; x < tileSize; x++) {
604
- var yc = y;
605
- var r = png.get(x, yc, 0);
606
- var g = png.get(x, yc, 1);
607
- var b = png.get(x, yc, 2);
608
- terrain[y * gridSize + x] = r * 256 * 256 * interval + g * 256.0 * interval + b * interval + offset;
609
- }
610
- } // backfill right and bottom borders
611
-
612
-
613
- for (var _x = 0; _x < gridSize - 1; _x++) {
614
- terrain[gridSize * (gridSize - 1) + _x] = terrain[gridSize * (gridSize - 2) + _x];
615
- }
616
-
617
- for (var _y = 0; _y < gridSize; _y++) {
618
- terrain[gridSize * _y + gridSize - 1] = terrain[gridSize * _y + gridSize - 2];
619
- }
620
-
621
- return terrain;
622
- }
623
-
624
- function _emptyMesh(n) {
625
- n = Math.max(n, 2);
626
- var nTriangles = Math.pow(n - 1, 2) * 2;
627
- var nVertices = Math.pow(n, 2);
628
- var quantizedVertices = new Uint16Array(nVertices * 3);
629
- var indices = new Uint16Array(nTriangles * 3);
630
- var westIndices = [];
631
- var southIndices = [];
632
- var eastIndices = [];
633
- var northIndices = [];
634
- var tix = 0;
635
-
636
- for (var i = 0; i < nVertices; i++) {
637
- var rx = i % n; //* 32767) / (n - 1);
638
-
639
- var ry = Math.floor(i / n); //* 32767) / (n - 1);
640
-
641
- var ix = n * rx + ry;
642
- quantizedVertices[ix] = rx * 32768 / (n - 1);
643
- quantizedVertices[nVertices + ix] = ry * 32768 / (n - 1);
644
- quantizedVertices[2 * nVertices + ix] = 0;
645
- if (ry == 0) westIndices.push(ix);
646
- if (rx == 0) southIndices.push(ix);
647
- if (rx == n - 1) eastIndices.push(ix);
648
- if (ry == n - 1) northIndices.push(ix); // Add triangles
649
-
650
- var rix = i - ry * n;
651
-
652
- if (rix != n - 1) {
653
- indices[tix * 3] = i;
654
- indices[tix * 3 + 1] = i + n + 1;
655
- indices[tix * 3 + 2] = i + 1;
656
- tix++;
657
- }
658
-
659
- if (rix != 0) {
660
- indices[tix * 3] = i - 1;
661
- indices[tix * 3 + 1] = i + n - 1;
662
- indices[tix * 3 + 2] = i + n;
663
- tix++;
664
- }
665
- }
666
-
667
- return {
668
- minimumHeight: 0,
669
- maximumHeight: 0,
670
- quantizedVertices: quantizedVertices,
671
- indices: indices,
672
- westIndices: westIndices,
673
- southIndices: southIndices,
674
- eastIndices: eastIndices,
675
- northIndices: northIndices
676
- };
677
- }
678
-
679
- var _meshCache = [];
680
- function emptyMesh(n) {
681
- // A memoized function to return empty meshes
682
- if (n in _meshCache) {
683
- return _meshCache[n];
684
- } else {
685
- var result = _emptyMesh(n);
686
-
687
- _meshCache[n] = result;
688
- return result;
689
- }
690
- }
691
-
692
- function createQuantizedMeshData(tile, mesh, tileSize) {
693
- var xvals = [];
694
- var yvals = [];
695
- var heightMeters = [];
696
- var northIndices = [];
697
- var southIndices = [];
698
- var eastIndices = [];
699
- var westIndices = [];
700
- var minimumHeight = Infinity;
701
- var maximumHeight = -Infinity;
702
- var scalar = 32768.0 / tileSize;
703
-
704
- for (var ix = 0; ix < mesh.vertices.length / 2; ix++) {
705
- var vertexIx = ix;
706
- var px = mesh.vertices[ix * 2];
707
- var py = mesh.vertices[ix * 2 + 1];
708
- var height = tile.terrain[py * (tileSize + 1) + px];
709
- if (height > maximumHeight) maximumHeight = height;
710
- if (height < minimumHeight) minimumHeight = height;
711
- heightMeters.push(height);
712
- if (py == 0) northIndices.push(vertexIx);
713
- if (py == tileSize) southIndices.push(vertexIx);
714
- if (px == 0) westIndices.push(vertexIx);
715
- if (px == tileSize) eastIndices.push(vertexIx);
716
- var xv = px * scalar;
717
- var yv = (tileSize - py) * scalar;
718
- xvals.push(xv);
719
- yvals.push(yv);
720
- }
721
-
722
- var heightRange = maximumHeight - minimumHeight;
723
- var heights = heightMeters.map(function (d) {
724
- if (heightRange < 1) return 0;
725
- return (d - minimumHeight) * (32767.0 / heightRange);
726
- });
727
- var triangles = new Uint16Array(mesh.triangles);
728
- var quantizedVertices = new Uint16Array( //verts
729
- [].concat(xvals, yvals, _toConsumableArray(heights))); // SE NW NE
730
- // NE NW SE
731
-
732
- return {
733
- minimumHeight: minimumHeight,
734
- maximumHeight: maximumHeight,
735
- quantizedVertices: quantizedVertices,
736
- indices: triangles,
737
- westIndices: westIndices,
738
- southIndices: southIndices,
739
- eastIndices: eastIndices,
740
- northIndices: northIndices
741
- };
742
- }
743
-
744
- function iota(n) {
745
- var result = new Array(n);
746
- for(var i=0; i<n; ++i) {
747
- result[i] = i;
748
- }
749
- return result
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
- }
774
-
775
- var hasTypedArrays = ((typeof Float64Array) !== "undefined");
776
-
777
- function compare1st(a, b) {
778
- return a[0] - b[0]
779
- }
780
-
781
- function order() {
782
- var stride = this.stride;
783
- var terms = new Array(stride.length);
784
- var i;
785
- for(i=0; i<terms.length; ++i) {
786
- terms[i] = [Math.abs(stride[i]), i];
787
- }
788
- terms.sort(compare1st);
789
- var result = new Array(terms.length);
790
- for(i=0; i<result.length; ++i) {
791
- result[i] = terms[i][1];
792
- }
793
- return result
794
- }
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
- class Tile {
1180
- constructor(terrain, martini) {
1181
- const size = martini.gridSize;
1182
- if (terrain.length !== size * size) throw new Error(`Expected terrain data of length ${size * size} (${size} x ${size}), got ${terrain.length}.`);
1183
- this.terrain = terrain;
1184
- this.martini = martini;
1185
- this.errors = new Float32Array(terrain.length);
1186
- this.update();
1187
- }
1188
-
1189
- update() {
1190
- const {
1191
- numTriangles,
1192
- numParentTriangles,
1193
- coords,
1194
- gridSize: size
1195
- } = this.martini;
1196
- const {
1197
- terrain,
1198
- errors
1199
- } = this; // iterate over all possible triangles, starting from the smallest level
1200
-
1201
- for (let i = numTriangles - 1; i >= 0; i--) {
1202
- const k = i * 4;
1203
- const ax = coords[k + 0];
1204
- const ay = coords[k + 1];
1205
- const bx = coords[k + 2];
1206
- const by = coords[k + 3];
1207
- const mx = ax + bx >> 1;
1208
- const my = ay + by >> 1;
1209
- const cx = mx + my - ay;
1210
- const cy = my + ax - mx; // calculate error in the middle of the long edge of the triangle
1211
-
1212
- const interpolatedHeight = (terrain[ay * size + ax] + terrain[by * size + bx]) / 2;
1213
- const middleIndex = my * size + mx;
1214
- const middleError = Math.abs(interpolatedHeight - terrain[middleIndex]);
1215
- errors[middleIndex] = Math.max(errors[middleIndex], middleError);
1216
-
1217
- if (i < numParentTriangles) {
1218
- // bigger triangles; accumulate error with children
1219
- const leftChildIndex = (ay + cy >> 1) * size + (ax + cx >> 1);
1220
- const rightChildIndex = (by + cy >> 1) * size + (bx + cx >> 1);
1221
- errors[middleIndex] = Math.max(errors[middleIndex], errors[leftChildIndex], errors[rightChildIndex]);
1222
- }
1223
- }
1224
- }
1225
-
1226
- getMesh(maxError = 0, maxLength = null) {
1227
- const {
1228
- gridSize: size,
1229
- indices
1230
- } = this.martini;
1231
- const {
1232
- errors
1233
- } = this;
1234
- let numVertices = 0;
1235
- let numTriangles = 0;
1236
- const max = size - 1; // The maxLength parameter will cause triangles to be generated until the legs are below this length
1237
- // It is meant to support cases where a certain mesh density is required to do spherical math on digital globes
1238
-
1239
- const maxScale = maxLength || size; // use an index grid to keep track of vertices that were already used to avoid duplication
1240
-
1241
- indices.fill(0); // retrieve mesh in two stages that both traverse the error map:
1242
- // - countElements: find used vertices (and assign each an index), and count triangles (for minimum allocation)
1243
- // - processTriangle: fill the allocated vertices & triangles typed arrays
1244
-
1245
- function countElements(ax, ay, bx, by, cx, cy) {
1246
- const mx = ax + bx >> 1;
1247
- const my = ay + by >> 1;
1248
- const legLength = Math.abs(ax - cx) + Math.abs(ay - cy);
1249
-
1250
- if (legLength > 1 && errors[my * size + mx] > maxError || legLength > maxScale) {
1251
- countElements(cx, cy, ax, ay, mx, my);
1252
- countElements(bx, by, cx, cy, mx, my);
1253
- } else {
1254
- indices[ay * size + ax] = indices[ay * size + ax] || ++numVertices;
1255
- indices[by * size + bx] = indices[by * size + bx] || ++numVertices;
1256
- indices[cy * size + cx] = indices[cy * size + cx] || ++numVertices;
1257
- numTriangles++;
1258
- }
1259
- }
1260
-
1261
- countElements(0, 0, max, max, max, 0);
1262
- countElements(max, max, 0, 0, 0, max);
1263
- const vertices = new Uint16Array(numVertices * 2);
1264
- const triangles = new Uint32Array(numTriangles * 3);
1265
- let triIndex = 0;
1266
-
1267
- function processTriangle(ax, ay, bx, by, cx, cy) {
1268
- const mx = ax + bx >> 1;
1269
- const my = ay + by >> 1;
1270
- const legLength = Math.abs(ax - cx) + Math.abs(ay - cy);
1271
-
1272
- if (legLength > 1 && errors[my * size + mx] > maxError || legLength > maxScale) {
1273
- // triangle doesn't approximate the surface well enough; drill down further
1274
- processTriangle(cx, cy, ax, ay, mx, my);
1275
- processTriangle(bx, by, cx, cy, mx, my);
1276
- } else {
1277
- // add a triangle
1278
- const a = indices[ay * size + ax] - 1;
1279
- const b = indices[by * size + bx] - 1;
1280
- const c = indices[cy * size + cx] - 1;
1281
- vertices[2 * a] = ax;
1282
- vertices[2 * a + 1] = ay;
1283
- vertices[2 * b] = bx;
1284
- vertices[2 * b + 1] = by;
1285
- vertices[2 * c] = cx;
1286
- vertices[2 * c + 1] = cy;
1287
- triangles[triIndex++] = a;
1288
- triangles[triIndex++] = b;
1289
- triangles[triIndex++] = c;
1290
- }
1291
- }
1292
-
1293
- processTriangle(0, 0, max, max, max, 0);
1294
- processTriangle(max, max, 0, 0, 0, max);
1295
- return {
1296
- vertices,
1297
- triangles
1298
- };
1299
- }
1300
-
1301
- }
1302
-
1303
- function createCommonjsModule(fn) {
1304
- var module = { exports: {} };
1305
- return fn(module, module.exports), module.exports;
1306
- }
1307
-
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;
577
+ // overrides based on highResolution flag
578
+ if (highResolution) {
579
+ if (opts.maxZoom === undefined) {
580
+ _this.maxZoom = 14;
581
+ }
582
+ if (opts.tileSize === undefined) {
583
+ _this.tileSize = 512;
2023
584
  }
2024
-
2025
- return ContinueSentinel;
2026
585
  }
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;
586
+ _this.resource = Resource.createIfNeeded("https://api.mapbox.com/v4/mapbox.terrain-rgb/{z}/{x}/{y}".concat(highResolution ? "@2x" : "", ".").concat(format));
587
+ if (opts.accessToken) {
588
+ _this.resource.setQueryParameters({
589
+ access_token: opts.accessToken
590
+ });
591
+ }
592
+ return _this;
593
+ }
594
+ _inherits(MapboxTerrainResource, _DefaultHeightmapReso);
595
+ return _createClass(MapboxTerrainResource);
596
+ }(DefaultHeightmapResource);
2034
597
 
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
- ));
598
+ function _emptyMesh(n) {
599
+ n = Math.max(n, 2);
600
+ var nTriangles = Math.pow(n - 1, 2) * 2;
601
+ var nVertices = Math.pow(n, 2);
602
+ var quantizedVertices = new Uint16Array(nVertices * 3);
603
+ var indices = new Uint16Array(nTriangles * 3);
604
+ var westIndices = [];
605
+ var southIndices = [];
606
+ var eastIndices = [];
607
+ var northIndices = [];
608
+ var tix = 0;
609
+ for (var i = 0; i < nVertices; i++) {
610
+ var rx = i % n; //* 32767) / (n - 1);
611
+ var ry = Math.floor(i / n); //* 32767) / (n - 1);
612
+ var ix = n * rx + ry;
613
+ quantizedVertices[ix] = rx * 32768 / (n - 1);
614
+ quantizedVertices[nVertices + ix] = ry * 32768 / (n - 1);
615
+ quantizedVertices[2 * nVertices + ix] = 0;
616
+ if (ry == 0) westIndices.push(ix);
617
+ if (rx == 0) southIndices.push(ix);
618
+ if (rx == n - 1) eastIndices.push(ix);
619
+ if (ry == n - 1) northIndices.push(ix);
2042
620
 
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;
621
+ // Add triangles
622
+ var rix = i - ry * n;
623
+ if (rix != n - 1) {
624
+ indices[tix * 3] = i;
625
+ indices[tix * 3 + 1] = i + n + 1;
626
+ indices[tix * 3 + 2] = i + 1;
627
+ tix++;
628
+ }
629
+ if (rix != 0) {
630
+ indices[tix * 3] = i - 1;
631
+ indices[tix * 3 + 1] = i + n - 1;
632
+ indices[tix * 3 + 2] = i + n;
633
+ tix++;
634
+ }
635
+ }
636
+ return {
637
+ minimumHeight: 0,
638
+ maximumHeight: 0,
639
+ quantizedVertices: quantizedVertices,
640
+ indices: indices,
641
+ westIndices: westIndices,
642
+ southIndices: southIndices,
643
+ eastIndices: eastIndices,
644
+ northIndices: northIndices
645
+ };
646
+ }
647
+ var _meshCache = [];
648
+ function emptyMesh(n) {
649
+ // A memoized function to return empty meshes
650
+ if (n in _meshCache) {
651
+ return _meshCache[n];
2058
652
  } else {
2059
- Function("r", "regeneratorRuntime = r")(runtime);
653
+ var result = _emptyMesh(n);
654
+ _meshCache[n] = result;
655
+ return result;
2060
656
  }
2061
657
  }
2062
- });
2063
-
2064
- var martini = null;
2065
-
2066
- function decodeTerrain(parameters, transferableObjects) {
2067
- var _martini;
2068
-
2069
- var imageData = parameters.imageData,
2070
- _parameters$tileSize = parameters.tileSize,
2071
- tileSize = _parameters$tileSize === void 0 ? 256 : _parameters$tileSize,
2072
- errorLevel = parameters.errorLevel,
2073
- interval = parameters.interval,
2074
- offset = parameters.offset;
2075
- var pixels = ndarray(new Uint8Array(imageData), [tileSize, tileSize, 4], [4, 4 * tileSize, 1], 0); // Tile size must be maintained through the life of the worker
2076
-
2077
- (_martini = martini) !== null && _martini !== void 0 ? _martini : martini = new Martini(tileSize + 1);
2078
- var terrain = mapboxTerrainToGrid(pixels, interval, offset);
2079
- var tile = martini.createTile(terrain); // get a mesh (vertices and triangles indices) for a 10m error
2080
658
 
2081
- var mesh = tile.getMesh(errorLevel, parameters.maxLength);
2082
- return createQuantizedMeshData(tile, mesh, tileSize);
659
+ var resolves = {};
660
+ var rejects = {};
661
+ var globalMsgId = 0; // Activate calculation in the worker, returning a promise
662
+ function sendMessage(_x, _x2, _x3) {
663
+ return _sendMessage.apply(this, arguments);
664
+ } // Handle incoming calculation result
665
+ function _sendMessage() {
666
+ _sendMessage = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee2(worker, payload, transferableObjects) {
667
+ var msgId, msg;
668
+ return _regeneratorRuntime().wrap(function _callee2$(_context2) {
669
+ while (1) switch (_context2.prev = _context2.next) {
670
+ case 0:
671
+ msgId = globalMsgId++;
672
+ msg = {
673
+ id: msgId,
674
+ payload: payload
675
+ };
676
+ return _context2.abrupt("return", new Promise(function (resolve, reject) {
677
+ // save callbacks for later
678
+ resolves[msgId] = resolve;
679
+ rejects[msgId] = reject;
680
+ worker.postMessage(msg, transferableObjects);
681
+ }));
682
+ case 3:
683
+ case "end":
684
+ return _context2.stop();
685
+ }
686
+ }, _callee2);
687
+ }));
688
+ return _sendMessage.apply(this, arguments);
2083
689
  }
2084
-
2085
- self.onmessage = function (msg) {
690
+ function handleMessage(msg) {
2086
691
  var _msg$data = msg.data,
2087
- id = _msg$data.id,
2088
- payload = _msg$data.payload;
2089
- if (id == null) return;
2090
- var objects = [];
2091
- var res = null;
2092
-
2093
- try {
2094
- res = decodeTerrain(payload);
2095
- objects.push(res.indices.buffer);
2096
- objects.push(res.quantizedVertices.buffer);
2097
- self.postMessage({
2098
- id: id,
2099
- payload: res
2100
- }, objects);
2101
- } catch (err) {
2102
- self.postMessage({
2103
- id: id,
2104
- err: err.toString()
2105
- });
2106
- } finally {
2107
- res = null;
2108
- objects = null;
692
+ id = _msg$data.id,
693
+ err = _msg$data.err,
694
+ payload = _msg$data.payload;
695
+ if (payload) {
696
+ var resolve = resolves[id];
697
+ if (resolve) {
698
+ resolve(payload);
699
+ }
700
+ } else {
701
+ // error condition
702
+ var reject = rejects[id];
703
+ if (reject) {
704
+ if (err) {
705
+ reject(err);
706
+ } else {
707
+ reject("Got nothing");
708
+ }
709
+ }
2109
710
  }
2110
- };
2111
711
 
2112
- var StretchedTilingScheme = /*#__PURE__*/function (_WebMercatorTilingSch) {
2113
- _inherits(StretchedTilingScheme, _WebMercatorTilingSch);
712
+ // purge used callbacks
713
+ delete resolves[id];
714
+ delete rejects[id];
715
+ }
716
+ var WorkerFarm = /*#__PURE__*/function () {
717
+ function WorkerFarm(opts) {
718
+ _classCallCheck(this, WorkerFarm);
719
+ this.worker = opts.worker;
720
+ this.worker.onmessage = handleMessage;
721
+ }
722
+ return _createClass(WorkerFarm, [{
723
+ key: "scheduleTask",
724
+ value: function () {
725
+ var _scheduleTask = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(params, transferableObjects) {
726
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
727
+ while (1) switch (_context.prev = _context.next) {
728
+ case 0:
729
+ _context.next = 2;
730
+ return sendMessage(this.worker, params, transferableObjects);
731
+ case 2:
732
+ return _context.abrupt("return", _context.sent);
733
+ case 3:
734
+ case "end":
735
+ return _context.stop();
736
+ }
737
+ }, _callee, this);
738
+ }));
739
+ function scheduleTask(_x4, _x5) {
740
+ return _scheduleTask.apply(this, arguments);
741
+ }
742
+ return scheduleTask;
743
+ }()
744
+ }]);
745
+ }();
2114
746
 
2115
- var _super = _createSuper(StretchedTilingScheme);
747
+ var DefaultTerrainDecoder = /*#__PURE__*/function () {
748
+ function DefaultTerrainDecoder() {
749
+ _classCallCheck(this, DefaultTerrainDecoder);
750
+ _defineProperty(this, "inProgress", 0);
751
+ _defineProperty(this, "maxRequests", 2);
752
+ }
753
+ return _createClass(DefaultTerrainDecoder, [{
754
+ key: "requestTileGeometry",
755
+ value: function requestTileGeometry(coords, processFunction) {
756
+ var _this = this;
757
+ if (this.inProgress > this.maxRequests) return undefined;
758
+ this.inProgress += 1;
759
+ return processFunction(coords)["finally"](function () {
760
+ _this.inProgress -= 1;
761
+ });
762
+ }
763
+ }, {
764
+ key: "decodeTerrain",
765
+ value: function decodeTerrain(params, data) {
766
+ return Promise.resolve(null);
767
+ }
768
+ }]);
769
+ }();
770
+ var WorkerFarmTerrainDecoder = /*#__PURE__*/function (_DefaultTerrainDecode) {
771
+ function WorkerFarmTerrainDecoder(opts) {
772
+ var _opts$maxWorkers;
773
+ var _this2;
774
+ _classCallCheck(this, WorkerFarmTerrainDecoder);
775
+ _this2 = _callSuper(this, WorkerFarmTerrainDecoder);
776
+ _this2.farm = new WorkerFarm({
777
+ worker: opts.worker
778
+ });
779
+ _this2.maxRequests = (_opts$maxWorkers = opts.maxWorkers) !== null && _opts$maxWorkers !== void 0 ? _opts$maxWorkers : 5;
780
+ return _this2;
781
+ }
782
+ _inherits(WorkerFarmTerrainDecoder, _DefaultTerrainDecode);
783
+ return _createClass(WorkerFarmTerrainDecoder, [{
784
+ key: "decodeTerrain",
785
+ value: function decodeTerrain(params, data) {
786
+ return this.farm.scheduleTask(params, [data]);
787
+ }
788
+ }]);
789
+ }(DefaultTerrainDecoder);
2116
790
 
791
+ // https://github.com/CesiumGS/cesium/blob/1.68/Source/Scene/MapboxImageryProvider.js#L42
792
+ var StretchedTilingScheme = /*#__PURE__*/function (_WebMercatorTilingSch) {
2117
793
  function StretchedTilingScheme() {
2118
794
  _classCallCheck(this, StretchedTilingScheme);
2119
-
2120
- return _super.apply(this, arguments);
795
+ return _callSuper(this, StretchedTilingScheme, arguments);
2121
796
  }
2122
-
2123
- _createClass(StretchedTilingScheme, [{
797
+ _inherits(StretchedTilingScheme, _WebMercatorTilingSch);
798
+ return _createClass(StretchedTilingScheme, [{
2124
799
  key: "tileXYToRectangle",
2125
800
  value: function tileXYToRectangle(x, y, level, res) {
2126
- var result = _get(_getPrototypeOf(StretchedTilingScheme.prototype), "tileXYToRectangle", this).call(this, x, y, level);
2127
-
801
+ var result = _superPropGet(StretchedTilingScheme, "tileXYToRectangle", this, 3)([x, y, level]);
2128
802
  if (y == 0) {
2129
803
  //console.log("Top row", res, y, level);
2130
804
  result.north = Math.PI / 2;
2131
805
  }
2132
-
2133
806
  if (y + 1 == Math.pow(2, level)) {
2134
807
  result.south = -Math.PI / 2;
2135
808
  }
2136
-
2137
809
  return result;
2138
810
  }
2139
811
  }]);
2140
-
2141
- return StretchedTilingScheme;
2142
- }(cesium.WebMercatorTilingScheme);
2143
-
812
+ }(WebMercatorTilingScheme);
2144
813
  var MartiniTerrainProvider = /*#__PURE__*/function () {
2145
814
  // @ts-ignore
2146
815
  function MartiniTerrainProvider() {
2147
- var _opts$interval, _opts$offset, _opts$maxWorkers, _opts$minZoomLevel, _opts$fillPoles, _opts$detailScalar, _opts$minimumErrorLev, _opts$ellipsoid;
2148
-
816
+ var _this$resource$credit, _opts$minZoomLevel, _opts$fillPoles, _opts$detailScalar, _opts$minimumErrorLev, _opts$ellipsoid;
2149
817
  var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2150
-
2151
818
  _classCallCheck(this, MartiniTerrainProvider);
2152
-
2153
819
  _defineProperty(this, "hasWaterMask", false);
2154
-
2155
820
  _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
-
821
+ _defineProperty(this, "credit", new Credit("Mapbox"));
2163
822
  _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
-
2171
- _defineProperty(this, "workerFarm", null);
2172
-
2173
- _defineProperty(this, "inProgressWorkers", 0);
2174
-
823
+ _defineProperty(this, "errorEvent", new Event());
2175
824
  _defineProperty(this, "levelOfDetailScalar", null);
2176
-
2177
- _defineProperty(this, "maxWorkers", 5);
2178
-
2179
825
  _defineProperty(this, "minError", 0.1);
2180
-
2181
- _defineProperty(this, "minZoomLevel", void 0);
2182
-
2183
826
  _defineProperty(this, "fillPoles", true);
2184
-
2185
827
  _defineProperty(this, "_errorAtMinZoom", 1000);
2186
-
2187
828
  _defineProperty(this, "resource", null);
2188
-
2189
- _defineProperty(this, "interval", void 0);
2190
-
2191
- _defineProperty(this, "offset", void 0);
2192
-
829
+ _defineProperty(this, "decoder", null);
2193
830
  _defineProperty(this, "RADIUS_SCALAR", 1.0);
2194
-
2195
831
  //this.martini = new Martini(257);
2196
832
  this.resource = opts.resource;
2197
- this.interval = (_opts$interval = opts.interval) !== null && _opts$interval !== void 0 ? _opts$interval : 0.1;
2198
- this.offset = (_opts$offset = opts.offset) !== null && _opts$offset !== void 0 ? _opts$offset : -10000;
2199
- this.maxWorkers = (_opts$maxWorkers = opts.maxWorkers) !== null && _opts$maxWorkers !== void 0 ? _opts$maxWorkers : 5;
833
+ this.credit = (_this$resource$credit = this.resource.credit) !== null && _this$resource$credit !== void 0 ? _this$resource$credit : new Credit("Mapbox");
834
+ this.decoder = opts.decoder;
835
+ if (!this.decoder) {
836
+ var _opts$maxWorkers;
837
+ var maxWorkers = (_opts$maxWorkers = opts.maxWorkers) !== null && _opts$maxWorkers !== void 0 ? _opts$maxWorkers : 5;
838
+ if (maxWorkers > 0) {
839
+ this.decoder = new WorkerFarmTerrainDecoder({
840
+ maxWorkers: maxWorkers
841
+ });
842
+ } else {
843
+ this.decoder = new DefaultTerrainDecoder();
844
+ }
845
+ }
2200
846
  this.minZoomLevel = (_opts$minZoomLevel = opts.minZoomLevel) !== null && _opts$minZoomLevel !== void 0 ? _opts$minZoomLevel : 3;
2201
847
  this.fillPoles = (_opts$fillPoles = opts.fillPoles) !== null && _opts$fillPoles !== void 0 ? _opts$fillPoles : true;
2202
- console.log("fillPoles", this.fillPoles);
2203
- this.levelOfDetailScalar = ((_opts$detailScalar = opts.detailScalar) !== null && _opts$detailScalar !== void 0 ? _opts$detailScalar : 4.0) + cesium.Math.EPSILON5;
848
+ this.levelOfDetailScalar = ((_opts$detailScalar = opts.detailScalar) !== null && _opts$detailScalar !== void 0 ? _opts$detailScalar : 4.0) + Math$1.EPSILON5;
2204
849
  this.ready = true;
2205
850
  this.readyPromise = Promise.resolve(true);
2206
851
  this.minError = (_opts$minimumErrorLev = opts.minimumErrorLevel) !== null && _opts$minimumErrorLev !== void 0 ? _opts$minimumErrorLev : 0.1;
2207
852
  this.errorEvent.addEventListener(console.log, this);
2208
- this.ellipsoid = (_opts$ellipsoid = opts.ellipsoid) !== null && _opts$ellipsoid !== void 0 ? _opts$ellipsoid : cesium.Ellipsoid.WGS84;
2209
-
2210
- if (this.maxWorkers > 0) {
2211
- this.workerFarm = new WorkerFarm();
2212
- }
2213
-
2214
- var scheme = cesium.WebMercatorTilingScheme;
2215
-
853
+ this.ellipsoid = (_opts$ellipsoid = opts.ellipsoid) !== null && _opts$ellipsoid !== void 0 ? _opts$ellipsoid : Ellipsoid.WGS84;
854
+ var scheme = WebMercatorTilingScheme;
2216
855
  if (this.fillPoles) {
2217
856
  scheme = StretchedTilingScheme;
2218
857
  }
2219
-
2220
858
  this.tilingScheme = new scheme({
2221
859
  numberOfLevelZeroTilesX: 1,
2222
860
  numberOfLevelZeroTilesY: 1,
@@ -2224,104 +862,76 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
2224
862
  });
2225
863
  this._errorAtMinZoom = this.errorAtZoom(this.minZoomLevel);
2226
864
  }
2227
-
2228
- _createClass(MartiniTerrainProvider, [{
865
+ return _createClass(MartiniTerrainProvider, [{
2229
866
  key: "requestTileGeometry",
2230
867
  value: function requestTileGeometry(x, y, z, request) {
2231
- var _this = this;
2232
-
2233
868
  // Look for tiles both below the zoom level and below the error threshold for the zoom level at the equator...
2234
869
  if (z < this.minZoomLevel || this.scaledErrorForTile(x, y, z) > this._errorAtMinZoom) {
2235
870
  // If we are below the minimum zoom level, we return empty heightmaps
2236
871
  // to avoid unnecessary requests for low-resolution data.
2237
872
  return Promise.resolve(this.emptyMesh(x, y, z));
2238
- } // Note: we still load a TON of tiles near the poles. We might need to do some overzooming here...
2239
-
2240
-
2241
- if (this.inProgressWorkers > this.maxWorkers) return undefined;
2242
- this.inProgressWorkers += 1;
2243
- return this.processTile(x, y, z)["finally"](function () {
2244
- _this.inProgressWorkers -= 1;
2245
- });
873
+ }
874
+ // Note: we still load a TON of tiles near the poles. We might need to do some overzooming here...
875
+ return this.decoder.requestTileGeometry({
876
+ x: x,
877
+ y: y,
878
+ z: z
879
+ }, this.processTile.bind(this));
2246
880
  }
2247
881
  }, {
2248
882
  key: "processTile",
2249
883
  value: function () {
2250
- var _processTile = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(x, y, z) {
2251
- var _this$resource, tileSize, getTilePixels, px, pixelData, tileRect, err, maxLength, params, res;
2252
-
2253
- return regeneratorRuntime.wrap(function _callee$(_context) {
2254
- while (1) {
2255
- switch (_context.prev = _context.next) {
2256
- case 0:
2257
- _context.prev = 0;
2258
- _this$resource = this.resource, tileSize = _this$resource.tileSize, getTilePixels = _this$resource.getTilePixels;
2259
- _context.next = 4;
2260
- return getTilePixels({
2261
- x: x,
2262
- y: y,
2263
- z: z
2264
- });
2265
-
2266
- case 4:
2267
- px = _context.sent;
2268
- pixelData = px.data;
2269
- tileRect = this.tilingScheme.tileXYToRectangle(x, y, z); ///const center = Rectangle.center(tileRect);
2270
-
2271
- err = this.errorAtZoom(z);
2272
- maxLength = this.maxVertexDistance(tileRect);
2273
- params = {
2274
- imageData: pixelData,
2275
- maxLength: maxLength,
2276
- x: x,
2277
- y: y,
2278
- z: z,
2279
- errorLevel: err,
2280
- ellipsoidRadius: this.ellipsoid.maximumRadius,
2281
- tileSize: tileSize,
2282
- interval: this.interval,
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;
2297
- break;
2298
-
2299
- case 16:
2300
- res = decodeTerrain(params);
2301
-
2302
- case 17:
2303
- pixelData = undefined;
2304
- px = undefined;
2305
- return _context.abrupt("return", this.createQuantizedMeshData(tileRect, err, res));
2306
-
2307
- case 22:
2308
- _context.prev = 22;
2309
- _context.t0 = _context["catch"](0);
2310
- console.log(_context.t0);
2311
- return _context.abrupt("return", this.emptyMesh(x, y, z));
2312
-
2313
- case 26:
2314
- case "end":
2315
- return _context.stop();
2316
- }
884
+ var _processTile = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(_ref) {
885
+ var x, y, z, _this$resource, tileSize, getTilePixels, px, pixelData, tileRect, err, maxLength, params, res;
886
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
887
+ while (1) switch (_context.prev = _context.next) {
888
+ case 0:
889
+ x = _ref.x, y = _ref.y, z = _ref.z;
890
+ _context.prev = 1;
891
+ _this$resource = this.resource, tileSize = _this$resource.tileSize, getTilePixels = _this$resource.getTilePixels;
892
+ _context.next = 5;
893
+ return getTilePixels({
894
+ x: x,
895
+ y: y,
896
+ z: z
897
+ });
898
+ case 5:
899
+ px = _context.sent;
900
+ pixelData = px.data;
901
+ tileRect = this.tilingScheme.tileXYToRectangle(x, y, z); ///const center = Rectangle.center(tileRect);
902
+ err = this.errorAtZoom(z);
903
+ maxLength = this.maxVertexDistance(tileRect);
904
+ params = {
905
+ imageData: pixelData,
906
+ maxLength: maxLength,
907
+ x: x,
908
+ y: y,
909
+ z: z,
910
+ errorLevel: err,
911
+ ellipsoidRadius: this.ellipsoid.maximumRadius,
912
+ tileSize: tileSize
913
+ };
914
+ _context.next = 13;
915
+ return this.decoder.decodeTerrain(params, pixelData.buffer);
916
+ case 13:
917
+ res = _context.sent;
918
+ pixelData = undefined;
919
+ px = undefined;
920
+ return _context.abrupt("return", this.createQuantizedMeshData(tileRect, err, res));
921
+ case 19:
922
+ _context.prev = 19;
923
+ _context.t0 = _context["catch"](1);
924
+ console.log(_context.t0);
925
+ return _context.abrupt("return", this.emptyMesh(x, y, z));
926
+ case 23:
927
+ case "end":
928
+ return _context.stop();
2317
929
  }
2318
- }, _callee, this, [[0, 22]]);
930
+ }, _callee, this, [[1, 19]]);
2319
931
  }));
2320
-
2321
- function processTile(_x, _x2, _x3) {
932
+ function processTile(_x) {
2322
933
  return _processTile.apply(this, arguments);
2323
934
  }
2324
-
2325
935
  return processTile;
2326
936
  }()
2327
937
  }, {
@@ -2333,8 +943,8 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
2333
943
  key: "scaledErrorForTile",
2334
944
  value: function scaledErrorForTile(x, y, z) {
2335
945
  var tileRect = this.tilingScheme.tileXYToRectangle(x, y, z);
2336
- var center = cesium.Rectangle.center(tileRect);
2337
- return this.errorAtZoom(z) / (1 - Math.sin(center.latitude));
946
+ var center = Rectangle.center(tileRect);
947
+ return this.errorAtZoom(z) / Math.pow(1 - Math.sin(center.latitude), 2);
2338
948
  }
2339
949
  }, {
2340
950
  key: "maxVertexDistance",
@@ -2345,12 +955,10 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
2345
955
  key: "emptyMesh",
2346
956
  value: function emptyMesh$1(x, y, z) {
2347
957
  var tileRect = this.tilingScheme.tileXYToRectangle(x, y, z);
2348
- var center = cesium.Rectangle.center(tileRect);
958
+ var center = Rectangle.center(tileRect);
2349
959
  var latScalar = Math.min(Math.abs(Math.sin(center.latitude)), 0.995);
2350
960
  var v = Math.max(Math.ceil(200 / (z + 1) * Math.pow(1 - latScalar, 0.25)), 4);
2351
-
2352
961
  var output = emptyMesh(v);
2353
-
2354
962
  var err = this.errorAtZoom(z);
2355
963
  return this.createQuantizedMeshData(tileRect, err, output);
2356
964
  }
@@ -2358,34 +966,36 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
2358
966
  key: "createQuantizedMeshData",
2359
967
  value: function createQuantizedMeshData(tileRect, errorLevel, workerOutput) {
2360
968
  var minimumHeight = workerOutput.minimumHeight,
2361
- maximumHeight = workerOutput.maximumHeight,
2362
- quantizedVertices = workerOutput.quantizedVertices,
2363
- indices = workerOutput.indices,
2364
- westIndices = workerOutput.westIndices,
2365
- southIndices = workerOutput.southIndices,
2366
- eastIndices = workerOutput.eastIndices,
2367
- northIndices = workerOutput.northIndices;
969
+ maximumHeight = workerOutput.maximumHeight,
970
+ quantizedVertices = workerOutput.quantizedVertices,
971
+ indices = workerOutput.indices,
972
+ westIndices = workerOutput.westIndices,
973
+ southIndices = workerOutput.southIndices,
974
+ eastIndices = workerOutput.eastIndices,
975
+ northIndices = workerOutput.northIndices;
2368
976
  var err = errorLevel;
2369
977
  var skirtHeight = err * 20;
2370
- var center = cesium.Rectangle.center(tileRect); // Calculating occlusion height is kind of messy currently, but it definitely works
978
+ var center = Rectangle.center(tileRect);
2371
979
 
980
+ // Calculating occlusion height is kind of messy currently, but it definitely works
2372
981
  var halfAngle = tileRect.width / 2;
2373
982
  var dr = Math.cos(halfAngle); // half tile width since our ref point is at the center
2374
983
 
2375
984
  var occlusionHeight = dr * this.ellipsoid.maximumRadius + maximumHeight;
2376
-
2377
985
  if (halfAngle > Math.PI / 4) {
2378
986
  occlusionHeight = (1 + halfAngle) * this.ellipsoid.maximumRadius;
2379
987
  }
2380
-
2381
- var occlusionPoint = new cesium.Cartographic(center.longitude, center.latitude, occlusionHeight // Scaling factor of two just to be sure.
988
+ var occlusionPoint = new Cartographic(center.longitude, center.latitude, occlusionHeight
989
+ // Scaling factor of two just to be sure.
2382
990
  );
2383
- var horizonOcclusionPoint = this.ellipsoid.transformPositionToScaledSpace(cesium.Cartographic.toCartesian(occlusionPoint));
2384
- var orientedBoundingBox = cesium.OrientedBoundingBox.fromRectangle(tileRect, minimumHeight, maximumHeight, this.tilingScheme.ellipsoid);
2385
- var boundingSphere = cesium.BoundingSphere.fromOrientedBoundingBox(orientedBoundingBox); // SE NW NE
991
+ var horizonOcclusionPoint = this.ellipsoid.transformPositionToScaledSpace(Cartographic.toCartesian(occlusionPoint));
992
+ var orientedBoundingBox = OrientedBoundingBox.fromRectangle(tileRect, minimumHeight, maximumHeight, this.tilingScheme.ellipsoid);
993
+ var boundingSphere = BoundingSphere.fromOrientedBoundingBox(orientedBoundingBox);
994
+
995
+ // SE NW NE
2386
996
  // NE NW SE
2387
997
 
2388
- var result = new cesium.QuantizedMeshTerrainData({
998
+ var result = new QuantizedMeshTerrainData({
2389
999
  minimumHeight: minimumHeight,
2390
1000
  maximumHeight: maximumHeight,
2391
1001
  quantizedVertices: quantizedVertices,
@@ -2408,9 +1018,10 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
2408
1018
  }, {
2409
1019
  key: "getLevelMaximumGeometricError",
2410
1020
  value: function getLevelMaximumGeometricError(level) {
2411
- var levelZeroMaximumGeometricError = cesium.TerrainProvider.getEstimatedLevelZeroGeometricErrorForAHeightmap(this.tilingScheme.ellipsoid, 65, this.tilingScheme.getNumberOfXTilesAtLevel(0)); // Scalar to control overzooming
2412
- // also seems to control zooming for imagery layers
1021
+ var levelZeroMaximumGeometricError = TerrainProvider.getEstimatedLevelZeroGeometricErrorForAHeightmap(this.tilingScheme.ellipsoid, 65, this.tilingScheme.getNumberOfXTilesAtLevel(0));
2413
1022
 
1023
+ // Scalar to control overzooming
1024
+ // also seems to control zooming for imagery layers
2414
1025
  var scalar = this.resource.tileSize / 256;
2415
1026
  return levelZeroMaximumGeometricError / scalar / (1 << level);
2416
1027
  }
@@ -2424,31 +1035,58 @@ var MartiniTerrainProvider = /*#__PURE__*/function () {
2424
1035
  });
2425
1036
  }
2426
1037
  }]);
2427
-
2428
- return MartiniTerrainProvider;
2429
1038
  }();
2430
1039
 
2431
- var MapboxTerrainProvider = /*#__PURE__*/function (_MartiniTerrainProvid) {
2432
- _inherits(MapboxTerrainProvider, _MartiniTerrainProvid);
1040
+ function decodeBase64(base64, enableUnicode) {
1041
+ var binaryString = atob(base64);
1042
+ if (enableUnicode) {
1043
+ var binaryView = new Uint8Array(binaryString.length);
1044
+ for (var i = 0, n = binaryString.length; i < n; ++i) {
1045
+ binaryView[i] = binaryString.charCodeAt(i);
1046
+ }
1047
+ const decoder = new TextDecoder("utf-16le");
1048
+ return decoder.decode(new Uint16Array(binaryView.buffer));
1049
+ }
1050
+ return binaryString;
1051
+ }
1052
+
1053
+ function createURL(base64, sourcemapArg, enableUnicodeArg) {
1054
+ var sourcemap = sourcemapArg === undefined ? null : sourcemapArg;
1055
+ var enableUnicode = enableUnicodeArg === undefined ? false : enableUnicodeArg;
1056
+ var source = decodeBase64(base64, enableUnicode);
1057
+ var start = source.indexOf('\n', 10) + 1;
1058
+ var body = source.substring(start) + (sourcemap ? '\/\/# sourceMappingURL=' + sourcemap : '');
1059
+ var blob = new Blob([body], { type: 'application/javascript' });
1060
+ return URL.createObjectURL(blob);
1061
+ }
1062
+
1063
+ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
1064
+ var url;
1065
+ return function WorkerFactory(options) {
1066
+ url = url || createURL(base64, sourcemapArg, enableUnicodeArg);
1067
+ return new Worker(url, options);
1068
+ };
1069
+ }
2433
1070
 
2434
- var _super2 = _createSuper(MapboxTerrainProvider);
1071
+ var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('Lyogcm9sbHVwLXBsdWdpbi13ZWItd29ya2VyLWxvYWRlciAqLwooZnVuY3Rpb24gKCkgewogICd1c2Ugc3RyaWN0JzsKCiAgZnVuY3Rpb24gX2FycmF5TGlrZVRvQXJyYXkociwgYSkgewogICAgKG51bGwgPT0gYSB8fCBhID4gci5sZW5ndGgpICYmIChhID0gci5sZW5ndGgpOwogICAgZm9yICh2YXIgZSA9IDAsIG4gPSBBcnJheShhKTsgZSA8IGE7IGUrKykgbltlXSA9IHJbZV07CiAgICByZXR1cm4gbjsKICB9CiAgZnVuY3Rpb24gX2FycmF5V2l0aG91dEhvbGVzKHIpIHsKICAgIGlmIChBcnJheS5pc0FycmF5KHIpKSByZXR1cm4gX2FycmF5TGlrZVRvQXJyYXkocik7CiAgfQogIGZ1bmN0aW9uIF9pdGVyYWJsZVRvQXJyYXkocikgewogICAgaWYgKCJ1bmRlZmluZWQiICE9IHR5cGVvZiBTeW1ib2wgJiYgbnVsbCAhPSByW1N5bWJvbC5pdGVyYXRvcl0gfHwgbnVsbCAhPSByWyJAQGl0ZXJhdG9yIl0pIHJldHVybiBBcnJheS5mcm9tKHIpOwogIH0KICBmdW5jdGlvbiBfbm9uSXRlcmFibGVTcHJlYWQoKSB7CiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCJJbnZhbGlkIGF0dGVtcHQgdG8gc3ByZWFkIG5vbi1pdGVyYWJsZSBpbnN0YW5jZS5cbkluIG9yZGVyIHRvIGJlIGl0ZXJhYmxlLCBub24tYXJyYXkgb2JqZWN0cyBtdXN0IGhhdmUgYSBbU3ltYm9sLml0ZXJhdG9yXSgpIG1ldGhvZC4iKTsKICB9CiAgZnVuY3Rpb24gX3RvQ29uc3VtYWJsZUFycmF5KHIpIHsKICAgIHJldHVybiBfYXJyYXlXaXRob3V0SG9sZXMocikgfHwgX2l0ZXJhYmxlVG9BcnJheShyKSB8fCBfdW5zdXBwb3J0ZWRJdGVyYWJsZVRvQXJyYXkocikgfHwgX25vbkl0ZXJhYmxlU3ByZWFkKCk7CiAgfQogIGZ1bmN0aW9uIF91bnN1cHBvcnRlZEl0ZXJhYmxlVG9BcnJheShyLCBhKSB7CiAgICBpZiAocikgewogICAgICBpZiAoInN0cmluZyIgPT0gdHlwZW9mIHIpIHJldHVybiBfYXJyYXlMaWtlVG9BcnJheShyLCBhKTsKICAgICAgdmFyIHQgPSB7fS50b1N0cmluZy5jYWxsKHIpLnNsaWNlKDgsIC0xKTsKICAgICAgcmV0dXJuICJPYmplY3QiID09PSB0ICYmIHIuY29uc3RydWN0b3IgJiYgKHQgPSByLmNvbnN0cnVjdG9yLm5hbWUpLCAiTWFwIiA9PT0gdCB8fCAiU2V0IiA9PT0gdCA/IEFycmF5LmZyb20ocikgOiAiQXJndW1lbnRzIiA9PT0gdCB8fCAvXig/OlVpfEkpbnQoPzo4fDE2fDMyKSg/OkNsYW1wZWQpP0FycmF5JC8udGVzdCh0KSA/IF9hcnJheUxpa2VUb0FycmF5KHIsIGEpIDogdm9pZCAwOwogICAgfQogIH0KCiAgLy8gV2Ugc2hvdWxkIHNhdmUgdGhlc2UKICAvL2NvbnN0IGNhbnZhcyA9IG5ldyBPZmZzY3JlZW5DYW52YXMoMjU2LCAyNTYpOwogIC8vY29uc3QgY3R4ID0gY2FudmFzLmdldENvbnRleHQoIjJkIik7CgogIC8qKiBNYXBib3ggVGVycmFpbi1SR0IgZGVmYXVsdCBkZWNvZGUgZnVuY3Rpb24KICAqICAociAqIDI1NiAqIDI1NikgLyAxMCArIChnICogMjU2KSAvIDEwICsgYiAvIDEwIC0gMTAwMDAKICAqLwogIHZhciBkZWZhdWx0TWFwYm94RGVjb2RlUmdiID0gZnVuY3Rpb24gZGVmYXVsdE1hcGJveERlY29kZVJnYihyLCBnLCBiLCBhKSB7CiAgICByZXR1cm4gciAqIDY1NTMuNiArIGcgKiAyNS42ICsgYiAqIDAuMSAtIDEwMDAwOwogIH07CiAgZnVuY3Rpb24gcmdiVGVycmFpblRvR3JpZChwbmcsIGRlY29kZVJnYikgewogICAgLy8gbWF5YmUgd2Ugc2hvdWxkIGRvIHRoaXMgb24gdGhlIEdQVSB1c2luZyBSRUdMPwogICAgLy8gYnV0IHRoYXQgd291bGQgcmVxdWlyZSBHUFUgLT4gQ1BVIC0+IEdQVQogICAgdmFyIGdyaWRTaXplID0gcG5nLnNoYXBlWzBdICsgMTsKICAgIHZhciB0ZXJyYWluID0gbmV3IEZsb2F0MzJBcnJheShncmlkU2l6ZSAqIGdyaWRTaXplKTsKICAgIHZhciB0aWxlU2l6ZSA9IHBuZy5zaGFwZVswXTsKICAgIHZhciBkZWNvZGUgPSBkZWNvZGVSZ2IgIT09IG51bGwgJiYgZGVjb2RlUmdiICE9PSB2b2lkIDAgPyBkZWNvZGVSZ2IgOiBkZWZhdWx0TWFwYm94RGVjb2RlUmdiOwoKICAgIC8vIGRlY29kZSB0ZXJyYWluIHZhbHVlcwogICAgZm9yICh2YXIgeSA9IDA7IHkgPCB0aWxlU2l6ZTsgeSsrKSB7CiAgICAgIGZvciAodmFyIHggPSAwOyB4IDwgdGlsZVNpemU7IHgrKykgewogICAgICAgIHZhciB5YyA9IHk7CiAgICAgICAgdmFyIF9yID0gcG5nLmdldCh4LCB5YywgMCk7CiAgICAgICAgdmFyIF9nID0gcG5nLmdldCh4LCB5YywgMSk7CiAgICAgICAgdmFyIF9iID0gcG5nLmdldCh4LCB5YywgMik7CiAgICAgICAgdmFyIF9hID0gcG5nLmdldCh4LCB5YywgMyk7CiAgICAgICAgdGVycmFpblt5ICogZ3JpZFNpemUgKyB4XSA9IGRlY29kZShfciwgX2csIF9iLCBfYSk7CiAgICAgIH0KICAgIH0KICAgIC8vIGJhY2tmaWxsIHJpZ2h0IGFuZCBib3R0b20gYm9yZGVycwogICAgZm9yICh2YXIgX3ggPSAwOyBfeCA8IGdyaWRTaXplIC0gMTsgX3grKykgewogICAgICB0ZXJyYWluW2dyaWRTaXplICogKGdyaWRTaXplIC0gMSkgKyBfeF0gPSB0ZXJyYWluW2dyaWRTaXplICogKGdyaWRTaXplIC0gMikgKyBfeF07CiAgICB9CiAgICBmb3IgKHZhciBfeSA9IDA7IF95IDwgZ3JpZFNpemU7IF95KyspIHsKICAgICAgdGVycmFpbltncmlkU2l6ZSAqIF95ICsgZ3JpZFNpemUgLSAxXSA9IHRlcnJhaW5bZ3JpZFNpemUgKiBfeSArIGdyaWRTaXplIC0gMl07CiAgICB9CiAgICByZXR1cm4gdGVycmFpbjsKICB9CiAgZnVuY3Rpb24gY3JlYXRlUXVhbnRpemVkTWVzaERhdGEodGlsZSwgbWVzaCwgdGlsZVNpemUpIHsKICAgIHZhciB4dmFscyA9IFtdOwogICAgdmFyIHl2YWxzID0gW107CiAgICB2YXIgaGVpZ2h0TWV0ZXJzID0gW107CiAgICB2YXIgbm9ydGhJbmRpY2VzID0gW107CiAgICB2YXIgc291dGhJbmRpY2VzID0gW107CiAgICB2YXIgZWFzdEluZGljZXMgPSBbXTsKICAgIHZhciB3ZXN0SW5kaWNlcyA9IFtdOwogICAgdmFyIG1pbmltdW1IZWlnaHQgPSBJbmZpbml0eTsKICAgIHZhciBtYXhpbXVtSGVpZ2h0ID0gLUluZmluaXR5OwogICAgdmFyIHNjYWxhciA9IDMyNzY4LjAgLyB0aWxlU2l6ZTsKICAgIGZvciAodmFyIGl4ID0gMDsgaXggPCBtZXNoLnZlcnRpY2VzLmxlbmd0aCAvIDI7IGl4KyspIHsKICAgICAgdmFyIHZlcnRleEl4ID0gaXg7CiAgICAgIHZhciBweCA9IG1lc2gudmVydGljZXNbaXggKiAyXTsKICAgICAgdmFyIHB5ID0gbWVzaC52ZXJ0aWNlc1tpeCAqIDIgKyAxXTsKICAgICAgdmFyIGhlaWdodCA9IHRpbGUudGVycmFpbltweSAqICh0aWxlU2l6ZSArIDEpICsgcHhdOwogICAgICBpZiAoaGVpZ2h0ID4gbWF4aW11bUhlaWdodCkgbWF4aW11bUhlaWdodCA9IGhlaWdodDsKICAgICAgaWYgKGhlaWdodCA8IG1pbmltdW1IZWlnaHQpIG1pbmltdW1IZWlnaHQgPSBoZWlnaHQ7CiAgICAgIGhlaWdodE1ldGVycy5wdXNoKGhlaWdodCk7CiAgICAgIGlmIChweSA9PSAwKSBub3J0aEluZGljZXMucHVzaCh2ZXJ0ZXhJeCk7CiAgICAgIGlmIChweSA9PSB0aWxlU2l6ZSkgc291dGhJbmRpY2VzLnB1c2godmVydGV4SXgpOwogICAgICBpZiAocHggPT0gMCkgd2VzdEluZGljZXMucHVzaCh2ZXJ0ZXhJeCk7CiAgICAgIGlmIChweCA9PSB0aWxlU2l6ZSkgZWFzdEluZGljZXMucHVzaCh2ZXJ0ZXhJeCk7CiAgICAgIHZhciB4diA9IHB4ICogc2NhbGFyOwogICAgICB2YXIgeXYgPSAodGlsZVNpemUgLSBweSkgKiBzY2FsYXI7CiAgICAgIHh2YWxzLnB1c2goeHYpOwogICAgICB5dmFscy5wdXNoKHl2KTsKICAgIH0KICAgIHZhciBoZWlnaHRSYW5nZSA9IG1heGltdW1IZWlnaHQgLSBtaW5pbXVtSGVpZ2h0OwogICAgdmFyIGhlaWdodHMgPSBoZWlnaHRNZXRlcnMubWFwKGZ1bmN0aW9uIChkKSB7CiAgICAgIGlmIChoZWlnaHRSYW5nZSA8IDEpIHJldHVybiAwOwogICAgICByZXR1cm4gKGQgLSBtaW5pbXVtSGVpZ2h0KSAqICgzMjc2Ny4wIC8gaGVpZ2h0UmFuZ2UpOwogICAgfSk7CiAgICB2YXIgdHJpYW5nbGVzID0gbmV3IFVpbnQxNkFycmF5KG1lc2gudHJpYW5nbGVzKTsKICAgIHZhciBxdWFudGl6ZWRWZXJ0aWNlcyA9IG5ldyBVaW50MTZBcnJheSgvL3ZlcnRzCiAgICBbXS5jb25jYXQoeHZhbHMsIHl2YWxzLCBfdG9Db25zdW1hYmxlQXJyYXkoaGVpZ2h0cykpKTsKCiAgICAvLyBTRSBOVyBORQogICAgLy8gTkUgTlcgU0UKCiAgICByZXR1cm4gewogICAgICBtaW5pbXVtSGVpZ2h0OiBtaW5pbXVtSGVpZ2h0LAogICAgICBtYXhpbXVtSGVpZ2h0OiBtYXhpbXVtSGVpZ2h0LAogICAgICBxdWFudGl6ZWRWZXJ0aWNlczogcXVhbnRpemVkVmVydGljZXMsCiAgICAgIGluZGljZXM6IHRyaWFuZ2xlcywKICAgICAgd2VzdEluZGljZXM6IHdlc3RJbmRpY2VzLAogICAgICBzb3V0aEluZGljZXM6IHNvdXRoSW5kaWNlcywKICAgICAgZWFzdEluZGljZXM6IGVhc3RJbmRpY2VzLAogICAgICBub3J0aEluZGljZXM6IG5vcnRoSW5kaWNlcwogICAgfTsKICB9CgogIGZ1bmN0aW9uIGlvdGEobikgewogICAgdmFyIHJlc3VsdCA9IG5ldyBBcnJheShuKTsKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgbjsgKytpKSB7CiAgICAgIHJlc3VsdFtpXSA9IGk7CiAgICB9CiAgICByZXR1cm4gcmVzdWx0OwogIH0KICB2YXIgaW90YV8xID0gaW90YTsKCiAgLyohCiAgICogRGV0ZXJtaW5lIGlmIGFuIG9iamVjdCBpcyBhIEJ1ZmZlcgogICAqCiAgICogQGF1dGhvciAgIEZlcm9zcyBBYm91a2hhZGlqZWggPGh0dHBzOi8vZmVyb3NzLm9yZz4KICAgKiBAbGljZW5zZSAgTUlUCiAgICovCiAgLy8gVGhlIF9pc0J1ZmZlciBjaGVjayBpcyBmb3IgU2FmYXJpIDUtNyBzdXBwb3J0LCBiZWNhdXNlIGl0J3MgbWlzc2luZwogIC8vIE9iamVjdC5wcm90b3R5cGUuY29uc3RydWN0b3IuIFJlbW92ZSB0aGlzIGV2ZW50dWFsbHkKICB2YXIgaXNCdWZmZXJfMSA9IGZ1bmN0aW9uIChvYmopIHsKICAgIHJldHVybiBvYmogIT0gbnVsbCAmJiAoaXNCdWZmZXIob2JqKSB8fCBpc1Nsb3dCdWZmZXIob2JqKSB8fCAhIW9iai5faXNCdWZmZXIpOwogIH07CiAgZnVuY3Rpb24gaXNCdWZmZXIob2JqKSB7CiAgICByZXR1cm4gISFvYmouY29uc3RydWN0b3IgJiYgdHlwZW9mIG9iai5jb25zdHJ1Y3Rvci5pc0J1ZmZlciA9PT0gJ2Z1bmN0aW9uJyAmJiBvYmouY29uc3RydWN0b3IuaXNCdWZmZXIob2JqKTsKICB9CgogIC8vIEZvciBOb2RlIHYwLjEwIHN1cHBvcnQuIFJlbW92ZSB0aGlzIGV2ZW50dWFsbHkuCiAgZnVuY3Rpb24gaXNTbG93QnVmZmVyKG9iaikgewogICAgcmV0dXJuIHR5cGVvZiBvYmoucmVhZEZsb2F0TEUgPT09ICdmdW5jdGlvbicgJiYgdHlwZW9mIG9iai5zbGljZSA9PT0gJ2Z1bmN0aW9uJyAmJiBpc0J1ZmZlcihvYmouc2xpY2UoMCwgMCkpOwogIH0KCiAgdmFyIGhhc1R5cGVkQXJyYXlzID0gdHlwZW9mIEZsb2F0NjRBcnJheSAhPT0gInVuZGVmaW5lZCI7CiAgZnVuY3Rpb24gY29tcGFyZTFzdChhLCBiKSB7CiAgICByZXR1cm4gYVswXSAtIGJbMF07CiAgfQogIGZ1bmN0aW9uIG9yZGVyKCkgewogICAgdmFyIHN0cmlkZSA9IHRoaXMuc3RyaWRlOwogICAgdmFyIHRlcm1zID0gbmV3IEFycmF5KHN0cmlkZS5sZW5ndGgpOwogICAgdmFyIGk7CiAgICBmb3IgKGkgPSAwOyBpIDwgdGVybXMubGVuZ3RoOyArK2kpIHsKICAgICAgdGVybXNbaV0gPSBbTWF0aC5hYnMoc3RyaWRlW2ldKSwgaV07CiAgICB9CiAgICB0ZXJtcy5zb3J0KGNvbXBhcmUxc3QpOwogICAgdmFyIHJlc3VsdCA9IG5ldyBBcnJheSh0ZXJtcy5sZW5ndGgpOwogICAgZm9yIChpID0gMDsgaSA8IHJlc3VsdC5sZW5ndGg7ICsraSkgewogICAgICByZXN1bHRbaV0gPSB0ZXJtc1tpXVsxXTsKICAgIH0KICAgIHJldHVybiByZXN1bHQ7CiAgfQogIGZ1bmN0aW9uIGNvbXBpbGVDb25zdHJ1Y3RvcihkdHlwZSwgZGltZW5zaW9uKSB7CiAgICB2YXIgY2xhc3NOYW1lID0gWyJWaWV3IiwgZGltZW5zaW9uLCAiZCIsIGR0eXBlXS5qb2luKCIiKTsKICAgIGlmIChkaW1lbnNpb24gPCAwKSB7CiAgICAgIGNsYXNzTmFtZSA9ICJWaWV3X05pbCIgKyBkdHlwZTsKICAgIH0KICAgIHZhciB1c2VHZXR0ZXJzID0gZHR5cGUgPT09ICJnZW5lcmljIjsKICAgIGlmIChkaW1lbnNpb24gPT09IC0xKSB7CiAgICAgIC8vU3BlY2lhbCBjYXNlIGZvciB0cml2aWFsIGFycmF5cwogICAgICB2YXIgY29kZSA9ICJmdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIihhKXt0aGlzLmRhdGE9YTt9O1wKdmFyIHByb3RvPSIgKyBjbGFzc05hbWUgKyAiLnByb3RvdHlwZTtcCnByb3RvLmR0eXBlPSciICsgZHR5cGUgKyAiJztcCnByb3RvLmluZGV4PWZ1bmN0aW9uKCl7cmV0dXJuIC0xfTtcCnByb3RvLnNpemU9MDtcCnByb3RvLmRpbWVuc2lvbj0tMTtcCnByb3RvLnNoYXBlPXByb3RvLnN0cmlkZT1wcm90by5vcmRlcj1bXTtcCnByb3RvLmxvPXByb3RvLmhpPXByb3RvLnRyYW5zcG9zZT1wcm90by5zdGVwPVwKZnVuY3Rpb24oKXtyZXR1cm4gbmV3ICIgKyBjbGFzc05hbWUgKyAiKHRoaXMuZGF0YSk7fTtcCnByb3RvLmdldD1wcm90by5zZXQ9ZnVuY3Rpb24oKXt9O1wKcHJvdG8ucGljaz1mdW5jdGlvbigpe3JldHVybiBudWxsfTtcCnJldHVybiBmdW5jdGlvbiBjb25zdHJ1Y3RfIiArIGNsYXNzTmFtZSArICIoYSl7cmV0dXJuIG5ldyAiICsgY2xhc3NOYW1lICsgIihhKTt9IjsKICAgICAgdmFyIHByb2NlZHVyZSA9IG5ldyBGdW5jdGlvbihjb2RlKTsKICAgICAgcmV0dXJuIHByb2NlZHVyZSgpOwogICAgfSBlbHNlIGlmIChkaW1lbnNpb24gPT09IDApIHsKICAgICAgLy9TcGVjaWFsIGNhc2UgZm9yIDBkIGFycmF5cwogICAgICB2YXIgY29kZSA9ICJmdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIihhLGQpIHtcCnRoaXMuZGF0YSA9IGE7XAp0aGlzLm9mZnNldCA9IGRcCn07XAp2YXIgcHJvdG89IiArIGNsYXNzTmFtZSArICIucHJvdG90eXBlO1wKcHJvdG8uZHR5cGU9JyIgKyBkdHlwZSArICInO1wKcHJvdG8uaW5kZXg9ZnVuY3Rpb24oKXtyZXR1cm4gdGhpcy5vZmZzZXR9O1wKcHJvdG8uZGltZW5zaW9uPTA7XApwcm90by5zaXplPTE7XApwcm90by5zaGFwZT1cCnByb3RvLnN0cmlkZT1cCnByb3RvLm9yZGVyPVtdO1wKcHJvdG8ubG89XApwcm90by5oaT1cCnByb3RvLnRyYW5zcG9zZT1cCnByb3RvLnN0ZXA9ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfY29weSgpIHtcCnJldHVybiBuZXcgIiArIGNsYXNzTmFtZSArICIodGhpcy5kYXRhLHRoaXMub2Zmc2V0KVwKfTtcCnByb3RvLnBpY2s9ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfcGljaygpe1wKcmV0dXJuIFRyaXZpYWxBcnJheSh0aGlzLmRhdGEpO1wKfTtcCnByb3RvLnZhbHVlT2Y9cHJvdG8uZ2V0PWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX2dldCgpe1wKcmV0dXJuICIgKyAodXNlR2V0dGVycyA/ICJ0aGlzLmRhdGEuZ2V0KHRoaXMub2Zmc2V0KSIgOiAidGhpcy5kYXRhW3RoaXMub2Zmc2V0XSIpICsgIn07XApwcm90by5zZXQ9ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfc2V0KHYpe1wKcmV0dXJuICIgKyAodXNlR2V0dGVycyA/ICJ0aGlzLmRhdGEuc2V0KHRoaXMub2Zmc2V0LHYpIiA6ICJ0aGlzLmRhdGFbdGhpcy5vZmZzZXRdPXYiKSArICJcCn07XApyZXR1cm4gZnVuY3Rpb24gY29uc3RydWN0XyIgKyBjbGFzc05hbWUgKyAiKGEsYixjLGQpe3JldHVybiBuZXcgIiArIGNsYXNzTmFtZSArICIoYSxkKX0iOwogICAgICB2YXIgcHJvY2VkdXJlID0gbmV3IEZ1bmN0aW9uKCJUcml2aWFsQXJyYXkiLCBjb2RlKTsKICAgICAgcmV0dXJuIHByb2NlZHVyZShDQUNIRURfQ09OU1RSVUNUT1JTW2R0eXBlXVswXSk7CiAgICB9CiAgICB2YXIgY29kZSA9IFsiJ3VzZSBzdHJpY3QnIl07CgogICAgLy9DcmVhdGUgY29uc3RydWN0b3IgZm9yIHZpZXcKICAgIHZhciBpbmRpY2VzID0gaW90YV8xKGRpbWVuc2lvbik7CiAgICB2YXIgYXJncyA9IGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiaSIgKyBpOwogICAgfSk7CiAgICB2YXIgaW5kZXhfc3RyID0gInRoaXMub2Zmc2V0KyIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gInRoaXMuc3RyaWRlWyIgKyBpICsgIl0qaSIgKyBpOwogICAgfSkuam9pbigiKyIpOwogICAgdmFyIHNoYXBlQXJnID0gaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJiIiArIGk7CiAgICB9KS5qb2luKCIsIik7CiAgICB2YXIgc3RyaWRlQXJnID0gaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJjIiArIGk7CiAgICB9KS5qb2luKCIsIik7CiAgICBjb2RlLnB1c2goImZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiKGEsIiArIHNoYXBlQXJnICsgIiwiICsgc3RyaWRlQXJnICsgIixkKXt0aGlzLmRhdGE9YSIsICJ0aGlzLnNoYXBlPVsiICsgc2hhcGVBcmcgKyAiXSIsICJ0aGlzLnN0cmlkZT1bIiArIHN0cmlkZUFyZyArICJdIiwgInRoaXMub2Zmc2V0PWR8MH0iLCAidmFyIHByb3RvPSIgKyBjbGFzc05hbWUgKyAiLnByb3RvdHlwZSIsICJwcm90by5kdHlwZT0nIiArIGR0eXBlICsgIiciLCAicHJvdG8uZGltZW5zaW9uPSIgKyBkaW1lbnNpb24pOwoKICAgIC8vdmlldy5zaXplOgogICAgY29kZS5wdXNoKCJPYmplY3QuZGVmaW5lUHJvcGVydHkocHJvdG8sJ3NpemUnLHtnZXQ6ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfc2l6ZSgpe1wKcmV0dXJuICIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gInRoaXMuc2hhcGVbIiArIGkgKyAiXSI7CiAgICB9KS5qb2luKCIqIiksICJ9fSkiKTsKCiAgICAvL3ZpZXcub3JkZXI6CiAgICBpZiAoZGltZW5zaW9uID09PSAxKSB7CiAgICAgIGNvZGUucHVzaCgicHJvdG8ub3JkZXI9WzBdIik7CiAgICB9IGVsc2UgewogICAgICBjb2RlLnB1c2goIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShwcm90bywnb3JkZXInLHtnZXQ6Iik7CiAgICAgIGlmIChkaW1lbnNpb24gPCA0KSB7CiAgICAgICAgY29kZS5wdXNoKCJmdW5jdGlvbiAiICsgY2xhc3NOYW1lICsgIl9vcmRlcigpeyIpOwogICAgICAgIGlmIChkaW1lbnNpb24gPT09IDIpIHsKICAgICAgICAgIGNvZGUucHVzaCgicmV0dXJuIChNYXRoLmFicyh0aGlzLnN0cmlkZVswXSk+TWF0aC5hYnModGhpcy5zdHJpZGVbMV0pKT9bMSwwXTpbMCwxXX19KSIpOwogICAgICAgIH0gZWxzZSBpZiAoZGltZW5zaW9uID09PSAzKSB7CiAgICAgICAgICBjb2RlLnB1c2goInZhciBzMD1NYXRoLmFicyh0aGlzLnN0cmlkZVswXSksczE9TWF0aC5hYnModGhpcy5zdHJpZGVbMV0pLHMyPU1hdGguYWJzKHRoaXMuc3RyaWRlWzJdKTtcCmlmKHMwPnMxKXtcCmlmKHMxPnMyKXtcCnJldHVybiBbMiwxLDBdO1wKfWVsc2UgaWYoczA+czIpe1wKcmV0dXJuIFsxLDIsMF07XAp9ZWxzZXtcCnJldHVybiBbMSwwLDJdO1wKfVwKfWVsc2UgaWYoczA+czIpe1wKcmV0dXJuIFsyLDAsMV07XAp9ZWxzZSBpZihzMj5zMSl7XApyZXR1cm4gWzAsMSwyXTtcCn1lbHNle1wKcmV0dXJuIFswLDIsMV07XAp9fX0pIik7CiAgICAgICAgfQogICAgICB9IGVsc2UgewogICAgICAgIGNvZGUucHVzaCgiT1JERVJ9KSIpOwogICAgICB9CiAgICB9CgogICAgLy92aWV3LnNldChpMCwgLi4uLCB2KToKICAgIGNvZGUucHVzaCgicHJvdG8uc2V0PWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX3NldCgiICsgYXJncy5qb2luKCIsIikgKyAiLHYpeyIpOwogICAgaWYgKHVzZUdldHRlcnMpIHsKICAgICAgY29kZS5wdXNoKCJyZXR1cm4gdGhpcy5kYXRhLnNldCgiICsgaW5kZXhfc3RyICsgIix2KX0iKTsKICAgIH0gZWxzZSB7CiAgICAgIGNvZGUucHVzaCgicmV0dXJuIHRoaXMuZGF0YVsiICsgaW5kZXhfc3RyICsgIl09dn0iKTsKICAgIH0KCiAgICAvL3ZpZXcuZ2V0KGkwLCAuLi4pOgogICAgY29kZS5wdXNoKCJwcm90by5nZXQ9ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfZ2V0KCIgKyBhcmdzLmpvaW4oIiwiKSArICIpeyIpOwogICAgaWYgKHVzZUdldHRlcnMpIHsKICAgICAgY29kZS5wdXNoKCJyZXR1cm4gdGhpcy5kYXRhLmdldCgiICsgaW5kZXhfc3RyICsgIil9Iik7CiAgICB9IGVsc2UgewogICAgICBjb2RlLnB1c2goInJldHVybiB0aGlzLmRhdGFbIiArIGluZGV4X3N0ciArICJdfSIpOwogICAgfQoKICAgIC8vdmlldy5pbmRleDoKICAgIGNvZGUucHVzaCgicHJvdG8uaW5kZXg9ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfaW5kZXgoIiwgYXJncy5qb2luKCksICIpe3JldHVybiAiICsgaW5kZXhfc3RyICsgIn0iKTsKCiAgICAvL3ZpZXcuaGkoKToKICAgIGNvZGUucHVzaCgicHJvdG8uaGk9ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfaGkoIiArIGFyZ3Muam9pbigiLCIpICsgIil7cmV0dXJuIG5ldyAiICsgY2xhc3NOYW1lICsgIih0aGlzLmRhdGEsIiArIGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiBbIih0eXBlb2YgaSIsIGksICIhPT0nbnVtYmVyJ3x8aSIsIGksICI8MCk/dGhpcy5zaGFwZVsiLCBpLCAiXTppIiwgaSwgInwwIl0uam9pbigiIik7CiAgICB9KS5qb2luKCIsIikgKyAiLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gInRoaXMuc3RyaWRlWyIgKyBpICsgIl0iOwogICAgfSkuam9pbigiLCIpICsgIix0aGlzLm9mZnNldCl9Iik7CgogICAgLy92aWV3LmxvKCk6CiAgICB2YXIgYV92YXJzID0gaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJhIiArIGkgKyAiPXRoaXMuc2hhcGVbIiArIGkgKyAiXSI7CiAgICB9KTsKICAgIHZhciBjX3ZhcnMgPSBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gImMiICsgaSArICI9dGhpcy5zdHJpZGVbIiArIGkgKyAiXSI7CiAgICB9KTsKICAgIGNvZGUucHVzaCgicHJvdG8ubG89ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfbG8oIiArIGFyZ3Muam9pbigiLCIpICsgIil7dmFyIGI9dGhpcy5vZmZzZXQsZD0wLCIgKyBhX3ZhcnMuam9pbigiLCIpICsgIiwiICsgY192YXJzLmpvaW4oIiwiKSk7CiAgICBmb3IgKHZhciBpID0gMDsgaSA8IGRpbWVuc2lvbjsgKytpKSB7CiAgICAgIGNvZGUucHVzaCgiaWYodHlwZW9mIGkiICsgaSArICI9PT0nbnVtYmVyJyYmaSIgKyBpICsgIj49MCl7XApkPWkiICsgaSArICJ8MDtcCmIrPWMiICsgaSArICIqZDtcCmEiICsgaSArICItPWR9Iik7CiAgICB9CiAgICBjb2RlLnB1c2goInJldHVybiBuZXcgIiArIGNsYXNzTmFtZSArICIodGhpcy5kYXRhLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gImEiICsgaTsKICAgIH0pLmpvaW4oIiwiKSArICIsIiArIGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiYyIgKyBpOwogICAgfSkuam9pbigiLCIpICsgIixiKX0iKTsKCiAgICAvL3ZpZXcuc3RlcCgpOgogICAgY29kZS5wdXNoKCJwcm90by5zdGVwPWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX3N0ZXAoIiArIGFyZ3Muam9pbigiLCIpICsgIil7dmFyICIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gImEiICsgaSArICI9dGhpcy5zaGFwZVsiICsgaSArICJdIjsKICAgIH0pLmpvaW4oIiwiKSArICIsIiArIGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiYiIgKyBpICsgIj10aGlzLnN0cmlkZVsiICsgaSArICJdIjsKICAgIH0pLmpvaW4oIiwiKSArICIsYz10aGlzLm9mZnNldCxkPTAsY2VpbD1NYXRoLmNlaWwiKTsKICAgIGZvciAodmFyIGkgPSAwOyBpIDwgZGltZW5zaW9uOyArK2kpIHsKICAgICAgY29kZS5wdXNoKCJpZih0eXBlb2YgaSIgKyBpICsgIj09PSdudW1iZXInKXtcCmQ9aSIgKyBpICsgInwwO1wKaWYoZDwwKXtcCmMrPWIiICsgaSArICIqKGEiICsgaSArICItMSk7XAphIiArIGkgKyAiPWNlaWwoLWEiICsgaSArICIvZClcCn1lbHNle1wKYSIgKyBpICsgIj1jZWlsKGEiICsgaSArICIvZClcCn1cCmIiICsgaSArICIqPWRcCn0iKTsKICAgIH0KICAgIGNvZGUucHVzaCgicmV0dXJuIG5ldyAiICsgY2xhc3NOYW1lICsgIih0aGlzLmRhdGEsIiArIGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAiYSIgKyBpOwogICAgfSkuam9pbigiLCIpICsgIiwiICsgaW5kaWNlcy5tYXAoZnVuY3Rpb24gKGkpIHsKICAgICAgcmV0dXJuICJiIiArIGk7CiAgICB9KS5qb2luKCIsIikgKyAiLGMpfSIpOwoKICAgIC8vdmlldy50cmFuc3Bvc2UoKToKICAgIHZhciB0U2hhcGUgPSBuZXcgQXJyYXkoZGltZW5zaW9uKTsKICAgIHZhciB0U3RyaWRlID0gbmV3IEFycmF5KGRpbWVuc2lvbik7CiAgICBmb3IgKHZhciBpID0gMDsgaSA8IGRpbWVuc2lvbjsgKytpKSB7CiAgICAgIHRTaGFwZVtpXSA9ICJhW2kiICsgaSArICJdIjsKICAgICAgdFN0cmlkZVtpXSA9ICJiW2kiICsgaSArICJdIjsKICAgIH0KICAgIGNvZGUucHVzaCgicHJvdG8udHJhbnNwb3NlPWZ1bmN0aW9uICIgKyBjbGFzc05hbWUgKyAiX3RyYW5zcG9zZSgiICsgYXJncyArICIpeyIgKyBhcmdzLm1hcChmdW5jdGlvbiAobiwgaWR4KSB7CiAgICAgIHJldHVybiBuICsgIj0oIiArIG4gKyAiPT09dW5kZWZpbmVkPyIgKyBpZHggKyAiOiIgKyBuICsgInwwKSI7CiAgICB9KS5qb2luKCI7IiksICJ2YXIgYT10aGlzLnNoYXBlLGI9dGhpcy5zdHJpZGU7cmV0dXJuIG5ldyAiICsgY2xhc3NOYW1lICsgIih0aGlzLmRhdGEsIiArIHRTaGFwZS5qb2luKCIsIikgKyAiLCIgKyB0U3RyaWRlLmpvaW4oIiwiKSArICIsdGhpcy5vZmZzZXQpfSIpOwoKICAgIC8vdmlldy5waWNrKCk6CiAgICBjb2RlLnB1c2goInByb3RvLnBpY2s9ZnVuY3Rpb24gIiArIGNsYXNzTmFtZSArICJfcGljaygiICsgYXJncyArICIpe3ZhciBhPVtdLGI9W10sYz10aGlzLm9mZnNldCIpOwogICAgZm9yICh2YXIgaSA9IDA7IGkgPCBkaW1lbnNpb247ICsraSkgewogICAgICBjb2RlLnB1c2goImlmKHR5cGVvZiBpIiArIGkgKyAiPT09J251bWJlcicmJmkiICsgaSArICI+PTApe2M9KGMrdGhpcy5zdHJpZGVbIiArIGkgKyAiXSppIiArIGkgKyAiKXwwfWVsc2V7YS5wdXNoKHRoaXMuc2hhcGVbIiArIGkgKyAiXSk7Yi5wdXNoKHRoaXMuc3RyaWRlWyIgKyBpICsgIl0pfSIpOwogICAgfQogICAgY29kZS5wdXNoKCJ2YXIgY3Rvcj1DVE9SX0xJU1RbYS5sZW5ndGgrMV07cmV0dXJuIGN0b3IodGhpcy5kYXRhLGEsYixjKX0iKTsKCiAgICAvL0FkZCByZXR1cm4gc3RhdGVtZW50CiAgICBjb2RlLnB1c2goInJldHVybiBmdW5jdGlvbiBjb25zdHJ1Y3RfIiArIGNsYXNzTmFtZSArICIoZGF0YSxzaGFwZSxzdHJpZGUsb2Zmc2V0KXtyZXR1cm4gbmV3ICIgKyBjbGFzc05hbWUgKyAiKGRhdGEsIiArIGluZGljZXMubWFwKGZ1bmN0aW9uIChpKSB7CiAgICAgIHJldHVybiAic2hhcGVbIiArIGkgKyAiXSI7CiAgICB9KS5qb2luKCIsIikgKyAiLCIgKyBpbmRpY2VzLm1hcChmdW5jdGlvbiAoaSkgewogICAgICByZXR1cm4gInN0cmlkZVsiICsgaSArICJdIjsKICAgIH0pLmpvaW4oIiwiKSArICIsb2Zmc2V0KX0iKTsKCiAgICAvL0NvbXBpbGUgcHJvY2VkdXJlCiAgICB2YXIgcHJvY2VkdXJlID0gbmV3IEZ1bmN0aW9uKCJDVE9SX0xJU1QiLCAiT1JERVIiLCBjb2RlLmpvaW4oIlxuIikpOwogICAgcmV0dXJuIHByb2NlZHVyZShDQUNIRURfQ09OU1RSVUNUT1JTW2R0eXBlXSwgb3JkZXIpOwogIH0KICBmdW5jdGlvbiBhcnJheURUeXBlKGRhdGEpIHsKICAgIGlmIChpc0J1ZmZlcl8xKGRhdGEpKSB7CiAgICAgIHJldHVybiAiYnVmZmVyIjsKICAgIH0KICAgIGlmIChoYXNUeXBlZEFycmF5cykgewogICAgICBzd2l0Y2ggKE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChkYXRhKSkgewogICAgICAgIGNhc2UgIltvYmplY3QgRmxvYXQ2NEFycmF5XSI6CiAgICAgICAgICByZXR1cm4gImZsb2F0NjQiOwogICAgICAgIGNhc2UgIltvYmplY3QgRmxvYXQzMkFycmF5XSI6CiAgICAgICAgICByZXR1cm4gImZsb2F0MzIiOwogICAgICAgIGNhc2UgIltvYmplY3QgSW50OEFycmF5XSI6CiAgICAgICAgICByZXR1cm4gImludDgiOwogICAgICAgIGNhc2UgIltvYmplY3QgSW50MTZBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJpbnQxNiI7CiAgICAgICAgY2FzZSAiW29iamVjdCBJbnQzMkFycmF5XSI6CiAgICAgICAgICByZXR1cm4gImludDMyIjsKICAgICAgICBjYXNlICJbb2JqZWN0IFVpbnQ4QXJyYXldIjoKICAgICAgICAgIHJldHVybiAidWludDgiOwogICAgICAgIGNhc2UgIltvYmplY3QgVWludDE2QXJyYXldIjoKICAgICAgICAgIHJldHVybiAidWludDE2IjsKICAgICAgICBjYXNlICJbb2JqZWN0IFVpbnQzMkFycmF5XSI6CiAgICAgICAgICByZXR1cm4gInVpbnQzMiI7CiAgICAgICAgY2FzZSAiW29iamVjdCBVaW50OENsYW1wZWRBcnJheV0iOgogICAgICAgICAgcmV0dXJuICJ1aW50OF9jbGFtcGVkIjsKICAgICAgICBjYXNlICJbb2JqZWN0IEJpZ0ludDY0QXJyYXldIjoKICAgICAgICAgIHJldHVybiAiYmlnaW50NjQiOwogICAgICAgIGNhc2UgIltvYmplY3QgQmlnVWludDY0QXJyYXldIjoKICAgICAgICAgIHJldHVybiAiYmlndWludDY0IjsKICAgICAgfQogICAgfQogICAgaWYgKEFycmF5LmlzQXJyYXkoZGF0YSkpIHsKICAgICAgcmV0dXJuICJhcnJheSI7CiAgICB9CiAgICByZXR1cm4gImdlbmVyaWMiOwogIH0KICB2YXIgQ0FDSEVEX0NPTlNUUlVDVE9SUyA9IHsKICAgICJmbG9hdDMyIjogW10sCiAgICAiZmxvYXQ2NCI6IFtdLAogICAgImludDgiOiBbXSwKICAgICJpbnQxNiI6IFtdLAogICAgImludDMyIjogW10sCiAgICAidWludDgiOiBbXSwKICAgICJ1aW50MTYiOiBbXSwKICAgICJ1aW50MzIiOiBbXSwKICAgICJhcnJheSI6IFtdLAogICAgInVpbnQ4X2NsYW1wZWQiOiBbXSwKICAgICJiaWdpbnQ2NCI6IFtdLAogICAgImJpZ3VpbnQ2NCI6IFtdLAogICAgImJ1ZmZlciI6IFtdLAogICAgImdlbmVyaWMiOiBbXQogIH07CiAgZnVuY3Rpb24gd3JhcHBlZE5EQXJyYXlDdG9yKGRhdGEsIHNoYXBlLCBzdHJpZGUsIG9mZnNldCkgewogICAgaWYgKGRhdGEgPT09IHVuZGVmaW5lZCkgewogICAgICB2YXIgY3RvciA9IENBQ0hFRF9DT05TVFJVQ1RPUlMuYXJyYXlbMF07CiAgICAgIHJldHVybiBjdG9yKFtdKTsKICAgIH0gZWxzZSBpZiAodHlwZW9mIGRhdGEgPT09ICJudW1iZXIiKSB7CiAgICAgIGRhdGEgPSBbZGF0YV07CiAgICB9CiAgICBpZiAoc2hhcGUgPT09IHVuZGVmaW5lZCkgewogICAgICBzaGFwZSA9IFtkYXRhLmxlbmd0aF07CiAgICB9CiAgICB2YXIgZCA9IHNoYXBlLmxlbmd0aDsKICAgIGlmIChzdHJpZGUgPT09IHVuZGVmaW5lZCkgewogICAgICBzdHJpZGUgPSBuZXcgQXJyYXkoZCk7CiAgICAgIGZvciAodmFyIGkgPSBkIC0gMSwgc3ogPSAxOyBpID49IDA7IC0taSkgewogICAgICAgIHN0cmlkZVtpXSA9IHN6OwogICAgICAgIHN6ICo9IHNoYXBlW2ldOwogICAgICB9CiAgICB9CiAgICBpZiAob2Zmc2V0ID09PSB1bmRlZmluZWQpIHsKICAgICAgb2Zmc2V0ID0gMDsKICAgICAgZm9yICh2YXIgaSA9IDA7IGkgPCBkOyArK2kpIHsKICAgICAgICBpZiAoc3RyaWRlW2ldIDwgMCkgewogICAgICAgICAgb2Zmc2V0IC09IChzaGFwZVtpXSAtIDEpICogc3RyaWRlW2ldOwogICAgICAgIH0KICAgICAgfQogICAgfQogICAgdmFyIGR0eXBlID0gYXJyYXlEVHlwZShkYXRhKTsKICAgIHZhciBjdG9yX2xpc3QgPSBDQUNIRURfQ09OU1RSVUNUT1JTW2R0eXBlXTsKICAgIHdoaWxlIChjdG9yX2xpc3QubGVuZ3RoIDw9IGQgKyAxKSB7CiAgICAgIGN0b3JfbGlzdC5wdXNoKGNvbXBpbGVDb25zdHJ1Y3RvcihkdHlwZSwgY3Rvcl9saXN0Lmxlbmd0aCAtIDEpKTsKICAgIH0KICAgIHZhciBjdG9yID0gY3Rvcl9saXN0W2QgKyAxXTsKICAgIHJldHVybiBjdG9yKGRhdGEsIHNoYXBlLCBzdHJpZGUsIG9mZnNldCk7CiAgfQogIHZhciBuZGFycmF5ID0gd3JhcHBlZE5EQXJyYXlDdG9yOwoKICBjbGFzcyBNYXJ0aW5pIHsKICAgIGNvbnN0cnVjdG9yKGdyaWRTaXplID0gMjU3KSB7CiAgICAgIHRoaXMuZ3JpZFNpemUgPSBncmlkU2l6ZTsKICAgICAgY29uc3QgdGlsZVNpemUgPSBncmlkU2l6ZSAtIDE7CiAgICAgIGlmICh0aWxlU2l6ZSAmIHRpbGVTaXplIC0gMSkgdGhyb3cgbmV3IEVycm9yKGBFeHBlY3RlZCBncmlkIHNpemUgdG8gYmUgMl5uKzEsIGdvdCAke2dyaWRTaXplfS5gKTsKICAgICAgdGhpcy5udW1UcmlhbmdsZXMgPSB0aWxlU2l6ZSAqIHRpbGVTaXplICogMiAtIDI7CiAgICAgIHRoaXMubnVtUGFyZW50VHJpYW5nbGVzID0gdGhpcy5udW1UcmlhbmdsZXMgLSB0aWxlU2l6ZSAqIHRpbGVTaXplOwogICAgICB0aGlzLmluZGljZXMgPSBuZXcgVWludDMyQXJyYXkodGhpcy5ncmlkU2l6ZSAqIHRoaXMuZ3JpZFNpemUpOwoKICAgICAgLy8gY29vcmRpbmF0ZXMgZm9yIGFsbCBwb3NzaWJsZSB0cmlhbmdsZXMgaW4gYW4gUlRJTiB0aWxlCiAgICAgIHRoaXMuY29vcmRzID0gbmV3IFVpbnQxNkFycmF5KHRoaXMubnVtVHJpYW5nbGVzICogNCk7CgogICAgICAvLyBnZXQgdHJpYW5nbGUgY29vcmRpbmF0ZXMgZnJvbSBpdHMgaW5kZXggaW4gYW4gaW1wbGljaXQgYmluYXJ5IHRyZWUKICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLm51bVRyaWFuZ2xlczsgaSsrKSB7CiAgICAgICAgbGV0IGlkID0gaSArIDI7CiAgICAgICAgbGV0IGF4ID0gMCwKICAgICAgICAgIGF5ID0gMCwKICAgICAgICAgIGJ4ID0gMCwKICAgICAgICAgIGJ5ID0gMCwKICAgICAgICAgIGN4ID0gMCwKICAgICAgICAgIGN5ID0gMDsKICAgICAgICBpZiAoaWQgJiAxKSB7CiAgICAgICAgICBieCA9IGJ5ID0gY3ggPSB0aWxlU2l6ZTsgLy8gYm90dG9tLWxlZnQgdHJpYW5nbGUKICAgICAgICB9IGVsc2UgewogICAgICAgICAgYXggPSBheSA9IGN5ID0gdGlsZVNpemU7IC8vIHRvcC1yaWdodCB0cmlhbmdsZQogICAgICAgIH0KICAgICAgICB3aGlsZSAoKGlkID4+PSAxKSA+IDEpIHsKICAgICAgICAgIGNvbnN0IG14ID0gYXggKyBieCA+PiAxOwogICAgICAgICAgY29uc3QgbXkgPSBheSArIGJ5ID4+IDE7CiAgICAgICAgICBpZiAoaWQgJiAxKSB7CiAgICAgICAgICAgIC8vIGxlZnQgaGFsZgogICAgICAgICAgICBieCA9IGF4OwogICAgICAgICAgICBieSA9IGF5OwogICAgICAgICAgICBheCA9IGN4OwogICAgICAgICAgICBheSA9IGN5OwogICAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgLy8gcmlnaHQgaGFsZgogICAgICAgICAgICBheCA9IGJ4OwogICAgICAgICAgICBheSA9IGJ5OwogICAgICAgICAgICBieCA9IGN4OwogICAgICAgICAgICBieSA9IGN5OwogICAgICAgICAgfQogICAgICAgICAgY3ggPSBteDsKICAgICAgICAgIGN5ID0gbXk7CiAgICAgICAgfQogICAgICAgIGNvbnN0IGsgPSBpICogNDsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgMF0gPSBheDsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgMV0gPSBheTsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgMl0gPSBieDsKICAgICAgICB0aGlzLmNvb3Jkc1trICsgM10gPSBieTsKICAgICAgfQogICAgfQogICAgY3JlYXRlVGlsZSh0ZXJyYWluKSB7CiAgICAgIHJldHVybiBuZXcgVGlsZSh0ZXJyYWluLCB0aGlzKTsKICAgIH0KICB9CiAgY2xhc3MgVGlsZSB7CiAgICBjb25zdHJ1Y3Rvcih0ZXJyYWluLCBtYXJ0aW5pKSB7CiAgICAgIGNvbnN0IHNpemUgPSBtYXJ0aW5pLmdyaWRTaXplOwogICAgICBpZiAodGVycmFpbi5sZW5ndGggIT09IHNpemUgKiBzaXplKSB0aHJvdyBuZXcgRXJyb3IoYEV4cGVjdGVkIHRlcnJhaW4gZGF0YSBvZiBsZW5ndGggJHtzaXplICogc2l6ZX0gKCR7c2l6ZX0geCAke3NpemV9KSwgZ290ICR7dGVycmFpbi5sZW5ndGh9LmApOwogICAgICB0aGlzLnRlcnJhaW4gPSB0ZXJyYWluOwogICAgICB0aGlzLm1hcnRpbmkgPSBtYXJ0aW5pOwogICAgICB0aGlzLmVycm9ycyA9IG5ldyBGbG9hdDMyQXJyYXkodGVycmFpbi5sZW5ndGgpOwogICAgICB0aGlzLnVwZGF0ZSgpOwogICAgfQogICAgdXBkYXRlKCkgewogICAgICBjb25zdCB7CiAgICAgICAgbnVtVHJpYW5nbGVzLAogICAgICAgIG51bVBhcmVudFRyaWFuZ2xlcywKICAgICAgICBjb29yZHMsCiAgICAgICAgZ3JpZFNpemU6IHNpemUKICAgICAgfSA9IHRoaXMubWFydGluaTsKICAgICAgY29uc3QgewogICAgICAgIHRlcnJhaW4sCiAgICAgICAgZXJyb3JzCiAgICAgIH0gPSB0aGlzOwoKICAgICAgLy8gaXRlcmF0ZSBvdmVyIGFsbCBwb3NzaWJsZSB0cmlhbmdsZXMsIHN0YXJ0aW5nIGZyb20gdGhlIHNtYWxsZXN0IGxldmVsCiAgICAgIGZvciAobGV0IGkgPSBudW1UcmlhbmdsZXMgLSAxOyBpID49IDA7IGktLSkgewogICAgICAgIGNvbnN0IGsgPSBpICogNDsKICAgICAgICBjb25zdCBheCA9IGNvb3Jkc1trICsgMF07CiAgICAgICAgY29uc3QgYXkgPSBjb29yZHNbayArIDFdOwogICAgICAgIGNvbnN0IGJ4ID0gY29vcmRzW2sgKyAyXTsKICAgICAgICBjb25zdCBieSA9IGNvb3Jkc1trICsgM107CiAgICAgICAgY29uc3QgbXggPSBheCArIGJ4ID4+IDE7CiAgICAgICAgY29uc3QgbXkgPSBheSArIGJ5ID4+IDE7CiAgICAgICAgY29uc3QgY3ggPSBteCArIG15IC0gYXk7CiAgICAgICAgY29uc3QgY3kgPSBteSArIGF4IC0gbXg7CgogICAgICAgIC8vIGNhbGN1bGF0ZSBlcnJvciBpbiB0aGUgbWlkZGxlIG9mIHRoZSBsb25nIGVkZ2Ugb2YgdGhlIHRyaWFuZ2xlCiAgICAgICAgY29uc3QgaW50ZXJwb2xhdGVkSGVpZ2h0ID0gKHRlcnJhaW5bYXkgKiBzaXplICsgYXhdICsgdGVycmFpbltieSAqIHNpemUgKyBieF0pIC8gMjsKICAgICAgICBjb25zdCBtaWRkbGVJbmRleCA9IG15ICogc2l6ZSArIG14OwogICAgICAgIGNvbnN0IG1pZGRsZUVycm9yID0gTWF0aC5hYnMoaW50ZXJwb2xhdGVkSGVpZ2h0IC0gdGVycmFpblttaWRkbGVJbmRleF0pOwogICAgICAgIGVycm9yc1ttaWRkbGVJbmRleF0gPSBNYXRoLm1heChlcnJvcnNbbWlkZGxlSW5kZXhdLCBtaWRkbGVFcnJvcik7CiAgICAgICAgaWYgKGkgPCBudW1QYXJlbnRUcmlhbmdsZXMpIHsKICAgICAgICAgIC8vIGJpZ2dlciB0cmlhbmdsZXM7IGFjY3VtdWxhdGUgZXJyb3Igd2l0aCBjaGlsZHJlbgogICAgICAgICAgY29uc3QgbGVmdENoaWxkSW5kZXggPSAoYXkgKyBjeSA+PiAxKSAqIHNpemUgKyAoYXggKyBjeCA+PiAxKTsKICAgICAgICAgIGNvbnN0IHJpZ2h0Q2hpbGRJbmRleCA9IChieSArIGN5ID4+IDEpICogc2l6ZSArIChieCArIGN4ID4+IDEpOwogICAgICAgICAgZXJyb3JzW21pZGRsZUluZGV4XSA9IE1hdGgubWF4KGVycm9yc1ttaWRkbGVJbmRleF0sIGVycm9yc1tsZWZ0Q2hpbGRJbmRleF0sIGVycm9yc1tyaWdodENoaWxkSW5kZXhdKTsKICAgICAgICB9CiAgICAgIH0KICAgIH0KICAgIGdldE1lc2gobWF4RXJyb3IgPSAwLCBtYXhMZW5ndGggPSBudWxsKSB7CiAgICAgIGNvbnN0IHsKICAgICAgICBncmlkU2l6ZTogc2l6ZSwKICAgICAgICBpbmRpY2VzCiAgICAgIH0gPSB0aGlzLm1hcnRpbmk7CiAgICAgIGNvbnN0IHsKICAgICAgICBlcnJvcnMKICAgICAgfSA9IHRoaXM7CiAgICAgIGxldCBudW1WZXJ0aWNlcyA9IDA7CiAgICAgIGxldCBudW1UcmlhbmdsZXMgPSAwOwogICAgICBjb25zdCBtYXggPSBzaXplIC0gMTsKCiAgICAgIC8vIFRoZSBtYXhMZW5ndGggcGFyYW1ldGVyIHdpbGwgY2F1c2UgdHJpYW5nbGVzIHRvIGJlIGdlbmVyYXRlZCB1bnRpbCB0aGUgbGVncyBhcmUgYmVsb3cgdGhpcyBsZW5ndGgKICAgICAgLy8gSXQgaXMgbWVhbnQgdG8gc3VwcG9ydCBjYXNlcyB3aGVyZSBhIGNlcnRhaW4gbWVzaCBkZW5zaXR5IGlzIHJlcXVpcmVkIHRvIGRvIHNwaGVyaWNhbCBtYXRoIG9uIGRpZ2l0YWwgZ2xvYmVzCiAgICAgIGNvbnN0IG1heFNjYWxlID0gbWF4TGVuZ3RoIHx8IHNpemU7CgogICAgICAvLyB1c2UgYW4gaW5kZXggZ3JpZCB0byBrZWVwIHRyYWNrIG9mIHZlcnRpY2VzIHRoYXQgd2VyZSBhbHJlYWR5IHVzZWQgdG8gYXZvaWQgZHVwbGljYXRpb24KICAgICAgaW5kaWNlcy5maWxsKDApOwoKICAgICAgLy8gcmV0cmlldmUgbWVzaCBpbiB0d28gc3RhZ2VzIHRoYXQgYm90aCB0cmF2ZXJzZSB0aGUgZXJyb3IgbWFwOgogICAgICAvLyAtIGNvdW50RWxlbWVudHM6IGZpbmQgdXNlZCB2ZXJ0aWNlcyAoYW5kIGFzc2lnbiBlYWNoIGFuIGluZGV4KSwgYW5kIGNvdW50IHRyaWFuZ2xlcyAoZm9yIG1pbmltdW0gYWxsb2NhdGlvbikKICAgICAgLy8gLSBwcm9jZXNzVHJpYW5nbGU6IGZpbGwgdGhlIGFsbG9jYXRlZCB2ZXJ0aWNlcyAmIHRyaWFuZ2xlcyB0eXBlZCBhcnJheXMKCiAgICAgIGZ1bmN0aW9uIGNvdW50RWxlbWVudHMoYXgsIGF5LCBieCwgYnksIGN4LCBjeSkgewogICAgICAgIGNvbnN0IG14ID0gYXggKyBieCA+PiAxOwogICAgICAgIGNvbnN0IG15ID0gYXkgKyBieSA+PiAxOwogICAgICAgIGNvbnN0IGxlZ0xlbmd0aCA9IE1hdGguYWJzKGF4IC0gY3gpICsgTWF0aC5hYnMoYXkgLSBjeSk7CiAgICAgICAgaWYgKGxlZ0xlbmd0aCA+IDEgJiYgZXJyb3JzW215ICogc2l6ZSArIG14XSA+IG1heEVycm9yIHx8IGxlZ0xlbmd0aCA+IG1heFNjYWxlKSB7CiAgICAgICAgICBjb3VudEVsZW1lbnRzKGN4LCBjeSwgYXgsIGF5LCBteCwgbXkpOwogICAgICAgICAgY291bnRFbGVtZW50cyhieCwgYnksIGN4LCBjeSwgbXgsIG15KTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgaW5kaWNlc1theSAqIHNpemUgKyBheF0gPSBpbmRpY2VzW2F5ICogc2l6ZSArIGF4XSB8fCArK251bVZlcnRpY2VzOwogICAgICAgICAgaW5kaWNlc1tieSAqIHNpemUgKyBieF0gPSBpbmRpY2VzW2J5ICogc2l6ZSArIGJ4XSB8fCArK251bVZlcnRpY2VzOwogICAgICAgICAgaW5kaWNlc1tjeSAqIHNpemUgKyBjeF0gPSBpbmRpY2VzW2N5ICogc2l6ZSArIGN4XSB8fCArK251bVZlcnRpY2VzOwogICAgICAgICAgbnVtVHJpYW5nbGVzKys7CiAgICAgICAgfQogICAgICB9CiAgICAgIGNvdW50RWxlbWVudHMoMCwgMCwgbWF4LCBtYXgsIG1heCwgMCk7CiAgICAgIGNvdW50RWxlbWVudHMobWF4LCBtYXgsIDAsIDAsIDAsIG1heCk7CiAgICAgIGNvbnN0IHZlcnRpY2VzID0gbmV3IFVpbnQxNkFycmF5KG51bVZlcnRpY2VzICogMik7CiAgICAgIGNvbnN0IHRyaWFuZ2xlcyA9IG5ldyBVaW50MzJBcnJheShudW1UcmlhbmdsZXMgKiAzKTsKICAgICAgbGV0IHRyaUluZGV4ID0gMDsKICAgICAgZnVuY3Rpb24gcHJvY2Vzc1RyaWFuZ2xlKGF4LCBheSwgYngsIGJ5LCBjeCwgY3kpIHsKICAgICAgICBjb25zdCBteCA9IGF4ICsgYnggPj4gMTsKICAgICAgICBjb25zdCBteSA9IGF5ICsgYnkgPj4gMTsKICAgICAgICBjb25zdCBsZWdMZW5ndGggPSBNYXRoLmFicyhheCAtIGN4KSArIE1hdGguYWJzKGF5IC0gY3kpOwogICAgICAgIGlmIChsZWdMZW5ndGggPiAxICYmIGVycm9yc1tteSAqIHNpemUgKyBteF0gPiBtYXhFcnJvciB8fCBsZWdMZW5ndGggPiBtYXhTY2FsZSkgewogICAgICAgICAgLy8gdHJpYW5nbGUgZG9lc24ndCBhcHByb3hpbWF0ZSB0aGUgc3VyZmFjZSB3ZWxsIGVub3VnaDsgZHJpbGwgZG93biBmdXJ0aGVyCiAgICAgICAgICBwcm9jZXNzVHJpYW5nbGUoY3gsIGN5LCBheCwgYXksIG14LCBteSk7CiAgICAgICAgICBwcm9jZXNzVHJpYW5nbGUoYngsIGJ5LCBjeCwgY3ksIG14LCBteSk7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgIC8vIGFkZCBhIHRyaWFuZ2xlCiAgICAgICAgICBjb25zdCBhID0gaW5kaWNlc1theSAqIHNpemUgKyBheF0gLSAxOwogICAgICAgICAgY29uc3QgYiA9IGluZGljZXNbYnkgKiBzaXplICsgYnhdIC0gMTsKICAgICAgICAgIGNvbnN0IGMgPSBpbmRpY2VzW2N5ICogc2l6ZSArIGN4XSAtIDE7CiAgICAgICAgICB2ZXJ0aWNlc1syICogYV0gPSBheDsKICAgICAgICAgIHZlcnRpY2VzWzIgKiBhICsgMV0gPSBheTsKICAgICAgICAgIHZlcnRpY2VzWzIgKiBiXSA9IGJ4OwogICAgICAgICAgdmVydGljZXNbMiAqIGIgKyAxXSA9IGJ5OwogICAgICAgICAgdmVydGljZXNbMiAqIGNdID0gY3g7CiAgICAgICAgICB2ZXJ0aWNlc1syICogYyArIDFdID0gY3k7CiAgICAgICAgICB0cmlhbmdsZXNbdHJpSW5kZXgrK10gPSBhOwogICAgICAgICAgdHJpYW5nbGVzW3RyaUluZGV4KytdID0gYjsKICAgICAgICAgIHRyaWFuZ2xlc1t0cmlJbmRleCsrXSA9IGM7CiAgICAgICAgfQogICAgICB9CiAgICAgIHByb2Nlc3NUcmlhbmdsZSgwLCAwLCBtYXgsIG1heCwgbWF4LCAwKTsKICAgICAgcHJvY2Vzc1RyaWFuZ2xlKG1heCwgbWF4LCAwLCAwLCAwLCBtYXgpOwogICAgICByZXR1cm4gewogICAgICAgIHZlcnRpY2VzLAogICAgICAgIHRyaWFuZ2xlcwogICAgICB9OwogICAgfQogIH0KCiAgLy8gaHR0cHM6Ly9naXRodWIuY29tL0Nlc2l1bUdTL2Nlc2l1bS9ibG9iLzEuNzYvU291cmNlL1dvcmtlcnNFUzYvY3JlYXRlVmVydGljZXNGcm9tUXVhbnRpemVkVGVycmFpbk1lc2guanMKCiAgdmFyIG1hcnRpbmkgPSBudWxsOwogIGZ1bmN0aW9uIGRlY29kZVRlcnJhaW4ocGFyYW1ldGVycywgdHJhbnNmZXJhYmxlT2JqZWN0cykgewogICAgdmFyIGltYWdlRGF0YSA9IHBhcmFtZXRlcnMuaW1hZ2VEYXRhLAogICAgICBfcGFyYW1ldGVycyR0aWxlU2l6ZSA9IHBhcmFtZXRlcnMudGlsZVNpemUsCiAgICAgIHRpbGVTaXplID0gX3BhcmFtZXRlcnMkdGlsZVNpemUgPT09IHZvaWQgMCA/IDI1NiA6IF9wYXJhbWV0ZXJzJHRpbGVTaXplLAogICAgICBlcnJvckxldmVsID0gcGFyYW1ldGVycy5lcnJvckxldmVsOwogICAgdmFyIHBpeGVscyA9IG5kYXJyYXkobmV3IFVpbnQ4QXJyYXkoaW1hZ2VEYXRhKSwgW3RpbGVTaXplLCB0aWxlU2l6ZSwgNF0sIFs0LCA0ICogdGlsZVNpemUsIDFdLCAwKTsKCiAgICAvLyBUaWxlIHNpemUgbXVzdCBiZSBtYWludGFpbmVkIHRocm91Z2ggdGhlIGxpZmUgb2YgdGhlIHdvcmtlcgogICAgbWFydGluaSAhPT0gbnVsbCAmJiBtYXJ0aW5pICE9PSB2b2lkIDAgPyBtYXJ0aW5pIDogbWFydGluaSA9IG5ldyBNYXJ0aW5pKHRpbGVTaXplICsgMSk7CiAgICB2YXIgdGVycmFpbiA9IHJnYlRlcnJhaW5Ub0dyaWQocGl4ZWxzKTsKICAgIHZhciB0aWxlID0gbWFydGluaS5jcmVhdGVUaWxlKHRlcnJhaW4pOwoKICAgIC8vIGdldCBhIG1lc2ggKHZlcnRpY2VzIGFuZCB0cmlhbmdsZXMgaW5kaWNlcykgZm9yIGEgMTBtIGVycm9yCiAgICB2YXIgbWVzaCA9IHRpbGUuZ2V0TWVzaChlcnJvckxldmVsLCBwYXJhbWV0ZXJzLm1heExlbmd0aCk7CiAgICByZXR1cm4gY3JlYXRlUXVhbnRpemVkTWVzaERhdGEodGlsZSwgbWVzaCwgdGlsZVNpemUpOwogIH0KICBzZWxmLm9ubWVzc2FnZSA9IGZ1bmN0aW9uIChtc2cpIHsKICAgIHZhciBfbXNnJGRhdGEgPSBtc2cuZGF0YSwKICAgICAgaWQgPSBfbXNnJGRhdGEuaWQsCiAgICAgIHBheWxvYWQgPSBfbXNnJGRhdGEucGF5bG9hZDsKICAgIGlmIChpZCA9PSBudWxsKSByZXR1cm47CiAgICB2YXIgb2JqZWN0cyA9IFtdOwogICAgdmFyIHJlcyA9IG51bGw7CiAgICB0cnkgewogICAgICByZXMgPSBkZWNvZGVUZXJyYWluKHBheWxvYWQpOwogICAgICBvYmplY3RzLnB1c2gocmVzLmluZGljZXMuYnVmZmVyKTsKICAgICAgb2JqZWN0cy5wdXNoKHJlcy5xdWFudGl6ZWRWZXJ0aWNlcy5idWZmZXIpOwogICAgICBzZWxmLnBvc3RNZXNzYWdlKHsKICAgICAgICBpZDogaWQsCiAgICAgICAgcGF5bG9hZDogcmVzCiAgICAgIH0sIG9iamVjdHMpOwogICAgfSBjYXRjaCAoZXJyKSB7CiAgICAgIHNlbGYucG9zdE1lc3NhZ2UoewogICAgICAgIGlkOiBpZCwKICAgICAgICBlcnI6IGVyci50b1N0cmluZygpCiAgICAgIH0pOwogICAgfSBmaW5hbGx5IHsKICAgICAgcmVzID0gbnVsbDsKICAgICAgb2JqZWN0cyA9IG51bGw7CiAgICB9CiAgfTsKCn0pKCk7Cgo=', null, false);
1072
+ /* eslint-enable */
2435
1073
 
1074
+ var MapboxTerrainProvider = /*#__PURE__*/function (_MartiniTerrainProvid) {
2436
1075
  function MapboxTerrainProvider() {
2437
1076
  var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2438
-
2439
1077
  _classCallCheck(this, MapboxTerrainProvider);
2440
-
2441
1078
  var resource = new MapboxTerrainResource(opts);
2442
- return _super2.call(this, _objectSpread2(_objectSpread2({}, opts), {}, {
2443
- resource: resource
2444
- }));
1079
+ var decoder = new WorkerFarmTerrainDecoder({
1080
+ worker: new WorkerFactory()
1081
+ });
1082
+ return _callSuper(this, MapboxTerrainProvider, [_objectSpread2(_objectSpread2({}, opts), {}, {
1083
+ resource: resource,
1084
+ decoder: decoder
1085
+ })]);
2445
1086
  }
2446
-
1087
+ _inherits(MapboxTerrainProvider, _MartiniTerrainProvid);
2447
1088
  return _createClass(MapboxTerrainProvider);
2448
1089
  }(MartiniTerrainProvider);
2449
1090
 
2450
- exports.DefaultHeightmapResource = DefaultHeightmapResource;
2451
- exports.MapboxTerrainResource = MapboxTerrainResource;
2452
- exports.MartiniTerrainProvider = MartiniTerrainProvider;
2453
- exports["default"] = MapboxTerrainProvider;
1091
+ export { DefaultHeightmapResource, MapboxTerrainResource, MartiniTerrainProvider, MapboxTerrainProvider as default };
2454
1092
  //# sourceMappingURL=index.js.map