summaryrefslogtreecommitdiff
path: root/sql
diff options
context:
space:
mode:
Diffstat (limited to 'sql')
-rw-r--r--sql/log_event.cc8
-rw-r--r--sql/rpl_utility.cc3
-rw-r--r--sql/rpl_utility.h4
3 files changed, 7 insertions, 8 deletions
diff --git a/sql/log_event.cc b/sql/log_event.cc
index 22b5a96753d..6f63d8bf718 100644
--- a/sql/log_event.cc
+++ b/sql/log_event.cc
@@ -6412,7 +6412,7 @@ const int Table_map_log_event::calc_field_metadata_size()
case MYSQL_TYPE_VARCHAR:
case MYSQL_TYPE_SET:
{
- size= size + sizeof(short int); // Store short int here.
+ size= size + 2; // Store short int here.
break;
}
default:
@@ -6515,7 +6515,7 @@ int Table_map_log_event::save_field_metadata()
{
char *ptr= (char *)&m_field_metadata[index];
int2store(ptr, m_table->s->field[i]->field_length);
- index= index + sizeof(short int);
+ index= index + 2;
break;
}
case MYSQL_TYPE_STRING:
@@ -6709,6 +6709,7 @@ Table_map_log_event::Table_map_log_event(const char *buf, uint event_len,
if (bytes_read < event_len)
{
m_field_metadata_size= net_field_length(&ptr_after_colcnt);
+ DBUG_ASSERT(m_field_metadata_size <= (m_colcnt * 2));
uint num_null_bytes= (m_colcnt + 7) / 8;
m_meta_memory= (uchar *)my_multi_malloc(MYF(MY_WME),
&m_null_bits, num_null_bytes,
@@ -6934,8 +6935,7 @@ bool Table_map_log_event::write_data_body(IO_CACHE *file)
Store the size of the field metadata.
*/
uchar mbuf[sizeof(m_field_metadata_size)];
- uchar *const mbuf_end= net_store_length(mbuf,
- (size_t) m_field_metadata_size);
+ uchar *const mbuf_end= net_store_length(mbuf, m_field_metadata_size);
return (my_b_safe_write(file, dbuf, sizeof(dbuf)) ||
my_b_safe_write(file, (const uchar*)m_dbnam, m_dblen+1) ||
diff --git a/sql/rpl_utility.cc b/sql/rpl_utility.cc
index 279575f33ce..40937e98b27 100644
--- a/sql/rpl_utility.cc
+++ b/sql/rpl_utility.cc
@@ -97,7 +97,7 @@ uint32 table_def::calc_field_size(uint col, uchar *master_data)
{
uint from_len= (m_field_metadata[col] >> 8U) & 0x00ff;
uint from_bit_len= m_field_metadata[col] & 0x00ff;
- DBUG_ASSERT(from_len >= 0 && from_bit_len >= 0 && from_bit_len <= 7);
+ DBUG_ASSERT(from_bit_len >= 0 && from_bit_len <= 7);
length= from_len + ((from_bit_len > 0) ? 1 : 0);
break;
}
@@ -121,7 +121,6 @@ uint32 table_def::calc_field_size(uint col, uchar *master_data)
default:
length= -1;
}
- DBUG_ASSERT(length >= 0);
return length;
}
diff --git a/sql/rpl_utility.h b/sql/rpl_utility.h
index c91113c9e2a..034b6e084af 100644
--- a/sql/rpl_utility.h
+++ b/sql/rpl_utility.h
@@ -123,7 +123,7 @@ public:
*/
char *ptr= (char *)&field_metadata[index];
m_field_metadata[i]= sint2korr(ptr);
- index= index + sizeof(short int);
+ index= index + 2;
break;
}
case MYSQL_TYPE_NEWDECIMAL:
@@ -238,7 +238,7 @@ public:
private:
ulong m_size; // Number of elements in the types array
field_type *m_type; // Array of type descriptors
- short int *m_field_metadata;
+ uint16 *m_field_metadata;
uchar *m_null_bits;
uchar *m_memory;
};