Commit b13c6cc7 authored by Zardosht Kasheff's avatar Zardosht Kasheff Committed by Yoni Fogel

addresses #1567

change order of null byte and type byte in descriptor
add a null byte for hpk

git-svn-id: file:///svn/mysql/tokudb-engine/src@10959 c7de825b-a66e-492c-adef-691d508d4ae1
parent a405f04d
...@@ -1141,17 +1141,17 @@ int create_toku_key_descriptor(KEY* key, uchar* buf) { ...@@ -1141,17 +1141,17 @@ int create_toku_key_descriptor(KEY* key, uchar* buf) {
for (uint i = 0; i < key->key_parts; i++){ for (uint i = 0; i < key->key_parts; i++){
Field* field = key->key_part[i].field; Field* field = key->key_part[i].field;
// //
// The first byte for each field is the type // The first byte states if there is a null byte
// //
TOKU_TYPE type = mysql_to_toku_type(field); *pos = field->null_bit;
assert (type < 256);
*pos = (uchar)(type & 255);
pos++; pos++;
// //
// The second bytes states if there is a null byte // The second byte for each field is the type
// //
*pos = field->null_bit; TOKU_TYPE type = mysql_to_toku_type(field);
assert (type < 256);
*pos = (uchar)(type & 255);
pos++; pos++;
// //
...@@ -1243,8 +1243,9 @@ int create_toku_descriptor( ...@@ -1243,8 +1243,9 @@ int create_toku_descriptor(
assert(!(is_clustering_key && !is_second_hpk && second_key == NULL)); assert(!(is_clustering_key && !is_second_hpk && second_key == NULL));
if (is_first_hpk) { if (is_first_hpk) {
pos[0] = toku_type_hpk; pos[0] = 0; //field cannot be NULL, stating it
pos++; pos[1] = toku_type_hpk;
pos += 2;
} }
else { else {
// //
...@@ -1281,8 +1282,9 @@ int create_toku_descriptor( ...@@ -1281,8 +1282,9 @@ int create_toku_descriptor(
// write in the offset to this position in the first four bytes // write in the offset to this position in the first four bytes
// //
if (is_second_hpk) { if (is_second_hpk) {
pos[0] = toku_type_hpk; pos[0] = 0; //field cannot be NULL, stating it
pos++; pos[1] = toku_type_hpk;
pos += 2;
} }
else { else {
// //
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment