blob: b9e21676d9b239401e8a67dd2c22e672f64eeee0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
const std = @import("std");
const typeVerify = @import("util.zig").typeVerify;
/// ```zig
/// (fn (fn (fn (a) bool, []a) []a)
/// ```
/// Filters a slice, only keeping items give `true` when passed into `func`
/// Type signature: `(a -> bool) -> [a] -> [a]`
/// `func` is of type `a -> bool`, where `items` is of type `[a]`
pub fn filter(
func: anytype,
items: []typeVerify(@TypeOf(func), .{ .@"fn" }).@"fn".params[0].type.?,
) []typeVerify(@TypeOf(func), .{ .@"fn" }).@"fn".params[0].type.? {
var output = items;
var i: u32 = 0;
for (items) |it|
if (func(it)) {
output[i] = it;
i = i + 1;
};
return output[0..i];
}
|