8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-24 10:43:03 +01:00

Misc and try to be consistent to use the padding char.

More to come.
This commit is contained in:
robocop 2006-06-15 08:39:13 +00:00
parent 315bd0a8f5
commit 5cdb49cde9

View File

@ -282,7 +282,6 @@ double CVT_get_double(const dsc* desc, FPTR_ERROR err)
* *
**************************************/ **************************************/
double value; double value;
SSHORT scale;
switch (desc->dsc_dtype) { switch (desc->dsc_dtype) {
case dtype_short: case dtype_short:
@ -336,7 +335,7 @@ double CVT_get_double(const dsc* desc, FPTR_ERROR err)
&p, &p,
(vary*) buffer, sizeof(buffer), err); (vary*) buffer, sizeof(buffer), err);
value = 0.0; value = 0.0;
scale = 0; int scale = 0;
SSHORT sign = 0; SSHORT sign = 0;
bool digit_seen = false, past_sign = false, fraction = false; bool digit_seen = false, past_sign = false, fraction = false;
const char* const end = p + length; const char* const end = p + length;
@ -451,20 +450,21 @@ double CVT_get_double(const dsc* desc, FPTR_ERROR err)
/* Last, but not least, adjust for scale */ /* Last, but not least, adjust for scale */
if ((scale = desc->dsc_scale) == 0) const int dscale = desc->dsc_scale;
if (dscale == 0)
return value; return value;
/* if the scale is greater than the power of 10 representable /* if the scale is greater than the power of 10 representable
in a double number, then something has gone wrong... let in a double number, then something has gone wrong... let
the user know... */ the user know... */
if (ABSOLUT(scale) > DBL_MAX_10_EXP) if (ABSOLUT(dscale) > DBL_MAX_10_EXP)
(*err) (isc_arith_except, 0); (*err) (isc_arith_except, 0);
if (scale > 0) if (dscale > 0)
value *= power_of_ten(scale); value *= power_of_ten(dscale);
else if (scale < 0) else if (dscale < 0)
value /= power_of_ten(-scale); value /= power_of_ten(-dscale);
return value; return value;
} }
@ -483,7 +483,7 @@ SLONG CVT_get_long(const dsc* desc, SSHORT scale, FPTR_ERROR err)
* scale. * scale.
* *
**************************************/ **************************************/
SLONG value, high, fraction; SLONG value, high;
double d, eps; double d, eps;
SINT64 val64; SINT64 val64;
@ -510,10 +510,10 @@ SLONG CVT_get_long(const dsc* desc, SSHORT scale, FPTR_ERROR err)
/* adjust for scale first, *before* range-checking the value. */ /* adjust for scale first, *before* range-checking the value. */
if (scale > 0) { if (scale > 0) {
fraction = 0; SLONG fraction = 0;
do { do {
if (scale == 1) if (scale == 1)
fraction = (SLONG) (val64 % 10); fraction = SLONG(val64 % 10);
val64 /= 10; val64 /= 10;
} while (--scale); } while (--scale);
if (fraction > 4) if (fraction > 4)
@ -622,7 +622,7 @@ SLONG CVT_get_long(const dsc* desc, SSHORT scale, FPTR_ERROR err)
if (scale > 0) { if (scale > 0) {
if (DTYPE_IS_EXACT(desc->dsc_dtype)) { if (DTYPE_IS_EXACT(desc->dsc_dtype)) {
fraction = 0; SLONG fraction = 0;
do { do {
if (scale == 1) if (scale == 1)
fraction = value % 10; fraction = value % 10;
@ -787,9 +787,6 @@ SQUAD CVT_get_quad(const dsc* desc, SSHORT scale, FPTR_ERROR err)
* *
**************************************/ **************************************/
SQUAD value; SQUAD value;
#ifdef NATIVE_QUAD
SLONG fraction;
#endif
double d; double d;
TEXT buffer[50]; /* long enough to represent largest quad in ASCII */ TEXT buffer[50]; /* long enough to represent largest quad in ASCII */
@ -897,7 +894,7 @@ SQUAD CVT_get_quad(const dsc* desc, SSHORT scale, FPTR_ERROR err)
if (desc->dsc_dtype == dtype_short || if (desc->dsc_dtype == dtype_short ||
desc->dsc_dtype == dtype_long || desc->dsc_dtype == dtype_quad) desc->dsc_dtype == dtype_long || desc->dsc_dtype == dtype_quad)
{ {
fraction = 0; SLONG fraction = 0;
do { do {
if (scale == 1) if (scale == 1)
fraction = value % 10; fraction = value % 10;
@ -947,7 +944,6 @@ SINT64 CVT_get_int64(const dsc* desc, SSHORT scale, FPTR_ERROR err)
* *
**************************************/ **************************************/
SINT64 value; SINT64 value;
SLONG fraction;
double d, eps; double d, eps;
TEXT buffer[50]; /* long enough to represent largest SINT64 in ASCII */ TEXT buffer[50]; /* long enough to represent largest SINT64 in ASCII */
@ -1053,7 +1049,7 @@ SINT64 CVT_get_int64(const dsc* desc, SSHORT scale, FPTR_ERROR err)
if (desc->dsc_dtype == dtype_short || if (desc->dsc_dtype == dtype_short ||
desc->dsc_dtype == dtype_long || desc->dsc_dtype == dtype_int64) desc->dsc_dtype == dtype_long || desc->dsc_dtype == dtype_int64)
{ {
fraction = 0; SLONG fraction = 0;
do { do {
if (scale == 1) if (scale == 1)
fraction = (SLONG) (value % 10); fraction = (SLONG) (value % 10);
@ -1301,15 +1297,7 @@ void CVT_move(const dsc* from, dsc* to, FPTR_ERROR err)
* Move (and possible convert) something to something else. * Move (and possible convert) something to something else.
* *
**************************************/ **************************************/
SSHORT fill;
SLONG l; SLONG l;
UCHAR *ptr;
USHORT strtype;
#if !defined(REQUESTER) && !defined(SUPERCLIENT)
CHARSET_ID charset1, charset2;
#endif
UCHAR fill_char;
SLONG length = from->dsc_length; SLONG length = from->dsc_length;
UCHAR* p = to->dsc_address; UCHAR* p = to->dsc_address;
const UCHAR* q = from->dsc_address; const UCHAR* q = from->dsc_address;
@ -1535,6 +1523,7 @@ void CVT_move(const dsc* from, dsc* to, FPTR_ERROR err)
#ifndef REQUESTER #ifndef REQUESTER
#ifndef SUPERCLIENT #ifndef SUPERCLIENT
CHARSET_ID charset1, charset2;
if ((INTL_TTYPE(from) == ttype_dynamic) && (err == ERR_post)) if ((INTL_TTYPE(from) == ttype_dynamic) && (err == ERR_post))
charset1 = INTL_charset(NULL, INTL_TTYPE(from)); charset1 = INTL_charset(NULL, INTL_TTYPE(from));
else else
@ -1569,17 +1558,26 @@ void CVT_move(const dsc* from, dsc* to, FPTR_ERROR err)
#endif #endif
#endif #endif
length = l = { // scope
CVT_get_string_ptr(from, &strtype, &ptr, NULL, 0, err); USHORT strtype_unused;
q = ptr; UCHAR *ptr;
length = l =
CVT_get_string_ptr(from, &strtype_unused, &ptr, NULL, 0, err);
q = ptr;
} // end scope
USHORT to_size = TEXT_LEN(to); USHORT to_size = TEXT_LEN(to);
UCHAR* start = to->dsc_address; UCHAR* start = to->dsc_address;
UCHAR fill_char = ASCII_SPACE;
#if !defined(REQUESTER) && !defined(SUPERCLIENT) #if !defined(REQUESTER) && !defined(SUPERCLIENT)
CharSet* toCharSet = (err != ERR_post || charset2 == ttype_dynamic || charset2 == CS_METADATA ? CharSet* toCharSet = (err != ERR_post || charset2 == ttype_dynamic || charset2 == CS_METADATA ?
NULL : INTL_charset_lookup(NULL, charset2)); NULL : INTL_charset_lookup(NULL, charset2));
if (charset2 == ttype_binary)
fill_char = 0x00;
USHORT toLength; USHORT toLength;
#endif #endif
int fill;
switch (to->dsc_dtype) { switch (to->dsc_dtype) {
case dtype_text: case dtype_text:
@ -1593,18 +1591,10 @@ void CVT_move(const dsc* from, dsc* to, FPTR_ERROR err)
l -= length; l -= length;
/* TMN: Here we should really have the following fb_assert */ /* TMN: Here we should really have the following fb_assert */
/* fb_assert((to->dsc_length - length) <= MAX_SSHORT); */ /* fb_assert((to->dsc_length - length) <= MAX_SSHORT); */
fill = (SSHORT) (to->dsc_length - length); fill = to->dsc_length - length;
CVT_COPY_BUFF(q, p, length); CVT_COPY_BUFF(q, p, length);
if (fill > 0) { if (fill > 0) {
#ifndef REQUESTER
#ifndef SUPERCLIENT
if (charset2 == ttype_binary)
fill_char = 0x00;
else
#endif
#endif
fill_char = ASCII_SPACE;
do { do {
*p++ = fill_char; *p++ = fill_char;
} while (--fill); } while (--fill);
@ -1666,13 +1656,12 @@ void CVT_move(const dsc* from, dsc* to, FPTR_ERROR err)
#endif #endif
if (l) { if (l) {
/* scan the truncated string to ensure only spaces lost */ // Scan the truncated string to ensure only spaces lost
/* Note: it is correct only for narrow and multi-byte // Warning: it is correct only for narrow and multi-byte
character sets which use ASCII for the SPACE // character sets which use ASCII or NULL for the SPACE character
character. */
do { do {
if (*q++ != ASCII_SPACE) if (*q++ != fill_char)
(*err) (isc_arith_except, 0); (*err) (isc_arith_except, 0);
} while (--l); } while (--l);
} }
@ -1757,8 +1746,7 @@ void CVT_move(const dsc* from, dsc* to, FPTR_ERROR err)
case dtype_real: case dtype_real:
{ {
double d_value; double d_value = CVT_get_double(from, err);
d_value = CVT_get_double(from, err);
if (ABSOLUT(d_value) > FLOAT_MAX) if (ABSOLUT(d_value) > FLOAT_MAX)
(*err) (isc_arith_except, 0); (*err) (isc_arith_except, 0);
*(float*) p = (float) d_value; *(float*) p = (float) d_value;
@ -1982,7 +1970,8 @@ static SSHORT decompose(const char* string,
errd.dsc_address = reinterpret_cast<UCHAR*>(const_cast<char*>(string)); errd.dsc_address = reinterpret_cast<UCHAR*>(const_cast<char*>(string));
SINT64 value = 0; SINT64 value = 0;
SSHORT scale = 0, sign = 0; SSHORT scale = 0;
int sign = 0;
bool digit_seen = false, fraction = false; bool digit_seen = false, fraction = false;
const SINT64 lower_limit = (dtype == dtype_long) ? MIN_SLONG : MIN_SINT64; const SINT64 lower_limit = (dtype == dtype_long) ? MIN_SLONG : MIN_SINT64;
const SINT64 upper_limit = (dtype == dtype_long) ? MAX_SLONG : MAX_SINT64; const SINT64 upper_limit = (dtype == dtype_long) ? MAX_SLONG : MAX_SINT64;
@ -2618,7 +2607,7 @@ static void string_to_datetime(
return; return;
} }
tm times, times2; tm times;
memset(&times, 0, sizeof(times)); memset(&times, 0, sizeof(times));
if (expect_type != expect_sql_time) { if (expect_type != expect_sql_time) {
@ -2679,6 +2668,7 @@ static void string_to_datetime(
times.tm_mday = components[position_day]; times.tm_mday = components[position_day];
// Fetch current date/time // Fetch current date/time
tm times2;
Firebird::TimeStamp().decode(&times2); Firebird::TimeStamp().decode(&times2);
/* Handle defaulting of year */ /* Handle defaulting of year */
@ -2724,6 +2714,7 @@ static void string_to_datetime(
isc_encode_timestamp(&times, date); isc_encode_timestamp(&times, date);
if (expect_type != expect_sql_time) { if (expect_type != expect_sql_time) {
tm times2;
isc_decode_timestamp(date, &times2); isc_decode_timestamp(date, &times2);
if ((times.tm_year + 1900) < MIN_YEAR if ((times.tm_year + 1900) < MIN_YEAR