mirror of
https://github.com/c3lang/c3c.git
synced 2026-02-27 12:01:16 +00:00
47 lines
1.7 KiB
Plaintext
47 lines
1.7 KiB
Plaintext
// #target: macos-x64
|
|
module test;
|
|
|
|
macro int test(int[2][2]* y)
|
|
{
|
|
$typeof(*y) z = *y;
|
|
return z[1][1];
|
|
}
|
|
|
|
fn void main()
|
|
{
|
|
int[2][*] x = { { 2, 3}, { 5, 6 }};
|
|
int[<2>][*] y = { { 1, 3 }};
|
|
int[<2>][*] z = y;
|
|
int[<2>][1] w = z;
|
|
int[<2>][] aa = { { 1, 3 }};
|
|
int[][*] bb = { { 1, 3 } };
|
|
test(&x);
|
|
}
|
|
/* #expect: test.ll
|
|
|
|
%x = alloca [2 x [2 x i32]], align 16
|
|
%y = alloca [1 x <2 x i32>], align 4
|
|
%z = alloca [1 x <2 x i32>], align 4
|
|
%w = alloca [1 x <2 x i32>], align 4
|
|
%aa = alloca %"int[<2>][]", align 8
|
|
%literal = alloca [1 x <2 x i32>], align 4
|
|
%bb = alloca [1 x %"int[]"], align 16
|
|
%literal1 = alloca [2 x i32], align 4
|
|
%z2 = alloca [2 x [2 x i32]], align 16
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 16 %x, ptr align 16 @.__const, i32 16, i1 false)
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %y, ptr align 4 @.__const.1, i32 8, i1 false)
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %z, ptr align 4 %y, i32 8, i1 false)
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %w, ptr align 4 %z, i32 8, i1 false)
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %literal, ptr align 4 @.__const.2, i32 8, i1 false)
|
|
%0 = insertvalue %"int[<2>][]" undef, ptr %literal, 0
|
|
%1 = insertvalue %"int[<2>][]" %0, i64 1, 1
|
|
store %"int[<2>][]" %1, ptr %aa, align 8
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %literal1, ptr align 4 @.__const.3, i32 8, i1 false)
|
|
%2 = insertvalue %"int[]" undef, ptr %literal1, 0
|
|
%3 = insertvalue %"int[]" %2, i64 2, 1
|
|
store %"int[]" %3, ptr %bb, align 16
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 16 %z2, ptr align 4 %x, i32 16, i1 false)
|
|
%ptradd = getelementptr inbounds i8, ptr %z2, i64 8
|
|
%ptradd3 = getelementptr inbounds i8, ptr %ptradd, i64 4
|
|
ret void
|