summaryrefslogtreecommitdiff
path: root/sql/wsrep_applier.h
blob: a8da2acbb9a3a8f7b6aa81892286801fae9fc53f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* Copyright 2013-2015 Codership Oy <http://www.codership.com>

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; version 2 of the License.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA */

#ifndef WSREP_APPLIER_H
#define WSREP_APPLIER_H

#include <my_config.h>

#include "sql_class.h" // THD class

int wsrep_apply_events(THD*        thd,
                       Relay_log_info* rli,
                       const void* events_buf,
                       size_t      buf_len);


/* Applier error codes, when nothing better is available. */
#define WSREP_RET_SUCCESS      0 // Success
#define WSREP_ERR_GENERIC      1 // When in doubt (MySQL default error code)
#define WSREP_ERR_BAD_EVENT    2 // Can't parse event
#define WSREP_ERR_NOT_FOUND    3 // Key. table, schema not found
#define WSREP_ERR_EXISTS       4 // Key, table, schema already exists
#define WSREP_ERR_WRONG_TYPE   5 // Incompatible data type
#define WSREP_ERR_FAILED       6 // Operation failed for some internal reason
#define WSREP_ERR_ABORTED      7 // Operation was aborted externally

class wsrep_apply_error
{
public:
  wsrep_apply_error() : str_(NULL), len_(0) {};
  ~wsrep_apply_error() { ::free(str_); }
  /* stores the current THD error info from the diagnostic area. Works only
   * once, subsequent invocations are ignored in order to preserve the original
   * condition. */
  void store(const THD* thd);
  const char* c_str() const { return str_; }
  size_t length() const { return len_; }
  bool is_null() const { return (c_str() == NULL && length() == 0); }
  wsrep_buf_t get_buf() const
  {
    wsrep_buf_t ret= { c_str(), length() };
    return ret;
  }
private:
  char*  str_;
  size_t len_;
};

class Format_description_log_event;
void wsrep_set_apply_format(THD*, Format_description_log_event*);
Format_description_log_event* wsrep_get_apply_format(THD* thd);
int wsrep_apply(void*                   ctx,
                uint32_t                flags,
                const wsrep_buf_t*      buf,
                const wsrep_trx_meta_t* meta,
                wsrep_apply_error&      err);

wsrep_cb_status_t wsrep_unordered_cb(void*              ctx,
                                     const wsrep_buf_t* data);

#endif /* WSREP_APPLIER_H */