aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGiovanni Bajo <giovannibajo@gcc.gnu.org>2004-01-16 12:29:40 +0000
committerGiovanni Bajo <giovannibajo@gcc.gnu.org>2004-01-16 12:29:40 +0000
commit1ed53ef30cdbfafa4d25d57e5f75b5aef84657b0 (patch)
treec9e198d82185c6ce3465c02f8638403dfcb7c758
parente24e721187ece610590c92b1a19b42b5d8ffe306 (diff)
downloadgcc-1ed53ef30cdbfafa4d25d57e5f75b5aef84657b0.zip
gcc-1ed53ef30cdbfafa4d25d57e5f75b5aef84657b0.tar.gz
gcc-1ed53ef30cdbfafa4d25d57e5f75b5aef84657b0.tar.bz2
re PR c++/13407 (Confusing error message from extraneous typename)
PR c++/13407 * parser.c (cp_parser_base_specifier): Check for an invalid keyword 'typename' and emit an user-friendly error message. From-SVN: r75969
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/parser.c12
2 files changed, 18 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index f78d9af..a902c25 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2004-01-15 Giovanni Bajo <giovannibajo@gcc.gnu.org>
+
+ PR c++/13407
+ * parser.c (cp_parser_base_specifier): Check for an invalid
+ keyword `typename' and emit an user-friendly error message.
+
2004-01-15 Geoffrey Keating <geoffk@apple.com>
PR pch/13361
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index 6a78264..481864b 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -12690,6 +12690,18 @@ cp_parser_base_specifier (cp_parser* parser)
break;
}
}
+ /* It is not uncommon to see programs mechanically, errouneously, use
+ the 'typename' keyword to denote (dependent) qualified types
+ as base classes. */
+ if (cp_lexer_next_token_is_keyword (parser->lexer, RID_TYPENAME))
+ {
+ if (!processing_template_decl)
+ error ("keyword `typename' not allowed outside of templates");
+ else
+ error ("keyword `typename' not allowed in this context "
+ "(the base class is implicitly a type)");
+ cp_lexer_consume_token (parser->lexer);
+ }
/* Look for the optional `::' operator. */
cp_parser_global_scope_opt (parser, /*current_scope_valid_p=*/false);