[cfe-commits] r134258 - in /cfe/trunk: lib/Parse/ParseExpr.cpp test/Parser/parenthesis-balance.cpp test/SemaCXX/copy-assignment.cpp
Richard Trieu
rtrieu at google.com
Fri Jul 1 13:54:03 PDT 2011
Author: rtrieu
Date: Fri Jul 1 15:54:02 2011
New Revision: 134258
URL: http://llvm.org/viewvc/llvm-project?rev=134258&view=rev
Log:
For code such as:
int f(int x) {
if (int foo = f(bar)) {}
return 0;
}
Clang produces the following error messages:
paren_imbalance.cc:2:19: error: use of undeclared identifier 'bar'
if (int foo = f(bar)) {}
^
paren_imbalance.cc:2:26: error: expected ')'
if (int foo = f(bar)) {}
^
paren_imbalance.cc:2:6: note: to match this '('
if (int foo = f(bar)) {}
^
The second error is incorrect. This patch will stop Clang from producing an error on parenthesis imbalance during error recovery when there isn't one.
Added:
cfe/trunk/test/Parser/parenthesis-balance.cpp
Modified:
cfe/trunk/lib/Parse/ParseExpr.cpp
cfe/trunk/test/SemaCXX/copy-assignment.cpp
Modified: cfe/trunk/lib/Parse/ParseExpr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Parse/ParseExpr.cpp?rev=134258&r1=134257&r2=134258&view=diff
==============================================================================
--- cfe/trunk/lib/Parse/ParseExpr.cpp (original)
+++ cfe/trunk/lib/Parse/ParseExpr.cpp Fri Jul 1 15:54:02 2011
@@ -1260,7 +1260,6 @@
if (Tok.isNot(tok::r_paren)) {
if (ParseExpressionList(ArgExprs, CommaLocs, &Sema::CodeCompleteCall,
LHS.get())) {
- SkipUntil(tok::r_paren);
LHS = ExprError();
}
}
Added: cfe/trunk/test/Parser/parenthesis-balance.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Parser/parenthesis-balance.cpp?rev=134258&view=auto
==============================================================================
--- cfe/trunk/test/Parser/parenthesis-balance.cpp (added)
+++ cfe/trunk/test/Parser/parenthesis-balance.cpp Fri Jul 1 15:54:02 2011
@@ -0,0 +1,15 @@
+// RUN: %clang_cc1 -fsyntax-only -verify %s
+
+int f(int x) {
+ if (int foo = f(bar)) {} // expected-error{{use of undeclared identifier 'bar'}}
+ while (int foo = f(bar)) {} // expected-error{{use of undeclared identifier 'bar'}}
+ for (int foo = f(bar);;) {} // expected-error{{use of undeclared identifier 'bar'}}
+
+ int bar;
+ if (int foo = f(bar)) {}
+ while (int foo = f(bar)) {}
+ for (int foo = f(bar);;) {}
+
+ return 0;
+}
+
Modified: cfe/trunk/test/SemaCXX/copy-assignment.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/copy-assignment.cpp?rev=134258&r1=134257&r2=134258&view=diff
==============================================================================
--- cfe/trunk/test/SemaCXX/copy-assignment.cpp (original)
+++ cfe/trunk/test/SemaCXX/copy-assignment.cpp Fri Jul 1 15:54:02 2011
@@ -99,15 +99,17 @@
// <rdar://problem/8315440>: Don't crash
// FIXME: the recovery here is really bad.
-namespace test1 { // expected-note{{to match this '{'}}
- template<typename T> class A : public unknown::X { // expected-error {{undeclared identifier 'unknown'}} expected-error {{expected class name}} \
- // expected-note{{template parameter is declared here}}
+namespace test1 {
+ template<typename T> class A : public unknown::X { // expected-error {{undeclared identifier 'unknown'}} expected-error {{expected class name}}
A(UndeclaredType n) : X(n) {} // expected-error{{expected ')'}} expected-note{{to match this '('}} \
- // expected-error{{use of undeclared identifier 'n'}}
+ // expected-error{{use of undeclared identifier 'n'}} \
+ // expected-error{{expected ';' at end of declaration list}} \
+ // expected-error{{field has incomplete type 'test1::A<char>'}}
};
- template<typename T> class B : public A<T> { // expected-error{{declaration of 'T' shadows template parameter}}
+ template<typename T> class B : public A<T> {
virtual void foo() {}
};
- extern template class A<char>; // expected-error{{expected member name or ';' after declaration specifiers}}
- extern template class B<char>; // expected-error{{expected member name or ';' after declaration specifiers}}
-} // expected-error{{expected ';' after class}} // expected-error{{expected '}'}}
+ extern template class A<char>; // expected-note {{in instantiation of template class 'test1::A<char>' requested here}} \
+ // expected-note {{definition of 'test1::A<char>' is not complete until the closing '}'}}
+ extern template class B<char>;
+}
More information about the cfe-commits
mailing list