diff --git a/Release/include/cpprest/asyncrt_utils.h b/Release/include/cpprest/asyncrt_utils.h index 3d7f3ee5e0..73b6f5b97e 100644 --- a/Release/include/cpprest/asyncrt_utils.h +++ b/Release/include/cpprest/asyncrt_utils.h @@ -197,6 +197,11 @@ namespace conversions return print_string(val, std::locale()); } + inline utility::string_t print_string(const utility::string_t &val) + { + return val; + } + template Target scan_string(const utility::string_t &str, const std::locale &loc) { @@ -216,6 +221,11 @@ namespace conversions { return scan_string(str, std::locale()); } + + inline utility::string_t scan_string(const utility::string_t &str) + { + return str; + } } namespace details diff --git a/Release/include/cpprest/base_uri.h b/Release/include/cpprest/base_uri.h index ee24fb453e..e6428e3e5c 100644 --- a/Release/include/cpprest/base_uri.h +++ b/Release/include/cpprest/base_uri.h @@ -223,6 +223,12 @@ namespace web { /// uri() { m_uri = _XPLATSTR("/");}; + /// + /// Creates a URI from the given URI components. + /// + /// A URI components object to create the URI instance. + _ASYNCRTIMP uri(const details::uri_components &components); + /// /// Creates a URI from the given encoded string. This will throw an exception if the string /// does not contain a valid URI. Use uri::validate if processing user-input. diff --git a/Release/include/cpprest/http_headers.h b/Release/include/cpprest/http_headers.h index 388fb4bd1c..0d318cbee4 100644 --- a/Release/include/cpprest/http_headers.h +++ b/Release/include/cpprest/http_headers.h @@ -159,7 +159,7 @@ class http_headers { if (has(name)) { - m_headers[name] = m_headers[name].append(_XPLATSTR(", ") + utility::conversions::print_string(value)); + m_headers[name].append(_XPLATSTR(", ")).append(utility::conversions::print_string(value)); } else { diff --git a/Release/src/uri/uri.cpp b/Release/src/uri/uri.cpp index 104719c81d..d161a5d924 100644 --- a/Release/src/uri/uri.cpp +++ b/Release/src/uri/uri.cpp @@ -53,28 +53,27 @@ utility::string_t uri_components::join() m_path.insert(m_path.begin(), 1, _XPLATSTR('/')); } - utility::ostringstream_t os; - os.imbue(std::locale::classic()); + utility::string_t ret; if (!m_scheme.empty()) { - os << m_scheme << _XPLATSTR(':'); + ret.append(m_scheme).append({ _XPLATSTR(':') }); } if (!m_host.empty()) { - os << _XPLATSTR("//"); + ret.append(_XPLATSTR("//")); if (!m_user_info.empty()) { - os << m_user_info << _XPLATSTR('@'); + ret.append(m_user_info).append({ _XPLATSTR('@') }); } - os << m_host; + ret.append(m_host); if (m_port > 0) { - os << _XPLATSTR(':') << m_port; + ret.append({ _XPLATSTR(':') }).append(utility::conversions::print_string(m_port, std::locale::classic())); } } @@ -83,27 +82,37 @@ utility::string_t uri_components::join() // only add the leading slash when the host is present if (!m_host.empty() && m_path.front() != _XPLATSTR('/')) { - os << _XPLATSTR('/'); + ret.append({ _XPLATSTR('/') }); } - os << m_path; + + ret.append(m_path); } if (!m_query.empty()) { - os << _XPLATSTR('?') << m_query; + ret.append({ _XPLATSTR('?') }).append(m_query); } if (!m_fragment.empty()) { - os << _XPLATSTR('#') << m_fragment; + ret.append({ _XPLATSTR('#') }).append(m_fragment); } - return os.str(); + return ret; } } using namespace details; +uri::uri(const details::uri_components &components) : m_components(components) +{ + m_uri = m_components.join(); + if (!details::uri_parser::validate(m_uri)) + { + throw uri_exception("provided uri is invalid: " + utility::conversions::to_utf8string(m_uri)); + } +} + uri::uri(const utility::string_t &uri_string) { if (!details::uri_parser::parse(uri_string, m_components)) diff --git a/Release/src/uri/uri_builder.cpp b/Release/src/uri/uri_builder.cpp index a94a22eb9b..28085161c0 100644 --- a/Release/src/uri/uri_builder.cpp +++ b/Release/src/uri/uri_builder.cpp @@ -110,7 +110,7 @@ utility::string_t uri_builder::to_string() uri uri_builder::to_uri() { - return uri(m_uri.join()); + return uri(m_uri); } bool uri_builder::is_valid() diff --git a/Release/src/uri/uri_parser.cpp b/Release/src/uri/uri_parser.cpp index 1d4f7e33e7..75bf73f273 100644 --- a/Release/src/uri/uri_parser.cpp +++ b/Release/src/uri/uri_parser.cpp @@ -100,7 +100,7 @@ bool parse(const utility::string_t &encoded_string, uri_components &components) // convert scheme to lowercase std::transform(components.m_scheme.begin(), components.m_scheme.end(), components.m_scheme.begin(), [](utility::char_t c) { - return std::tolower(c, std::locale::classic()); + return (utility::char_t)tolower(c); }); } else @@ -119,7 +119,7 @@ bool parse(const utility::string_t &encoded_string, uri_components &components) // convert host to lowercase std::transform(components.m_host.begin(), components.m_host.end(), components.m_host.begin(), [](utility::char_t c) { - return std::tolower(c, std::locale::classic()); + return (utility::char_t)tolower(c); }); } else