Skip to content

Commit

Permalink
Make iterator more prone to JIT optimizations
Browse files Browse the repository at this point in the history
  • Loading branch information
megawac committed Jul 21, 2016
1 parent 72a7810 commit 422026d
Showing 1 changed file with 29 additions and 22 deletions.
51 changes: 29 additions & 22 deletions lib/internal/iterator.js
Expand Up @@ -2,33 +2,40 @@ import isArrayLike from 'lodash/isArrayLike';
import getIterator from './getIterator';
import keys from 'lodash/keys';

export default function iterator(coll) {
function createArrayIterator(coll) {
var i = -1;
var len;
if (isArrayLike(coll)) {
len = coll.length;
return function next() {
i++;
return i < len ? {value: coll[i], key: i} : null;
};
var len = coll.length;
return function next() {
return ++i < len ? {value: coll[i], key: i} : null;
}
}

var iterate = getIterator(coll);
if (iterate) {
return function next() {
var item = iterate.next();
if (item.done)
return null;
i++;
return {value: item.value, key: i};
};
function createES2015Iterator(iterator) {
var i = -1;
return function next() {
var item = iterator.next();
if (item.done)
return null;
i++;
return {value: item.value, key: i};
}
}

var okeys = keys(coll);
len = okeys.length;
function createObjectIterator(obj) {
var okeys = keys(obj);
var i = -1;
var len = okeys.length;
return function next() {
i++;
var key = okeys[i];
return i < len ? {value: coll[key], key: key} : null;
var key = okeys[++i];
return i < len ? {value: obj[key], key: key} : null;
};
}

export default function iterator(coll) {
if (isArrayLike(coll)) {
return createArrayIterator(coll);
}

var iterator = getIterator(coll);
return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll);
}

0 comments on commit 422026d

Please sign in to comment.