liblog: Add log_time += operator

Change-Id: I1d2987b6cb333fc344d4fee1b7bb25f32a4143c6
This commit is contained in:
Mark Salyzyn 2014-10-13 14:13:18 -07:00
parent 69159ba0b7
commit decd92945f
2 changed files with 34 additions and 0 deletions

View File

@ -100,6 +100,12 @@ public:
log_time local(*this);
return local -= T;
}
log_time operator+= (const timespec &T);
log_time operator+ (const timespec &T) const
{
log_time local(*this);
return local += T;
}
// log_time
bool operator== (const log_time &T) const
@ -134,6 +140,12 @@ public:
log_time local(*this);
return local -= T;
}
log_time operator+= (const log_time &T);
log_time operator+ (const log_time &T) const
{
log_time local(*this);
return local += T;
}
uint64_t nsec() const
{

View File

@ -150,6 +150,17 @@ log_time log_time::operator-= (const timespec &T) {
return *this;
}
log_time log_time::operator+= (const timespec &T) {
this->tv_nsec += (unsigned long int)T.tv_nsec;
if (this->tv_nsec >= NS_PER_SEC) {
this->tv_nsec -= NS_PER_SEC;
++this->tv_sec;
}
this->tv_sec += T.tv_sec;
return *this;
}
log_time log_time::operator-= (const log_time &T) {
// No concept of negative time, clamp to EPOCH
if (*this <= T) {
@ -166,3 +177,14 @@ log_time log_time::operator-= (const log_time &T) {
return *this;
}
log_time log_time::operator+= (const log_time &T) {
this->tv_nsec += T.tv_nsec;
if (this->tv_nsec >= NS_PER_SEC) {
this->tv_nsec -= NS_PER_SEC;
++this->tv_sec;
}
this->tv_sec += T.tv_sec;
return *this;
}