Code review.

This commit is contained in:
Sergey Magidovich 2015-11-20 15:24:39 +03:00
parent ab5d2a5a88
commit f1c736614d
4 changed files with 63 additions and 38 deletions

View file

@ -31,6 +31,7 @@ SOURCES += \
thread_pool.cpp \
threaded_container.cpp \
timer.cpp \
w3ctime.cpp \
HEADERS += \
SRC_FIRST.hpp \
@ -81,4 +82,5 @@ HEADERS += \
threaded_list.hpp \
threaded_priority_queue.hpp \
timer.hpp \
w3ctime.hpp \
worker_thread.hpp \

View file

@ -1,12 +1,14 @@
#include "base/w3ctime.hpp"
#include "testing/testing.hpp"
using namespace w3ctime;
#include "base/w3ctime.hpp"
using namespace base;
UNIT_TEST(ParseTime)
{
TEST_EQUAL(ParseTime(""), kNotATime, ());
TEST_EQUAL(ParseTime("2015-10-11 23:21"), kNotATime, ());
TEST(NotATime(ParseTime("")), ());
TEST(NotATime(ParseTime("2015-10-11 23:21")), ());
TEST(!NotATime(ParseTime("2015-10-11T23:21Z")), ());
TEST_EQUAL(ParseTime("2015-10-11T23:21Z"), 1444605660, ());
}

43
base/w3ctime.cpp Normal file
View file

@ -0,0 +1,43 @@
#include "w3ctime.hpp"
#include "std/array.hpp"
// It would be better to use c++ standard means of
// time parsing and unparsing like
// time_get/time_put (<locale>) or get_time/put_time (<iomanip>).
// But at the moment of writing they was not widely supporded
// and/or worked incorrect.
//
// All covertions are made in UTC
namespace
{
char constexpr kW3CTimeFormat[] = "%Y-%m-%dT%H:%MZ";
// Two more digits for year.
size_t constexpr kBufSize = sizeof(kW3CTimeFormat) + 2;
} // namespace
namespace base
{
time_t ParseTime(std::string const & w3ctime) noexcept
{
std::tm tm{};
if (strptime(w3ctime.data(), kW3CTimeFormat, &tm) == nullptr)
return -1;
return timegm(&tm);
}
std::string TimeToString(time_t const timestamp)
{
std::tm tm{};
array<char, kBufSize> buff{};
gmtime_r(&timestamp, &tm);
if (strftime(buff.data(), kBufSize, kW3CTimeFormat, &tm) == 0)
buff[0] = 0;
return buff.data();
}
} // namespace base

View file

@ -1,44 +1,22 @@
#pragma once
#include "std/array.hpp"
#include "std/ctime.hpp"
#include "std/string.hpp"
// It would be better to use c++ standard means of
// time parsing and unparsing like
// time_get/time_put (<locale>) or get_time/put_time (<iomanip>).
// But at the moment of writing they was not widely supporded
// and/or worked inkorekd.
//
// All covertions are made in UTC
namespace w3ctime
namespace base
{
char constexpr kW3CTimeFormat[] = "%Y-%m-%dT%H:%MZ";
// Two more digits for year and one for \n
size_t constexpr kBufSize = sizeof(kW3CTimeFormat) + 2 + 1;
inline bool NotATime(time_t const t) noexcept { return t == -1; }
time_t constexpr kNotATime = -1;
// See http://www.w3.org/TR/NOTE-datetime to learn more
// about the format.
inline time_t ParseTime(std::string const & w3ctime) noexcept
{
std::tm tm{};
if (strptime(w3ctime.data(), kW3CTimeFormat, &tm) == nullptr)
return kNotATime;
// Parses a string of a format YYYY-MM-DDThh:mmTZD
// (eg 1997-07-16T19:20:30.45+01:00).
// Returns timestamp corresponding to w3ctime or -1 on failure.
time_t ParseTime(std::string const & w3ctime) noexcept;
return timegm(&tm);
}
inline std::string TimeToString(time_t const timestamp) noexcept
{
std::tm tm{};
array<char, kBufSize> buff{};
gmtime_r(&timestamp, &tm);
strftime(buff.data(), kBufSize, kW3CTimeFormat, &tm);
return buff.data();
}
} // namespace w3ctime
// Converts timestamp to a string of a fromat YYYY-MM-DDThh:mmTZD
// or empty string if cannot convert.
std::string TimeToString(time_t const timestamp);
} // namespace base