1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2010 Brian Aker
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; either version 2 of the License, or
9
* (at your option) any later version.
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, write to the Free Software
18
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23
#include "replication_dictionary.h"
24
#include "drizzled/current_session.h"
29
#include "os0thread.h"
30
#include "srv0start.h"
37
#include "row0mysql.h"
41
#include "lock0lock.h"
42
#include "dict0crea.h"
46
#include "sync0sync.h"
49
#include "row0merge.h"
51
#include "dict0boot.h"
52
#include "ha_prototypes.h"
54
#include "ibuf0ibuf.h"
55
#include "create_replication.h"
56
#include "read_replication.h"
57
#include "handler0vars.h"
59
#include "drizzled/drizzled.h"
61
#include "drizzled/replication_services.h"
63
#include <google/protobuf/io/zero_copy_stream.h>
64
#include <google/protobuf/io/zero_copy_stream_impl.h>
65
#include <google/protobuf/io/coded_stream.h>
66
#include <google/protobuf/text_format.h>
69
using namespace drizzled;
72
* Fill the dynamic table data_dictionary.INNODB_CMP and INNODB_CMP_RESET
75
InnodbReplicationTable::InnodbReplicationTable() :
76
plugin::TableFunction("DATA_DICTIONARY", "INNODB_REPLICATION_LOG")
78
add_field("TRANSACTION_ID", plugin::TableFunction::NUMBER, 0, false);
79
add_field("TRANSACTION_SEGMENT_ID", plugin::TableFunction::NUMBER, 0, false);
80
add_field("COMMIT_ID", plugin::TableFunction::NUMBER, 0, false);
81
add_field("END_TIMESTAMP", plugin::TableFunction::NUMBER, 0, false);
82
add_field("TRANSACTION_MESSAGE_STRING", plugin::TableFunction::STRING, transaction_message_threshold, false);
83
add_field("TRANSACTION_LENGTH", plugin::TableFunction::NUMBER, 0, false);
86
InnodbReplicationTable::Generator::Generator(Field **arg) :
87
plugin::TableFunction::Generator(arg)
89
replication_state =replication_read_init();
92
InnodbReplicationTable::Generator::~Generator()
94
replication_read_deinit(replication_state);
97
bool InnodbReplicationTable::Generator::populate()
99
struct read_replication_return_st ret= replication_read_next(replication_state);
101
if (ret.message == NULL)
105
push(static_cast<uint64_t>(ret.id));
108
push(static_cast<uint64_t>(ret.seg_id));
110
push(static_cast<uint64_t>(ret.commit_id));
112
push(static_cast<uint64_t>(ret.end_timestamp));
114
/* Message in viewable format */
115
bool result= message.ParseFromArray(ret.message, ret.message_length);
119
fprintf(stderr, _("Unable to parse transaction. Got error: %s.\n"), message.InitializationErrorString().c_str());
124
google::protobuf::TextFormat::PrintToString(message, &transaction_text);
125
push(transaction_text);
128
push(static_cast<int64_t>(ret.message_length));