update
This commit is contained in:
parent
d9becc67b6
commit
9308795b8b
964 changed files with 104265 additions and 16 deletions
49
node_modules/ramda/src/tryCatch.js
generated
vendored
Normal file
49
node_modules/ramda/src/tryCatch.js
generated
vendored
Normal file
|
@ -0,0 +1,49 @@
|
|||
var _arity =
|
||||
/*#__PURE__*/
|
||||
require("./internal/_arity");
|
||||
|
||||
var _concat =
|
||||
/*#__PURE__*/
|
||||
require("./internal/_concat");
|
||||
|
||||
var _curry2 =
|
||||
/*#__PURE__*/
|
||||
require("./internal/_curry2");
|
||||
/**
|
||||
* `tryCatch` takes two functions, a `tryer` and a `catcher`. The returned
|
||||
* function evaluates the `tryer`; if it does not throw, it simply returns the
|
||||
* result. If the `tryer` *does* throw, the returned function evaluates the
|
||||
* `catcher` function and returns its result. Note that for effective
|
||||
* composition with this function, both the `tryer` and `catcher` functions
|
||||
* must return the same type of results.
|
||||
*
|
||||
* @func
|
||||
* @memberOf R
|
||||
* @since v0.20.0
|
||||
* @category Function
|
||||
* @sig (...x -> a) -> ((e, ...x) -> a) -> (...x -> a)
|
||||
* @param {Function} tryer The function that may throw.
|
||||
* @param {Function} catcher The function that will be evaluated if `tryer` throws.
|
||||
* @return {Function} A new function that will catch exceptions and send then to the catcher.
|
||||
* @example
|
||||
*
|
||||
* R.tryCatch(R.prop('x'), R.F)({x: true}); //=> true
|
||||
* R.tryCatch(() => { throw 'foo'}, R.always('catched'))('bar') // => 'catched'
|
||||
* R.tryCatch(R.times(R.identity), R.always([]))('s') // => []
|
||||
* R.tryCatch(() => { throw 'this is not a valid value'}, (err, value)=>({error : err, value }))('bar') // => {'error': 'this is not a valid value', 'value': 'bar'}
|
||||
*/
|
||||
|
||||
|
||||
var tryCatch =
|
||||
/*#__PURE__*/
|
||||
_curry2(function _tryCatch(tryer, catcher) {
|
||||
return _arity(tryer.length, function () {
|
||||
try {
|
||||
return tryer.apply(this, arguments);
|
||||
} catch (e) {
|
||||
return catcher.apply(this, _concat([e], arguments));
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
module.exports = tryCatch;
|
Loading…
Add table
Add a link
Reference in a new issue