UNPKG

75.6 kBJavaScriptView Raw
1define('@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":"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"}