18
18
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21
#ifdef USE_PRAGMA_IMPLEMENTATION
22
#pragma implementation // gcc: Class implementation
25
#include <drizzled/server_includes.h>
23
26
#include <drizzled/field/varstring.h>
24
#include <drizzled/table.h>
25
#include <drizzled/session.h>
26
#include <plugin/myisam/myisam.h>
35
28
/****************************************************************************
51
44
const uint32_t Field_varstring::MAX_SIZE= UINT16_MAX;
53
Field_varstring::Field_varstring(unsigned char *ptr_arg,
55
uint32_t length_bytes_arg,
56
unsigned char *null_ptr_arg,
57
unsigned char null_bit_arg,
58
const char *field_name_arg,
59
const CHARSET_INFO * const cs) :
65
length_bytes(length_bytes_arg)
69
Field_varstring::Field_varstring(uint32_t len_arg,
71
const char *field_name_arg,
72
const CHARSET_INFO * const cs) :
73
Field_str((unsigned char*) 0,
75
maybe_null_arg ? (unsigned char*) "": 0,
79
length_bytes(len_arg < 256 ? 1 :2)
47
Save the field metadata for varstring fields.
49
Saves the field length in the first byte. Note: may consume
50
2 bytes. Caller must ensure second byte is contiguous with
51
first byte (e.g. array index 0,1).
53
@param metadata_ptr First byte of field metadata
55
@returns number of bytes written to metadata_ptr
57
int Field_varstring::do_save_field_metadata(unsigned char *metadata_ptr)
59
char *ptr= (char *)metadata_ptr;
60
assert(field_length <= 65535);
61
int2store(ptr, field_length);
83
65
int Field_varstring::store(const char *from,uint32_t length, const CHARSET_INFO * const cs)
118
length= (uint32_t) (field_charset->cset->int64_t10_to_str)(field_charset,
121
(unsigned_val ? 10: -10),
98
length= (uint) (field_charset->cset->int64_t10_to_str)(field_charset,
123
104
return Field_varstring::store(buff, length, field_charset);
127
double Field_varstring::val_real(void) const
108
double Field_varstring::val_real(void)
130
111
char *end_not_used;
132
ASSERT_COLUMN_MARKED_FOR_READ;
134
uint32_t length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
112
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
136
113
return my_strntod(field_charset, (char*) ptr+length_bytes, length,
137
114
&end_not_used, ¬_used);
141
int64_t Field_varstring::val_int(void) const
118
int64_t Field_varstring::val_int(void)
144
121
char *end_not_used;
147
ASSERT_COLUMN_MARKED_FOR_READ;
149
length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
122
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
151
123
return my_strntoll(field_charset, (char*) ptr+length_bytes, length, 10,
152
124
&end_not_used, ¬_used);
155
String *Field_varstring::val_str(String *, String *val_ptr) const
127
String *Field_varstring::val_str(String *val_buffer __attribute__((unused)),
157
uint32_t length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
159
ASSERT_COLUMN_MARKED_FOR_READ;
130
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
161
131
val_ptr->set((const char*) ptr+length_bytes, length, field_charset);
167
type::Decimal *Field_varstring::val_decimal(type::Decimal *decimal_value) const
136
my_decimal *Field_varstring::val_decimal(my_decimal *decimal_value)
171
ASSERT_COLUMN_MARKED_FOR_READ;
173
length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
175
decimal_value->store(E_DEC_FATAL_ERROR, (char*) ptr+length_bytes, length, charset());
138
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
139
str2my_decimal(E_DEC_FATAL_ERROR, (char*) ptr+length_bytes, length,
140
charset(), decimal_value);
177
141
return decimal_value;
215
179
int Field_varstring::key_cmp(const unsigned char *key_ptr, uint32_t max_key_length)
217
uint32_t length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
181
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
218
182
uint32_t local_char_length= max_key_length / field_charset->mbmaxlen;
220
184
local_char_length= my_charpos(field_charset, ptr + length_bytes,
221
ptr + length_bytes + length, local_char_length);
185
ptr + length_bytes + length, local_char_length);
222
186
set_if_smaller(length, local_char_length);
223
return field_charset->coll->strnncollsp(field_charset,
187
return field_charset->coll->strnncollsp(field_charset,
224
188
ptr + length_bytes,
261
225
mi_int2store(to+length-2, tot_length);
262
226
length-= length_bytes;
265
229
tot_length= my_strnxfrm(field_charset,
266
to, length, ptr + length_bytes,
230
to, length, ptr + length_bytes,
268
232
assert(tot_length == length);
298
Field_varstring::pack_key(unsigned char *to, const unsigned char *key, uint32_t max_length,
299
bool low_byte_first __attribute__((unused)))
301
uint32_t length= length_bytes == 1 ? (uint) *key : uint2korr(key);
302
uint32_t local_char_length= ((field_charset->mbmaxlen > 1) ?
303
max_length/field_charset->mbmaxlen : max_length);
305
if (length > local_char_length)
307
local_char_length= my_charpos(field_charset, key, key+length,
309
set_if_smaller(length, local_char_length);
311
*to++= (char) (length & 255);
312
if (max_length > 255)
313
*to++= (char) (length >> 8);
315
memcpy(to, key, length);
321
Unpack a key into a record buffer.
323
A VARCHAR key has a maximum size of 64K-1.
324
In its packed form, the length field is one or two bytes long,
325
depending on 'max_length'.
327
@param to Pointer into the record buffer.
328
@param key Pointer to the packed key.
329
@param max_length Key length limit from key description.
332
Pointer to end of 'key' (To the next key part if multi-segment key)
335
const unsigned char *
336
Field_varstring::unpack_key(unsigned char *to __attribute__((unused)),
337
const unsigned char *key, uint32_t max_length,
338
bool low_byte_first __attribute__((unused)))
340
/* get length of the blob key */
341
uint32_t length= *key++;
342
if (max_length > 255)
343
length+= (*key++) << 8;
345
/* put the length into the record buffer */
346
if (length_bytes == 1)
347
*ptr= (unsigned char) length;
349
int2store(ptr, length);
350
memcpy(ptr + length_bytes, key, length);
355
Create a packed key that will be used for storage in the index tree.
357
@param to Store packed key segment here
358
@param from Key segment (as given to index_read())
359
@param max_length Max length of key
366
Field_varstring::pack_key_from_key_image(unsigned char *to, const unsigned char *from, uint32_t max_length,
367
bool low_byte_first __attribute__((unused)))
369
/* Key length is always stored as 2 bytes */
370
uint32_t length= uint2korr(from);
371
if (length > max_length)
373
*to++= (char) (length & 255);
374
if (max_length > 255)
375
*to++= (char) (length >> 8);
377
memcpy(to, from+HA_KEY_BLOB_LENGTH, length);
329
383
Unpack a varstring field from row data.
424
int Field_varstring::pack_cmp(const unsigned char *a, const unsigned char *b,
425
uint32_t key_length_arg,
426
bool insert_or_update)
428
uint32_t a_length, b_length;
429
if (key_length_arg > 255)
431
a_length=uint2korr(a); a+= 2;
432
b_length=uint2korr(b); b+= 2;
436
a_length= (uint) *a++;
437
b_length= (uint) *b++;
439
return field_charset->coll->strnncollsp(field_charset,
446
int Field_varstring::pack_cmp(const unsigned char *b, uint32_t key_length_arg,
447
bool insert_or_update)
449
unsigned char *a= ptr+ length_bytes;
450
uint32_t a_length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
452
uint32_t local_char_length= ((field_charset->mbmaxlen > 1) ?
453
key_length_arg / field_charset->mbmaxlen :
456
if (key_length_arg > 255)
458
b_length=uint2korr(b); b+= HA_KEY_BLOB_LENGTH;
461
b_length= (uint) *b++;
463
if (a_length > local_char_length)
465
local_char_length= my_charpos(field_charset, a, a+a_length,
467
set_if_smaller(a_length, local_char_length);
470
return field_charset->coll->strnncollsp(field_charset,
477
uint32_t Field_varstring::packed_col_length(const unsigned char *data_ptr, uint32_t length)
480
return uint2korr(data_ptr)+2;
481
return (uint) *data_ptr + 1;
370
485
uint32_t Field_varstring::max_packed_col_length(uint32_t max_length)
372
487
return (max_length > 255 ? 2 : 1)+max_length;
375
uint32_t Field_varstring::get_key_image(basic_string<unsigned char> &buff, uint32_t length)
377
/* Key is always stored with 2 bytes */
378
const uint32_t key_len= 2;
379
uint32_t f_length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
380
uint32_t local_char_length= length / field_charset->mbmaxlen;
381
unsigned char *pos= ptr+length_bytes;
382
local_char_length= my_charpos(field_charset, pos, pos + f_length,
384
set_if_smaller(f_length, local_char_length);
385
unsigned char len_buff[key_len];
386
int2store(len_buff,f_length);
387
buff.append(len_buff);
388
buff.append(pos, f_length);
389
if (f_length < length)
392
Must clear this as we do a memcmp in optimizer/range.cc to detect
395
buff.append(length-f_length, 0);
397
return key_len+f_length;
401
uint32_t Field_varstring::get_key_image(unsigned char *buff, uint32_t length)
403
uint32_t f_length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
490
uint32_t Field_varstring::get_key_image(unsigned char *buff,
492
imagetype type __attribute__((unused)))
494
uint32_t f_length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
404
495
uint32_t local_char_length= length / field_charset->mbmaxlen;
405
496
unsigned char *pos= ptr+length_bytes;
406
497
local_char_length= my_charpos(field_charset, pos, pos + f_length,
420
511
return HA_KEY_BLOB_LENGTH+f_length;
423
void Field_varstring::set_key_image(const unsigned char *buff, uint32_t length)
515
void Field_varstring::set_key_image(const unsigned char *buff,uint32_t length)
425
517
length= uint2korr(buff); // Real length is here
426
(void) Field_varstring::store((const char*) buff+HA_KEY_BLOB_LENGTH, length, field_charset);
518
(void) Field_varstring::store((const char*) buff+HA_KEY_BLOB_LENGTH, length,
429
int Field_varstring::cmp_binary(const unsigned char *a_ptr,
430
const unsigned char *b_ptr,
523
int Field_varstring::cmp_binary(const unsigned char *a_ptr, const unsigned char *b_ptr,
431
524
uint32_t max_length)
433
526
uint32_t a_length,b_length;
435
528
if (length_bytes == 1)
437
a_length= (uint32_t) *a_ptr;
438
b_length= (uint32_t) *b_ptr;
530
a_length= (uint) *a_ptr;
531
b_length= (uint) *b_ptr;
481
} /* namespace drizzled */
575
uint32_t Field_varstring::is_equal(Create_field *new_field)
577
if (new_field->sql_type == real_type() &&
578
new_field->charset == field_charset)
580
if (new_field->length == max_display_length())
582
if (new_field->length > max_display_length() &&
583
((new_field->length <= 255 && max_display_length() <= 255) ||
584
(new_field->length > 255 && max_display_length() > 255)))
585
return IS_EQUAL_PACK_LENGTH; // VARCHAR, longer variable length
591
void Field_varstring::hash(uint32_t *nr, uint32_t *nr2)
595
*nr^= (*nr << 1) | 1;
599
uint32_t len= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
600
const CHARSET_INFO * const cs= charset();
601
cs->coll->hash_sort(cs, ptr + length_bytes, len, nr, nr2);