| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 | var baseIteratee = require('./_baseIteratee'),    basePullAt = require('./_basePullAt');/** * Removes all elements from `array` that `predicate` returns truthy for * and returns an array of the removed elements. The predicate is invoked * with three arguments: (value, index, array). * * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull` * to pull elements from an array by value. * * @static * @memberOf _ * @since 2.0.0 * @category Array * @param {Array} array The array to modify. * @param {Function} [predicate=_.identity] The function invoked per iteration. * @returns {Array} Returns the new array of removed elements. * @example * * var array = [1, 2, 3, 4]; * var evens = _.remove(array, function(n) { *   return n % 2 == 0; * }); * * console.log(array); * // => [1, 3] * * console.log(evens); * // => [2, 4] */function remove(array, predicate) {  var result = [];  if (!(array && array.length)) {    return result;  }  var index = -1,      indexes = [],      length = array.length;  predicate = baseIteratee(predicate, 3);  while (++index < length) {    var value = array[index];    if (predicate(value, index, array)) {      result.push(value);      indexes.push(index);    }  }  basePullAt(array, indexes);  return result;}module.exports = remove;
 |