aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/resolve.c
diff options
context:
space:
mode:
authorThomas Koenig <tkoenig@gcc.gnu.org>2018-01-29 07:11:16 +0000
committerThomas Koenig <tkoenig@gcc.gnu.org>2018-01-29 07:11:16 +0000
commit3be34c0b1dec1272dfabec1e94a4666e9499fdc1 (patch)
treed1acf816d6e79e1b17fc516eaa0ccb9955c86ab6 /gcc/fortran/resolve.c
parentd6ffdc5b0a7e6fcd42fa9d658008589b6175e87c (diff)
downloadgcc-3be34c0b1dec1272dfabec1e94a4666e9499fdc1.zip
gcc-3be34c0b1dec1272dfabec1e94a4666e9499fdc1.tar.gz
gcc-3be34c0b1dec1272dfabec1e94a4666e9499fdc1.tar.bz2
re PR fortran/84073 (In -fc-prototypes fixed (nonzero) length strings are mapped to plain char in prototype.)
2017-01-29 Thomas Koenig <tkoenig@gcc.gnu.org> PR fortran/84073 * resolve.c (resolve_component): Ensure BIND(C) character components have length one. (resolve_symbol): Likewise for variables. 2017-01-29 Thomas Koenig <tkoenig@gcc.gnu.org> PR fortran/84073 * gfortran.dg/bind_c_usage_31.f90: New test. From-SVN: r257138
Diffstat (limited to 'gcc/fortran/resolve.c')
-rw-r--r--gcc/fortran/resolve.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
index 8078005..9c8ba86 100644
--- a/gcc/fortran/resolve.c
+++ b/gcc/fortran/resolve.c
@@ -13557,6 +13557,17 @@ resolve_component (gfc_component *c, gfc_symbol *sym)
return false;
}
+ /* F2003, 15.2.1 - length has to be one. */
+ if (sym->attr.is_bind_c && c->ts.type == BT_CHARACTER
+ && (c->ts.u.cl == NULL || c->ts.u.cl->length == NULL
+ || !gfc_is_constant_expr (c->ts.u.cl->length)
+ || mpz_cmp_si (c->ts.u.cl->length->value.integer, 1) != 0))
+ {
+ gfc_error ("Component %qs of BIND(C) type at %L must have length one",
+ c->name, &c->loc);
+ return false;
+ }
+
if (c->attr.proc_pointer && c->ts.interface)
{
gfc_symbol *ifc = c->ts.interface;
@@ -14804,6 +14815,15 @@ resolve_symbol (gfc_symbol *sym)
"module level scope", sym->name, &(sym->declared_at));
t = false;
}
+ else if (sym->ts.type == BT_CHARACTER
+ && (sym->ts.u.cl == NULL || sym->ts.u.cl->length == NULL
+ || !gfc_is_constant_expr (sym->ts.u.cl->length)
+ || mpz_cmp_si (sym->ts.u.cl->length->value.integer, 1) != 0))
+ {
+ gfc_error ("BIND(C) Variable %qs at %L must have length one",
+ sym->name, &sym->declared_at);
+ t = false;
+ }
else if (sym->common_head != NULL && sym->attr.implicit_type == 0)
{
t = verify_com_block_vars_c_interop (sym->common_head);