Commit 0d4b8a31 authored by marko's avatar marko

branches/zip: Fix bugs in the handling of externally stored columns.

btr_cur_pessimistic_insert(): Pass the "extern storage" flags to
btr_root_raise_and_insert() or btr_page_split_and_insert().

btr_copy_externally_stored_field(): Include local_len in the returned length.
parent dcfc19c4
...@@ -1202,6 +1202,7 @@ btr_cur_pessimistic_insert( ...@@ -1202,6 +1202,7 @@ btr_cur_pessimistic_insert(
{ {
dict_index_t* index = cursor->index; dict_index_t* index = cursor->index;
big_rec_t* big_rec_vec = NULL; big_rec_t* big_rec_vec = NULL;
mem_heap_t* heap = NULL;
page_t* page; page_t* page;
ulint err; ulint err;
ibool dummy_inh; ibool dummy_inh;
...@@ -1278,6 +1279,26 @@ btr_cur_pessimistic_insert( ...@@ -1278,6 +1279,26 @@ btr_cur_pessimistic_insert(
} }
} }
/* Add externally stored records, if needed */
if (UNIV_LIKELY_NULL(big_rec_vec)) {
ulint n_more_ext = big_rec_vec->n_fields;
ulint* more_ext;
ulint i;
heap = mem_heap_create((n_more_ext + n_ext) * sizeof(ulint));
more_ext = mem_heap_alloc(heap,
(n_more_ext + n_ext) * sizeof(ulint));
if (n_ext) {
memcpy(more_ext, ext, n_ext * sizeof(ulint));
}
for (i = 0; i < n_more_ext; i++) {
more_ext[n_ext++] = big_rec_vec->fields[i].field_no;
}
ext = more_ext;
}
if (dict_tree_get_page(index->tree) if (dict_tree_get_page(index->tree)
== buf_frame_get_page_no(page)) { == buf_frame_get_page_no(page)) {
...@@ -1289,6 +1310,10 @@ btr_cur_pessimistic_insert( ...@@ -1289,6 +1310,10 @@ btr_cur_pessimistic_insert(
ext, n_ext, mtr); ext, n_ext, mtr);
} }
if (UNIV_LIKELY_NULL(heap)) {
mem_heap_free(heap);
}
btr_cur_position(index, page_rec_get_prev(*rec), cursor); btr_cur_position(index, page_rec_get_prev(*rec), cursor);
#ifdef BTR_CUR_ADAPT #ifdef BTR_CUR_ADAPT
...@@ -3615,7 +3640,6 @@ btr_store_big_rec_extern_fields( ...@@ -3615,7 +3640,6 @@ btr_store_big_rec_extern_fields(
MLOG_4BYTES, &mtr); MLOG_4BYTES, &mtr);
if (err == Z_STREAM_END) { if (err == Z_STREAM_END) {
fprintf(stderr,"in:%lu out:%lu\n", c_stream.total_in, c_stream.total_out);
mlog_write_ulint(field_ref mlog_write_ulint(field_ref
+ BTR_EXTERN_LEN + 4, + BTR_EXTERN_LEN + 4,
c_stream.total_in, c_stream.total_in,
...@@ -4011,7 +4035,7 @@ btr_copy_externally_stored_field( ...@@ -4011,7 +4035,7 @@ btr_copy_externally_stored_field(
memcpy(buf, data, local_len); memcpy(buf, data, local_len);
copied_len = local_len; copied_len = local_len;
if (extern_len == 0) { if (UNIV_UNLIKELY(extern_len == 0)) {
*len = copied_len; *len = copied_len;
return(buf); return(buf);
...@@ -4071,7 +4095,9 @@ btr_copy_externally_stored_field( ...@@ -4071,7 +4095,9 @@ btr_copy_externally_stored_field(
ut_a(!d_stream.avail_out); ut_a(!d_stream.avail_out);
inflateEnd(&d_stream); inflateEnd(&d_stream);
*len = d_stream.total_out; ut_ad(buf + local_len + d_stream.total_out ==
d_stream.next_out);
*len = d_stream.next_out - buf;
return(buf); return(buf);
} }
......
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