diff --git a/src/shared/cplusplus/Bind.cpp b/src/shared/cplusplus/Bind.cpp index 89cdbf6ad43bc4d7546e08cc5bc0629fda00993d..97d2f491d6fe4dd60028217c32cc94410b0f9089 100644 --- a/src/shared/cplusplus/Bind.cpp +++ b/src/shared/cplusplus/Bind.cpp @@ -1905,7 +1905,6 @@ bool Bind::visit(FunctionDefinitionAST *ast) if (CompoundStatementAST *c = ast->function_body->asCompoundStatement()) { if (c->symbol) { - fun->setBlock(c->symbol); fun->setEndOffset(c->symbol->endOffset()); } } diff --git a/src/shared/cplusplus/Symbols.cpp b/src/shared/cplusplus/Symbols.cpp index a2259e715ae01d68f1d00a794c03ee80a9a37d9a..121ea0364ea7162168c349663fe06f02cc450e27 100644 --- a/src/shared/cplusplus/Symbols.cpp +++ b/src/shared/cplusplus/Symbols.cpp @@ -164,7 +164,6 @@ void TypenameArgument::visitSymbol0(SymbolVisitor *visitor) Function::Function(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : Scope(translationUnit, sourceLocation, name), - _block(0), _flags(0) { } @@ -189,12 +188,6 @@ int Function::methodKey() const void Function::setMethodKey(int key) { f._methodKey = key; } -Block *Function::block() const -{ return _block; } - -void Function::setBlock(Block *block) -{ _block = block; } - bool Function::isEqualTo(const Type *other) const { const Function *o = other->asFunctionType(); @@ -293,10 +286,10 @@ bool Function::hasReturnType() const unsigned Function::argumentCount() const { - if (_block) - return memberCount() - 1; - - return memberCount(); + const unsigned c = memberCount(); + if (c > 0 && memberAt(c - 1)->isBlock()) + return c - 1; + return c; } Symbol *Function::argumentAt(unsigned index) const diff --git a/src/shared/cplusplus/Symbols.h b/src/shared/cplusplus/Symbols.h index b3f388f9774ff81ddc8e27f3d6bfdecd80960b0e..dd7fe67a1a4e084b885566f772234ab18beb6f28 100644 --- a/src/shared/cplusplus/Symbols.h +++ b/src/shared/cplusplus/Symbols.h @@ -297,9 +297,6 @@ public: int methodKey() const; void setMethodKey(int key); - Block *block() const; - void setBlock(Block *block); - FullySpecifiedType returnType() const; void setReturnType(const FullySpecifiedType &returnType); @@ -360,7 +357,6 @@ protected: private: FullySpecifiedType _returnType; - Block *_block; struct Flags { unsigned _isVirtual: 1; unsigned _isVariadic: 1;