blob: 5cde928baad73a414dc11196f67e09bdc120ef6d [file] [log] [blame]
! { dg-do compile }
! { dg-options "-std=f2003" }
!
! PR fortran/33197
! PR fortran/40728
!
! Complex inverse trigonometric functions
! and complex inverse hyperbolic functions
!
! Argument type check
!
PROGRAM ArcTrigHyp
IMPLICIT NONE
real(4), volatile :: r4
real(8), volatile :: r8
complex(4), volatile :: z4
complex(8), volatile :: z8
r4 = 0.0_4
r8 = 0.0_8
z4 = cmplx(0.0_4, 0.0_4, kind=4)
z8 = cmplx(0.0_8, 0.0_8, kind=8)
r4 = asin(r4)
r8 = asin(r8)
r4 = acos(r4)
r8 = acos(r8)
r4 = atan(r4)
r8 = atan(r8)
! a(sin,cos,tan)h cannot be checked as they are not part of
! Fortran 2003 - not even for real arguments
z4 = asin(z4) ! { dg-error "Fortran 2008: COMPLEX argument" }
z8 = asin(z8) ! { dg-error "Fortran 2008: COMPLEX argument" }
z4 = acos(z4) ! { dg-error "Fortran 2008: COMPLEX argument" }
z8 = acos(z8) ! { dg-error "Fortran 2008: COMPLEX argument" }
z4 = atan(z4) ! { dg-error "Fortran 2008: COMPLEX argument" }
z8 = atan(z8) ! { dg-error "Fortran 2008: COMPLEX argument" }
END PROGRAM ArcTrigHyp