aboutsummaryrefslogtreecommitdiff
path: root/src/filter.zig
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];
}