Mercurial > hg > CbC > CbC_gcc
view gcc/testsuite/gfortran.dg/contained_module_proc_1.f90 @ 128:fe568345ddd5
fix CbC-example
author | mir3636 |
---|---|
date | Wed, 11 Apr 2018 19:32:28 +0900 |
parents | 04ced10e8804 |
children | 84e7813d76e9 |
line wrap: on
line source
! { dg-do run } ! Tests the check for PR31292, in which the module procedure ! statement would put the symbol for assign_t in the wrong ! namespace and this caused the interface checking to fail. ! ! Contributed by Tobias Burnus <burnus@gcc.gnu.org> ! module chk_gfortran implicit none type t integer x end type t contains function is_gfortran() logical is_gfortran interface assignment(=) module procedure assign_t end interface assignment(=) type(t) y(3) y%x = (/1,2,3/) y = y((/2,3,1/)) is_gfortran = y(3)%x == 1 end function is_gfortran elemental subroutine assign_t(lhs,rhs) type(t), intent(in) :: rhs type(t), intent(out) :: lhs lhs%x = rhs%x end subroutine assign_t end module chk_gfortran program fire use chk_gfortran implicit none if(.not. is_gfortran()) call abort() end program fire