summaryrefslogtreecommitdiff
path: root/school/node_modules/graphql/polyfills/arrayFrom.mjs
diff options
context:
space:
mode:
Diffstat (limited to 'school/node_modules/graphql/polyfills/arrayFrom.mjs')
-rw-r--r--school/node_modules/graphql/polyfills/arrayFrom.mjs49
1 files changed, 49 insertions, 0 deletions
diff --git a/school/node_modules/graphql/polyfills/arrayFrom.mjs b/school/node_modules/graphql/polyfills/arrayFrom.mjs
new file mode 100644
index 0000000..1ea59f0
--- /dev/null
+++ b/school/node_modules/graphql/polyfills/arrayFrom.mjs
@@ -0,0 +1,49 @@
+import { SYMBOL_ITERATOR } from "./symbols.mjs";
+
+/* eslint-disable no-redeclare */
+// $FlowFixMe[name-already-bound]
+var arrayFrom = Array.from || function (obj, mapFn, thisArg) {
+ if (obj == null) {
+ throw new TypeError('Array.from requires an array-like object - not null or undefined');
+ } // Is Iterable?
+
+
+ var iteratorMethod = obj[SYMBOL_ITERATOR];
+
+ if (typeof iteratorMethod === 'function') {
+ var iterator = iteratorMethod.call(obj);
+ var result = [];
+ var step;
+
+ for (var i = 0; !(step = iterator.next()).done; ++i) {
+ result.push(mapFn.call(thisArg, step.value, i)); // Infinite Iterators could cause forEach to run forever.
+ // After a very large number of iterations, produce an error.
+ // istanbul ignore if (Too big to actually test)
+
+ if (i > 9999999) {
+ throw new TypeError('Near-infinite iteration.');
+ }
+ }
+
+ return result;
+ } // Is Array like?
+
+
+ var length = obj.length;
+
+ if (typeof length === 'number' && length >= 0 && length % 1 === 0) {
+ var _result = [];
+
+ for (var _i = 0; _i < length; ++_i) {
+ if (Object.prototype.hasOwnProperty.call(obj, _i)) {
+ _result.push(mapFn.call(thisArg, obj[_i], _i));
+ }
+ }
+
+ return _result;
+ }
+
+ return [];
+};
+
+export default arrayFrom;