File: class_46.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 (39 lines) | stat: -rw-r--r-- 789 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
module class_46_mod

   type :: SomeType
   contains
      procedure :: method1
      procedure :: method2
   end type SomeType

contains

   subroutine method1(self, arr)
      class(SomeType), intent(in) :: self
      integer, intent(in) :: arr(:)
      integer, allocatable :: local(:)

      local = self%method2(arr)
      print *, "local: ", local

      if (.not. all(local == [1, 2, 3])) error stop
   end subroutine method1

   function method2(self, a) result(out)
      class(SomeType), intent(in) :: self
      integer, intent(in) :: a(:)
      integer :: out(size(a))

      out = a
   end function method2

end module class_46_mod

program class_46
   use class_46_mod

   type(SomeType) :: obj
   integer :: arr(3) = [1, 2, 3]

   call obj%method1(arr)
end program class_46