File: modules2.f90

package info (click to toggle)
lfortran 0.58.0-3
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 54,508 kB
  • sloc: cpp: 162,179; f90: 68,251; python: 17,476; ansic: 6,278; yacc: 2,334; sh: 1,317; fortran: 892; makefile: 34; javascript: 15
file content (38 lines) | stat: -rw-r--r-- 754 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
module tomlf_type_array
   use tomlf_type_value, only : toml_value
   use tomlf_structure, only : toml_ordered
   implicit none

   type, extends(toml_value) :: toml_array

      class(toml_ordered), allocatable :: list

   contains

      procedure :: destroy

   end type toml_array

   interface new
      module procedure :: new_array
   end interface


contains

subroutine destroy(self)
   class(toml_array), intent(inout) :: self
   if (allocated(self%key)) then
      deallocate(self%key)
   end if
   if (allocated(self%list)) then
      call self%list%destroy
      deallocate(self%list)
   end if
end subroutine destroy

subroutine new_array(self)
   type(toml_array), intent(out) :: self
end subroutine new_array

end module tomlf_type_array