~drizzle-trunk/drizzle/development

2148.7.5 by Brian Aker
Move transactions out.
1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 *
4
 *  Copyright (C) 2011 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
#ifndef DRIZZLED_SESSION_TRANSACTIONS_H
22
#define DRIZZLED_SESSION_TRANSACTIONS_H
23
24
#include <deque>
25
26
namespace drizzled
27
{
28
29
class Session;
30
31
namespace session
32
{
33
34
/**
35
 * Structure used to manage "statement transactions" and
36
 * "normal transactions". In autocommit mode, the normal transaction is
37
 * equivalent to the statement transaction.
38
 *
39
 * Storage engines will be registered here when they participate in
40
 * a transaction. No engine is registered more than once.
41
 */
42
class Transactions {
43
public:
44
  Transactions() :
45
    savepoints(),
46
    all(),
47
    stmt(),
48
    xid_state()
49
  { }
50
51
  std::deque<NamedSavepoint> savepoints;
52
53
  /**
54
   * The normal transaction (since BEGIN WORK).
55
   *
56
   * Contains a list of all engines that have participated in any of the
57
   * statement transactions started within the context of the normal
58
   * transaction.
59
   *
60
   * @note In autocommit mode, this is empty.
61
   */
62
  TransactionContext all;
63
64
  /**
65
   * The statment transaction.
66
   *
67
   * Contains a list of all engines participating in the given statement.
68
   *
69
   * @note In autocommit mode, this will be used to commit/rollback the
70
   * normal transaction.
71
   */
72
  TransactionContext stmt;
73
74
  XID_STATE xid_state;
75
76
  void cleanup()
77
  {
78
    savepoints.clear();
79
  }
80
};
81
82
} /* namespace session */
83
} /* namespace drizzled */
84
85
#endif /* DRIZZLED_SESSION_TRANSACTIONS_H */