// Test hlfir.as_expr codegen for polymorphic expressions. // RUN: fir-opt %s -bufferize-hlfir | FileCheck %s !t = !fir.type func.func @as_expr_class(%arg0 : !fir.class, %arg1: !fir.ref) { %0 = hlfir.as_expr %arg0 : (!fir.class) -> !hlfir.expr hlfir.assign %0 to %arg1 : !hlfir.expr, !fir.ref return } // CHECK-LABEL: func.func @as_expr_class( // CHECK: %[[VAL_5:.*]] = arith.constant true // CHECK: %[[VAL_6:.*]]:2 = hlfir.declare %{{.*}} {fortran_attrs = #fir.var_attrs, uniq_name = ".tmp"} : (!fir.ref>>>) -> (!fir.ref>>>, !fir.ref>>>) // ... copy ... // CHECK: %[[VAL_11:.*]] = fir.load %[[VAL_6]]#0 : !fir.ref>>> // CHECK: %[[VAL_12:.*]] = fir.undefined tuple>>, i1> // CHECK: %[[VAL_13:.*]] = fir.insert_value %[[VAL_12]], %[[VAL_5]], [1 : index] : (tuple>>, i1>, i1) -> tuple>>, i1> // CHECK: %[[VAL_14:.*]] = fir.insert_value %[[VAL_13]], %[[VAL_11]], [0 : index] : (tuple>>, i1>, !fir.class>>) -> tuple>>, i1> // CHECK: hlfir.assign %[[VAL_11]] to %{{.*}} : !fir.class>>, !fir.ref> func.func @as_expr_class_2(%arg0 : !fir.class>) { %0 = hlfir.as_expr %arg0 : (!fir.class>) -> !hlfir.expr %c1 = arith.constant 1 : index %1 = hlfir.apply %0, %c1 : (!hlfir.expr, index) -> !hlfir.expr return } // CHECK-LABEL: func.func @as_expr_class_2( // CHECK: %[[VAL_9:.*]] = arith.constant true // CHECK: %[[VAL_10:.*]]:2 = hlfir.declare %{{.*}} {fortran_attrs = #fir.var_attrs, uniq_name = ".tmp"} : (!fir.ref>>>>) -> (!fir.ref>>>>, !fir.ref>>>>) // CHECK: %[[VAL_11:.*]] = arith.constant 1 : i32 // ... copy ... // CHECK: %[[VAL_15:.*]] = fir.load %[[VAL_10]]#0 : !fir.ref>>>> // CHECK: %[[VAL_16:.*]] = fir.undefined tuple>>>, i1> // CHECK: %[[VAL_17:.*]] = fir.insert_value %[[VAL_16]], %[[VAL_9]], [1 : index] : (tuple>>>, i1>, i1) -> tuple>>>, i1> // CHECK: %[[VAL_18:.*]] = fir.insert_value %[[VAL_17]], %[[VAL_15]], [0 : index] : (tuple>>>, i1>, !fir.class>>>) -> tuple>>>, i1> // CHECK: %[[VAL_19:.*]] = arith.constant 1 : index // CHECK: %[[VAL_20:.*]] = hlfir.designate %[[VAL_15]] (%[[VAL_19]]) : (!fir.class>>>, index) -> !fir.class>