| Summary: | slow c++ code import | ||
|---|---|---|---|
| Product: | [Applications] umbrello | Reporter: | Ralf Habacker <ralf.habacker> | 
| Component: | general | Assignee: | Umbrello Development Group <umbrello-devel> | 
| Status: | RESOLVED FIXED | ||
| Severity: | normal | ||
| Priority: | NOR | ||
| Version First Reported In: | SVN | ||
| Target Milestone: | --- | ||
| Platform: | Other | ||
| OS: | All | ||
| Latest Commit: | Version Fixed/Implemented In: | 4.10.2 | |
| Sentry Crash Report: | |||
| 
        
          Description
        
        
          Ralf Habacker
        
        
        
        
          2013-03-16 09:44:16 UTC
        
       There are two reasons why the import is so slow. 1. The c+ class importer parses by default all includes file for a given file. The advantage is that umbrello is able to find most definitions and do not need to ask the user to identify unknown namespaces or classes. The drawback is that the parser needs much time to parse. A solution is here to add an option, which disables the dependency resolution and let umbrello ask for non defined namespaces or classes. 2. The Tree View object needs much update time when adding entries. Hiding the related dockwindow the list view while importing will speed up the import. Another approach would be to include the c++ parser from recent kdevelop project. Unfortunally this has been rejected https://bugs.kde.org/show_bug.cgi?id=297321 Git commit 52fb1a74cf88216f6b9df8a8bfc6c84d6e9c3eaa by Ralf Habacker. Committed on 15/03/2013 at 18:28. Pushed by habacker into branch 'master'. Add 'resolve dependencies' option to c++ code import settings. If this attribute is set to false included files are not parsed, which speeds up importing. M +2 -2 umbrello/codeimport/cppimport.cpp M +3 -0 umbrello/dialogs/codeimportoptionspage.cpp M +15 -2 umbrello/dialogs/codeimportoptionspage.ui M +1 -0 umbrello/optionstate.h M +5 -0 umbrello/umbrello.kcfg M +2 -0 umbrello/uml.cpp http://commits.kde.org/umbrello/52fb1a74cf88216f6b9df8a8bfc6c84d6e9c3eaa Git commit deed8d83b1303daaa7ca11a990a56560d1a091fb by Ralf Habacker. Committed on 16/03/2013 at 15:19. Pushed by habacker into branch 'master'. Speed up c++ code import by hiding the list view dock window. M +7 -0 umbrello/codeimpwizard/codeimpstatuspage.cpp M +1 -0 umbrello/codeimpwizard/codeimpstatuspage.h http://commits.kde.org/umbrello/deed8d83b1303daaa7ca11a990a56560d1a091fb Git commit 66228d2fdc7b86d41b68b7c0c4b95ada4a27a569 by Ralf Habacker. Committed on 15/03/2013 at 18:28. Pushed by habacker into branch 'KDE/4.10'. Add 'resolve dependencies' option to c++ code import settings. If this attribute is set to false included files are not parsed, which speeds up importing. M +2 -2 umbrello/codeimport/cppimport.cpp M +3 -0 umbrello/dialogs/codeimportoptionspage.cpp M +15 -2 umbrello/dialogs/codeimportoptionspage.ui M +1 -0 umbrello/optionstate.h M +5 -0 umbrello/umbrello.kcfg M +2 -0 umbrello/uml.cpp http://commits.kde.org/umbrello/66228d2fdc7b86d41b68b7c0c4b95ada4a27a569 |