~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/item.cc

  • Committer: Brian Aker
  • Date: 2009-05-15 07:55:30 UTC
  • mfrom: (991.1.5 for-brian)
  • Revision ID: brian@gaz-20090515075530-ics1z7f23hrjy3av
MErge Stewart

Show diffs side-by-side

added added

removed removed

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