| 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;
 |