Garden is a JavaScript library providing support for functional programming in JavaScript.
square = partial Math.pow, _, 2
assert (square 3) == 9
npm i @pandastrike/garden
You can get an idea of what we're planning by looking at the issues list. If you want something that isn't there, and you think it would be a good addition, please open a ticket.
Returns the value of its argument. Useful when you need to pass a function that leaves a value unchaged.
Returns a function that returns the given value.
Given an arity (the number of arguments to a function) and a function, returns a function with the given arity that will invoke the given function. Useful in conjunction with curry
or partial
to allow partial application of a function that may have an unknown arity.
Equivalent to arity 1, f
.
Equivalent to arity 2, f
.
Equivalent to arity 3, f
.
Returns a function that can be curried: arguments may be bound to a function without invoking it, returning a new (curryable) function that takes the remaining arguments.
multiply = (x, y) → x * y
double = multiply 2
assert.equal 4, double 2
A constant that may be used with partial
to specificy which function arguments remain unbound.
Substitutes the values in the from
array for values in the to
array whose value is the constant _
.
assert.deepEqual [1, 2, 3],
substitute [1, _, 3], [2]
Returns a function that will merge the given arguments in ax
with those provided at invocation, based on the substitution constant _
. Similar to curry
, but allows you to provide arguments out of order.
square = partial Math.pow, _, 2
assert (square 3) == 9
Given a variadic function, returns a function that takes an array.
Given a function that takes an array, returns a variadic function.
Given a function, returns a function that takes the arguments in reverse.
square = (curry flip Math.pow)(2)
assert (square 3) == 9
Given an array of functions, returns the result of composing them such that they're invoked in the order given. Same as compose
but with the arguments reversed, so that it's easier to see the intent.
# jquery style combinators
query = (selector) → document.querySelectorAll selector
text = (elements) → elements.map property "textContent"
textFor = pipe [ query, text, first ]
# ex: textFor "h1"
Given an array of functions, returns the result of composing them. See pipe
.
Given a function transformation and an array of functions, returns the result of composing them after applying the transformation. Useful for specializing composition. See flow
for an example.
Given a function, returns a function that, if any of its arguments are promises, will wait for the promises to resolve before calling the given function with the resolved values, and returning a promise for the function's return value. Arguments that are not promises are simply passed to the function. Useful when composing synchronous and asynchronous functions.
Given an array of possibly asynchronous functions, returns the result of composing the functions, awaiting if necessary.
Equivalent to pipeWith wait
.
# gulp style combinators
flow [
glob "**/*.css", "src"
read
compile
write ".js", "build"
]
Given a function, returns a function that will always return its first argument, regardless of the return value of the given function.
Given a function, returns a function that will always return its last argument, regardless of the return value of the given function.
Given a predicate function, returns a function that negates the return value of the given function.
Given a function, returns a function that will ensure the given function is only called once.
Given a function taking a string, returns a function that will memoize the results of calling the given function.
Equivalent to f.call undefined, ax...
.
Equivalent to f.apply undefined, ax
.