17 lines
551 B
Fortran
17 lines
551 B
Fortran
|
! RUN: bbc -emit-fir %s -o - | FileCheck %s
|
||
|
|
||
|
! Test lowering of non standard features.
|
||
|
|
||
|
! Test mismatch on result type between callee/caller
|
||
|
! CHECK-LABEL: func @_QPexpect_i32
|
||
|
subroutine expect_i32()
|
||
|
external :: returns_i32
|
||
|
real(4) :: returns_i32
|
||
|
! CHECK: %[[funcAddr:.*]] = fir.address_of(@_QPreturns_i32) : () -> i32
|
||
|
! CHECK: %[[funcCast:.*]] = fir.convert %[[funcAddr]] : (() -> i32) -> (() -> f32)
|
||
|
! CHECK: fir.call %[[funcCast]]() {{.*}}: () -> f32
|
||
|
print *, returns_i32()
|
||
|
end subroutine
|
||
|
integer(4) function returns_i32()
|
||
|
end function
|