OSDN Git Service

PR c++/52725
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 1 Jun 2012 21:19:36 +0000 (21:19 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 1 Jun 2012 21:19:36 +0000 (21:19 +0000)
* parser.c (cp_parser_binary_expression): Bail early if we're parsing
tentatively and the LHS has a parse error.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-4_7-branch@188128 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/parse/new6.C [new file with mode: 0644]
gcc/testsuite/g++.dg/template/sizeof-template-argument.C

index 2bdff61..2a8d513 100644 (file)
@@ -1,5 +1,11 @@
 2012-06-01  Jason Merrill  <jason@redhat.com>
 
+       PR c++/52725
+       * parser.c (cp_parser_binary_expression): Bail early if we're parsing
+       tentatively and the LHS has a parse error.
+
+2012-06-01  Jason Merrill  <jason@redhat.com>
+
        PR c++/53137
        * pt.c (instantiate_class_template_1): Set LAMBDA_EXPR_THIS_CAPTURE.
        (instantiate_decl): Don't push_to_top_level for local class methods.
index 9b1478a..20e42af 100644 (file)
@@ -7276,6 +7276,9 @@ cp_parser_binary_expression (cp_parser* parser, bool cast_p,
   lhs = cp_parser_cast_expression (parser, /*address_p=*/false, cast_p, pidk);
   lhs_type = ERROR_MARK;
 
+  if (cp_parser_error_occurred (parser))
+    return error_mark_node;
+
   for (;;)
     {
       /* Get an operator token.  */
index b64a74b..01115c0 100644 (file)
@@ -1,5 +1,11 @@
 2012-06-01  Jason Merrill  <jason@redhat.com>
 
+       PR c++/52725
+       * g++.dg/parse/new6.C: New.
+       * g++.dg/template/sizeof-template-argument.C: Adjust error message.
+
+2012-06-01  Jason Merrill  <jason@redhat.com>
+
        PR c++/53137
        * g++.dg/cpp0x/lambda/lambda-template5.C: New.
 
diff --git a/gcc/testsuite/g++.dg/parse/new6.C b/gcc/testsuite/g++.dg/parse/new6.C
new file mode 100644 (file)
index 0000000..213837c
--- /dev/null
@@ -0,0 +1,10 @@
+// PR c++/52725
+
+struct A { };
+
+const int n = 42;
+
+void f()
+{
+  A** p = new (A*[n]);
+}
index 2cdc328..31aeeec 100644 (file)
@@ -3,9 +3,9 @@
 
 template<int> struct A {};
 
-template<typename> struct B : A <sizeof(=)> {}; /* { dg-error "parse error in template argument list" } */
+template<typename> struct B : A <sizeof(=)> {}; /* { dg-error "template argument" } */
 
-template<typename> struct C : A <sizeof(=)> {}; /* { dg-error "parse error in template argument list" } */
+template<typename> struct C : A <sizeof(=)> {}; /* { dg-error "template argument" } */
 
 int a;