Skip to content

Commit

Permalink
Make PackageManifest.Serializer.readArray more careful (#12106)
Browse files Browse the repository at this point in the history
  • Loading branch information
Jarred-Sumner authored Jun 25, 2024
1 parent ccd92a9 commit bb66bba
Showing 1 changed file with 10 additions and 6 deletions.
16 changes: 10 additions & 6 deletions src/install/npm.zig
Original file line number Diff line number Diff line change
Expand Up @@ -608,8 +608,8 @@ pub const PackageManifest = struct {
alignment: usize,
};
var data: [fields.len]Data = undefined;
for (fields, 0..) |field_info, i| {
data[i] = .{
for (fields, &data) |field_info, *dat| {
dat.* = .{
.size = @sizeOf(field_info.type),
.name = field_info.name,
.alignment = if (@sizeOf(field_info.type) == 0) 1 else field_info.alignment,
Expand All @@ -623,9 +623,9 @@ pub const PackageManifest = struct {
std.sort.pdq(Data, &data, {}, Sort.lessThan);
var sizes_bytes: [fields.len]usize = undefined;
var names: [fields.len][]const u8 = undefined;
for (data, 0..) |elem, i| {
sizes_bytes[i] = elem.size;
names[i] = elem.name;
for (data, &sizes_bytes, &names) |elem, *size_, *name_| {
size_.* = elem.size;
name_.* = elem.name;
}
break :blk .{
.bytes = sizes_bytes,
Expand Down Expand Up @@ -659,7 +659,11 @@ pub const PackageManifest = struct {
}

stream.pos += Aligner.skipAmount(Type, stream.pos);
const result_bytes = stream.buffer[stream.pos..][0..byte_len];
const remaining = stream.buffer[@min(stream.pos, stream.buffer.len)..];
if (remaining.len < byte_len) {
return error.BufferTooSmall;
}
const result_bytes = remaining[0..byte_len];
const result = @as([*]const Type, @ptrCast(@alignCast(result_bytes.ptr)))[0 .. result_bytes.len / @sizeOf(Type)];
stream.pos += result_bytes.len;
return result;
Expand Down

0 comments on commit bb66bba

Please sign in to comment.