mirror of
https://github.com/MariaDB/server.git
synced 2026-05-16 20:07:13 +02:00
Add 0x before pointers (to help with debugging)
Add support for VARCHAR with 1 or 2 length bytes Enable VARCHAR packing in MyISAM files (previous patch didn't pack data properly) Give error if we got problems in temporary tables during a SELECT Don't use new table generated by ALTER TABLE if index generation fails Fixed wrong call by range_end() (Could cause an ASSERT in debug mode) BUILD/SETUP.sh: Add flags for Intel 64 dbug/dbug.c: Add 0x before pointers (to help with debugging) heap/_check.c: Add 0x before pointers (to help with debugging) heap/hp_create.c: Add support for VARCHAR with 1 or 2 length bytes heap/hp_delete.c: Add 0x before pointers heap/hp_hash.c: Add support for VARCHAR with 1 or 2 length bytes Added more debugging heap/hp_open.c: Add 0x before pointers heap/hp_rkey.c: Add 0x before pointers heap/hp_rrnd.c: Add 0x before pointers heap/hp_write.c: Add 0x before pointers include/my_base.h: Add support for VARCHAR with 1 or 2 length bytes myisam/ft_static.c: Add support for VARCHAR with 1 or 2 length bytes myisam/ft_test1.c: Add support for VARCHAR with 1 or 2 length bytes Fixed indentation (This file should probably be deleted as it doesn't compile) myisam/ft_update.c: Add support for VARCHAR with 1 or 2 length bytes Fixed indentation Removed some not needed 'else' myisam/mi_check.c: Don't give an error for tables packed with myisampack myisam/mi_checksum.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_create.c: Add support for VARCHAR with 1 or 2 length bytes Store in number of pack-length-bytes in keyseg->bit_start myisam/mi_dbug.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_dynrec.c: Add support for VARCHAR with 1 or 2 length bytes (old code in _mi_rec_unpack() didn't really work with VARCHAR's) myisam/mi_key.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_open.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_packrec.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_search.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_test1.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_test3.c: Add support for VARCHAR with 1 or 2 length bytes myisam/mi_test_all.res: Update results myisam/mi_unique.c: Add support for VARCHAR with 1 or 2 length bytes myisam/myisampack.c: Add support for VARCHAR with 1 or 2 length bytes mysql-test/include/varchar.inc: Added more tests mysql-test/r/bdb.result: Update results after new tests mysql-test/r/information_schema.result: Update results mysql-test/r/innodb.result: Update results mysql-test/r/myisam.result: Update results after new tests mysql-test/r/ps_1general.result: Update results mysql-test/t/bdb.test: Shorter comments mysys/list.c: Add 0x before pointers mysys/my_handler.c: Add support for VARCHAR with 1 or 2 length bytes mysys/raid.cc: Add 0x before pointers sql/field.cc: Add support for VARCHAR with 1 or 2 length bytes sql/field.h: Add support for VARCHAR with 1 or 2 length bytes sql/field_conv.cc: Add support for VARCHAR with 1 or 2 length bytes sql/ha_berkeley.cc: Add support for VARCHAR with 1 or 2 length bytes sql/ha_heap.cc: Add support for VARCHAR with 1 or 2 length bytes sql/ha_myisam.cc: Ensure that enable_indexes() will report an error if it fails Enable VARCHAR packing for MyISAM files sql/item_sum.cc: Change key_cmp -> cmp() as we are comparing fields, not key segements sql/opt_range.cc: Add support for VARCHAR with 1 or 2 length bytes Change range_end to call ha_index_or_rnd_end() as in some error cases we may be in rnd mode when we abort sql/sql_base.cc: Remove compiler warning sql/sql_parse.cc: Move length checking code to sql_table.cc (as we don't have character set for fields at this stage) sql/sql_select.cc: Add support for VARCHAR with 1 or 2 length bytes Ensure that we report an error if we get an error while writing to internal temporary tables sql/sql_select.h: Add support for VARCHAR with 1 or 2 length bytes sql/sql_show.cc: Fix typo in comment sql/sql_table.cc: Don't use new table generated by ALTER TABLE if index generation fails vio/vio.c: Fixed DBUG info vio/viosocket.c: Fixed DBUG info vio/viossl.c: Fixed DBUG info vio/viosslfactories.c: Fixed DBUG info
This commit is contained in:
parent
5ae35e327a
commit
8eaef91fff
57 changed files with 1404 additions and 459 deletions
|
|
@ -768,11 +768,21 @@ uint _mi_rec_pack(MI_INFO *info, register byte *to, register const byte *from)
|
|||
}
|
||||
else if (type == FIELD_VARCHAR)
|
||||
{
|
||||
uint tmp_length=uint2korr(from);
|
||||
store_key_length_inc(to,tmp_length);
|
||||
memcpy(to,from+2,tmp_length);
|
||||
to+=tmp_length;
|
||||
continue;
|
||||
uint pack_length= HA_VARCHAR_PACKLENGTH(rec->length -1);
|
||||
uint tmp_length;
|
||||
if (pack_length == 1)
|
||||
{
|
||||
tmp_length= (uint) *(uchar*) from;
|
||||
*to++= *from;
|
||||
}
|
||||
else
|
||||
{
|
||||
tmp_length= uint2korr(from);
|
||||
store_key_length_inc(to,tmp_length);
|
||||
}
|
||||
memcpy(to, from+pack_length,tmp_length);
|
||||
to+= tmp_length;
|
||||
continue;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -878,9 +888,20 @@ my_bool _mi_rec_check(MI_INFO *info,const char *record, byte *rec_buff,
|
|||
}
|
||||
else if (type == FIELD_VARCHAR)
|
||||
{
|
||||
uint tmp_length=uint2korr(record);
|
||||
to+=get_pack_length(tmp_length)+tmp_length;
|
||||
continue;
|
||||
uint pack_length= HA_VARCHAR_PACKLENGTH(rec->length -1);
|
||||
uint tmp_length;
|
||||
if (pack_length == 1)
|
||||
{
|
||||
tmp_length= (uint) *(uchar*) record;
|
||||
to+= 1+ tmp_length;
|
||||
continue;
|
||||
}
|
||||
else
|
||||
{
|
||||
tmp_length= uint2korr(record);
|
||||
to+= get_pack_length(tmp_length)+tmp_length;
|
||||
}
|
||||
continue;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -894,9 +915,7 @@ my_bool _mi_rec_check(MI_INFO *info,const char *record, byte *rec_buff,
|
|||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
to+=length;
|
||||
}
|
||||
to+= length;
|
||||
}
|
||||
if (packed_length != (uint) (to - rec_buff) + test(info->s->calc_checksum) ||
|
||||
(bit != 1 && (flag & ~(bit - 1))))
|
||||
|
|
@ -947,13 +966,27 @@ ulong _mi_rec_unpack(register MI_INFO *info, register byte *to, byte *from,
|
|||
{
|
||||
if (type == FIELD_VARCHAR)
|
||||
{
|
||||
get_key_length(length,from);
|
||||
if (length > rec_length-2)
|
||||
goto err;
|
||||
int2store(to,length);
|
||||
memcpy(to+2,from,length);
|
||||
from+=length;
|
||||
continue;
|
||||
uint pack_length= HA_VARCHAR_PACKLENGTH(rec_length-1);
|
||||
if (pack_length == 1)
|
||||
{
|
||||
length= (uint) *(uchar*) from;
|
||||
if (length > rec_length-1)
|
||||
goto err;
|
||||
*to= *from++;
|
||||
}
|
||||
else
|
||||
{
|
||||
get_key_length(length, from);
|
||||
if (length > rec_length-2)
|
||||
goto err;
|
||||
int2store(to,length);
|
||||
}
|
||||
if (from+length > from_end)
|
||||
goto err;
|
||||
memcpy(to+pack_length, from, length);
|
||||
from+= length;
|
||||
min_pack_length--;
|
||||
continue;
|
||||
}
|
||||
if (flag & bit)
|
||||
{
|
||||
|
|
@ -1021,15 +1054,17 @@ ulong _mi_rec_unpack(register MI_INFO *info, register byte *to, byte *from,
|
|||
if (min_pack_length > (uint) (from_end - from))
|
||||
goto err;
|
||||
min_pack_length-=rec_length;
|
||||
memcpy(to,(byte*) from,(size_t) rec_length); from+=rec_length;
|
||||
memcpy(to, (byte*) from, (size_t) rec_length);
|
||||
from+=rec_length;
|
||||
}
|
||||
}
|
||||
if (info->s->calc_checksum)
|
||||
from++;
|
||||
if (to == to_end && from == from_end && (bit == 1 || !(flag & ~(bit-1))))
|
||||
DBUG_RETURN(found_length);
|
||||
|
||||
err:
|
||||
my_errno=HA_ERR_RECORD_DELETED;
|
||||
my_errno= HA_ERR_WRONG_IN_RECORD;
|
||||
DBUG_PRINT("error",("to_end: %lx -> %lx from_end: %lx -> %lx",
|
||||
to,to_end,from,from_end));
|
||||
DBUG_DUMP("from",(byte*) info->rec_buff,info->s->base.min_pack_length);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue