~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/item.cc

  • Committer: Stewart Smith
  • Date: 2009-05-14 07:17:50 UTC
  • mto: (991.1.5 for-brian)
  • mto: This revision was merged to the branch mainline in revision 1022.
  • Revision ID: stewart@flamingspork.com-20090514071750-cr9loc247jn9gvqj
move Item_default_value out into its own files under drizzled/item/ to make it easier to find and follow current convention

Show diffs side-by-side

added added

removed removed

Lines of Context:
1635
1635
  return result;
1636
1636
}
1637
1637
 
1638
 
 
1639
 
bool Item_default_value::eq(const Item *item, bool binary_cmp) const
1640
 
{
1641
 
  return item->type() == DEFAULT_VALUE_ITEM &&
1642
 
    ((Item_default_value *)item)->arg->eq(arg, binary_cmp);
1643
 
}
1644
 
 
1645
 
 
1646
 
bool Item_default_value::fix_fields(Session *session, Item **)
1647
 
{
1648
 
  Item *real_arg;
1649
 
  Item_field *field_arg;
1650
 
  Field *def_field;
1651
 
  assert(fixed == 0);
1652
 
 
1653
 
  if (!arg)
1654
 
  {
1655
 
    fixed= 1;
1656
 
    return false;
1657
 
  }
1658
 
  if (!arg->fixed && arg->fix_fields(session, &arg))
1659
 
    goto error;
1660
 
 
1661
 
 
1662
 
  real_arg= arg->real_item();
1663
 
  if (real_arg->type() != FIELD_ITEM)
1664
 
  {
1665
 
    my_error(ER_NO_DEFAULT_FOR_FIELD, MYF(0), arg->name);
1666
 
    goto error;
1667
 
  }
1668
 
 
1669
 
  field_arg= (Item_field *)real_arg;
1670
 
  if (field_arg->field->flags & NO_DEFAULT_VALUE_FLAG)
1671
 
  {
1672
 
    my_error(ER_NO_DEFAULT_FOR_FIELD, MYF(0), field_arg->field->field_name);
1673
 
    goto error;
1674
 
  }
1675
 
  if (!(def_field= (Field*) sql_alloc(field_arg->field->size_of())))
1676
 
    goto error;
1677
 
  memcpy(def_field, field_arg->field, field_arg->field->size_of());
1678
 
  def_field->move_field_offset((my_ptrdiff_t)
1679
 
                               (def_field->table->s->default_values -
1680
 
                                def_field->table->record[0]));
1681
 
  set_field(def_field);
1682
 
  return false;
1683
 
 
1684
 
error:
1685
 
  context->process_error(session);
1686
 
  return true;
1687
 
}
1688
 
 
1689
 
 
1690
 
void Item_default_value::print(String *str, enum_query_type query_type)
1691
 
{
1692
 
  if (!arg)
1693
 
  {
1694
 
    str->append(STRING_WITH_LEN("default"));
1695
 
    return;
1696
 
  }
1697
 
  str->append(STRING_WITH_LEN("default("));
1698
 
  arg->print(str, query_type);
1699
 
  str->append(')');
1700
 
}
1701
 
 
1702
 
 
1703
 
int Item_default_value::save_in_field(Field *field_arg, bool no_conversions)
1704
 
{
1705
 
  if (!arg)
1706
 
  {
1707
 
    if (field_arg->flags & NO_DEFAULT_VALUE_FLAG)
1708
 
    {
1709
 
      if (field_arg->reset())
1710
 
      {
1711
 
        my_message(ER_CANT_CREATE_GEOMETRY_OBJECT,
1712
 
                   ER(ER_CANT_CREATE_GEOMETRY_OBJECT), MYF(0));
1713
 
        return -1;
1714
 
      }
1715
 
 
1716
 
      {
1717
 
        push_warning_printf(field_arg->table->in_use,
1718
 
                            DRIZZLE_ERROR::WARN_LEVEL_WARN,
1719
 
                            ER_NO_DEFAULT_FOR_FIELD,
1720
 
                            ER(ER_NO_DEFAULT_FOR_FIELD),
1721
 
                            field_arg->field_name);
1722
 
      }
1723
 
      return 1;
1724
 
    }
1725
 
    field_arg->set_default();
1726
 
    return 0;
1727
 
  }
1728
 
  return Item_field::save_in_field(field_arg, no_conversions);
1729
 
}
1730
 
 
1731
 
 
1732
 
/**
1733
 
  This method like the walk method traverses the item tree, but at the
1734
 
  same time it can replace some nodes in the tree.
1735
 
*/
1736
 
 
1737
 
Item *Item_default_value::transform(Item_transformer transformer, unsigned char *args)
1738
 
{
1739
 
  Item *new_item= arg->transform(transformer, args);
1740
 
  if (!new_item)
1741
 
    return NULL;
1742
 
 
1743
 
  /*
1744
 
    Session::change_item_tree() should be called only if the tree was
1745
 
    really transformed, i.e. when a new item has been created.
1746
 
    Otherwise we'll be allocating a lot of unnecessary memory for
1747
 
    change records at each execution.
1748
 
  */
1749
 
  if (arg != new_item)
1750
 
    current_session->change_item_tree(&arg, new_item);
1751
 
  return (this->*transformer)(args);
1752
 
}
1753
 
 
1754
1638
Item_result item_cmp_type(Item_result a,Item_result b)
1755
1639
{
1756
1640
  if (a == STRING_RESULT && b == STRING_RESULT)