~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/item/insert_value.cc

  • Committer: Brian Aker
  • Date: 2010-01-27 18:58:12 UTC
  • Revision ID: brian@gaz-20100127185812-n62n0vwetnx8jrjy
Remove dead code.

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) 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 "config.h"
 
21
#include <drizzled/error.h>
 
22
#include <drizzled/name_resolution_context.h>
 
23
#include <drizzled/table.h>
 
24
#include <drizzled/item/insert_value.h>
 
25
#include <drizzled/item/ref.h>
 
26
#include <drizzled/item/copy_string.h>
 
27
#include <drizzled/item/default_value.h>
 
28
#include <drizzled/field/null.h>
 
29
 
 
30
using namespace drizzled;
 
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*) memory::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());
 
77
    def_field->move_field_offset((ptrdiff_t)
 
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 */
 
86
    tmp_field= new Field_null(0, 0, field_arg->field->field_name, &my_charset_bin);
 
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