diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2008-06-21 10:00:56 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2008-06-21 10:00:56 +0000 |
commit | e6aff3db250bf5ab3e3afb2cd3fe2c186496dc97 (patch) | |
tree | 9c9c76a2810563527c4511bca8426290c8f3a4f0 /clang/lib/Parse/Parser.cpp | |
parent | 42bbca11ccaa7e2f5ab1695ce7d311f6c48567a5 (diff) | |
download | bcm5719-llvm-e6aff3db250bf5ab3e3afb2cd3fe2c186496dc97.tar.gz bcm5719-llvm-e6aff3db250bf5ab3e3afb2cd3fe2c186496dc97.zip |
K&R-style functions not allowed in C++.
llvm-svn: 52575
Diffstat (limited to 'clang/lib/Parse/Parser.cpp')
-rw-r--r-- | clang/lib/Parse/Parser.cpp | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/clang/lib/Parse/Parser.cpp b/clang/lib/Parse/Parser.cpp index 84a13814433..51223a7ccfe 100644 --- a/clang/lib/Parse/Parser.cpp +++ b/clang/lib/Parse/Parser.cpp @@ -420,8 +420,9 @@ Parser::DeclTy *Parser::ParseDeclarationOrFunctionDefinition() { Tok.is(tok::kw___attribute)) { // int X() __attr__ -> not a function def // FALL THROUGH. } else if (DeclaratorInfo.isFunctionDeclarator() && - (Tok.is(tok::l_brace) || // int X() {} - isDeclarationSpecifier())) { // int X(f) int f; {} + (Tok.is(tok::l_brace) || // int X() {} + ( !getLang().CPlusPlus && + isDeclarationSpecifier() ))) { // int X(f) int f; {} if (DS.getStorageClassSpec() == DeclSpec::SCS_typedef) { Diag(Tok, diag::err_function_declared_typedef); |