From fc17a4226b13c983584817f52dfb2de81259f467 Mon Sep 17 00:00:00 2001 From: Roberto Raggi Date: Fri, 13 Aug 2010 10:57:12 +0200 Subject: Process simple declarations. --- src/shared/cplusplus/Bind.cpp | 28 +++++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) (limited to 'src/shared/cplusplus') diff --git a/src/shared/cplusplus/Bind.cpp b/src/shared/cplusplus/Bind.cpp index ebaac0a934..efd3ebc772 100644 --- a/src/shared/cplusplus/Bind.cpp +++ b/src/shared/cplusplus/Bind.cpp @@ -1504,12 +1504,34 @@ bool Bind::visit(SimpleDeclarationAST *ast) for (SpecifierListAST *it = ast->decl_specifier_list; it; it = it->next) { type = this->specifier(it->value, type); } + + List **symbolTail = &ast->symbols; + for (DeclaratorListAST *it = ast->declarator_list; it; it = it->next) { DeclaratorIdAST *declaratorId = 0; - FullySpecifiedType declTy = this->declarator(it->value, type, &declaratorId); + FullySpecifiedType declTy = this->declarator(it->value, type.qualifiedType(), &declaratorId); + + const Name *declName = 0; + unsigned sourceLocation = ast->firstToken(); + if (declaratorId && declaratorId->name) { + sourceLocation = declaratorId->firstToken(); + declName = declaratorId->name->name; + } + + Declaration *decl = control()->newDeclaration(sourceLocation, declName); + decl->setType(declTy); + if (_scope->isClass()) { + decl->setVisibility(_visibility); + + if (Function *funTy = decl->type()->asFunctionType()) { + funTy->setMethodKey(_methodKey); + } + } + _scope->addMember(decl); + + *symbolTail = new (translationUnit()->memoryPool()) List(decl); + symbolTail = &(*symbolTail)->next; } - // unsigned semicolon_token = ast->semicolon_token; - // List *symbols = ast->symbols; return false; } -- cgit v1.2.1