From: Janus Weil Date: Thu, 16 Sep 2010 13:12:59 +0000 (+0200) Subject: re PR fortran/45674 ([OOP] Undefined references for extended types) X-Git-Tag: releases/gcc-4.6.0~4301 X-Git-Url: https://gcc.gnu.org/git/?a=commitdiff_plain;h=7d58b9e77aab0f4c8cd8f6eb4dc618b240325099;p=gcc.git re PR fortran/45674 ([OOP] Undefined references for extended types) 2010-09-16 Janus Weil PR fortran/45674 * interface.c (compare_parameter): Create vtab for actual argument, instead of formal (if needed). 2010-09-16 Janus Weil PR fortran/45674 * gfortran.dg/class_dummy_2.f03: New. From-SVN: r164338 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 10e4ce21423b..e8fe091e4d7e 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2010-09-16 Janus Weil + + PR fortran/45674 + * interface.c (compare_parameter): Create vtab for actual argument, + instead of formal (if needed). + 2010-09-15 Janus Weil PR fortran/45577 diff --git a/gcc/fortran/interface.c b/gcc/fortran/interface.c index e9d310a24443..044ccd639f28 100644 --- a/gcc/fortran/interface.c +++ b/gcc/fortran/interface.c @@ -1428,10 +1428,10 @@ compare_parameter (gfc_symbol *formal, gfc_expr *actual, && actual->ts.u.derived && actual->ts.u.derived->ts.is_iso_c) return 1; - if (formal->ts.type == BT_CLASS) + if (formal->ts.type == BT_CLASS && actual->ts.type == BT_DERIVED) /* Make sure the vtab symbol is present when the module variables are generated. */ - gfc_find_derived_vtab (formal->ts.u.derived); + gfc_find_derived_vtab (actual->ts.u.derived); if (actual->ts.type == BT_PROCEDURE) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8baa140bad35..163079a253b2 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-09-16 Janus Weil + + PR fortran/45674 + * gfortran.dg/class_dummy_2.f03: New. + 2010-09-16 Richard Guenther PR tree-optimization/45623 diff --git a/gcc/testsuite/gfortran.dg/class_dummy_2.f03 b/gcc/testsuite/gfortran.dg/class_dummy_2.f03 new file mode 100644 index 000000000000..c1735822bb45 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/class_dummy_2.f03 @@ -0,0 +1,33 @@ +! { dg-do run } +! +! PR 45674: [OOP] Undefined references for extended types +! +! Contributed by Dietmar Ebner + +module fails_mod + implicit none + type :: a_t + integer :: a + end type + type, extends(a_t) :: b_t + integer :: b + end type +contains + subroutine foo(a) + class(a_t) :: a + end subroutine foo +end module fails_mod + +module fails_test + implicit none +contains + subroutine bar + use fails_mod + type(b_t) :: b + call foo(b) + end subroutine bar +end module fails_test + +end + +! { dg-final { cleanup-modules "fails_mod fails_test" } }