DCL 4.1
Loading...
Searching...
No Matches
DateTime.cpp
Go to the documentation of this file.
1#include <dcl/Config.h>
2
3#if __DCL_WINDOWS
4 #include <windows.h> // GetSystemTime
5 #include <sys/timeb.h> // _ftime_s
6 #include <time.h> // _get_timezone
7#else
8 #include <sys/time.h> // gettimeofday
9 #include <time.h> // localtime_r
10#endif
11
12#include <string.h> // memset
13#include <wchar.h> // wcsftime
14
15#include <dcl/DateTime.h>
16
17#if __DCL_HAVE_ALLOC_DEBUG
18#undef __DCL_ALLOC_LEVEL
19#define __DCL_ALLOC_LEVEL __DCL_ALLOC_INTERNAL
20#endif
21
22#if __DCL_DEBUG
23#undef __THIS_FILE__
24static const char_t __THIS_FILE__[] = __T("dcl/DateTime.cpp");
25#endif
26
27__DCL_BEGIN_NAMESPACE
28
30{
31 __jday = 0;
32}
33
34Date::Date(const Date& _src)
35{
36 __jday = _src.__jday;
37}
38
39Date::Date(int _year, int _month, int _day)
40{
41 assign(_year, _month, _day);
42}
43
44Date::Date(long _days)
45{
46 assign(_days);
47}
48
49void Date::assign(int _year, int _month, int _day)
50{
51 __DCL_ASSERT(Date::isValid(_year, _month, _day));
52
54 _year,
55 _month,
56 _day
57 );
58}
59
60#define AD_START 220866926 // 0001-01-01
61#define BC_END (AD_START - 367) // -0001-01-31
62
63void Date::assign(long _days)
64{
65 if (_days < 0)
66 __jday = _days + BC_END + 1;
67 else if (_days > 0)
68 __jday = _days + AD_START - 1;
69 else
70 // set NULL date
71 __jday = _days;
72}
73
74long Date::days() const
75{
76 if (__jday <= BC_END)
77 return __jday - BC_END - 1;
78 else if (__jday >= AD_START)
79 return __jday - AD_START + 1;
80 else {
81 __DCL_ASSERT(__jday == 0);
82 return __jday;
83 }
84}
85
87{
88 __DCL_ASSERT(__jday != 0);
89
90 if (__jday == BC_END)
92 else
93 __jday++;
94
95 return *this;
96}
97
99{
100 __DCL_ASSERT(__jday != 0);
101
102 Date r = *this;
103
104 if (__jday == BC_END)
106 else
107 __jday++;
108
109 return r;
110}
111
113{
114 __DCL_ASSERT(__jday != 0);
115
116 if (__jday == AD_START)
117 __jday = BC_END;
118 else
119 __jday--;
120
121 return *this;
122}
123
125{
126 __DCL_ASSERT(__jday != 0);
127
128 Date r = *this;
129
130 if (__jday == AD_START)
131 __jday = BC_END;
132 else
133 __jday--;
134
135 return r;
136}
137
138const Date& Date::operator = (const Date& _src)
139{
140 __jday = _src.__jday;
141 return *this;
142}
143
144const Date& Date::operator += (long _days)
145{
146 __DCL_ASSERT(__jday != 0);
147
148 if (__jday <= BC_END) {
149 __jday += _days - BC_END;
150
151 if (__jday <= 0)
152 __jday += BC_END;
153 else
154 __jday += AD_START - 1;
155 }
156 else {
158
159 __jday += _days - AD_START;
160
161 if (__jday >= 0)
162 __jday += AD_START;
163 else
164 __jday += BC_END + 1;
165 }
166
167
168 return *this;
169}
170
171const Date& Date::operator -= (long _days)
172{
173 __DCL_ASSERT(__jday != 0);
174
175 return operator += (-_days);
176}
177
178DCLCAPI Date operator + (const Date& _date, long _days)
179{
180 Date r = _date;
181 r += _days;
182 return r;
183}
184
185void Date::decode(int& _year, int& _month, int& _day) const
186{
187 convertJulianToGregorian(__jday, _year, _month, _day);
188}
189
190int Date::year() const
191{
192 int year, month, day;
194 return year;
195}
196
197int Date::month() const
198{
199 int year, month, day;
201 return month;
202}
203
204int Date::day() const
205{
206 int year, month, day;
208 return day;
209}
210
212{
213 return (((__jday + 1) % 7) + 7) % 7 + 1;
214}
215
217{
218 return __jday - convertGregorianToJulian(year(), 1, 1) + 1;
219}
220
221static const int __monthDays__[] =
222{
223// 1 2 3 4 5 6 7 8 9 10 11 12
224 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31
225};
226
228{
229 int year, month, day;
231 if (month == 2 && isLeapYear(year))
232 return 29;
233
234 return __monthDays__[month];
235}
236
238{
239 int year, month, day;
241
242 if (isLeapYear(year))
243 return 366;
244 return 365;
245}
246
247String Date::toString() const
248{
249 int year, month, day;
250 decode(year, month, day);
251 return String::format(L"%04d-%02d-%02d", year, month, day);
252}
253
254const wchar_t* Date::FORMAT_STRING = L"%Y-%m-%d";
255
256String Date::toStringF(const wchar_t* _format) const
257{
258 if (!_format)
259 _format = FORMAT_STRING;
260
261 __DCL_ASSERT(*_format != L'\0');
262
263 int year, month, day;
264 decode(year, month, day);
265
266 struct tm _time;
267 memset(&_time, 0, sizeof(struct tm));
268 _time.tm_year = year - 1900;
269 _time.tm_mon = month - 1;
270 _time.tm_mday = day;
271 _time.tm_isdst = -1;
272
273 CharBuffer* buf = CharBuffer::create(DATETIME_FORMAT_BUFFER_SIZE);
274 size_t n = wcsftime(buf->data(), DATETIME_FORMAT_BUFFER_SIZE, _format, &_time);
275 __DCL_ASSERT(buf->__allocLength >= n);
276 buf->__dataLength = n;
277
278 String r = buf;
279 buf->release();
280 return r;
281}
282
283// 알고리즘 출처
284// Communications of the ACM, Vol 6, No 8.
286 int _y, int _m, int _d
287 )
288{
289 if (_y == 0) {
290 __DCL_ASSERT(_m == 0 && _d == 0);
291 return 0;
292 }
293
294 _y += 600000;
295
296 int c, ya;
297 if (_m > 2)
298 _m -= 3;
299 else {
300 _m += 9;
301 _y--;
302 }
303 c = _y / 100;
304 ya = _y - 100 * c;
305
306 return (146097 * c) / 4
307 + (1461 * ya) / 4
308 + (153 * _m + 2) / 5
309 + _d
310 + 1721119;
311}
312
314 long _j,
315 int& _y, int& _m, int& _d
316 )
317{
318 if (_j == 0) {
319 _y = 0;
320 _m = 0;
321 _d = 0;
322 }
323 else {
324 _j -= 1721119;
325
326 _y = (4 * _j - 1) / 146097;
327 _j = 4 * _j - 1 - 146097 * _y;
328 _d = _j / 4;
329
330 _j = (4 * _d + 3) / 1461;
331 _d = 4 * _d + 3 - 1461 * _j;
332 _d = (_d + 4) / 4;
333
334 _m = (5 * _d - 3) / 153;
335 _d = 5 * _d - 3 - 153 * _m;
336 _d = (_d + 5 ) / 5;
337
338 _y = 100 * _y + _j;
339 if (_m < 10)
340 _m += 3;
341 else {
342 _m -= 9;
343 _y++;
344 }
345
346 _y -= 600000;
347 }
348}
349
350bool Date::isValid(int _y, int _m, int _d)
351{
352 if (_y == 0) {
353 // null date
354 if (_m == 0 && _d == 0)
355 return true;
356 }
357 else {
358 if ((-9999 <= _y && _y <= 9999) &&
359 (0 < _m && _m <= 12)
360 && (0 < _d)) {
361 if (_m == 2 && _d == 29)
362 return Date::isLeapYear(_y);
363 else
364 return _d <= __monthDays__[_m];
365 }
366 }
367 return false;
368}
369
371{
372 return (_y % 4 == 0 && _y % 100 != 0) || _y % 400 == 0;
373}
374
375
377
379{
380 __milliseconds = 0;
381}
382
383
384Time::Time(const Time& _src)
385{
387}
388
389#define SEC_PER_DAY 86400
390#define MSEC_PER_DAY 86400000
391#define SEC_PER_HOUR 3600
392#define MSEC_PER_HOUR 3600000
393#define SEC_PER_MIN 60
394#define MSEC_PER_MIN 60000
395
396Time::Time(int _hour, int _min, int _sec, int _millisecond /* = 0 */)
397{
398 assign(_hour, _min, _sec, _millisecond);
399}
400
401Time::Time(long _milliseconds)
402{
403 assign(_milliseconds);
404}
405
406void Time::assign(int _hour, int _min, int _sec, int _millisecond /* = 0 */)
407{
408 long msec = _hour * MSEC_PER_HOUR
409 + _min * MSEC_PER_MIN
410 + _sec * 1000
411 + _millisecond;
412
413 msec %= MSEC_PER_DAY;
414 msec += MSEC_PER_DAY;
416}
417
418void Time::assign(long _milliseconds)
419{
420 _milliseconds %= MSEC_PER_DAY;
421 _milliseconds += MSEC_PER_DAY;
422 __milliseconds = _milliseconds % MSEC_PER_DAY;
423}
424
425
426const Time& Time::operator = (const Time& _src)
427{
429 return *this;
430}
431
432const Time& Time::operator += (long _milliseconds)
433{
434 long msec = __milliseconds + _milliseconds;
435 msec %= MSEC_PER_DAY;
436 msec += MSEC_PER_DAY;
438
439 return *this;
440}
441
442const Time& Time::operator -= (long _milliseconds)
443{
444 long msec = __milliseconds - _milliseconds;
445 msec %= MSEC_PER_DAY;
446 msec += MSEC_PER_DAY;
448
449 return *this;
450}
451
452DCLCAPI Time operator + (const Time& _time, long _milliseconds)
453{
454 Time result = _time;
455 result += _milliseconds;
456 return result;
457}
458
459void Time::decode(int& _hour, int& _min, int& _sec, int& _millisecond) const
460{
463 _sec = (__milliseconds % MSEC_PER_MIN) / 1000;
464 _millisecond = __milliseconds % 1000;
465}
466
467int Time::hour() const // 0 ~ 23
468{
470}
471
472int Time::minute() const // 0 ~ 59
473{
475}
476
477int Time::second() const // 0 ~ 59
478{
479 return (__milliseconds % MSEC_PER_MIN) / 1000;
480}
481
482int Time::msecond() const // 0 ~ 999
483{
484 return __milliseconds % 1000;
485}
486
487// HH:MM:SS.MS
488String Time::toString() const
489{
490 return String::format(L"%02d:%02d:%02d.%03d",
491 hour(),
492 minute(),
493 second(),
494 msecond()
495 );
496}
497
498const wchar_t* Time::FORMAT_STRING = L"%H:%M:%S";
499
500String Time::toStringF(const wchar_t* _format)
501{
502 if (!_format)
503 _format = FORMAT_STRING;
504
505 __DCL_ASSERT(*_format != L'\0');
506
507 struct tm _time;
508 memset(&_time, 0, sizeof(struct tm));
509 _time.tm_hour = hour();
510 _time.tm_min = minute();
511 _time.tm_sec = second();
512 _time.tm_isdst = -1;
513
514 CharBuffer* buf = CharBuffer::create(DATETIME_FORMAT_BUFFER_SIZE);
515 size_t n = wcsftime(buf->data(), DATETIME_FORMAT_BUFFER_SIZE, _format, &_time);
516 __DCL_ASSERT(buf->__allocLength <= n);
517 buf->__dataLength = n;
518
519 String r = buf;
520 buf->release();
521 return r;
522}
523
524// static members
525bool Time::isValid(int _hour, int _min, int _sec, int _millisecond)
526{
527 return (0 <= _hour && _hour <= 23)
528 && (0 <= _min && _min <= 59)
529 && (0 <= _sec && _sec <= 59)
530 && (0 <= _millisecond && _millisecond <= 999);
531}
532
533
535
540
542{
544}
545
546Interval::Interval(int _days, int _milliseconds)
547{
548 assign(_days, _milliseconds);
549}
550
552 int _hours, int _minutes, int _seconds,
553 int _milliseconds
554 )
555{
556 assign(_days, _hours, _minutes, _seconds, _milliseconds);
557}
558
559Interval::Interval(int64_t _milliseconds)
560{
561 assign(_milliseconds);
562}
563
564void Interval::assign(int _days, int _milliseconds)
565{
566 __milliseconds = (int64_t)_days * MSEC_PER_DAY + _milliseconds;
567}
568
569void Interval::assign(int _days,
570 int _hours, int _minutes, int _seconds,
571 int _milliseconds
572 )
573{
574 __milliseconds= (int64_t)_days * MSEC_PER_DAY
575 + (int64_t)_hours * MSEC_PER_HOUR
576 + (int64_t)_minutes * MSEC_PER_MIN
577 + _seconds * 1000
578 + _milliseconds;
579}
580
581void Interval::assign(int64_t _milliseconds)
582{
583 __milliseconds = _milliseconds;
584}
585
587{
589
590 return *this;
591}
592
594{
596
597 return *this;
598}
599
601{
603
604 return *this;
605}
606
608{
610 return r;
611}
612
614{
616 return r;
617}
618
619void Interval::decode(long& _days,
620 int& _hours, int& _minutes, int& _seconds,
621 int& _milliseconds
622 ) const
623{
624 _days = (long)(__milliseconds / MSEC_PER_DAY);
625 _hours = (int)((__milliseconds % MSEC_PER_DAY) / MSEC_PER_HOUR);
626 _minutes = (int)((__milliseconds % MSEC_PER_HOUR) / MSEC_PER_MIN);
627 _seconds = (int)((__milliseconds % MSEC_PER_MIN) / 1000);
628 _milliseconds = (int)(__milliseconds % 1000);
629}
630
631void Interval::decode(long& _days, long& _milliseconds) const
632{
633 _days = (long)(__milliseconds / MSEC_PER_DAY);
634 _milliseconds = (long)(__milliseconds % MSEC_PER_DAY);
635}
636
637long Interval::days() const
638{
639 return (long)(__milliseconds / MSEC_PER_DAY);
640}
641
642int Interval::hour() const
643{
644 return (int)((__milliseconds % MSEC_PER_DAY) / MSEC_PER_HOUR);
645}
646
648{
649 return (int)((__milliseconds % MSEC_PER_HOUR) / MSEC_PER_MIN);
650}
651
653{
654 return (int)((__milliseconds % MSEC_PER_MIN) / 1000);
655}
656
658{
659 return (int)(__milliseconds % 1000);
660}
661
662int64_t Interval::totalHours() const
663{
665}
666
668{
670}
671
673{
674 return __milliseconds / 1000;
675}
676
677String Interval::toString() const
678{
679 long d;
680 int h, m, s, msec;
681 decode(d, h, m, s, msec);
682 if (__milliseconds < 0) {
683 return String::format(L"-%ld %02d:%02d:%02d.%03d",
684 -d,
685 -h, -m, -s, -msec
686 );
687 }
688 else {
689 return String::format(L"+%ld %02d:%02d:%02d.%03d",
690 d,
691 h, m, s, msec
692 );
693 }
694}
695
696// static members
697
700{
701 __date = _src.__date;
702 __time = _src.__time;
703}
704
705DateTime::DateTime(time_t _timer)
706{
707 assign(_timer);
708}
709
710DateTime::DateTime(const Date& _date, const Time& _time)
711{
712 __date = _date;
713 __time = _time;
714}
715
716DateTime::DateTime(int _year, int _month, int _day,
717 int _hour, int _min, int _sec, int _millisecond /* = 0 */)
718{
719 __date.assign(_year, _month, _day);
720 __time.assign(_hour, _min, _sec, _millisecond);
721}
722
723void DateTime::assign(time_t _timer)
724{
725 long tm_gmtoff = 0;
726
727#if __DCL_WINDOWS
728 long seconds;
729 _get_timezone(&seconds);
730 tm_gmtoff = -seconds;
731#else
732 struct tm tm;
733 localtime_r(&_timer, &tm);
734 tm_gmtoff = tm.tm_gmtoff;
735#endif
736
737 __date.assign(
738 (long) (719163 + ((_timer + tm_gmtoff) / SEC_PER_DAY)) // 1970-01-01 00:00:00 + time
739 );
740 __time.assign(
741 0,
742 0,
743 _timer % SEC_PER_DAY + tm_gmtoff,
744 0
745 );
746}
747
748void DateTime::assign(const Date& _date, const Time& _time)
749{
750 __date = _date;
751 __time = _time;
752}
753
754void DateTime::assign(int _year, int _month, int _day,
755 int _hour, int _min, int _sec, int _millisecond /* = 0 */)
756{
757 __date.assign(_year, _month, _day);
758 __time.assign(_hour, _min, _sec, _millisecond);
759}
760
762{
763 __date = _src.__date;
764 __time = _src.__time;
765
766 return *this;
767}
768
770{
771 int64_t msec = (int64_t)__date.days() * MSEC_PER_DAY
772 + (int64_t)__time.totalMilliSeconds()
773 + _iv.totalMilliSeconds();
774
775 __date.assign((long)(msec / MSEC_PER_DAY));
776 __time.assign((long)(msec % MSEC_PER_DAY));
777
778 return *this;
779}
780
782{
783 int64_t msec = (int64_t)__date.days() * MSEC_PER_DAY
784 + (int64_t)__time.totalMilliSeconds()
785 - _iv.totalMilliSeconds();
786
787 __date.assign((long)(msec / MSEC_PER_DAY));
788 __time.assign((long)(msec % MSEC_PER_DAY));
789
790 return *this;
791}
792
794{
795 DateTime r = _dt;
796 r += _iv;
797 return r;
798}
799
801{
802 return operator + (_dt, _iv);
803}
804
806{
807 DateTime r = _dt;
808 r -= _iv;
809
810 return r;
811}
812
814{
815 Interval r(
816 (int64_t)_dt1.date().days() * MSEC_PER_DAY
817 + (int64_t)_dt1.time().totalMilliSeconds()
818 - (int64_t)_dt2.date().days() * MSEC_PER_DAY
819 - (int64_t)_dt2.time().totalMilliSeconds()
820 );
821
822 return r;
823}
824
825// Date::toString() + Time::toString()
826String DateTime::toString() const
827{
828 return __date.toString() + L" " + __time.toString();
829}
830
831const wchar_t* DateTime::FORMAT_STRING = L"%Y-%m-%d %H:%M:%S";
832
833// strftime
834String DateTime::toStringF(const wchar_t* _format) const
835{
836 if (!_format)
837 _format = FORMAT_STRING;
838
839 __DCL_ASSERT(*_format != L'\0');
840
841 int year, month, day, hour, min, sec, msec;
842 __date.decode(year, month, day);
843 __time.decode(hour, min, sec, msec);
844
845 struct tm time;
846 time.tm_year = year - 1900;
847 time.tm_mon = month - 1;
848 time.tm_mday = day;
849 time.tm_hour = hour;
850 time.tm_min = min;
851 time.tm_sec = sec;
852
853 time.tm_wday = 0;
854 time.tm_yday = 0;
855 time.tm_isdst = -1;
856
857 CharBuffer* buf = CharBuffer::create(DATETIME_FORMAT_BUFFER_SIZE);
858 size_t n = wcsftime(buf->data(), DATETIME_FORMAT_BUFFER_SIZE, _format, &time);
859 __DCL_ASSERT(buf->__allocLength >= n);
860 buf->__dataLength = n;
861 __DCL_ASSERT(buf->data()[buf->__dataLength] == __T('\0'));
862
863 String r = buf;
864 buf->release();
865 return r;
866}
867
868// static members
869int DateTime::compare(const DateTime& _dt1, const DateTime& _dt2)
870{
871 if (_dt1.__date < _dt2.__date)
872 return -1;
873 else if (_dt1.__date == _dt2.__date) {
874 if (_dt1.__time < _dt2.__time)
875 return -1;
876 else if (_dt1.__time == _dt2.__time)
877 return 0;
878 }
879 return 1;
880}
881
883{
884#if __DCL_WINDOWS
885 SYSTEMTIME time;
886 GetSystemTime(&time);
887
888 Date dt(time.wYear, time.wMonth, time.wDay);
889 int64_t r = dt.days() * 24;
890 r = (r + time.wHour) * 60;
891 r = (r + time.wMinute) * 60;
892 r = (r + time.wSecond) * 1000;
893 r += time.wMilliseconds;
894 return r;
895#else
896 struct timeval tv;
897 gettimeofday(&tv, NULL);
898 int64_t r = tv.tv_sec * 1000;
899 r += tv.tv_usec / 1000;
900 return r;
901#endif
902}
903
905{
906 DateTime r;
907#if __DCL_WINDOWS
908 struct _timeb timeb;
909 _ftime_s(&timeb);
910
911 r.__date.assign(
912 (long) (719163 + (timeb.time / SEC_PER_DAY)) // 1970-01-01 00:00:00 + time
913 );
914 r.__time.assign(
915 0,
916 0,
917 timeb.time % SEC_PER_DAY,
918 timeb.millitm
919 );
920#else
921 struct timeval tv;
922 gettimeofday(&tv, NULL);
923
924 r.__date.assign(
925 719163 + tv.tv_sec / SEC_PER_DAY // 1970-01-01 00:00:00 + time
926 );
927 r.__time.assign(
928 0,
929 0,
930 tv.tv_sec % SEC_PER_DAY,
931 tv.tv_usec / 1000
932 );
933#endif
934 return r;
935}
936
938{
939 DateTime r;
940#if __DCL_WINDOWS
941 struct _timeb timeb;
942 _ftime_s(&timeb);
943
944 r.__date.assign(
945 (long) (719163 + ((timeb.time - timeb.timezone * 60) / SEC_PER_DAY)) // 1970-01-01 00:00:00 + time
946 );
947 r.__time.assign(
948 0,
949 -timeb.timezone,
950 timeb.time % SEC_PER_DAY,
951 timeb.millitm
952 );
953#else
954 time_t timer;
955 struct tm tm;
956 ::time(&timer);
957 localtime_r(&timer, &tm);
958
959 struct timeval tv;
960 gettimeofday(&tv, NULL);
961
962 r.__date.assign(
963 719163 + (tv.tv_sec + tm.tm_gmtoff) / SEC_PER_DAY // 1970-01-01 00:00:00 + time
964 );
965 r.__time.assign(
966 0,
967 0,
968 tv.tv_sec % SEC_PER_DAY + tm.tm_gmtoff,
969 tv.tv_usec / 1000
970 );
971#endif
972 return r;
973}
974
975#if 0
976DateTime DateTime::parseF(
977 const char* pszDateTimeString,
978 const char* _format
980{
981 __DCL_ASSERT(pszDateTimeString != NULL && *pszDateTimeString != '\0');
982 __DCL_ASSERT(_format != NULL && *_format != '\0');
983
984 struct tm tm;
985 memset(&tm, 0, sizeof(tm));
986 const char* p = strptime(pszDateTimeString, _format, &tm);
987 if (p == NULL) {
988 throw new ParseException(L"no match to format");
989 }
990
991 if (*p != '\0') {
992 throw new ParseException(
993 L"extra data",
994 p - pszDateTimeString
995 );
996
997 }
998
999 DateTime _dt2(
1000 tm.tm_year + 1900,
1001 tm.tm_mon + 1,
1002 tm.tm_mday,
1003 tm.tm_hour,
1004 tm.tm_min,
1005 tm.tm_sec
1006 );
1007
1008 return _dt2;
1009}
1010#endif
1011
1012__DCL_END_NAMESPACE
#define __THIS_FILE__
Definition _trace.h:14
#define NULL
Definition Config.h:340
#define DCLCAPI
Definition Config.h:100
wchar_t char_t
Definition Config.h:275
#define __DCL_THROWS1(e)
Definition Config.h:167
#define MSEC_PER_HOUR
Definition DateTime.cpp:392
#define SEC_PER_DAY
Definition DateTime.cpp:389
DCLCAPI Interval operator-(const Interval &_iv1, const Interval &_iv2)
Definition DateTime.cpp:613
DCLCAPI Date operator+(const Date &_date, long _days)
Definition DateTime.cpp:178
#define AD_START
Definition DateTime.cpp:60
#define BC_END
Definition DateTime.cpp:61
#define MSEC_PER_DAY
Definition DateTime.cpp:390
#define MSEC_PER_MIN
Definition DateTime.cpp:394
#define DATETIME_FORMAT_BUFFER_SIZE
Definition DateTime.h:21
#define __DCL_ASSERT(expr)
Definition Object.h:371
#define __T(str)
Definition Object.h:44
ByteString r
ByteBuffer * buf
void CharsetConvertException *size_t n
Definition SQLField.cpp:254
return result
const Date & operator=(const Date &_src)
Definition DateTime.cpp:138
long __jday
Definition DateTime.h:77
const Date & operator--()
Definition DateTime.cpp:112
void assign(int _year, int _month, int _day)
Definition DateTime.cpp:49
long days() const
Definition DateTime.cpp:74
int day() const
Definition DateTime.cpp:204
static long convertGregorianToJulian(int _year, int _month, int _day)
Definition DateTime.cpp:285
static bool isValid(int y, int m, int d)
Definition DateTime.cpp:350
static void convertJulianToGregorian(long uJulianDays, int &_year, int &_month, int &_day)
Definition DateTime.cpp:313
String toStringF(const wchar_t *_format=NULL) const
Definition DateTime.cpp:256
int daysInYear() const
Definition DateTime.cpp:237
int month() const
Definition DateTime.cpp:197
static const wchar_t * FORMAT_STRING
Definition DateTime.h:66
String toString() const
Definition DateTime.cpp:247
const Date & operator++()
Definition DateTime.cpp:86
int dayOfWeek() const
Definition DateTime.cpp:211
int daysInMonth() const
Definition DateTime.cpp:227
const Date & operator+=(long _days)
Definition DateTime.cpp:144
void decode(int &_year, int &_month, int &_day) const
Definition DateTime.cpp:185
const Date & operator-=(long _days)
Definition DateTime.cpp:171
Date()
Definition DateTime.cpp:29
int year() const
Definition DateTime.cpp:190
static bool isLeapYear(int _year)
Definition DateTime.cpp:370
int dayOfYear() const
Definition DateTime.cpp:216
const DateTime & operator+=(const Interval &_iv)
Definition DateTime.cpp:769
void assign(time_t _timer)
Definition DateTime.cpp:723
Time & time()
Definition DateTime.inl:162
String toString() const
Definition DateTime.cpp:826
const DateTime & operator=(const DateTime &_src)
Definition DateTime.cpp:761
static const wchar_t * FORMAT_STRING
Definition DateTime.h:236
Time __time
Definition DateTime.h:265
static DateTime getCurrentUTCTime()
Definition DateTime.cpp:904
static int64_t getCurrentTimeMillis()
Definition DateTime.cpp:882
String toStringF(const wchar_t *_format=NULL) const
Definition DateTime.cpp:834
Date & date()
Definition DateTime.inl:152
Date __date
Definition DateTime.h:264
static DateTime getCurrentLocalTime()
Definition DateTime.cpp:937
static int compare(const DateTime &_dt1, const DateTime &_dt2)
Definition DateTime.cpp:869
const DateTime & operator-=(const Interval &_iv)
Definition DateTime.cpp:781
long days() const
Definition DateTime.cpp:637
int64_t totalHours() const
Definition DateTime.cpp:662
int64_t totalMinutes() const
Definition DateTime.cpp:667
void assign(int _days, int _milliseconds)
Definition DateTime.cpp:564
int hour() const
Definition DateTime.cpp:642
int64_t totalSeconds() const
Definition DateTime.cpp:672
String toString() const
Definition DateTime.cpp:677
void decode(long &_days, int &_hours, int &_minutes, int &_seconds, int &_milliseconds) const
Definition DateTime.cpp:619
int minute() const
Definition DateTime.cpp:647
int64_t totalMilliSeconds() const
Definition DateTime.inl:116
const Interval & operator-=(const Interval &_iv)
Definition DateTime.cpp:600
const Interval & operator+=(const Interval &_iv)
Definition DateTime.cpp:593
const Interval & operator=(const Interval &_src)
Definition DateTime.cpp:586
int64_t __milliseconds
Definition DateTime.h:200
int msecond() const
Definition DateTime.cpp:657
int second() const
Definition DateTime.cpp:652
String toStringF(const wchar_t *_format=NULL)
Definition DateTime.cpp:500
const Time & operator=(const Time &_src)
Definition DateTime.cpp:426
int hour() const
Definition DateTime.cpp:467
int second() const
Definition DateTime.cpp:477
void decode(int &_hour, int &_min, int &_sec, int &_millisecond) const
Definition DateTime.cpp:459
static const wchar_t * FORMAT_STRING
Definition DateTime.h:129
int msecond() const
Definition DateTime.cpp:482
static bool isValid(int _hour, int _min, int _sec, int _millisecond)
Definition DateTime.cpp:525
const Time & operator-=(long _milliseconds)
Definition DateTime.cpp:442
int minute() const
Definition DateTime.cpp:472
unsigned long __milliseconds
Definition DateTime.h:139
void assign(int _hour, int _min, int _sec, int _millisecond=0)
Definition DateTime.cpp:406
String toString() const
Definition DateTime.cpp:488
long totalMilliSeconds() const
Definition DateTime.inl:65
const Time & operator+=(long _milliseconds)
Definition DateTime.cpp:432