You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							35 lines
						
					
					
						
							1.0 KiB
						
					
					
				
			
		
		
	
	
							35 lines
						
					
					
						
							1.0 KiB
						
					
					
				var asciiWords = require('./_asciiWords'), | 
						|
    hasUnicodeWord = require('./_hasUnicodeWord'), | 
						|
    toString = require('./toString'), | 
						|
    unicodeWords = require('./_unicodeWords'); | 
						|
 | 
						|
/** | 
						|
 * Splits `string` into an array of its words. | 
						|
 * | 
						|
 * @static | 
						|
 * @memberOf _ | 
						|
 * @since 3.0.0 | 
						|
 * @category String | 
						|
 * @param {string} [string=''] The string to inspect. | 
						|
 * @param {RegExp|string} [pattern] The pattern to match words. | 
						|
 * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. | 
						|
 * @returns {Array} Returns the words of `string`. | 
						|
 * @example | 
						|
 * | 
						|
 * _.words('fred, barney, & pebbles'); | 
						|
 * // => ['fred', 'barney', 'pebbles'] | 
						|
 * | 
						|
 * _.words('fred, barney, & pebbles', /[^, ]+/g); | 
						|
 * // => ['fred', 'barney', '&', 'pebbles'] | 
						|
 */ | 
						|
function words(string, pattern, guard) { | 
						|
  string = toString(string); | 
						|
  pattern = guard ? undefined : pattern; | 
						|
 | 
						|
  if (pattern === undefined) { | 
						|
    return hasUnicodeWord(string) ? unicodeWords(string) : asciiWords(string); | 
						|
  } | 
						|
  return string.match(pattern) || []; | 
						|
} | 
						|
 | 
						|
module.exports = words;
 | 
						|
 |