forked from organicmaps/organicmaps-tmp
Fix issues while build on Linux
This commit is contained in:
parent
20c0eb77e3
commit
63b6375f7c
6 changed files with 67 additions and 5 deletions
|
@ -46,7 +46,7 @@ private:
|
|||
MoveStatic(buffer_vector<T, N> & 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
|
||||
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
#include <algorithm>
|
||||
#include <functional>
|
||||
#include <iterator>
|
||||
#include <memory>
|
||||
|
||||
namespace my
|
||||
{
|
||||
|
|
|
@ -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)
|
||||
|
|
|
@ -12,6 +12,65 @@
|
|||
#include <iomanip>
|
||||
#include <sstream>
|
||||
|
||||
#ifndef OMIM_OS_LINUX
|
||||
using std::get_time;
|
||||
using std::put_time;
|
||||
|
||||
#else
|
||||
#include <cassert>
|
||||
|
||||
namespace detail
|
||||
{
|
||||
template <class _CharT> struct get_time_manip
|
||||
{
|
||||
tm* __tm_;
|
||||
const _CharT* __fmt_;
|
||||
|
||||
get_time_manip(tm* __tm, const _CharT* __fmt)
|
||||
: __tm_(__tm), __fmt_(__fmt) {}
|
||||
};
|
||||
|
||||
template <class _CharT, class _Traits>
|
||||
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 <class _CharT, class _Traits>
|
||||
std::basic_istream<_CharT, _Traits>&
|
||||
operator>>(std::basic_istream<_CharT, _Traits>& __is, const get_time_manip<_CharT>& __x)
|
||||
{
|
||||
if (!reinterpret_cast<stream_buf_impl<_CharT, _Traits>*>(__is.rdbuf())->parse(__x))
|
||||
__is.setstate(std::ios_base::failbit);
|
||||
return __is;
|
||||
}
|
||||
}
|
||||
|
||||
template <class _CharT>
|
||||
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))
|
||||
{
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
|
||||
#include "std/type_traits.hpp"
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
// #define ENDIAN_IS_BIG
|
||||
|
||||
|
|
|
@ -34,6 +34,7 @@
|
|||
|
||||
#include "std/array.hpp"
|
||||
#include "std/fstream.hpp"
|
||||
#include "std/iterator.hpp"
|
||||
#include "std/sstream.hpp"
|
||||
#include "std/vector.hpp"
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue