1 | define('@glimmer/util', ['exports', '@glimmer/env'], function (exports, env) { 'use strict';
|
2 |
|
3 | var EMPTY_ARRAY = Object.freeze([]);
|
4 | function emptyArray() {
|
5 | return EMPTY_ARRAY;
|
6 | }
|
7 | var EMPTY_STRING_ARRAY = emptyArray();
|
8 | var EMPTY_NUMBER_ARRAY = emptyArray();
|
9 | /**
|
10 | * This function returns `true` if the input array is the special empty array sentinel,
|
11 | * which is sometimes used for optimizations.
|
12 | */
|
13 |
|
14 | function isEmptyArray(input) {
|
15 | return input === EMPTY_ARRAY;
|
16 | }
|
17 |
|
18 | // import Logger from './logger';
|
19 |
|
20 | function debugAssert(test, msg) {
|
21 | // if (!alreadyWarned) {
|
22 | // alreadyWarned = true;
|
23 | // Logger.warn("Don't leave debug assertions on in public builds");
|
24 | // }
|
25 | if (!test) {
|
26 | throw new Error(msg || 'assertion failure');
|
27 | }
|
28 | }
|
29 | function deprecate(desc) {
|
30 | LOCAL_LOGGER.warn("DEPRECATION: " + desc);
|
31 | }
|
32 |
|
33 | function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
34 |
|
35 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
|
36 |
|
37 | function dict() {
|
38 | return Object.create(null);
|
39 | }
|
40 | function isDict(u) {
|
41 | return u !== null && u !== undefined;
|
42 | }
|
43 | function isObject(u) {
|
44 | return typeof u === 'function' || typeof u === 'object' && u !== null;
|
45 | }
|
46 | var StackImpl = /*#__PURE__*/function () {
|
47 | function StackImpl(values) {
|
48 | if (values === void 0) {
|
49 | values = [];
|
50 | }
|
51 |
|
52 | this.current = null;
|
53 | this.stack = values;
|
54 | }
|
55 |
|
56 | var _proto = StackImpl.prototype;
|
57 |
|
58 | _proto.push = function push(item) {
|
59 | this.current = item;
|
60 | this.stack.push(item);
|
61 | };
|
62 |
|
63 | _proto.pop = function pop() {
|
64 | var item = this.stack.pop();
|
65 | var len = this.stack.length;
|
66 | this.current = len === 0 ? null : this.stack[len - 1];
|
67 | return item === undefined ? null : item;
|
68 | };
|
69 |
|
70 | _proto.nth = function nth(from) {
|
71 | var len = this.stack.length;
|
72 | return len < from ? null : this.stack[len - from];
|
73 | };
|
74 |
|
75 | _proto.isEmpty = function isEmpty() {
|
76 | return this.stack.length === 0;
|
77 | };
|
78 |
|
79 | _proto.toArray = function toArray() {
|
80 | return this.stack;
|
81 | };
|
82 |
|
83 | _createClass(StackImpl, [{
|
84 | key: "size",
|
85 | get: function get() {
|
86 | return this.stack.length;
|
87 | }
|
88 | }]);
|
89 |
|
90 | return StackImpl;
|
91 | }();
|
92 |
|
93 | function clearElement(parent) {
|
94 | var current = parent.firstChild;
|
95 |
|
96 | while (current) {
|
97 | var next = current.nextSibling;
|
98 | parent.removeChild(current);
|
99 | current = next;
|
100 | }
|
101 | }
|
102 |
|
103 | var SERIALIZATION_FIRST_NODE_STRING = '%+b:0%';
|
104 | function isSerializationFirstNode(node) {
|
105 | return node.nodeValue === SERIALIZATION_FIRST_NODE_STRING;
|
106 | }
|
107 |
|
108 | var _a;
|
109 |
|
110 | var objKeys = Object.keys;
|
111 |
|
112 | function assignFn(obj) {
|
113 | for (var i = 1; i < arguments.length; i++) {
|
114 | var assignment = arguments[i];
|
115 | if (assignment === null || typeof assignment !== 'object') continue;
|
116 | var keys = objKeys(assignment);
|
117 |
|
118 | for (var j = 0; j < keys.length; j++) {
|
119 | var key = keys[j];
|
120 | obj[key] = assignment[key];
|
121 | }
|
122 | }
|
123 |
|
124 | return obj;
|
125 | }
|
126 |
|
127 | var assign = (_a = Object.assign) !== null && _a !== void 0 ? _a : assignFn;
|
128 | function fillNulls(count) {
|
129 | var arr = new Array(count);
|
130 |
|
131 | for (var i = 0; i < count; i++) {
|
132 | arr[i] = null;
|
133 | }
|
134 |
|
135 | return arr;
|
136 | }
|
137 | function values(obj) {
|
138 | var vals = [];
|
139 |
|
140 | for (var key in obj) {
|
141 | vals.push(obj[key]);
|
142 | }
|
143 |
|
144 | return vals;
|
145 | }
|
146 |
|
147 | /**
|
148 | Strongly hint runtimes to intern the provided string.
|
149 |
|
150 | When do I need to use this function?
|
151 |
|
152 | For the most part, never. Pre-mature optimization is bad, and often the
|
153 | runtime does exactly what you need it to, and more often the trade-off isn't
|
154 | worth it.
|
155 |
|
156 | Why?
|
157 |
|
158 | Runtimes store strings in at least 2 different representations:
|
159 | Ropes and Symbols (interned strings). The Rope provides a memory efficient
|
160 | data-structure for strings created from concatenation or some other string
|
161 | manipulation like splitting.
|
162 |
|
163 | Unfortunately checking equality of different ropes can be quite costly as
|
164 | runtimes must resort to clever string comparison algorithms. These
|
165 | algorithms typically cost in proportion to the length of the string.
|
166 | Luckily, this is where the Symbols (interned strings) shine. As Symbols are
|
167 | unique by their string content, equality checks can be done by pointer
|
168 | comparison.
|
169 |
|
170 | How do I know if my string is a rope or symbol?
|
171 |
|
172 | Typically (warning general sweeping statement, but truthy in runtimes at
|
173 | present) static strings created as part of the JS source are interned.
|
174 | Strings often used for comparisons can be interned at runtime if some
|
175 | criteria are met. One of these criteria can be the size of the entire rope.
|
176 | For example, in chrome 38 a rope longer then 12 characters will not
|
177 | intern, nor will segments of that rope.
|
178 |
|
179 | Some numbers: http://jsperf.com/eval-vs-keys/8
|
180 |
|
181 | Known Trick™
|
182 |
|
183 | @private
|
184 | @return {String} interned version of the provided string
|
185 | */
|
186 | function intern(str) {
|
187 | var obj = {};
|
188 | obj[str] = 1;
|
189 |
|
190 | for (var key in obj) {
|
191 | if (key === str) {
|
192 | return key;
|
193 | }
|
194 | }
|
195 |
|
196 | return str;
|
197 | }
|
198 |
|
199 | var HAS_NATIVE_PROXY = typeof Proxy === 'function';
|
200 | var HAS_NATIVE_SYMBOL = function () {
|
201 | if (typeof Symbol !== 'function') {
|
202 | return false;
|
203 | } // eslint-disable-next-line symbol-description
|
204 |
|
205 |
|
206 | return typeof Symbol() === 'symbol';
|
207 | }();
|
208 | function keys(obj) {
|
209 | return Object.keys(obj);
|
210 | }
|
211 | function unwrap(val) {
|
212 | if (val === null || val === undefined) throw new Error("Expected value to be present");
|
213 | return val;
|
214 | }
|
215 | function expect(val, message) {
|
216 | if (val === null || val === undefined) throw new Error(message);
|
217 | return val;
|
218 | }
|
219 | function unreachable(message) {
|
220 | if (message === void 0) {
|
221 | message = 'unreachable';
|
222 | }
|
223 |
|
224 | return new Error(message);
|
225 | }
|
226 | function exhausted(value) {
|
227 | throw new Error("Exhausted " + value);
|
228 | }
|
229 | var tuple = function tuple() {
|
230 | for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
231 | args[_key] = arguments[_key];
|
232 | }
|
233 |
|
234 | return args;
|
235 | };
|
236 | function enumerableSymbol(key) {
|
237 | return intern("__" + key + Math.floor(Math.random() * Date.now()) + "__");
|
238 | }
|
239 | var symbol = HAS_NATIVE_SYMBOL ? Symbol : enumerableSymbol;
|
240 |
|
241 | function _createForOfIteratorHelperLoose(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } it = o[Symbol.iterator](); return it.next.bind(it); }
|
242 |
|
243 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
244 |
|
245 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
246 |
|
247 | function strip(strings) {
|
248 | var out = '';
|
249 |
|
250 | for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
251 | args[_key - 1] = arguments[_key];
|
252 | }
|
253 |
|
254 | for (var i = 0; i < strings.length; i++) {
|
255 | var string = strings[i];
|
256 | var dynamic = args[i] !== undefined ? String(args[i]) : '';
|
257 | out += "" + string + dynamic;
|
258 | }
|
259 |
|
260 | var lines = out.split('\n');
|
261 |
|
262 | while (lines.length && lines[0].match(/^\s*$/)) {
|
263 | lines.shift();
|
264 | }
|
265 |
|
266 | while (lines.length && lines[lines.length - 1].match(/^\s*$/)) {
|
267 | lines.pop();
|
268 | }
|
269 |
|
270 | var min = Infinity;
|
271 |
|
272 | for (var _iterator = _createForOfIteratorHelperLoose(lines), _step; !(_step = _iterator()).done;) {
|
273 | var line = _step.value;
|
274 | var leading = line.match(/^\s*/)[0].length;
|
275 | min = Math.min(min, leading);
|
276 | }
|
277 |
|
278 | var stripped = [];
|
279 |
|
280 | for (var _iterator2 = _createForOfIteratorHelperLoose(lines), _step2; !(_step2 = _iterator2()).done;) {
|
281 | var _line = _step2.value;
|
282 | stripped.push(_line.slice(min));
|
283 | }
|
284 |
|
285 | return stripped.join('\n');
|
286 | }
|
287 |
|
288 | function isHandle(value) {
|
289 | return value >= 0;
|
290 | }
|
291 | function isNonPrimitiveHandle(value) {
|
292 | return value > 3
|
293 | /* ENCODED_UNDEFINED_HANDLE */
|
294 | ;
|
295 | }
|
296 | function constants() {
|
297 | for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {
|
298 | values[_key] = arguments[_key];
|
299 | }
|
300 |
|
301 | return [false, true, null, undefined].concat(values);
|
302 | }
|
303 | function isSmallInt(value) {
|
304 | return value % 1 === 0 && value <= 536870911
|
305 | /* MAX_INT */
|
306 | && value >= -536870912
|
307 | /* MIN_INT */
|
308 | ;
|
309 | }
|
310 | function encodeNegative(num) {
|
311 |
|
312 | return num & -536870913
|
313 | /* SIGN_BIT */
|
314 | ;
|
315 | }
|
316 | function decodeNegative(num) {
|
317 |
|
318 | return num | ~-536870913
|
319 | /* SIGN_BIT */
|
320 | ;
|
321 | }
|
322 | function encodePositive(num) {
|
323 |
|
324 | return ~num;
|
325 | }
|
326 | function decodePositive(num) {
|
327 |
|
328 | return ~num;
|
329 | }
|
330 | function encodeHandle(num) {
|
331 |
|
332 | return num;
|
333 | }
|
334 | function decodeHandle(num) {
|
335 |
|
336 | return num;
|
337 | }
|
338 | function encodeImmediate(num) {
|
339 | num |= 0;
|
340 | return num < 0 ? encodeNegative(num) : encodePositive(num);
|
341 | }
|
342 | function decodeImmediate(num) {
|
343 | num |= 0;
|
344 | return num > -536870913
|
345 | /* SIGN_BIT */
|
346 | ? decodePositive(num) : decodeNegative(num);
|
347 | } // Warm
|
348 | [1, -1].forEach(function (x) {
|
349 | return decodeImmediate(encodeImmediate(x));
|
350 | });
|
351 |
|
352 | function unwrapHandle(handle) {
|
353 | if (typeof handle === 'number') {
|
354 | return handle;
|
355 | } else {
|
356 | var error = handle.errors[0];
|
357 | throw new Error("Compile Error: " + error.problem + " @ " + error.span.start + ".." + error.span.end);
|
358 | }
|
359 | }
|
360 | function unwrapTemplate(template) {
|
361 | if (template.result === 'error') {
|
362 | throw new Error("Compile Error: " + template.problem + " @ " + template.span.start + ".." + template.span.end);
|
363 | }
|
364 |
|
365 | return template;
|
366 | }
|
367 | function extractHandle(handle) {
|
368 | if (typeof handle === 'number') {
|
369 | return handle;
|
370 | } else {
|
371 | return handle.handle;
|
372 | }
|
373 | }
|
374 | function isOkHandle(handle) {
|
375 | return typeof handle === 'number';
|
376 | }
|
377 | function isErrHandle(handle) {
|
378 | return typeof handle === 'number';
|
379 | }
|
380 |
|
381 | var weakSet = typeof WeakSet === 'function' ? WeakSet : /*#__PURE__*/function () {
|
382 | function WeakSetPolyFill() {
|
383 | this._map = new WeakMap();
|
384 | }
|
385 |
|
386 | var _proto = WeakSetPolyFill.prototype;
|
387 |
|
388 | _proto.add = function add(val) {
|
389 | this._map.set(val, true);
|
390 |
|
391 | return this;
|
392 | };
|
393 |
|
394 | _proto["delete"] = function _delete(val) {
|
395 | return this._map["delete"](val);
|
396 | };
|
397 |
|
398 | _proto.has = function has(val) {
|
399 | return this._map.has(val);
|
400 | };
|
401 |
|
402 | return WeakSetPolyFill;
|
403 | }();
|
404 |
|
405 | function castToSimple(node) {
|
406 | if (isDocument(node)) {
|
407 | return node;
|
408 | } else if (isElement(node)) {
|
409 | return node;
|
410 | } else {
|
411 | return node;
|
412 | }
|
413 | }
|
414 | function castToBrowser(node, sugaryCheck) {
|
415 | if (node === null || node === undefined) {
|
416 | return null;
|
417 | }
|
418 |
|
419 | if (typeof document === undefined) {
|
420 | throw new Error('Attempted to cast to a browser node in a non-browser context');
|
421 | }
|
422 |
|
423 | if (isDocument(node)) {
|
424 | return node;
|
425 | }
|
426 |
|
427 | if (node.ownerDocument !== document) {
|
428 | throw new Error('Attempted to cast to a browser node with a node that was not created from this document');
|
429 | }
|
430 |
|
431 | return checkNode(node, sugaryCheck);
|
432 | }
|
433 |
|
434 | function checkError(from, check) {
|
435 | return new Error("cannot cast a " + from + " into " + check);
|
436 | }
|
437 |
|
438 | function isDocument(node) {
|
439 | return node.nodeType === 9
|
440 | /* DOCUMENT_NODE */
|
441 | ;
|
442 | }
|
443 |
|
444 | function isElement(node) {
|
445 | return node.nodeType === 1
|
446 | /* ELEMENT_NODE */
|
447 | ;
|
448 | }
|
449 |
|
450 | function checkNode(node, check) {
|
451 | var isMatch = false;
|
452 |
|
453 | if (node !== null) {
|
454 | if (typeof check === 'string') {
|
455 | isMatch = stringCheckNode(node, check);
|
456 | } else if (Array.isArray(check)) {
|
457 | isMatch = check.some(function (c) {
|
458 | return stringCheckNode(node, c);
|
459 | });
|
460 | } else {
|
461 | throw unreachable();
|
462 | }
|
463 | }
|
464 |
|
465 | if (isMatch) {
|
466 | return node;
|
467 | } else {
|
468 | throw checkError("SimpleElement(" + node + ")", check);
|
469 | }
|
470 | }
|
471 |
|
472 | function stringCheckNode(node, check) {
|
473 | switch (check) {
|
474 | case 'NODE':
|
475 | return true;
|
476 |
|
477 | case 'HTML':
|
478 | return node instanceof HTMLElement;
|
479 |
|
480 | case 'SVG':
|
481 | return node instanceof SVGElement;
|
482 |
|
483 | case 'ELEMENT':
|
484 | return node instanceof Element;
|
485 |
|
486 | default:
|
487 | if (check.toUpperCase() === check) {
|
488 | throw new Error("BUG: this code is missing handling for a generic node type");
|
489 | }
|
490 |
|
491 | return node instanceof Element && node.tagName.toLowerCase() === check;
|
492 | }
|
493 | }
|
494 |
|
495 | function _createForOfIteratorHelperLoose$1(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$1(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } it = o[Symbol.iterator](); return it.next.bind(it); }
|
496 |
|
497 | function _unsupportedIterableToArray$1(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$1(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray$1(o, minLen); }
|
498 |
|
499 | function _arrayLikeToArray$1(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
500 |
|
501 | function isPresent(list) {
|
502 | return list.length > 0;
|
503 | }
|
504 | function ifPresent(list, ifPresent, otherwise) {
|
505 | if (isPresent(list)) {
|
506 | return ifPresent(list);
|
507 | } else {
|
508 | return otherwise();
|
509 | }
|
510 | }
|
511 | function toPresentOption(list) {
|
512 | if (isPresent(list)) {
|
513 | return list;
|
514 | } else {
|
515 | return null;
|
516 | }
|
517 | }
|
518 | function assertPresent(list, message) {
|
519 | if (message === void 0) {
|
520 | message = "unexpected empty list";
|
521 | }
|
522 |
|
523 | if (!isPresent(list)) {
|
524 | throw new Error(message);
|
525 | }
|
526 | }
|
527 | function mapPresent(list, callback) {
|
528 | if (list === null) {
|
529 | return null;
|
530 | }
|
531 |
|
532 | var out = [];
|
533 |
|
534 | for (var _iterator = _createForOfIteratorHelperLoose$1(list), _step; !(_step = _iterator()).done;) {
|
535 | var item = _step.value;
|
536 | out.push(callback(item));
|
537 | }
|
538 |
|
539 | return out;
|
540 | }
|
541 |
|
542 | function buildUntouchableThis(source) {
|
543 | var context = null;
|
544 |
|
545 | if (env.DEBUG && HAS_NATIVE_PROXY) {
|
546 | var assertOnProperty = function assertOnProperty(property) {
|
547 | throw new Error("You accessed `this." + String(property) + "` from a function passed to the " + source + ", but the function itself was not bound to a valid `this` context. Consider updating to use a bound function (for instance, use an arrow function, `() => {}`).");
|
548 | };
|
549 |
|
550 | context = new Proxy({}, {
|
551 | get: function get(_target, property) {
|
552 | assertOnProperty(property);
|
553 | },
|
554 | set: function set(_target, property) {
|
555 | assertOnProperty(property);
|
556 | return false;
|
557 | },
|
558 | has: function has(_target, property) {
|
559 | assertOnProperty(property);
|
560 | return false;
|
561 | }
|
562 | });
|
563 | }
|
564 |
|
565 | return context;
|
566 | }
|
567 |
|
568 | var debugToString;
|
569 |
|
570 | if (env.DEBUG) {
|
571 | var getFunctionName = function getFunctionName(fn) {
|
572 | var functionName = fn.name;
|
573 |
|
574 | if (functionName === undefined) {
|
575 | var match = Function.prototype.toString.call(fn).match(/function (\w+)\s*\(/);
|
576 | functionName = match && match[1] || '';
|
577 | }
|
578 |
|
579 | return functionName.replace(/^bound /, '');
|
580 | };
|
581 |
|
582 | var getObjectName = function getObjectName(obj) {
|
583 | var name;
|
584 | var className;
|
585 |
|
586 | if (obj.constructor && typeof obj.constructor === 'function') {
|
587 | className = getFunctionName(obj.constructor);
|
588 | }
|
589 |
|
590 | if ('toString' in obj && obj.toString !== Object.prototype.toString && obj.toString !== Function.prototype.toString) {
|
591 | name = obj.toString();
|
592 | } // If the class has a decent looking name, and the `toString` is one of the
|
593 | // default Ember toStrings, replace the constructor portion of the toString
|
594 | // with the class name. We check the length of the class name to prevent doing
|
595 | // this when the value is minified.
|
596 |
|
597 |
|
598 | if (name && name.match(/<.*:ember\d+>/) && className && className[0] !== '_' && className.length > 2 && className !== 'Class') {
|
599 | return name.replace(/<.*:/, "<" + className + ":");
|
600 | }
|
601 |
|
602 | return name || className;
|
603 | };
|
604 |
|
605 | var getPrimitiveName = function getPrimitiveName(value) {
|
606 | return String(value);
|
607 | };
|
608 |
|
609 | debugToString = function debugToString(value) {
|
610 | if (typeof value === 'function') {
|
611 | return getFunctionName(value) || "(unknown function)";
|
612 | } else if (typeof value === 'object' && value !== null) {
|
613 | return getObjectName(value) || "(unknown object)";
|
614 | } else {
|
615 | return getPrimitiveName(value);
|
616 | }
|
617 | };
|
618 | }
|
619 |
|
620 | var debugToString$1 = debugToString;
|
621 |
|
622 | var beginTestSteps;
|
623 | var endTestSteps;
|
624 | var verifySteps;
|
625 | var logStep;
|
626 |
|
627 | /**
|
628 | * This constant exists to make it easier to differentiate normal logs from
|
629 | * errant console.logs. LOCAL_LOGGER should only be used inside a
|
630 | * LOCAL_SHOULD_LOG check.
|
631 | *
|
632 | * It does not alleviate the need to check LOCAL_SHOULD_LOG, which is used
|
633 | * for stripping.
|
634 | */
|
635 |
|
636 | var LOCAL_LOGGER = console;
|
637 | /**
|
638 | * This constant exists to make it easier to differentiate normal logs from
|
639 | * errant console.logs. LOGGER can be used outside of LOCAL_SHOULD_LOG checks,
|
640 | * and is meant to be used in the rare situation where a console.* call is
|
641 | * actually appropriate.
|
642 | */
|
643 |
|
644 | var LOGGER = console;
|
645 | function assertNever(value, desc) {
|
646 | if (desc === void 0) {
|
647 | desc = 'unexpected unreachable branch';
|
648 | }
|
649 |
|
650 | LOGGER.log('unreachable', value);
|
651 | LOGGER.log(desc + " :: " + JSON.stringify(value) + " (" + value + ")");
|
652 | throw new Error("code reached unreachable");
|
653 | }
|
654 |
|
655 | exports.EMPTY_ARRAY = EMPTY_ARRAY;
|
656 | exports.EMPTY_NUMBER_ARRAY = EMPTY_NUMBER_ARRAY;
|
657 | exports.EMPTY_STRING_ARRAY = EMPTY_STRING_ARRAY;
|
658 | exports.HAS_NATIVE_PROXY = HAS_NATIVE_PROXY;
|
659 | exports.HAS_NATIVE_SYMBOL = HAS_NATIVE_SYMBOL;
|
660 | exports.LOCAL_LOGGER = LOCAL_LOGGER;
|
661 | exports.LOGGER = LOGGER;
|
662 | exports.SERIALIZATION_FIRST_NODE_STRING = SERIALIZATION_FIRST_NODE_STRING;
|
663 | exports.Stack = StackImpl;
|
664 | exports._WeakSet = weakSet;
|
665 | exports.assert = debugAssert;
|
666 | exports.assertNever = assertNever;
|
667 | exports.assertPresent = assertPresent;
|
668 | exports.assign = assign;
|
669 | exports.beginTestSteps = beginTestSteps;
|
670 | exports.buildUntouchableThis = buildUntouchableThis;
|
671 | exports.castToBrowser = castToBrowser;
|
672 | exports.castToSimple = castToSimple;
|
673 | exports.checkNode = checkNode;
|
674 | exports.clearElement = clearElement;
|
675 | exports.constants = constants;
|
676 | exports.debugToString = debugToString$1;
|
677 | exports.decodeHandle = decodeHandle;
|
678 | exports.decodeImmediate = decodeImmediate;
|
679 | exports.decodeNegative = decodeNegative;
|
680 | exports.decodePositive = decodePositive;
|
681 | exports.deprecate = deprecate;
|
682 | exports.dict = dict;
|
683 | exports.emptyArray = emptyArray;
|
684 | exports.encodeHandle = encodeHandle;
|
685 | exports.encodeImmediate = encodeImmediate;
|
686 | exports.encodeNegative = encodeNegative;
|
687 | exports.encodePositive = encodePositive;
|
688 | exports.endTestSteps = endTestSteps;
|
689 | exports.enumerableSymbol = enumerableSymbol;
|
690 | exports.exhausted = exhausted;
|
691 | exports.expect = expect;
|
692 | exports.extractHandle = extractHandle;
|
693 | exports.fillNulls = fillNulls;
|
694 | exports.ifPresent = ifPresent;
|
695 | exports.intern = intern;
|
696 | exports.isDict = isDict;
|
697 | exports.isEmptyArray = isEmptyArray;
|
698 | exports.isErrHandle = isErrHandle;
|
699 | exports.isHandle = isHandle;
|
700 | exports.isNonPrimitiveHandle = isNonPrimitiveHandle;
|
701 | exports.isObject = isObject;
|
702 | exports.isOkHandle = isOkHandle;
|
703 | exports.isPresent = isPresent;
|
704 | exports.isSerializationFirstNode = isSerializationFirstNode;
|
705 | exports.isSmallInt = isSmallInt;
|
706 | exports.keys = keys;
|
707 | exports.logStep = logStep;
|
708 | exports.mapPresent = mapPresent;
|
709 | exports.strip = strip;
|
710 | exports.symbol = symbol;
|
711 | exports.toPresentOption = toPresentOption;
|
712 | exports.tuple = tuple;
|
713 | exports.unreachable = unreachable;
|
714 | exports.unwrap = unwrap;
|
715 | exports.unwrapHandle = unwrapHandle;
|
716 | exports.unwrapTemplate = unwrapTemplate;
|
717 | exports.values = values;
|
718 | exports.verifySteps = verifySteps;
|
719 |
|
720 | Object.defineProperty(exports, '__esModule', { value: true });
|
721 |
|
722 | });
|
723 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"glimmer-util.js","sources":["../../../../../../packages/@glimmer/util/lib/array-utils.ts","../../../../../../packages/@glimmer/util/lib/assert.ts","../../../../../../packages/@glimmer/util/lib/collections.ts","../../../../../../packages/@glimmer/util/lib/dom.ts","../../../../../../packages/@glimmer/util/lib/is-serialization-first-node.ts","../../../../../../packages/@glimmer/util/lib/object-utils.ts","../../../../../../packages/@glimmer/util/lib/intern.ts","../../../../../../packages/@glimmer/util/lib/platform-utils.ts","../../../../../../packages/@glimmer/util/lib/string.ts","../../../../../../packages/@glimmer/util/lib/immediate.ts","../../../../../../packages/@glimmer/util/lib/template.ts","../../../../../../packages/@glimmer/util/lib/weak-set.ts","../../../../../../packages/@glimmer/util/lib/simple-cast.ts","../../../../../../packages/@glimmer/util/lib/present.ts","../../../../../../packages/@glimmer/util/lib/untouchable-this.ts","../../../../../../packages/@glimmer/util/lib/debug-to-string.ts","../../../../../../packages/@glimmer/util/lib/debug-steps.ts","../../../../../../packages/@glimmer/util/index.ts"],"sourcesContent":["export const EMPTY_ARRAY: readonly unknown[] = Object.freeze([]) as readonly unknown[];\n\nexport function emptyArray<T extends unknown>(): T[] {\n  return EMPTY_ARRAY as T[];\n}\n\nexport const EMPTY_STRING_ARRAY = emptyArray<string>();\nexport const EMPTY_NUMBER_ARRAY = emptyArray<number>();\n\n/**\n * This function returns `true` if the input array is the special empty array sentinel,\n * which is sometimes used for optimizations.\n */\nexport function isEmptyArray(input: unknown[] | readonly unknown[]): boolean {\n  return input === EMPTY_ARRAY;\n}\n","// import Logger from './logger';\n\nimport { LOCAL_LOGGER } from '../index';\n\n// let alreadyWarned = false;\n\nexport function debugAssert(test: any, msg: string): asserts test {\n  // if (!alreadyWarned) {\n  //   alreadyWarned = true;\n  //   Logger.warn(\"Don't leave debug assertions on in public builds\");\n  // }\n\n  if (!test) {\n    throw new Error(msg || 'assertion failure');\n  }\n}\n\nexport function prodAssert() {}\n\nexport function deprecate(desc: string) {\n  LOCAL_LOGGER.warn(`DEPRECATION: ${desc}`);\n}\n\nexport default debugAssert;\n","import { Dict, Option, Stack } from '@glimmer/interfaces';\n\nexport function dict<T = unknown>(): Dict<T> {\n  return Object.create(null);\n}\n\nexport function isDict<T>(u: T): u is Dict & T {\n  return u !== null && u !== undefined;\n}\n\nexport function isObject<T>(u: T): u is object & T {\n  return typeof u === 'function' || (typeof u === 'object' && u !== null);\n}\n\nexport class StackImpl<T> implements Stack<T> {\n  private stack: T[];\n  public current: Option<T> = null;\n\n  constructor(values: T[] = []) {\n    this.stack = values;\n  }\n\n  public get size() {\n    return this.stack.length;\n  }\n\n  push(item: T) {\n    this.current = item;\n    this.stack.push(item);\n  }\n\n  pop(): Option<T> {\n    let item = this.stack.pop();\n    let len = this.stack.length;\n    this.current = len === 0 ? null : this.stack[len - 1];\n\n    return item === undefined ? null : item;\n  }\n\n  nth(from: number): Option<T> {\n    let len = this.stack.length;\n    return len < from ? null : this.stack[len - from];\n  }\n\n  isEmpty(): boolean {\n    return this.stack.length === 0;\n  }\n\n  toArray(): T[] {\n    return this.stack;\n  }\n}\n","import { Option } from '@glimmer/interfaces';\nimport { SimpleElement, SimpleNode } from '@simple-dom/interface';\n\nexport function clearElement(parent: SimpleElement) {\n  let current: Option<SimpleNode> = parent.firstChild;\n\n  while (current) {\n    let next = current.nextSibling;\n    parent.removeChild(current);\n    current = next;\n  }\n}\n","import { SimpleNode } from '@simple-dom/interface';\n\nexport const SERIALIZATION_FIRST_NODE_STRING = '%+b:0%';\n\nexport function isSerializationFirstNode(node: SimpleNode): boolean {\n  return node.nodeValue === SERIALIZATION_FIRST_NODE_STRING;\n}\n","const { keys: objKeys } = Object;\n\nfunction assignFn<T, U>(obj: T, assignments: U): T & U;\nfunction assignFn<T, U, V>(obj: T, a: U, b: V): T & U & V;\nfunction assignFn<T, U, V, W>(obj: T, a: U, b: V, c: W): T & U & V & W;\nfunction assignFn<T, U, V, W, X>(obj: T, a: U, b: V, c: W, d: X): T & U & V & W & X;\nfunction assignFn<T, U, V, W, X, Y>(obj: T, a: U, b: V, c: W, d: X, e: Y): T & U & V & W & X & Y;\nfunction assignFn<T, U, V, W, X, Y, Z>(\n  obj: T,\n  a: U,\n  b: V,\n  c: W,\n  d: X,\n  e: Y,\n  f: Z\n): T & U & V & W & X & Y & Z;\nfunction assignFn(target: any, ...args: any[]): any;\nfunction assignFn(obj: any) {\n  for (let i = 1; i < arguments.length; i++) {\n    let assignment = arguments[i];\n    if (assignment === null || typeof assignment !== 'object') continue;\n    let keys = objKeys(assignment);\n    for (let j = 0; j < keys.length; j++) {\n      let key = keys[j];\n      obj[key] = assignment[key];\n    }\n  }\n  return obj;\n}\n\nexport let assign = Object.assign ?? assignFn;\n\nexport function fillNulls<T>(count: number): T[] {\n  let arr = new Array(count);\n\n  for (let i = 0; i < count; i++) {\n    arr[i] = null;\n  }\n\n  return arr;\n}\n\nexport function values<T>(obj: { [s: string]: T }): T[] {\n  const vals = [];\n  for (const key in obj) {\n    vals.push(obj[key]);\n  }\n  return vals;\n}\n","/**\n  Strongly hint runtimes to intern the provided string.\n\n  When do I need to use this function?\n\n  For the most part, never. Pre-mature optimization is bad, and often the\n  runtime does exactly what you need it to, and more often the trade-off isn't\n  worth it.\n\n  Why?\n\n  Runtimes store strings in at least 2 different representations:\n  Ropes and Symbols (interned strings). The Rope provides a memory efficient\n  data-structure for strings created from concatenation or some other string\n  manipulation like splitting.\n\n  Unfortunately checking equality of different ropes can be quite costly as\n  runtimes must resort to clever string comparison algorithms. These\n  algorithms typically cost in proportion to the length of the string.\n  Luckily, this is where the Symbols (interned strings) shine. As Symbols are\n  unique by their string content, equality checks can be done by pointer\n  comparison.\n\n  How do I know if my string is a rope or symbol?\n\n  Typically (warning general sweeping statement, but truthy in runtimes at\n  present) static strings created as part of the JS source are interned.\n  Strings often used for comparisons can be interned at runtime if some\n  criteria are met.  One of these criteria can be the size of the entire rope.\n  For example, in chrome 38 a rope longer then 12 characters will not\n  intern, nor will segments of that rope.\n\n  Some numbers: http://jsperf.com/eval-vs-keys/8\n\n  Known Trick™\n\n  @private\n  @return {String} interned version of the provided string\n*/\nexport default function intern(str: string): string {\n  let obj: Record<string, number> = {};\n  obj[str] = 1;\n  for (let key in obj) {\n    if (key === str) {\n      return key;\n    }\n  }\n  return str;\n}\n","import { Maybe } from '@glimmer/interfaces';\nimport intern from './intern';\n\nexport type Factory<T> = new (...args: unknown[]) => T;\n\nexport const HAS_NATIVE_PROXY = typeof Proxy === 'function';\n\nexport const HAS_NATIVE_SYMBOL = (function () {\n  if (typeof Symbol !== 'function') {\n    return false;\n  }\n\n  // eslint-disable-next-line symbol-description\n  return typeof Symbol() === 'symbol';\n})();\n\nexport function keys<T>(obj: T): Array<keyof T> {\n  return Object.keys(obj) as Array<keyof T>;\n}\n\nexport function unwrap<T>(val: Maybe<T>): T {\n  if (val === null || val === undefined) throw new Error(`Expected value to be present`);\n  return val as T;\n}\n\nexport function expect<T>(val: Maybe<T>, message: string): T {\n  if (val === null || val === undefined) throw new Error(message);\n  return val as T;\n}\n\nexport function unreachable(message = 'unreachable'): Error {\n  return new Error(message);\n}\n\nexport function exhausted(value: never): never {\n  throw new Error(`Exhausted ${value}`);\n}\n\nexport type Lit = string | number | boolean | undefined | null | void | {};\n\nexport const tuple = <T extends Lit[]>(...args: T) => args;\n\nexport function enumerableSymbol(key: string): any {\n  return intern(`__${key}${Math.floor(Math.random() * Date.now())}__`);\n}\n\nexport const symbol = HAS_NATIVE_SYMBOL ? Symbol : enumerableSymbol;\n","export function strip(strings: TemplateStringsArray, ...args: unknown[]) {\n  let out = '';\n  for (let i = 0; i < strings.length; i++) {\n    let string = strings[i];\n    let dynamic = args[i] !== undefined ? String(args[i]) : '';\n\n    out += `${string}${dynamic}`;\n  }\n\n  let lines = out.split('\\n');\n\n  while (lines.length && lines[0].match(/^\\s*$/)) {\n    lines.shift();\n  }\n\n  while (lines.length && lines[lines.length - 1].match(/^\\s*$/)) {\n    lines.pop();\n  }\n\n  let min = Infinity;\n\n  for (let line of lines) {\n    let leading = line.match(/^\\s*/)![0].length;\n\n    min = Math.min(min, leading);\n  }\n\n  let stripped = [];\n\n  for (let line of lines) {\n    stripped.push(line.slice(min));\n  }\n\n  return stripped.join('\\n');\n}\n","import { LOCAL_DEBUG } from '@glimmer/local-debug-flags';\nimport { debugAssert as assert } from './assert';\n\n/*\n  Encoding notes\n\n  We use 30 bit integers for encoding, so that we don't ever encode a non-SMI\n  integer to push on the stack.\n\n  Handles are >= 0\n  Immediates are < 0\n\n  True, False, Undefined and Null are pushed as handles into the symbol table,\n  with well known handles (0, 1, 2, 3)\n\n  The negative space is divided into positives and negatives. Positives are\n  higher numbers (-1, -2, -3, etc), negatives are lower.\n\n  We only encode immediates for two reasons:\n\n  1. To transfer over the wire, so they're smaller in general\n  2. When pushing values onto the stack from the low level/inner VM, which may\n     be converted into WASM one day.\n\n  This allows the low-level VM to always use SMIs, and to minimize using JS\n  values via handles for things like the stack pointer and frame pointer.\n  Externally, most code pushes values as JS values, except when being pulled\n  from the append byte code where it was already encoded.\n\n  Logically, this is because the low level VM doesn't really care about these\n  higher level values. For instance, the result of a userland helper may be a\n  number, or a boolean, or undefined/null, but it's extra work to figure that\n  out and push it correctly, vs. just pushing the value as a JS value with a\n  handle.\n\n  Note: The details could change here in the future, this is just the current\n  strategy.\n*/\n\nexport const enum ImmediateConstants {\n  MAX_SMI = 2 ** 30 - 1,\n  MIN_SMI = ~MAX_SMI,\n  SIGN_BIT = ~(2 ** 29),\n  MAX_INT = ~SIGN_BIT - 1,\n  MIN_INT = ~MAX_INT,\n\n  FALSE_HANDLE = 0,\n  TRUE_HANDLE = 1,\n  NULL_HANDLE = 2,\n  UNDEFINED_HANDLE = 3,\n\n  ENCODED_FALSE_HANDLE = FALSE_HANDLE,\n  ENCODED_TRUE_HANDLE = TRUE_HANDLE,\n  ENCODED_NULL_HANDLE = NULL_HANDLE,\n  ENCODED_UNDEFINED_HANDLE = UNDEFINED_HANDLE,\n}\n\nexport function isHandle(value: number) {\n  return value >= 0;\n}\n\nexport function isNonPrimitiveHandle(value: number) {\n  return value > ImmediateConstants.ENCODED_UNDEFINED_HANDLE;\n}\n\nexport function constants(...values: unknown[]): unknown[] {\n  return [false, true, null, undefined, ...values];\n}\n\nexport function isSmallInt(value: number) {\n  return (\n    value % 1 === 0 && value <= ImmediateConstants.MAX_INT && value >= ImmediateConstants.MIN_INT\n  );\n}\n\nexport function encodeNegative(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num >= ImmediateConstants.MIN_INT && num < 0,\n      `Could not encode negative: ${num}`\n    );\n  }\n\n  return num & ImmediateConstants.SIGN_BIT;\n}\n\nexport function decodeNegative(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num < ~ImmediateConstants.MAX_INT && num >= ImmediateConstants.MIN_SMI,\n      `Could not decode negative: ${num}`\n    );\n  }\n\n  return num | ~ImmediateConstants.SIGN_BIT;\n}\n\nexport function encodePositive(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num >= 0 && num <= ImmediateConstants.MAX_INT,\n      `Could not encode positive: ${num}`\n    );\n  }\n\n  return ~num;\n}\n\nexport function decodePositive(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num <= 0 && num >= ~ImmediateConstants.MAX_INT,\n      `Could not decode positive: ${num}`\n    );\n  }\n\n  return ~num;\n}\n\nexport function encodeHandle(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num >= 0 && num <= ImmediateConstants.MAX_SMI,\n      `Could not encode handle: ${num}`\n    );\n  }\n\n  return num;\n}\n\nexport function decodeHandle(num: number) {\n  if (LOCAL_DEBUG) {\n    assert(\n      num % 1 === 0 && num <= ImmediateConstants.MAX_SMI && num >= 0,\n      `Could not decode handle: ${num}`\n    );\n  }\n\n  return num;\n}\n\nexport function encodeImmediate(num: number) {\n  num |= 0;\n  return num < 0 ? encodeNegative(num) : encodePositive(num);\n}\n\nexport function decodeImmediate(num: number) {\n  num |= 0;\n  return num > ImmediateConstants.SIGN_BIT ? decodePositive(num) : decodeNegative(num);\n}\n\n// Warm\n[1, 2, 3].forEach((x) => decodeHandle(encodeHandle(x)));\n[1, -1].forEach((x) => decodeImmediate(encodeImmediate(x)));\n","import { HandleResult, Template, TemplateOk, OkHandle, ErrHandle } from '@glimmer/interfaces';\n\nexport function unwrapHandle(handle: HandleResult): number {\n  if (typeof handle === 'number') {\n    return handle;\n  } else {\n    let error = handle.errors[0];\n    throw new Error(`Compile Error: ${error.problem} @ ${error.span.start}..${error.span.end}`);\n  }\n}\n\nexport function unwrapTemplate(template: Template): TemplateOk {\n  if (template.result === 'error') {\n    throw new Error(\n      `Compile Error: ${template.problem} @ ${template.span.start}..${template.span.end}`\n    );\n  }\n\n  return template;\n}\n\nexport function extractHandle(handle: HandleResult): number {\n  if (typeof handle === 'number') {\n    return handle;\n  } else {\n    return handle.handle;\n  }\n}\n\nexport function isOkHandle(handle: HandleResult): handle is OkHandle {\n  return typeof handle === 'number';\n}\n\nexport function isErrHandle(handle: HandleResult): handle is ErrHandle {\n  return typeof handle === 'number';\n}\n","export default (typeof WeakSet === 'function'\n  ? WeakSet\n  : class WeakSetPolyFill<T extends object> {\n      private _map = new WeakMap();\n\n      add(val: T): this {\n        this._map.set(val, true);\n        return this;\n      }\n\n      delete(val: T) {\n        return this._map.delete(val);\n      }\n\n      has(val: T) {\n        return this._map.has(val);\n      }\n    }) as WeakSetConstructor;\n","import { unreachable } from './platform-utils';\nimport { NodeType, SimpleDocument, SimpleElement, SimpleNode } from '@simple-dom/interface';\n\ninterface GenericElementTags {\n  HTML: HTMLElement;\n  SVG: SVGElement;\n  ELEMENT: HTMLElement | SVGElement;\n}\n\ninterface GenericNodeTags {\n  NODE: Node;\n}\n\ntype GenericNodeTag = keyof GenericNodeTags;\n\ninterface BrowserElementTags extends HTMLElementTagNameMap, GenericElementTags {}\ntype BrowserElementTag = keyof BrowserElementTags;\n\ninterface BrowserTags extends BrowserElementTags, GenericNodeTags {}\ntype BrowserTag = keyof BrowserTags;\n\ntype NodeCheck<N extends Node> = (node: Node) => node is N;\ntype SugaryNodeCheck<K extends BrowserTag = BrowserTag> = NodeCheck<BrowserTags[K]> | K | K[];\ntype NodeForSugaryCheck<S extends SugaryNodeCheck<BrowserTag>> = S extends NodeCheck<infer N>\n  ? N\n  : S extends keyof BrowserTags\n  ? BrowserTags[S]\n  : S extends (keyof BrowserTags)[]\n  ? BrowserTags[S[number]]\n  : never;\n\ntype BrowserNode = Element | Document | DocumentFragment | Text | Comment | Node;\n\nexport function castToSimple(doc: Document | SimpleDocument): SimpleDocument;\nexport function castToSimple(elem: Element | SimpleElement): SimpleElement;\nexport function castToSimple(node: Node | SimpleNode): SimpleNode;\nexport function castToSimple(\n  node: Document | Element | Node | SimpleDocument | SimpleElement | SimpleNode\n) {\n  if (isDocument(node)) {\n    return node as SimpleDocument;\n  } else if (isElement(node)) {\n    return node as SimpleElement;\n  } else {\n    return node as SimpleNode;\n  }\n}\n\n// If passed a document, verify we're in the browser and return it as a Document\nexport function castToBrowser(doc: Document | SimpleDocument): Document;\n// If we don't know what this is, but the check requires it to be an element,\n// the cast will mandate that it's a browser element\nexport function castToBrowser<S extends SugaryNodeCheck<BrowserElementTag>>(\n  node: BrowserNode | SimpleNode,\n  check: S\n): NodeForSugaryCheck<S>;\n// Finally, if it's a more generic check, the cast will mandate that it's a\n// browser node and return a BrowserNodeUtils corresponding to the check\nexport function castToBrowser<S extends SugaryNodeCheck<GenericNodeTag>>(\n  element: BrowserNode | SimpleNode,\n  check: S\n): NodeForSugaryCheck<S>;\nexport function castToBrowser<K extends keyof HTMLElementTagNameMap>(\n  element: SimpleElement | Element,\n  check: K\n): HTMLElementTagNameMap[K];\nexport function castToBrowser<S extends SugaryNodeCheck>(\n  node: SimpleNode | BrowserNode | null | undefined,\n  sugaryCheck?: S\n): Document | NodeForSugaryCheck<S> | null {\n  if (node === null || node === undefined) {\n    return null;\n  }\n\n  if (typeof document === undefined) {\n    throw new Error('Attempted to cast to a browser node in a non-browser context');\n  }\n\n  if (isDocument(node)) {\n    return node as Document;\n  }\n\n  if (node.ownerDocument !== document) {\n    throw new Error(\n      'Attempted to cast to a browser node with a node that was not created from this document'\n    );\n  }\n\n  return checkNode<S>(node, sugaryCheck!);\n}\n\nfunction checkError(from: string, check: SugaryNodeCheck): Error {\n  return new Error(`cannot cast a ${from} into ${check}`);\n}\n\nfunction isDocument(node: Node | SimpleNode | SimpleDocument): node is Document | SimpleDocument {\n  return node.nodeType === NodeType.DOCUMENT_NODE;\n}\n\nfunction isElement(node: Node | SimpleNode | SimpleElement): node is Element | SimpleElement {\n  return node.nodeType === NodeType.ELEMENT_NODE;\n}\n\nexport function checkNode<S extends SugaryNodeCheck>(\n  node: Node | null,\n  check: S\n): NodeForSugaryCheck<S> {\n  let isMatch = false;\n\n  if (node !== null) {\n    if (typeof check === 'string') {\n      isMatch = stringCheckNode(node, check as BrowserTag);\n    } else if (Array.isArray(check)) {\n      isMatch = check.some((c) => stringCheckNode(node, c as BrowserTag));\n    } else {\n      throw unreachable();\n    }\n  }\n\n  if (isMatch) {\n    return node as NodeForSugaryCheck<S>;\n  } else {\n    throw checkError(`SimpleElement(${node})`, check);\n  }\n}\n\nfunction stringCheckNode<S extends BrowserTag>(node: Node, check: S): node is BrowserTags[S] {\n  switch (check) {\n    case 'NODE':\n      return true;\n    case 'HTML':\n      return node instanceof HTMLElement;\n    case 'SVG':\n      return node instanceof SVGElement;\n    case 'ELEMENT':\n      return node instanceof Element;\n    default:\n      if (check.toUpperCase() === check) {\n        throw new Error(`BUG: this code is missing handling for a generic node type`);\n      }\n      return node instanceof Element && node.tagName.toLowerCase() === check;\n  }\n}\n","import { Option, PresentArray } from '@glimmer/interfaces';\n\nexport function isPresent<T>(list: readonly T[]): list is PresentArray<T> {\n  return list.length > 0;\n}\n\nexport function ifPresent<T, U, V>(\n  list: T[],\n  ifPresent: (input: PresentArray<T>) => U,\n  otherwise: () => V\n): U | V {\n  if (isPresent(list)) {\n    return ifPresent(list);\n  } else {\n    return otherwise();\n  }\n}\n\nexport function toPresentOption<T>(list: T[]): Option<PresentArray<T>> {\n  if (isPresent(list)) {\n    return list;\n  } else {\n    return null;\n  }\n}\n\nexport function assertPresent<T>(\n  list: T[],\n  message = `unexpected empty list`\n): asserts list is PresentArray<T> {\n  if (!isPresent(list)) {\n    throw new Error(message);\n  }\n}\n\nexport function mapPresent<T, U>(list: PresentArray<T>, callback: (input: T) => U): PresentArray<U>;\nexport function mapPresent<T, U>(\n  list: PresentArray<T> | null,\n  callback: (input: T) => U\n): PresentArray<U> | null;\nexport function mapPresent<T, U>(\n  list: PresentArray<T> | null,\n  callback: (input: T) => U\n): PresentArray<U> | null {\n  if (list === null) {\n    return null;\n  }\n  let out: U[] = [];\n\n  for (let item of list) {\n    out.push(callback(item));\n  }\n\n  return out as PresentArray<U>;\n}\n","import { DEBUG } from '@glimmer/env';\nimport { HAS_NATIVE_PROXY } from './platform-utils';\n\nexport default function buildUntouchableThis(source: string): null | object {\n  let context: null | object = null;\n  if (DEBUG && HAS_NATIVE_PROXY) {\n    let assertOnProperty = (property: string | number | symbol) => {\n      throw new Error(\n        `You accessed \\`this.${String(\n          property\n        )}\\` from a function passed to the ${source}, but the function itself was not bound to a valid \\`this\\` context. Consider updating to use a bound function (for instance, use an arrow function, \\`() => {}\\`).`\n      );\n    };\n\n    context = new Proxy(\n      {},\n      {\n        get(_target: {}, property: string | symbol) {\n          assertOnProperty(property);\n        },\n\n        set(_target: {}, property: string | symbol) {\n          assertOnProperty(property);\n\n          return false;\n        },\n\n        has(_target: {}, property: string | symbol) {\n          assertOnProperty(property);\n\n          return false;\n        },\n      }\n    );\n  }\n\n  return context;\n}\n","import { DEBUG } from '@glimmer/env';\n\nlet debugToString: undefined | ((value: unknown) => string);\n\nif (DEBUG) {\n  let getFunctionName = (fn: Function) => {\n    let functionName = fn.name;\n\n    if (functionName === undefined) {\n      let match = Function.prototype.toString.call(fn).match(/function (\\w+)\\s*\\(/);\n\n      functionName = (match && match[1]) || '';\n    }\n\n    return functionName.replace(/^bound /, '');\n  };\n\n  let getObjectName = (obj: object) => {\n    let name;\n    let className;\n\n    if (obj.constructor && typeof obj.constructor === 'function') {\n      className = getFunctionName(obj.constructor);\n    }\n\n    if (\n      'toString' in obj &&\n      obj.toString !== Object.prototype.toString &&\n      obj.toString !== Function.prototype.toString\n    ) {\n      name = obj.toString();\n    }\n\n    // If the class has a decent looking name, and the `toString` is one of the\n    // default Ember toStrings, replace the constructor portion of the toString\n    // with the class name. We check the length of the class name to prevent doing\n    // this when the value is minified.\n    if (\n      name &&\n      name.match(/<.*:ember\\d+>/) &&\n      className &&\n      className[0] !== '_' &&\n      className.length > 2 &&\n      className !== 'Class'\n    ) {\n      return name.replace(/<.*:/, `<${className}:`);\n    }\n\n    return name || className;\n  };\n\n  let getPrimitiveName = (value: any) => {\n    return String(value);\n  };\n\n  debugToString = (value: unknown) => {\n    if (typeof value === 'function') {\n      return getFunctionName(value) || `(unknown function)`;\n    } else if (typeof value === 'object' && value !== null) {\n      return getObjectName(value) || `(unknown object)`;\n    } else {\n      return getPrimitiveName(value);\n    }\n  };\n}\n\nexport default debugToString;\n","import { LOCAL_DEBUG } from '@glimmer/local-debug-flags';\nimport assert from './assert';\nimport { expect } from './platform-utils';\n\nexport let beginTestSteps: (() => void) | undefined;\nexport let endTestSteps: (() => void) | undefined;\n\nexport let verifySteps:\n  | ((type: string, steps: unknown[] | ((steps: unknown[]) => void), message?: string) => void)\n  | undefined;\nexport let logStep: ((type: string, steps: unknown) => void) | undefined;\n\nif (LOCAL_DEBUG) {\n  let LOGGED_STEPS: Record<string, unknown[]> | null = null;\n\n  beginTestSteps = () => {\n    assert(LOGGED_STEPS === null, 'attempted to start steps, but it already began');\n\n    LOGGED_STEPS = {};\n  };\n\n  endTestSteps = () => {\n    assert(LOGGED_STEPS, 'attempted to end steps, but they were not started');\n\n    LOGGED_STEPS = null;\n  };\n\n  logStep = (type: string, step: unknown) => {\n    if (LOGGED_STEPS === null) return;\n\n    LOGGED_STEPS[type] = LOGGED_STEPS[type] || [];\n    LOGGED_STEPS[type].push(step);\n  };\n\n  verifySteps = (\n    type: string,\n    expectedSteps: unknown[] | ((steps: unknown[]) => void),\n    message?: string\n  ) => {\n    let loggedSteps = expect(LOGGED_STEPS, 'attempetd to verify steps, but steps were not started');\n\n    let steps = loggedSteps[type] || [];\n\n    loggedSteps[type] = [];\n\n    if (Array.isArray(expectedSteps)) {\n      QUnit.config.current.assert.deepEqual(steps, expectedSteps, message);\n    } else {\n      expectedSteps(steps);\n    }\n  };\n}\n","export * from './lib/array-utils';\nexport { default as assert, deprecate } from './lib/assert';\nexport { dict, isDict, isObject, StackImpl as Stack } from './lib/collections';\nexport * from './lib/dom';\nexport {\n  isSerializationFirstNode,\n  SERIALIZATION_FIRST_NODE_STRING,\n} from './lib/is-serialization-first-node';\nexport { assign, fillNulls, values } from './lib/object-utils';\nexport * from './lib/platform-utils';\nexport * from './lib/string';\nexport * from './lib/immediate';\nexport * from './lib/template';\nexport { default as _WeakSet } from './lib/weak-set';\nexport { castToSimple, castToBrowser, checkNode } from './lib/simple-cast';\nexport * from './lib/present';\nexport { default as intern } from './lib/intern';\n\nexport { default as buildUntouchableThis } from './lib/untouchable-this';\nexport { default as debugToString } from './lib/debug-to-string';\nexport { beginTestSteps, endTestSteps, logStep, verifySteps } from './lib/debug-steps';\n\nexport type FIXME<T, S extends string> = (T & S) | T;\n\n/**\n * This constant exists to make it easier to differentiate normal logs from\n * errant console.logs. LOCAL_LOGGER should only be used inside a\n * LOCAL_SHOULD_LOG check.\n *\n * It does not alleviate the need to check LOCAL_SHOULD_LOG, which is used\n * for stripping.\n */\nexport const LOCAL_LOGGER = console;\n\n/**\n * This constant exists to make it easier to differentiate normal logs from\n * errant console.logs. LOGGER can be used outside of LOCAL_SHOULD_LOG checks,\n * and is meant to be used in the rare situation where a console.* call is\n * actually appropriate.\n */\nexport const LOGGER = console;\n\nexport function assertNever(value: never, desc = 'unexpected unreachable branch'): never {\n  LOGGER.log('unreachable', value);\n  LOGGER.log(`${desc} :: ${JSON.stringify(value)} (${value})`);\n\n  throw new Error(`code reached unreachable`);\n}\n"],"names":["DEBUG"],"mappings":";;MAAa,WAAW,GAAuB,MAAM,CAAN,MAAA,CAAxC,EAAwC;EAEzC,SAAA,UAAA,GAAoB;EACxB,SAAA,WAAA;EACD;MAEY,kBAAkB,GAAG,UAA3B;MACM,kBAAkB,GAAG,UAA3B;EAEP;;;;;EAIM,SAAA,YAAA,CAAA,KAAA,EAA4D;EAChE,SAAO,KAAK,KAAZ,WAAA;EACD;;ECfD;AAEA;AAIA,EAAM,SAAA,WAAA,CAAA,IAAA,EAAA,GAAA,EAA4C;EAChD;EACA;EACA;EACA;EAEA,MAAI,CAAJ,IAAA,EAAW;EACT,UAAM,IAAA,KAAA,CAAU,GAAG,IAAnB,mBAAM,CAAN;EACD;EACF;AAED,EAEM,SAAA,SAAA,CAAA,IAAA,EAAgC;EACpC,EAAA,YAAY,CAAZ,IAAA,mBAAA,IAAA;EACD;;;;;;ACnBD,EAAM,SAAA,IAAA,GAAc;EAClB,SAAO,MAAM,CAAN,MAAA,CAAP,IAAO,CAAP;EACD;AAED,EAAM,SAAA,MAAA,CAAA,CAAA,EAAwB;EAC5B,SAAO,CAAC,KAAD,IAAA,IAAc,CAAC,KAAtB,SAAA;EACD;AAED,EAAM,SAAA,QAAA,CAAA,CAAA,EAA0B;EAC9B,SAAO,OAAA,CAAA,KAAA,UAAA,IAA4B,OAAA,CAAA,KAAA,QAAA,IAAyB,CAAC,KAA7D,IAAA;EACD;AAED,MAAM,SAAN;EAIE,qBAAY,MAAZ,EAA4B;EAAA,QAAhB,MAAgB;EAAhB,MAAA,MAAgB,GAA5B,EAA4B;EAAA;;EAFrB,SAAA,OAAA,GAAA,IAAA;EAGL,SAAA,KAAA,GAAA,MAAA;EACD;;EANH;;EAAA,SAYE,IAZF,GAYE,cAAI,IAAJ,EAAY;EACV,SAAA,OAAA,GAAA,IAAA;EACA,SAAA,KAAA,CAAA,IAAA,CAAA,IAAA;EACD,GAfH;;EAAA,SAiBE,GAjBF,GAiBE,eAAG;EACD,QAAI,IAAI,GAAG,KAAA,KAAA,CAAX,GAAW,EAAX;EACA,QAAI,GAAG,GAAG,KAAA,KAAA,CAAV,MAAA;EACA,SAAA,OAAA,GAAe,GAAG,KAAH,CAAA,GAAA,IAAA,GAAmB,KAAA,KAAA,CAAW,GAAG,GAAhD,CAAkC,CAAlC;EAEA,WAAO,IAAI,KAAJ,SAAA,GAAA,IAAA,GAAP,IAAA;EACD,GAvBH;;EAAA,SAyBE,GAzBF,GAyBE,aAAG,IAAH,EAAgB;EACd,QAAI,GAAG,GAAG,KAAA,KAAA,CAAV,MAAA;EACA,WAAO,GAAG,GAAH,IAAA,GAAA,IAAA,GAAoB,KAAA,KAAA,CAAW,GAAG,GAAzC,IAA2B,CAA3B;EACD,GA5BH;;EAAA,SA8BE,OA9BF,GA8BE,mBAAO;EACL,WAAO,KAAA,KAAA,CAAA,MAAA,KAAP,CAAA;EACD,GAhCH;;EAAA,SAkCE,OAlCF,GAkCE,mBAAO;EACL,WAAO,KAAP,KAAA;EACD,GApCH;;EAAA;EAAA;EAAA,wBAQiB;EACb,aAAO,KAAA,KAAA,CAAP,MAAA;EACD;EAVH;;EAAA;EAAA;;ECXM,SAAA,YAAA,CAAA,MAAA,EAA4C;EAChD,MAAI,OAAO,GAAuB,MAAM,CAAxC,UAAA;;EAEA,SAAA,OAAA,EAAgB;EACd,QAAI,IAAI,GAAG,OAAO,CAAlB,WAAA;EACA,IAAA,MAAM,CAAN,WAAA,CAAA,OAAA;EACA,IAAA,OAAO,GAAP,IAAA;EACD;EACF;;MCTY,+BAA+B,GAArC,QAAA;AAEP,EAAM,SAAA,wBAAA,CAAA,IAAA,EAAmD;EACvD,SAAO,IAAI,CAAJ,SAAA,KAAP,+BAAA;EACD;;;;MCNa,UAAd,OAAQ;;EAiBR,SAAA,QAAA,CAAA,GAAA,EAA0B;EACxB,OAAK,IAAI,CAAC,GAAV,CAAA,EAAgB,CAAC,GAAG,SAAS,CAA7B,MAAA,EAAsC,CAAtC,EAAA,EAA2C;EACzC,QAAI,UAAU,GAAG,SAAS,CAA1B,CAA0B,CAA1B;EACA,QAAI,UAAU,KAAV,IAAA,IAAuB,OAAA,UAAA,KAA3B,QAAA,EAA2D;EAC3D,QAAI,IAAI,GAAG,OAAO,CAAlB,UAAkB,CAAlB;;EACA,SAAK,IAAI,CAAC,GAAV,CAAA,EAAgB,CAAC,GAAG,IAAI,CAAxB,MAAA,EAAiC,CAAjC,EAAA,EAAsC;EACpC,UAAI,GAAG,GAAG,IAAI,CAAd,CAAc,CAAd;EACA,MAAA,GAAG,CAAH,GAAG,CAAH,GAAW,UAAU,CAArB,GAAqB,CAArB;EACD;EACF;;EACD,SAAA,GAAA;EACD;;AAED,MAAW,MAAM,GAAA,CAAA,EAAA,GAAG,MAAM,CAAT,MAAA,MAAA,IAAA,IAAgB,EAAA,KAAA,KAAhB,CAAA,GAAA,EAAA,GAAV,QAAA;AAEP,EAAM,SAAA,SAAA,CAAA,KAAA,EAAoC;EACxC,MAAI,GAAG,GAAG,IAAA,KAAA,CAAV,KAAU,CAAV;;EAEA,OAAK,IAAI,CAAC,GAAV,CAAA,EAAgB,CAAC,GAAjB,KAAA,EAA2B,CAA3B,EAAA,EAAgC;EAC9B,IAAA,GAAG,CAAH,CAAG,CAAH,GAAA,IAAA;EACD;;EAED,SAAA,GAAA;EACD;AAED,EAAM,SAAA,MAAA,CAAA,GAAA,EAA2C;EAC/C,MAAM,IAAI,GAAV,EAAA;;EACA,OAAK,IAAL,GAAA,IAAA,GAAA,EAAuB;EACrB,IAAA,IAAI,CAAJ,IAAA,CAAU,GAAG,CAAb,GAAa,CAAb;EACD;;EACD,SAAA,IAAA;EACD;;EChDD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuCA,EAAc,SAAA,MAAA,CAAA,GAAA,EAA4B;EACxC,MAAI,GAAG,GAAP,EAAA;EACA,EAAA,GAAG,CAAH,GAAG,CAAH,GAAA,CAAA;;EACA,OAAK,IAAL,GAAA,IAAA,GAAA,EAAqB;EACnB,QAAI,GAAG,KAAP,GAAA,EAAiB;EACf,aAAA,GAAA;EACD;EACF;;EACD,SAAA,GAAA;EACD;;MC3CY,gBAAgB,GAAG,OAAA,KAAA,KAAzB,UAAA;AAEP,MAAa,iBAAiB,GAAI,YAAA;EAChC,MAAI,OAAA,MAAA,KAAJ,UAAA,EAAkC;EAChC,WAAA,KAAA;EAF8B,GAAA;;;EAMhC,SAAO,OAAO,MAAP,EAAA,KAAP,QAAA;EANK,CAA2B,EAA3B;AASP,EAAM,SAAA,IAAA,CAAA,GAAA,EAAwB;EAC5B,SAAO,MAAM,CAAN,IAAA,CAAP,GAAO,CAAP;EACD;AAED,EAAM,SAAA,MAAA,CAAA,GAAA,EAAiC;EACrC,MAAI,GAAG,KAAH,IAAA,IAAgB,GAAG,KAAvB,SAAA,EAAuC,MAAM,IAAN,KAAM,gCAAN;EACvC,SAAA,GAAA;EACD;AAED,EAAM,SAAA,MAAA,CAAA,GAAA,EAAA,OAAA,EAAkD;EACtD,MAAI,GAAG,KAAH,IAAA,IAAgB,GAAG,KAAvB,SAAA,EAAuC,MAAM,IAAA,KAAA,CAAN,OAAM,CAAN;EACvC,SAAA,GAAA;EACD;AAED,EAAM,SAAA,WAAA,CAAsB,OAAtB,EAA6C;EAAA,MAAvB,OAAuB;EAAvB,IAAA,OAAuB,GAA7C,aAA6C;EAAA;;EACjD,SAAO,IAAA,KAAA,CAAP,OAAO,CAAP;EACD;AAED,EAAM,SAAA,SAAA,CAAA,KAAA,EAAgC;EACpC,QAAM,IAAA,KAAA,gBAAN,KAAM,CAAN;EACD;AAID,MAAa,KAAK,GAAG,SAAR,KAAQ;EAAA,oCAAA,IAAA;EAAA,IAAA,IAAA;EAAA;;EAAA,SAAd,IAAc;EAAA,CAAd;AAEP,EAAM,SAAA,gBAAA,CAAA,GAAA,EAAsC;EAC1C,SAAO,MAAM,QAAM,GAAN,GAAY,IAAI,CAAJ,KAAA,CAAW,IAAI,CAAJ,MAAA,KAAgB,IAAI,CAAxD,GAAoD,EAA3B,CAAZ,QAAb;EACD;AAED,MAAa,MAAM,GAAG,iBAAiB,GAAA,MAAA,GAAhC,gBAAA;;;;;;;;AC9CP,EAAM,SAAA,KAAA,CAAA,OAAA,EAAiE;EACrE,MAAI,GAAG,GAAP,EAAA;;EADqE,oCAAjE,IAAiE;EAAjE,IAAA,IAAiE;EAAA;;EAErE,OAAK,IAAI,CAAC,GAAV,CAAA,EAAgB,CAAC,GAAG,OAAO,CAA3B,MAAA,EAAoC,CAApC,EAAA,EAAyC;EACvC,QAAI,MAAM,GAAG,OAAO,CAApB,CAAoB,CAApB;EACA,QAAI,OAAO,GAAG,IAAI,CAAJ,CAAI,CAAJ,KAAA,SAAA,GAAwB,MAAM,CAAC,IAAI,CAAnC,CAAmC,CAAL,CAA9B,GAAd,EAAA;EAEA,IAAA,GAAG,SAAO,MAAP,GAAH,OAAA;EACD;;EAED,MAAI,KAAK,GAAG,GAAG,CAAH,KAAA,CAAZ,IAAY,CAAZ;;EAEA,SAAO,KAAK,CAAL,MAAA,IAAgB,KAAK,CAAL,CAAK,CAAL,CAAA,KAAA,CAAvB,OAAuB,CAAvB,EAAgD;EAC9C,IAAA,KAAK,CAAL,KAAA;EACD;;EAED,SAAO,KAAK,CAAL,MAAA,IAAgB,KAAK,CAAC,KAAK,CAAL,MAAA,GAAN,CAAK,CAAL,CAAA,KAAA,CAAvB,OAAuB,CAAvB,EAA+D;EAC7D,IAAA,KAAK,CAAL,GAAA;EACD;;EAED,MAAI,GAAG,GAAP,QAAA;;EAEA,uDAAA,KAAA,wCAAwB;EAAA,QAAxB,IAAwB;EACtB,QAAI,OAAO,GAAG,IAAI,CAAJ,KAAA,CAAA,MAAA,EAAA,CAAA,EAAd,MAAA;EAEA,IAAA,GAAG,GAAG,IAAI,CAAJ,GAAA,CAAA,GAAA,EAAN,OAAM,CAAN;EACD;;EAED,MAAI,QAAQ,GAAZ,EAAA;;EAEA,wDAAA,KAAA,2CAAwB;EAAA,QAAxB,KAAwB;EACtB,IAAA,QAAQ,CAAR,IAAA,CAAc,KAAI,CAAJ,KAAA,CAAd,GAAc,CAAd;EACD;;EAED,SAAO,QAAQ,CAAR,IAAA,CAAP,IAAO,CAAP;EACD;;ECuBK,SAAA,QAAA,CAAA,KAAA,EAAgC;EACpC,SAAO,KAAK,IAAZ,CAAA;EACD;AAED,EAAM,SAAA,oBAAA,CAAA,KAAA,EAA4C;EAChD,SAAO,KAAK,GAAA;EAAA;EAAZ;EACD;AAED,EAAM,SAAA,SAAA,GAAwC;EAAA,oCAAxC,MAAwC;EAAxC,IAAA,MAAwC;EAAA;;EAC5C,UAAO,KAAP,EAAO,IAAP,EAAO,IAAP,EAAO,SAAP,SAAA,MAAA;EACD;AAED,EAAM,SAAA,UAAA,CAAA,KAAA,EAAkC;EACtC,SACE,KAAK,GAAL,CAAA,KAAA,CAAA,IAAmB,KAAK,IAAA;EAAA;EAAxB,KAA0D,KAAK,IAAA,CAAA;EAAA;EADjE;EAGD;AAED,EAAM,SAAA,cAAA,CAAA,GAAA,EAAoC;AACxC;EAOA,SAAO,GAAG,GAAA,CAAA;EAAA;EAAV;EACD;AAED,EAAM,SAAA,cAAA,CAAA,GAAA,EAAoC;AACxC;EAOA,SAAO,GAAG,GAAG,CAAA,CAAA;EAAA;EAAb;EACD;AAED,EAAM,SAAA,cAAA,CAAA,GAAA,EAAoC;AACxC;EAOA,SAAO,CAAP,GAAA;EACD;AAED,EAAM,SAAA,cAAA,CAAA,GAAA,EAAoC;AACxC;EAOA,SAAO,CAAP,GAAA;EACD;AAED,EAAM,SAAA,YAAA,CAAA,GAAA,EAAkC;AACtC;EAOA,SAAA,GAAA;EACD;AAED,EAAM,SAAA,YAAA,CAAA,GAAA,EAAkC;AACtC;EAOA,SAAA,GAAA;EACD;AAED,EAAM,SAAA,eAAA,CAAA,GAAA,EAAqC;EACzC,EAAA,GAAG,IAAH,CAAA;EACA,SAAO,GAAG,GAAH,CAAA,GAAU,cAAc,CAAxB,GAAwB,CAAxB,GAAgC,cAAc,CAArD,GAAqD,CAArD;EACD;AAED,EAAM,SAAA,eAAA,CAAA,GAAA,EAAqC;EACzC,EAAA,GAAG,IAAH,CAAA;EACA,SAAO,GAAG,GAAA,CAAA;EAAA;EAAH,IAAoC,cAAc,CAAlD,GAAkD,CAAlD,GAA0D,cAAc,CAA/E,GAA+E,CAA/E;;EAKF,CAAA,CAAA,EAAI,CAAJ,CAAA,EAAA,OAAA,CAAiB,UAAA,CAAD;EAAA,SAAO,eAAe,CAAC,eAAe,CAAtD,CAAsD,CAAhB,CAAtB;EAAA,CAAhB;;ECvJM,SAAA,YAAA,CAAA,MAAA,EAA2C;EAC/C,MAAI,OAAA,MAAA,KAAJ,QAAA,EAAgC;EAC9B,WAAA,MAAA;EADF,GAAA,MAEO;EACL,QAAI,KAAK,GAAG,MAAM,CAAN,MAAA,CAAZ,CAAY,CAAZ;EACA,UAAM,IAAA,KAAA,qBAA4B,KAAK,CAAC,OAAlC,WAA+C,KAAK,CAAL,IAAA,CAAW,KAA1D,UAAoE,KAAK,CAAL,IAAA,CAA1E,GAAM,CAAN;EACD;EACF;AAED,EAAM,SAAA,cAAA,CAAA,QAAA,EAA2C;EAC/C,MAAI,QAAQ,CAAR,MAAA,KAAJ,OAAA,EAAiC;EAC/B,UAAM,IAAA,KAAA,qBACc,QAAQ,CAAC,OADvB,WACoC,QAAQ,CAAR,IAAA,CAAc,KADlD,UAC4D,QAAQ,CAAR,IAAA,CADlE,GAAM,CAAN;EAGD;;EAED,SAAA,QAAA;EACD;AAED,EAAM,SAAA,aAAA,CAAA,MAAA,EAA4C;EAChD,MAAI,OAAA,MAAA,KAAJ,QAAA,EAAgC;EAC9B,WAAA,MAAA;EADF,GAAA,MAEO;EACL,WAAO,MAAM,CAAb,MAAA;EACD;EACF;AAED,EAAM,SAAA,UAAA,CAAA,MAAA,EAAyC;EAC7C,SAAO,OAAA,MAAA,KAAP,QAAA;EACD;AAED,EAAM,SAAA,WAAA,CAAA,MAAA,EAA0C;EAC9C,SAAO,OAAA,MAAA,KAAP,QAAA;EACD;;ACnCD,gBAAgB,OAAA,OAAA,KAAA,UAAA,GAAA,OAAA;EAEZ,6BAAA;EACU,SAAA,IAAA,GAAO,IAAP,OAAO,EAAP;EAcT;;EAjBW;;EAAA,SAKV,GALU,GAKV,aAAG,GAAH,EAAU;EACR,SAAA,IAAA,CAAA,GAAA,CAAA,GAAA,EAAA,IAAA;;EACA,WAAA,IAAA;EACD,GARS;;EAAA,qBAUV,iBAAM,GAAN,EAAa;EACX,WAAO,KAAA,IAAA,WAAP,GAAO,CAAP;EACD,GAZS;;EAAA,SAcV,GAdU,GAcV,aAAG,GAAH,EAAU;EACR,WAAO,KAAA,IAAA,CAAA,GAAA,CAAP,GAAO,CAAP;EACD,GAhBS;;EAAA;EAAA,GAAhB;;ECoCM,SAAA,YAAA,CAAA,IAAA,EACyE;EAE7E,MAAI,UAAU,CAAd,IAAc,CAAd,EAAsB;EACpB,WAAA,IAAA;EADF,GAAA,MAEO,IAAI,SAAS,CAAb,IAAa,CAAb,EAAqB;EAC1B,WAAA,IAAA;EADK,GAAA,MAEA;EACL,WAAA,IAAA;EACD;EACF;AAoBD,EAAM,SAAA,aAAA,CAAA,IAAA,EAAA,WAAA,EAEW;EAEf,MAAI,IAAI,KAAJ,IAAA,IAAiB,IAAI,KAAzB,SAAA,EAAyC;EACvC,WAAA,IAAA;EACD;;EAED,MAAI,OAAA,QAAA,KAAJ,SAAA,EAAmC;EACjC,UAAM,IAAA,KAAA,CAAN,8DAAM,CAAN;EACD;;EAED,MAAI,UAAU,CAAd,IAAc,CAAd,EAAsB;EACpB,WAAA,IAAA;EACD;;EAED,MAAI,IAAI,CAAJ,aAAA,KAAJ,QAAA,EAAqC;EACnC,UAAM,IAAA,KAAA,CAAN,yFAAM,CAAN;EAGD;;EAED,SAAO,SAAS,CAAA,IAAA,EAAhB,WAAgB,CAAhB;EACD;;EAED,SAAA,UAAA,CAAA,IAAA,EAAA,KAAA,EAAwD;EACtD,SAAO,IAAA,KAAA,oBAA2B,IAA3B,cAAP,KAAO,CAAP;EACD;;EAED,SAAA,UAAA,CAAA,IAAA,EAA4D;EAC1D,SAAO,IAAI,CAAJ,QAAA,KAAa;EAAA;EAApB;EACD;;EAED,SAAA,SAAA,CAAA,IAAA,EAA0D;EACxD,SAAO,IAAI,CAAJ,QAAA,KAAa;EAAA;EAApB;EACD;;AAED,EAAM,SAAA,SAAA,CAAA,IAAA,EAAA,KAAA,EAEI;EAER,MAAI,OAAO,GAAX,KAAA;;EAEA,MAAI,IAAI,KAAR,IAAA,EAAmB;EACjB,QAAI,OAAA,KAAA,KAAJ,QAAA,EAA+B;EAC7B,MAAA,OAAO,GAAG,eAAe,CAAA,IAAA,EAAzB,KAAyB,CAAzB;EADF,KAAA,MAEO,IAAI,KAAK,CAAL,OAAA,CAAJ,KAAI,CAAJ,EAA0B;EAC/B,MAAA,OAAO,GAAG,KAAK,CAAL,IAAA,CAAY,UAAA,CAAD;EAAA,eAAO,eAAe,CAAA,IAAA,EAA3C,CAA2C,CAAtB;EAAA,OAAX,CAAV;EADK,KAAA,MAEA;EACL,YAAM,WAAN,EAAA;EACD;EACF;;EAED,MAAA,OAAA,EAAa;EACX,WAAA,IAAA;EADF,GAAA,MAEO;EACL,UAAM,UAAU,oBAAA,IAAA,QAAhB,KAAgB,CAAhB;EACD;EACF;;EAED,SAAA,eAAA,CAAA,IAAA,EAAA,KAAA,EAAmE;EACjE,UAAA,KAAA;EACE,SAAA,MAAA;EACE,aAAA,IAAA;;EACF,SAAA,MAAA;EACE,aAAO,IAAI,YAAX,WAAA;;EACF,SAAA,KAAA;EACE,aAAO,IAAI,YAAX,UAAA;;EACF,SAAA,SAAA;EACE,aAAO,IAAI,YAAX,OAAA;;EACF;EACE,UAAI,KAAK,CAAL,WAAA,OAAJ,KAAA,EAAmC;EACjC,cAAM,IAAN,KAAM,8DAAN;EACD;;EACD,aAAO,IAAI,YAAJ,OAAA,IAA2B,IAAI,CAAJ,OAAA,CAAA,WAAA,OAAlC,KAAA;EAbJ;EAeD;;;;;;;;AC5ID,EAAM,SAAA,SAAA,CAAA,IAAA,EAAyC;EAC7C,SAAO,IAAI,CAAJ,MAAA,GAAP,CAAA;EACD;AAED,EAAM,SAAA,SAAA,CAAA,IAAA,EAAA,SAAA,EAAA,SAAA,EAGc;EAElB,MAAI,SAAS,CAAb,IAAa,CAAb,EAAqB;EACnB,WAAO,SAAS,CAAhB,IAAgB,CAAhB;EADF,GAAA,MAEO;EACL,WAAO,SAAP,EAAA;EACD;EACF;AAED,EAAM,SAAA,eAAA,CAAA,IAAA,EAAsC;EAC1C,MAAI,SAAS,CAAb,IAAa,CAAb,EAAqB;EACnB,WAAA,IAAA;EADF,GAAA,MAEO;EACL,WAAA,IAAA;EACD;EACF;AAED,EAAM,SAAA,aAAA,CAAA,IAAA,EAAA,OAAA,EAE6B;EAAA,MAF7B,OAE6B;EAF7B,IAAA,OAE6B;EAAA;;EAEjC,MAAI,CAAC,SAAS,CAAd,IAAc,CAAd,EAAsB;EACpB,UAAM,IAAA,KAAA,CAAN,OAAM,CAAN;EACD;EACF;AAOD,EAAM,SAAA,UAAA,CAAA,IAAA,EAAA,QAAA,EAEqB;EAEzB,MAAI,IAAI,KAAR,IAAA,EAAmB;EACjB,WAAA,IAAA;EACD;;EACD,MAAI,GAAG,GAAP,EAAA;;EAEA,yDAAA,IAAA,wCAAuB;EAAA,QAAvB,IAAuB;EACrB,IAAA,GAAG,CAAH,IAAA,CAAS,QAAQ,CAAjB,IAAiB,CAAjB;EACD;;EAED,SAAA,GAAA;EACD;;ECnDa,SAAA,oBAAA,CAAA,MAAA,EAA6C;EACzD,MAAI,OAAO,GAAX,IAAA;;EACA,MAAIA,SAAK,IAAT,gBAAA,EAA+B;EAC7B,QAAI,gBAAgB,GAAI,SAApB,gBAAoB,CAAA,QAAD,EAAuC;EAC5D,YAAM,IAAA,KAAA,yBACmB,MAAM,CAAA,QAAA,CADzB,wCAAN,MAAM,qKAAN;EADF,KAAA;;EAQA,IAAA,OAAO,GAAG,IAAA,KAAA,CAAA,EAAA,EAER;EACE,MAAA,GADF,eACK,OADL,EACK,QADL,EAC4C;EACxC,QAAA,gBAAgB,CAAhB,QAAgB,CAAhB;EAFJ,OAAA;EAKE,MAAA,GALF,eAKK,OALL,EAKK,QALL,EAK4C;EACxC,QAAA,gBAAgB,CAAhB,QAAgB,CAAhB;EAEA,eAAA,KAAA;EARJ,OAAA;EAWE,MAAA,GAXF,eAWK,OAXL,EAWK,QAXL,EAW4C;EACxC,QAAA,gBAAgB,CAAhB,QAAgB,CAAhB;EAEA,eAAA,KAAA;EACD;EAfH,KAFQ,CAAV;EAoBD;;EAED,SAAA,OAAA;EACD;;ECnCD,IAAA,aAAA;;EAEA,IAAAA,SAAA,EAAW;EACT,MAAI,eAAe,GAAI,SAAnB,eAAmB,CAAA,EAAD,EAAiB;EACrC,QAAI,YAAY,GAAG,EAAE,CAArB,IAAA;;EAEA,QAAI,YAAY,KAAhB,SAAA,EAAgC;EAC9B,UAAI,KAAK,GAAG,QAAQ,CAAR,SAAA,CAAA,QAAA,CAAA,IAAA,CAAA,EAAA,EAAA,KAAA,CAAZ,qBAAY,CAAZ;EAEA,MAAA,YAAY,GAAI,KAAK,IAAI,KAAK,CAAf,CAAe,CAAd,IAAhB,EAAA;EACD;;EAED,WAAO,YAAY,CAAZ,OAAA,CAAA,SAAA,EAAP,EAAO,CAAP;EATF,GAAA;;EAYA,MAAI,aAAa,GAAI,SAAjB,aAAiB,CAAA,GAAD,EAAgB;EAClC,QAAA,IAAA;EACA,QAAA,SAAA;;EAEA,QAAI,GAAG,CAAH,WAAA,IAAmB,OAAO,GAAG,CAAV,WAAA,KAAvB,UAAA,EAA8D;EAC5D,MAAA,SAAS,GAAG,eAAe,CAAC,GAAG,CAA/B,WAA2B,CAA3B;EACD;;EAED,QACE,cAAA,GAAA,IACA,GAAG,CAAH,QAAA,KAAiB,MAAM,CAAN,SAAA,CADjB,QAAA,IAEA,GAAG,CAAH,QAAA,KAAiB,QAAQ,CAAR,SAAA,CAHnB,QAAA,EAIE;EACA,MAAA,IAAI,GAAG,GAAG,CAAV,QAAO,EAAP;EAbgC,KAAA;EAiBlC;EACA;EACA;;;EACA,QACE,IAAI,IACJ,IAAI,CAAJ,KAAA,CADA,eACA,CADA,IAAA,SAAA,IAGA,SAAS,CAAT,CAAS,CAAT,KAHA,GAAA,IAIA,SAAS,CAAT,MAAA,GAJA,CAAA,IAKA,SAAS,KANX,OAAA,EAOE;EACA,aAAO,IAAI,CAAJ,OAAA,CAAA,MAAA,QAAP,SAAO,OAAP;EACD;;EAED,WAAO,IAAI,IAAX,SAAA;EA/BF,GAAA;;EAkCA,MAAI,gBAAgB,GAAI,SAApB,gBAAoB,CAAA,KAAD,EAAe;EACpC,WAAO,MAAM,CAAb,KAAa,CAAb;EADF,GAAA;;EAIA,EAAA,aAAa,GAAI,uBAAA,KAAD,EAAmB;EACjC,QAAI,OAAA,KAAA,KAAJ,UAAA,EAAiC;EAC/B,aAAO,eAAe,CAAtB,KAAsB,CAAf,wBAAP;EADF,KAAA,MAEO,IAAI,OAAA,KAAA,KAAA,QAAA,IAA6B,KAAK,KAAtC,IAAA,EAAiD;EACtD,aAAO,aAAa,CAApB,KAAoB,CAAb,sBAAP;EADK,KAAA,MAEA;EACL,aAAO,gBAAgB,CAAvB,KAAuB,CAAvB;EACD;EAPH,GAAA;EASD;;AAED,wBAAA,aAAA;;MC9DO,cAAA;AACP,MAAO,YAAA;AAEP,MAAO,WAAA;AAGP,MAAO,OAAA;;ECcP;;;;;;;;;AAQA,MAAa,YAAY,GAAlB,OAAA;EAEP;;;;;;;AAMA,MAAa,MAAM,GAAZ,OAAA;AAEP,EAAM,SAAA,WAAA,CAAA,KAAA,EAAoC,IAApC,EAA0E;EAAA,MAAtC,IAAsC;EAAtC,IAAA,IAAsC,GAA1E,+BAA0E;EAAA;;EAC9E,EAAA,MAAM,CAAN,GAAA,CAAA,aAAA,EAAA,KAAA;EACA,EAAA,MAAM,CAAN,GAAA,CAAc,IAAd,YAAyB,IAAI,CAAJ,SAAA,CAAA,KAAA,CAAzB,UAAA,KAAA;EAEA,QAAM,IAAN,KAAM,4BAAN;EACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|