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

kargl at gcc dot gnu.org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|UNCONFIRMED                 |WAITING
   Last reconfirmed|                            |2014-12-01
     Ever confirmed|0                           |1

--- Comment #4 from kargl at gcc dot gnu.org ---
(In reply to kargl from comment #1)
> (In reply to david from comment #0)
> > Hi,
> > 
> >    I have created a complex number module:
> > 
> >        module complex_number_module
> >         implicit none
> > 
> >         integer, parameter :: loc_real_precision = 8
> > 
> >         type complex_number
> >           real(kind=loc_real_precision) :: real_part, imag_part
> >         end type complex_number
> > 
> >         interface c_sub
> >           module procedure c_sub_cc,    &      ! z1 - z2
> >                            c_sub_cr,    &      ! z1 - num, where num is a
> > real number
> >                            c_sub_rc            ! num - z1, where num is a
> > real number
> >         end interface
> > 
> > ! --------------------------------------------------------------------------
> >         type (complex_number) function c_sub_cc (z1, z2)
> > 
> >         type (complex_number), intent(in) :: z1, z2
> > 
> >         c_sub_cc%real_part = z1%real_part - z2%real_part
> >         c_sub_cc%imag_part = z1%imag_part - z2%imag_part
> > 
> >         end function c_sub_ccj
> > 
> > ! --------------------------------------------------------------------------
> >         type (complex_number) function c_sub_cr (z1, num)
> > 
> >         type (complex_number),     intent(in) :: z1
> >         real(kind=loc_real_precision), intent(in) :: num
> > 
> >         c_sub_cr%real_part = z1%real_part - num
> >         c_sub_cr%imag_part = z1%imag_part
> > 
> >         end function c_sub_cr
> > 
> > ! --------------------------------------------------------------------------
> >         type (complex_number) function c_sub_rc (num, z1)
> > 
> >         type (complex_number),     intent(in) :: z1
> >         real(kind=loc_real_precision), intent(in) :: num
> > 
> >         c_sub_rc%real_part = num - z1%real_part
> >         c_sub_rc%imag_part = - z1%imag_part
> > 
> >         end function c_sub_rc
> > 
> >       end module complex_number_module
> > 
> > When I compile with gfortran (version 4.6.4), I got the following error:
> > 
> > module_twoway_rrtmg_aero_optical_util.F:14.85:
> > 
> >                  c_sub_rc            ! num - z1, where num is a real number
> >                                                                            1
> > 
> > Error: Ambiguous interfaces 'c_sub_rc' and 'c_sub_cr' in generic interface
> > 'c_sub' at (1)
> > 
> > I don't see any ambiguity and I don't encounter any problem with other
> > compilers such pgi and ifort. Please advise.
> > 
> > Cheers,
> > David
> 
> Please attach the exact code you tried to compile.  The above is nonsense.

I fixed the above code.  I believe gfortran is correct to complain
about an ambiguous interface.  In the last two line below, which
of c_sub_rc and c_sub_cr should be called.

program foo
  use complex_number_module
  type(complex_number) a, b
  real(dp) x
  a%re = 1
  a%im = 2
  x = 1
  b = c_sub(a, x); print '(A,2F5.1)', 'a-x = ', b%re, b%im
  b = c_sub(x, a); print '(A,2F5.1)', 'x-a = ', b%re, b%im
  b = c_sub(z1=a, num=x); print '(A,2F5.1)', 'a-x = ', b%re, b%im
  b = c_sub(num=x,a); print '(A,2F5.1)', 'a-x = ', b%re, b%im
end program foo

Reply via email to