aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Kenner <kenner@gcc.gnu.org>1995-02-11 15:16:04 -0500
committerRichard Kenner <kenner@gcc.gnu.org>1995-02-11 15:16:04 -0500
commitc40f7b333a8201eaf4af5c77297f9a1e39371325 (patch)
treefa2be066ddce1b26f07500908d81f411e0175a7c /gcc
parent5788afc6aadb9f7fadbf9a71c357b68d460febdf (diff)
downloadgcc-c40f7b333a8201eaf4af5c77297f9a1e39371325.zip
gcc-c40f7b333a8201eaf4af5c77297f9a1e39371325.tar.gz
gcc-c40f7b333a8201eaf4af5c77297f9a1e39371325.tar.bz2
(grokdeclarator): Use NAME, not IDENTIFIER_POINTER of DECLARATOR for
error messages; DECLARATOR might be null. From-SVN: r8907
Diffstat (limited to 'gcc')
-rw-r--r--gcc/c-decl.c22
1 files changed, 9 insertions, 13 deletions
diff --git a/gcc/c-decl.c b/gcc/c-decl.c
index a9b9877..12b24d0 100644
--- a/gcc/c-decl.c
+++ b/gcc/c-decl.c
@@ -1,5 +1,5 @@
/* Process declarations and variables for C compiler.
- Copyright (C) 1988, 1992, 1993, 1994 Free Software Foundation, Inc.
+ Copyright (C) 1988, 1992, 1993, 1994, 1995 Free Software Foundation, Inc.
This file is part of GNU CC.
@@ -4727,8 +4727,7 @@ grokdeclarator (declarator, declspecs, decl_context, initialized)
&& !(specbits
& ((1 << (int) RID_STATIC) | (1 << (int) RID_REGISTER)))))))
{
- error ("variable or field `%s' declared void",
- IDENTIFIER_POINTER (declarator));
+ error ("variable or field `%s' declared void", name);
type = integer_type_node;
}
@@ -4802,14 +4801,12 @@ grokdeclarator (declarator, declspecs, decl_context, initialized)
if (TREE_CODE (type) == FUNCTION_TYPE)
{
- error ("field `%s' declared as a function",
- IDENTIFIER_POINTER (declarator));
+ error ("field `%s' declared as a function", name);
type = build_pointer_type (type);
}
else if (TREE_CODE (type) != ERROR_MARK && TYPE_SIZE (type) == 0)
{
- error ("field `%s' has incomplete type",
- IDENTIFIER_POINTER (declarator));
+ error ("field `%s' has incomplete type", name);
type = error_mark_node;
}
/* Move type qualifiers down to element of an array. */
@@ -4838,19 +4835,16 @@ grokdeclarator (declarator, declspecs, decl_context, initialized)
if (specbits & (1 << (int) RID_AUTO)
&& (pedantic || current_binding_level == global_binding_level))
- pedwarn ("invalid storage class for function `%s'",
- IDENTIFIER_POINTER (declarator));
+ pedwarn ("invalid storage class for function `%s'", name);
if (specbits & (1 << (int) RID_REGISTER))
- error ("invalid storage class for function `%s'",
- IDENTIFIER_POINTER (declarator));
+ error ("invalid storage class for function `%s'", name);
/* Function declaration not at top level.
Storage classes other than `extern' are not allowed
and `extern' makes no difference. */
if (current_binding_level != global_binding_level
&& (specbits & ((1 << (int) RID_STATIC) | (1 << (int) RID_INLINE)))
&& pedantic)
- pedwarn ("invalid storage class for function `%s'",
- IDENTIFIER_POINTER (declarator));
+ pedwarn ("invalid storage class for function `%s'", name);
/* If this is a block level extern, it must live past the end
of the function so that we can check it against other
@@ -4870,9 +4864,11 @@ grokdeclarator (declarator, declspecs, decl_context, initialized)
if (extern_ref)
DECL_EXTERNAL (decl) = 1;
+
/* Record absence of global scope for `static' or `auto'. */
TREE_PUBLIC (decl)
= !(specbits & ((1 << (int) RID_STATIC) | (1 << (int) RID_AUTO)));
+
/* Record presence of `inline', if it is reasonable. */
if (inlinep)
{