aboutsummaryrefslogtreecommitdiff
path: root/test/codegen
diff options
context:
space:
mode:
Diffstat (limited to 'test/codegen')
-rw-r--r--test/codegen/ifaces.go14
-rw-r--r--test/codegen/switch.go9
2 files changed, 19 insertions, 4 deletions
diff --git a/test/codegen/ifaces.go b/test/codegen/ifaces.go
index d773845e8e..2be3fa5146 100644
--- a/test/codegen/ifaces.go
+++ b/test/codegen/ifaces.go
@@ -6,16 +6,22 @@
package codegen
-type I interface { M() }
+type I interface{ M() }
func NopConvertIface(x I) I {
- // amd64:-`.*runtime.convI2I`
+ // amd64:-`.*runtime.convI2I`
return I(x)
}
func NopConvertGeneric[T any](x T) T {
- // amd64:-`.*runtime.convI2I`
- return T(x)
+ // amd64:-`.*runtime.convI2I`
+ return T(x)
}
var NopConvertGenericIface = NopConvertGeneric[I]
+
+func ConvToM(x any) I {
+ // amd64:`CALL\truntime.typeAssert`,`MOVL\t16\(.*\)`,`MOVQ\t8\(.*\)(.*\*1)`
+ // arm64:`CALL\truntime.typeAssert`,`LDAR`,`MOVWU`,`MOVD\t\(R.*\)\(R.*\)`
+ return x.(I)
+}
diff --git a/test/codegen/switch.go b/test/codegen/switch.go
index 6778c65ab3..b0186ba5b7 100644
--- a/test/codegen/switch.go
+++ b/test/codegen/switch.go
@@ -139,3 +139,12 @@ func interfaceSwitch(x any) int {
return 3
}
}
+
+func interfaceCast(x any) int {
+ // amd64:`CALL\truntime.typeAssert`,`MOVL\t16\(.*\)`,`MOVQ\t8\(.*\)(.*\*1)`
+ // arm64:`CALL\truntime.typeAssert`,`LDAR`,`MOVWU`,`MOVD\t\(R.*\)\(R.*\)`
+ if _, ok := x.(I); ok {
+ return 3
+ }
+ return 5
+}