~drizzle-trunk/drizzle/development

492.3.24 by Lee
more changes to move functions from item_func.cc/h to the functions directory
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 *
4
 *  Copyright (C) 2008 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; version 2 of the License.
9
 *
10
 *  This program is distributed in the hope that it will be useful,
11
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 *  GNU General Public License for more details.
14
 *
15
 *  You should have received a copy of the GNU General Public License
16
 *  along with this program; if not, write to the Free Software
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
 */
19
20
#ifndef DRIZZLED_FUNCTIONS_GET_SYSTEM_VAR_H
21
#define DRIZZLED_FUNCTIONS_GET_SYSTEM_VAR_H
22
23
#include <drizzled/functions/func.h> 
24
25
/* A system variable */
26
27
class Item_func_get_system_var :public Item_func
28
{
29
  sys_var *var;
30
  enum_var_type var_type;
31
  LEX_STRING component;
32
public:
33
  Item_func_get_system_var(sys_var *var_arg, enum_var_type var_type_arg,
34
                           LEX_STRING *component_arg, const char *name_arg,
35
                           size_t name_len_arg);
36
  bool fix_fields(Session *session, Item **ref);
37
  /*
38
    Stubs for pure virtual methods. Should never be called: this
39
    item is always substituted with a constant in fix_fields().
40
  */
41
  double val_real()         { assert(0); return 0.0; }
42
  int64_t val_int()        { assert(0); return 0; }
43
  String* val_str(String*)  { assert(0); return 0; }
44
  void fix_length_and_dec() { assert(0); }
45
  /* TODO: fix to support views */
46
  const char *func_name() const { return "get_system_var"; }
47
  /**
48
    Indicates whether this system variable is written to the binlog or not.
49
50
    Variables are written to the binlog as part of "status_vars" in
51
    Query_log_event, as an Intvar_log_event, or a Rand_log_event.
52
53
    @return true if the variable is written to the binlog, false otherwise.
54
  */
55
  bool is_written_to_binlog();
56
};
57
58
59
#endif /* DRIZZLED_FUNCTIONS_GET_SYSTEM_VAR_H */