[PATCH] D124240: [clangd][NFC] Reduce memory usage while building dex
Kadir Cetinkaya via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Fri Apr 22 08:40:05 PDT 2022
kadircet updated this revision to Diff 424489.
kadircet marked 2 inline comments as done.
kadircet added a comment.
Copy-assign to empty containers rather than clear.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D124240/new/
https://reviews.llvm.org/D124240
Files:
clang-tools-extra/clangd/index/dex/Dex.cpp
Index: clang-tools-extra/clangd/index/dex/Dex.cpp
===================================================================
--- clang-tools-extra/clangd/index/dex/Dex.cpp
+++ clang-tools-extra/clangd/index/dex/Dex.cpp
@@ -13,14 +13,19 @@
#include "URI.h"
#include "index/Index.h"
#include "index/dex/Iterator.h"
+#include "index/dex/Token.h"
#include "index/dex/Trigram.h"
#include "support/Logger.h"
#include "support/Trace.h"
+#include "llvm/ADT/DenseMap.h"
+#include "llvm/ADT/StringMap.h"
#include "llvm/ADT/StringSet.h"
#include "llvm/Support/Path.h"
#include "llvm/Support/ScopedPrinter.h"
#include <algorithm>
#include <queue>
+#include <utility>
+#include <vector>
namespace clang {
namespace clangd {
@@ -76,23 +81,38 @@
}
// Assemble the final compressed posting lists for the added symbols.
- llvm::DenseMap<Token, PostingList> build() {
+ llvm::DenseMap<Token, PostingList> build() && {
llvm::DenseMap<Token, PostingList> Result(/*InitialReserve=*/
TrigramDocs.size() +
RestrictedCCDocs.size() +
TypeDocs.size() +
ScopeDocs.size() +
ProximityDocs.size());
- for (const auto &E : TrigramDocs)
+ // Tear down intermediate structs as we go to reduce memory usage.
+ // Since we're trying to get rid of underlying allocations, clearing the
+ // containers is not enough.
+ auto CreatePostingList =
+ [&Result](Token::Kind TK, llvm::StringMap<std::vector<DocID>> &Docs) {
+ for (auto &E : Docs) {
+ Result.try_emplace(Token(TK, E.first()), E.second);
+ E.second = {};
+ }
+ Docs = {};
+ };
+ CreatePostingList(Token::Kind::Type, TypeDocs);
+ CreatePostingList(Token::Kind::Scope, ScopeDocs);
+ CreatePostingList(Token::Kind::ProximityURI, ProximityDocs);
+
+ // TrigramDocs are stored in a DenseMap and RestrictedCCDocs is not even a
+ // map, treat them specially.
+ for (auto &E : TrigramDocs) {
Result.try_emplace(Token(Token::Kind::Trigram, E.first.str()), E.second);
- for (const auto &E : TypeDocs)
- Result.try_emplace(Token(Token::Kind::Type, E.first()), E.second);
- for (const auto &E : ScopeDocs)
- Result.try_emplace(Token(Token::Kind::Scope, E.first()), E.second);
- for (const auto &E : ProximityDocs)
- Result.try_emplace(Token(Token::Kind::ProximityURI, E.first()), E.second);
+ E.second = {};
+ }
+ TrigramDocs = llvm::DenseMap<Trigram, std::vector<DocID>>{};
if (!RestrictedCCDocs.empty())
- Result.try_emplace(RestrictedForCodeCompletion, RestrictedCCDocs);
+ Result.try_emplace(RestrictedForCodeCompletion,
+ std::move(RestrictedCCDocs));
return Result;
}
};
@@ -125,7 +145,7 @@
IndexBuilder Builder;
for (DocID SymbolRank = 0; SymbolRank < Symbols.size(); ++SymbolRank)
Builder.add(*Symbols[SymbolRank], SymbolRank);
- InvertedIndex = Builder.build();
+ InvertedIndex = std::move(Builder).build();
}
std::unique_ptr<Iterator> Dex::iterator(const Token &Tok) const {
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D124240.424489.patch
Type: text/x-patch
Size: 3256 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20220422/29a44028/attachment-0001.bin>
More information about the cfe-commits
mailing list