| var baseSlice = require('./_baseSlice'), | 
|     isIterateeCall = require('./_isIterateeCall'), | 
|     toInteger = require('./toInteger'); | 
|   | 
| /* Built-in method references for those with the same name as other `lodash` methods. */ | 
| var nativeCeil = Math.ceil, | 
|     nativeMax = Math.max; | 
|   | 
| /** | 
|  * Creates an array of elements split into groups the length of `size`. | 
|  * If `array` can't be split evenly, the final chunk will be the remaining | 
|  * elements. | 
|  * | 
|  * @static | 
|  * @memberOf _ | 
|  * @since 3.0.0 | 
|  * @category Array | 
|  * @param {Array} array The array to process. | 
|  * @param {number} [size=1] The length of each chunk | 
|  * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. | 
|  * @returns {Array} Returns the new array of chunks. | 
|  * @example | 
|  * | 
|  * _.chunk(['a', 'b', 'c', 'd'], 2); | 
|  * // => [['a', 'b'], ['c', 'd']] | 
|  * | 
|  * _.chunk(['a', 'b', 'c', 'd'], 3); | 
|  * // => [['a', 'b', 'c'], ['d']] | 
|  */ | 
| function chunk(array, size, guard) { | 
|   if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) { | 
|     size = 1; | 
|   } else { | 
|     size = nativeMax(toInteger(size), 0); | 
|   } | 
|   var length = array == null ? 0 : array.length; | 
|   if (!length || size < 1) { | 
|     return []; | 
|   } | 
|   var index = 0, | 
|       resIndex = 0, | 
|       result = Array(nativeCeil(length / size)); | 
|   | 
|   while (index < length) { | 
|     result[resIndex++] = baseSlice(array, index, (index += size)); | 
|   } | 
|   return result; | 
| } | 
|   | 
| module.exports = chunk; |