File: polymorphic_arguments_02.f90

package info (click to toggle)
lfortran 0.59.0-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 56,736 kB
  • sloc: cpp: 168,052; f90: 74,272; python: 17,537; ansic: 7,705; yacc: 2,345; sh: 1,334; fortran: 895; makefile: 37; javascript: 15
file content (47 lines) | stat: -rw-r--r-- 1,097 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47

program polymorphic_argument_02
   implicit none
   integer :: i_value = 1
   real :: r_value = 1
   character(len=1) :: c_value = "c"
   logical :: l_value = .true.

   interface str
      procedure str_scalar
   end interface str

   ! Calling generic procedure with any argument
   print *, str(i_value)
   if (str(i_value) /= 0) error stop

   print *, str(r_value)
   if (str(r_value) /= 0) error stop

   print *, str(c_value)
   if (str(c_value) /= 0) error stop

   print *, str(l_value)
   if (str(l_value) /= 0) error stop

   ! Calling subroutine with polymorphic parameter, with any argument
   print *, str_scalar(i_value)
   if (str_scalar(i_value) /= 0) error stop

   print *, str_scalar(r_value)
   if (str_scalar(r_value) /= 0) error stop

   print *, str_scalar(c_value)
   if (str_scalar(c_value) /= 0) error stop

   print *, str_scalar(l_value)
   if (str_scalar(l_value) /= 0) error stop

CONTAINS

   function str_scalar(g1)
      class(*), intent(in)  :: g1
      integer :: str_scalar
      str_scalar = 0
   end function str_scalar

end program polymorphic_argument_02