@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/.babelrc +1 -6
- package/.env.example +1 -0
- package/.npmrc +1 -0
- package/README.md +60 -12
- package/dist/index.cjs +1099 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.js +787 -2149
- package/dist/index.js.map +1 -1
- package/package.json +26 -31
- package/rollup.config.js +13 -6
- package/tsconfig.json +3 -3
- package/typings/worker-loader.d.ts +10 -0
- package/webpack.config.js +7 -1
- package/.gitmodules +0 -3
package/dist/index.js
CHANGED
|
@@ -1,256 +1,448 @@
|
|
|
1
|
-
|
|
1
|
+
import { Resource, Credit, Rectangle, Cartographic, OrientedBoundingBox, BoundingSphere, QuantizedMeshTerrainData, TerrainProvider, Event, Math as Math$1, Ellipsoid, WebMercatorTilingScheme } from 'cesium';
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
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
|
|
36
|
-
|
|
37
|
-
} catch (
|
|
38
|
-
|
|
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
|
|
52
|
-
|
|
53
|
-
return new Promise(function (
|
|
54
|
-
var
|
|
55
|
-
|
|
56
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
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
|
-
|
|
86
|
-
|
|
87
|
-
|
|
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
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
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
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
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
|
-
|
|
128
|
-
|
|
129
|
-
|
|
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
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
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
|
-
|
|
151
|
-
|
|
152
|
-
return
|
|
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
|
-
|
|
157
|
-
if (
|
|
158
|
-
|
|
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
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
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
|
|
175
|
-
|
|
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
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
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
|
-
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
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
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
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
|
|
228
|
-
|
|
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
|
-
|
|
232
|
-
|
|
423
|
+
function _superPropBase(t, o) {
|
|
424
|
+
for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t)););
|
|
425
|
+
return t;
|
|
233
426
|
}
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
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
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
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
|
-
|
|
253
|
-
|
|
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
|
-
|
|
274
|
-
|
|
275
|
-
|
|
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(
|
|
473
|
+
var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(coords) {
|
|
293
474
|
var url, img;
|
|
294
|
-
return
|
|
295
|
-
while (1) {
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
case 5:
|
|
307
|
-
case "end":
|
|
308
|
-
return _context.stop();
|
|
309
|
-
}
|
|
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 =
|
|
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;
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
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
|
-
|
|
2030
|
-
|
|
2031
|
-
|
|
2032
|
-
|
|
2033
|
-
|
|
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
|
-
|
|
2037
|
-
|
|
2038
|
-
|
|
2039
|
-
|
|
2040
|
-
|
|
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
|
-
|
|
2044
|
-
|
|
2045
|
-
|
|
2046
|
-
|
|
2047
|
-
|
|
2048
|
-
|
|
2049
|
-
|
|
2050
|
-
|
|
2051
|
-
|
|
2052
|
-
|
|
2053
|
-
|
|
2054
|
-
|
|
2055
|
-
|
|
2056
|
-
|
|
2057
|
-
|
|
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
|
-
|
|
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
|
-
|
|
2082
|
-
|
|
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
|
-
|
|
2088
|
-
|
|
2089
|
-
|
|
2090
|
-
|
|
2091
|
-
|
|
2092
|
-
|
|
2093
|
-
|
|
2094
|
-
|
|
2095
|
-
|
|
2096
|
-
|
|
2097
|
-
|
|
2098
|
-
|
|
2099
|
-
|
|
2100
|
-
|
|
2101
|
-
|
|
2102
|
-
|
|
2103
|
-
|
|
2104
|
-
|
|
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
|
-
|
|
2113
|
-
|
|
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
|
-
|
|
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 =
|
|
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
|
|
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.
|
|
2198
|
-
this.
|
|
2199
|
-
|
|
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
|
-
|
|
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 :
|
|
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
|
-
}
|
|
2239
|
-
|
|
2240
|
-
|
|
2241
|
-
|
|
2242
|
-
|
|
2243
|
-
|
|
2244
|
-
|
|
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(
|
|
2251
|
-
var _this$resource, tileSize, getTilePixels, px, pixelData, tileRect, err, maxLength, params, res;
|
|
2252
|
-
|
|
2253
|
-
|
|
2254
|
-
|
|
2255
|
-
|
|
2256
|
-
|
|
2257
|
-
|
|
2258
|
-
|
|
2259
|
-
|
|
2260
|
-
|
|
2261
|
-
|
|
2262
|
-
|
|
2263
|
-
|
|
2264
|
-
|
|
2265
|
-
|
|
2266
|
-
|
|
2267
|
-
|
|
2268
|
-
|
|
2269
|
-
|
|
2270
|
-
|
|
2271
|
-
|
|
2272
|
-
maxLength
|
|
2273
|
-
|
|
2274
|
-
|
|
2275
|
-
|
|
2276
|
-
|
|
2277
|
-
|
|
2278
|
-
|
|
2279
|
-
|
|
2280
|
-
|
|
2281
|
-
|
|
2282
|
-
|
|
2283
|
-
|
|
2284
|
-
|
|
2285
|
-
|
|
2286
|
-
|
|
2287
|
-
|
|
2288
|
-
|
|
2289
|
-
|
|
2290
|
-
|
|
2291
|
-
|
|
2292
|
-
|
|
2293
|
-
|
|
2294
|
-
|
|
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, [[
|
|
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 =
|
|
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 =
|
|
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
|
-
|
|
2362
|
-
|
|
2363
|
-
|
|
2364
|
-
|
|
2365
|
-
|
|
2366
|
-
|
|
2367
|
-
|
|
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 =
|
|
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
|
-
|
|
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(
|
|
2384
|
-
var orientedBoundingBox =
|
|
2385
|
-
var boundingSphere =
|
|
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
|
|
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 =
|
|
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
|
-
|
|
2432
|
-
|
|
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
|
-
|
|
2443
|
-
|
|
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
|
-
|
|
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
|