~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/innobase/handler/replication_dictionary.cc

  • Committer: Lee Bieber
  • Date: 2010-11-14 23:15:42 UTC
  • mfrom: (1929.1.42 warning-stack-frame)
  • Revision ID: kalebral@gmail.com-20101114231542-fnnu6ydd2p17n582
Merge Monty - fix bug 672372: some functions use > 32k stack

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 * vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 *  Copyright (C) 2010 Brian Aker
5
 
 *
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.
10
 
 *
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.
15
 
 *
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
19
 
 */
20
 
 
21
 
#include "config.h"
22
 
 
23
 
#include "replication_dictionary.h"
24
 
#include "drizzled/current_session.h"
25
 
 
26
 
#include "univ.i"
27
 
#include "btr0sea.h"
28
 
#include "os0file.h"
29
 
#include "os0thread.h"
30
 
#include "srv0start.h"
31
 
#include "srv0srv.h"
32
 
#include "trx0roll.h"
33
 
#include "trx0trx.h"
34
 
#include "trx0sys.h"
35
 
#include "mtr0mtr.h"
36
 
#include "row0ins.h"
37
 
#include "row0mysql.h"
38
 
#include "row0sel.h"
39
 
#include "row0upd.h"
40
 
#include "log0log.h"
41
 
#include "lock0lock.h"
42
 
#include "dict0crea.h"
43
 
#include "btr0cur.h"
44
 
#include "btr0btr.h"
45
 
#include "fsp0fsp.h"
46
 
#include "sync0sync.h"
47
 
#include "fil0fil.h"
48
 
#include "trx0xa.h"
49
 
#include "row0merge.h"
50
 
#include "thr0loc.h"
51
 
#include "dict0boot.h"
52
 
#include "ha_prototypes.h"
53
 
#include "ut0mem.h"
54
 
#include "ibuf0ibuf.h"
55
 
#include "create_replication.h"
56
 
#include "read_replication.h"
57
 
#include "handler0vars.h"
58
 
 
59
 
#include "drizzled/drizzled.h"
60
 
 
61
 
#include "drizzled/replication_services.h"
62
 
 
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>
67
 
#include <string>
68
 
 
69
 
using namespace drizzled;
70
 
 
71
 
/*
72
 
 * Fill the dynamic table data_dictionary.INNODB_CMP and INNODB_CMP_RESET
73
 
 *
74
 
 */
75
 
InnodbReplicationTable::InnodbReplicationTable() :
76
 
  plugin::TableFunction("DATA_DICTIONARY", "INNODB_REPLICATION_LOG")
77
 
{
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);
84
 
}
85
 
 
86
 
InnodbReplicationTable::Generator::Generator(Field **arg) :
87
 
  plugin::TableFunction::Generator(arg)
88
 
{
89
 
  replication_state =replication_read_init();
90
 
}
91
 
 
92
 
InnodbReplicationTable::Generator::~Generator()
93
 
{
94
 
  replication_read_deinit(replication_state);
95
 
}
96
 
 
97
 
bool InnodbReplicationTable::Generator::populate()
98
 
{
99
 
  struct read_replication_return_st ret= replication_read_next(replication_state);
100
 
 
101
 
  if (ret.message == NULL)
102
 
    return false;
103
 
 
104
 
  /* Transaction ID */
105
 
  push(static_cast<uint64_t>(ret.id));
106
 
 
107
 
  /* Segment ID */
108
 
  push(static_cast<uint64_t>(ret.seg_id));
109
 
 
110
 
  push(static_cast<uint64_t>(ret.commit_id));
111
 
 
112
 
  push(static_cast<uint64_t>(ret.end_timestamp));
113
 
  
114
 
  /* Message in viewable format */
115
 
  bool result= message.ParseFromArray(ret.message, ret.message_length);
116
 
 
117
 
  if (result == false)
118
 
  {
119
 
    fprintf(stderr, _("Unable to parse transaction. Got error: %s.\n"), message.InitializationErrorString().c_str());
120
 
    push("error");
121
 
  }
122
 
  else
123
 
  {
124
 
    google::protobuf::TextFormat::PrintToString(message, &transaction_text);
125
 
    push(transaction_text);
126
 
  }
127
 
 
128
 
  push(static_cast<int64_t>(ret.message_length));
129
 
 
130
 
  return true;
131
 
}