38
40
unsigned char null_bit_arg,
39
41
enum utype unireg_check_arg,
40
42
const char *field_name_arg,
51
precision= class_decimal_length_to_precision(len_arg, dec_arg, false);
52
set_if_smaller(precision, (uint32_t)DECIMAL_MAX_PRECISION);
53
assert((precision <= DECIMAL_MAX_PRECISION) && (dec <= DECIMAL_MAX_SCALE));
54
bin_size= class_decimal_get_binary_size(precision, dec);
55
precision= my_decimal_length_to_precision(len_arg, dec_arg, unsigned_arg);
56
set_if_smaller(precision, (uint32_t)DECIMAL_MAX_PRECISION);
57
assert((precision <= DECIMAL_MAX_PRECISION) &&
58
(dec <= DECIMAL_MAX_SCALE));
59
bin_size= my_decimal_get_binary_size(precision, dec);
57
62
Field_decimal::Field_decimal(uint32_t len_arg,
58
63
bool maybe_null_arg,
62
Field_num((unsigned char*) 0,
64
maybe_null_arg ? (unsigned char*) "": 0,
67
:Field_num((unsigned char*) 0,
69
maybe_null_arg ? (unsigned char*) "": 0,
72
precision= class_decimal_length_to_precision(len_arg, dec_arg, unsigned_arg);
77
precision= my_decimal_length_to_precision(len_arg, dec_arg, unsigned_arg);
73
78
set_if_smaller(precision, (uint32_t)DECIMAL_MAX_PRECISION);
74
79
assert((precision <= DECIMAL_MAX_PRECISION) &&
75
80
(dec <= DECIMAL_MAX_SCALE));
76
bin_size= class_decimal_get_binary_size(precision, dec);
81
bin_size= my_decimal_get_binary_size(precision, dec);
91
96
@param sign sign of value which caused overflow
94
void Field_decimal::set_value_on_overflow(type::Decimal *decimal_value,
99
void Field_decimal::set_value_on_overflow(my_decimal *decimal_value,
97
max_Decimal(decimal_value, precision, decimals());
102
max_my_decimal(decimal_value, precision, decimals());
99
104
decimal_value->sign(true);
109
114
If it does, stores the decimal in the buffer using binary format.
110
115
Otherwise sets maximal number that can be stored in the field.
112
@param decimal_value type::Decimal
117
@param decimal_value my_decimal
120
bool Field_decimal::store_value(const type::Decimal *decimal_value)
125
bool Field_decimal::store_value(const my_decimal *decimal_value)
122
int error= decimal_value->val_binary(E_DEC_FATAL_ERROR & ~E_DEC_OVERFLOW, ptr, precision, dec);
127
int error= my_decimal2binary(E_DEC_FATAL_ERROR & ~E_DEC_OVERFLOW,
128
decimal_value, ptr, precision, dec);
124
129
if (warn_if_overflow(error))
126
131
if (error != E_DEC_TRUNCATED)
129
134
set_value_on_overflow(&buff, decimal_value->sign());
130
buff.val_binary(E_DEC_FATAL_ERROR, ptr, precision, dec);
135
my_decimal2binary(E_DEC_FATAL_ERROR, &buff, ptr, precision, dec);
140
144
const CHARSET_INFO * const charset_arg)
143
type::Decimal decimal_value;
147
my_decimal decimal_value;
145
149
ASSERT_COLUMN_MARKED_FOR_WRITE;
147
if ((err= decimal_value.store(E_DEC_FATAL_ERROR &
151
if ((err= str2my_decimal(E_DEC_FATAL_ERROR &
148
152
~(E_DEC_OVERFLOW | E_DEC_BAD_NUM),
149
from, length, charset_arg)) &&
150
getTable()->in_use->abortOnWarning())
153
from, length, charset_arg,
155
getTable()->in_use->abort_on_warning)
152
157
/* Because "from" is not NUL-terminated and we use %s in the ER() */
153
158
String from_as_str;
182
187
ER(ER_TRUNCATED_WRONG_VALUE_FOR_FIELD),
183
188
"decimal", from_as_str.c_ptr(), field_name,
184
189
(uint32_t) getTable()->in_use->row_count);
185
decimal_value.set_zero();
190
my_decimal_set_zero(&decimal_value);
198
Fix following when double2_class_decimal when double2decimal
203
Fix following when double2my_decimal when double2decimal
199
204
will return E_DEC_TRUNCATED always correctly
202
207
int Field_decimal::store(double nr)
204
type::Decimal decimal_value;
209
my_decimal decimal_value;
207
212
ASSERT_COLUMN_MARKED_FOR_WRITE;
209
err= double2_class_decimal(E_DEC_FATAL_ERROR & ~E_DEC_OVERFLOW, nr,
214
err= double2my_decimal(E_DEC_FATAL_ERROR & ~E_DEC_OVERFLOW, nr,
226
231
int Field_decimal::store(int64_t nr, bool unsigned_val)
228
type::Decimal decimal_value;
233
my_decimal decimal_value;
231
236
ASSERT_COLUMN_MARKED_FOR_WRITE;
233
if ((err= int2_class_decimal(E_DEC_FATAL_ERROR & ~E_DEC_OVERFLOW,
238
if ((err= int2my_decimal(E_DEC_FATAL_ERROR & ~E_DEC_OVERFLOW,
234
239
nr, unsigned_val, &decimal_value)))
236
241
if (check_overflow(err))
249
int Field_decimal::store_decimal(const type::Decimal *decimal_value)
254
int Field_decimal::store_decimal(const my_decimal *decimal_value)
251
256
return store_value(decimal_value);
255
int Field_decimal::store_time(type::Time <ime,
260
int Field_decimal::store_time(DRIZZLE_TIME *ltime,
261
enum enum_drizzle_timestamp_type )
258
type::Decimal decimal_value;
259
return store_value(date2_class_decimal(<ime, &decimal_value));
263
my_decimal decimal_value;
264
return store_value(date2my_decimal(ltime, &decimal_value));
263
268
double Field_decimal::val_real(void)
266
type::Decimal decimal_value;
271
my_decimal decimal_value;
268
273
ASSERT_COLUMN_MARKED_FOR_READ;
270
class_decimal2double(E_DEC_FATAL_ERROR, val_decimal(&decimal_value), &dbl);
275
my_decimal2double(E_DEC_FATAL_ERROR, val_decimal(&decimal_value), &dbl);
276
281
int64_t Field_decimal::val_int(void)
279
type::Decimal decimal_value;
284
my_decimal decimal_value;
281
286
ASSERT_COLUMN_MARKED_FOR_READ;
283
val_decimal(&decimal_value)->val_int32(E_DEC_FATAL_ERROR, false, &i);
288
my_decimal2int(E_DEC_FATAL_ERROR, val_decimal(&decimal_value), false, &i);
289
type::Decimal* Field_decimal::val_decimal(type::Decimal *decimal_value)
294
my_decimal* Field_decimal::val_decimal(my_decimal *decimal_value)
291
296
ASSERT_COLUMN_MARKED_FOR_READ;
293
binary2_class_decimal(E_DEC_FATAL_ERROR, ptr, decimal_value,
298
binary2my_decimal(E_DEC_FATAL_ERROR, ptr, decimal_value,
295
300
return(decimal_value);
299
304
String *Field_decimal::val_str(String *val_buffer,
302
type::Decimal decimal_value;
307
my_decimal decimal_value;
304
309
ASSERT_COLUMN_MARKED_FOR_READ;
306
class_decimal2string(val_decimal(&decimal_value),
311
uint32_t fixed_precision= decimal_precision ? precision : 0;
312
my_decimal2string(E_DEC_FATAL_ERROR, val_decimal(&decimal_value),
313
fixed_precision, dec, '0', val_buffer);
308
314
return val_buffer;
347
353
uint32_t const source_precision= (field_metadata >> 8U) & 0x00ff;
348
354
uint32_t const source_decimal= field_metadata & 0x00ff;
349
uint32_t const source_size= class_decimal_get_binary_size(source_precision,
355
uint32_t const source_size= my_decimal_get_binary_size(source_precision,
351
357
return (source_size);
388
394
uint32_t from_precision= (param_data & 0xff00) >> 8U;
389
395
uint32_t from_decimal= param_data & 0x00ff;
390
396
uint32_t length=pack_length();
391
uint32_t from_pack_len= class_decimal_get_binary_size(from_precision, from_decimal);
397
uint32_t from_pack_len= my_decimal_get_binary_size(from_precision, from_decimal);
392
398
uint32_t len= (param_data && (from_pack_len < length)) ?
393
399
from_pack_len : length;
394
400
if ((from_pack_len && (from_pack_len < length)) ||