diff --git a/base/buffer_vector.hpp b/base/buffer_vector.hpp index f807cf18c7..d9df450959 100644 --- a/base/buffer_vector.hpp +++ b/base/buffer_vector.hpp @@ -46,7 +46,7 @@ private: MoveStatic(buffer_vector & rhs) { for (size_t i = 0; i < rhs.m_size; ++i) - Swap(m_static[i], rhs.m_static[i]); + std::swap(m_static[i], rhs.m_static[i]); } #endif diff --git a/base/stl_add.hpp b/base/stl_add.hpp index d30c16d2b8..5df723ee69 100644 --- a/base/stl_add.hpp +++ b/base/stl_add.hpp @@ -3,6 +3,7 @@ #include #include #include +#include namespace my { diff --git a/base/string_utils.cpp b/base/string_utils.cpp index 6379deab9e..d1ac84b24a 100644 --- a/base/string_utils.cpp +++ b/base/string_utils.cpp @@ -101,14 +101,14 @@ bool to_float(char const * s, float & f) { char * stop; f = strtof(s, &stop); - return *stop == 0 && s != stop && isfinite(f); + return *stop == 0 && s != stop && std::isfinite(f); } bool to_double(char const * s, double & d) { char * stop; d = strtod(s, &stop); - return *stop == 0 && s != stop && isfinite(d); + return *stop == 0 && s != stop && std::isfinite(d); } UniString MakeLowerCase(UniString const & s) diff --git a/base/timer.cpp b/base/timer.cpp index f8796b0479..07ca601f6a 100644 --- a/base/timer.cpp +++ b/base/timer.cpp @@ -12,6 +12,65 @@ #include #include +#ifndef OMIM_OS_LINUX +using std::get_time; +using std::put_time; + +#else +#include + +namespace detail +{ + template struct get_time_manip + { + tm* __tm_; + const _CharT* __fmt_; + + get_time_manip(tm* __tm, const _CharT* __fmt) + : __tm_(__tm), __fmt_(__fmt) {} + }; + + template + class stream_buf_impl : public std::basic_streambuf<_CharT, _Traits> + { + typedef std::basic_streambuf<_CharT, _Traits> base_t; + public: + bool parse(const get_time_manip<_CharT>& __x) + { + // Workaround works only for a stream buffer under null-terminated string. + assert(*base_t::egptr() == 0); + + char * res = ::strptime(base_t::gptr(), __x.__fmt_, __x.__tm_); + if (res == 0) + return false; + else + { + base_t::setg(base_t::eback(), res, base_t::egptr()); + return true; + } + } + }; + + template + std::basic_istream<_CharT, _Traits>& + operator>>(std::basic_istream<_CharT, _Traits>& __is, const get_time_manip<_CharT>& __x) + { + if (!reinterpret_cast*>(__is.rdbuf())->parse(__x)) + __is.setstate(std::ios_base::failbit); + return __is; + } +} + +template +detail::get_time_manip<_CharT> get_time(tm* __tm, const _CharT* __fmt) +{ + return detail::get_time_manip<_CharT>(__tm, __fmt); +} + +#endif + + + namespace my { @@ -103,7 +162,7 @@ time_t StringToTimestamp(std::string const & s) // Parse UTC format: 1970-01-01T00:00:00Z tm t{}; std::istringstream ss(s); - ss >> std::get_time(&t, "%Y-%m-%dT%H:%M:%SZ"); + ss >> get_time(&t, "%Y-%m-%dT%H:%M:%SZ"); if (!ss.fail() && IsValid(t)) res = base::TimeGM(t); @@ -114,7 +173,7 @@ time_t StringToTimestamp(std::string const & s) tm t1{}, t2{}; char sign; std::istringstream ss(s); - ss >> std::get_time(&t1, "%Y-%m-%dT%H:%M:%S") >> sign >> std::get_time(&t2, "%H:%M"); + ss >> get_time(&t1, "%Y-%m-%dT%H:%M:%S") >> sign >> get_time(&t2, "%H:%M"); if (!ss.fail() && IsValid(t1)) { diff --git a/coding/endianness.hpp b/coding/endianness.hpp index cb672748e1..103f6fa04b 100644 --- a/coding/endianness.hpp +++ b/coding/endianness.hpp @@ -4,6 +4,7 @@ #include "std/type_traits.hpp" +#include // #define ENDIAN_IS_BIG diff --git a/platform/http_client_curl.cpp b/platform/http_client_curl.cpp index ed78555136..e7ba50beba 100644 --- a/platform/http_client_curl.cpp +++ b/platform/http_client_curl.cpp @@ -34,6 +34,7 @@ #include "std/array.hpp" #include "std/fstream.hpp" +#include "std/iterator.hpp" #include "std/sstream.hpp" #include "std/vector.hpp"