deno.land / std@0.224.0 / collections / max_of.ts
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.// This module is browser compatible.
/** * Applies the given selector to all elements of the provided collection and * returns the max value of all elements. If an empty array is provided the * function will return undefined * * @example * ```ts * import { maxOf } from "https://deno.land/std@$STD_VERSION/collections/max_of.ts"; * import { assertEquals } from "https://deno.land/std@$STD_VERSION/assert/assert_equals.ts"; * * const inventory = [ * { name: "mustard", count: 2 }, * { name: "soy", count: 4 }, * { name: "tomato", count: 32 }, * ]; * * const maxCount = maxOf(inventory, (i) => i.count); * * assertEquals(maxCount, 32); * ``` */export function maxOf<T>( array: Iterable<T>, selector: (el: T) => number,): number | undefined;/** * Applies the given selector to all elements of the provided collection and * returns the max value of all elements. If an empty array is provided the * function will return undefined * * @example * ```ts * import { maxOf } from "https://deno.land/std@$STD_VERSION/collections/max_of.ts"; * import { assertEquals } from "https://deno.land/std@$STD_VERSION/assert/assert_equals.ts"; * * const inventory = [ * { name: "mustard", count: 2n }, * { name: "soy", count: 4n }, * { name: "tomato", count: 32n }, * ]; * * const maxCount = maxOf(inventory, (i) => i.count); * * assertEquals(maxCount, 32n); * ``` */export function maxOf<T>( array: Iterable<T>, selector: (el: T) => bigint,): bigint | undefined;export function maxOf<T, S extends ((el: T) => number) | ((el: T) => bigint)>( array: Iterable<T>, selector: S,): ReturnType<S> | undefined { let maximumValue: ReturnType<S> | undefined = undefined;
for (const i of array) { const currentValue = selector(i) as ReturnType<S>;
if (maximumValue === undefined || currentValue > maximumValue) { maximumValue = currentValue; continue; }
if (Number.isNaN(currentValue)) { return currentValue; } }
return maximumValue;}
Version Info