+2012-10-15  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/50080 (again)
+       * parser.c (cp_parser_optional_template_keyword): When -pedantic
+       and C++98 mode restore pre-Core/468 behavior.
+
 2012-10-15  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/50080
 
 {
   if (cp_lexer_next_token_is_keyword (parser->lexer, RID_TEMPLATE))
     {
-      /* Consume the `template' keyword.  */
-      cp_lexer_consume_token (parser->lexer);
-      return true;
+      /* In C++98 the `template' keyword can only be used within templates;
+        outside templates the parser can always figure out what is a
+        template and what is not.  In C++11,  per the resolution of DR 468,
+        `template' is allowed in cases where it is not strictly necessary.  */
+      if (!processing_template_decl
+         && pedantic && cxx_dialect == cxx98)
+       {
+         cp_token *token = cp_lexer_peek_token (parser->lexer);
+         pedwarn (token->location, OPT_Wpedantic,
+                  "in C++98 %<template%> (as a disambiguator) is only "
+                  "allowed within templates");
+         /* If this part of the token stream is rescanned, the same
+            error message would be generated.  So, we purge the token
+            from the stream.  */
+         cp_lexer_purge_token (parser->lexer);
+         return false;
+       }
+      else
+       {
+         /* Consume the `template' keyword.  */
+         cp_lexer_consume_token (parser->lexer);
+         return true;
+       }
     }
   return false;
 }
 
+2012-10-15  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/50080 (again)
+       * g++.dg/parse/tmpl-outside2.C: Tweak, error in C++98.
+       * g++.dg/parse/tmpl-outside1.C: Likewise.
+       * g++.dg/template/qualttp18.C: Likewise.
+       * g++.old-deja/g++.pt/memtemp87.C: Likewise.
+       * g++.old-deja/g++.pt/overload13.C: Likewise.
+
 2012-10-15  Uros Bizjak  <ubizjak@gmail.com>
 
        * gcc.target/i386/avx256-unaligned-load-1.c: Update asm scan patterns.