Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TDatime Class Reference

This class stores the date and time with a precision of one second in an unsigned 32 bit word (950130 124559).

The date is stored with the origin being the 1st January 1995.

This class has no support for time zones. The time is assumed to be in the local time of the machine where the object was created. As a result, TDatime objects are not portable between machines operating in different time zones and unsuitable for storing the date/time of data taking events and the like. If absolute time is required, use TTimeStamp.

Definition at line 37 of file TDatime.h.

Public Member Functions

 TDatime ()
 Create a TDatime and set it to the current time.
 
 TDatime (const char *sqlDateTime)
 Expects as input a string in SQL date/time compatible format, like: yyyy-mm-dd hh:mm:ss.
 
 TDatime (const TDatime &d)
 
 TDatime (Int_t date, Int_t time)
 Create a TDatime and set it to the specified date and time.
 
 TDatime (Int_t year, Int_t month, Int_t day, Int_t hour, Int_t min, Int_t sec)
 Create a TDatime and set it to the specified year, month, day, time, hour, minute and second.
 
 TDatime (UInt_t tloc, Bool_t dosDate=kFALSE)
 
virtual ~TDatime ()
 
const char * AsSQLString () const
 Return the date & time in SQL compatible string format, like: 1997-01-15 20:16:28.
 
const char * AsString () const
 Return the date & time as a string (ctime() format).
 
const char * AsString (char *out) const
 Return the date & time as a string (ctime() format).
 
UInt_t Convert (Bool_t toGMT=kFALSE) const
 Convert fDatime from TDatime format to the standard time_t format.
 
void Copy (TDatime &datime) const
 Copy this to datime.
 
void FillBuffer (char *&buffer)
 Encode Date/Time into buffer, used by I/O system.
 
UInt_t Get () const
 Return raw date/time as encoded by TDatime.
 
Int_t GetDate () const
 Return date in form of 19971224 (i.e. 24/12/1997)
 
Int_t GetDay () const
 
Int_t GetDayOfWeek () const
 Returns day of week, with Monday being day 1 and Sunday day 7.
 
Int_t GetHour () const
 
Int_t GetMinute () const
 
Int_t GetMonth () const
 
Int_t GetSecond () const
 
Int_t GetTime () const
 Return time in form of 123623 (i.e. 12:36:23)
 
Int_t GetYear () const
 
virtual TClassIsA () const
 
TDatimeoperator= (const TDatime &d)
 
void Print (Option_t *option="") const
 Print date and time.
 
void ReadBuffer (char *&buffer)
 Decode Date/Time from output buffer, used by I/O system.
 
void Set ()
 Set Date/Time to current time as reported by the system.
 
void Set (const char *sqlDateTime)
 Expects as input a string in SQL date/time compatible format, like: yyyy-mm-dd hh:mm:ss.
 
void Set (Int_t date, Int_t time)
 Set date and time.
 
void Set (Int_t year, Int_t month, Int_t day, Int_t hour, Int_t min, Int_t sec)
 Set date and time.
 
void Set (UInt_t tloc, Bool_t dosDate=kFALSE)
 The input arg is a time_t value returned by time() or a value returned by Convert().
 
Int_t Sizeof () const
 
virtual void Streamer (TBuffer &)
 Stream a object of type TDatime.
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 

Static Public Member Functions

static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
static Int_t GetDateFromGlobalDay (Int_t day)
 Static function that returns the date from the global day number.
 
static void GetDateTime (UInt_t datetime, Int_t &date, Int_t &time)
 Static function that returns the date and time.
 
static Int_t GetGlobalDayFromDate (Int_t date)
 Static function that returns the global day number from date.
 
static Int_t GetLegalGlobalDayFromDate (Int_t date)
 Static function that returns the global day number from date.
 

Protected Attributes

UInt_t fDatime
 

Friends

Bool_t operator!= (const TDatime &d1, const TDatime &d2)
 
Bool_t operator< (const TDatime &d1, const TDatime &d2)
 
Bool_t operator<= (const TDatime &d1, const TDatime &d2)
 
Bool_t operator== (const TDatime &d1, const TDatime &d2)
 
Bool_t operator> (const TDatime &d1, const TDatime &d2)
 
Bool_t operator>= (const TDatime &d1, const TDatime &d2)
 

#include <TDatime.h>

Constructor & Destructor Documentation

◆ TDatime() [1/6]

TDatime::TDatime ( )

Create a TDatime and set it to the current time.

Definition at line 50 of file TDatime.cxx.

◆ TDatime() [2/6]

TDatime::TDatime ( const TDatime d)
inline

Definition at line 46 of file TDatime.h.

◆ TDatime() [3/6]

TDatime::TDatime ( UInt_t  tloc,
Bool_t  dosDate = kFALSE 
)
inline

Definition at line 47 of file TDatime.h.

◆ TDatime() [4/6]

TDatime::TDatime ( Int_t  date,
Int_t  time 
)

Create a TDatime and set it to the specified date and time.

See Set(Int_t, Int_t) about the date, time format.

Definition at line 59 of file TDatime.cxx.

◆ TDatime() [5/6]

TDatime::TDatime ( Int_t  year,
Int_t  month,
Int_t  day,
Int_t  hour,
Int_t  min,
Int_t  sec 
)

Create a TDatime and set it to the specified year, month, day, time, hour, minute and second.

See Set() about the format.

Definition at line 68 of file TDatime.cxx.

◆ TDatime() [6/6]

TDatime::TDatime ( const char *  sqlDateTime)

Expects as input a string in SQL date/time compatible format, like: yyyy-mm-dd hh:mm:ss.

Definition at line 78 of file TDatime.cxx.

◆ ~TDatime()

virtual TDatime::~TDatime ( )
inlinevirtual

Definition at line 53 of file TDatime.h.

Member Function Documentation

◆ AsSQLString()

const char * TDatime::AsSQLString ( ) const

Return the date & time in SQL compatible string format, like: 1997-01-15 20:16:28.

The returned string buffer is static and will be reused.

Definition at line 152 of file TDatime.cxx.

◆ AsString() [1/2]

const char * TDatime::AsString ( ) const

Return the date & time as a string (ctime() format).

Copy result because it points to a statically allocated string.

Definition at line 102 of file TDatime.cxx.

◆ AsString() [2/2]

const char * TDatime::AsString ( char *  out) const

Return the date & time as a string (ctime() format).

Result is copied into out (and out is returned). Make sure out can at least contain 26 characters. Thread safe.

Definition at line 121 of file TDatime.cxx.

◆ Class()

static TClass * TDatime::Class ( )
static
Returns
TClass describing this class

◆ Class_Name()

static const char * TDatime::Class_Name ( )
static
Returns
Name of this class

◆ Class_Version()

static constexpr Version_t TDatime::Class_Version ( )
inlinestaticconstexpr
Returns
Version of this class

Definition at line 95 of file TDatime.h.

◆ Convert()

UInt_t TDatime::Convert ( Bool_t  toGMT = kFALSE) const

Convert fDatime from TDatime format to the standard time_t format.

If toGMT is true, the time offset of the current local time zone is subtracted from the returned time_t. One use of such a non-standard time_t value is to convert a TDatime object that contains local time to GMT, as in this example:

TDatime now;
now.Set(now.Convert(kTRUE));
constexpr Bool_t kTRUE
Definition RtypesCore.h:100
This class stores the date and time with a precision of one second in an unsigned 32 bit word (950130...
Definition TDatime.h:37
void Set()
Set Date/Time to current time as reported by the system.
Definition TDatime.cxx:289
UInt_t Convert(Bool_t toGMT=kFALSE) const
Convert fDatime from TDatime format to the standard time_t format.
Definition TDatime.cxx:182

Caution: the time_t returned from Convert(kTRUE) is incompatible with regular Unix time - it contains an artificial, locale-dependent offset.

Definition at line 182 of file TDatime.cxx.

◆ Copy()

void TDatime::Copy ( TDatime datime) const

Copy this to datime.

Definition at line 221 of file TDatime.cxx.

◆ DeclFileName()

static const char * TDatime::DeclFileName ( )
inlinestatic
Returns
Name of the file containing the class declaration

Definition at line 95 of file TDatime.h.

◆ FillBuffer()

void TDatime::FillBuffer ( char *&  buffer)

Encode Date/Time into buffer, used by I/O system.

Definition at line 229 of file TDatime.cxx.

◆ Get()

UInt_t TDatime::Get ( ) const

Return raw date/time as encoded by TDatime.

Note, this value cannot be used to e.g. calculate time differences, as it is an encoded value. To calculate time differences use the Convert() method to get a time in seconds and then subtract the values.

Definition at line 240 of file TDatime.cxx.

◆ GetDate()

Int_t TDatime::GetDate ( ) const

Return date in form of 19971224 (i.e. 24/12/1997)

Definition at line 248 of file TDatime.cxx.

◆ GetDateFromGlobalDay()

Int_t TDatime::GetDateFromGlobalDay ( Int_t  day)
static

Static function that returns the date from the global day number.

The output is in TDatime yyyymmdd format (as obtained via TDatime::GetDate()).

Definition at line 470 of file TDatime.cxx.

◆ GetDateTime()

void TDatime::GetDateTime ( UInt_t  datetime,
Int_t date,
Int_t time 
)
static

Static function that returns the date and time.

The input is in TDatime format (as obtained via TDatime::Get()). Date is returned in the format 950223 February 23 1995. Time is returned in the format 102459 10h 24m 59s.

Definition at line 435 of file TDatime.cxx.

◆ GetDay()

Int_t TDatime::GetDay ( ) const
inline

Definition at line 67 of file TDatime.h.

◆ GetDayOfWeek()

Int_t TDatime::GetDayOfWeek ( ) const

Returns day of week, with Monday being day 1 and Sunday day 7.

Definition at line 86 of file TDatime.cxx.

◆ GetGlobalDayFromDate()

Int_t TDatime::GetGlobalDayFromDate ( Int_t  date)
static

Static function that returns the global day number from date.

The input is in TDatime format yyyymmdd (as obtained via TDatime::GetDate()). This algorithm is only accurate for dates later than October 1582 (earliest date on Gregorian calendar).

Definition at line 453 of file TDatime.cxx.

◆ GetHour()

Int_t TDatime::GetHour ( ) const
inline

Definition at line 69 of file TDatime.h.

◆ GetLegalGlobalDayFromDate()

Int_t TDatime::GetLegalGlobalDayFromDate ( Int_t  date)
static

Static function that returns the global day number from date.

The input is in TDatime format yyyymmdd (as obtained via TDatime::GetDate()). This algorithm is only accurate for dates later than October 1582 (earliest date on Gregorian calendar) and it is checked that the date is larger than 15821001 and conversion is correct. In case of conversion failure 0 is returned. No need to use when you know dates are larger than October 1582.

Definition at line 496 of file TDatime.cxx.

◆ GetMinute()

Int_t TDatime::GetMinute ( ) const
inline

Definition at line 70 of file TDatime.h.

◆ GetMonth()

Int_t TDatime::GetMonth ( ) const
inline

Definition at line 66 of file TDatime.h.

◆ GetSecond()

Int_t TDatime::GetSecond ( ) const
inline

Definition at line 71 of file TDatime.h.

◆ GetTime()

Int_t TDatime::GetTime ( ) const

Return time in form of 123623 (i.e. 12:36:23)

Definition at line 259 of file TDatime.cxx.

◆ GetYear()

Int_t TDatime::GetYear ( ) const
inline

Definition at line 65 of file TDatime.h.

◆ IsA()

virtual TClass * TDatime::IsA ( ) const
inlinevirtual
Returns
TClass describing current object

Definition at line 95 of file TDatime.h.

◆ operator=()

TDatime & TDatime::operator= ( const TDatime d)
inline

Definition at line 99 of file TDatime.h.

◆ Print()

void TDatime::Print ( Option_t option = "") const

Print date and time.

Definition at line 270 of file TDatime.cxx.

◆ ReadBuffer()

void TDatime::ReadBuffer ( char *&  buffer)

Decode Date/Time from output buffer, used by I/O system.

Definition at line 278 of file TDatime.cxx.

◆ Set() [1/5]

void TDatime::Set ( )

Set Date/Time to current time as reported by the system.

Date and Time are encoded into one single unsigned 32 bit word. Date is stored with the origin being the 1st January 1995. Time has 1 second precision.

Definition at line 289 of file TDatime.cxx.

◆ Set() [2/5]

void TDatime::Set ( const char *  sqlDateTime)

Expects as input a string in SQL date/time compatible format, like: yyyy-mm-dd hh:mm:ss.

Definition at line 404 of file TDatime.cxx.

◆ Set() [3/5]

void TDatime::Set ( Int_t  date,
Int_t  time 
)

Set date and time.

Data must be in format 980418 or 19980418 and time in 224512 (second precision). The date must be >= 950101.

For years >= 2000, date can be given in the form 20001127 or 1001127 internally the date will be converted to 1001127

Definition at line 363 of file TDatime.cxx.

◆ Set() [4/5]

void TDatime::Set ( Int_t  year,
Int_t  month,
Int_t  day,
Int_t  hour,
Int_t  min,
Int_t  sec 
)

Set date and time.

Year may be xx where 95 <= xx <= 158 (158 being 2058). The year must be >= 1995.

Definition at line 388 of file TDatime.cxx.

◆ Set() [5/5]

void TDatime::Set ( UInt_t  tloc,
Bool_t  dosDate = kFALSE 
)

The input arg is a time_t value returned by time() or a value returned by Convert().

This value is the number of seconds since the EPOCH (i.e. 00:00:00 on Jan 1m 1970). If dosDate is true then the input is a dosDate value.

Definition at line 325 of file TDatime.cxx.

◆ Sizeof()

Int_t TDatime::Sizeof ( ) const
inline

Definition at line 81 of file TDatime.h.

◆ Streamer()

void TDatime::Streamer ( TBuffer b)
virtual

Stream a object of type TDatime.

Definition at line 420 of file TDatime.cxx.

◆ StreamerNVirtual()

void TDatime::StreamerNVirtual ( TBuffer ClassDef_StreamerNVirtual_b)
inline

Definition at line 95 of file TDatime.h.

Friends And Related Symbol Documentation

◆ operator!=

Bool_t operator!= ( const TDatime d1,
const TDatime d2 
)
friend

Definition at line 104 of file TDatime.h.

◆ operator<

Bool_t operator< ( const TDatime d1,
const TDatime d2 
)
friend

Definition at line 106 of file TDatime.h.

◆ operator<=

Bool_t operator<= ( const TDatime d1,
const TDatime d2 
)
friend

Definition at line 108 of file TDatime.h.

◆ operator==

Bool_t operator== ( const TDatime d1,
const TDatime d2 
)
friend

Definition at line 102 of file TDatime.h.

◆ operator>

Bool_t operator> ( const TDatime d1,
const TDatime d2 
)
friend

Definition at line 110 of file TDatime.h.

◆ operator>=

Bool_t operator>= ( const TDatime d1,
const TDatime d2 
)
friend

Definition at line 112 of file TDatime.h.

Member Data Documentation

◆ fDatime

UInt_t TDatime::fDatime
protected

Definition at line 42 of file TDatime.h.

  • core/base/inc/TDatime.h
  • core/base/src/TDatime.cxx