re PR fortran/36592 (F2003: Procedure pointer in COMMON)

2008-09-30  Janus Weil  <janus@gcc.gnu.org>

        PR fortran/36592
        * symbol.c (check_conflict): If a symbol in a COMMON block is a
        procedure, it must be a procedure pointer.
        (gfc_add_in_common): Symbols in COMMON blocks may be variables or
        procedure pointers.
        * trans-types.c (gfc_sym_type): Make procedure pointers in
        * COMMON
        blocks work.


2008-09-30  Janus Weil  <janus@gcc.gnu.org>

        PR fortran/36592
        * gfortran.dg/proc_ptr_common_1.f90: New.
        * gfortran.dg/proc_ptr_common_2.f90: New.

From-SVN: r140790
This commit is contained in:
Janus Weil 2008-09-30 17:19:25 +02:00 committed by Tobias Burnus
parent f249018cc2
commit 00625faea4
6 changed files with 80 additions and 9 deletions

View File

@ -1,3 +1,13 @@
2008-09-30 Janus Weil <janus@gcc.gnu.org>
PR fortran/36592
* symbol.c (check_conflict): If a symbol in a COMMON block is a
procedure, it must be a procedure pointer.
(gfc_add_in_common): Symbols in COMMON blocks may be variables or
procedure pointers.
* trans-types.c (gfc_sym_type): Make procedure pointers in COMMON
blocks work.
2008-09-25 Jerry DeLisle <jvdelisle@gcc.gnu.org 2008-09-25 Jerry DeLisle <jvdelisle@gcc.gnu.org
PR fortran/37498 PR fortran/37498

View File

@ -636,10 +636,12 @@ check_conflict (symbol_attribute *attr, const char *name, locus *where)
conf2 (threadprivate); conf2 (threadprivate);
} }
if (!attr->proc_pointer)
conf2 (in_common);
switch (attr->proc) switch (attr->proc)
{ {
case PROC_ST_FUNCTION: case PROC_ST_FUNCTION:
conf2 (in_common);
conf2 (dummy); conf2 (dummy);
break; break;
@ -649,7 +651,6 @@ check_conflict (symbol_attribute *attr, const char *name, locus *where)
case PROC_DUMMY: case PROC_DUMMY:
conf2 (result); conf2 (result);
conf2 (in_common);
conf2 (threadprivate); conf2 (threadprivate);
break; break;
@ -1133,13 +1134,7 @@ gfc_add_in_common (symbol_attribute *attr, const char *name, locus *where)
/* Duplicate attribute already checked for. */ /* Duplicate attribute already checked for. */
attr->in_common = 1; attr->in_common = 1;
if (check_conflict (attr, name, where) == FAILURE) return check_conflict (attr, name, where);
return FAILURE;
if (attr->flavor == FL_VARIABLE)
return SUCCESS;
return gfc_add_flavor (attr, FL_VARIABLE, name, where);
} }

View File

@ -1627,6 +1627,16 @@ gfc_sym_type (gfc_symbol * sym)
tree type; tree type;
int byref; int byref;
/* Procedure Pointers inside COMMON blocks. */
if (sym->attr.proc_pointer && sym->attr.in_common)
{
/* Unset proc_pointer as gfc_get_function_type calls gfc_sym_type. */
sym->attr.proc_pointer = 0;
type = build_pointer_type (gfc_get_function_type (sym));
sym->attr.proc_pointer = 1;
return type;
}
if (sym->attr.flavor == FL_PROCEDURE && !sym->attr.function) if (sym->attr.flavor == FL_PROCEDURE && !sym->attr.function)
return void_type_node; return void_type_node;

View File

@ -1,3 +1,9 @@
2008-09-30 Janus Weil <janus@gcc.gnu.org>
PR fortran/36592
* gfortran.dg/proc_ptr_common_1.f90: New.
* gfortran.dg/proc_ptr_common_2.f90: New.
2008-09-30 Paolo Bonzini <bonzini@gnu.org> 2008-09-30 Paolo Bonzini <bonzini@gnu.org>
* g++.dg/warn/if-empty-1.C: Copy from gcc.dg/if-empty-1.c. * g++.dg/warn/if-empty-1.C: Copy from gcc.dg/if-empty-1.c.

View File

@ -0,0 +1,30 @@
! { dg-do run }
! PR fortran/36592
!
! Procedure Pointers inside COMMON blocks.
!
! Contributed by Janus Weil <janus@gcc.gnu.org>.
subroutine one()
implicit none
common /com/ p1,p2,a,b
procedure(real), pointer :: p1,p2
integer :: a,b
if (a/=5 .or. b/=-9 .or. p1(0.0)/=1.0 .or. p2(0.0)/=0.0) call abort()
end subroutine one
program main
implicit none
integer :: x,y
intrinsic sin,cos
procedure(real), pointer :: func1
external func2
pointer func2
common /com/ func1,func2,x,y
x = 5
y = -9
func1 => cos
func2 => sin
call one()
end program main

View File

@ -0,0 +1,20 @@
! { dg-do compile }
! PR fortran/36592
!
! Procedure Pointers inside COMMON blocks.
!
! Contributed by Tobias Burnus <burnus@gcc.gnu.org>.
abstract interface
subroutine foo() bind(C)
end subroutine foo
end interface
procedure(foo), pointer, bind(C) :: proc
common /com/ proc,r
common s
call s() ! { dg-error "PROCEDURE attribute conflicts with COMMON attribute" }
end