summaryrefslogtreecommitdiff
path: root/src/shared/cplusplus/Bind.cpp
diff options
context:
space:
mode:
authorRoberto Raggi <roberto.raggi@nokia.com>2010-12-16 12:25:51 +0100
committerRoberto Raggi <roberto.raggi@nokia.com>2010-12-16 12:26:12 +0100
commit88fe5a50a11908c2c1cc99308fd6f8846b3b7644 (patch)
tree939a5c927c9733062a898a1c886e2abcda467875 /src/shared/cplusplus/Bind.cpp
parent476dda1b43ab0627c451a4422a4e1db799e6aa00 (diff)
downloadqt-creator-88fe5a50a11908c2c1cc99308fd6f8846b3b7644.tar.gz
Added semantic checks for stray semicolons and topldevel empty declarations.
Diffstat (limited to 'src/shared/cplusplus/Bind.cpp')
-rw-r--r--src/shared/cplusplus/Bind.cpp16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/shared/cplusplus/Bind.cpp b/src/shared/cplusplus/Bind.cpp
index ef95d898f9..7579838bb5 100644
--- a/src/shared/cplusplus/Bind.cpp
+++ b/src/shared/cplusplus/Bind.cpp
@@ -1796,7 +1796,13 @@ bool Bind::visit(SimpleDeclarationAST *ast)
bool Bind::visit(EmptyDeclarationAST *ast)
{
(void) ast;
- // unsigned semicolon_token = ast->semicolon_token;
+ unsigned semicolon_token = ast->semicolon_token;
+ if (_scope && (_scope->isClass() || _scope->isNamespace())) {
+ const Token &tk = tokenAt(semicolon_token);
+
+ if (! tk.generated())
+ translationUnit()->warning(semicolon_token, "extra `;'");
+ }
return false;
}
@@ -2770,6 +2776,14 @@ bool Bind::visit(EnumSpecifierAST *ast)
for (EnumeratorListAST *it = ast->enumerator_list; it; it = it->next) {
this->enumerator(it->value, e);
}
+
+ if (ast->stray_comma_token /* && ! translationUnit()->cxx0xEnabled()*/) {
+ const Token &tk = tokenAt(ast->stray_comma_token);
+ if (! tk.generated())
+ translationUnit()->warning(ast->stray_comma_token,
+ "commas at the end of enumerator lists are a C++0x-specific feature");
+ }
+
(void) switchScope(previousScope);
return false;
}