X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Ftime%2Fdatetime.h;h=b786798707ab4db60c61b06263499ff7080f1b9b;hp=4f439e6be7acde84557bf136ee8f05e2c5823239;hb=967785734be5c3fc6f75da122c2d93ebbb338271;hpb=80bbee2f401b4af71cb1b80508bdb0d2bb61fa40 diff --git a/source/time/datetime.h b/source/time/datetime.h index 4f439e6..b786798 100644 --- a/source/time/datetime.h +++ b/source/time/datetime.h @@ -1,9 +1,9 @@ -/* $Id$ */ #ifndef MSP_TIME_DATETIME_H_ #define MSP_TIME_DATETIME_H_ -#include #include +#include "timezone.h" +#include "rawtime.h" namespace Msp { namespace Time { @@ -22,24 +22,43 @@ TimeStamp is a better choice. */ class DateTime { +private: + int year; + unsigned char month; + unsigned char mday; + unsigned char hour; + unsigned char minute; + unsigned char second; + unsigned usec; + TimeZone zone; + public: DateTime(const TimeStamp &); - DateTime(int32_t, uint8_t, uint8_t); - DateTime(int32_t, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t); - DateTime(int32_t, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t, uint32_t); - - int32_t get_year() const { return year; } - uint8_t get_month() const { return month; } - uint8_t get_mday() const { return mday; } - uint8_t get_hour() const { return hour; } - uint8_t get_minute() const { return minute; } - uint8_t get_second() const { return second; } - uint32_t get_usec() const { return usec; } + DateTime(const TimeStamp &, const TimeZone &); + DateTime(int, unsigned char, unsigned char); + DateTime(int, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char); + DateTime(int, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned); +private: + void init(const TimeStamp &); + void init(int, unsigned char, unsigned char, unsigned char, unsigned char, unsigned char, unsigned); - void add_days(int32_t); +public: + int get_year() const { return year; } + unsigned char get_month() const { return month; } + unsigned char get_mday() const { return mday; } + unsigned char get_hour() const { return hour; } + unsigned char get_minute() const { return minute; } + unsigned char get_second() const { return second; } + unsigned get_usec() const { return usec; } + + void add_days(int); + void set_timezone(const TimeZone &); + void convert_timezone(const TimeZone &); DateTime operator+(const TimeDelta &) const; DateTime &operator+=(const TimeDelta &); + DateTime operator-(const TimeDelta &) const; + DateTime &operator-=(const TimeDelta &); bool operator==(const DateTime &d) const { return cmp(d)==0; } bool operator!=(const DateTime &d) const { return cmp(d)!=0; } @@ -51,16 +70,10 @@ public: int cmp(const DateTime &) const; TimeStamp get_timestamp() const; std::string format(const std::string &) const; -private: - int32_t year; - uint8_t month; - uint8_t mday; - uint8_t hour; - uint8_t minute; - uint8_t second; - uint32_t usec; + std::string format_rfc3339() const; - void add_raw(int64_t); +private: + void add_raw(RawTime); void normalize(); };