diff options
author | Luis Soares <luis.soares@oracle.com> | 2010-10-13 11:08:39 +0100 |
---|---|---|
committer | Luis Soares <luis.soares@oracle.com> | 2010-10-13 11:08:39 +0100 |
commit | e760a4d8ab820e5072149b2c1e86bb0a42f85171 (patch) | |
tree | 90e5328b77e8ac5eaa6a6938d7004247e331c7b7 /sql/log_event.cc | |
parent | 609bc2c4077f4c1244763a796aa52a5d9d363e15 (diff) | |
parent | 54c308d37d4c1485cacc204ce845b665dc981579 (diff) | |
download | mariadb-git-e760a4d8ab820e5072149b2c1e86bb0a42f85171.tar.gz |
Automerge from mysql-5.1-bugteam into mysql-5.5-bugteam.
Diffstat (limited to 'sql/log_event.cc')
-rw-r--r-- | sql/log_event.cc | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/sql/log_event.cc b/sql/log_event.cc index bfcac10e138..2a54d80178c 100644 --- a/sql/log_event.cc +++ b/sql/log_event.cc @@ -1244,7 +1244,7 @@ Log_event* Log_event::read_log_event(const char* buf, uint event_len, break; #ifdef HAVE_REPLICATION case SLAVE_EVENT: /* can never happen (unused event) */ - ev = new Slave_log_event(buf, event_len); + ev = new Slave_log_event(buf, event_len, description_event); break; #endif /* HAVE_REPLICATION */ case CREATE_FILE_EVENT: @@ -1332,8 +1332,10 @@ Log_event* Log_event::read_log_event(const char* buf, uint event_len, (because constructor is "void") ; so instead we leave the pointer we wanted to allocate (e.g. 'query') to 0 and we test it in is_valid(). Same for Format_description_log_event, member 'post_header_len'. + + SLAVE_EVENT is never used, so it should not be read ever. */ - if (!ev || !ev->is_valid()) + if (!ev || !ev->is_valid() || (event_type == SLAVE_EVENT)) { DBUG_PRINT("error",("Found invalid event in binary log")); @@ -6117,8 +6119,12 @@ void Slave_log_event::init_from_mem_pool(int data_size) /** This code is not used, so has not been updated to be format-tolerant. */ -Slave_log_event::Slave_log_event(const char* buf, uint event_len) - :Log_event(buf,0) /*unused event*/ ,mem_pool(0),master_host(0) +/* We are using description_event so that slave does not crash on Log_event + constructor */ +Slave_log_event::Slave_log_event(const char* buf, + uint event_len, + const Format_description_log_event* description_event) + :Log_event(buf,description_event),mem_pool(0),master_host(0) { if (event_len < LOG_EVENT_HEADER_LEN) return; |