From 3b24f55b09240dcc38e3df08e57b3fcd42f602c4 Mon Sep 17 00:00:00 2001 From: Richard Stallman Date: Tue, 23 Feb 1993 23:01:38 +0000 Subject: [PATCH] (check_for_full_enumeration_handling): Handle nameless type. From-SVN: r3516 --- gcc/stmt.c | 36 ++++++++++++++++++++++++------------ 1 file changed, 24 insertions(+), 12 deletions(-) diff --git a/gcc/stmt.c b/gcc/stmt.c index a615fce053a..5c16f50b2a2 100644 --- a/gcc/stmt.c +++ b/gcc/stmt.c @@ -3602,12 +3602,18 @@ check_for_full_enumeration_handling (type) ; if (!chain) - warning ("case value `%d' not in enumerated type `%s'", - TREE_INT_CST_LOW (n->low), - IDENTIFIER_POINTER ((TREE_CODE (TYPE_NAME (type)) - == IDENTIFIER_NODE) - ? TYPE_NAME (type) - : DECL_NAME (TYPE_NAME (type)))); + { + if (TYPE_NAME (type) == 0) + warning ("case value `%d' not in enumerated type", + TREE_INT_CST_LOW (n->low)); + else + warning ("case value `%d' not in enumerated type `%s'", + TREE_INT_CST_LOW (n->low), + IDENTIFIER_POINTER ((TREE_CODE (TYPE_NAME (type)) + == IDENTIFIER_NODE) + ? TYPE_NAME (type) + : DECL_NAME (TYPE_NAME (type)))); + } if (!tree_int_cst_equal (n->low, n->high)) { for (chain = TYPE_VALUES (type); @@ -3616,12 +3622,18 @@ check_for_full_enumeration_handling (type) ; if (!chain) - warning ("case value `%d' not in enumerated type `%s'", - TREE_INT_CST_LOW (n->high), - IDENTIFIER_POINTER ((TREE_CODE (TYPE_NAME (type)) - == IDENTIFIER_NODE) - ? TYPE_NAME (type) - : DECL_NAME (TYPE_NAME (type)))); + { + if (TYPE_NAME (type) == 0) + warning ("case value `%d' not in enumerated type", + TREE_INT_CST_LOW (n->high)); + else + warning ("case value `%d' not in enumerated type `%s'", + TREE_INT_CST_LOW (n->high), + IDENTIFIER_POINTER ((TREE_CODE (TYPE_NAME (type)) + == IDENTIFIER_NODE) + ? TYPE_NAME (type) + : DECL_NAME (TYPE_NAME (type)))); + } } } -- 2.30.2