~drizzle-trunk/drizzle/development

642.1.11 by Lee
move functions from item.cc/item.h to item 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
#include <drizzled/server_includes.h>
21
#include CSTDINT_H
22
#include <drizzled/error.h>
23
#include <drizzled/name_resolution_context.h>
24
#include <drizzled/table.h>
25
#include <drizzled/item/insert_value.h>
642.1.24 by Lee
more header file cleanup
26
#include <drizzled/item/ref.h>
642.1.61 by Lee
more header file cleanup
27
#include <drizzled/item/copy_string.h>
1008.3.1 by Stewart Smith
move Item_default_value out into its own files under drizzled/item/ to make it easier to find and follow current convention
28
#include <drizzled/item/default_value.h>
642.1.11 by Lee
move functions from item.cc/item.h to item directory
29
#include <drizzled/field/null.h>
30
31
32
bool Item_insert_value::eq(const Item *item, bool binary_cmp) const
33
{
34
  return item->type() == INSERT_VALUE_ITEM &&
35
    ((Item_default_value *)item)->arg->eq(arg, binary_cmp);
36
}
37
38
bool Item_insert_value::fix_fields(Session *session, Item **)
39
{
40
  assert(fixed == 0);
41
  /* We should only check that arg is in first table */
42
  if (!arg->fixed)
43
  {
44
    bool res;
45
    TableList *orig_next_table= context->last_name_resolution_table;
46
    context->last_name_resolution_table= context->first_name_resolution_table;
47
    res= arg->fix_fields(session, &arg);
48
    context->last_name_resolution_table= orig_next_table;
49
    if (res)
50
      return true;
51
  }
52
53
  if (arg->type() == REF_ITEM)
54
  {
55
    Item_ref *ref= (Item_ref *)arg;
56
    if (ref->ref[0]->type() != FIELD_ITEM)
57
    {
58
      my_error(ER_BAD_FIELD_ERROR, MYF(0), "", "VALUES() function");
59
      return true;
60
    }
61
    arg= ref->ref[0];
62
  }
63
  /*
64
    According to our SQL grammar, VALUES() function can reference
65
    only to a column.
66
  */
67
  assert(arg->type() == FIELD_ITEM);
68
69
  Item_field *field_arg= (Item_field *)arg;
70
71
  if (field_arg->field->table->insert_values)
72
  {
73
    Field *def_field= (Field*) sql_alloc(field_arg->field->size_of());
74
    if (!def_field)
75
      return true;
76
    memcpy(def_field, field_arg->field, field_arg->field->size_of());
1122.2.12 by Monty Taylor
Removed the silly my_ptrdiff_t typedef.
77
    def_field->move_field_offset((ptrdiff_t)
642.1.11 by Lee
move functions from item.cc/item.h to item directory
78
                                 (def_field->table->insert_values -
79
                                  def_field->table->record[0]));
80
    set_field(def_field);
81
  }
82
  else
83
  {
84
    Field *tmp_field= field_arg->field;
85
    /* charset doesn't matter here, it's to avoid sigsegv only */
1119.9.12 by Jay Pipes
First phase removal of MTYP_TYPENR() macro. This removes the unireg_check argument for all Field types where it is irrelevant (everything but numeric types and timestamp.
86
    tmp_field= new Field_null(0, 0, field_arg->field->field_name, &my_charset_bin);
642.1.11 by Lee
move functions from item.cc/item.h to item directory
87
    if (tmp_field)
88
    {
89
      tmp_field->init(field_arg->field->table);
90
      set_field(tmp_field);
91
    }
92
  }
93
  return false;
94
}
95
96
97
void Item_insert_value::print(String *str, enum_query_type query_type)
98
{
99
  str->append(STRING_WITH_LEN("values("));
100
  arg->print(str, query_type);
101
  str->append(')');
102
}
103
104
105