summaryrefslogtreecommitdiff
path: root/src/shared/cplusplus
diff options
context:
space:
mode:
authorErik Verbruggen <erik.verbruggen@nokia.com>2010-02-06 14:32:25 +0100
committerErik Verbruggen <erik.verbruggen@nokia.com>2010-02-07 10:49:03 +0100
commit21488e8898b1aaf5d33b3a33b488e2e280219f06 (patch)
tree03f2bb0c876eaddd1112995f3c3907a2d2bf4f90 /src/shared/cplusplus
parentac6aba5ec34e2b2f7f83105e9a986e629e00ad14 (diff)
downloadqt-creator-21488e8898b1aaf5d33b3a33b488e2e280219f06.tar.gz
Added semantic checks for Q_ENUMS.
Diffstat (limited to 'src/shared/cplusplus')
-rw-r--r--src/shared/cplusplus/AST.h2
-rw-r--r--src/shared/cplusplus/ASTClone.cpp4
-rw-r--r--src/shared/cplusplus/ASTMatcher.cpp6
-rw-r--r--src/shared/cplusplus/ASTVisit.cpp2
-rw-r--r--src/shared/cplusplus/CPlusPlusForwardDeclarations.h6
-rw-r--r--src/shared/cplusplus/CheckDeclaration.cpp68
-rw-r--r--src/shared/cplusplus/CheckDeclaration.h10
-rw-r--r--src/shared/cplusplus/Parser.cpp11
-rw-r--r--src/shared/cplusplus/Symbols.cpp10
-rw-r--r--src/shared/cplusplus/Symbols.h10
-rw-r--r--src/shared/cplusplus/Token.cpp2
11 files changed, 60 insertions, 71 deletions
diff --git a/src/shared/cplusplus/AST.h b/src/shared/cplusplus/AST.h
index a5f910e5c7..e7824f9393 100644
--- a/src/shared/cplusplus/AST.h
+++ b/src/shared/cplusplus/AST.h
@@ -570,7 +570,7 @@ public:
unsigned property_specifier_token;
unsigned lparen_token;
ExpressionAST *type_id;
- SimpleNameAST *type_name;
+ SimpleNameAST *property_name;
unsigned read_token;
SimpleNameAST *read_function;
unsigned write_token;
diff --git a/src/shared/cplusplus/ASTClone.cpp b/src/shared/cplusplus/ASTClone.cpp
index 8fadf080ab..68b907cdcf 100644
--- a/src/shared/cplusplus/ASTClone.cpp
+++ b/src/shared/cplusplus/ASTClone.cpp
@@ -145,8 +145,8 @@ QtPropertyDeclarationAST *QtPropertyDeclarationAST::clone(MemoryPool *pool) cons
ast->lparen_token = lparen_token;
if (type_id)
ast->type_id = type_id->clone(pool);
- if (type_name)
- ast->type_name = type_name->clone(pool);
+ if (property_name)
+ ast->property_name = property_name->clone(pool);
ast->read_token = read_token;
if (read_function)
ast->read_function = read_function->clone(pool);
diff --git a/src/shared/cplusplus/ASTMatcher.cpp b/src/shared/cplusplus/ASTMatcher.cpp
index 75ff5eceb8..0ec34db474 100644
--- a/src/shared/cplusplus/ASTMatcher.cpp
+++ b/src/shared/cplusplus/ASTMatcher.cpp
@@ -220,9 +220,9 @@ bool ASTMatcher::match(QtPropertyDeclarationAST *node, QtPropertyDeclarationAST
else if (! AST::match(node->type_id, pattern->type_id, this))
return false;
- if (! pattern->type_name)
- pattern->type_name = node->type_name;
- else if (! AST::match(node->type_name, pattern->type_name, this))
+ if (! pattern->property_name)
+ pattern->property_name = node->property_name;
+ else if (! AST::match(node->property_name, pattern->property_name, this))
return false;
pattern->read_token = node->read_token;
diff --git a/src/shared/cplusplus/ASTVisit.cpp b/src/shared/cplusplus/ASTVisit.cpp
index e37c964939..430f60679c 100644
--- a/src/shared/cplusplus/ASTVisit.cpp
+++ b/src/shared/cplusplus/ASTVisit.cpp
@@ -112,7 +112,7 @@ void QtPropertyDeclarationAST::accept0(ASTVisitor *visitor)
{
if (visitor->visit(this)) {
accept(type_id, visitor);
- accept(type_name, visitor);
+ accept(property_name, visitor);
accept(read_function, visitor);
accept(write_function, visitor);
accept(reset_function, visitor);
diff --git a/src/shared/cplusplus/CPlusPlusForwardDeclarations.h b/src/shared/cplusplus/CPlusPlusForwardDeclarations.h
index f600362294..836257e04f 100644
--- a/src/shared/cplusplus/CPlusPlusForwardDeclarations.h
+++ b/src/shared/cplusplus/CPlusPlusForwardDeclarations.h
@@ -60,11 +60,7 @@
# elif defined(CPLUSPLUS_BUILD_STATIC_LIB)
# define CPLUSPLUS_EXPORT
# else
-# ifdef ICHECK_BUILD
-# define CPLUSPLUS_EXPORT
-# else
-# define CPLUSPLUS_EXPORT Q_DECL_IMPORT
-# endif
+# define CPLUSPLUS_EXPORT Q_DECL_IMPORT
# endif
#else
# define CPLUSPLUS_EXPORT
diff --git a/src/shared/cplusplus/CheckDeclaration.cpp b/src/shared/cplusplus/CheckDeclaration.cpp
index 7a6e07ce97..b5c402e314 100644
--- a/src/shared/cplusplus/CheckDeclaration.cpp
+++ b/src/shared/cplusplus/CheckDeclaration.cpp
@@ -170,9 +170,7 @@ bool CheckDeclaration::visit(SimpleDeclarationAST *ast)
const bool isQ_SLOT = ast->qt_invokable_token && tokenKind(ast->qt_invokable_token) == T_Q_SLOT;
const bool isQ_SIGNAL = ast->qt_invokable_token && tokenKind(ast->qt_invokable_token) == T_Q_SIGNAL;
-#ifdef ICHECK_BUILD
const bool isQ_INVOKABLE = ast->qt_invokable_token && tokenKind(ast->qt_invokable_token) == T_Q_INVOKABLE;
-#endif
List<Declaration *> **decl_it = &ast->symbols;
for (DeclaratorListAST *it = ast->declarator_list; it; it = it->next) {
@@ -199,10 +197,8 @@ bool CheckDeclaration::visit(SimpleDeclarationAST *ast)
fun->setMethodKey(Function::SignalMethod);
else if (isQ_SLOT)
fun->setMethodKey(Function::SlotMethod);
-#ifdef ICHECK_BUILD
else if (isQ_INVOKABLE)
- fun->setInvokable(true);
-#endif
+ fun->setMethodKey(Function::InvokableMethod);
fun->setVisibility(semantic()->currentVisibility());
} else if (semantic()->currentMethodKey() != Function::NormalMethod) {
translationUnit()->warning(ast->firstToken(),
@@ -266,28 +262,6 @@ bool CheckDeclaration::visit(AccessDeclarationAST *ast)
return false;
}
-#ifdef ICHECK_BUILD
-bool CheckDeclaration::visit(QPropertyDeclarationAST *)
-{
- return false;
-}
-
-bool CheckDeclaration::visit(QEnumDeclarationAST *)
-{
- return false;
-}
-
-bool CheckDeclaration::visit(QFlagsDeclarationAST *)
-{
- return false;
-}
-
-bool CheckDeclaration::visit(QDeclareFlagsDeclarationAST *)
-{
- return false;
-}
-#endif
-
bool CheckDeclaration::visit(AsmDefinitionAST *)
{
return false;
@@ -827,3 +801,43 @@ bool CheckDeclaration::visit(ObjCPropertyDeclarationAST *ast)
return false;
}
+
+bool CheckDeclaration::visit(QtDeclareFlagsDeclarationAST *ast)
+{
+ if (ast->flags_name)
+ semantic()->check(ast->flags_name, _scope);
+ if (ast->enum_name)
+ semantic()->check(ast->enum_name, _scope);
+ return false;
+}
+
+bool CheckDeclaration::visit(QtEnumDeclarationAST *ast)
+{
+ for (NameListAST *iter = ast->enumerator_list; iter; iter = iter->next)
+ semantic()->check(iter->value, _scope);
+ return false;
+}
+
+bool CheckDeclaration::visit(QtFlagsDeclarationAST *ast)
+{
+ for (NameListAST *iter = ast->flag_enums_list; iter; iter = iter->next)
+ semantic()->check(iter->value, _scope);
+ return false;
+}
+
+bool CheckDeclaration::visit(QtPropertyDeclarationAST *ast)
+{
+ if (ast->type_id)
+ semantic()->check(ast->type_id, _scope);
+ if (ast->property_name)
+ semantic()->check(ast->property_name, _scope);
+ if (ast->read_function)
+ semantic()->check(ast->read_function, _scope);
+ if (ast->write_function)
+ semantic()->check(ast->write_function, _scope);
+ if (ast->reset_function)
+ semantic()->check(ast->reset_function, _scope);
+ if (ast->notify_function)
+ semantic()->check(ast->notify_function, _scope);
+ return false;
+}
diff --git a/src/shared/cplusplus/CheckDeclaration.h b/src/shared/cplusplus/CheckDeclaration.h
index 0090a1d670..03661bc68e 100644
--- a/src/shared/cplusplus/CheckDeclaration.h
+++ b/src/shared/cplusplus/CheckDeclaration.h
@@ -77,12 +77,10 @@ protected:
virtual bool visit(SimpleDeclarationAST *ast);
virtual bool visit(EmptyDeclarationAST *ast);
virtual bool visit(AccessDeclarationAST *ast);
-#ifdef ICHECK_BUILD
- virtual bool visit(QPropertyDeclarationAST *ast);
- virtual bool visit(QEnumDeclarationAST *ast);
- virtual bool visit(QFlagsDeclarationAST *ast);
- virtual bool visit(QDeclareFlagsDeclarationAST *ast);
-#endif
+ virtual bool visit(QtPropertyDeclarationAST *ast);
+ virtual bool visit(QtEnumDeclarationAST *ast);
+ virtual bool visit(QtFlagsDeclarationAST *ast);
+ virtual bool visit(QtDeclareFlagsDeclarationAST *ast);
virtual bool visit(AsmDefinitionAST *ast);
virtual bool visit(ExceptionDeclarationAST *ast);
virtual bool visit(FunctionDefinitionAST *ast);
diff --git a/src/shared/cplusplus/Parser.cpp b/src/shared/cplusplus/Parser.cpp
index 33f7660129..9c504f0f54 100644
--- a/src/shared/cplusplus/Parser.cpp
+++ b/src/shared/cplusplus/Parser.cpp
@@ -1792,8 +1792,8 @@ bool Parser::parseQtPropertyDeclaration(DeclarationAST *&node)
if (LA() == T_LPAREN) {
ast->lparen_token = consumeToken();
parseTypeId(ast->type_id);
- ast->type_name = new (_pool) SimpleNameAST;
- match(T_IDENTIFIER, &ast->type_name->identifier_token);
+ ast->property_name = new (_pool) SimpleNameAST;
+ match(T_IDENTIFIER, &ast->property_name->identifier_token);
while (true) {
if (LA() == T_RPAREN) {
@@ -1963,6 +1963,7 @@ bool Parser::parseQtDeclareFlags(DeclarationAST *&node)
ast->flags_name = new (_pool) SimpleNameAST;
match(T_IDENTIFIER, &ast->flags_name->identifier_token);
match(T_COMMA, &ast->comma_token);
+ ast->enum_name = new (_pool) SimpleNameAST;
match(T_IDENTIFIER, &ast->enum_name->identifier_token);
match(T_RPAREN, &ast->rparen_token);
node = ast;
@@ -1995,13 +1996,11 @@ bool Parser::parseMemberSpecification(DeclarationAST *&node)
case T_Q_ENUMS:
return parseQtEnumDeclaration(node);
-#ifdef ICHECK_BUILD
case T_Q_FLAGS:
- return parseQFlags(node);
+ return parseQtFlags(node);
case T_Q_DECLARE_FLAGS:
- return parseQDeclareFlags(node);
-#endif
+ return parseQtDeclareFlags(node);
default:
return parseSimpleDeclaration(node, /*acceptStructDeclarator=*/true);
diff --git a/src/shared/cplusplus/Symbols.cpp b/src/shared/cplusplus/Symbols.cpp
index ca20980d99..1b880dcf6e 100644
--- a/src/shared/cplusplus/Symbols.cpp
+++ b/src/shared/cplusplus/Symbols.cpp
@@ -353,16 +353,6 @@ bool Function::isPureVirtual() const
void Function::setPureVirtual(bool isPureVirtual)
{ f._isPureVirtual = isPureVirtual; }
-#ifdef ICHECK_BUILD
-
-bool Function::isInvokable() const
-{ return f._isInvokable == 1; }
-
-void Function::setInvokable(bool isInvokable)
-{ f._isInvokable = isInvokable; }
-
-#endif
-
bool Function::isAmbiguous() const
{ return f._isAmbiguous; }
diff --git a/src/shared/cplusplus/Symbols.h b/src/shared/cplusplus/Symbols.h
index ab8eb8b3a1..46ee58ff92 100644
--- a/src/shared/cplusplus/Symbols.h
+++ b/src/shared/cplusplus/Symbols.h
@@ -303,7 +303,8 @@ public:
enum MethodKey {
NormalMethod,
SlotMethod,
- SignalMethod
+ SignalMethod,
+ InvokableMethod
};
public:
@@ -351,11 +352,7 @@ public:
void setPureVirtual(bool isPureVirtual);
#ifdef ICHECK_BUILD
-
- bool isInvokable() const;
- void setInvokable(bool isInvokable);
bool isEqualTo(const Function* fct, bool ignoreName = false) const;
-
#endif
// Symbol's interface
@@ -395,9 +392,6 @@ private:
unsigned _isVolatile: 1;
unsigned _isAmbiguous: 1;
unsigned _methodKey: 3;
-#ifdef ICHECK_BUILD
- unsigned _isInvokable: 1;
-#endif
};
union {
unsigned _flags;
diff --git a/src/shared/cplusplus/Token.cpp b/src/shared/cplusplus/Token.cpp
index a0d1e38d78..f071d21d87 100644
--- a/src/shared/cplusplus/Token.cpp
+++ b/src/shared/cplusplus/Token.cpp
@@ -93,9 +93,7 @@ static const char *token_names[] = {
("SIGNAL"), ("SLOT"), ("Q_SIGNAL"), ("Q_SLOT"), ("signals"), ("slots"),
("Q_FOREACH"), ("Q_D"), ("Q_Q"),
-#ifdef ICHECK_BUILD
("Q_INVOKABLE"), ("Q_PROPERTY"), ("Q_ENUMS"), ("Q_FLAGS"), ("Q_DECLARE_FLAGS")
-#endif
};
Token::Token() :