Comparing version 2.8.1 to 2.9.0
@@ -49,6 +49,4 @@ 'use strict'; | ||
var Arrays = new WeakMap(); | ||
var Dodo = function () { | ||
function Dodo(array) { | ||
function Dodo(source) { | ||
var index = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; | ||
@@ -61,8 +59,8 @@ var actions = arguments.length <= 2 || arguments[2] === undefined ? noActions : arguments[2]; | ||
(0, _invariant2.default)(Array.isArray(array), 'new Dodo(arr, index) - arr is required'); | ||
(0, _invariant2.default)(index === false || actions !== noActions || Object.keys(index).length == array[0].length, 'new Dodo(arr, index) - index length (' + Object.keys(index).length + ') != array[0].length (' + array[0].length + ')'); | ||
(0, _invariant2.default)(source, 'new Dodo(source, index) - source is required'); | ||
if (Array.isArray(source) && index !== false && actions === noActions) (0, _invariant2.default)(Object.keys(index).length == source[0].length, 'new Dodo(arr, index) - index length (' + Object.keys(index).length + ') != array[0].length (' + source[0].length + ')'); | ||
this.index = index; | ||
this.actions = actions; | ||
Arrays.set(this, array); | ||
this.source = source; | ||
} | ||
@@ -78,3 +76,3 @@ | ||
value: function toArray() { | ||
if (this.actions != noActions) return (this.actions.some(_helpers.needSlowCase) ? _transducers.transduce : _helpers.transduceNoBreak)(Arrays.get(this), (0, _helpers.compose)(this.actions), _helpers.arrayReducer, []);else return Arrays.get(this); | ||
if (this.actions != noActions || !Array.isArray(this.source)) return this.reduce(_helpers.push, []);else return this.source; | ||
} | ||
@@ -91,3 +89,3 @@ }, { | ||
return new Dodo(Arrays.get(this), index, [].concat(_toConsumableArray(this.actions), [transformer])); | ||
return new Dodo(this.source, index, [].concat(_toConsumableArray(this.actions), [transformer])); | ||
} | ||
@@ -181,6 +179,6 @@ }, { | ||
var fn = (0, _transducers.map)(new Function('row', 'return [' + indices.map(function (i) { | ||
var fn = new Function('row', 'return [' + indices.map(function (i) { | ||
return 'row[' + i + ']'; | ||
}).join(',') + ']')); | ||
return this.transform(fn, names); | ||
}).join(',') + ']'); | ||
return this.transform((0, _transducers.map)(fn), names); | ||
} | ||
@@ -206,3 +204,3 @@ }, { | ||
value: function reduce(fn, init) { | ||
var _ref; | ||
var _doer; | ||
@@ -215,3 +213,5 @@ var final = arguments.length <= 2 || arguments[2] === undefined ? _helpers.identity : arguments[2]; | ||
return (this.actions.some(_helpers.needSlowCase) ? _transducers.transduce : _helpers.transduceNoBreak)(Arrays.get(this), (0, _helpers.compose)(this.actions), (_ref = {}, _defineProperty(_ref, '@@transducer/step', fn), _defineProperty(_ref, '@@transducer/result', final), _ref), init); | ||
var doer = !Array.isArray(this.source) || this.actions.some(_helpers.needSlowCase) ? _transducers.transduce : _helpers.transduceNoBreak; | ||
return doer(this.source, (0, _helpers.compose)(this.actions), (_doer = {}, _defineProperty(_doer, '@@transducer/step', fn), _defineProperty(_doer, '@@transducer/result', final), _doer), init); | ||
} | ||
@@ -335,3 +335,3 @@ }, { | ||
get: function get() { | ||
return this.toArray().length; | ||
return this.reduce(_helpers.REDUCERS.count[0], _helpers.REDUCERS.count[1](), _helpers.REDUCERS.count[2]); | ||
} | ||
@@ -441,2 +441,2 @@ }]); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/dodo.js"],"names":[],"mappings":"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","file":"dodo.js","sourcesContent":["import invariant from 'invariant'\nimport zip from 'lodash/zip'\nimport zipObject from 'lodash/zipObject'\nimport unzip from 'lodash/unzip'\nimport flatten from 'lodash/flatten'\nimport {map, filter, drop, take, transduce} from 'transducers.js'\n\nimport {\n  identity, combineReducers, REDUCERS, spread, createGrouper, isfunc,\n  arrayToIndex, compose, transduceNoBreak, arrayReducer, needSlowCase,\n  dispatchReduce\n} from './helpers'\n\nconst noActions = []\n\nconst Arrays = new WeakMap()\n\nexport default class Dodo {\n  constructor(array, index=false, actions=noActions) {\n    if (Array.isArray(index))\n      index = arrayToIndex(index)\n\n    invariant(Array.isArray(array), `new Dodo(arr, index) - arr is required`)\n    invariant(index === false || actions !== noActions || Object.keys(index).length == array[0].length,\n      `new Dodo(arr, index) - index length (${Object.keys(index).length}) != array[0].length (${array[0].length})`)\n\n    this.index = index\n    this.actions = actions\n    Arrays.set(this, array)\n  }\n\n  get columns() {\n    return Object.keys(this.index).sort((a, b) => this.index[a] - this.index[b])\n  }\n\n  [Symbol.iterator]() { return this.toArray().values() }\n\n  toArray() {\n    if (this.actions != noActions)\n      return (this.actions.some(needSlowCase) ? transduce : transduceNoBreak)(\n        Arrays.get(this),\n        compose(this.actions),\n        arrayReducer,\n        []\n      )\n    else\n      return Arrays.get(this)\n  }\n\n  get length() { return this.toArray().length }\n\n  uniq() { return [...new Set(this)] }\n\n  transform(transformer, index=this.index) {\n    return new Dodo(Arrays.get(this), index, [...this.actions, transformer])\n  }\n\n  filter(fn) {\n    invariant(isfunc(fn), `Dodo#filter(fn) — fn not a function`)\n    if (this.index) {\n      const I = this.index\n      return this.transform(filter(row => fn(row, I)))\n    } else {\n      return this.transform(filter(fn))\n    }\n  }\n\n  filterBy(name, fn) {\n    invariant(this.index, `Dodo#filterBy(name, fn) — only available on indexed dodos`)\n    invariant(name, `Dodo#filterBy(name, fn) - name is required`)\n    invariant(isfunc(fn), `Dodo#filterBy(name, fn) - fn not a function`)\n    const col = this.index[name]\n    invariant(col != null, `Dodo#col(name) — name ${name} not in index`)\n    return this.transform( filter(row => fn(row[col])) )\n  }\n\n  map(fn) {\n    invariant(isfunc(fn), `Dodo#map(fn) — fn not a function`)\n    if (this.index) {\n      const I = this.index\n      return this.transform(map(row => fn(row, I)))\n    } else {\n      return this.transform(map(fn))\n    }\n  }\n\n  col(name) {\n    invariant(this.index, `Dodo#col(name) — only available on indexed dodos`)\n    invariant(name, `Dodo#col(name) - name is required`)\n\n    const col = this.index[name]\n    invariant(col != null, `Dodo#col(name) — name ${name} not in index`)\n\n    return this.transform(map(row => row[col]), false)\n  }\n\n  cols(...names) {\n    invariant(this.index, `Dodo#cols(...names) — only available on indexed dodos`)\n    names = names.length ? flatten(names) : undefined\n    invariant(names, `Dodo#cols(...names) - names is required`)\n\n    const indices = names.map(name => this.index[name])\n    indices.forEach(i => invariant(i != null, `Dodo#cols(...names) - name ${this.columns[i]} not in index`))\n\n    const fn = map(new Function('row',`return [${indices.map(i => `row[${i}]`).join(',')}]`))\n    return this.transform(fn, names)\n  }\n\n  skip(amount) {\n    invariant(Number.isFinite(amount), `Dodo#skip(amount) - amount must be a number`)\n    invariant(amount >= 0, `Dodo#skip(amount) — amount smaller than 0`)\n\n    if (amount === 0)\n      return this\n    else\n      return this.transform(drop(amount))\n  }\n\n  take(amount) {\n    invariant(Number.isFinite(amount), `Dodo#take(amount) - amount must be a number`)\n    invariant(amount >= 0, `Dodo#take(amount) — amount smaller than 0`)\n\n    return this.transform(take(amount))\n  }\n\n  reduce(fn, init, final=identity) {\n    invariant(init != null, `Dodo#reduce(fn, init, final) - init is required`)\n    invariant(isfunc(fn), `Dodo#reduce(fn, init, final) — fn not a function`)\n    invariant(isfunc(final), `Dodo#reduce(fn, init, final) — final not a function`)\n\n    return (this.actions.some(needSlowCase) ? transduce : transduceNoBreak)(\n      Arrays.get(this),\n      compose(this.actions),\n      {\n        ['@@transducer/step']: fn,\n        ['@@transducer/result']: final\n      },\n      init\n    )\n  }\n\n  reduceEach(fn, initFactory, final=identity) {\n    invariant(this.index, `Dodo#reduceEach(fn, initFactory, final?) - only available on indexed dodos`)\n    invariant(isfunc(fn), `Dodo#reduceEach(fn, initFactory, final?) — fn not a function`)\n    invariant(isfunc(initFactory), `Dodo#reduceEach(fn, initFactory, final?) - initFactory not a function`)\n    invariant(isfunc(final), `Dodo#reduceEach(fn, ininitFactory, final?) — final not a function`)\n\n    const [fns, inits, finals] = unzip(this.columns.map(() => [fn, initFactory(), final]))\n    return zipObject(\n      this.columns,\n      this.reduce(combineReducers(fns, true), inits, spread(finals))\n    )\n  }\n\n  stats(...methods) {\n    invariant(methods && methods.length, `Dodo#stats(...methods) - at least one method is required`)\n    methods.forEach(m => invariant(typeof m == 'string' && m in REDUCERS, `Dodo#stats(...methods) - method ${m} is not implemented`))\n\n    const [fns, inits, finals] = zip(...methods.map(m => REDUCERS[m]))\n    return dispatchReduce.call(this,\n      combineReducers(fns),\n      () => inits.map(i => i()),\n      spread(finals)\n    )\n  }\n\n  count() { return dispatchReduce.call(this, ...REDUCERS.count) }\n\n  sum() { return dispatchReduce.call(this, ...REDUCERS.sum) }\n\n  min() { return dispatchReduce.call(this, ...REDUCERS.min) }\n\n  max() { return dispatchReduce.call(this, ...REDUCERS.max) }\n\n  countUniq() { return dispatchReduce.call(this, ...REDUCERS.countUniq) }\n\n  mean() { return dispatchReduce.call(this, ...REDUCERS.mean) }\n\n  groupBy(name, fn) {\n    if (isfunc(name)) {\n      fn = name\n      name = undefined\n    }\n    invariant(this.index ? name : !name, `Dodo#groupBy(name, fn?) — name is required on indexed dodos` )\n    invariant(!name || this.columns.includes(name), `Dodo#groupBy(name?, fn?) — name ${name} not in index`)\n    invariant(!fn || isfunc(fn), `Dodo#groupBy(name?, fn?) — fn not a function`)\n\n    const grouper = createGrouper(fn, name ? this.index[name] : name)\n    const toDodos = map => (map.forEach(arrayToDodo(this.index)), map)\n    return Flock(this.reduce(grouper, new Map(), toDodos))\n  }\n\n  flock(fn) {\n    invariant(isfunc(fn), `Dodo#flock(fn) — fn not a function`)\n    return Flock(fn.call(this, this))\n  }\n}\n\nexport function arrayToDodo(index) {\n  return function(array, key, map) {\n    map.set(key, new Dodo(array, index))\n  }\n}\n\nDodo.prototype.drop = Dodo.prototype.skip\n\nconst dodoMethods = Object.getOwnPropertyNames(Dodo.prototype)\ndodoMethods.filter(method => method != 'constructor')\n\nfunction Flock(map, method, args) {\n  map = new Map(map)\n\n  // if called with method arg call that method on all Dodos\n  if (method)\n    for (const [key, dodo] of map.entries())\n      map.set(key, dodo[method](...args))\n\n  // if the values are Dodos add the Dodo methods to the returned Map\n  if (map.values().next().value instanceof Dodo)\n    for (const method of dodoMethods)\n      map[method] = (...args) => Flock(map, method, args)\n\n  // mapEntries method with same signature as native Map#forEach()\n  map.mapEntries = mapEntries\n\n  return map\n}\n\nfunction mapEntries(fn) {\n  const entries = [...this.entries()]\n  const len = this.size\n  let i = -1\n  while (++i < len) {\n    let entry = entries[i]\n    entries[i] = fn(entry[1], entry[0], this)\n  }\n  return entries\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/dodo.js"],"names":[],"mappings":"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","file":"dodo.js","sourcesContent":["import invariant from 'invariant'\nimport zip from 'lodash/zip'\nimport zipObject from 'lodash/zipObject'\nimport unzip from 'lodash/unzip'\nimport flatten from 'lodash/flatten'\nimport {map, filter, drop, take, transduce} from 'transducers.js'\n\nimport {\n  identity, combineReducers, REDUCERS, spread, createGrouper, isfunc,\n  arrayToIndex, compose, transduceNoBreak, push, needSlowCase,\n  dispatchReduce\n} from './helpers'\n\nconst noActions = []\n\nexport default class Dodo {\n  constructor(source, index=false, actions=noActions) {\n    if (Array.isArray(index))\n      index = arrayToIndex(index)\n\n    invariant(source, `new Dodo(source, index) - source is required`)\n    if (Array.isArray(source) && index !== false && actions === noActions)\n      invariant(Object.keys(index).length == source[0].length,\n        `new Dodo(arr, index) - index length (${Object.keys(index).length}) != array[0].length (${source[0].length})`)\n\n    this.index = index\n    this.actions = actions\n    this.source = source\n  }\n\n  get columns() {\n    return Object.keys(this.index).sort((a, b) => this.index[a] - this.index[b])\n  }\n\n  [Symbol.iterator]() { return this.toArray().values() }\n\n  toArray() {\n    if (this.actions != noActions || !Array.isArray(this.source))\n      return this.reduce(push, [])\n    else\n      return this.source\n  }\n\n  get length() {\n    return this.reduce(REDUCERS.count[0], REDUCERS.count[1](), REDUCERS.count[2])\n  }\n\n  uniq() { return [...new Set(this)] }\n\n  transform(transformer, index=this.index) {\n    return new Dodo(this.source, index, [...this.actions, transformer])\n  }\n\n  filter(fn) {\n    invariant(isfunc(fn), `Dodo#filter(fn) — fn not a function`)\n    if (this.index) {\n      const I = this.index\n      return this.transform(filter(row => fn(row, I)))\n    } else {\n      return this.transform(filter(fn))\n    }\n  }\n\n  filterBy(name, fn) {\n    invariant(this.index, `Dodo#filterBy(name, fn) — only available on indexed dodos`)\n    invariant(name, `Dodo#filterBy(name, fn) - name is required`)\n    invariant(isfunc(fn), `Dodo#filterBy(name, fn) - fn not a function`)\n    const col = this.index[name]\n    invariant(col != null, `Dodo#col(name) — name ${name} not in index`)\n    return this.transform( filter(row => fn(row[col])) )\n  }\n\n  map(fn) {\n    invariant(isfunc(fn), `Dodo#map(fn) — fn not a function`)\n    if (this.index) {\n      const I = this.index\n      return this.transform(map(row => fn(row, I)))\n    } else {\n      return this.transform(map(fn))\n    }\n  }\n\n  col(name) {\n    invariant(this.index, `Dodo#col(name) — only available on indexed dodos`)\n    invariant(name, `Dodo#col(name) - name is required`)\n\n    const col = this.index[name]\n    invariant(col != null, `Dodo#col(name) — name ${name} not in index`)\n\n    return this.transform(map(row => row[col]), false)\n  }\n\n  cols(...names) {\n    invariant(this.index, `Dodo#cols(...names) — only available on indexed dodos`)\n    names = names.length ? flatten(names) : undefined\n    invariant(names, `Dodo#cols(...names) - names is required`)\n\n    const indices = names.map(name => this.index[name])\n    indices.forEach(i => invariant(i != null, `Dodo#cols(...names) - name ${this.columns[i]} not in index`))\n\n    const fn = new Function('row',`return [${indices.map(i => `row[${i}]`).join(',')}]`)\n    return this.transform(map(fn), names)\n  }\n\n  skip(amount) {\n    invariant(Number.isFinite(amount), `Dodo#skip(amount) - amount must be a number`)\n    invariant(amount >= 0, `Dodo#skip(amount) — amount smaller than 0`)\n\n    if (amount === 0)\n      return this\n    else\n      return this.transform(drop(amount))\n  }\n\n  take(amount) {\n    invariant(Number.isFinite(amount), `Dodo#take(amount) - amount must be a number`)\n    invariant(amount >= 0, `Dodo#take(amount) — amount smaller than 0`)\n\n    return this.transform(take(amount))\n  }\n\n  reduce(fn, init, final=identity) {\n    invariant(init != null, `Dodo#reduce(fn, init, final) - init is required`)\n    invariant(isfunc(fn), `Dodo#reduce(fn, init, final) — fn not a function`)\n    invariant(isfunc(final), `Dodo#reduce(fn, init, final) — final not a function`)\n\n    const doer = (!Array.isArray(this.source) || this.actions.some(needSlowCase))\n      ? transduce\n      : transduceNoBreak\n\n    return doer(\n      this.source,\n      compose(this.actions),\n      {\n        ['@@transducer/step']: fn,\n        ['@@transducer/result']: final\n      },\n      init\n    )\n  }\n\n  reduceEach(fn, initFactory, final=identity) {\n    invariant(this.index, `Dodo#reduceEach(fn, initFactory, final?) - only available on indexed dodos`)\n    invariant(isfunc(fn), `Dodo#reduceEach(fn, initFactory, final?) — fn not a function`)\n    invariant(isfunc(initFactory), `Dodo#reduceEach(fn, initFactory, final?) - initFactory not a function`)\n    invariant(isfunc(final), `Dodo#reduceEach(fn, ininitFactory, final?) — final not a function`)\n\n    const [fns, inits, finals] = unzip(this.columns.map(() => [fn, initFactory(), final]))\n    return zipObject(\n      this.columns,\n      this.reduce(combineReducers(fns, true), inits, spread(finals))\n    )\n  }\n\n  stats(...methods) {\n    invariant(methods && methods.length, `Dodo#stats(...methods) - at least one method is required`)\n    methods.forEach(m => invariant(typeof m == 'string' && m in REDUCERS, `Dodo#stats(...methods) - method ${m} is not implemented`))\n\n    const [fns, inits, finals] = zip(...methods.map(m => REDUCERS[m]))\n    return dispatchReduce.call(this,\n      combineReducers(fns),\n      () => inits.map(i => i()),\n      spread(finals)\n    )\n  }\n\n  count() { return dispatchReduce.call(this, ...REDUCERS.count) }\n\n  sum() { return dispatchReduce.call(this, ...REDUCERS.sum) }\n\n  min() { return dispatchReduce.call(this, ...REDUCERS.min) }\n\n  max() { return dispatchReduce.call(this, ...REDUCERS.max) }\n\n  countUniq() { return dispatchReduce.call(this, ...REDUCERS.countUniq) }\n\n  mean() { return dispatchReduce.call(this, ...REDUCERS.mean) }\n\n  groupBy(name, fn) {\n    if (isfunc(name)) {\n      fn = name\n      name = undefined\n    }\n    invariant(this.index ? name : !name, `Dodo#groupBy(name, fn?) — name is required on indexed dodos` )\n    invariant(!name || this.columns.includes(name), `Dodo#groupBy(name?, fn?) — name ${name} not in index`)\n    invariant(!fn || isfunc(fn), `Dodo#groupBy(name?, fn?) — fn not a function`)\n\n    const grouper = createGrouper(fn, name ? this.index[name] : name)\n    const toDodos = map => (map.forEach(arrayToDodo(this.index)), map)\n    return Flock(this.reduce(grouper, new Map(), toDodos))\n  }\n\n  flock(fn) {\n    invariant(isfunc(fn), `Dodo#flock(fn) — fn not a function`)\n    return Flock(fn.call(this, this))\n  }\n}\n\nexport function arrayToDodo(index) {\n  return function(array, key, map) {\n    map.set(key, new Dodo(array, index))\n  }\n}\n\nDodo.prototype.drop = Dodo.prototype.skip\n\nconst dodoMethods = Object.getOwnPropertyNames(Dodo.prototype)\ndodoMethods.filter(method => method != 'constructor')\n\nfunction Flock(map, method, args) {\n  map = new Map(map)\n\n  // if called with method arg call that method on all Dodos\n  if (method)\n    for (const [key, dodo] of map.entries())\n      map.set(key, dodo[method](...args))\n\n  // if the values are Dodos add the Dodo methods to the returned Map\n  if (map.values().next().value instanceof Dodo)\n    for (const method of dodoMethods)\n      map[method] = (...args) => Flock(map, method, args)\n\n  // mapEntries method with same signature as native Map#forEach()\n  map.mapEntries = mapEntries\n\n  return map\n}\n\nfunction mapEntries(fn) {\n  const entries = [...this.entries()]\n  const len = this.size\n  let i = -1\n  while (++i < len) {\n    let entry = entries[i]\n    entries[i] = fn(entry[1], entry[0], this)\n  }\n  return entries\n}\n"]} |
@@ -6,12 +6,11 @@ 'use strict'; | ||
}); | ||
exports.needSlowCase = exports.arrayToIndex = exports.isfunc = exports.REDUCERS = exports.arrayReducer = exports.identity = undefined; | ||
exports.needSlowCase = exports.arrayToIndex = exports.isfunc = exports.REDUCERS = exports.identity = undefined; | ||
var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); | ||
var _arrayReducer; | ||
exports.compose = compose; | ||
exports.spread = spread; | ||
exports.push = push; | ||
exports.transduceNoBreak = transduceNoBreak; | ||
exports.combineReducers = combineReducers; | ||
exports.spread = spread; | ||
exports.createGrouper = createGrouper; | ||
@@ -28,4 +27,2 @@ exports.dispatchReduce = dispatchReduce; | ||
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | ||
var identity = exports.identity = function identity(a) { | ||
@@ -35,2 +32,45 @@ return a; | ||
var REDUCERS = exports.REDUCERS = { | ||
max: [function (max, el) { | ||
return max > el ? max : el; | ||
}, function () { | ||
return -Infinity; | ||
}, identity], | ||
min: [function (min, el) { | ||
return min < el ? min : el; | ||
}, function () { | ||
return Infinity; | ||
}, identity], | ||
sum: [function (sum, el) { | ||
return sum + el; | ||
}, function () { | ||
return 0; | ||
}, identity], | ||
mean: [function (stats, el) { | ||
++stats[0]; | ||
stats[1] += el; | ||
return stats; | ||
}, function () { | ||
return [0, 0]; | ||
}, function (_ref) { | ||
var _ref2 = _slicedToArray(_ref, 2); | ||
var count = _ref2[0]; | ||
var sum = _ref2[1]; | ||
return sum / count; | ||
}], | ||
count: [function (count) { | ||
return ++count; | ||
}, function () { | ||
return 0; | ||
}, identity], | ||
countUniq: [function (set, el) { | ||
return set.add(el); | ||
}, function () { | ||
return new Set(); | ||
}, function (set) { | ||
return set.size; | ||
}] | ||
}; | ||
function compose(funcs) { | ||
@@ -48,17 +88,6 @@ var len = funcs.length; | ||
function spread(fns) { | ||
var len = fns.length; | ||
return function (value) { | ||
var i = -1; | ||
while (++i < len) { | ||
value[i] = fns[i](value[i]); | ||
} | ||
return value; | ||
}; | ||
} | ||
var arrayReducer = exports.arrayReducer = (_arrayReducer = {}, _defineProperty(_arrayReducer, '@@transducer/result', identity), _defineProperty(_arrayReducer, '@@transducer/step', function transducerStep(arr, v) { | ||
function push(arr, v) { | ||
arr.push(v); | ||
return arr; | ||
}), _arrayReducer); | ||
} | ||
@@ -97,45 +126,13 @@ function transduceNoBreak(coll, xform, reducer, init) { | ||
var REDUCERS = exports.REDUCERS = { | ||
max: [function (max, el) { | ||
return max > el ? max : el; | ||
}, function () { | ||
return -Infinity; | ||
}, identity], | ||
min: [function (min, el) { | ||
return min < el ? min : el; | ||
}, function () { | ||
return Infinity; | ||
}, identity], | ||
sum: [function (sum, el) { | ||
return sum + el; | ||
}, function () { | ||
return 0; | ||
}, identity], | ||
mean: [function (stats, el) { | ||
++stats[0]; | ||
stats[1] += el; | ||
return stats; | ||
}, function () { | ||
return [0, 0]; | ||
}, function (_ref) { | ||
var _ref2 = _slicedToArray(_ref, 2); | ||
function spread(fns) { | ||
var len = fns.length; | ||
return function (value) { | ||
var i = -1; | ||
while (++i < len) { | ||
value[i] = fns[i](value[i]); | ||
} | ||
return value; | ||
}; | ||
} | ||
var count = _ref2[0]; | ||
var sum = _ref2[1]; | ||
return sum / count; | ||
}], | ||
count: [function (count) { | ||
return ++count; | ||
}, function () { | ||
return 0; | ||
}, identity], | ||
countUniq: [function (set, el) { | ||
return set.add(el); | ||
}, function () { | ||
return new Set(); | ||
}, function (set) { | ||
return set.size; | ||
}] | ||
}; | ||
function createGrouper(fn, col) { | ||
@@ -188,2 +185,2 @@ if (fn) { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/helpers.js"],"names":[],"mappings":"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","file":"helpers.js","sourcesContent":["import zipObject from 'lodash/zipObject'\n\nexport const identity = a => a\n\nexport function compose(funcs) {\n  var len = funcs.length\n  return function(r) {\n    var value = r\n    var i = len\n    while (i--) {\n      value = funcs[i](value)\n    }\n    return value\n  }\n}\n\nexport function spread(fns) {\n  const len = fns.length\n  return function(value) {\n    let i = -1\n    while (++i < len) {\n      value[i] = fns[i](value[i])\n    }\n    return value\n  }\n}\n\nexport const arrayReducer = {\n  ['@@transducer/result']: identity,\n\n  ['@@transducer/step'](arr, v) {\n    arr.push(v)\n    return arr\n  },\n}\n\nexport function transduceNoBreak(coll, xform, reducer, init) {\n  xform = xform(reducer)\n  var result = init;\n  var index = -1;\n  var len = coll.length;\n  while(++index < len) {\n    result = xform['@@transducer/step'](result, coll[index]);\n  }\n  return xform['@@transducer/result'](result);\n}\n\nexport function combineReducers(fns, spread) {\n  const len = fns.length\n  if (spread) {\n    return function(accs, row) {\n      let i = -1\n      while (++i < len) {\n        accs[i] = fns[i](accs[i], row[i])\n      }\n      return accs\n    }\n  } else {\n    return function(accs, row) {\n      let i = -1\n      while (++i < len) {\n        accs[i] = fns[i](accs[i], row)\n      }\n      return accs\n    }\n  }\n}\n\nexport const REDUCERS = {\n  max: [(max, el) => max > el ? max : el, () => -Infinity, identity],\n  min: [(min, el) => min < el ? min : el, () => Infinity, identity],\n  sum: [(sum, el) => sum + el, () => 0, identity],\n  mean: [\n    (stats, el) => {\n      ++stats[0]\n      stats[1] += el\n      return stats\n    },\n    () => [0, 0],\n    ([count, sum]) => sum / count\n  ],\n  count: [count => ++count, () => 0, identity],\n  countUniq: [(set, el) => set.add(el), () => new Set(), set => set.size],\n}\n\nexport function createGrouper(fn, col) {\n  if (fn) {\n    if (col == undefined) {\n      return function(map, row) {\n        const key = fn(row)\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    } else {\n      return function(map, row) {\n        const key = fn(row[col])\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    }\n  } else {\n    if (col == undefined) {\n      return function(map, row) {\n        const key = row\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    } else {\n      return function(map, row) {\n        const key = row[col]\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    }\n  }\n}\n\nexport const isfunc = fn => fn && typeof fn == 'function'\n\nexport const arrayToIndex = arr => zipObject(arr, [...arr.keys()])\n\nexport const needSlowCase = a =>\n  a.toString().includes('new Take') || a.toString().includes('new Drop')\n\nexport function dispatchReduce(fn, initFactory, final) {\n  if (this.index)\n    return this.reduceEach(fn, initFactory, final)\n  else\n    return this.reduce(fn, initFactory(), final)\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/helpers.js"],"names":[],"mappings":"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","file":"helpers.js","sourcesContent":["import zipObject from 'lodash/zipObject'\n\nexport const identity = a => a\n\nexport const REDUCERS = {\n  max: [(max, el) => max > el ? max : el, () => -Infinity, identity],\n  min: [(min, el) => min < el ? min : el, () => Infinity, identity],\n  sum: [(sum, el) => sum + el, () => 0, identity],\n  mean: [\n    (stats, el) => {\n      ++stats[0]\n      stats[1] += el\n      return stats\n    },\n    () => [0, 0],\n    ([count, sum]) => sum / count\n  ],\n  count: [count => ++count, () => 0, identity],\n  countUniq: [(set, el) => set.add(el), () => new Set(), set => set.size],\n}\n\nexport function compose(funcs) {\n  var len = funcs.length\n  return function(r) {\n    var value = r\n    var i = len\n    while (i--) {\n      value = funcs[i](value)\n    }\n    return value\n  }\n}\n\nexport function push(arr, v) {\n  arr.push(v)\n  return arr\n}\n\nexport function transduceNoBreak(coll, xform, reducer, init) {\n  xform = xform(reducer)\n  var result = init;\n  var index = -1;\n  var len = coll.length;\n  while(++index < len) {\n    result = xform['@@transducer/step'](result, coll[index]);\n  }\n  return xform['@@transducer/result'](result);\n}\n\nexport function combineReducers(fns, spread) {\n  const len = fns.length\n  if (spread) {\n    return function(accs, row) {\n      let i = -1\n      while (++i < len) {\n        accs[i] = fns[i](accs[i], row[i])\n      }\n      return accs\n    }\n  } else {\n    return function(accs, row) {\n      let i = -1\n      while (++i < len) {\n        accs[i] = fns[i](accs[i], row)\n      }\n      return accs\n    }\n  }\n}\n\nexport function spread(fns) {\n  const len = fns.length\n  return function(value) {\n    let i = -1\n    while (++i < len) {\n      value[i] = fns[i](value[i])\n    }\n    return value\n  }\n}\n\nexport function createGrouper(fn, col) {\n  if (fn) {\n    if (col == undefined) {\n      return function(map, row) {\n        const key = fn(row)\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    } else {\n      return function(map, row) {\n        const key = fn(row[col])\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    }\n  } else {\n    if (col == undefined) {\n      return function(map, row) {\n        const key = row\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    } else {\n      return function(map, row) {\n        const key = row[col]\n        map.has(key)\n          ? map.get(key).push(row)\n          : map.set(key, [row])\n        return map\n      }\n    }\n  }\n}\n\nexport const isfunc = fn => fn && typeof fn == 'function'\n\nexport const arrayToIndex = arr => zipObject(arr, [...arr.keys()])\n\nexport const needSlowCase = a =>\n  a.toString().includes('new Take') || a.toString().includes('new Drop')\n\nexport function dispatchReduce(fn, initFactory, final) {\n  if (this.index)\n    return this.reduceEach(fn, initFactory, final)\n  else\n    return this.reduce(fn, initFactory(), final)\n}\n"]} |
{ | ||
"name": "dodos", | ||
"version": "2.8.1", | ||
"version": "2.9.0", | ||
"description": "Pandas-inspired iterator-based data wrangling library for js", | ||
@@ -37,11 +37,11 @@ "main": "lib/dodo.js", | ||
"ava": "~0.14.0", | ||
"babel-cli": "~6.7.5", | ||
"babel-core": "~6.7.2", | ||
"babel-eslint": "~6.0.0", | ||
"babel-cli": "~6.7.7", | ||
"babel-core": "~6.7.7", | ||
"babel-eslint": "~6.0.3", | ||
"babel-loader": "~6.2.4", | ||
"babel-polyfill": "~6.7.2", | ||
"babel-polyfill": "~6.7.4", | ||
"babel-preset-es2015": "~6.6.0", | ||
"babel-require": "~1.0.1", | ||
"benchmark": "~2.1.0", | ||
"d3-dsv": "~0.3.1", | ||
"d3-dsv": "~0.3.2", | ||
"eslint": "~2.8.0", | ||
@@ -48,0 +48,0 @@ "husky": "~0.11.4", |
@@ -10,3 +10,3 @@ import invariant from 'invariant' | ||
identity, combineReducers, REDUCERS, spread, createGrouper, isfunc, | ||
arrayToIndex, compose, transduceNoBreak, arrayReducer, needSlowCase, | ||
arrayToIndex, compose, transduceNoBreak, push, needSlowCase, | ||
dispatchReduce | ||
@@ -17,16 +17,15 @@ } from './helpers' | ||
const Arrays = new WeakMap() | ||
export default class Dodo { | ||
constructor(array, index=false, actions=noActions) { | ||
constructor(source, index=false, actions=noActions) { | ||
if (Array.isArray(index)) | ||
index = arrayToIndex(index) | ||
invariant(Array.isArray(array), `new Dodo(arr, index) - arr is required`) | ||
invariant(index === false || actions !== noActions || Object.keys(index).length == array[0].length, | ||
`new Dodo(arr, index) - index length (${Object.keys(index).length}) != array[0].length (${array[0].length})`) | ||
invariant(source, `new Dodo(source, index) - source is required`) | ||
if (Array.isArray(source) && index !== false && actions === noActions) | ||
invariant(Object.keys(index).length == source[0].length, | ||
`new Dodo(arr, index) - index length (${Object.keys(index).length}) != array[0].length (${source[0].length})`) | ||
this.index = index | ||
this.actions = actions | ||
Arrays.set(this, array) | ||
this.source = source | ||
} | ||
@@ -41,14 +40,11 @@ | ||
toArray() { | ||
if (this.actions != noActions) | ||
return (this.actions.some(needSlowCase) ? transduce : transduceNoBreak)( | ||
Arrays.get(this), | ||
compose(this.actions), | ||
arrayReducer, | ||
[] | ||
) | ||
if (this.actions != noActions || !Array.isArray(this.source)) | ||
return this.reduce(push, []) | ||
else | ||
return Arrays.get(this) | ||
return this.source | ||
} | ||
get length() { return this.toArray().length } | ||
get length() { | ||
return this.reduce(REDUCERS.count[0], REDUCERS.count[1](), REDUCERS.count[2]) | ||
} | ||
@@ -58,3 +54,3 @@ uniq() { return [...new Set(this)] } | ||
transform(transformer, index=this.index) { | ||
return new Dodo(Arrays.get(this), index, [...this.actions, transformer]) | ||
return new Dodo(this.source, index, [...this.actions, transformer]) | ||
} | ||
@@ -109,4 +105,4 @@ | ||
const fn = map(new Function('row',`return [${indices.map(i => `row[${i}]`).join(',')}]`)) | ||
return this.transform(fn, names) | ||
const fn = new Function('row',`return [${indices.map(i => `row[${i}]`).join(',')}]`) | ||
return this.transform(map(fn), names) | ||
} | ||
@@ -136,4 +132,8 @@ | ||
return (this.actions.some(needSlowCase) ? transduce : transduceNoBreak)( | ||
Arrays.get(this), | ||
const doer = (!Array.isArray(this.source) || this.actions.some(needSlowCase)) | ||
? transduce | ||
: transduceNoBreak | ||
return doer( | ||
this.source, | ||
compose(this.actions), | ||
@@ -140,0 +140,0 @@ { |
@@ -5,2 +5,19 @@ import zipObject from 'lodash/zipObject' | ||
export const REDUCERS = { | ||
max: [(max, el) => max > el ? max : el, () => -Infinity, identity], | ||
min: [(min, el) => min < el ? min : el, () => Infinity, identity], | ||
sum: [(sum, el) => sum + el, () => 0, identity], | ||
mean: [ | ||
(stats, el) => { | ||
++stats[0] | ||
stats[1] += el | ||
return stats | ||
}, | ||
() => [0, 0], | ||
([count, sum]) => sum / count | ||
], | ||
count: [count => ++count, () => 0, identity], | ||
countUniq: [(set, el) => set.add(el), () => new Set(), set => set.size], | ||
} | ||
export function compose(funcs) { | ||
@@ -18,22 +35,7 @@ var len = funcs.length | ||
export function spread(fns) { | ||
const len = fns.length | ||
return function(value) { | ||
let i = -1 | ||
while (++i < len) { | ||
value[i] = fns[i](value[i]) | ||
} | ||
return value | ||
} | ||
export function push(arr, v) { | ||
arr.push(v) | ||
return arr | ||
} | ||
export const arrayReducer = { | ||
['@@transducer/result']: identity, | ||
['@@transducer/step'](arr, v) { | ||
arr.push(v) | ||
return arr | ||
}, | ||
} | ||
export function transduceNoBreak(coll, xform, reducer, init) { | ||
@@ -71,17 +73,11 @@ xform = xform(reducer) | ||
export const REDUCERS = { | ||
max: [(max, el) => max > el ? max : el, () => -Infinity, identity], | ||
min: [(min, el) => min < el ? min : el, () => Infinity, identity], | ||
sum: [(sum, el) => sum + el, () => 0, identity], | ||
mean: [ | ||
(stats, el) => { | ||
++stats[0] | ||
stats[1] += el | ||
return stats | ||
}, | ||
() => [0, 0], | ||
([count, sum]) => sum / count | ||
], | ||
count: [count => ++count, () => 0, identity], | ||
countUniq: [(set, el) => set.add(el), () => new Set(), set => set.size], | ||
export function spread(fns) { | ||
const len = fns.length | ||
return function(value) { | ||
let i = -1 | ||
while (++i < len) { | ||
value[i] = fns[i](value[i]) | ||
} | ||
return value | ||
} | ||
} | ||
@@ -88,0 +84,0 @@ |
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
167815
3290