summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>2007-11-30 09:31:56 +0000
committerburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>2007-11-30 09:31:56 +0000
commit42927892e8491e30ae6a032a2a48de3a666c6f3d (patch)
treeff3798fc5a704430ba9eb2aed7a0a828e27a0e6c /gcc
parentd5a707b497b110e441c9729509ae102931d06cc5 (diff)
downloadgcc-42927892e8491e30ae6a032a2a48de3a666c6f3d.tar.gz
2007-11-30 Tobias Burnus <burnus@net-b.de>
PR fortran/34186 * symbol.c (generate_isocbinding_symbol): Set string length. * dump-parse-tree.c (gfc_show_attr): Show BIND(C) attribute. * misc.c (gfc_basic_typename): Handle BT_VOID. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@130534 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog7
-rw-r--r--gcc/fortran/dump-parse-tree.c2
-rw-r--r--gcc/fortran/misc.c3
-rw-r--r--gcc/fortran/symbol.c2
4 files changed, 14 insertions, 0 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 6aa5a35f779..6f23f68503c 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,10 @@
+2007-11-30 Tobias Burnus <burnus@net-b.de>
+
+ PR fortran/34186
+ * symbol.c (generate_isocbinding_symbol): Set string length.
+ * dump-parse-tree.c (gfc_show_attr): Show BIND(C) attribute.
+ * misc.c (gfc_basic_typename): Handle BT_VOID.
+
2007-11-29 Steven G. Kargl <kargls@comcast.net>
PR fortran/34230
diff --git a/gcc/fortran/dump-parse-tree.c b/gcc/fortran/dump-parse-tree.c
index ce46e3513f7..e1e463f7fcd 100644
--- a/gcc/fortran/dump-parse-tree.c
+++ b/gcc/fortran/dump-parse-tree.c
@@ -582,6 +582,8 @@ gfc_show_attr (symbol_attribute *attr)
gfc_status (" RESULT");
if (attr->entry)
gfc_status (" ENTRY");
+ if (attr->is_bind_c)
+ gfc_status (" BIND(C)");
if (attr->data)
gfc_status (" DATA");
diff --git a/gcc/fortran/misc.c b/gcc/fortran/misc.c
index 85f982dca60..4bc5c432207 100644
--- a/gcc/fortran/misc.c
+++ b/gcc/fortran/misc.c
@@ -139,6 +139,9 @@ gfc_basic_typename (bt type)
case BT_PROCEDURE:
p = "PROCEDURE";
break;
+ case BT_VOID:
+ p = "VOID";
+ break;
case BT_UNKNOWN:
p = "UNKNOWN";
break;
diff --git a/gcc/fortran/symbol.c b/gcc/fortran/symbol.c
index 8ef2b1d22a2..a2bb43fecab 100644
--- a/gcc/fortran/symbol.c
+++ b/gcc/fortran/symbol.c
@@ -3810,6 +3810,8 @@ generate_isocbinding_symbol (const char *mod_name, iso_c_binding_symbol s,
tmp_sym->value->value.character.string[0]
= (char) c_interop_kinds_table[s].value;
tmp_sym->value->value.character.string[1] = '\0';
+ tmp_sym->value->ts.cl = gfc_get_charlen ();
+ tmp_sym->value->ts.cl->length = gfc_int_expr (1);
/* May not need this in both attr and ts, but do need in
attr for writing module file. */