mirror of
https://github.com/ziglang/zig.git
synced 2025-12-24 23:23:07 +00:00
Fix ensureTotalCapacity calls that should be ensureUnusedCapacity calls
If these functions are called more than once, then the array list would no longer be guaranteed to have enough capacity during the appendAssumeCapacity calls. With ensureUnusedCapacity, they will always be guaranteed to have enough capacity regardless of how many times the function is called.
This commit is contained in:
parent
77eefebe65
commit
70ef9bc75c
@ -629,7 +629,7 @@ pub const DeclGen = struct {
|
||||
const params = decl.ty.fnParamLen();
|
||||
var i: usize = 0;
|
||||
|
||||
try self.args.ensureTotalCapacity(params);
|
||||
try self.args.ensureUnusedCapacity(params);
|
||||
while (i < params) : (i += 1) {
|
||||
const param_type_id = self.spv.types.get(decl.ty.fnParamType(i)).?;
|
||||
const arg_result_id = self.spv.allocResultId();
|
||||
|
||||
@ -180,7 +180,7 @@ pub fn parse(self: *Dylib, allocator: *Allocator, target: std.Target) !void {
|
||||
fn readLoadCommands(self: *Dylib, allocator: *Allocator, reader: anytype) !void {
|
||||
const should_lookup_reexports = self.header.?.flags & macho.MH_NO_REEXPORTED_DYLIBS == 0;
|
||||
|
||||
try self.load_commands.ensureTotalCapacity(allocator, self.header.?.ncmds);
|
||||
try self.load_commands.ensureUnusedCapacity(allocator, self.header.?.ncmds);
|
||||
|
||||
var i: u16 = 0;
|
||||
while (i < self.header.?.ncmds) : (i += 1) {
|
||||
|
||||
@ -267,7 +267,7 @@ pub fn readLoadCommands(self: *Object, allocator: *Allocator, reader: anytype) !
|
||||
const header = self.header orelse unreachable; // Unreachable here signifies a fatal unexplored condition.
|
||||
const offset = self.file_offset orelse 0;
|
||||
|
||||
try self.load_commands.ensureTotalCapacity(allocator, header.ncmds);
|
||||
try self.load_commands.ensureUnusedCapacity(allocator, header.ncmds);
|
||||
|
||||
var i: u16 = 0;
|
||||
while (i < header.ncmds) : (i += 1) {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user