aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Thomas <pault@gcc.gnu.org>2006-09-10 17:17:57 +0000
committerPaul Thomas <pault@gcc.gnu.org>2006-09-10 17:17:57 +0000
commit380bfbbd61795428e53826d379ce1f4bfe1768f0 (patch)
tree852eefcc3400d2e2027106084cca7ca4f03cd93f
parentc71d6a561e249d1fe07fcbd97e348b0849247d42 (diff)
downloadgcc-380bfbbd61795428e53826d379ce1f4bfe1768f0.zip
gcc-380bfbbd61795428e53826d379ce1f4bfe1768f0.tar.gz
gcc-380bfbbd61795428e53826d379ce1f4bfe1768f0.tar.bz2
re PR fortran/28959 (ICE on derived type with host association)
2006-09-10 Paul Thomas <pault@gcc.gnu.org> PR fortran/28959 trans-types.c (gfc_get_derived_type): Use the parent namespace of the procedure if the type's own namespace does not have a parent. 2006-09-10 Paul Thomas <pault@gcc.gnu.org> PR fortran/28959 gfortran.dg/used_types_10: New test. From-SVN: r116816
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/trans-types.c7
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gfortran.dg/used_types_10.f9072
4 files changed, 90 insertions, 2 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 5b62215..159b4d1 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,5 +1,11 @@
2006-09-10 Paul Thomas <pault@gcc.gnu.org>
+ PR fortran/28959
+ trans-types.c (gfc_get_derived_type): Use the parent namespace of
+ the procedure if the type's own namespace does not have a parent.
+
+2006-09-10 Paul Thomas <pault@gcc.gnu.org>
+
PR fortran/28923
expr.c (find_array_section): Only use the array lower and upper
bounds for the start and end of the sections, where the expr is
diff --git a/gcc/fortran/trans-types.c b/gcc/fortran/trans-types.c
index 4ecf94b..377a5af 100644
--- a/gcc/fortran/trans-types.c
+++ b/gcc/fortran/trans-types.c
@@ -1483,7 +1483,12 @@ gfc_get_derived_type (gfc_symbol * derived)
same TREE_TYPE. If an equal type is found without a backend_decl,
build the parent version and use it in the current namespace. */
- for (ns = derived->ns->parent; ns; ns = ns->parent)
+ /* Derived types in an interface body obtain their parent reference
+ through the proc_name symbol. */
+ ns = derived->ns->parent ? derived->ns->parent
+ : derived->ns->proc_name->ns->parent;
+
+ for (; ns; ns = ns->parent)
{
for (dt = ns->derived_types; dt; dt = dt->next)
{
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 152d5cf..c482122 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,4 +1,9 @@
-2006-09-09 Paul Thomas <pault@gcc.gnu.org>
+2006-09-10 Paul Thomas <pault@gcc.gnu.org>
+
+ PR fortran/28959
+ gfortran.dg/used_types_10: New test.
+
+2006-09-10 Paul Thomas <pault@gcc.gnu.org>
PR libfortran/28923
gfortran.dg/array_initializer_2.f90: Fill in missing index start value.
diff --git a/gcc/testsuite/gfortran.dg/used_types_10.f90 b/gcc/testsuite/gfortran.dg/used_types_10.f90
new file mode 100644
index 0000000..c35fb58
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/used_types_10.f90
@@ -0,0 +1,72 @@
+! { dg-do compile }
+! Tests the fix for PR28959 in which interface derived types were
+! not always being associated.
+!
+! Contributed by Salvatore Filippone <sfilippone@uniroma2.it>
+!
+module derived_type_mod
+
+ type foo_dtype
+ integer, pointer :: v1(:)=>null()
+ end type foo_dtype
+
+
+end module derived_type_mod
+
+
+Module tools
+
+ interface foo_d_sub
+ subroutine cdalv(m, v, i, desc_a, info, flag)
+ use derived_type_mod
+ Integer, intent(in) :: m,i, v(:)
+ integer, intent(in), optional :: flag
+ integer, intent(out) :: info
+ Type(foo_dtype), intent(out) :: desc_a
+ end subroutine cdalv
+ end interface
+
+end module tools
+
+
+
+subroutine foo_bar(a,p,info)
+ use derived_type_mod
+ implicit none
+
+ type(foo_dtype), intent(in) :: a
+ type(foo_dtype), intent(inout) :: p
+ integer, intent(out) :: info
+
+ info=0
+
+ call inner_sub(info)
+
+
+ return
+
+
+contains
+
+ subroutine inner_sub(info)
+ use tools
+ implicit none
+
+ integer, intent(out) :: info
+
+ integer :: i, nt,iv(10)
+
+ i = 0
+ nt = 1
+
+ call foo_d_sub(nt,iv,i,p,info,flag=1)
+
+ return
+
+
+ end subroutine inner_sub
+
+
+
+end subroutine foo_bar
+! { dg-final { cleanup-modules "derived_type_mod tools" } }