File: class_47.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 (65 lines) | stat: -rw-r--r-- 1,421 bytes parent folder | download | duplicates (3)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
module class_47_mod

   type, abstract :: AbsType
   contains
      procedure(method2), deferred :: method2
   end type AbsType

   abstract interface
      function method2(self,arr) result(a)
         import
         class(AbsType), intent(in) :: self
         integer,        intent(in) :: arr(:)
         integer                    :: a(size(arr))
      end function method2
   end interface

   type, extends(AbsType) :: MyType
   contains
      procedure :: method2 => my_method2
   end type MyType

   type :: SomeType
      integer,        allocatable :: arr(:)
      class(MyType), allocatable :: obj
   contains
      procedure :: method1
   end type SomeType

contains

   subroutine method1(self)
      class(SomeType), intent(inout) :: self
      allocate(MyType :: self%obj)
      self%arr = self%obj%method2(self%arr)
   end subroutine method1

   function my_method2(self, arr) result(a)
      class(MyType), intent(in) :: self
      integer, intent(in) :: arr(:)
      integer :: a(size(arr))

      integer :: i
      do i = 1, size(arr)
         a(i) = arr(i) * 2
      end do
   end function my_method2

end module class_47_mod

program class_47
   use class_47_mod
   implicit none

   class(SomeType), allocatable :: s

   allocate(s)
   allocate(s%arr(3))
   s%arr = [1, 2, 3]

   call s%method1()
   print *, "s%arr: ", s%arr

   if (.not. all(s%arr == [2, 4, 6])) error stop

end program class_47