summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clangd/JSONTransport.cpp
diff options
context:
space:
mode:
authorSam McCall <sam.mccall@gmail.com>2018-10-20 15:30:37 +0000
committerSam McCall <sam.mccall@gmail.com>2018-10-20 15:30:37 +0000
commitc008af646620f6718384c2cd95f58a7311fe10fb (patch)
tree4961c6079af876f19462df09f9a0d0fa1176a824 /clang-tools-extra/clangd/JSONTransport.cpp
parent0c35aa114d34c4f8add2a532de3a797ef0c1b667 (diff)
downloadbcm5719-llvm-c008af646620f6718384c2cd95f58a7311fe10fb.tar.gz
bcm5719-llvm-c008af646620f6718384c2cd95f58a7311fe10fb.zip
[clangd] Namespace style cleanup in cpp files. NFC.
Standardize on the most common namespace setup in our *.cpp files: using namespace llvm; namespace clang { namespace clangd { void foo(StringRef) { ... } And remove redundant llvm:: qualifiers. (Except for cases like make_unique where this causes problems with std:: and ADL). This choice is pretty arbitrary, but some broad consistency is nice. This is going to conflict with everything. Sorry :-/ Squash the other configurations: A) using namespace llvm; using namespace clang; using namespace clangd; void clangd::foo(StringRef); This is in some of the older files. (It prevents accidentally defining a new function instead of one in the header file, for what that's worth). B) namespace clang { namespace clangd { void foo(llvm::StringRef) { ... } This is fine, but in practice the using directive often gets added over time. C) namespace clang { namespace clangd { using namespace llvm; // inside the namespace This was pretty common, but is a bit misleading: name lookup preferrs clang::clangd::foo > clang::foo > llvm:: foo (no matter where the using directive is). llvm-svn: 344850
Diffstat (limited to 'clang-tools-extra/clangd/JSONTransport.cpp')
-rw-r--r--clang-tools-extra/clangd/JSONTransport.cpp62
1 files changed, 30 insertions, 32 deletions
diff --git a/clang-tools-extra/clangd/JSONTransport.cpp b/clang-tools-extra/clangd/JSONTransport.cpp
index 0d5f409ba6c..83ef49b0324 100644
--- a/clang-tools-extra/clangd/JSONTransport.cpp
+++ b/clang-tools-extra/clangd/JSONTransport.cpp
@@ -25,7 +25,7 @@ json::Object encodeError(Error E) {
Code = L.Code;
return Error::success();
}))
- Message = llvm::toString(std::move(Unhandled));
+ Message = toString(std::move(Unhandled));
return json::Object{
{"message", std::move(Message)},
@@ -42,8 +42,8 @@ Error decodeError(const json::Object &O) {
class JSONTransport : public Transport {
public:
- JSONTransport(std::FILE *In, llvm::raw_ostream &Out,
- llvm::raw_ostream *InMirror, bool Pretty, JSONStreamStyle Style)
+ JSONTransport(std::FILE *In, raw_ostream &Out, raw_ostream *InMirror,
+ bool Pretty, JSONStreamStyle Style)
: In(In), Out(Out), InMirror(InMirror ? *InMirror : nulls()),
Pretty(Pretty), Style(Style) {}
@@ -90,7 +90,7 @@ public:
} else {
// Parse error. Log the raw message.
vlog("<<< {0}\n", *JSON);
- elog("JSON parse error: {0}", llvm::toString(Doc.takeError()));
+ elog("JSON parse error: {0}", toString(Doc.takeError()));
}
}
}
@@ -99,12 +99,12 @@ public:
private:
// Dispatches incoming message to Handler onNotify/onCall/onReply.
- bool handleMessage(llvm::json::Value Message, MessageHandler &Handler);
+ bool handleMessage(json::Value Message, MessageHandler &Handler);
// Writes outgoing message to Out stream.
- void sendMessage(llvm::json::Value Message) {
+ void sendMessage(json::Value Message) {
std::string S;
- llvm::raw_string_ostream OS(S);
- OS << llvm::formatv(Pretty ? "{0:2}" : "{0}", Message);
+ raw_string_ostream OS(S);
+ OS << formatv(Pretty ? "{0:2}" : "{0}", Message);
OS.flush();
Out << "Content-Length: " << S.size() << "\r\n\r\n" << S;
Out.flush();
@@ -112,21 +112,21 @@ private:
}
// Read raw string messages from input stream.
- llvm::Optional<std::string> readRawMessage() {
+ Optional<std::string> readRawMessage() {
return Style == JSONStreamStyle::Delimited ? readDelimitedMessage()
: readStandardMessage();
}
- llvm::Optional<std::string> readDelimitedMessage();
- llvm::Optional<std::string> readStandardMessage();
+ Optional<std::string> readDelimitedMessage();
+ Optional<std::string> readStandardMessage();
std::FILE *In;
- llvm::raw_ostream &Out;
- llvm::raw_ostream &InMirror;
+ raw_ostream &Out;
+ raw_ostream &InMirror;
bool Pretty;
JSONStreamStyle Style;
};
-bool JSONTransport::handleMessage(llvm::json::Value Message,
+bool JSONTransport::handleMessage(json::Value Message,
MessageHandler &Handler) {
// Message must be an object with "jsonrpc":"2.0".
auto *Object = Message.getAsObject();
@@ -135,7 +135,7 @@ bool JSONTransport::handleMessage(llvm::json::Value Message,
return false;
}
// ID may be any JSON value. If absent, this is a notification.
- llvm::Optional<json::Value> ID;
+ Optional<json::Value> ID;
if (auto *I = Object->get("id"))
ID = std::move(*I);
auto Method = Object->getString("method");
@@ -172,7 +172,7 @@ bool readLine(std::FILE *In, std::string &Out) {
for (;;) {
Out.resize(Size + BufSize);
// Handle EINTR which is sent when a debugger attaches on some platforms.
- if (!llvm::sys::RetryAfterSignal(nullptr, ::fgets, &Out[Size], BufSize, In))
+ if (!sys::RetryAfterSignal(nullptr, ::fgets, &Out[Size], BufSize, In))
return false;
clearerr(In);
// If the line contained null bytes, anything after it (including \n) will
@@ -189,17 +189,17 @@ bool readLine(std::FILE *In, std::string &Out) {
// Returns None when:
// - ferror() or feof() are set.
// - Content-Length is missing or empty (protocol error)
-llvm::Optional<std::string> JSONTransport::readStandardMessage() {
+Optional<std::string> JSONTransport::readStandardMessage() {
// A Language Server Protocol message starts with a set of HTTP headers,
// delimited by \r\n, and terminated by an empty line (\r\n).
unsigned long long ContentLength = 0;
std::string Line;
while (true) {
if (feof(In) || ferror(In) || !readLine(In, Line))
- return llvm::None;
+ return None;
InMirror << Line;
- llvm::StringRef LineRef(Line);
+ StringRef LineRef(Line);
// We allow comments in headers. Technically this isn't part
@@ -214,7 +214,7 @@ llvm::Optional<std::string> JSONTransport::readStandardMessage() {
"The previous value for this message ({0}) was ignored.",
ContentLength);
}
- llvm::getAsUnsignedInteger(LineRef.trim(), 0, ContentLength);
+ getAsUnsignedInteger(LineRef.trim(), 0, ContentLength);
continue;
} else if (!LineRef.trim().empty()) {
// It's another header, ignore it.
@@ -231,22 +231,22 @@ llvm::Optional<std::string> JSONTransport::readStandardMessage() {
elog("Refusing to read message with long Content-Length: {0}. "
"Expect protocol errors",
ContentLength);
- return llvm::None;
+ return None;
}
if (ContentLength == 0) {
log("Warning: Missing Content-Length header, or zero-length message.");
- return llvm::None;
+ return None;
}
std::string JSON(ContentLength, '\0');
for (size_t Pos = 0, Read; Pos < ContentLength; Pos += Read) {
// Handle EINTR which is sent when a debugger attaches on some platforms.
- Read = llvm::sys::RetryAfterSignal(0u, ::fread, &JSON[Pos], 1,
- ContentLength - Pos, In);
+ Read = sys::RetryAfterSignal(0u, ::fread, &JSON[Pos], 1,
+ ContentLength - Pos, In);
if (Read == 0) {
elog("Input was aborted. Read only {0} bytes of expected {1}.", Pos,
ContentLength);
- return llvm::None;
+ return None;
}
InMirror << StringRef(&JSON[Pos], Read);
clearerr(In); // If we're done, the error was transient. If we're not done,
@@ -261,12 +261,12 @@ llvm::Optional<std::string> JSONTransport::readStandardMessage() {
// - lines starting with # are ignored.
// This is a testing path, so favor simplicity over performance here.
// When returning None, feof() or ferror() will be set.
-llvm::Optional<std::string> JSONTransport::readDelimitedMessage() {
+Optional<std::string> JSONTransport::readDelimitedMessage() {
std::string JSON;
std::string Line;
while (readLine(In, Line)) {
InMirror << Line;
- auto LineRef = llvm::StringRef(Line).trim();
+ auto LineRef = StringRef(Line).trim();
if (LineRef.startswith("#")) // comment
continue;
@@ -279,17 +279,15 @@ llvm::Optional<std::string> JSONTransport::readDelimitedMessage() {
if (ferror(In)) {
elog("Input error while reading message!");
- return llvm::None;
+ return None;
}
return std::move(JSON); // Including at EOF
}
} // namespace
-std::unique_ptr<Transport> newJSONTransport(std::FILE *In,
- llvm::raw_ostream &Out,
- llvm::raw_ostream *InMirror,
- bool Pretty,
+std::unique_ptr<Transport> newJSONTransport(std::FILE *In, raw_ostream &Out,
+ raw_ostream *InMirror, bool Pretty,
JSONStreamStyle Style) {
return llvm::make_unique<JSONTransport>(In, Out, InMirror, Pretty, Style);
}
OpenPOWER on IntegriCloud