File: classes1.f90

package info (click to toggle)
lfortran 0.58.0-4
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 54,512 kB
  • sloc: cpp: 162,179; f90: 68,251; python: 17,476; ansic: 6,278; yacc: 2,334; sh: 1,317; fortran: 892; makefile: 33; javascript: 15
file content (26 lines) | stat: -rw-r--r-- 437 bytes parent folder | download
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
module xx

    type :: base
        integer :: x
    contains
        procedure, non_overridable :: show_x
    end type

    contains
        subroutine show_x(this)
            class(base), intent(inout) :: this
            this%x = 12
        end subroutine show_x
end module

program main
    use xx
    implicit none

    type(base) :: b
    b%x = 10
    call b%show_x()
    print *, b%x
    if ( b%x /= 12 ) error stop
end program