diff options
Diffstat (limited to 'node_modules/fbjs/lib/countDistinct.js.flow')
-rw-r--r-- | node_modules/fbjs/lib/countDistinct.js.flow | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/node_modules/fbjs/lib/countDistinct.js.flow b/node_modules/fbjs/lib/countDistinct.js.flow new file mode 100644 index 000000000..9fd9ca490 --- /dev/null +++ b/node_modules/fbjs/lib/countDistinct.js.flow @@ -0,0 +1,33 @@ +/** + * Copyright (c) 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + * @providesModule countDistinct + * @flow + */ + +'use strict'; + +var Set = require('./Set'); + +var emptyFunction = require('./emptyFunction'); + +/** + * Returns the count of distinct elements selected from an array. + */ +function countDistinct<T1, T2>(iter: Iterable<T1>, selector: (item: T1) => T2): number { + selector = selector || emptyFunction.thatReturnsArgument; + + var set = new Set(); + for (var val of iter) { + set.add(selector(val)); + } + + return set.size; +} + +module.exports = countDistinct;
\ No newline at end of file |