|
|
@@ -16,7 +16,7 @@ fn Foo(n: i32) -> (i32, f64) {
|
|
|
// CHECK:STDOUT: sem_ir:
|
|
|
// CHECK:STDOUT: - cross_reference_irs_size: 1
|
|
|
// CHECK:STDOUT: functions: [
|
|
|
-// CHECK:STDOUT: {name: str0, param_refs: block1, return_type: type3, return_slot: node+6, body: [block4]},
|
|
|
+// CHECK:STDOUT: {name: str0, param_refs: block1, return_type: type3, return_slot: node+4, body: [block4]},
|
|
|
// CHECK:STDOUT: ]
|
|
|
// CHECK:STDOUT: integer_literals: [
|
|
|
// CHECK:STDOUT: 2,
|
|
|
@@ -33,9 +33,9 @@ fn Foo(n: i32) -> (i32, f64) {
|
|
|
// CHECK:STDOUT: ]
|
|
|
// CHECK:STDOUT: types: [
|
|
|
// CHECK:STDOUT: nodeIntegerType,
|
|
|
-// CHECK:STDOUT: node+3,
|
|
|
+// CHECK:STDOUT: node+1,
|
|
|
// CHECK:STDOUT: nodeFloatingPointType,
|
|
|
-// CHECK:STDOUT: node+5,
|
|
|
+// CHECK:STDOUT: node+3,
|
|
|
// CHECK:STDOUT: ]
|
|
|
// CHECK:STDOUT: type_blocks: [
|
|
|
// CHECK:STDOUT: [
|
|
|
@@ -49,27 +49,23 @@ fn Foo(n: i32) -> (i32, f64) {
|
|
|
// CHECK:STDOUT: ]
|
|
|
// CHECK:STDOUT: nodes: [
|
|
|
// CHECK:STDOUT: {kind: Parameter, arg0: str1, type: type0},
|
|
|
-// CHECK:STDOUT: {kind: StubReference, arg0: nodeIntegerType, type: typeTypeType},
|
|
|
-// CHECK:STDOUT: {kind: StubReference, arg0: nodeFloatingPointType, type: typeTypeType},
|
|
|
// CHECK:STDOUT: {kind: TupleType, arg0: typeBlock0, type: typeTypeType},
|
|
|
// CHECK:STDOUT: {kind: TupleLiteral, arg0: block2, type: type1},
|
|
|
// CHECK:STDOUT: {kind: TupleType, arg0: typeBlock1, type: typeTypeType},
|
|
|
// CHECK:STDOUT: {kind: VarStorage, arg0: str2, type: type3},
|
|
|
// CHECK:STDOUT: {kind: FunctionDeclaration, arg0: function0},
|
|
|
// CHECK:STDOUT: {kind: IntegerLiteral, arg0: int0, type: type0},
|
|
|
-// CHECK:STDOUT: {kind: BinaryOperatorAdd, arg0: node+0, arg1: node+8, type: type0},
|
|
|
-// CHECK:STDOUT: {kind: StubReference, arg0: node+9, type: type0},
|
|
|
+// CHECK:STDOUT: {kind: BinaryOperatorAdd, arg0: node+0, arg1: node+6, type: type0},
|
|
|
// CHECK:STDOUT: {kind: RealLiteral, arg0: real0, type: type2},
|
|
|
-// CHECK:STDOUT: {kind: StubReference, arg0: node+11, type: type2},
|
|
|
// CHECK:STDOUT: {kind: TupleLiteral, arg0: block5, type: type3},
|
|
|
// CHECK:STDOUT: {kind: IntegerLiteral, arg0: int1, type: type0},
|
|
|
-// CHECK:STDOUT: {kind: TupleIndex, arg0: node+6, arg1: node+14, type: type0},
|
|
|
-// CHECK:STDOUT: {kind: InitializeFrom, arg0: node+10, arg1: node+15, type: type0},
|
|
|
+// CHECK:STDOUT: {kind: TupleIndex, arg0: node+4, arg1: node+10, type: type0},
|
|
|
+// CHECK:STDOUT: {kind: InitializeFrom, arg0: node+7, arg1: node+11, type: type0},
|
|
|
// CHECK:STDOUT: {kind: IntegerLiteral, arg0: int2, type: type0},
|
|
|
-// CHECK:STDOUT: {kind: TupleIndex, arg0: node+6, arg1: node+17, type: type2},
|
|
|
-// CHECK:STDOUT: {kind: InitializeFrom, arg0: node+12, arg1: node+18, type: type2},
|
|
|
-// CHECK:STDOUT: {kind: TupleInit, arg0: node+13, arg1: block6, type: type3},
|
|
|
-// CHECK:STDOUT: {kind: ReturnExpression, arg0: node+20},
|
|
|
+// CHECK:STDOUT: {kind: TupleIndex, arg0: node+4, arg1: node+13, type: type2},
|
|
|
+// CHECK:STDOUT: {kind: InitializeFrom, arg0: node+8, arg1: node+14, type: type2},
|
|
|
+// CHECK:STDOUT: {kind: TupleInit, arg0: node+9, arg1: block6, type: type3},
|
|
|
+// CHECK:STDOUT: {kind: ReturnExpression, arg0: node+16},
|
|
|
// CHECK:STDOUT: ]
|
|
|
// CHECK:STDOUT: node_blocks: [
|
|
|
// CHECK:STDOUT: [
|
|
|
@@ -78,8 +74,8 @@ fn Foo(n: i32) -> (i32, f64) {
|
|
|
// CHECK:STDOUT: node+0,
|
|
|
// CHECK:STDOUT: ],
|
|
|
// CHECK:STDOUT: [
|
|
|
-// CHECK:STDOUT: node+1,
|
|
|
-// CHECK:STDOUT: node+2,
|
|
|
+// CHECK:STDOUT: nodeIntegerType,
|
|
|
+// CHECK:STDOUT: nodeFloatingPointType,
|
|
|
// CHECK:STDOUT: ],
|
|
|
// CHECK:STDOUT: [
|
|
|
// CHECK:STDOUT: node+0,
|
|
|
@@ -87,10 +83,10 @@ fn Foo(n: i32) -> (i32, f64) {
|
|
|
// CHECK:STDOUT: node+2,
|
|
|
// CHECK:STDOUT: node+3,
|
|
|
// CHECK:STDOUT: node+4,
|
|
|
-// CHECK:STDOUT: node+5,
|
|
|
-// CHECK:STDOUT: node+6,
|
|
|
// CHECK:STDOUT: ],
|
|
|
// CHECK:STDOUT: [
|
|
|
+// CHECK:STDOUT: node+6,
|
|
|
+// CHECK:STDOUT: node+7,
|
|
|
// CHECK:STDOUT: node+8,
|
|
|
// CHECK:STDOUT: node+9,
|
|
|
// CHECK:STDOUT: node+10,
|
|
|
@@ -101,21 +97,17 @@ fn Foo(n: i32) -> (i32, f64) {
|
|
|
// CHECK:STDOUT: node+15,
|
|
|
// CHECK:STDOUT: node+16,
|
|
|
// CHECK:STDOUT: node+17,
|
|
|
-// CHECK:STDOUT: node+18,
|
|
|
-// CHECK:STDOUT: node+19,
|
|
|
-// CHECK:STDOUT: node+20,
|
|
|
-// CHECK:STDOUT: node+21,
|
|
|
// CHECK:STDOUT: ],
|
|
|
// CHECK:STDOUT: [
|
|
|
-// CHECK:STDOUT: node+10,
|
|
|
-// CHECK:STDOUT: node+12,
|
|
|
+// CHECK:STDOUT: node+7,
|
|
|
+// CHECK:STDOUT: node+8,
|
|
|
// CHECK:STDOUT: ],
|
|
|
// CHECK:STDOUT: [
|
|
|
-// CHECK:STDOUT: node+16,
|
|
|
-// CHECK:STDOUT: node+19,
|
|
|
+// CHECK:STDOUT: node+12,
|
|
|
+// CHECK:STDOUT: node+15,
|
|
|
// CHECK:STDOUT: ],
|
|
|
// CHECK:STDOUT: [
|
|
|
-// CHECK:STDOUT: node+7,
|
|
|
+// CHECK:STDOUT: node+5,
|
|
|
// CHECK:STDOUT: ],
|
|
|
// CHECK:STDOUT: ]
|
|
|
// CHECK:STDOUT:
|
|
|
@@ -126,17 +118,15 @@ fn Foo(n: i32) -> (i32, f64) {
|
|
|
// CHECK:STDOUT: fn @Foo(%n: i32) -> %return: (i32, f64) {
|
|
|
// CHECK:STDOUT: !entry:
|
|
|
// CHECK:STDOUT: %.loc12_15: i32 = int_literal 2
|
|
|
-// CHECK:STDOUT: %.loc12_13.1: i32 = add %n, %.loc12_15
|
|
|
-// CHECK:STDOUT: %.loc12_13.2: i32 = stub_reference %.loc12_13.1
|
|
|
-// CHECK:STDOUT: %.loc12_18.1: f64 = real_literal 34e-1
|
|
|
-// CHECK:STDOUT: %.loc12_18.2: f64 = stub_reference %.loc12_18.1
|
|
|
-// CHECK:STDOUT: %.loc12_21: (i32, f64) = tuple_literal (%.loc12_13.2, %.loc12_18.2)
|
|
|
+// CHECK:STDOUT: %.loc12_13: i32 = add %n, %.loc12_15
|
|
|
+// CHECK:STDOUT: %.loc12_18: f64 = real_literal 34e-1
|
|
|
+// CHECK:STDOUT: %.loc12_21: (i32, f64) = tuple_literal (%.loc12_13, %.loc12_18)
|
|
|
// CHECK:STDOUT: %.loc12_22.1: i32 = int_literal 0
|
|
|
// CHECK:STDOUT: %.loc12_22.2: ref i32 = tuple_index %return, %.loc12_22.1
|
|
|
-// CHECK:STDOUT: %.loc12_22.3: init i32 = initialize_from %.loc12_13.2 to %.loc12_22.2
|
|
|
+// CHECK:STDOUT: %.loc12_22.3: init i32 = initialize_from %.loc12_13 to %.loc12_22.2
|
|
|
// CHECK:STDOUT: %.loc12_22.4: i32 = int_literal 1
|
|
|
// CHECK:STDOUT: %.loc12_22.5: ref f64 = tuple_index %return, %.loc12_22.4
|
|
|
-// CHECK:STDOUT: %.loc12_22.6: init f64 = initialize_from %.loc12_18.2 to %.loc12_22.5
|
|
|
+// CHECK:STDOUT: %.loc12_22.6: init f64 = initialize_from %.loc12_18 to %.loc12_22.5
|
|
|
// CHECK:STDOUT: %.loc12_22.7: init (i32, f64) = tuple_init %.loc12_21, (%.loc12_22.3, %.loc12_22.6)
|
|
|
// CHECK:STDOUT: return %.loc12_22.7
|
|
|
// CHECK:STDOUT: }
|