~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/statement/flush.cc

  • Committer: Brian Aker
  • Date: 2009-02-21 00:18:15 UTC
  • Revision ID: brian@tangent.org-20090221001815-x20e8h71e984lvs1
Completion (?) of uint conversion.

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) 2009 Sun Microsystems, Inc.
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 <drizzled/show.h>
24
 
#include <drizzled/session.h>
25
 
#include <drizzled/lock.h>
26
 
#include <drizzled/statement/flush.h>
27
 
#include "drizzled/sql_table.h"
28
 
#include "drizzled/plugin/logging.h"
29
 
#include "drizzled/plugin/storage_engine.h"
30
 
 
31
 
namespace drizzled
32
 
{
33
 
 
34
 
bool statement::Flush::execute()
35
 
{
36
 
  /*
37
 
   * reloadCache() will tell us if we are allowed to write to the
38
 
   * binlog or not.
39
 
   */
40
 
  if (not reloadCache())
41
 
  {
42
 
    /*
43
 
     * We WANT to write and we CAN write.
44
 
     * ! we write after unlocking the table.
45
 
     *
46
 
     * Presumably, RESET and binlog writing doesn't require synchronization
47
 
     */
48
 
    write_bin_log(getSession(), *getSession()->getQueryString());
49
 
    getSession()->my_ok();
50
 
  }
51
 
 
52
 
  return false;
53
 
}
54
 
 
55
 
bool statement::Flush::reloadCache()
56
 
{
57
 
  bool result= false;
58
 
  TableList *tables= (TableList *) getSession()->lex->select_lex.table_list.first;
59
 
 
60
 
  if (flush_log)
61
 
  {
62
 
    if (plugin::StorageEngine::flushLogs(NULL))
63
 
    {
64
 
      result= true;
65
 
    }
66
 
  }
67
 
  /*
68
 
    Note that if REFRESH_READ_LOCK bit is set then REFRESH_TABLES is set too
69
 
    (see sql_yacc.yy)
70
 
  */
71
 
  if (flush_tables || flush_tables_with_read_lock)
72
 
  {
73
 
    if (getSession() && flush_tables_with_read_lock)
74
 
    {
75
 
      if (getSession()->lockGlobalReadLock())
76
 
      {
77
 
        return true; /* Killed */
78
 
      }
79
 
      result= getSession()->close_cached_tables(tables, true, true);
80
 
 
81
 
      if (getSession()->makeGlobalReadLockBlockCommit()) /* Killed */
82
 
      {
83
 
        /* Don't leave things in a half-locked state */
84
 
        getSession()->unlockGlobalReadLock();
85
 
        return true;
86
 
      }
87
 
    }
88
 
    else
89
 
    {
90
 
      result= getSession()->close_cached_tables(tables, true, false);
91
 
    }
92
 
  }
93
 
 
94
 
  if (getSession() && flush_status)
95
 
  {
96
 
    getSession()->refresh_status();
97
 
  }
98
 
 
99
 
  if (getSession() && flush_global_status)
100
 
  {
101
 
    memset(&current_global_counters, 0, sizeof(current_global_counters));
102
 
    plugin::Logging::resetStats(getSession());
103
 
    getSession()->refresh_status();
104
 
  }
105
 
 
106
 
  return result;
107
 
}
108
 
 
109
 
}