|
| 1 | +!RUN: %flang_fc1 -emit-hlfir %s -o - | FileCheck %s |
| 2 | + |
| 3 | +!CHECK-LABEL: func.func @_QPpath_only |
| 4 | +!CHECK-SAME: %[[dummyPath:.*]]: !fir.boxchar<1> {fir.bindc_name = "path"}) { |
| 5 | +subroutine path_only(path) |
| 6 | + CHARACTER(len=*) :: path |
| 7 | + !CHECK-DAG: %[[scope:.*]] = fir.dummy_scope : !fir.dscope |
| 8 | + !CHECK-DAG: %[[unbox_path:.*]]:2 = fir.unboxchar %[[dummyPath]] : (!fir.boxchar<1>) -> (!fir.ref<!fir.char<1,?>>, index) |
| 9 | + !CHECK-DAG: %[[path_decl:.*]]:2 = hlfir.declare %[[unbox_path]]#0 typeparams %[[unbox_path]]#1 dummy_scope %[[scope]] {uniq_name = "_QFpath_onlyEpath"} : (!fir.ref<!fir.char<1,?>>, index, !fir.dscope) -> (!fir.boxchar<1>, !fir.ref<!fir.char<1,?>>) |
| 10 | + !CHECK-DAG: %[[src_path_addr:.*]] = fir.address_of(@_{{.*}}) : !fir.ref<!fir.char<1,{{.*}}>> |
| 11 | + !CHECK-DAG: %[[line_value:.*]] = arith.constant {{.*}} : i64 |
| 12 | + !CHECK-DAG: %[[path:.*]] = fir.convert %[[path_decl]]#1 : (!fir.ref<!fir.char<1,?>>) -> !fir.ref<i8> |
| 13 | + !CHECK-DAG: %[[path_len:.*]] = fir.convert %[[unbox_path]]#1 : (index) -> i64 |
| 14 | + !CHECK-DAG: %[[src_path:.*]] = fir.convert %[[src_path_addr]] : (!fir.ref<!fir.char<1,{{.*}}>) -> !fir.ref<i8> |
| 15 | + !CHECK-DAG: %[[line:.*]] = fir.convert %[[line_value]] : (i64) -> i32 |
| 16 | + !CHECK: fir.call @_FortranAUnlink(%[[path]], %[[path_len]], %[[src_path]], %[[line]]) |
| 17 | + !CHECK-SAME: : (!fir.ref<i8>, i64, !fir.ref<i8>, i32) |
| 18 | + !CHECK-SAME: -> i32 |
| 19 | + call unlink(path) |
| 20 | + !CHECK: return |
| 21 | +end subroutine path_only |
| 22 | + !CHECK: } |
| 23 | + |
| 24 | + !CHECK-LABEL: func.func @_QPall_arguments |
| 25 | + !CHECK-SAME: %[[dummyPath:.*]]: !fir.boxchar<1> {fir.bindc_name = "path"} |
| 26 | + !CHECK-SAME: %[[dummyStat:.*]]: !fir.ref<i32> {fir.bindc_name = "status"} |
| 27 | + !CHECK-SAME: ) { |
| 28 | +subroutine all_arguments(path, status) |
| 29 | + CHARACTER(len=*) :: path |
| 30 | + INTEGER :: status |
| 31 | + !CHECK-DAG: %[[scope:.*]] = fir.dummy_scope : !fir.dscope |
| 32 | + !CHECK-DAG: %[[unbox_path:.*]]:2 = fir.unboxchar %[[dummyPath]] : (!fir.boxchar<1>) -> (!fir.ref<!fir.char<1,?>>, index) |
| 33 | + !CHECK-DAG: %[[path_decl:.*]]:2 = hlfir.declare %[[unbox_path]]#0 typeparams %[[unbox_path]]#1 dummy_scope %[[scope]] {uniq_name = "_QFall_argumentsEpath"} : (!fir.ref<!fir.char<1,?>>, index, !fir.dscope) -> (!fir.boxchar<1>, !fir.ref<!fir.char<1,?>>) |
| 34 | + !CHECK-DAG: %[[status_decl:.*]]:2 = hlfir.declare %[[dummyStat]] dummy_scope %[[scope]] {uniq_name = "_QFall_argumentsEstatus"} : (!fir.ref<i32>, !fir.dscope) -> (!fir.ref<i32>, !fir.ref<i32>) |
| 35 | + !CHECK-DAG: %[[src_path_addr:.*]] = fir.address_of(@_{{.*}}) : !fir.ref<!fir.char<1,{{.*}}>> |
| 36 | + !CHECK-DAG: %[[line_value:.*]] = arith.constant {{.*}} : i64 |
| 37 | + !CHECK-DAG: %[[path:.*]] = fir.convert %[[path_decl]]#1 : (!fir.ref<!fir.char<1,?>>) -> !fir.ref<i8> |
| 38 | + !CHECK-DAG: %[[path_len:.*]] = fir.convert %[[unbox_path]]#1 : (index) -> i64 |
| 39 | + !CHECK-DAG: %[[src_path:.*]] = fir.convert %[[src_path_addr]] : (!fir.ref<!fir.char<1,{{.*}}>) -> !fir.ref<i8> |
| 40 | + !CHECK-DAG: %[[line:.*]] = fir.convert %[[line_value]] : (i64) -> i32 |
| 41 | + !CHECK: %[[unlink_result:.*]] = fir.call @_FortranAUnlink(%[[path]], %[[path_len]], %[[src_path]], %[[line]]) |
| 42 | + !CHECK-SAME: : (!fir.ref<i8>, i64, !fir.ref<i8>, i32) |
| 43 | + !CHECK-SAME: -> i32 |
| 44 | + |
| 45 | + !CHECK-DAG: %[[status_i64:.*]] = fir.convert %[[status_decl]]#0 : (!fir.ref<i32>) -> i64 |
| 46 | + !CHECK-DAG: %[[c_null:.*]] = arith.constant 0 : i64 |
| 47 | + !CHECK-DAG: %[[cmp_result:.*]] = arith.cmpi ne, %[[status_i64]], %[[c_null]] : i64 |
| 48 | + !CHECK: fir.if %[[cmp_result]] { |
| 49 | + !CHECK-NEXT: fir.store %[[unlink_result]] to %[[status_decl]]#0 : !fir.ref<i32> |
| 50 | + !CHECK-NEXT: } |
| 51 | + call unlink(path, status) |
| 52 | + !CHECK: return |
| 53 | +end subroutine all_arguments |
| 54 | + !CHECK: } |
0 commit comments