https://gcc.gnu.org/bugzilla/show_bug.cgi?id=64104

            Bug ID: 64104
           Summary: [F2003][IEEE] Allow IEEE functions in specification
                    expressions
           Product: gcc
           Version: 5.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: fortran
          Assignee: unassigned at gcc dot gnu.org
          Reporter: fxcoudert at gcc dot gnu.org

Reported by James Van Buskirk on comp.lang.fortran:

Have you tested whether gfortran accepts IEEE functions syntactically?
The following should be OK I think, but gfortran shows a lot of errors.

module funcs
   use IEEE_ARITHMETIC
   use IEEE_EXCEPTIONS
   implicit none
   integer, parameter :: ep = selected_real_kind(18,4931)
   integer, parameter :: ik4 = selected_int_kind(9)
   integer, parameter :: ik8 = selected_int_kind(18)
   contains
      subroutine test_specification(x)
         real(ep) x
         integer src(IEEE_SELECTED_REAL_KIND())
         integer datatype(merge(1,2,IEEE_SUPPORT_DATATYPE(x)))
         integer denormal(merge(1,2,IEEE_SUPPORT_DENORMAL(x)))
         integer divide(merge(1,2,IEEE_SUPPORT_DIVIDE(x)))
         integer inf(merge(1,2,IEEE_SUPPORT_INF(x)))
         integer io(merge(1,2,IEEE_SUPPORT_IO(x)))
         integer nan(merge(1,2,IEEE_SUPPORT_NAN(x)))
         integer rounding(merge(1,2,IEEE_SUPPORT_ROUNDING(IEEE_TO_ZERO,x)))
         integer sqrt(merge(1,2,IEEE_SUPPORT_SQRT(x)))
         integer standard(merge(1,2,IEEE_SUPPORT_STANDARD(x)))
         integer 
underflow_control(merge(1,2,IEEE_SUPPORT_UNDERFLOW_CONTROL(x)))
         integer flag(merge(1,2,IEEE_SUPPORT_FLAG(IEEE_INEXACT,x)))
         integer halting(merge(1,2,IEEE_SUPPORT_HALTING(IEEE_INEXACT)))
         src = 1
         write(*,*) 'src',size(src), src
         datatype = 1
         write(*,*) 'datatype',size(datatype),datatype
         denormal = 1
         write(*,*) 'denormal',size(denormal),denormal
         divide = 1
         write(*,*) 'divide',size(divide),divide
         inf = 1
         write(*,*) 'inf',size(inf),inf
         io = 1
         write(*,*) 'io',size(io),io
         nan = 1
         write(*,*) 'nan',size(nan),nan
         rounding = 1
         write(*,*) 'rounding',size(rounding),rounding
         sqrt = 1
         write(*,*) 'sqrt',size(sqrt),sqrt
         standard = 1
         write(*,*) 'standard',size(standard),standard
         underflow_control = 1
         write(*,*) 
'underflow_control',size(underflow_control),underflow_control
         flag = 1
         write(*,*) 'flag',size(flag),flag
         halting = 1
         write(*,*) 'halting',size(halting),halting
      end subroutine test_specification
      subroutine test_constant(x)
         real(ep) x
         real(IEEE_SELECTED_REAL_KIND()) src
         integer(merge(ik4,ik8,IEEE_SUPPORT_DATATYPE(x))) datatype
         integer(merge(ik4,ik8,IEEE_SUPPORT_DENORMAL(x))) denormal
         integer(merge(ik4,ik8,IEEE_SUPPORT_DIVIDE(x))) divide
         integer(merge(ik4,ik8,IEEE_SUPPORT_INF(x))) inf
         integer(merge(ik4,ik8,IEEE_SUPPORT_IO(x))) io
         integer(merge(ik4,ik8,IEEE_SUPPORT_NAN(x))) nan
         integer(merge(ik4,ik8,IEEE_SUPPORT_ROUNDING(IEEE_TO_ZERO,x))) 
rounding
         integer(merge(ik4,ik8,IEEE_SUPPORT_SQRT(x))) sqrt
         integer(merge(ik4,ik8,IEEE_SUPPORT_STANDARD(x))) standard
         integer(merge(ik4,ik8,IEEE_SUPPORT_UNDERFLOW_CONTROL(x))) 
underflow_control
         integer(merge(ik4,ik8,IEEE_SUPPORT_FLAG(IEEE_INEXACT,x))) flag
         integer(merge(ik4,ik8,IEEE_SUPPORT_HALTING(IEEE_INEXACT))) halting
         src = 1
         write(*,*) 'src',kind(src), src
         datatype = 1
         write(*,*) 'datatype',kind(datatype),datatype
         denormal = 1
         write(*,*) 'denormal',kind(denormal),denormal
         divide = 1
         write(*,*) 'divide',kind(divide),divide
         inf = 1
         write(*,*) 'inf',kind(inf),inf
         io = 1
         write(*,*) 'io',kind(io),io
         nan = 1
         write(*,*) 'nan',kind(nan),nan
         rounding = 1
         write(*,*) 'rounding',kind(rounding),rounding
         sqrt = 1
         write(*,*) 'sqrt',kind(sqrt),sqrt
         standard = 1
         write(*,*) 'standard',kind(standard),standard
         underflow_control = 1
         write(*,*) 
'underflow_control',kind(underflow_control),underflow_control
         flag = 1
         write(*,*) 'flag',kind(flag),flag
         halting = 1
         write(*,*) 'halting',kind(halting),halting
      end subroutine test_constant
end module funcs

program ieee
   use funcs
   implicit none
   real(ep) x
   call test_specification(x)
   call test_constant(x)
end program ieee

Reply via email to