| var baseToString = require('./_baseToString'), | |
|     baseTrim = require('./_baseTrim'), | |
|     castSlice = require('./_castSlice'), | |
|     charsEndIndex = require('./_charsEndIndex'), | |
|     charsStartIndex = require('./_charsStartIndex'), | |
|     stringToArray = require('./_stringToArray'), | |
|     toString = require('./toString'); | |
| 
 | |
| /** | |
|  * Removes leading and trailing whitespace or specified characters from `string`. | |
|  * | |
|  * @static | |
|  * @memberOf _ | |
|  * @since 3.0.0 | |
|  * @category String | |
|  * @param {string} [string=''] The string to trim. | |
|  * @param {string} [chars=whitespace] The characters to trim. | |
|  * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. | |
|  * @returns {string} Returns the trimmed string. | |
|  * @example | |
|  * | |
|  * _.trim('  abc  '); | |
|  * // => 'abc' | |
|  * | |
|  * _.trim('-_-abc-_-', '_-'); | |
|  * // => 'abc' | |
|  * | |
|  * _.map(['  foo  ', '  bar  '], _.trim); | |
|  * // => ['foo', 'bar'] | |
|  */ | |
| function trim(string, chars, guard) { | |
|   string = toString(string); | |
|   if (string && (guard || chars === undefined)) { | |
|     return baseTrim(string); | |
|   } | |
|   if (!string || !(chars = baseToString(chars))) { | |
|     return string; | |
|   } | |
|   var strSymbols = stringToArray(string), | |
|       chrSymbols = stringToArray(chars), | |
|       start = charsStartIndex(strSymbols, chrSymbols), | |
|       end = charsEndIndex(strSymbols, chrSymbols) + 1; | |
| 
 | |
|   return castSlice(strSymbols, start, end).join(''); | |
| } | |
| 
 | |
| module.exports = trim;
 |