]> gerrit.simantics Code Review - simantics/district.git/blobdiff - org.simantics.maps.server/node/node-v4.8.0-win-x64/node_modules/npm/node_modules/node-gyp/node_modules/path-array/node_modules/array-index/node_modules/es6-symbol/node_modules/es5-ext/node_modules/es6-iterator/for-of.js
Adding integrated tile server
[simantics/district.git] / org.simantics.maps.server / node / node-v4.8.0-win-x64 / node_modules / npm / node_modules / node-gyp / node_modules / path-array / node_modules / array-index / node_modules / es6-symbol / node_modules / es5-ext / node_modules / es6-iterator / for-of.js
diff --git a/org.simantics.maps.server/node/node-v4.8.0-win-x64/node_modules/npm/node_modules/node-gyp/node_modules/path-array/node_modules/array-index/node_modules/es6-symbol/node_modules/es5-ext/node_modules/es6-iterator/for-of.js b/org.simantics.maps.server/node/node-v4.8.0-win-x64/node_modules/npm/node_modules/node-gyp/node_modules/path-array/node_modules/array-index/node_modules/es6-symbol/node_modules/es5-ext/node_modules/es6-iterator/for-of.js
new file mode 100644 (file)
index 0000000..c7a2841
--- /dev/null
@@ -0,0 +1,46 @@
+'use strict';
+
+var isArguments = require('es5-ext/function/is-arguments')
+  , callable    = require('es5-ext/object/valid-callable')
+  , isString    = require('es5-ext/string/is-string')
+  , get         = require('./get')
+
+  , isArray = Array.isArray, call = Function.prototype.call
+  , some = Array.prototype.some;
+
+module.exports = function (iterable, cb/*, thisArg*/) {
+       var mode, thisArg = arguments[2], result, doBreak, broken, i, l, char, code;
+       if (isArray(iterable) || isArguments(iterable)) mode = 'array';
+       else if (isString(iterable)) mode = 'string';
+       else iterable = get(iterable);
+
+       callable(cb);
+       doBreak = function () { broken = true; };
+       if (mode === 'array') {
+               some.call(iterable, function (value) {
+                       call.call(cb, thisArg, value, doBreak);
+                       if (broken) return true;
+               });
+               return;
+       }
+       if (mode === 'string') {
+               l = iterable.length;
+               for (i = 0; i < l; ++i) {
+                       char = iterable[i];
+                       if ((i + 1) < l) {
+                               code = char.charCodeAt(0);
+                               if ((code >= 0xD800) && (code <= 0xDBFF)) char += iterable[++i];
+                       }
+                       call.call(cb, thisArg, char, doBreak);
+                       if (broken) break;
+               }
+               return;
+       }
+       result = iterable.next();
+
+       while (!result.done) {
+               call.call(cb, thisArg, result.value, doBreak);
+               if (broken) return;
+               result = iterable.next();
+       }
+};