mirror of
https://github.com/denoland/std.git
synced 2024-11-22 04:59:05 +00:00
d102a10235
* refactor: import from `@std/assert` * update
59 lines
1.5 KiB
TypeScript
59 lines
1.5 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
// This module is browser compatible.
|
|
|
|
/**
|
|
* Returns a tuple of two records with the first one containing all entries of
|
|
* the given record that match the given predicate and the second one containing
|
|
* all that do not.
|
|
*
|
|
* @typeParam T The type of the values in the record.
|
|
*
|
|
* @param record The record to partition.
|
|
* @param predicate The predicate function to determine which entries go where.
|
|
*
|
|
* @returns A tuple containing two records, the first one containing all entries
|
|
* that match the predicate and the second one containing all that do not.
|
|
*
|
|
* @example Basic usage
|
|
* ```ts
|
|
* import { partitionEntries } from "@std/collections/partition-entries";
|
|
* import { assertEquals } from "@std/assert";
|
|
*
|
|
* const menu = {
|
|
* Salad: 11,
|
|
* Soup: 8,
|
|
* Pasta: 13,
|
|
* };
|
|
* const myOptions = partitionEntries(
|
|
* menu,
|
|
* ([item, price]) => item !== "Pasta" && price < 10,
|
|
* );
|
|
*
|
|
* assertEquals(
|
|
* myOptions,
|
|
* [
|
|
* { Soup: 8 },
|
|
* { Salad: 11, Pasta: 13 },
|
|
* ],
|
|
* );
|
|
* ```
|
|
*/
|
|
export function partitionEntries<T>(
|
|
record: Readonly<Record<string, T>>,
|
|
predicate: (entry: [string, T]) => boolean,
|
|
): [match: Record<string, T>, rest: Record<string, T>] {
|
|
const match: Record<string, T> = {};
|
|
const rest: Record<string, T> = {};
|
|
const entries = Object.entries(record);
|
|
|
|
for (const [key, value] of entries) {
|
|
if (predicate([key, value])) {
|
|
match[key] = value;
|
|
} else {
|
|
rest[key] = value;
|
|
}
|
|
}
|
|
|
|
return [match, rest];
|
|
}
|