40
37
/****************************************************************************
42
****************************************************************************/
44
int Int32::store(const char *from,uint32_t len, const CHARSET_INFO * const cs)
39
****************************************************************************/
41
int Field_long::store(const char *from,uint32_t len, const CHARSET_INFO * const cs)
47
ASSERT_COLUMN_MARKED_FOR_WRITE;
49
error= get_int(cs, from, len, &rnd, UINT32_MAX, INT32_MIN, INT32_MAX);
50
store_tmp= (long) rnd;
51
#ifdef WORDS_BIGENDIAN
52
if (table->s->db_low_byte_first)
50
ASSERT_COLUMN_MARKED_FOR_WRITE;
52
error= get_int(cs, from, len, &rnd, UINT32_MAX, INT32_MIN, INT32_MAX);
53
store_tmp= (long) rnd;
54
int4store(ptr, store_tmp);
54
58
longstore(ptr, store_tmp);
60
int Int32::store(double nr)
66
ASSERT_COLUMN_MARKED_FOR_WRITE;
68
if (nr < (double) INT32_MIN)
70
res=(int32_t) INT32_MIN;
73
else if (nr > (double) INT32_MAX)
75
res=(int32_t) INT32_MAX;
79
res=(int32_t) (int64_t) nr;
82
set_warning(DRIZZLE_ERROR::WARN_LEVEL_WARN, ER_WARN_DATA_OUT_OF_RANGE, 1);
90
int Int32::store(int64_t nr, bool unsigned_val)
95
ASSERT_COLUMN_MARKED_FOR_WRITE;
97
if (nr < 0 && unsigned_val)
98
nr= ((int64_t) INT32_MAX) + 1; // Generate overflow
100
if (nr < (int64_t) INT32_MIN)
102
res=(int32_t) INT32_MIN;
105
else if (nr > (int64_t) INT32_MAX)
107
res=(int32_t) INT32_MAX;
116
set_warning(DRIZZLE_ERROR::WARN_LEVEL_WARN, ER_WARN_DATA_OUT_OF_RANGE, 1);
124
double Int32::val_real(void)
128
ASSERT_COLUMN_MARKED_FOR_READ;
135
int64_t Int32::val_int(void)
139
ASSERT_COLUMN_MARKED_FOR_READ;
146
String *Int32::val_str(String *val_buffer, String *)
148
const CHARSET_INFO * const cs= &my_charset_bin;
150
uint32_t mlength= max(field_length+1,12*cs->mbmaxlen);
151
val_buffer->alloc(mlength);
152
char *to=(char*) val_buffer->ptr();
155
ASSERT_COLUMN_MARKED_FOR_READ;
159
length=cs->cset->long10_to_str(cs,to,mlength,-10,(long) j);
160
val_buffer->length(length);
165
int Int32::cmp(const unsigned char *a_ptr, const unsigned char *b_ptr)
63
int Field_long::store(double nr)
69
ASSERT_COLUMN_MARKED_FOR_WRITE;
71
if (nr < (double) INT32_MIN)
73
res=(int32_t) INT32_MIN;
76
else if (nr > (double) INT32_MAX)
78
res=(int32_t) INT32_MAX;
82
res=(int32_t) (int64_t) nr;
85
set_warning(DRIZZLE_ERROR::WARN_LEVEL_WARN, ER_WARN_DATA_OUT_OF_RANGE, 1);
87
#ifdef WORDS_BIGENDIAN
88
if (table->s->db_low_byte_first)
99
int Field_long::store(int64_t nr, bool unsigned_val)
104
ASSERT_COLUMN_MARKED_FOR_WRITE;
106
if (nr < 0 && unsigned_val)
107
nr= ((int64_t) INT32_MAX) + 1; // Generate overflow
108
if (nr < (int64_t) INT32_MIN)
110
res=(int32_t) INT32_MIN;
113
else if (nr > (int64_t) INT32_MAX)
115
res=(int32_t) INT32_MAX;
122
set_warning(DRIZZLE_ERROR::WARN_LEVEL_WARN, ER_WARN_DATA_OUT_OF_RANGE, 1);
124
#ifdef WORDS_BIGENDIAN
125
if (table->s->db_low_byte_first)
136
double Field_long::val_real(void)
140
ASSERT_COLUMN_MARKED_FOR_READ;
142
#ifdef WORDS_BIGENDIAN
143
if (table->s->db_low_byte_first)
151
int64_t Field_long::val_int(void)
155
ASSERT_COLUMN_MARKED_FOR_READ;
157
/* See the comment in Field_long::store(int64_t) */
158
assert(table->in_use == current_session);
159
#ifdef WORDS_BIGENDIAN
160
if (table->s->db_low_byte_first)
168
String *Field_long::val_str(String *val_buffer,
171
const CHARSET_INFO * const cs= &my_charset_bin;
173
uint32_t mlength= max(field_length+1,12*cs->mbmaxlen);
174
val_buffer->alloc(mlength);
175
char *to=(char*) val_buffer->ptr();
178
ASSERT_COLUMN_MARKED_FOR_READ;
180
#ifdef WORDS_BIGENDIAN
181
if (table->s->db_low_byte_first)
187
length=cs->cset->long10_to_str(cs,to,mlength,-10,(long) j);
188
val_buffer->length(length);
193
int Field_long::cmp(const unsigned char *a_ptr, const unsigned char *b_ptr)
196
#ifdef WORDS_BIGENDIAN
197
if (table->s->db_low_byte_first)
169
205
longget(a,a_ptr);
170
206
longget(b,b_ptr);
172
return (a < b) ? -1 : (a > b) ? 1 : 0;
175
void Int32::sort_string(unsigned char *to,uint32_t )
177
#ifdef WORDS_BIGENDIAN
179
to[0] = (char) (ptr[0] ^ 128); /* Revers signbit */
186
to[0] = (char) (ptr[3] ^ 128); /* Revers signbit */
195
void Int32::sql_type(String &res) const
197
const CHARSET_INFO * const cs=res.charset();
198
res.length(cs->cset->snprintf(cs,(char*) res.ptr(),res.alloced_length(), "int"));
201
unsigned char *Int32::pack(unsigned char* to, const unsigned char *from, uint32_t, bool)
207
return to + sizeof(val);
211
const unsigned char *Int32::unpack(unsigned char* to, const unsigned char *from, uint32_t, bool)
218
return from + sizeof(val);
221
} /* namespace field */
209
return (a < b) ? -1 : (a > b) ? 1 : 0;
212
void Field_long::sort_string(unsigned char *to,uint32_t )
214
#ifdef WORDS_BIGENDIAN
215
if (!table->s->db_low_byte_first)
217
to[0] = (char) (ptr[0] ^ 128); /* Revers signbit */
225
to[0] = (char) (ptr[3] ^ 128); /* Revers signbit */
233
void Field_long::sql_type(String &res) const
235
const CHARSET_INFO * const cs=res.charset();
236
res.length(cs->cset->snprintf(cs,(char*) res.ptr(),res.alloced_length(), "int"));
239
unsigned char *Field_long::pack(unsigned char* to, const unsigned char *from,
241
#ifdef WORDS_BIGENDIAN
249
#ifdef WORDS_BIGENDIAN
250
if (table->s->db_low_byte_first)
251
val = sint4korr(from);
256
#ifdef WORDS_BIGENDIAN
262
return to + sizeof(val);
266
const unsigned char *Field_long::unpack(unsigned char* to, const unsigned char *from, uint32_t,
267
#ifdef WORDS_BIGENDIAN
275
#ifdef WORDS_BIGENDIAN
277
val = sint4korr(from);
282
#ifdef WORDS_BIGENDIAN
283
if (table->s->db_low_byte_first)
288
return from + sizeof(val);
222
291
} /* namespace drizzled */