| /** |
| * Lo-Dash 2.4.1 (Custom Build) <http://lodash.com/> |
| * Build: `lodash modularize underscore exports="node" -o ./underscore/` |
| * Copyright 2012-2013 The Dojo Foundation <http://dojofoundation.org/> |
| * Based on Underscore.js 1.5.2 <http://underscorejs.org/LICENSE> |
| * Copyright 2009-2013 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors |
| * Available under MIT license <http://lodash.com/license> |
| */ |
| var baseIndexOf = require('./baseIndexOf'); |
| |
| /** |
| * The base implementation of `_.uniq` without support for callback shorthands |
| * or `thisArg` binding. |
| * |
| * @private |
| * @param {Array} array The array to process. |
| * @param {boolean} [isSorted=false] A flag to indicate that `array` is sorted. |
| * @param {Function} [callback] The function called per iteration. |
| * @returns {Array} Returns a duplicate-value-free array. |
| */ |
| function baseUniq(array, isSorted, callback) { |
| var index = -1, |
| indexOf = baseIndexOf, |
| length = array ? array.length : 0, |
| result = [], |
| seen = callback ? [] : result; |
| |
| while (++index < length) { |
| var value = array[index], |
| computed = callback ? callback(value, index, array) : value; |
| |
| if (isSorted |
| ? !index || seen[seen.length - 1] !== computed |
| : indexOf(seen, computed) < 0 |
| ) { |
| if (callback) { |
| seen.push(computed); |
| } |
| result.push(value); |
| } |
| } |
| return result; |
| } |
| |
| module.exports = baseUniq; |