[Patch, Fortran] PR 45586: Correct access to parent components of DT on tree level
Mikael Morin
mikael.morin@sfr.fr
Sat Feb 12 15:48:00 GMT 2011
On Saturday 12 February 2011 12:20:58 Tobias Burnus wrote:
> The issue was found by Michael when working on the "restrict" issue of
> DT; see http://gcc.gnu.org/bugzilla/show_bug.cgi?id=45586#c40
>
> Without the patch, not only his draft patch fails, but one also gets -
> as Mikael pointed out - strange dumps. For extends_1.f03 the result
> without patch is:
>
> new_person->service.education.person.service.education.person.education.per
> son.person.ss = *ss;
>
> with the patch the result is the more reasonable:
>
> new_person->service.education.person.ss = *ss;
>
> Build and regtested on x86-64-linux.
> OK for the trunk?
>
> Tobias
>
> PS: Michael plans to submit his restrict patch (comment 35) after this
> patch has been committed; the draft patch has been already pre-reviewed
> by Mikael (comment 38).
Hello,
I'm going to commit the attached testcase.
Mikael
2011-02-12 Mikael Morin <mikael.morin@sfr.fr>
PR fortran/45586
* gfortran.dg/extends_11.f03: New.
-------------- next part --------------
! { dg-do compile }
! { dg-options "-fdump-tree-original" }
!
! PR fortran/45586
! Test that access to inherited components are properly generated
!
! Stripped down from extends_1.f03
!
type :: person
integer :: ss = 1
end type person
type, extends(person) :: education
integer :: attainment = 0
end type education
type, extends(education) :: service
integer :: personnel_number = 0
end type service
type, extends(service) :: person_record
type (person_record), pointer :: supervisor => NULL ()
end type person_record
type(person_record) :: recruit
! Check that references by ultimate component and by parent type work
! All the following component access are equivalent
recruit%ss = 2
recruit%person%ss = 3
recruit%education%ss = 4
recruit%education%person%ss = 5
recruit%service%ss = 6
recruit%service%person%ss = 7
recruit%service%education%ss = 8
recruit%service%education%person%ss = 9
end
! { dg-final { scan-tree-dump-times " +recruit\\.service\\.education\\.person\\.ss =" 8 "original"} }
! { dg-final { cleanup-tree-dump "original" } }
More information about the Gcc-patches
mailing list