mirror of
https://github.com/ziglang/zig.git
synced 2026-02-18 23:39:17 +00:00
prevent by-length slice compile error in static json parsing
This commit is contained in:
parent
1748511058
commit
41d5aa1b36
@ -402,21 +402,33 @@ pub fn innerParse(
|
||||
},
|
||||
.partial_string_escaped_1 => |arr| {
|
||||
if (i + arr.len > r.len) return error.LengthMismatch;
|
||||
// tell the compiler that the by-length slice below is valid;
|
||||
// this assert is required for the inequality to be comptime-known
|
||||
if (arr.len > r.len) unreachable;
|
||||
@memcpy(r[i..][0..arr.len], arr[0..]);
|
||||
i += arr.len;
|
||||
},
|
||||
.partial_string_escaped_2 => |arr| {
|
||||
if (i + arr.len > r.len) return error.LengthMismatch;
|
||||
// tell the compiler that the by-length slice below is valid;
|
||||
// this assert is required for the inequality to be comptime-known
|
||||
if (arr.len > r.len) unreachable;
|
||||
@memcpy(r[i..][0..arr.len], arr[0..]);
|
||||
i += arr.len;
|
||||
},
|
||||
.partial_string_escaped_3 => |arr| {
|
||||
if (i + arr.len > r.len) return error.LengthMismatch;
|
||||
// tell the compiler that the by-length slice below is valid;
|
||||
// this assert is required for the inequality to be comptime-known
|
||||
if (arr.len > r.len) unreachable;
|
||||
@memcpy(r[i..][0..arr.len], arr[0..]);
|
||||
i += arr.len;
|
||||
},
|
||||
.partial_string_escaped_4 => |arr| {
|
||||
if (i + arr.len > r.len) return error.LengthMismatch;
|
||||
// tell the compiler that the by-length slice below is valid;
|
||||
// this assert is required for the inequality to be comptime-known
|
||||
if (arr.len > r.len) unreachable;
|
||||
@memcpy(r[i..][0..arr.len], arr[0..]);
|
||||
i += arr.len;
|
||||
},
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user