1 /***************************************************************************
2 * Copyright (C) 2007 by www.databasecache.com *
3 * Contact: praba_tuty@databasecache.com *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) any later version. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 ***************************************************************************/
20 #define SmallestValJulDate (1721426)
22 Date::Date(int year
, int month
, int day
)
23 { YMDToJulian(year
, month
, day
, julianDate
); }
24 int Date::set(int year
, int month
, int day
)
25 { return YMDToJulian(year
,month
,day
,julianDate
); }
26 int Date::get(int &year
, int &month
, int &day
) const
27 { return julianToYMD(julianDate
,year
,month
,day
); }
29 int Date::parseFrom(const char *s
) {
32 count
= sscanf(s
,"%d/%d/%d",&year
,&month
,&day
);
33 if (count
< 3) return -1;
35 if (year
< 100) year
+= 1900;
37 if (!isValidDate(year
, month
, day
))
39 return set(year
,month
,day
);
42 int Date::dayOfMonth() const {
47 int Date::month() const {
52 int Date::year() const {
58 int Date::dayOfWeek() const { return dayOfWeek(julianDate
); }
60 const char *Date::dayOfWeekName() const
61 { return dayOfWeekName(dayOfWeek(julianDate
)); }
63 const char *Date::dayOfWeekAbbr() const
64 { return dayOfWeekAbbr(dayOfWeek(julianDate
)); }
66 static const char *day_names
[] = {
67 "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"
69 static const char *day_abbrs
[] = {
70 "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"
73 static const char *month_names
[] = {
74 "January", "February", "March", "April", "May", "June",
75 "July", "August", "September", "October", "November", "December"
77 static const char *month_abbrs
[] = {
78 "Jan", "Feb", "Mar", "Apr", "May", "Jun",
79 "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"
83 static int daysBeforeMonth
[] = {
84 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365
86 static int days_per_month
[] = {
87 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31
90 const char * Date::dayOfWeekName(int day
)
91 { return (day
< 1 || day
> 7) ? 0 : day_names
[day
-1]; }
93 const char * Date::dayOfWeekAbbr(int day
)
94 { return (day
< 1 || day
> 7) ? 0 : day_abbrs
[day
-1]; }
96 const char * Date::monthName() const { return monthName(month()); }
97 const char * Date::monthAbbr() const { return monthAbbr(month()); }
98 const char * Date::monthName(int month
)
99 { return (month
< 1 || month
> 12) ? 0 : month_names
[month
-1]; }
100 const char * Date::monthAbbr(int month
)
101 { return (month
< 1 || month
> 12) ? 0 : month_abbrs
[month
-1]; }
102 Date
operator+(const Date
&d1
, int days
)
103 { return Date(d1
.julianDate
+ days
); }
104 Date
operator+(int days
, const Date
&d1
)
105 { return Date(d1
.julianDate
+ days
); }
106 Date
operator-(const Date
&d1
, int days
)
107 { return Date(d1
.julianDate
- days
); }
109 int operator-(const Date
&d1
, const Date
& d2
)
110 { return d1
.julianDate
- d2
.julianDate
; }
112 int operator<(const Date
&d1
,const Date
&d2
)
113 { return d1
.julianDate
< d2
.julianDate
; }
114 int operator>(const Date
&d1
,const Date
&d2
)
115 { return d1
.julianDate
> d2
.julianDate
; }
116 int operator<=(const Date
&d1
,const Date
&d2
)
117 { return d1
.julianDate
<= d2
.julianDate
; }
118 int operator>=(const Date
&d1
,const Date
&d2
)
119 { return d1
.julianDate
>= d2
.julianDate
; }
120 int operator==(const Date
&d1
,const Date
&d2
)
121 { return d1
.julianDate
== d2
.julianDate
; }
122 int operator!=(const Date
&d1
,const Date
&d2
)
123 { return d1
.julianDate
!= d2
.julianDate
; }
125 bool Date::isValid() const
126 { return julianDate
>= SmallestValJulDate
; }
128 bool Date::isLeapYear(int year
)
130 return (year
% 400 == 0) || ((year
% 4 == 0) && !(year
% 100 == 0));
133 int Date::dayOfYear() const {
136 int tmp
= daysBeforeMonth
[month
-1];
137 if (month
>= 3 && isLeapYear(year
))
142 int Date::daysInMonth(int month
, int year
) {
144 int tmp
= days_per_month
[month
];
145 if (month
== 1 && isLeapYear(year
)) tmp
++;
149 bool Date::isValidDate(int year
, int month
, int day
) {
150 if (year
< 1 || year
> 10000) return false;
151 if (month
< 1 || month
> 12) return false;
152 return (day
>= 1) && (day
<= daysInMonth(month
,year
));
155 // Algorithm Author: Robert G. Tantzen
156 int Date::YMDToJulian(int year
, int mon
, int day
, JulianRep
&jul
) {
157 if (!isValidDate(year
, mon
, day
))
158 { jul
= (JulianRep
)0; return -1; }
160 // year, month, day are assumed to be valid
161 int m
= mon
, d
= day
, y
= year
;
165 else { m
+= 9; --y
; }
168 j
= (146097*c
)/4 + (1461*ya
)/4 + (153*m
+2)/5 + d
+ 1721119;
173 // Julian date converter. Takes a julian date (the number of days since some
174 // distant epoch or other), and returns month, day of month, and year in
175 // integer references.
176 // Algorithm Author: Robert G. Tantzen
177 int Date::dayOfWeek(JulianRep jul
) {
178 return (int)((jul
+1)%7+1);
181 int Date::julianToYMD(JulianRep jul
, int &year
, int &month
, int &day
) {
185 if (j
< SmallestValJulDate
)
186 { year
= month
= day
= 0; return -1; }
189 y
= (4 * j
- 1)/146097;
190 j
= 4 * j
- 1 - 146097 * y
;
192 j
= (4 * d
+ 3)/1461;
193 d
= 4 * d
+ 3 - 1461 * j
;
196 d
= 5 * d
- 3 - 153 * m
;
200 else { m
-= 9; ++y
; }
207 #define MAX_VALID_SECONDS (60 * 60 * 24 -1)
208 Time::Time(int hours
, int mins
, int secs
, int usec
)
209 { set(hours
,mins
,secs
, usec
); }
211 int Time::set(int hours
, int mins
, int secs
, int usec
) {
212 if((hours
| mins
| secs
| usec
) < 0) { timeVal
= -1; return -1; }
213 if(hours
>= 24 | mins
>= 60 | secs
>= 62)
214 { timeVal
= -1; return -1; }
215 timeVal
= secs
+ mins
* 60 + hours
* 3600;
217 if(usec
) timeVal
+= usec
/100;
221 int Time::get(int &hours
, int &mins
, int &secs
) const {
222 if (timeVal
< 0) return -1;
223 int s
= timeVal
/10000;
232 int Time::seconds() const { return (timeVal
/10000) % 60; }
233 int Time::minutes() const { return (timeVal
/(60*10000)) % 60; }
234 int Time::hours() const { return timeVal
/ (3600*10000); }
235 int Time::msec() const { return (timeVal
% 10000) / 10; }
236 int Time::usec() const { return (timeVal
% 10000) * 100; }
238 int Time::setMsec(int ms
) {
239 if(ms
< 0 || ms
>= 1000) return -1;
240 timeVal
= timeVal
+(10*ms
);
243 int Time::setUsec(int us
) {
244 if(us
< 0 || us
>= 1000000) return -1;
245 timeVal
= timeVal
+us
/100;
249 bool Time::isValid() const
250 { return timeVal
>= 0 && timeVal
<= (10000*(MAX_VALID_SECONDS
+1)-1); }
252 bool Time::isValidTime(int hours
, int mins
, int secs
) {
253 return (hours
>= 0 && hours
< 24) &&
254 (mins
>= 0 && mins
< 60) &&
255 (secs
>= 0 && secs
< 60);
258 Time
operator+(const Time
&t1
, int seconds
)
259 { return Time(t1
.timeVal
+ seconds
*10000); }
260 Time
operator+(int seconds
, const Time
&t1
)
261 { return Time(t1
.timeVal
+ seconds
*10000); }
262 Time
operator-(const Time
&t1
, int seconds
)
263 { return Time(t1
.timeVal
- seconds
*10000); }
265 int operator-(const Time
&t1
, const Time
& t2
)
266 { return (t1
.timeVal
- t2
.timeVal
)/10000; }
268 int operator<(const Time
&t1
,const Time
&t2
)
269 { return t1
.timeVal
< t2
.timeVal
; }
270 int operator>(const Time
&t1
,const Time
&t2
)
271 { return t1
.timeVal
> t2
.timeVal
; }
272 int operator<=(const Time
&t1
,const Time
&t2
)
273 { return t1
.timeVal
<= t2
.timeVal
; }
274 int operator>=(const Time
&t1
,const Time
&t2
)
275 { return t1
.timeVal
>= t2
.timeVal
; }
276 int operator==(const Time
&t1
,const Time
&t2
)
277 { return t1
.timeVal
== t2
.timeVal
; }
278 int operator!=(const Time
&t1
,const Time
&t2
)
279 { return t1
.timeVal
!= t2
.timeVal
; }
281 int Time::parseFrom(const char *s
) {
284 count
= sscanf(s
,"%d:%d:%d",&hours
,&mins
,&secs
);
285 if (count
< 2) return -1;
286 if (count
== 2) secs
= 0;
288 if (!isValidTime(hours
,mins
,secs
))
290 return set(hours
,mins
,secs
);
292 int TimeStamp::parseFrom(const char *s
) {
296 count
= sscanf(s
,"%d/%d/%d %d:%d:%d",&year
,&month
,&day
, &hours
, &mins
, &secs
);
297 if (count
< 5) return -1;
298 if (count
== 5) secs
= 0;
300 if (year
< 100) year
+= 1900;
302 if (!date
.isValidDate(year
, month
, day
))
305 setDate(year
,month
,day
);
308 if (!time
.isValidTime(hours
,mins
,secs
))
310 return setTime(hours
,mins
,secs
);
313 int operator< (const TimeStamp
&d1
, const TimeStamp
&d2
)
314 { return (d1
.date
!= d2
.date
) ? d1
.date
< d2
.date
: d1
.time
< d2
.time
; }
315 int operator> (const TimeStamp
&d1
, const TimeStamp
&d2
)
316 { return (d1
.date
!= d2
.date
) ? d1
.date
> d2
.date
: d1
.time
> d2
.time
; }
317 int operator<=(const TimeStamp
&d1
, const TimeStamp
&d2
)
318 { return (d1
.date
!= d2
.date
) ? d1
.date
< d2
.date
: d1
.time
<= d2
.time
; }
319 int operator>=(const TimeStamp
&d1
, const TimeStamp
&d2
)
320 { return (d1
.date
!= d2
.date
) ? d1
.date
> d2
.date
: d1
.time
>= d2
.time
; }
321 int operator==(const TimeStamp
&d1
, const TimeStamp
&d2
)
322 { return d1
.date
== d2
.date
&& d1
.time
== d2
.time
; }
323 int operator!=(const TimeStamp
&d1
, const TimeStamp
&d2
)
324 { return d1
.date
!= d2
.date
&& d1
.time
!= d2
.time
; }
327 long AllDataType::size(DataType type
, int length
)
329 if (type
== typeInt
) return sizeof(int);
330 else if (type
== typeString
) return length
;
342 size
= sizeof(long long);
345 size
= sizeof(short);
351 size
= sizeof(double);
354 size
= sizeof(float);
358 //fldDef.length_ = sizeof(long double);
367 size
= sizeof(TimeStamp
);
380 char* AllDataType::getSQLString(DataType type
)
384 case typeInt
: return "INT";
385 case typeLong
: return "INT";
386 case typeLongLong
: return "BIGINT";
387 case typeShort
: return "SMALLINT";
388 case typeByteInt
: return "TINYINT";
389 case typeDouble
: return "REAL";
390 case typeFloat
: return "FLOAT";
391 case typeDate
: return "DATE";
392 case typeTime
: return "TIME";
393 case typeTimeStamp
: return "TIMESTAMP";
394 case typeString
: return "CHAR";
395 case typeBinary
: return "BINARY";
396 default: return "UNKNOWN";
401 SQLSMALLINT
AllDataType::convertToSQLType(DataType type
)
425 return SQL_TYPE_DATE
;
427 return SQL_TYPE_TIME
;
429 return SQL_TYPE_TIMESTAMP
;
437 SQLSMALLINT
AllDataType::convertToSQL_C_Type(DataType type
)
446 return SQL_C_SBIGINT
;
450 return SQL_C_STINYINT
;
459 return SQL_C_TYPE_DATE
;
461 return SQL_C_TYPE_TIME
;
463 return SQL_C_TYPE_TIMESTAMP
;
472 DataType
AllDataType::convertFromSQLType(SQLSMALLINT type
)
489 case SQL_TYPE_TIMESTAMP
:
490 return typeTimeStamp
;
500 void AllDataType::copyVal(void* dest
, void *src
, DataType type
, int length
)
502 //Performance optimization. putting likely case first
503 if (typeInt
== type
)
505 *(int*)dest
= *(int*)src
;
507 }else if (typeString
== type
)
509 //null is always put at the last byte by insert
510 //so using strcpy is safe
511 //strcpy((char*)dest, (char*)src);
512 strncpy((char*)dest
, (char*)src
, length
);
513 char *d
=(char*)dest
;
516 }else if (typeShort
== type
) {
517 *(short*)dest
= *(short*)src
;
518 }else if (typeDouble
== type
) {
519 *(double*)dest
= *(double*)src
;
520 }else if (typeTimeStamp
== type
) {
521 *(TimeStamp
*)dest
= *(TimeStamp
*)src
;
522 }else if (typeDate
== type
) {
523 *(Date
*)dest
= *(Date
*)src
;
524 }else if (typeFloat
== type
) {
525 *(float*)dest
= *(float*)src
;
526 }else if (typeTime
== type
) {
527 *(Time
*)dest
= *(Time
*)src
;
528 }else if (typeLong
== type
) {
529 *(long*)dest
= *(long*)src
;
530 }else if (typeLongLong
== type
) {
531 *(long long*)dest
= *(long long*)src
;
532 }else if (typeByteInt
== type
) {
533 *(char*)dest
= *(char*)src
;
534 }else if (typeBinary
== type
) {
535 os::memcpy(dest
, src
, length
);
536 }else if (typeComposite
== type
) {
537 os::memcpy(dest
, src
, length
);
541 void AllDataType::addVal(void* dest
, void *src
, DataType type
)
545 *(int*)dest
= *(int*)dest
+ *(int*)src
;
551 *(int*)dest
= *(int*)dest
+ *(int*)src
;
554 *(long*)dest
= *(long*)dest
+ *(long*)src
;
557 *(long long*)dest
= *(long long*)dest
+ *(long long*)src
;
560 *(short*)dest
= *(short*)dest
+ *(short*)src
;
563 *(char*)dest
= *(char*)dest
+ *(char*)src
;
566 *(double*)dest
= *(double*)dest
+ *(double*)src
;
569 *(float*)dest
= *(float*)dest
+ *(float*)src
;
582 void AllDataType::subVal(void* dest
, void *src
, DataType type
)
587 *(int*)dest
= *(int*)dest
- *(int*)src
;
590 *(long*)dest
= *(long*)dest
- *(long*)src
;
593 *(long long*)dest
= *(long long*)dest
- *(long long*)src
;
596 *(short*)dest
= *(short*)dest
- *(short*)src
;
599 *(char*)dest
= *(char*)dest
- *(char*)src
;
602 *(double*)dest
= *(double*)dest
- *(double*)src
;
605 *(float*)dest
= *(float*)dest
- *(float*)src
;
617 void AllDataType::mulVal(void* dest
, void *src
, DataType type
)
622 *(int*)dest
= *(int*)dest
* (*(int*)src
);
625 *(long*)dest
= *(long*)dest
* (*(long*)src
);
628 *(long long*)dest
= *(long long*)dest
* (*(long long*)src
);
631 *(short*)dest
= *(short*)dest
* (*(short*)src
);
634 *(char*)dest
= *(char*)dest
* (*(char*)src
);
637 *(double*)dest
= *(double*)dest
* (*(double*)src
);
640 *(float*)dest
= *(float*)dest
* (*(float*)src
);
652 void AllDataType::mudVal(void* dest
, void *src
, DataType type
)
656 *(int*)dest
= *(int*)dest
% (*(int*)src
);
662 *(int*)dest
= *(int*)dest
% (*(int*)src
);
665 *(long*)dest
= *(long*)dest
% (*(long*)src
);
668 *(long long*)dest
= *(long long*)dest
% (*(long long*)src
);
671 *(short*)dest
= *(short*)dest
% (*(short*)src
);
674 *(char*)dest
= *(char*)dest
% (*(char*)src
);
677 *(double*)dest
= *(long long*)dest
% (*(long long*)src
);
680 *(float*)dest
= *(int*)dest
% (*(int*)src
);
692 void AllDataType::divVal(void* dest
, void *src
, DataType type
)
696 *(int*)dest
= *(int*)dest
/ (*(int*)src
);
702 *(int*)dest
= *(int*)dest
/ (*(int*)src
);
705 *(long*)dest
= *(long*)dest
/ (*(long*)src
);
708 *(long long*)dest
= *(long long*)dest
/ (*(long long*)src
);
711 *(short*)dest
= *(short*)dest
/ (*(short*)src
);
714 *(char*)dest
= *(char*)dest
/ (*(char*)src
);
717 *(double*)dest
= *(double *)dest
/ (*(double*)src
);
720 *(float*)dest
= *(float*)dest
/ (*(float*)src
);
732 void AllDataType::divVal(void* dest
, int src
, DataType type
)
736 *(int*)dest
= *(int*)dest
/ src
;
742 *(int*)dest
= *(int*)dest
/ src
;
745 *(long*)dest
= *(long*)dest
/ src
;
748 *(long long*)dest
= *(long long*)dest
/ src
;
751 *(short*)dest
= *(short*)dest
/ src
;
754 *(char*)dest
= *(char*)dest
/ src
;
757 *(double*)dest
= *(double*)dest
/ src
;
760 *(float*)dest
= *(float*)dest
/ src
;
774 bool AllDataType::compareVal(void *val1
, void *val2
, ComparisionOp op
,
775 DataType type
, long length
)
777 //Performance optimization.
778 //do not convert compareXXXVal to virtual functions. it takes more time
781 //as int is the heavily used type, hardcoding the compare here itself
782 if (OpEquals
== op
) {
783 if (*(int*)val1
== *(int*)val2
) return true;
785 }else if (OpGreaterThanEquals
== op
) {
786 if (*(int*)val1
>= *(int*)val2
) return true;
788 }else if (OpLessThanEquals
== op
) {
789 if (*(int*)val1
<= *(int*)val2
) return true;
791 }else if (OpGreaterThan
== op
) {
792 if (*(int*)val1
> *(int*)val2
) return true;
794 }else if (OpLessThan
== op
) {
795 if (*(int*)val1
< *(int*)val2
) return true;
797 }else if (OpNotEquals
== op
) {
798 if (*(int*)val1
!= *(int*)val2
) return true;
802 }else if(typeString
== type
) {
803 return AllDataType::compareStringVal(val1
, val2
, op
);
804 } else if (typeShort
== type
) {
805 return AllDataType::compareShortVal(val1
, val2
, op
);
806 } else if (typeDouble
== type
) {
807 return AllDataType::compareDoubleVal(val1
, val2
, op
);
808 } else if (typeFloat
== type
) {
809 return AllDataType::compareFloatVal(val1
, val2
, op
);
810 } else if (typeLong
== type
) {
811 return AllDataType::compareLongVal(val1
, val2
, op
);
812 } else if (typeLongLong
== type
) {
813 return AllDataType::compareLongLongVal(val1
, val2
, op
);
814 } else if (typeByteInt
== type
) {
815 return AllDataType::compareByteIntVal(val1
, val2
, op
);
816 } else if (typeTimeStamp
== type
) {
817 return AllDataType::compareTimeStampVal(val1
, val2
, op
);
818 } else if (typeDate
== type
) {
819 return AllDataType::compareDateVal(val1
, val2
, op
);
820 } else if (typeTime
== type
) {
821 return AllDataType::compareTimeVal(val1
, val2
, op
);
822 } else if (typeBinary
== type
) {
823 return AllDataType::compareBinaryVal(val1
, val2
, op
, length
);
824 } else if (typeComposite
== type
) {
825 return AllDataType::compareBinaryVal(val1
, val2
, op
, length
);
829 bool AllDataType::compareIntVal(void* src1
, void *src2
, ComparisionOp op
)
831 printf("This function should never be called by anyone");
832 if (OpEquals
== op
) {
833 if (*(int*)src1
== *(int*)src2
) return true;
835 }else if (OpGreaterThan
== op
) {
836 if (*(int*)src1
> *(int*)src2
) return true;
838 }else if (OpLessThan
== op
) {
839 if (*(int*)src1
< *(int*)src2
) return true;
841 }else if (OpLessThanEquals
== op
) {
842 if (*(int*)src1
<= *(int*)src2
) return true;
844 }else if (OpGreaterThanEquals
== op
) {
845 if (*(int*)src1
>= *(int*)src2
) return true;
847 }else if (OpNotEquals
== op
) {
848 if (*(int*)src1
!= *(int*)src2
) return true;
854 bool AllDataType::compareLongVal(void* src1
, void *src2
, ComparisionOp op
)
860 if (*(long*)src1
== *(long*)src2
) result
= true;
864 if (*(long*)src1
!= *(long*)src2
) result
= true;
868 if (*(long*)src1
< *(long*)src2
) result
= true;
871 case OpLessThanEquals
:
872 if (*(long*)src1
<= *(long*)src2
) result
= true;
876 if (*(long*)src1
> *(long*)src2
) result
= true;
879 case OpGreaterThanEquals
:
880 if (*(long*)src1
>= *(long*)src2
) result
= true;
887 bool AllDataType::compareLongLongVal(void* src1
, void *src2
,
894 if (*(long long*)src1
== *(long long*)src2
) result
= true;
898 if (*(long long*)src1
!= *(long long*)src2
) result
= true;
902 if (*(long long*)src1
< *(long long*)src2
) result
= true;
905 case OpLessThanEquals
:
906 if (*(long long*)src1
<= *(long long*)src2
) result
= true;
910 if (*(long long*)src1
> *(long long*)src2
) result
= true;
913 case OpGreaterThanEquals
:
914 if (*(long long*)src1
>= *(long long*)src2
) result
= true;
921 bool AllDataType::compareShortVal(void* src1
, void *src2
, ComparisionOp op
)
927 if (*(short*)src1
== *(short*)src2
) result
= true;
931 if (*(short*)src1
!= *(short*)src2
) result
= true;
935 if (*(short*)src1
< *(short*)src2
) result
= true;
938 case OpLessThanEquals
:
939 if (*(short*)src1
<= *(short*)src2
) result
= true;
943 if (*(short*)src1
> *(short*)src2
) result
= true;
946 case OpGreaterThanEquals
:
947 if (*(short*)src1
>= *(short*)src2
) result
= true;
954 bool AllDataType::compareByteIntVal(void* src1
, void *src2
, ComparisionOp op
)
960 if (*(ByteInt
*)src1
== *(ByteInt
*)src2
) result
= true;
964 if (*(ByteInt
*)src1
!= *(ByteInt
*)src2
) result
= true;
968 if (*(ByteInt
*)src1
< *(ByteInt
*)src2
) result
= true;
971 case OpLessThanEquals
:
972 if (*(ByteInt
*)src1
<= *(ByteInt
*)src2
) result
= true;
976 if (*(ByteInt
*)src1
> *(ByteInt
*)src2
) result
= true;
979 case OpGreaterThanEquals
:
980 if (*(ByteInt
*)src1
>= *(ByteInt
*)src2
) result
= true;
987 bool AllDataType::compareDoubleVal(void* src1
, void *src2
, ComparisionOp op
)
993 if (*(double*)src1
== *(double*)src2
) result
= true;
997 if (*(double*)src1
!= *(double*)src2
) result
= true;
1001 if (*(double*)src1
< *(double*)src2
) result
= true;
1002 else result
= false;
1004 case OpLessThanEquals
:
1005 if (*(double*)src1
<= *(double*)src2
) result
= true;
1006 else result
= false;
1009 if (*(double*)src1
> *(double*)src2
) result
= true;
1010 else result
= false;
1012 case OpGreaterThanEquals
:
1013 if (*(double*)src1
>= *(double*)src2
) result
= true;
1014 else result
= false;
1020 bool AllDataType::compareFloatVal(void* src1
, void *src2
, ComparisionOp op
)
1022 bool result
= false;
1026 if (*(float*)src1
== *(float*)src2
) result
= true;
1027 else result
= false;
1030 if (*(float*)src1
!= *(float*)src2
) result
= true;
1031 else result
= false;
1034 if (*(float*)src1
< *(float*)src2
) result
= true;
1035 else result
= false;
1037 case OpLessThanEquals
:
1038 if (*(float*)src1
<= *(float*)src2
) result
= true;
1039 else result
= false;
1042 if (*(float*)src1
> *(float*)src2
) result
= true;
1043 else result
= false;
1045 case OpGreaterThanEquals
:
1046 if (*(float*)src1
>= *(float*)src2
) result
= true;
1047 else result
= false;
1053 bool AllDataType::compareDateVal(void* src1
, void *src2
, ComparisionOp op
)
1055 bool result
= false;
1059 if (*(Date
*)src1
== *(Date
*)src2
) result
= true;
1060 else result
= false;
1063 if (*(Date
*)src1
!= *(Date
*)src2
) result
= true;
1064 else result
= false;
1067 if (*(Date
*)src1
< *(Date
*)src2
) result
= true;
1068 else result
= false;
1070 case OpLessThanEquals
:
1071 if (*(Date
*)src1
<= *(Date
*)src2
) result
= true;
1072 else result
= false;
1075 if (*(Date
*)src1
> *(Date
*)src2
) result
= true;
1076 else result
= false;
1078 case OpGreaterThanEquals
:
1079 if (*(Date
*)src1
>= *(Date
*)src2
) result
= true;
1080 else result
= false;
1086 bool AllDataType::compareTimeVal(void* src1
, void *src2
, ComparisionOp op
)
1088 bool result
= false;
1092 if (*(Time
*)src1
== *(Time
*)src2
) result
= true;
1093 else result
= false;
1096 if (*(Time
*)src1
!= *(Time
*)src2
) result
= true;
1097 else result
= false;
1100 if (*(Time
*)src1
< *(Time
*)src2
) result
= true;
1101 else result
= false;
1103 case OpLessThanEquals
:
1104 if (*(Time
*)src1
<= *(Time
*)src2
) result
= true;
1105 else result
= false;
1108 if (*(Time
*)src1
> *(Time
*)src2
) result
= true;
1109 else result
= false;
1111 case OpGreaterThanEquals
:
1112 if (*(Time
*)src1
>= *(Time
*)src2
) result
= true;
1113 else result
= false;
1119 bool AllDataType::compareTimeStampVal(void* src1
, void *src2
, ComparisionOp op
)
1121 bool result
= false;
1125 if (*(TimeStamp
*)src1
== *(TimeStamp
*)src2
) result
= true;
1126 else result
= false;
1129 if (*(TimeStamp
*)src1
!= *(TimeStamp
*)src2
) result
= true;
1130 else result
= false;
1133 if (*(TimeStamp
*)src1
< *(TimeStamp
*)src2
) result
= true;
1134 else result
= false;
1136 case OpLessThanEquals
:
1137 if (*(TimeStamp
*)src1
<= *(TimeStamp
*)src2
) result
= true;
1138 else result
= false;
1141 if (*(TimeStamp
*)src1
> *(TimeStamp
*)src2
) result
= true;
1142 else result
= false;
1144 case OpGreaterThanEquals
:
1145 if (*(TimeStamp
*)src1
>= *(TimeStamp
*)src2
) result
= true;
1146 else result
= false;
1152 bool AllDataType::compareStringVal(void* src1
, void *src2
, ComparisionOp op
)
1154 if (OpEquals
== op
) {
1155 if (strcmp((char*)src1
, (char*)src2
) ==0) return true;
1157 }else if (OpGreaterThan
== op
) {
1158 if (strcmp((char*)src1
, (char*)src2
) >0) return true;
1160 }else if (OpLessThan
== op
) {
1161 if (strcmp((char*)src1
, (char*)src2
) <0 ) return true;
1163 }else if (OpLessThanEquals
== op
) {
1164 printf("Illegal Operator:Not Supported for String\n");
1166 //if (strcmp((char*)src1, (char*)src2)<= 0) return true;
1167 //else return false;
1168 }else if (OpGreaterThanEquals
== op
) {
1169 printf("Illegal Operator:Not Supported for String\n");
1171 //if (strcmp((char*)src1, (char*)src2) >=0) return true;
1172 //else return false;
1173 }else if (OpNotEquals
== op
) {
1174 if (strcmp((char*)src1
, (char*)src2
) != 0) return true;
1176 }else if (OpLike
== op
) {
1177 return !os::strmatch((char*)src2
, (char*)src1
);
1179 printf("Illegeal Operator:Not supported for String\n");
1183 bool AllDataType::compareBinaryVal(void* src1
, void *src2
,
1184 ComparisionOp op
, int length
)
1186 bool result
= false;
1187 int ret
= os::memcmp(src1
, src2
, length
);
1191 if (ret
== 0 ) result
= true; else result
= false;
1194 if (ret
!= 0 ) result
= true; else result
= false;
1197 if (ret
< 0 ) result
= true; else result
= false;
1199 case OpLessThanEquals
:
1200 printf("Illegal Operator:Not Supported for Binary\n");
1203 if (ret
> 0 ) result
= true; else result
= false;
1205 case OpGreaterThanEquals
:
1206 printf("Illegal Operator:Not Supported for Binary\n");
1214 ComparisionOp
AllDataType::getComparisionOperator(char *str
)
1217 if (strcmp(str
, "<=") == 0)
1218 op
= OpLessThanEquals
;
1219 else if (strcmp(str
, ">=") == 0)
1220 op
= OpGreaterThanEquals
;
1221 else if (strcmp(str
, "<") == 0)
1223 else if (strcmp(str
, ">") == 0)
1225 else if (strcmp(str
, "=") == 0)
1227 else if (strcmp(str
, "!=") == 0 || strcmp(str
, "<>") == 0 )
1229 else if (strcasecmp(str
, "LIKE") == 0 )
1232 op
= OpInvalidComparisionOp
;
1236 void* AllDataType::alloc(DataType type
, int length
)
1242 dest
= malloc(sizeof(int));
1245 dest
= malloc(sizeof(long));
1248 dest
= malloc(sizeof(long long));
1251 dest
= malloc(sizeof(short));
1254 dest
= malloc(sizeof(char));
1257 dest
= malloc(sizeof(double));
1260 dest
= malloc(sizeof(float));
1264 //fldDef.length_ = sizeof(long double);
1267 if (length
== 0 ) return NULL
;
1268 dest
= malloc(length
);
1271 if (length
== 0 || length
> 512) return NULL
;
1272 dest
= malloc(length
);
1273 memset(dest
, 0, length
);
1276 dest
= malloc(sizeof(Date
));
1279 dest
= malloc(sizeof(Time
));
1282 dest
= malloc(sizeof(TimeStamp
));
1288 void AllDataType::memoryset(void *value
,DataType type
)
1293 value
=os::memset(value
, 0, sizeof(int));
1296 value
= os::memset(value
, 0, sizeof(long));
1299 value
=os::memset(value
, 0, sizeof(long long));
1302 value
= os::memset(value
, 0, sizeof(short));
1305 value
= os::memset(value
, 0, sizeof(char));
1308 value
= os::memset(value
, 0, sizeof(double));
1311 value
= os::memset(value
, 0, sizeof(float));
1316 *(char*)value
= '\0';
1317 //if (length == 0 ) return NULL;
1318 //dest = malloc(length);
1321 /* if (length == 0 || length > 256 ) return NULL;
1323 memset(dest, 0, length);*/
1326 value
= os::memset(value
, 0, sizeof(Date
));
1329 value
= os::memset(value
, 0, sizeof(Time
));
1332 value
= os::memset(value
, 0, sizeof(TimeStamp
));
1340 DbRetVal
AllDataType::strToValue(void* dest
, char *src
, DataType type
, int length
)
1346 sscanf( src
, "%d", &val
);
1351 sscanf( src
, "%ld", &val
);
1354 case typeLongLong
: {
1356 sscanf( src
, "%lld", &val
);
1357 *(long long*)dest
= val
;
1361 sscanf( src
, "%hd", &val
);
1362 *(short*)dest
= val
;
1366 sscanf( src
, "%d", &val
);
1367 *(char*)dest
= *(char *)&val
;
1371 sscanf( src
, "%lg", &val
);
1372 *(double*)dest
= val
;
1376 sscanf( src
, "%f", &val
);
1377 *(float*)dest
= val
;
1382 strncpy((char*)dest
, (char*)src
, length
);
1383 char *d
=(char*)dest
;
1388 res
= sscanf( src
, "%d-%d-%d", &y
, &m
, &d
);
1390 res
= sscanf( src
, "%d/%d/%d", &y
, &m
, &d
);
1393 fprintf(stderr
,"Error reading date. yyyy{-/}mm{-/}dd is the valid format.");
1396 Date
dateObj(y
,m
,d
);
1397 *(Date
*)dest
= dateObj
;
1401 res
= sscanf( src
, "%d:%d:%d", &h
, &m
, &s
);
1404 fprintf(stderr
, "Error reading time, hh:mm:ss is the valid format.");
1407 Time
timeObj(h
,m
,s
);
1408 *(Time
*)dest
= timeObj
;
1410 case typeTimeStamp
: {
1411 int d
,m
,y
, h
,mn
,s
, res
=0;
1412 res
= sscanf( src
, "%d-%d-%d %d:%d:%d", &y
, &m
, &d
, &h
, &mn
, &s
);
1414 res
= sscanf( src
, "%d-%d-%d, %d:%d:%d", &y
, &m
, &d
, &h
, &mn
, &s
);
1416 res
= sscanf( src
, "%d/%d/%d %d:%d:%d", &y
, &m
, &d
, &h
, &mn
, &s
);
1418 res
= sscanf( src
, "%d/%d/%d, %d:%d:%d", &y
, &m
, &d
, &h
, &mn
, &s
);
1421 fprintf(stderr
, "Error reading timestamp, yyyy{-/}mm{-/}dd[,] hh:mm:ss is the valid format.");
1424 TimeStamp
timeStampObj(y
,m
,d
,h
,mn
,s
);
1425 *(TimeStamp
*)dest
= timeStampObj
;
1428 memset ((void *) dest
, 0, length
);
1429 unsigned char c
= 0;
1430 const char *str
= (const char *)src
;
1433 bool evenlegth
=false;
1434 if(i
%2){ evenlegth
=true;}
1435 unsigned char *val
= (unsigned char *)dest
+(length
-1);
1438 if (!isxdigit((int)c
)) {
1439 printError(ErrBadArg
, "Invalid hexadecimal value");
1442 if (c
<= '9') c
-= '0';
1443 else if (c
>= 'a') c
= c
- 'a' + 10;
1444 else c
= c
- 'A' + 10;
1447 if ((i
+1) % 2) { *val
= *val
| (c
<<4); val
--;}
1450 if (i
% 2) { *val
= *val
| (c
<<4); val
--;}
1464 void AllDataType::convert(DataType srcType
, void *src
,
1465 DataType destType
, void *dest
, int length
)
1467 switch ((DataType
) destType
)
1469 case typeInt
: convertToInt(dest
, src
, srcType
); break;
1470 case typeLong
: convertToLong(dest
, src
, srcType
); break;
1471 case typeLongLong
: convertToLongLong(dest
, src
, srcType
); break;
1472 case typeShort
: convertToShort(dest
, src
, srcType
); break;
1473 case typeByteInt
: convertToByteInt(dest
, src
, srcType
); break;
1475 case typeFloat
: convertToFloat(dest
, src
, srcType
); break;
1476 case typeDouble
: convertToDouble(dest
, src
, srcType
); break;
1479 case typeDecimal
: convertToDouble(dest
, src
, srcType
); break;
1481 case typeString
: convertToString(dest
, src
, srcType
); break;
1482 case typeBinary
: convertToBinary(dest
, src
, srcType
,length
); break;
1483 case typeDate
: convertToDate(dest
, src
, srcType
); break;
1484 case typeTime
: convertToTime(dest
, src
, srcType
); break;
1485 case typeTimeStamp
: convertToTimeStamp(dest
, src
, srcType
); break;
1490 void AllDataType::convertToInt( void* dest
, void* src
, DataType srcType
)
1494 case typeInt
: *(int *)dest
= *(int *)src
; break;
1495 case typeLong
: *(int *)dest
=(int) *(long *)src
; break;
1496 case typeLongLong
: *(int *)dest
=(int) *(long long *)src
; break;
1497 case typeShort
: *(int *)dest
=(int) *(short *)src
; break;
1498 case typeByteInt
: *(int *)dest
=(int) *(char *)src
; break;
1500 case typeFloat
: *(int *)dest
= (int) *(float *)src
; break;
1501 case typeDouble
: *(int *)dest
=(int) *(double *)src
; break;
1503 case typeString
: sscanf((const char*)src
, "%d", (int*) dest
); break;
1509 default: *(int *)dest
= (int) 0;
1513 void AllDataType::convertToLong( void* dest
, void* src
, DataType srcType
)
1517 case typeInt
: *(long *)dest
=(long) *(int *)src
; break;
1518 case typeLong
: *(long *)dest
= *(long *)src
; break;
1519 case typeLongLong
: *(long *)dest
=(long) *(long long *)src
; break;
1520 case typeShort
: *(long *)dest
=(long) *(short *)src
; break;
1521 case typeByteInt
: *(long *)dest
=(long) *(char *)src
; break;
1523 case typeFloat
: *(long *)dest
= (long) *(float *)src
; break;
1524 case typeDouble
: *(long *)dest
=(long) *(double *)src
; break;
1526 case typeString
: sscanf((const char*)src
, "%ld", (long*) dest
); break;
1532 default: *(long *)dest
= (long) 0;
1537 void AllDataType::convertToLongLong( void* dest
, void* src
, DataType srcType
)
1541 case typeInt
: *(long long *)dest
=(long long) *(int *)src
; break;
1542 case typeLong
: *(long long *)dest
= (long long) *(long *)src
; break;
1543 case typeLongLong
: *(long long *)dest
= *(long long *)src
; break;
1544 case typeShort
: *(long long *)dest
=(long long) *(short *)src
; break;
1545 case typeByteInt
: *(long long *)dest
=(long long) *(char *)src
; break;
1547 case typeFloat
: *(long long *)dest
= (long long) *(float *)src
; break;
1548 case typeDouble
: *(long long *)dest
=(long long) *(double *)src
; break;
1550 case typeString
: sscanf((const char*)src
, "%lld", (long long*) dest
); break;
1556 default: *(long long *)dest
= (long long) 0;
1560 void AllDataType::convertToShort( void* dest
, void* src
, DataType srcType
)
1564 case typeInt
: *(short*)dest
=(short) *(int*)src
; break;
1565 case typeLong
: *(short*)dest
= (short) *(long*)src
; break;
1566 case typeLongLong
: *(short*)dest
= (short) *(long long*)src
; break;
1567 case typeShort
: *(short*)dest
= *(short*)src
; break;
1568 case typeByteInt
: *(short*)dest
=(short) *(char *)src
; break;
1570 case typeFloat
: *(short*)dest
= (short) *(float *)src
; break;
1571 case typeDouble
: *(short*)dest
=(short) *(double *)src
; break;
1573 case typeString
: sscanf((const char*)src
, "%hd", (short*) dest
); break;
1579 default: *(short*)dest
= (short) 0;
1583 void AllDataType::convertToByteInt( void* dest
, void* src
, DataType srcType
)
1587 case typeInt
: *(char*)dest
= (char) *(int*)src
; break;
1588 case typeLong
: *(char*)dest
= (char) *(long*)src
; break;
1589 case typeLongLong
: *(char*)dest
= (char) *(long long*)src
; break;
1590 case typeShort
: *(char*)dest
= (char) *(short*)src
; break;
1591 case typeByteInt
: *(char*)dest
= *(char *)src
; break;
1593 case typeFloat
: *(char*)dest
= (char) *(float *)src
; break;
1594 case typeDouble
: *(char*)dest
=(char) *(double *)src
; break;
1596 case typeString
: sscanf((const char*)src
, "%c", (char*) dest
); break;
1602 default: *(char*)dest
= (char) 0;
1606 void AllDataType::convertToFloat( void* dest
, void* src
, DataType srcType
)
1610 case typeInt
: *(float *)dest
=(float) *(int *)src
; break;
1611 case typeLong
: *(float *)dest
=(float) *(long *)src
; break;
1612 case typeLongLong
: *(float *)dest
=(float) *(long long *)src
; break;
1613 case typeShort
: *(float *)dest
=(float) *(short *)src
; break;
1614 case typeByteInt
: *(float *)dest
=(float) *(char *)src
; break;
1616 case typeFloat
: *(float *)dest
= *(float *)src
; break;
1617 case typeDouble
: *(float *)dest
=(float) *(double *)src
; break;
1619 case typeString
: sscanf((const char*)src
, "%f", (float*) dest
); break;
1625 default: *(float *)dest
= (float) 0;
1629 void AllDataType::convertToDouble( void* dest
, void* src
, DataType srcType
)
1633 case typeInt
: *(double *)dest
=(double) *(int *)src
; break;
1634 case typeLong
: *(double *)dest
=(double) *(long *)src
; break;
1635 case typeLongLong
: *(double *)dest
=(double) *(long long *)src
; break;
1636 case typeShort
: *(double *)dest
=(double) *(short *)src
; break;
1637 case typeByteInt
: *(double *)dest
=(double) *(char *)src
; break;
1639 case typeFloat
: *(double *)dest
=(double) *(float *)src
; break;
1640 case typeDouble
: *(double *)dest
= *(double *)src
; break;
1642 case typeString
: sscanf((const char*)src
, "%lf", (double*) dest
); break;
1648 default: *(double *)dest
= (double) 0;
1652 void AllDataType::convertToString( void* dest
, void* src
, DataType srcType
, int length
)
1658 sprintf ((char *)dest
, "%d", *(int *)src
);
1663 sprintf ((char *)dest
, "%ld", *(long *)src
);
1668 sprintf ((char *)dest
, "%lld", *(long long *)src
);
1673 sprintf ((char *)dest
, "%hd", *(short *)src
);
1678 sprintf ((char *)dest
, "%hd", *(char *)src
);
1684 sprintf ((char *)dest
, "%f", *(float *)src
);
1689 sprintf ((char *) dest
, "%lf", *(double *)src
);
1695 strcpy((char*)dest
, (char*)src
);
1700 Date
* dt
= (Date
*)src
;
1701 sprintf((char*) dest
, "%d/%d/%d", dt
->year(),
1702 dt
->month(), dt
->dayOfMonth());
1707 Time
* tm
= (Time
*)src
;
1708 sprintf((char*)dest
,"%d:%d:%d.%d", tm
->hours(), tm
->minutes(), tm
->seconds(), 0);
1713 TimeStamp
* tm
= (TimeStamp
*)src
;
1714 sprintf((char*)dest
, "%d/%d/%d %d:%d:%d.%d", tm
->year(),
1715 tm
->month(), tm
->dayOfMonth(), tm
->hours(),
1716 tm
->minutes(), tm
->seconds(), 0 );
1721 unsigned char *c
= (unsigned char *) src
;
1722 unsigned char *str
= (unsigned char *) dest
;
1723 unsigned char p
= 0;
1725 while (i
< length
) {
1727 if (p
< 10) sprintf ((char *)str
++, "%c", '0' + p
);
1728 else sprintf((char *)str
++, "%c", 'A' + p
- 10);
1730 if (p
< 10) sprintf ((char *)str
++, "%c", '0' + p
);
1731 else sprintf((char *)str
++, "%c", 'A' + p
- 10);
1737 default: ((char*)dest
)[0] = '\0';
1741 void AllDataType::convertToDate( void* dest
, void* src
, DataType srcType
)
1757 Date
*dt
= (Date
*) dest
;
1758 dt
->parseFrom((char*)src
);
1761 default: ((char*)dest
)[0] = '\0';
1765 void AllDataType::convertToTime( void* dest
, void* src
, DataType srcType
)
1781 Time
*dt
= (Time
*) dest
;
1782 dt
->parseFrom((char*)src
);
1785 default: ((char*)dest
)[0] = '\0';
1789 void AllDataType::convertToTimeStamp( void* dest
, void* src
, DataType srcType
)
1805 TimeStamp
*dt
= (TimeStamp
*) dest
;
1806 dt
->parseFrom((char*)src
);
1809 default: ((char*)dest
)[0] = '\0';
1813 void AllDataType::convertToBinary(void *dest
, void *src
, DataType srcType
, int length
)
1819 memset ((void *) dest
, 0, length
);
1820 unsigned char c
= 0;
1821 const char *str
= (const char *)src
;
1823 i
= strlen((char*)src
)-1;
1824 bool evenlegth
=false;
1825 if(i
%2){ evenlegth
=true;}
1826 unsigned char *val
= (unsigned char *)dest
+(length
-1);
1829 if (c
<= '9') c
-= '0';
1830 else if (c
>= 'a') c
= c
- 'a' + 10;
1831 else c
= c
- 'A' + 10;
1834 if ((i
+1) % 2) { *val
= *val
| (c
<<4); val
--;}
1837 if (i
% 2) { *val
= *val
| (c
<<4); val
--;}
1846 int AllDataType::printVal(void* src
, DataType srcType
, int length
)
1853 count
= printf ("%d", *(int *)src
);
1858 count
= printf ("%ld", *(long *)src
);
1863 count
= printf ("%lld", *(long long *)src
);
1868 count
= printf("%hd", *(short *)src
);
1873 count
= printf("%hd", *(char *)src
);
1879 count
= printf("%f", *(float *)src
);
1884 count
= printf("%lf", *(double *)src
);
1890 count
= printf("%s", (char*)src
);
1895 Date
* dt
= (Date
*)src
;
1896 count
= printf("%d/%d/%d", dt
->year(),
1897 dt
->month(), dt
->dayOfMonth());
1902 Time
* tm
= (Time
*)src
;
1903 count
= printf("%d:%d:%d.%d", tm
->hours(), tm
->minutes(), tm
->seconds(), 0);
1908 TimeStamp
* tm
= (TimeStamp
*)src
;
1909 count
= printf("%d/%d/%d %d:%d:%d.%d", tm
->year(),
1910 tm
->month(), tm
->dayOfMonth(), tm
->hours(),
1911 tm
->minutes(), tm
->seconds(), 0 );
1916 unsigned char *c
= (unsigned char *) src
;
1917 unsigned char p
= 0;
1919 bool isDigitFound
=false;
1920 while (i
< length
) {
1922 if(('0'+p
)!='0'|| isDigitFound
){
1923 if (p
< 10) printf ("%c", '0' + p
);
1924 else printf("%c", 'A' + p
- 10);
1928 if(('0'+p
)!='0' || isDigitFound
){
1929 if (p
< 10) printf ("%c", '0' + p
);
1930 else printf("%c", 'A' + p
- 10);
1938 default: { printf("DataType not supported\n"); break; }