fix TestNamedStruct
This commit is contained in:
@@ -8,12 +8,12 @@ source_filename = "main"
|
|||||||
|
|
||||||
define void @"(*main.Foo).Print"(ptr %0) {
|
define void @"(*main.Foo).Print"(ptr %0) {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
%1 = getelementptr inbounds i1, ptr %0, i32 0, i32 1
|
%1 = getelementptr inbounds %main.Foo, ptr %0, i32 0, i32 1
|
||||||
%2 = load i1, ptr %1, align 1
|
%2 = load i1, ptr %1, align 1
|
||||||
br i1 %2, label %_llgo_1, label %_llgo_2
|
br i1 %2, label %_llgo_1, label %_llgo_2
|
||||||
|
|
||||||
_llgo_1: ; preds = %_llgo_0
|
_llgo_1: ; preds = %_llgo_0
|
||||||
%3 = getelementptr inbounds i32, ptr %0, i32 0, i32 0
|
%3 = getelementptr inbounds %main.Foo, ptr %0, i32 0, i32 0
|
||||||
%4 = load i32, ptr %3, align 4
|
%4 = load i32, ptr %3, align 4
|
||||||
call void (ptr, ...) @printf(ptr @main.format, i32 %4)
|
call void (ptr, ...) @printf(ptr @main.format, i32 %4)
|
||||||
br label %_llgo_2
|
br label %_llgo_2
|
||||||
@@ -49,8 +49,8 @@ define void @main() {
|
|||||||
_llgo_0:
|
_llgo_0:
|
||||||
call void @main.init()
|
call void @main.init()
|
||||||
%0 = alloca %main.Foo, align 8
|
%0 = alloca %main.Foo, align 8
|
||||||
%1 = getelementptr inbounds i32, ptr %0, i32 0, i32 0
|
%1 = getelementptr inbounds %main.Foo, ptr %0, i32 0, i32 0
|
||||||
%2 = getelementptr inbounds i1, ptr %0, i32 0, i32 1
|
%2 = getelementptr inbounds %main.Foo, ptr %0, i32 0, i32 1
|
||||||
store i32 100, ptr %1, align 4
|
store i32 100, ptr %1, align 4
|
||||||
store i1 true, ptr %2, align 1
|
store i1 true, ptr %2, align 1
|
||||||
call void @"(*main.Foo).Print"(ptr %0)
|
call void @"(*main.Foo).Print"(ptr %0)
|
||||||
|
|||||||
@@ -4,16 +4,16 @@ source_filename = "main"
|
|||||||
@main.format = global ptr null
|
@main.format = global ptr null
|
||||||
@"main.init$guard" = global ptr null
|
@"main.init$guard" = global ptr null
|
||||||
|
|
||||||
define i64 @"(T).Add"(i64 %0, i64 %1) {
|
define i64 @"(main.T).Add"(i64 %0, i64 %1) {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
%2 = add i64 %0, %1
|
%2 = add i64 %0, %1
|
||||||
ret i64 %2
|
ret i64 %2
|
||||||
}
|
}
|
||||||
|
|
||||||
define i64 @"(*T).Add"(ptr %0, i64 %1) {
|
define i64 @"(*main.T).Add"(ptr %0, i64 %1) {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
%2 = load i64, ptr %0, align 4
|
%2 = load i64, ptr %0, align 4
|
||||||
%3 = call i64 @"(T).Add"(i64 %2, i64 %1)
|
%3 = call i64 @"(main.T).Add"(i64 %2, i64 %1)
|
||||||
ret i64 %3
|
ret i64 %3
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -43,7 +43,7 @@ _llgo_2: ; preds = %_llgo_1, %_llgo_0
|
|||||||
define void @main() {
|
define void @main() {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
call void @main.init()
|
call void @main.init()
|
||||||
%0 = call i64 @"(T).Add"(i64 1, i64 2)
|
%0 = call i64 @"(main.T).Add"(i64 1, i64 2)
|
||||||
call void (ptr, ...) @printf(ptr @main.format, i64 %0)
|
call void (ptr, ...) @printf(ptr @main.format, i64 %0)
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ source_filename = "main"
|
|||||||
@main.format = global ptr null
|
@main.format = global ptr null
|
||||||
@"main.init$guard" = global ptr null
|
@"main.init$guard" = global ptr null
|
||||||
|
|
||||||
define void @"(*T).Print"(ptr %0, i64 %1) {
|
define void @"(*main.T).Print"(ptr %0, i64 %1) {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
call void (ptr, ...) @printf(ptr %0, i64 %1)
|
call void (ptr, ...) @printf(ptr %0, i64 %1)
|
||||||
ret void
|
ret void
|
||||||
@@ -36,7 +36,7 @@ _llgo_2: ; preds = %_llgo_1, %_llgo_0
|
|||||||
define void @main() {
|
define void @main() {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
call void @main.init()
|
call void @main.init()
|
||||||
call void @"(*T).Print"(ptr @main.format, i64 100)
|
call void @"(*main.T).Print"(ptr @main.format, i64 100)
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -307,7 +307,7 @@ func (b Builder) FieldAddr(x Expr, idx int) Expr {
|
|||||||
tstruc := prog.Elem(x.Type)
|
tstruc := prog.Elem(x.Type)
|
||||||
telem := prog.Field(tstruc, idx)
|
telem := prog.Field(tstruc, idx)
|
||||||
pt := prog.Pointer(telem)
|
pt := prog.Pointer(telem)
|
||||||
return Expr{llvm.CreateStructGEP(b.impl, telem.ll, x.impl, idx), pt}
|
return Expr{llvm.CreateStructGEP(b.impl, tstruc.ll, x.impl, idx), pt}
|
||||||
}
|
}
|
||||||
|
|
||||||
// The IndexAddr instruction yields the address of the element at
|
// The IndexAddr instruction yields the address of the element at
|
||||||
|
|||||||
@@ -88,9 +88,9 @@ func TestNamedStruct(t *testing.T) {
|
|||||||
assertPkg(t, pkg, `; ModuleID = 'foo/bar'
|
assertPkg(t, pkg, `; ModuleID = 'foo/bar'
|
||||||
source_filename = "foo/bar"
|
source_filename = "foo/bar"
|
||||||
|
|
||||||
%Empty = type {}
|
%bar.Empty = type {}
|
||||||
|
|
||||||
@a = external global %Empty
|
@a = external global %bar.Empty
|
||||||
`)
|
`)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user