@@ -51,3 +51,35 @@ subroutine only_command(command)
51
51
! CHECK-NEXT: return
52
52
! CHECK-NEXT: }
53
53
end subroutine only_command
54
+
55
+ ! CHECK-LABEL: func.func @_QPas_function(
56
+ ! CHECK-SAME: %[[commandArg:.*]]: !fir.boxchar<1> {fir.bindc_name = "command"}
57
+ subroutine as_function (command )
58
+ CHARACTER (* ) :: command
59
+ INTEGER :: exitstat
60
+ exitstat = system(command)
61
+ end subroutine
62
+ ! CHECK-NEXT: %[[cmdstatVal:.*]] = fir.alloca i16
63
+ ! CHECK-NEXT: %[[RETVAL:.*]] = fir.alloca i32
64
+ ! CHECK-NEXT: %[[DSCOPE:.*]] = fir.dummy_scope : !fir.dscope
65
+ ! CHECK-NEXT: %[[commandUnbox:.*]]:2 = fir.unboxchar %[[commandArg]] : (!fir.boxchar<1>) -> (!fir.ref<!fir.char<1,?>>, index)
66
+ ! CHECK-NEXT: %[[commandDeclare:.*]]:2 = hlfir.declare %[[commandUnbox]]#0 typeparams %[[commandUnbox]]#1 dummy_scope %[[DSCOPE]] {uniq_name = "_QFas_functionEcommand"} : (!fir.ref<!fir.char<1,?>>, index, !fir.dscope) -> (!fir.boxchar<1>, !fir.ref<!fir.char<1,?>>)
67
+ ! CHECK-NEXT: %[[EXITSTAT_ALLOC:.*]] = fir.alloca i32
68
+ ! CHECK-NEXT: %[[exitstatDeclare:.*]]:2 = hlfir.declare %[[EXITSTAT_ALLOC]] {uniq_name = "_QFas_functionEexitstat"} : (!fir.ref<i32>) -> (!fir.ref<i32>, !fir.ref<i32>)
69
+ ! CHECK-NEXT: %[[commandBox:.*]] = fir.embox %[[commandDeclare]]#1 typeparams %[[commandUnbox]]#1 : (!fir.ref<!fir.char<1,?>>, index) -> !fir.box<!fir.char<1,?>>
70
+ ! CHECK-NEXT: %[[exitstatBox:.*]] = fir.embox %[[RETVAL]] : (!fir.ref<i32>) -> !fir.box<i32>
71
+ ! CHECK-NEXT: %[[true:.*]] = arith.constant true
72
+ ! CHECK-NEXT: %[[c0_i16:.*]] = arith.constant 0 : i16
73
+ ! CHECK-NEXT: fir.store %[[c0_i16]] to %[[cmdstatVal]] : !fir.ref<i16>
74
+ ! CHECK-NEXT: %[[cmdstatBox:.*]] = fir.embox %[[cmdstatVal]] : (!fir.ref<i16>) -> !fir.box<i16>
75
+ ! CHECK-NEXT: %[[absentBox:.*]] = fir.absent !fir.box<none>
76
+ ! CHECK: %[[LINE_NO:.*]] = arith.constant {{.*}} : i32
77
+ ! CHECK-NEXT: %[[command:.*]] = fir.convert %[[commandBox]] : (!fir.box<!fir.char<1,?>>) -> !fir.box<none>
78
+ ! CHECK-NEXT: %[[exitstat:.*]] = fir.convert %[[exitstatBox]] : (!fir.box<i32>) -> !fir.box<none>
79
+ ! CHECK-NEXT: %[[cmdstat:.*]] = fir.convert %[[cmdstatBox]] : (!fir.box<i16>) -> !fir.box<none>
80
+ ! CHECK: %[[VAL_13:.*]] = fir.call @_FortranAExecuteCommandLine(%[[command]], %[[true]], %[[exitstat]], %[[cmdstat]], %[[absentBox]], %[[VAL_12:.*]], %[[LINE_NO]]) fastmath<contract> : (!fir.box<none>, i1, !fir.box<none>, !fir.box<none>, !fir.box<none>, !fir.ref<i8>, i32) -> none
81
+ ! CHECK-NEXT: %[[RET_ADDR:.*]] = fir.box_addr %[[exitstatBox]] : (!fir.box<i32>) -> !fir.ref<i32>
82
+ ! CHECK-NEXT: %[[RET:.*]] = fir.load %[[RET_ADDR]] : !fir.ref<i32>
83
+ ! CHECK-NEXT: hlfir.assign %[[RET]] to %[[exitstatDeclare]]#0 : i32, !fir.ref<i32>
84
+ ! CHECK-NEXT: return
85
+ ! CHECK-NEXT: }
0 commit comments