summaryrefslogtreecommitdiff
path: root/sql/log_event.cc
diff options
context:
space:
mode:
Diffstat (limited to 'sql/log_event.cc')
-rw-r--r--sql/log_event.cc158
1 files changed, 1 insertions, 157 deletions
diff --git a/sql/log_event.cc b/sql/log_event.cc
index d484ef55e5e..b67629a2c08 100644
--- a/sql/log_event.cc
+++ b/sql/log_event.cc
@@ -26,6 +26,7 @@
#include "rpl_mi.h"
#include "rpl_filter.h"
#include "rpl_utility.h"
+#include "rpl_record.h"
#include <my_dir.h>
#endif /* MYSQL_CLIENT */
#include <base64.h>
@@ -5811,163 +5812,6 @@ int Rows_log_event::do_add_row_data(byte *const row_data,
#endif
#if !defined(MYSQL_CLIENT) && defined(HAVE_REPLICATION)
-/*
- Unpack a row into table->record[0].
-
- SYNOPSIS
- unpack_row()
- rli Relay log info
- table Table to unpack into
- colcnt Number of columns to read from record
- row Packed row data
- cols Pointer to columns data to fill in
- row_end Pointer to variable that will hold the value of the
- one-after-end position for the row
- master_reclength
- Pointer to variable that will be set to the length of the
- record on the master side
- rw_set Pointer to bitmap that holds either the read_set or the
- write_set of the table
-
- DESCRIPTION
-
- The function will always unpack into the table->record[0]
- record. This is because there are too many dependencies on
- where the various member functions of Field and subclasses
- expect to write.
-
- The row is assumed to only consist of the fields for which the
- bitset represented by 'arr' and 'bits'; the other parts of the
- record are left alone.
-
- At most 'colcnt' columns are read: if the table is larger than
- that, the remaining fields are not filled in.
-
- RETURN VALUE
-
- Error code, or zero if no error. The following error codes can
- be returned:
-
- ER_NO_DEFAULT_FOR_FIELD
- Returned if one of the fields existing on the slave but not on
- the master does not have a default value (and isn't nullable)
- */
-static int
-unpack_row(RELAY_LOG_INFO const *rli,
- TABLE *table, uint const colcnt,
- char const *const row_data, MY_BITMAP const *cols,
- char const **const row_end, ulong *const master_reclength,
- MY_BITMAP* const rw_set, Log_event_type const event_type)
-{
- DBUG_ENTER("unpack_row");
- DBUG_ASSERT(row_data);
- my_size_t const master_null_byte_count= (bitmap_bits_set(cols) + 7) / 8;
- int error= 0;
-
- char const *null_ptr= row_data;
- char const *pack_ptr= row_data + master_null_byte_count;
-
- bitmap_clear_all(rw_set);
-
- empty_record(table);
-
- Field **const begin_ptr = table->field;
- Field **field_ptr;
- Field **const end_ptr= begin_ptr + colcnt;
-
- DBUG_ASSERT(null_ptr < row_data + master_null_byte_count);
-
- // Mask to mask out the correct bit among the null bits
- unsigned int null_mask= 1U;
- // The "current" null bits
- unsigned int null_bits= *null_ptr++;
- for (field_ptr= begin_ptr ; field_ptr < end_ptr ; ++field_ptr)
- {
- Field *const f= *field_ptr;
-
- /*
- No need to bother about columns that does not exist: they have
- gotten default values when being emptied above.
- */
- if (bitmap_is_set(cols, field_ptr - begin_ptr))
- {
- if ((null_mask & 0xFF) == 0)
- {
- DBUG_ASSERT(null_ptr < row_data + master_null_byte_count);
- null_mask= 1U;
- null_bits= *null_ptr++;
- }
-
- DBUG_ASSERT(null_mask & 0xFF); // One of the 8 LSB should be set
-
- /* Field...::unpack() cannot return 0 */
- DBUG_ASSERT(pack_ptr != NULL);
-
- if ((null_bits & null_mask) && f->maybe_null())
- f->set_null();
- else
- {
- f->set_notnull();
-
- /*
- We only unpack the field if it was non-null
- */
- pack_ptr= f->unpack(f->ptr, pack_ptr);
- }
-
- bitmap_set_bit(rw_set, f->field_index);
- null_mask <<= 1;
- }
- }
-
- /*
- We should now have read all the null bytes, otherwise something is
- really wrong.
- */
- DBUG_ASSERT(null_ptr == row_data + master_null_byte_count);
-
- *row_end = pack_ptr;
- if (master_reclength)
- {
- if (*field_ptr)
- *master_reclength = (*field_ptr)->ptr - (char*) table->record[0];
- else
- *master_reclength = table->s->reclength;
- }
-
- /*
- Set properties for remaining columns, if there are any. We let the
- corresponding bit in the write_set be set, to write the value if
- it was not there already. We iterate over all remaining columns,
- even if there were an error, to get as many error messages as
- possible. We are still able to return a pointer to the next row,
- so redo that.
-
- This generation of error messages is only relevant when inserting
- new rows.
- */
- for ( ; *field_ptr ; ++field_ptr)
- {
- uint32 const mask= NOT_NULL_FLAG | NO_DEFAULT_VALUE_FLAG;
- Field *const f= *field_ptr;
-
- if (event_type == WRITE_ROWS_EVENT &&
- ((*field_ptr)->flags & mask) == mask)
- {
- slave_print_msg(ERROR_LEVEL, rli, ER_NO_DEFAULT_FOR_FIELD,
- "Field `%s` of table `%s`.`%s` "
- "has no default value and cannot be NULL",
- (*field_ptr)->field_name, table->s->db.str,
- table->s->table_name.str);
- error = ER_NO_DEFAULT_FOR_FIELD;
- }
- else
- f->set_default();
- }
-
- DBUG_RETURN(error);
-}
-
int Rows_log_event::do_apply_event(RELAY_LOG_INFO const *rli)
{
DBUG_ENTER("Rows_log_event::do_apply_event(st_relay_log_info*)");