1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
| var createWrap = require('./_createWrap');
|
| /** Used to compose bitmasks for function metadata. */
| var WRAP_CURRY_RIGHT_FLAG = 16;
|
| /**
| * This method is like `_.curry` except that arguments are applied to `func`
| * in the manner of `_.partialRight` instead of `_.partial`.
| *
| * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic
| * builds, may be used as a placeholder for provided arguments.
| *
| * **Note:** This method doesn't set the "length" property of curried functions.
| *
| * @static
| * @memberOf _
| * @since 3.0.0
| * @category Function
| * @param {Function} func The function to curry.
| * @param {number} [arity=func.length] The arity of `func`.
| * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
| * @returns {Function} Returns the new curried function.
| * @example
| *
| * var abc = function(a, b, c) {
| * return [a, b, c];
| * };
| *
| * var curried = _.curryRight(abc);
| *
| * curried(3)(2)(1);
| * // => [1, 2, 3]
| *
| * curried(2, 3)(1);
| * // => [1, 2, 3]
| *
| * curried(1, 2, 3);
| * // => [1, 2, 3]
| *
| * // Curried with placeholders.
| * curried(3)(1, _)(2);
| * // => [1, 2, 3]
| */
| function curryRight(func, arity, guard) {
| arity = guard ? undefined : arity;
| var result = createWrap(func, WRAP_CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity);
| result.placeholder = curryRight.placeholder;
| return result;
| }
|
| // Assign default placeholders.
| curryRight.placeholder = {};
|
| module.exports = curryRight;
|
|