aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/auto_dealloc_2.f90
blob: 93d4f95ddf6faa50c37b439a963bf003d715614f (plain)
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
! { dg-do compile }
! { dg-options "-fdump-tree-original" }
!
! PR 47637: [OOP] Memory leak involving INTENT(OUT) CLASS argument w/ allocatable components
!
! Contributed by Rich Townsend <townsend@astro.wisc.edu>

program test

type :: t
  integer, allocatable :: i(:)
end type

block ! New block as the main program implies SAVE
type(t) :: a

call init(a)
call init(a)
end block
contains

  subroutine init(x)
    class(t), intent(out) :: x
    allocate(x%i(1000))
  end subroutine

end program

! { dg-final { scan-tree-dump-times "__builtin_free" 4 "original" } }
! { dg-final { scan-tree-dump-times "_vptr->_final \\(&desc" 1 "original" } }