Commit ec3e6cc8 authored by Alexander Barkov's avatar Alexander Barkov

Merge 10.0-connect -> 10.0

parents 911ed937 b10fa87b
...@@ -960,6 +960,8 @@ bool ha_connect::GetBooleanOption(char *opname, bool bdef) ...@@ -960,6 +960,8 @@ bool ha_connect::GetBooleanOption(char *opname, bool bdef)
opval= options->readonly; opval= options->readonly;
else if (!stricmp(opname, "SepIndex")) else if (!stricmp(opname, "SepIndex"))
opval= options->sepindex; opval= options->sepindex;
else if (!stricmp(opname, "Header"))
opval= (options->header != 0); // Is Boolean for some table types
else if (options->oplist) else if (options->oplist)
if ((pv= GetListOption(xp->g, opname, options->oplist))) if ((pv= GetListOption(xp->g, opname, options->oplist)))
opval= (!*pv || *pv == 'y' || *pv == 'Y' || atoi(pv) != 0); opval= (!*pv || *pv == 'y' || *pv == 'Y' || atoi(pv) != 0);
...@@ -1838,6 +1840,7 @@ int ha_connect::ScanRecord(PGLOBAL g, uchar *buf) ...@@ -1838,6 +1840,7 @@ int ha_connect::ScanRecord(PGLOBAL g, uchar *buf)
} // endswitch type } // endswitch type
((DTVAL*)sdvalin)->SetFormat(g, fmt, strlen(fmt)); ((DTVAL*)sdvalin)->SetFormat(g, fmt, strlen(fmt));
sdvalin->SetNullable(colp->IsNullable());
fp->val_str(&attribute); fp->val_str(&attribute);
sdvalin->SetValue_psz(attribute.c_ptr_safe()); sdvalin->SetValue_psz(attribute.c_ptr_safe());
value->SetValue_pval(sdvalin); value->SetValue_pval(sdvalin);
......
...@@ -730,6 +730,7 @@ int ExtractDate(char *dts, PDTP pdp, int defy, int val[6]) ...@@ -730,6 +730,7 @@ int ExtractDate(char *dts, PDTP pdp, int defy, int val[6])
char *fmt, c, d, e, W[8][12]; char *fmt, c, d, e, W[8][12];
int i, k, m, numval; int i, k, m, numval;
int n, y = 30; int n, y = 30;
bool b = true; // true for null dates
if (pdp) if (pdp)
fmt = pdp->InFmt; fmt = pdp->InFmt;
...@@ -763,7 +764,8 @@ int ExtractDate(char *dts, PDTP pdp, int defy, int val[6]) ...@@ -763,7 +764,8 @@ int ExtractDate(char *dts, PDTP pdp, int defy, int val[6])
m = pdp->Num; m = pdp->Num;
for (i = 0; i < m; i++) { for (i = 0; i < m; i++) {
n = *(int*)W[i]; if ((n = *(int*)W[i]))
b = false;
switch (k = pdp->Index[i]) { switch (k = pdp->Index[i]) {
case 0: case 0:
...@@ -822,7 +824,7 @@ int ExtractDate(char *dts, PDTP pdp, int defy, int val[6]) ...@@ -822,7 +824,7 @@ int ExtractDate(char *dts, PDTP pdp, int defy, int val[6])
htrc("numval=%d val=(%d,%d,%d,%d,%d,%d)\n", htrc("numval=%d val=(%d,%d,%d,%d,%d,%d)\n",
numval, val[0], val[1], val[2], val[3], val[4], val[5]); numval, val[0], val[1], val[2], val[3], val[4], val[5]);
return numval; return (b) ? 0 : numval;
} // end of ExtractDate } // end of ExtractDate
/***********************************************************************/ /***********************************************************************/
......
...@@ -1075,8 +1075,9 @@ void ODBCCOL::ReadColumn(PGLOBAL g) ...@@ -1075,8 +1075,9 @@ void ODBCCOL::ReadColumn(PGLOBAL g)
} // endif Bufp } // endif Bufp
if (Buf_Type == TYPE_DATE) { if (Buf_Type == TYPE_DATE) {
struct tm dbtime = {0,0,0,0,0,0,0,0,0}; struct tm dbtime;
memset(&dbtime, 0, sizeof(tm));
dbtime.tm_sec = (int)Sqlbuf->second; dbtime.tm_sec = (int)Sqlbuf->second;
dbtime.tm_min = (int)Sqlbuf->minute; dbtime.tm_min = (int)Sqlbuf->minute;
dbtime.tm_hour = (int)Sqlbuf->hour; dbtime.tm_hour = (int)Sqlbuf->hour;
......
...@@ -2428,9 +2428,11 @@ bool DTVAL::SetValue_char(char *p, int n) ...@@ -2428,9 +2428,11 @@ bool DTVAL::SetValue_char(char *p, int n)
if (trace > 1) if (trace > 1)
htrc(" setting date: '%s' -> %d\n", Sdate, Tval); htrc(" setting date: '%s' -> %d\n", Sdate, Tval);
Null = false; Null = (Nullable && ndv == 0);
} else } else {
rc = TYPVAL<int>::SetValue_char(p, n); rc = TYPVAL<int>::SetValue_char(p, n);
Null = (Nullable && Tval == 0);
} // endif Pdtp
return rc; return rc;
} // end of SetValue } // end of SetValue
...@@ -2453,9 +2455,11 @@ void DTVAL::SetValue_psz(PSZ p) ...@@ -2453,9 +2455,11 @@ void DTVAL::SetValue_psz(PSZ p)
if (trace > 1) if (trace > 1)
htrc(" setting date: '%s' -> %d\n", Sdate, Tval); htrc(" setting date: '%s' -> %d\n", Sdate, Tval);
Null = false; Null = (Nullable && ndv == 0);
} else } else {
TYPVAL<int>::SetValue_psz(p); TYPVAL<int>::SetValue_psz(p);
Null = (Nullable && Tval == 0);
} // endif Pdtp
} // end of SetValue } // end of SetValue
...@@ -2496,7 +2500,7 @@ char *DTVAL::GetCharString(char *p) ...@@ -2496,7 +2500,7 @@ char *DTVAL::GetCharString(char *p)
} else } else
sprintf(p, "%d", Tval); sprintf(p, "%d", Tval);
Null = false; //Null = false; ??????????????
return p; return p;
} // end of GetCharString } // end of GetCharString
...@@ -2507,6 +2511,8 @@ char *DTVAL::ShowValue(char *buf, int len) ...@@ -2507,6 +2511,8 @@ char *DTVAL::ShowValue(char *buf, int len)
{ {
if (Pdtp) { if (Pdtp) {
char *p; char *p;
if (!Null) {
size_t m, n = 0; size_t m, n = 0;
struct tm tm, *ptm = GetGmTime(&tm); struct tm tm, *ptm = GetGmTime(&tm);
...@@ -2526,6 +2532,9 @@ char *DTVAL::ShowValue(char *buf, int len) ...@@ -2526,6 +2532,9 @@ char *DTVAL::ShowValue(char *buf, int len)
strncat(p, "Error", m); strncat(p, "Error", m);
} // endif n } // endif n
} else
p = ""; // DEFAULT VALUE ???
return p; return p;
} else } else
return TYPVAL<int>::ShowValue(buf, len); return TYPVAL<int>::ShowValue(buf, len);
......
...@@ -357,6 +357,7 @@ class DllExport DTVAL : public TYPVAL<int> { ...@@ -357,6 +357,7 @@ class DllExport DTVAL : public TYPVAL<int> {
DTVAL(PGLOBAL g, double f); DTVAL(PGLOBAL g, double f);
// Implementation // Implementation
virtual bool IsZero(void) {return Null;}
virtual bool SetValue_pval(PVAL valp, bool chktype); virtual bool SetValue_pval(PVAL valp, bool chktype);
virtual bool SetValue_char(char *p, int n); virtual bool SetValue_char(char *p, int n);
virtual void SetValue_psz(PSZ s); virtual void SetValue_psz(PSZ s);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment