diff options
author | Janus Weil <janus@gcc.gnu.org> | 2008-12-06 13:15:49 +0100 |
---|---|---|
committer | Janus Weil <janus@gcc.gnu.org> | 2008-12-06 13:15:49 +0100 |
commit | fb7ca5a762a94ab5c7f3d16831b3dc037dfa6619 (patch) | |
tree | 5a9334a2b80c82df9dca83e90e67075a67ae7527 /gcc | |
parent | 22493a73d5952c7d84908d8cc2abbb21264e3d5f (diff) | |
download | gcc-fb7ca5a762a94ab5c7f3d16831b3dc037dfa6619.zip gcc-fb7ca5a762a94ab5c7f3d16831b3dc037dfa6619.tar.gz gcc-fb7ca5a762a94ab5c7f3d16831b3dc037dfa6619.tar.bz2 |
re PR fortran/38415 (procedure pointer assignment to abstract interface)
2008-12-06 Janus Weil <janus@gcc.gnu.org>
PR fortran/38415
* expr.c (gfc_check_pointer_assign): Added a check for abstract
interfaces in procedure pointer assignments, removed check involving
gfc_compare_interfaces until PR38290 is fixed completely.
2008-12-06 Janus Weil <janus@gcc.gnu.org>
PR fortran/38415
* gfortran.dg/proc_ptr_2.f90: Extended.
* gfortran.dg/proc_ptr_11.f90: Modified.
From-SVN: r142520
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/fortran/expr.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/proc_ptr_11.f90 | 6 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/proc_ptr_2.f90 | 8 |
5 files changed, 34 insertions, 2 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 5cdbb23..0fed3d2 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,10 @@ +2008-12-06 Janus Weil <janus@gcc.gnu.org> + + PR fortran/38415 + * expr.c (gfc_check_pointer_assign): Added a check for abstract + interfaces in procedure pointer assignments, removed check involving + gfc_compare_interfaces until PR38290 is fixed completely. + 2008-12-05 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR fortran/38291 diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c index b94e5ac..07dfc7a 100644 --- a/gcc/fortran/expr.c +++ b/gcc/fortran/expr.c @@ -3125,6 +3125,13 @@ gfc_check_pointer_assign (gfc_expr *lvalue, gfc_expr *rvalue) &rvalue->where); return FAILURE; } + if (attr.abstract) + { + gfc_error ("Abstract interface '%s' is invalid " + "in procedure pointer assignment at %L", + rvalue->symtree->name, &rvalue->where); + } + /* TODO. See PR 38290. if (rvalue->expr_type == EXPR_VARIABLE && lvalue->symtree->n.sym->attr.if_source != IFSRC_UNKNOWN && !gfc_compare_interfaces (lvalue->symtree->n.sym, @@ -3133,7 +3140,7 @@ gfc_check_pointer_assign (gfc_expr *lvalue, gfc_expr *rvalue) gfc_error ("Interfaces don't match " "in procedure pointer assignment at %L", &rvalue->where); return FAILURE; - } + }*/ return SUCCESS; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5b26088..2c7ee3c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2008-12-06 Janus Weil <janus@gcc.gnu.org> + + PR fortran/38415 + * gfortran.dg/proc_ptr_2.f90: Extended. + * gfortran.dg/proc_ptr_11.f90: Modified. + 2008-12-05 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR fortran/38291 diff --git a/gcc/testsuite/gfortran.dg/proc_ptr_11.f90 b/gcc/testsuite/gfortran.dg/proc_ptr_11.f90 index a5cdbb5..69bf140 100644 --- a/gcc/testsuite/gfortran.dg/proc_ptr_11.f90 +++ b/gcc/testsuite/gfortran.dg/proc_ptr_11.f90 @@ -14,8 +14,12 @@ program bsp end interface procedure( up ) , pointer :: pptr + procedure(isign), pointer :: q - pptr => add ! { dg-error "Interfaces don't match" } + ! TODO. See PR 38290. + !pptr => add ! { "Interfaces don't match" } + + q => add print *, pptr() ! { dg-error "is not a function" } diff --git a/gcc/testsuite/gfortran.dg/proc_ptr_2.f90 b/gcc/testsuite/gfortran.dg/proc_ptr_2.f90 index 6224dc5..98539b9 100644 --- a/gcc/testsuite/gfortran.dg/proc_ptr_2.f90 +++ b/gcc/testsuite/gfortran.dg/proc_ptr_2.f90 @@ -8,10 +8,18 @@ PROCEDURE(REAL), POINTER :: ptr PROCEDURE(REAL), SAVE :: noptr ! { dg-error "attribute conflicts with" } REAL :: x + abstract interface + subroutine bar(a) + integer :: a + end subroutine bar + end interface + ptr => cos(4.0) ! { dg-error "Invalid procedure pointer assignment" } ptr => x ! { dg-error "Invalid procedure pointer assignment" } ptr => sin(x) ! { dg-error "Invalid procedure pointer assignment" } +ptr => bar ! { dg-error "is invalid in procedure pointer assignment" } + ALLOCATE(ptr) ! { dg-error "must be ALLOCATABLE" } end |