File: class_30.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 (28 lines) | stat: -rw-r--r-- 633 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
 module class_30_mod
    type :: abstract_lexer
    end type

   type :: stack_item
      integer :: scope
   end type stack_item

   type, extends(abstract_lexer) :: toml_lexer
      integer :: top = 1
      type(stack_item), allocatable :: stack(:)
   end type toml_lexer
end module

program class_30
    use class_30_mod
    type(toml_lexer) :: lexer
    allocate(lexer%stack(10))
    lexer%stack(lexer%top)%scope = 1
    call check_scope(lexer)

contains

    subroutine check_scope(lex)
        class(toml_lexer), intent(in) :: lex
        if (lex%stack(lex%top)%scope /= 1) error stop
    end subroutine check_scope
end program