~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to server/field/date.h

  • Committer: Patrick Galbraith
  • Date: 2008-07-24 16:57:40 UTC
  • mto: (202.2.4 rename-mysql-to-drizzle)
  • mto: This revision was merged to the branch mainline in revision 212.
  • Revision ID: patg@ishvara-20080724165740-x58yw6zs6d9o17lf
Most everything working with client rename
mysqlslap test still fails... can't connect to the server

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* - mode: c++ c-basic-offset: 2; indent-tabs-mode: nil; -*-
 
1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
3
 *
4
4
 *  Copyright (C) 2008 MySQL
21
21
#ifndef DRIZZLE_SERVER_FIELD_NEW_DATE
22
22
#define DRIZZLE_SERVER_FIELD_NEW_DATE
23
23
 
 
24
#include "mysql_priv.h"
 
25
 
24
26
class Field_newdate :public Field_str {
25
27
public:
26
 
  Field_newdate(unsigned char *ptr_arg, unsigned char *null_ptr_arg, unsigned char null_bit_arg,
 
28
  Field_newdate(uchar *ptr_arg, uchar *null_ptr_arg, uchar null_bit_arg,
27
29
                enum utype unireg_check_arg, const char *field_name_arg,
28
 
                const CHARSET_INFO * const cs)
 
30
                CHARSET_INFO *cs)
29
31
    :Field_str(ptr_arg, 10, null_ptr_arg, null_bit_arg,
30
32
               unireg_check_arg, field_name_arg, cs)
31
33
    {}
32
34
  Field_newdate(bool maybe_null_arg, const char *field_name_arg,
33
 
                const CHARSET_INFO * const cs)
34
 
    :Field_str((unsigned char*) 0,10, maybe_null_arg ? (unsigned char*) "": 0,0,
 
35
                CHARSET_INFO *cs)
 
36
    :Field_str((uchar*) 0,10, maybe_null_arg ? (uchar*) "": 0,0,
35
37
               NONE, field_name_arg, cs) {}
36
 
  enum_field_types type() const { return DRIZZLE_TYPE_NEWDATE;}
37
 
  enum_field_types real_type() const { return DRIZZLE_TYPE_NEWDATE; }
 
38
  enum_field_types type() const { return MYSQL_TYPE_NEWDATE;}
 
39
  enum_field_types real_type() const { return MYSQL_TYPE_NEWDATE; }
38
40
  enum ha_base_keytype key_type() const { return HA_KEYTYPE_UINT24; }
39
41
  enum Item_result cmp_type () const { return INT_RESULT; }
40
 
  int  store(const char *to,uint32_t length, const CHARSET_INFO * const charset);
 
42
  int  store(const char *to,uint length,CHARSET_INFO *charset);
41
43
  int  store(double nr);
42
44
  int  store(int64_t nr, bool unsigned_val);
43
 
  int store_time(DRIZZLE_TIME *ltime, enum enum_drizzle_timestamp_type type);
 
45
  int store_time(MYSQL_TIME *ltime, timestamp_type type);
44
46
  int reset(void) { ptr[0]=ptr[1]=ptr[2]=0; return 0; }
45
47
  double val_real(void);
46
48
  int64_t val_int(void);
47
49
  String *val_str(String*,String *);
48
50
  bool send_binary(Protocol *protocol);
49
 
  int cmp(const unsigned char *,const unsigned char *);
50
 
  void sort_string(unsigned char *buff,uint32_t length);
 
51
  int cmp(const uchar *,const uchar *);
 
52
  void sort_string(uchar *buff,uint length);
51
53
  uint32_t pack_length() const { return 3; }
52
54
  void sql_type(String &str) const;
53
55
  bool can_be_compared_as_int64_t() const { return true; }
54
56
  bool zero_pack() const { return 1; }
55
 
  bool get_date(DRIZZLE_TIME *ltime,uint32_t fuzzydate);
56
 
  bool get_time(DRIZZLE_TIME *ltime);
 
57
  bool get_date(MYSQL_TIME *ltime,uint fuzzydate);
 
58
  bool get_time(MYSQL_TIME *ltime);
57
59
};
58
60
 
59
61
#endif