mirror of
https://github.com/swc-project/swc.git
synced 2024-12-23 05:32:09 +03:00
50 lines
1.4 KiB
TypeScript
50 lines
1.4 KiB
TypeScript
// Loaded from https://deno.land/x/ramda@v0.27.2/source/allPass.js
|
|
|
|
|
|
import _curry1 from './internal/_curry1.js';
|
|
import curryN from './curryN.js';
|
|
import max from './max.js';
|
|
import pluck from './pluck.js';
|
|
import reduce from './reduce.js';
|
|
|
|
|
|
/**
|
|
* Takes a list of predicates and returns a predicate that returns true for a
|
|
* given list of arguments if every one of the provided predicates is satisfied
|
|
* by those arguments.
|
|
*
|
|
* The function returned is a curried function whose arity matches that of the
|
|
* highest-arity predicate.
|
|
*
|
|
* @func
|
|
* @memberOf R
|
|
* @since v0.9.0
|
|
* @category Logic
|
|
* @sig [(*... -> Boolean)] -> (*... -> Boolean)
|
|
* @param {Array} predicates An array of predicates to check
|
|
* @return {Function} The combined predicate
|
|
* @see R.anyPass
|
|
* @example
|
|
*
|
|
* const isQueen = R.propEq('rank', 'Q');
|
|
* const isSpade = R.propEq('suit', '♠︎');
|
|
* const isQueenOfSpades = R.allPass([isQueen, isSpade]);
|
|
*
|
|
* isQueenOfSpades({rank: 'Q', suit: '♣︎'}); //=> false
|
|
* isQueenOfSpades({rank: 'Q', suit: '♠︎'}); //=> true
|
|
*/
|
|
var allPass = _curry1(function allPass(preds) {
|
|
return curryN(reduce(max, 0, pluck('length', preds)), function() {
|
|
var idx = 0;
|
|
var len = preds.length;
|
|
while (idx < len) {
|
|
if (!preds[idx].apply(this, arguments)) {
|
|
return false;
|
|
}
|
|
idx += 1;
|
|
}
|
|
return true;
|
|
});
|
|
});
|
|
export default allPass;
|