[PATCH] D93531: [clangd] Reuse buffer for JSONTransport::sendMessage
Nathan James via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Tue Dec 22 03:31:13 PST 2020
This revision was automatically updated to reflect the committed changes.
Closed by commit rG4b3633cf2cb6: [clangd] Reuse buffer for JSONTransport::sendMessage (authored by njames93).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D93531/new/
https://reviews.llvm.org/D93531
Files:
clang-tools-extra/clangd/JSONTransport.cpp
Index: clang-tools-extra/clangd/JSONTransport.cpp
===================================================================
--- clang-tools-extra/clangd/JSONTransport.cpp
+++ clang-tools-extra/clangd/JSONTransport.cpp
@@ -126,13 +126,13 @@
bool handleMessage(llvm::json::Value Message, MessageHandler &Handler);
// Writes outgoing message to Out stream.
void sendMessage(llvm::json::Value Message) {
- std::string S;
- llvm::raw_string_ostream OS(S);
+ OutputBuffer.clear();
+ llvm::raw_svector_ostream OS(OutputBuffer);
OS << llvm::formatv(Pretty ? "{0:2}" : "{0}", Message);
- OS.flush();
- Out << "Content-Length: " << S.size() << "\r\n\r\n" << S;
+ Out << "Content-Length: " << OutputBuffer.size() << "\r\n\r\n"
+ << OutputBuffer;
Out.flush();
- vlog(">>> {0}\n", S);
+ vlog(">>> {0}\n", OutputBuffer);
}
// Read raw string messages from input stream.
@@ -143,6 +143,7 @@
llvm::Optional<std::string> readDelimitedMessage();
llvm::Optional<std::string> readStandardMessage();
+ llvm::SmallVector<char, 0> OutputBuffer;
std::FILE *In;
llvm::raw_ostream &Out;
llvm::raw_ostream &InMirror;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D93531.313283.patch
Type: text/x-patch
Size: 1163 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20201222/c4bf42b2/attachment.bin>
More information about the cfe-commits
mailing list