31 lines
		
	
	
		
			871 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			31 lines
		
	
	
		
			871 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
|  | var castFunction = require('./_castFunction'), | ||
|  |     partial = require('./partial'); | ||
|  | 
 | ||
|  | /** | ||
|  |  * Creates a function that provides `value` to `wrapper` as its first | ||
|  |  * argument. Any additional arguments provided to the function are appended | ||
|  |  * to those provided to the `wrapper`. The wrapper is invoked with the `this` | ||
|  |  * binding of the created function. | ||
|  |  * | ||
|  |  * @static | ||
|  |  * @memberOf _ | ||
|  |  * @since 0.1.0 | ||
|  |  * @category Function | ||
|  |  * @param {*} value The value to wrap. | ||
|  |  * @param {Function} [wrapper=identity] The wrapper function. | ||
|  |  * @returns {Function} Returns the new function. | ||
|  |  * @example | ||
|  |  * | ||
|  |  * var p = _.wrap(_.escape, function(func, text) { | ||
|  |  *   return '<p>' + func(text) + '</p>'; | ||
|  |  * }); | ||
|  |  * | ||
|  |  * p('fred, barney, & pebbles'); | ||
|  |  * // => '<p>fred, barney, & pebbles</p>'
 | ||
|  |  */ | ||
|  | function wrap(value, wrapper) { | ||
|  |   return partial(castFunction(wrapper), value); | ||
|  | } | ||
|  | 
 | ||
|  | module.exports = wrap; |