diff options
Diffstat (limited to 'gcc/fortran')
-rw-r--r-- | gcc/fortran/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/fortran/decl.c | 4 |
2 files changed, 10 insertions, 0 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 8c4ace7..435f93d 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2020-04-06 Steven G. Kargl <kargl@gcc.gnu.org> + + PR fortran/93686 + * decl.c (gfc_match_data): Handle data matching for derived type + pointers. + 2020-04-02 Tobias Burnus <tobias@codesourcery.com> * gfortran.h (gfc_resolve_formal_arglist): Add prototype. diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index ea30908..b3ed63c 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -696,6 +696,10 @@ gfc_match_data (void) /* F2008:C567 (R536) A data-i-do-object or a variable that appears as a data-stmt-object shall not be an object designator in which a pointer appears other than as the entire rightmost part-ref. */ + if (!e->ref && e->ts.type == BT_DERIVED + && e->symtree->n.sym->attr.pointer) + goto partref; + ref = e->ref; if (e->symtree->n.sym->ts.type == BT_DERIVED && e->symtree->n.sym->attr.pointer |