// Test hlfir.assign operation parse, verify (no errors), and unparse. // RUN: fir-opt %s | fir-opt | FileCheck %s func.func @scalar_logical(%arg0: !fir.ref>, %arg1: !fir.ref>) { hlfir.assign %arg1 to %arg0 : !fir.ref>, !fir.ref> return } // CHECK-LABEL: func.func @scalar_logical( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.ref>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.ref>, !fir.ref> func.func @scalar_logical_2(%arg0: !fir.ref>, %arg1: i1) { hlfir.assign %arg1 to %arg0 : i1, !fir.ref> return } // CHECK-LABEL: func.func @scalar_logical_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>, // CHECK-SAME: %[[VAL_1:.*]]: i1) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : i1, !fir.ref> func.func @scalar_integer(%arg0: !fir.ref, %arg1: !fir.ref) { hlfir.assign %arg1 to %arg0 : !fir.ref, !fir.ref return } // CHECK-LABEL: func.func @scalar_integer( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref, // CHECK-SAME: %[[VAL_1:.*]]: !fir.ref) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.ref, !fir.ref func.func @scalar_integer_2(%arg0: !fir.ref, %arg1: i32) { hlfir.assign %arg1 to %arg0 : i32, !fir.ref return } // CHECK-LABEL: func.func @scalar_integer_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref, // CHECK-SAME: %[[VAL_1:.*]]: i32) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : i32, !fir.ref func.func @scalar_real(%arg0: !fir.ref, %arg1: !fir.ref) { hlfir.assign %arg1 to %arg0 : !fir.ref, !fir.ref return } // CHECK-LABEL: func.func @scalar_real( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref, // CHECK-SAME: %[[VAL_1:.*]]: !fir.ref) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.ref, !fir.ref func.func @scalar_complex(%arg0: !fir.ref>, %arg1: !fir.ref>) { hlfir.assign %arg1 to %arg0 : !fir.ref>, !fir.ref> return } // CHECK-LABEL: func.func @scalar_complex( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.ref>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.ref>, !fir.ref> func.func @scalar_complex_2(%arg0: !fir.ref>, %arg1: !fir.complex<8>) { hlfir.assign %arg1 to %arg0 : !fir.complex<8>, !fir.ref> return } // CHECK-LABEL: func.func @scalar_complex_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.complex<8>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.complex<8>, !fir.ref> func.func @scalar_character(%arg0: !fir.boxchar<1>, %arg1: !fir.boxchar<1>) { hlfir.assign %arg1 to %arg0 : !fir.boxchar<1>, !fir.boxchar<1> return } // CHECK-LABEL: func.func @scalar_character( // CHECK-SAME: %[[VAL_0:.*]]: !fir.boxchar<1>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.boxchar<1>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.boxchar<1>, !fir.boxchar<1> func.func @scalar_character_2(%arg0: !fir.ref>, %arg1: !fir.ref>) { hlfir.assign %arg1 to %arg0 : !fir.ref>, !fir.ref> return } // CHECK-LABEL: func.func @scalar_character_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.ref>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.ref>, !fir.ref> func.func @scalar_character_3(%arg0: !fir.boxchar<1>, %arg1: !hlfir.expr>) { hlfir.assign %arg1 to %arg0 : !hlfir.expr>, !fir.boxchar<1> return } // CHECK-LABEL: func.func @scalar_character_3( // CHECK-SAME: %[[VAL_0:.*]]: !fir.boxchar<1>, // CHECK-SAME: %[[VAL_1:.*]]: !hlfir.expr>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !hlfir.expr>, !fir.boxchar<1> func.func @array(%arg0: !fir.ref>, %arg1: i32) { hlfir.assign %arg1 to %arg0 : i32, !fir.ref> return } // CHECK-LABEL: func.func @array( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>, // CHECK-SAME: %[[VAL_1:.*]]: i32) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : i32, !fir.ref> func.func @array_2(%arg0: !fir.ref>, %arg1: !hlfir.expr) { hlfir.assign %arg1 to %arg0 : !hlfir.expr, !fir.ref> return } // CHECK-LABEL: func.func @array_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>, // CHECK-SAME: %[[VAL_1:.*]]: !hlfir.expr) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !hlfir.expr, !fir.ref> func.func @array_3(%arg0: !fir.box>, %arg1: !hlfir.expr) { hlfir.assign %arg1 to %arg0 : !hlfir.expr, !fir.box> return } // CHECK-LABEL: func.func @array_3( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>, // CHECK-SAME: %[[VAL_1:.*]]: !hlfir.expr) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !hlfir.expr, !fir.box> func.func @array_4(%arg0: !fir.box>, %arg1: !fir.box>) { hlfir.assign %arg1 to %arg0 : !fir.box>, !fir.box> return } // CHECK-LABEL: func.func @array_4( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] : !fir.box>, !fir.box> func.func @alloc_assign(%arg0: !fir.ref>>>, %arg1: !fir.box>) { hlfir.assign %arg1 to %arg0 realloc : !fir.box>, !fir.ref>>> return } // CHECK-LABEL: func.func @alloc_assign( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>>>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] realloc : !fir.box>, !fir.ref>>> func.func @alloc_assign_keep_lhs_len(%arg0: !fir.ref>>>>, %arg1: !fir.box>>) { hlfir.assign %arg1 to %arg0 realloc keep_lhs_len : !fir.box>>, !fir.ref>>>> return } // CHECK-LABEL: func.func @alloc_assign_keep_lhs_len( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>>>>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box>>) { // CHECK: hlfir.assign %[[VAL_1]] to %[[VAL_0]] realloc keep_lhs_len : !fir.box>>, !fir.ref>>>>