[prev in list] [next in list] [prev in thread] [next in thread] 

List:       kde-commits
Subject:    kdevelop/languages/cpp
From:       Roberto Raggi <roberto () kdevelop ! org>
Date:       2003-11-13 14:16:32
[Download RAW message or body]

CVS commit by raggi: 


now the class store works with C-style typedef/struct definitions like

typedef struct
{
   int z;
} DATA;

CCMAIL: 66825-done@bugs.kde.org


  M +15 -1     store_walker.cpp   1.57
  M +3 -1      store_walker.h   1.14


--- kdevelop/languages/cpp/store_walker.cpp  #1.56:1.57
@@ -43,4 +43,6 @@ void StoreWalker::parseTranslationUnit( 
     m_inSignals = false;
     m_inStorageSpec = false;
+    m_inTypedef = false;
+    m_currentDeclarator = 0;
     m_anon = 0;
     m_imports.clear();
@@ -110,5 +112,15 @@ void StoreWalker::parseUsingDirective( U
 void StoreWalker::parseTypedef( TypedefAST* ast )
 {
+    DeclaratorAST* oldDeclarator = m_currentDeclarator;
+    
+    if( ast && ast->initDeclaratorList() && ast->initDeclaratorList()->initDeclaratorList().count() > 0 ) {
+            QPtrList<InitDeclaratorAST> lst( ast->initDeclaratorList()->initDeclaratorList() );
+            m_currentDeclarator = lst.at( 0 )->declarator();
+    }
+    
+    m_inTypedef = true;    
     TreeParser::parseTypedef( ast );
+    m_inTypedef = false;
+    m_currentDeclarator = oldDeclarator;
 }
 
@@ -260,5 +272,7 @@ void StoreWalker::parseClassSpecifier( C
 
     QString className;
-    if( !ast->name() ){
+    if( !ast->name() && m_currentDeclarator && m_currentDeclarator->declaratorId() ) {
+        className = m_currentDeclarator->declaratorId()->text().stripWhiteSpace();
+    } else if( !ast->name() ){
         QFileInfo fileInfo( m_fileName );
         QString shortFileName = fileInfo.baseName();

--- kdevelop/languages/cpp/store_walker.h  #1.13:1.14
@@ -73,5 +73,7 @@ private:
     int m_anon;
     bool m_inStorageSpec;
+    bool m_inTypedef;
 
+    DeclaratorAST* m_currentDeclarator;
     QValueStack<NamespaceDom> m_currentNamespace;
     QValueStack<ClassDom> m_currentClass;


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic