blob: 0417c793a88b22e7a2c36efe867a719e4273973d (
plain)
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
|
/**
* Copyright (c) 2013-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @providesModule minBy
* @flow
*/
var compareNumber = (a, b) => a - b;
/**
* Returns the minimum element as measured by a scoring function f. Returns the
* first such element if there are ties.
*/
function minBy<A, B>(as: Iterable<A>, f: (a: A) => B, compare?: ?(u: B, v: B) => number): ?A {
compare = compare || (compareNumber: any);
var minA = undefined;
var minB = undefined;
var seenFirst = false;
for (var a of as) {
var b = f(a);
if (!seenFirst || compare(b, (minB: any)) < 0) {
minA = a;
minB = b;
seenFirst = true;
}
}
return minA;
}
module.exports = minBy;
|