X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=folly%2FUri.cpp;h=57ddfb42df495f9fc594582846bd2e471a94f8e4;hb=520e20a8baebc98a5ec84d67865da4cf9819f88a;hp=bc94a31fb33a6cd688225ee97e9354eee6f5dffd;hpb=321542683a01c3f334047531e9b487f047129775;p=folly.git diff --git a/folly/Uri.cpp b/folly/Uri.cpp index bc94a31f..57ddfb42 100644 --- a/folly/Uri.cpp +++ b/folly/Uri.cpp @@ -1,5 +1,5 @@ /* - * Copyright 2016 Facebook, Inc. + * Copyright 2017 Facebook, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -16,22 +16,23 @@ #include -#include +#include + #include namespace folly { namespace { -fbstring submatch(const boost::cmatch& m, size_t idx) { +std::string submatch(const boost::cmatch& m, int idx) { auto& sub = m[idx]; - return fbstring(sub.first, sub.second); + return std::string(sub.first, sub.second); } template void toLower(String& s) { for (auto& c : s) { - c = tolower(c); + c = char(tolower(c)); } } @@ -61,7 +62,7 @@ Uri::Uri(StringPiece str) : hasAuthority_(false), port_(0) { authorityAndPathRegex)) { // Does not start with //, doesn't have authority hasAuthority_ = false; - path_ = authorityAndPath.fbstr(); + path_ = authorityAndPath.str(); } else { static const boost::regex authorityRegex( "(?:([^@:]*)(?::([^@]*))?@)?" // username, password @@ -96,8 +97,8 @@ Uri::Uri(StringPiece str) : hasAuthority_(false), port_(0) { fragment_ = submatch(match, 4); } -fbstring Uri::authority() const { - fbstring result; +std::string Uri::authority() const { + std::string result; // Port is 5 characters max and we have up to 3 delimiters. result.reserve(host().size() + username().size() + password().size() + 8); @@ -123,7 +124,7 @@ fbstring Uri::authority() const { return result; } -fbstring Uri::hostname() const { +std::string Uri::hostname() const { if (host_.size() > 0 && host_[0] == '[') { // If it starts with '[', then it should end with ']', this is ensured by // regex @@ -132,7 +133,7 @@ fbstring Uri::hostname() const { return host_; } -const std::vector>& Uri::getQueryParams() { +const std::vector>& Uri::getQueryParams() { if (!query_.empty() && queryParams_.empty()) { // Parse query string static const boost::regex queryParamRegex( @@ -150,8 +151,8 @@ const std::vector>& Uri::getQueryParams() { continue; } queryParams_.emplace_back( - fbstring((*itr)[2].first, (*itr)[2].second), // parameter name - fbstring((*itr)[3].first, (*itr)[3].second) // parameter value + std::string((*itr)[2].first, (*itr)[2].second), // parameter name + std::string((*itr)[3].first, (*itr)[3].second) // parameter value ); } }