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;