zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 9d0872a625f511cee0628c92e5d4a0797641ad24 (tree)
parent acd0dabab29e2e771e65919366fa8914d97f6e60
Author: Andrew Kelley <andrew@ziglang.org>
Date:   Fri, 31 Jul 2020 01:16:17 -0700

std.ArrayList: add appendNTimesAssumeCapacity

Diffstat:
Mlib/std/array_list.zig | 18++++++++++++++++++
1 file changed, 18 insertions(+), 0 deletions(-)

diff --git a/lib/std/array_list.zig b/lib/std/array_list.zig @@ -216,6 +216,15 @@ pub fn ArrayListAligned(comptime T: type, comptime alignment: ?u29) type { mem.set(T, self.items[old_len..self.items.len], value); } + /// Append a value to the list `n` times. + /// Asserts the capacity is enough. + pub fn appendNTimesAssumeCapacity(self: *Self, value: T, n: usize) void { + const new_len = self.items.len + n; + assert(new_len <= self.capacity); + mem.set(T, self.items.ptr[self.items.len..new_len], value); + self.items.len = new_len; + } + /// Adjust the list's length to `new_len`. /// Does not initialize added items if any. pub fn resize(self: *Self, new_len: usize) !void { @@ -473,6 +482,15 @@ pub fn ArrayListAlignedUnmanaged(comptime T: type, comptime alignment: ?u29) typ mem.set(T, self.items[old_len..self.items.len], value); } + /// Append a value to the list `n` times. + /// Asserts the capacity is enough. + pub fn appendNTimesAssumeCapacity(self: *Self, value: T, n: usize) void { + const new_len = self.items.len + n; + assert(new_len <= self.capacity); + mem.set(T, self.items.ptr[self.items.len..new_len], value); + self.items.len = new_len; + } + /// Adjust the list's length to `new_len`. /// Does not initialize added items if any. pub fn resize(self: *Self, allocator: *Allocator, new_len: usize) !void {