https://gcc.gnu.org/bugzilla/show_bug.cgi?id=86481

janus at gcc dot gnu.org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |janus at gcc dot gnu.org

--- Comment #3 from janus at gcc dot gnu.org ---
Here is the simplest reduction of the test case that I could find:


program simple_leak

  implicit none

  type :: foo_t
  end type

  class(foo_t), allocatable :: f

  allocate(f, SOURCE=func_foo())

contains

  function func_foo () result (f)
    class(foo_t), allocatable :: f
    allocate(foo_t :: f)
  end function

end


It leaks a lot less, though:

==27446== HEAP SUMMARY:
==27446==     in use at exit: 2 bytes in 2 blocks
==27446==   total heap usage: 23 allocs, 21 frees, 13,562 bytes allocated
==27446== 
==27446== 1 bytes in 1 blocks are definitely lost in loss record 2 of 2

Reply via email to