Fix issues while build on Linux

This commit is contained in:
Sergey Yershov 2016-12-20 16:12:52 +03:00
parent 20c0eb77e3
commit 63b6375f7c
6 changed files with 67 additions and 5 deletions

View file

@ -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

View file

@ -3,6 +3,7 @@
#include <algorithm>
#include <functional>
#include <iterator>
#include <memory>
namespace my
{

View file

@ -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)

View file

@ -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))
{

View file

@ -4,6 +4,7 @@
#include "std/type_traits.hpp"
#include <cstddef>
// #define ENDIAN_IS_BIG

View file

@ -34,6 +34,7 @@
#include "std/array.hpp"
#include "std/fstream.hpp"
#include "std/iterator.hpp"
#include "std/sstream.hpp"
#include "std/vector.hpp"