Commit 8b4d7880 authored by marko's avatar marko

branches/zip: Fix some bugs in file-based merge sort.

row_merge_read_rec(): Correct a typo in a comment.  Fix error in
arithmetics when the record spans two blocks.

row_merge_write_rec_low(): Add a "size" parameter.  Add debug assertions
about extra_size and size.

row_merge_write_rec(): After writing a record, properly advance the
buffer pointer.
parent ec405955
...@@ -607,7 +607,7 @@ row_merge_read_rec( ...@@ -607,7 +607,7 @@ row_merge_read_rec(
extra_size |= *b++; extra_size |= *b++;
} }
/* Normalize extra_size. Above, value 0 signals "end of list. */ /* Normalize extra_size. Above, value 0 signals "end of list". */
extra_size--; extra_size--;
/* Read the extra bytes. */ /* Read the extra bytes. */
...@@ -669,6 +669,7 @@ row_merge_read_rec( ...@@ -669,6 +669,7 @@ row_merge_read_rec(
/* The record spans two blocks. Copy it to buf. */ /* The record spans two blocks. Copy it to buf. */
b -= extra_size + data_size;
avail_size = block[1] - b; avail_size = block[1] - b;
memcpy(*buf, b, avail_size); memcpy(*buf, b, avail_size);
*mrec = *buf + extra_size; *mrec = *buf + extra_size;
...@@ -697,9 +698,17 @@ row_merge_write_rec_low( ...@@ -697,9 +698,17 @@ row_merge_write_rec_low(
/*====================*/ /*====================*/
byte* b, /* out: buffer */ byte* b, /* out: buffer */
ulint e, /* in: encoded extra_size */ ulint e, /* in: encoded extra_size */
#ifdef UNIV_DEBUG
ulint size, /* in: total size to write */
#endif /* UNIV_DEBUG */
const mrec_t* mrec, /* in: record to write */ const mrec_t* mrec, /* in: record to write */
const ulint* offsets)/* in: offsets of mrec */ const ulint* offsets)/* in: offsets of mrec */
{ {
#ifdef UNIV_DEBUG
const byte* const end = b + size;
#endif /* UNIV_DEBUG */
ut_ad(e == rec_offs_extra_size(offsets) + 1);
if (e < 0x80) { if (e < 0x80) {
*b++ = e; *b++ = e;
} else { } else {
...@@ -708,8 +717,13 @@ row_merge_write_rec_low( ...@@ -708,8 +717,13 @@ row_merge_write_rec_low(
} }
memcpy(b, mrec - rec_offs_extra_size(offsets), rec_offs_size(offsets)); memcpy(b, mrec - rec_offs_extra_size(offsets), rec_offs_size(offsets));
ut_ad(b + rec_offs_size(offsets) == end);
} }
#ifndef UNIV_DEBUG
# define row_merge_write_rec_low(b,e,s,m,o) row_merge_write_rec_low(b,e,m,o)
#endif /* UNIV_DEBUG */
/************************************************************************ /************************************************************************
Write a merge record. */ Write a merge record. */
static static
...@@ -750,7 +764,8 @@ row_merge_write_rec( ...@@ -750,7 +764,8 @@ row_merge_write_rec(
Copy it to the temporary buffer first. */ Copy it to the temporary buffer first. */
avail_size = block[1] - b; avail_size = block[1] - b;
row_merge_write_rec_low(buf[0], extra_size, mrec, offsets); row_merge_write_rec_low(buf[0],
extra_size, size, mrec, offsets);
/* Copy the head of the temporary buffer, write /* Copy the head of the temporary buffer, write
the completed block, and copy the tail of the the completed block, and copy the tail of the
...@@ -766,8 +781,8 @@ row_merge_write_rec( ...@@ -766,8 +781,8 @@ row_merge_write_rec(
memcpy(b, buf[0] + avail_size, size - avail_size); memcpy(b, buf[0] + avail_size, size - avail_size);
b += size - avail_size; b += size - avail_size;
} else { } else {
row_merge_write_rec_low(b, extra_size, mrec, offsets); row_merge_write_rec_low(b, extra_size, size, mrec, offsets);
b += rec_offs_size(offsets); b += size;
} }
return(b); return(b);
......
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