diff options
author | Tobias Burnus <burnus@net-b.de> | 2010-08-15 18:20:56 +0200 |
---|---|---|
committer | Tobias Burnus <burnus@gcc.gnu.org> | 2010-08-15 18:20:56 +0200 |
commit | ba3721c1c20ccd158a3631af7518e6d1d2662514 (patch) | |
tree | 0b60fb361f5d9e16fc724fb17db94a493bbe66bf /gcc | |
parent | 08857b61110b21df00ad74de9d36ef8392dc98d3 (diff) | |
download | gcc-ba3721c1c20ccd158a3631af7518e6d1d2662514.zip gcc-ba3721c1c20ccd158a3631af7518e6d1d2662514.tar.gz gcc-ba3721c1c20ccd158a3631af7518e6d1d2662514.tar.bz2 |
re PR fortran/45211 (C interoperable error when compiling BIND(C) function in a module.)
2010-08-15 Tobias Burnus <burnus@net-b.de>
PR fortran/45211
* decl.c (verify_c_interop_param): Remove superfluous space (" ").
(verify_c_interop): Handle unresolved DT with bind(C).
2010-08-15 Tobias Burnus <burnus@net-b.de>
PR fortran/45211
* gfortran.dg/bind_c_usage_21.f90: New.
* gfortran.dg/bind_c_dts_3.f03: Update dg-error.
From-SVN: r163264
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/fortran/decl.c | 5 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/bind_c_dts_3.f03 | 2 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/bind_c_usage_21.f90 | 25 |
5 files changed, 41 insertions, 3 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 4bddcb4..b88d9c9 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,5 +1,11 @@ 2010-08-15 Tobias Burnus <burnus@net-b.de> + PR fortran/45211 + * decl.c (verify_c_interop_param): Remove superfluous space (" "). + (verify_c_interop): Handle unresolved DT with bind(C). + +2010-08-15 Tobias Burnus <burnus@net-b.de> + * trans-expr.c (gfc_conv_expr_present): Regard nullified pointer arrays as absent. (gfc_conv_procedure_call): Handle EXPR_NULL for non-pointer diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index be41af8..5baa400 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -991,7 +991,7 @@ verify_c_interop_param (gfc_symbol *sym) /* Make personalized messages to give better feedback. */ if (sym->ts.type == BT_DERIVED) gfc_error ("Type '%s' at %L is a parameter to the BIND(C) " - " procedure '%s' but is not C interoperable " + "procedure '%s' but is not C interoperable " "because derived type '%s' is not C interoperable", sym->name, &(sym->declared_at), sym->ns->proc_name->name, @@ -3612,7 +3612,8 @@ gfc_try verify_c_interop (gfc_typespec *ts) { if (ts->type == BT_DERIVED && ts->u.derived != NULL) - return (ts->u.derived->ts.is_c_interop ? SUCCESS : FAILURE); + return (ts->u.derived->ts.is_c_interop || ts->u.derived->attr.is_bind_c) + ? SUCCESS : FAILURE; else if (ts->is_c_interop != 1) return FAILURE; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 1065b33..7c43d39 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,11 @@ 2010-08-15 Tobias Burnus <burnus@net-b.de> + PR fortran/45211 + * gfortran.dg/bind_c_usage_21.f90: New. + * gfortran.dg/bind_c_dts_3.f03: Update dg-error. + +2010-08-15 Tobias Burnus <burnus@net-b.de> + * gfortran.dg/optional_absent_1.f90: New. * gfortran.dg/null_actual.f90: New. diff --git a/gcc/testsuite/gfortran.dg/bind_c_dts_3.f03 b/gcc/testsuite/gfortran.dg/bind_c_dts_3.f03 index 6c6da9f..fa54fb7 100644 --- a/gcc/testsuite/gfortran.dg/bind_c_dts_3.f03 +++ b/gcc/testsuite/gfortran.dg/bind_c_dts_3.f03 @@ -26,7 +26,7 @@ type, bind(c):: t3 ! { dg-error "BIND.C. derived type" } end type t3 contains - subroutine sub0(my_type, expected_value) bind(c) ! { dg-error "is not C interoperable" } + subroutine sub0(my_type, expected_value) bind(c) type(my_c_type_1) :: my_type integer(c_int), value :: expected_value diff --git a/gcc/testsuite/gfortran.dg/bind_c_usage_21.f90 b/gcc/testsuite/gfortran.dg/bind_c_usage_21.f90 new file mode 100644 index 0000000..10a86db --- /dev/null +++ b/gcc/testsuite/gfortran.dg/bind_c_usage_21.f90 @@ -0,0 +1,25 @@ +! { dg-do compile } +! +! PR fortran/45211 +! +! Contributed by Scot Breitenfeld +! +module m +contains + FUNCTION liter_cb(link_info) bind(C) + USE ISO_C_BINDING + IMPLICIT NONE + + INTEGER(c_int) liter_cb + + TYPE, bind(C) :: info_t + INTEGER(c_int) :: type + END TYPE info_t + + TYPE(info_t) :: link_info + + liter_cb = 0 + END FUNCTION liter_cb +end module m + +! { dg-final { cleanup-modules "m" } } |