~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
 *
1999.6.1 by kalebral at gmail
update Copyright strings to a more common format to help with creating the master debian copyright file
4
 *  Copyright (C) 2009 Sun Microsystems, Inc.
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
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),
1900.3.1 by Andrew Hutchings
Add FLUSH GLOBAL STATUS; command
42
    flush_status(false),
43
    flush_global_status(false)
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
44
  {}
45
46
  bool execute();
47
48
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.
49
  bool flush_log;
50
  bool flush_tables;
51
  bool flush_tables_with_read_lock;
52
  bool flush_status;
1900.3.1 by Andrew Hutchings
Add FLUSH GLOBAL STATUS; command
53
  bool flush_global_status;
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.
54
55
public:
56
  void setFlushLog(bool f) { flush_log= f; }
57
  void setFlushTables(bool f) { flush_tables= f; }
58
  void setFlushTablesWithReadLock(bool f) {
59
    flush_tables= flush_tables_with_read_lock= f;
60
  }
61
  void setFlushStatus(bool f) { flush_status= f; }
1900.3.1 by Andrew Hutchings
Add FLUSH GLOBAL STATUS; command
62
  void setFlushGlobalStatus(bool f) { flush_global_status= f; }
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.
63
64
private:
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
65
66
  /**
67
   * Reload/resets privileges and the different caches.
68
   *
69
   * @note Depending on 'options', it may be very bad to write the
70
   * query to the binlog (e.g. FLUSH SLAVE); this is a
71
   * pointer where reloadCache() will put 0 if
72
   * it thinks we really should not write to the binlog.
73
   * Otherwise it will put 1.
74
   * 
75
   * @return Error status code
76
   * @retval 0 Ok
77
   * @retval !=0  Error; session->killed is set or session->is_error() is true
78
   */
79
  bool reloadCache();
80
};
81
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
82
} /* namespace statement */
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
83
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
84
} /* namespace drizzled */
1100.3.48 by Padraig O'Sullivan
Extracted the FLUSH command into its own class and implementation files.
85
86
#endif /* DRIZZLED_STATEMENT_FLUSH_H */