Skip to content

Commit bbea91e

Browse files
committed
Sema: use elemPtrOneLayerOnly in zirMemCpy
Closes #15633
1 parent f4c6134 commit bbea91e

File tree

2 files changed

+15
-2
lines changed

2 files changed

+15
-2
lines changed

src/Sema.zig

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -22138,7 +22138,7 @@ fn zirMemcpy(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!void
2213822138
const len = try sema.usizeCast(block, dest_src, len_u64);
2213922139
for (0..len) |i| {
2214022140
const elem_index = try sema.addIntUnsigned(Type.usize, i);
22141-
const dest_elem_ptr = try sema.elemPtr(
22141+
const dest_elem_ptr = try sema.elemPtrOneLayerOnly(
2214222142
block,
2214322143
src,
2214422144
dest_ptr,
@@ -22147,7 +22147,7 @@ fn zirMemcpy(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!void
2214722147
true, // init
2214822148
false, // oob_safety
2214922149
);
22150-
const src_elem_ptr = try sema.elemPtr(
22150+
const src_elem_ptr = try sema.elemPtrOneLayerOnly(
2215122151
block,
2215222152
src,
2215322153
src_ptr,

test/behavior/memcpy.zig

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,3 +65,16 @@ fn testMemcpyDestManyPtr() !void {
6565
try expect(buf[98] == 'l');
6666
try expect(buf[99] == 'o');
6767
}
68+
69+
comptime {
70+
const S = struct {
71+
buffer: [8]u8 = undefined,
72+
fn set(self: *@This(), items: []const u8) void {
73+
@memcpy(self.buffer[0..items.len], items);
74+
}
75+
};
76+
77+
var s = S{};
78+
s.set("hello");
79+
if (!std.mem.eql(u8, s.buffer[0..5], "hello")) @compileError("bad");
80+
}

0 commit comments

Comments
 (0)