zig

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

commit b2895f356fa6203d0f3f1476c4e8fb9cf5b6d860 (tree)
parent e6396025696abdce5ac9d6d683954df8dc7fdae6
Author: Mateusz Poliwczak <mpoliwczak34@gmail.com>
Date:   Thu,  6 Nov 2025 07:52:01 +0100

std.ArrayList: actaully memset to undefined in shrinkRetainingCapacity and clearRetainingCapacity

See #25810

Diffstat:
Mlib/std/array_list.zig | 7+++++--
1 file changed, 5 insertions(+), 2 deletions(-)

diff --git a/lib/std/array_list.zig b/lib/std/array_list.zig @@ -380,15 +380,15 @@ pub fn AlignedManaged(comptime T: type, comptime alignment: ?mem.Alignment) type /// Asserts that the new length is less than or equal to the previous length. pub fn shrinkRetainingCapacity(self: *Self, new_len: usize) void { assert(new_len <= self.items.len); - self.items.len = new_len; @memset(self.items[new_len..], undefined); + self.items.len = new_len; } /// Reduce length to 0. /// Invalidates all element pointers. pub fn clearRetainingCapacity(self: *Self) void { - self.items.len = 0; @memset(self.items, undefined); + self.items.len = 0; } /// Invalidates all element pointers. @@ -1141,11 +1141,14 @@ pub fn Aligned(comptime T: type, comptime alignment: ?mem.Alignment) type { /// Asserts that the new length is less than or equal to the previous length. pub fn shrinkRetainingCapacity(self: *Self, new_len: usize) void { assert(new_len <= self.items.len); + @memset(self.items[new_len..], undefined); self.items.len = new_len; } + /// Reduce length to 0. /// Invalidates all element pointers. pub fn clearRetainingCapacity(self: *Self) void { + @memset(self.items, undefined); self.items.len = 0; }