missing_optional_dummy_3.f90

来自「用于进行gcc测试」· F90 代码 · 共 33 行

F90
33
字号
! { dg-do compile }! Tests the fix for PR29976, in which the call to CMPLX caused an! ICE with an optional dummy for the imaginary part.!! Contributed by Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>!SUBROUTINE pw_sumup (alpha_im)  REAL, INTENT(in), OPTIONAL :: alpha_im  COMPLEX :: my_alpha_c  IF (PRESENT(alpha_im)) THEN     my_alpha_c = CMPLX(0.,alpha_im)  END IFEND SUBROUTINE pw_sumup! Check non-intrinsic functions.SUBROUTINE pw_sumup_2 (alpha_im)  REAL, INTENT(in), OPTIONAL :: alpha_im  COMPLEX :: my_alpha_c  IF (PRESENT(alpha_im)) THEN     my_alpha_c = MY_CMPLX(0.,alpha_im)  END IFcontains  complex function MY_CMPLX (re, im)    real, intent(in) :: re    real, intent(in), optional :: im    if (present (im)) then       MY_CMPLX = cmplx (re, im)    else      MY_CMPLX = cmplx (re, 0.0)    end if  end function MY_CMPLXEND SUBROUTINE pw_sumup_2

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?