mirror of
https://github.com/ziglang/zig.git
synced 2025-12-06 14:23:09 +00:00
Zcu: fix ZOIR cache bugs
* When saving bigint limbs, we gave the iovec the wrong length, meaning bigint data (and the following string and compile error data) was corrupted. * When updating a stale ZOIR cache, we failed to truncate the file, so just wrote more bytes onto the end of the stale cache.
This commit is contained in:
parent
f2c838d2cf
commit
4089134892
@ -2751,7 +2751,7 @@ pub fn saveZoirCache(cache_file: std.fs.File, stat: std.fs.File.Stat, zoir: Zoir
|
|||||||
},
|
},
|
||||||
.{
|
.{
|
||||||
.base = @ptrCast(zoir.limbs),
|
.base = @ptrCast(zoir.limbs),
|
||||||
.len = zoir.limbs.len * 4,
|
.len = zoir.limbs.len * @sizeOf(std.math.big.Limb),
|
||||||
},
|
},
|
||||||
.{
|
.{
|
||||||
.base = zoir.string_bytes.ptr,
|
.base = zoir.string_bytes.ptr,
|
||||||
|
|||||||
@ -234,6 +234,7 @@ pub fn updateFile(
|
|||||||
error.FileTooBig => unreachable, // 0 is not too big
|
error.FileTooBig => unreachable, // 0 is not too big
|
||||||
else => |e| return e,
|
else => |e| return e,
|
||||||
};
|
};
|
||||||
|
try cache_file.seekTo(0);
|
||||||
|
|
||||||
if (stat.size > std.math.maxInt(u32))
|
if (stat.size > std.math.maxInt(u32))
|
||||||
return error.FileTooBig;
|
return error.FileTooBig;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user