mirror of
https://github.com/denoland/std.git
synced 2024-11-21 20:50:22 +00:00
feat(collections/unstable): support Iterable argument in withoutAll()
(#6031)
This commit is contained in:
parent
d0a2982ab7
commit
aa928efcc1
@ -46,9 +46,10 @@
|
|||||||
"./take-last-while": "./take_last_while.ts",
|
"./take-last-while": "./take_last_while.ts",
|
||||||
"./take-while": "./take_while.ts",
|
"./take-while": "./take_while.ts",
|
||||||
"./union": "./union.ts",
|
"./union": "./union.ts",
|
||||||
|
"./unstable-chunk": "./unstable_chunk.ts",
|
||||||
"./unstable-sort-by": "./unstable_sort_by.ts",
|
"./unstable-sort-by": "./unstable_sort_by.ts",
|
||||||
"./unstable-take-while": "./unstable_take_while.ts",
|
"./unstable-take-while": "./unstable_take_while.ts",
|
||||||
"./unstable-chunk": "./unstable_chunk.ts",
|
"./unstable-without-all": "./unstable_without_all.ts",
|
||||||
"./unzip": "./unzip.ts",
|
"./unzip": "./unzip.ts",
|
||||||
"./without-all": "./without_all.ts",
|
"./without-all": "./without_all.ts",
|
||||||
"./zip": "./zip.ts"
|
"./zip": "./zip.ts"
|
||||||
|
41
collections/unstable_without_all.ts
Normal file
41
collections/unstable_without_all.ts
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
||||||
|
// This module is browser compatible.
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an array excluding all given values from an iterable.
|
||||||
|
*
|
||||||
|
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
||||||
|
*
|
||||||
|
* @typeParam T The type of the elements in the iterable.
|
||||||
|
*
|
||||||
|
* @param iterable The iterable to exclude values from.
|
||||||
|
* @param values The values to exclude from the iterable.
|
||||||
|
*
|
||||||
|
* @returns An array containing all elements from iterables except the
|
||||||
|
* ones that are in the values iterable.
|
||||||
|
*
|
||||||
|
* @remarks
|
||||||
|
* If both inputs are a {@linkcode Set}, and you want the difference as a
|
||||||
|
* {@linkcode Set}, you could use {@linkcode Set.prototype.difference} instead.
|
||||||
|
*
|
||||||
|
* @example Basic usage
|
||||||
|
* ```ts
|
||||||
|
* import { withoutAll } from "@std/collections/unstable-without-all";
|
||||||
|
* import { assertEquals } from "@std/assert";
|
||||||
|
*
|
||||||
|
* const withoutList = withoutAll([2, 1, 2, 3], [1, 2]);
|
||||||
|
*
|
||||||
|
* assertEquals(withoutList, [3]);
|
||||||
|
* ```
|
||||||
|
*/
|
||||||
|
export function withoutAll<T>(iterable: Iterable<T>, values: Iterable<T>): T[] {
|
||||||
|
const excludedSet = new Set(values);
|
||||||
|
const result: T[] = [];
|
||||||
|
for (const value of iterable) {
|
||||||
|
if (excludedSet.has(value)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
result.push(value);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
105
collections/unstable_without_all_test.ts
Normal file
105
collections/unstable_without_all_test.ts
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
||||||
|
|
||||||
|
import { assertEquals } from "@std/assert";
|
||||||
|
import { withoutAll } from "./unstable_without_all.ts";
|
||||||
|
|
||||||
|
function withoutAllTest<I>(
|
||||||
|
input: Array<I>,
|
||||||
|
excluded: Array<I>,
|
||||||
|
expected: Array<I>,
|
||||||
|
message?: string,
|
||||||
|
) {
|
||||||
|
const actual = withoutAll(input, excluded);
|
||||||
|
assertEquals(actual, expected, message);
|
||||||
|
}
|
||||||
|
|
||||||
|
Deno.test({
|
||||||
|
name: "(unstable) withoutAll() handles no mutation",
|
||||||
|
fn() {
|
||||||
|
const array = [1, 2, 3, 4];
|
||||||
|
withoutAll(array, [2, 3]);
|
||||||
|
assertEquals(array, [1, 2, 3, 4]);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test({
|
||||||
|
name: "(unstable) withoutAll() handles empty input",
|
||||||
|
fn() {
|
||||||
|
withoutAllTest([], [], []);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test({
|
||||||
|
name: "(unstable) withoutAll() handles no matches",
|
||||||
|
fn() {
|
||||||
|
withoutAllTest([1, 2, 3, 4], [0, 7, 9], [1, 2, 3, 4]);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test({
|
||||||
|
name: "(unstable) withoutAll() handles single match",
|
||||||
|
fn() {
|
||||||
|
withoutAllTest([1, 2, 3, 4], [1], [2, 3, 4]);
|
||||||
|
withoutAllTest([1, 2, 3, 2], [2], [1, 3]);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test({
|
||||||
|
name: "(unstable) withoutAll() handles multiple matches",
|
||||||
|
fn() {
|
||||||
|
withoutAllTest([1, 2, 3, 4, 6, 3], [1, 2], [3, 4, 6, 3]);
|
||||||
|
withoutAllTest([7, 2, 9, 8, 7, 6, 5, 7], [7, 9], [2, 8, 6, 5]);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test({
|
||||||
|
name: "(unstable) withoutAll() leaves duplicate elements",
|
||||||
|
fn() {
|
||||||
|
withoutAllTest(
|
||||||
|
Array.from({ length: 110 }, () => 3),
|
||||||
|
[1],
|
||||||
|
Array.from({ length: 110 }, () => 3),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test("(unstable) withoutAll() handles generators", () => {
|
||||||
|
function* genInput() {
|
||||||
|
yield 1;
|
||||||
|
yield 2;
|
||||||
|
yield 3;
|
||||||
|
yield 4;
|
||||||
|
}
|
||||||
|
function* genExcluded() {
|
||||||
|
yield 2;
|
||||||
|
yield 3;
|
||||||
|
}
|
||||||
|
const result = withoutAll(genInput(), genExcluded());
|
||||||
|
assertEquals(result, [1, 4]);
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test("(unstable) withoutAll() handles iterators", () => {
|
||||||
|
const input = new Set([1, 2, 3, 4]);
|
||||||
|
const excluded = new Set([2, 3]);
|
||||||
|
const result = withoutAll(input.values(), excluded.values());
|
||||||
|
assertEquals(result, [1, 4]);
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test("(unstable) withoutAll() handles a mix of inputs", () => {
|
||||||
|
const a = [1, 2, 3, 4];
|
||||||
|
const b = new Set([2, 3, 5]);
|
||||||
|
assertEquals(withoutAll(a, b), [1, 4], "Array and Set");
|
||||||
|
assertEquals(withoutAll(b, a), [5], "Set and Array");
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test("(unstable) withoutAll() handles allows excluded to be a superset of types", () => {
|
||||||
|
const a = [1, 2, 3, 4];
|
||||||
|
const b = [1, "other", 3, 4];
|
||||||
|
assertEquals(withoutAll(a, b), [2]);
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test("(unstable) withoutAll() works with sets", () => {
|
||||||
|
const a = new Set([1, 2, 3, 4]);
|
||||||
|
const b = new Set([2, 3]);
|
||||||
|
assertEquals(withoutAll(a, b), [1, 4]);
|
||||||
|
});
|
Loading…
Reference in New Issue
Block a user