~drizzle-trunk/drizzle/development

1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 *
4
 *  Copyright (C) 2009 Sun Microsystems
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_STATEMENT_FLUSH_H
22
#define DRIZZLED_STATEMENT_FLUSH_H
23
24
#include <drizzled/statement.h>
25
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
26
namespace drizzled
27
{
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
28
class Session;
29
30
namespace statement
31
{
32
33
class Flush : public Statement
34
{
35
public:
36
  Flush(Session *in_session)
37
    :
1315.2.17 by Stewart Smith
move FLUSH statement to use boolean values in statement::Flush instead of overloading Lex->type with REFRESH_STATUS and others.
38
    Statement(in_session),
39
    flush_log(false),
40
    flush_tables(false),
41
    flush_tables_with_read_lock(false),
42
    flush_status(false)
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
43
  {}
44
45
  bool execute();
46
47
private:
1315.2.17 by Stewart Smith
move FLUSH statement to use boolean values in statement::Flush instead of overloading Lex->type with REFRESH_STATUS and others.
48
  bool flush_log;
49
  bool flush_tables;
50
  bool flush_tables_with_read_lock;
51
  bool flush_status;
52
53
public:
54
  void setFlushLog(bool f) { flush_log= f; }
55
  void setFlushTables(bool f) { flush_tables= f; }
56
  void setFlushTablesWithReadLock(bool f) {
57
    flush_tables= flush_tables_with_read_lock= f;
58
  }
59
  void setFlushStatus(bool f) { flush_status= f; }
60
61
private:
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
62
63
  /**
64
   * Reload/resets privileges and the different caches.
65
   *
66
   * @note Depending on 'options', it may be very bad to write the
67
   * query to the binlog (e.g. FLUSH SLAVE); this is a
68
   * pointer where reloadCache() will put 0 if
69
   * it thinks we really should not write to the binlog.
70
   * Otherwise it will put 1.
71
   * 
72
   * @return Error status code
73
   * @retval 0 Ok
74
   * @retval !=0  Error; session->killed is set or session->is_error() is true
75
   */
76
  bool reloadCache();
77
};
78
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
79
} /* namespace statement */
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
80
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
81
} /* namespace drizzled */
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
82
83
#endif /* DRIZZLED_STATEMENT_FLUSH_H */