Further refactor time_helper.h

Actions:
* Remove superfluous includes to boost/date_time, iostream, and pragma_comp_defs.h
* Include cstdio for snprintf
* Include string for std::string
* Move get_gmt_time to top of module for following step
* Use thread-safe get_gmt_time instead of unsafe gm_time in function get_internet_time_str()
* In get_time_interval_string(), add explicit (int) casts to git rid of VS4996 warnings
* In get_time_interval_string(), use snprintf instead of boost::lexical_casts and string concats
* In file epee_utils.cpp, include boost/range/iterator_range.hpp for boost::make_iterator_range.
  Previously, epee_util.cpp was including some file which was including time_helper which included
  a boost header which included iterator_range.hpp at some point, which allowed epee_util.cpp to
  compile without an explicit include of iterator_range.hpp. I added it because I removed the boost
  includes in the first step which broke epee_util.cpp.
This commit is contained in:
Jeffrey 2022-03-04 13:48:12 -06:00
parent 020531a813
commit 7fa9e2817d
2 changed files with 24 additions and 30 deletions

View File

@ -28,46 +28,48 @@
#pragma once #pragma once
#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/date_time/local_time/local_time.hpp>
#include <chrono> #include <chrono>
#include <cstdio>
#include <ctime> #include <ctime>
#include <iostream> #include <string>
#include "pragma_comp_defs.h"
namespace epee namespace epee
{ {
namespace misc_utils namespace misc_utils
{ {
inline bool get_gmt_time(time_t t, struct tm &tm)
{
#ifdef _WIN32
return gmtime_s(&tm, &t);
#else
return gmtime_r(&t, &tm);
#endif
}
inline std::string get_internet_time_str(const time_t& time_) inline std::string get_internet_time_str(const time_t& time_)
{ {
char tmpbuf[200] = {0}; char tmpbuf[200] = {0};
tm* pt = NULL; struct tm pt;
PRAGMA_WARNING_PUSH get_gmt_time(time_, pt);
PRAGMA_WARNING_DISABLE_VS(4996) strftime( tmpbuf, 199, "%a, %d %b %Y %H:%M:%S GMT", &pt );
pt = gmtime(&time_);
PRAGMA_WARNING_POP
strftime( tmpbuf, 199, "%a, %d %b %Y %H:%M:%S GMT", pt );
return tmpbuf; return tmpbuf;
} }
inline std::string get_time_interval_string(const time_t& time_) inline std::string get_time_interval_string(const time_t& time_)
{ {
std::string res;
time_t tail = time_; time_t tail = time_;
PRAGMA_WARNING_PUSH const int days = (int) (tail/(60*60*24));
PRAGMA_WARNING_DISABLE_VS(4244)
int days = tail/(60*60*24);
tail = tail%(60*60*24); tail = tail%(60*60*24);
int hours = tail/(60*60); const int hours = (int) (tail/(60*60));
tail = tail%(60*60); tail = tail%(60*60);
int minutes = tail/(60); const int minutes = (int) (tail/(60));
tail = tail%(60); tail = tail%(60);
int seconds = tail; const int seconds = (int) tail;
PRAGMA_WARNING_POP
res = std::string() + "d" + boost::lexical_cast<std::string>(days) + ".h" + boost::lexical_cast<std::string>(hours) + ".m" + boost::lexical_cast<std::string>(minutes) + ".s" + boost::lexical_cast<std::string>(seconds); char tmpbuf[64] = {0};
return res; snprintf(tmpbuf, sizeof(tmpbuf) - 1, "d%d.h%d.m%d.s%d", days, hours, minutes, seconds);
return tmpbuf;
} }
inline uint64_t get_ns_count() inline uint64_t get_ns_count()
@ -81,14 +83,5 @@ PRAGMA_WARNING_POP
{ {
return get_ns_count() / 1000000; return get_ns_count() / 1000000;
} }
inline bool get_gmt_time(time_t t, struct tm &tm)
{
#ifdef _WIN32
return gmtime_s(&tm, &t);
#else
return gmtime_r(&t, &tm);
#endif
}
} }
} }

View File

@ -31,6 +31,7 @@
#include <boost/endian/conversion.hpp> #include <boost/endian/conversion.hpp>
#include <boost/range/algorithm/equal.hpp> #include <boost/range/algorithm/equal.hpp>
#include <boost/range/algorithm_ext/iota.hpp> #include <boost/range/algorithm_ext/iota.hpp>
#include <boost/range/iterator_range.hpp>
#include <cstdint> #include <cstdint>
#include <gtest/gtest.h> #include <gtest/gtest.h>
#include <iterator> #include <iterator>