diff --git a/src/plugins/cppeditor/cppcheckundefinedsymbols.cpp b/src/plugins/cppeditor/cppcheckundefinedsymbols.cpp index bf3f3dfdd9b..7e9bffa9c11 100644 --- a/src/plugins/cppeditor/cppcheckundefinedsymbols.cpp +++ b/src/plugins/cppeditor/cppcheckundefinedsymbols.cpp @@ -278,8 +278,10 @@ void CheckUndefinedSymbols::runFunctor(QFutureInterface &future) _future = &future; _diagnosticMessages.clear(); - if (_doc->translationUnit()) + if (_doc->translationUnit()) { accept(_doc->translationUnit()->ast()); + flush(); + } } bool CheckUndefinedSymbols::warning(unsigned line, unsigned column, const QString &text, unsigned length) @@ -464,7 +466,10 @@ void CheckUndefinedSymbols::endVisit(TemplateDeclarationAST *) void CheckUndefinedSymbols::addTypeUsage(const Use &use) { - _future->reportResult(use); // ### TODO: compress + _typeUsages.append(use); + + if (_typeUsages.size() == 50) + flush(); } void CheckUndefinedSymbols::addTypeUsage(ClassOrNamespace *b, NameAST *ast) @@ -548,3 +553,12 @@ Scope *CheckUndefinedSymbols::findScope(AST *ast) const return scope; } + +void CheckUndefinedSymbols::flush() +{ + if (_typeUsages.isEmpty()) + return; + + _future->reportResults(_typeUsages); + _typeUsages.clear(); +} diff --git a/src/plugins/cppeditor/cppcheckundefinedsymbols.h b/src/plugins/cppeditor/cppcheckundefinedsymbols.h index f331efdc96c..14c9335a76d 100644 --- a/src/plugins/cppeditor/cppcheckundefinedsymbols.h +++ b/src/plugins/cppeditor/cppcheckundefinedsymbols.h @@ -89,6 +89,8 @@ protected: unsigned startOfTemplateDeclaration(TemplateDeclarationAST *ast) const; Scope *findScope(AST *ast) const; + void flush(); + private: Document::Ptr _doc; LookupContext _context; @@ -97,6 +99,7 @@ private: QSet _potentialTypes; QList _scopes; QList _templateDeclarationStack; + QVector _typeUsages; QFutureInterface *_future; };