Sha256: 21bf6502bd0fd64f2bbe11eedd9b17e2e93440220f4a044e80b20fc507221812

Contents?: true

Size: 1.87 KB

Versions: 276

Compression:

Stored size: 1.87 KB

Contents

var SetCache = require('./_SetCache'),
    arrayIncludes = require('./_arrayIncludes'),
    arrayIncludesWith = require('./_arrayIncludesWith'),
    arrayMap = require('./_arrayMap'),
    baseUnary = require('./_baseUnary'),
    cacheHas = require('./_cacheHas');

/** Used as the size to enable large array optimizations. */
var LARGE_ARRAY_SIZE = 200;

/**
 * The base implementation of methods like `_.difference` without support
 * for excluding multiple arrays or iteratee shorthands.
 *
 * @private
 * @param {Array} array The array to inspect.
 * @param {Array} values The values to exclude.
 * @param {Function} [iteratee] The iteratee invoked per element.
 * @param {Function} [comparator] The comparator invoked per element.
 * @returns {Array} Returns the new array of filtered values.
 */
function baseDifference(array, values, iteratee, comparator) {
  var index = -1,
      includes = arrayIncludes,
      isCommon = true,
      length = array.length,
      result = [],
      valuesLength = values.length;

  if (!length) {
    return result;
  }
  if (iteratee) {
    values = arrayMap(values, baseUnary(iteratee));
  }
  if (comparator) {
    includes = arrayIncludesWith;
    isCommon = false;
  }
  else if (values.length >= LARGE_ARRAY_SIZE) {
    includes = cacheHas;
    isCommon = false;
    values = new SetCache(values);
  }
  outer:
  while (++index < length) {
    var value = array[index],
        computed = iteratee == null ? value : iteratee(value);

    value = (comparator || value !== 0) ? value : 0;
    if (isCommon && computed === computed) {
      var valuesIndex = valuesLength;
      while (valuesIndex--) {
        if (values[valuesIndex] === computed) {
          continue outer;
        }
      }
      result.push(value);
    }
    else if (!includes(values, computed, comparator)) {
      result.push(value);
    }
  }
  return result;
}

module.exports = baseDifference;

Version data entries

276 entries across 274 versions & 30 rubygems

Version Path
appmap-0.68.2 ./node_modules/lodash/_baseDifference.js
appmap-0.68.1 ./node_modules/lodash/_baseDifference.js
disco_app-0.15.2 test/dummy/node_modules/lodash/_baseDifference.js
appmap-0.68.0 ./node_modules/lodash/_baseDifference.js
appmap-0.67.1 ./node_modules/lodash/_baseDifference.js
trusty-cms-5.0.3 node_modules/lodash/_baseDifference.js
trusty-cms-5.0.2 node_modules/lodash/_baseDifference.js
appmap-0.67.0 ./node_modules/lodash/_baseDifference.js
disco_app-0.18.4 test/dummy/node_modules/lodash/_baseDifference.js
disco_app-0.18.1 test/dummy/node_modules/lodash/_baseDifference.js
disco_app-0.12.7.pre.puma.pre.3 test/dummy/node_modules/lodash/_baseDifference.js
disco_app-0.14.0 test/dummy/node_modules/lodash/_baseDifference.js
disco_app-0.13.6.pre.puma.pre.3 test/dummy/node_modules/lodash/_baseDifference.js
appmap-0.66.2 ./node_modules/lodash/_baseDifference.js
trusty-cms-5.0.1 node_modules/lodash/_baseDifference.js
trusty-cms-4.3.5 node_modules/lodash/_baseDifference.js
trusty-cms-5.0.0 node_modules/lodash/_baseDifference.js
appmap-0.66.1 ./node_modules/lodash/_baseDifference.js
appmap-0.66.0 ./node_modules/lodash/_baseDifference.js
appmap-0.65.1 ./node_modules/lodash/_baseDifference.js