~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to server/field/new_date.h

  • Committer: Toru Maesaka
  • Date: 2008-07-18 07:38:40 UTC
  • mto: (202.1.1 toru)
  • mto: This revision was merged to the branch mainline in revision 204.
  • Revision ID: dev@torum.net-20080718073840-g2ssxjtk7uegna98
ripped out STRING and renamed new_decimal and new_date

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 MySQL
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; either version 2 of the License, or
9
 
 *  (at your option) any later version.
10
 
 *
11
 
 *  This program is distributed in the hope that it will be useful,
12
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 
 *  GNU General Public License for more details.
15
 
 *
16
 
 *  You should have received a copy of the GNU General Public License
17
 
 *  along with this program; if not, write to the Free Software
18
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19
 
 */
20
 
 
21
 
#ifndef DRIZZLE_SERVER_FIELD_NEW_DATE
22
 
#define DRIZZLE_SERVER_FIELD_NEW_DATE
23
 
 
24
 
#include "mysql_priv.h"
25
 
 
26
 
class Field_newdate :public Field_str {
27
 
public:
28
 
  Field_newdate(uchar *ptr_arg, uchar *null_ptr_arg, uchar null_bit_arg,
29
 
                enum utype unireg_check_arg, const char *field_name_arg,
30
 
                CHARSET_INFO *cs)
31
 
    :Field_str(ptr_arg, 10, null_ptr_arg, null_bit_arg,
32
 
               unireg_check_arg, field_name_arg, cs)
33
 
    {}
34
 
  Field_newdate(bool maybe_null_arg, const char *field_name_arg,
35
 
                CHARSET_INFO *cs)
36
 
    :Field_str((uchar*) 0,10, maybe_null_arg ? (uchar*) "": 0,0,
37
 
               NONE, field_name_arg, cs) {}
38
 
  enum_field_types type() const { return MYSQL_TYPE_NEWDATE;}
39
 
  enum_field_types real_type() const { return MYSQL_TYPE_NEWDATE; }
40
 
  enum ha_base_keytype key_type() const { return HA_KEYTYPE_UINT24; }
41
 
  enum Item_result cmp_type () const { return INT_RESULT; }
42
 
  int  store(const char *to,uint length,CHARSET_INFO *charset);
43
 
  int  store(double nr);
44
 
  int  store(int64_t nr, bool unsigned_val);
45
 
  int store_time(MYSQL_TIME *ltime, timestamp_type type);
46
 
  int reset(void) { ptr[0]=ptr[1]=ptr[2]=0; return 0; }
47
 
  double val_real(void);
48
 
  int64_t val_int(void);
49
 
  String *val_str(String*,String *);
50
 
  bool send_binary(Protocol *protocol);
51
 
  int cmp(const uchar *,const uchar *);
52
 
  void sort_string(uchar *buff,uint length);
53
 
  uint32 pack_length() const { return 3; }
54
 
  void sql_type(String &str) const;
55
 
  bool can_be_compared_as_int64_t() const { return true; }
56
 
  bool zero_pack() const { return 1; }
57
 
  bool get_date(MYSQL_TIME *ltime,uint fuzzydate);
58
 
  bool get_time(MYSQL_TIME *ltime);
59
 
};
60
 
 
61
 
#endif
62