2010-07-03 03:28:44 +08:00
|
|
|
//===-- TimeValue.cpp -------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "lldb/Host/TimeValue.h"
|
2013-08-23 20:44:05 +08:00
|
|
|
#include "lldb/Host/Config.h"
|
2010-07-03 03:28:44 +08:00
|
|
|
|
|
|
|
// C Includes
|
2011-08-10 10:10:13 +08:00
|
|
|
#include <stddef.h>
|
|
|
|
#include <time.h>
|
2011-08-12 04:40:21 +08:00
|
|
|
#include <cstring>
|
2013-09-21 06:35:22 +08:00
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
#include "lldb/Host/windows/windows.h"
|
|
|
|
#endif
|
|
|
|
|
2010-07-03 03:28:44 +08:00
|
|
|
// C++ Includes
|
2016-08-10 08:02:58 +08:00
|
|
|
#include <chrono>
|
|
|
|
|
2010-07-03 03:28:44 +08:00
|
|
|
// Other libraries and framework includes
|
|
|
|
// Project includes
|
2011-08-10 10:10:13 +08:00
|
|
|
#include "lldb/Core/Stream.h"
|
|
|
|
|
2010-07-03 03:28:44 +08:00
|
|
|
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// TimeValue constructor
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
TimeValue::TimeValue() :
|
|
|
|
m_nano_seconds (0)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// TimeValue copy constructor
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
TimeValue::TimeValue(const TimeValue& rhs) :
|
|
|
|
m_nano_seconds (rhs.m_nano_seconds)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
TimeValue::TimeValue(const struct timespec& ts) :
|
2012-04-07 12:55:02 +08:00
|
|
|
m_nano_seconds ((uint64_t) ts.tv_sec * NanoSecPerSec + ts.tv_nsec)
|
2010-07-03 03:28:44 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2016-08-10 08:02:58 +08:00
|
|
|
TimeValue::TimeValue(uint32_t seconds, uint64_t nanos) :
|
2013-09-04 21:56:11 +08:00
|
|
|
m_nano_seconds((uint64_t) seconds * NanoSecPerSec + nanos)
|
2010-07-03 03:28:44 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// Destructor
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
TimeValue::~TimeValue()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
uint64_t
|
|
|
|
TimeValue::GetAsNanoSecondsSinceJan1_1970() const
|
|
|
|
{
|
|
|
|
return m_nano_seconds;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint64_t
|
|
|
|
TimeValue::GetAsMicroSecondsSinceJan1_1970() const
|
|
|
|
{
|
2011-06-19 07:52:14 +08:00
|
|
|
return m_nano_seconds / NanoSecPerMicroSec;
|
2010-07-03 03:28:44 +08:00
|
|
|
}
|
|
|
|
|
2011-08-10 10:10:13 +08:00
|
|
|
uint64_t
|
|
|
|
TimeValue::GetAsSecondsSinceJan1_1970() const
|
|
|
|
{
|
|
|
|
return m_nano_seconds / NanoSecPerSec;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2010-07-03 03:28:44 +08:00
|
|
|
struct timespec
|
|
|
|
TimeValue::GetAsTimeSpec () const
|
|
|
|
{
|
|
|
|
struct timespec ts;
|
2011-06-19 07:52:14 +08:00
|
|
|
ts.tv_sec = m_nano_seconds / NanoSecPerSec;
|
|
|
|
ts.tv_nsec = m_nano_seconds % NanoSecPerSec;
|
2010-07-03 03:28:44 +08:00
|
|
|
return ts;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
TimeValue::Clear ()
|
|
|
|
{
|
|
|
|
m_nano_seconds = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
TimeValue::IsValid () const
|
|
|
|
{
|
|
|
|
return m_nano_seconds != 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
TimeValue::OffsetWithSeconds (uint64_t sec)
|
|
|
|
{
|
2011-06-19 07:52:14 +08:00
|
|
|
m_nano_seconds += sec * NanoSecPerSec;
|
2010-07-03 03:28:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
TimeValue::OffsetWithMicroSeconds (uint64_t usec)
|
|
|
|
{
|
2011-06-19 07:52:14 +08:00
|
|
|
m_nano_seconds += usec * NanoSecPerMicroSec;
|
2010-07-03 03:28:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
TimeValue::OffsetWithNanoSeconds (uint64_t nsec)
|
|
|
|
{
|
|
|
|
m_nano_seconds += nsec;
|
|
|
|
}
|
|
|
|
|
|
|
|
TimeValue
|
|
|
|
TimeValue::Now()
|
|
|
|
{
|
2016-08-10 08:02:58 +08:00
|
|
|
using namespace std::chrono;
|
|
|
|
auto now = system_clock::now();
|
|
|
|
auto ns_since_epoch = duration_cast<std::chrono::nanoseconds>(now.time_since_epoch()).count();
|
|
|
|
|
|
|
|
return TimeValue(0, ns_since_epoch);
|
2010-07-03 03:28:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// TimeValue assignment operator
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
const TimeValue&
|
|
|
|
TimeValue::operator=(const TimeValue& rhs)
|
|
|
|
{
|
|
|
|
m_nano_seconds = rhs.m_nano_seconds;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2011-08-10 10:10:13 +08:00
|
|
|
void
|
|
|
|
TimeValue::Dump (Stream *s, uint32_t width) const
|
|
|
|
{
|
|
|
|
if (s == NULL)
|
|
|
|
return;
|
|
|
|
|
2013-08-23 20:44:05 +08:00
|
|
|
#ifndef LLDB_DISABLE_POSIX
|
2011-08-10 10:10:13 +08:00
|
|
|
char time_buf[32];
|
|
|
|
time_t time = GetAsSecondsSinceJan1_1970();
|
|
|
|
char *time_cstr = ::ctime_r(&time, time_buf);
|
|
|
|
if (time_cstr)
|
|
|
|
{
|
|
|
|
char *newline = ::strpbrk(time_cstr, "\n\r");
|
|
|
|
if (newline)
|
|
|
|
*newline = '\0';
|
|
|
|
if (width > 0)
|
|
|
|
s->Printf("%-*s", width, time_cstr);
|
|
|
|
else
|
|
|
|
s->PutCString(time_cstr);
|
|
|
|
}
|
|
|
|
else if (width > 0)
|
|
|
|
s->Printf("%-*s", width, "");
|
2013-08-23 20:44:05 +08:00
|
|
|
#endif
|
2011-08-10 10:10:13 +08:00
|
|
|
}
|
2010-07-03 03:28:44 +08:00
|
|
|
|
|
|
|
bool
|
|
|
|
lldb_private::operator == (const TimeValue &lhs, const TimeValue &rhs)
|
|
|
|
{
|
|
|
|
return lhs.GetAsNanoSecondsSinceJan1_1970() == rhs.GetAsNanoSecondsSinceJan1_1970();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
lldb_private::operator != (const TimeValue &lhs, const TimeValue &rhs)
|
|
|
|
{
|
|
|
|
return lhs.GetAsNanoSecondsSinceJan1_1970() != rhs.GetAsNanoSecondsSinceJan1_1970();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
lldb_private::operator < (const TimeValue &lhs, const TimeValue &rhs)
|
|
|
|
{
|
|
|
|
return lhs.GetAsNanoSecondsSinceJan1_1970() < rhs.GetAsNanoSecondsSinceJan1_1970();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
lldb_private::operator <= (const TimeValue &lhs, const TimeValue &rhs)
|
|
|
|
{
|
|
|
|
return lhs.GetAsNanoSecondsSinceJan1_1970() <= rhs.GetAsNanoSecondsSinceJan1_1970();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
lldb_private::operator > (const TimeValue &lhs, const TimeValue &rhs)
|
|
|
|
{
|
|
|
|
return lhs.GetAsNanoSecondsSinceJan1_1970() > rhs.GetAsNanoSecondsSinceJan1_1970();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
lldb_private::operator >= (const TimeValue &lhs, const TimeValue &rhs)
|
|
|
|
{
|
|
|
|
return lhs.GetAsNanoSecondsSinceJan1_1970() >= rhs.GetAsNanoSecondsSinceJan1_1970();
|
|
|
|
}
|
|
|
|
|
|
|
|
uint64_t
|
|
|
|
lldb_private::operator - (const TimeValue &lhs, const TimeValue &rhs)
|
|
|
|
{
|
|
|
|
return lhs.GetAsNanoSecondsSinceJan1_1970() - rhs.GetAsNanoSecondsSinceJan1_1970();
|
|
|
|
}
|
|
|
|
|
|
|
|
|