~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/field/int64_t.h

Removed/replaced DBUG symbols and standardized TRUE/FALSE

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_INT_64_T
22
 
#define DRIZZLE_SERVER_FIELD_INT_64_T
23
 
 
24
 
class Field_int64_t :public Field_num {
25
 
public:
26
 
  Field_int64_t(unsigned char *ptr_arg, uint32_t len_arg, unsigned char *null_ptr_arg,
27
 
              unsigned char null_bit_arg,
28
 
              enum utype unireg_check_arg, const char *field_name_arg,
29
 
              bool zero_arg, bool unsigned_arg)
30
 
    :Field_num(ptr_arg, len_arg, null_ptr_arg, null_bit_arg,
31
 
               unireg_check_arg, field_name_arg,
32
 
               0, zero_arg,unsigned_arg)
33
 
    {}
34
 
  Field_int64_t(uint32_t len_arg,bool maybe_null_arg,
35
 
                 const char *field_name_arg,
36
 
                  bool unsigned_arg)
37
 
    :Field_num((unsigned char*) 0, len_arg, maybe_null_arg ? (unsigned char*) "": 0,0,
38
 
               NONE, field_name_arg,0,0,unsigned_arg)
39
 
    {}
40
 
  enum Item_result result_type () const { return INT_RESULT; }
41
 
  enum_field_types type() const { return DRIZZLE_TYPE_LONGLONG;}
42
 
  enum ha_base_keytype key_type() const
43
 
    { return unsigned_flag ? HA_KEYTYPE_ULONGLONG : HA_KEYTYPE_LONGLONG; }
44
 
  int store(const char *to,uint32_t length, const CHARSET_INFO * const charset);
45
 
  int store(double nr);
46
 
  int store(int64_t nr, bool unsigned_val);
47
 
  int reset(void)
48
 
  {
49
 
    ptr[0]=ptr[1]=ptr[2]=ptr[3]=ptr[4]=ptr[5]=ptr[6]=ptr[7]=0;
50
 
    return 0;
51
 
  }
52
 
  double val_real(void);
53
 
  int64_t val_int(void);
54
 
  String *val_str(String*,String *);
55
 
  bool send_binary(Protocol *protocol);
56
 
  int cmp(const unsigned char *,const unsigned char *);
57
 
  void sort_string(unsigned char *buff,uint32_t length);
58
 
  uint32_t pack_length() const { return 8; }
59
 
  void sql_type(String &str) const;
60
 
  bool can_be_compared_as_int64_t() const { return true; }
61
 
  uint32_t max_display_length() { return 20; }
62
 
  virtual unsigned char *pack(unsigned char* to, const unsigned char *from,
63
 
                      uint32_t max_length __attribute__((unused)),
64
 
                      bool low_byte_first __attribute__((unused)))
65
 
  {
66
 
    int64_t val;
67
 
#ifdef WORDS_BIGENDIAN
68
 
    if (table->s->db_low_byte_first)
69
 
      val = sint8korr(from);
70
 
    else
71
 
#endif
72
 
      int64_tget(val, from);
73
 
 
74
 
#ifdef WORDS_BIGENDIAN
75
 
    if (low_byte_first)
76
 
      int8store(to, val);
77
 
    else
78
 
#endif
79
 
      int64_tstore(to, val);
80
 
    return to + sizeof(val);
81
 
  }
82
 
 
83
 
  virtual const unsigned char *unpack(unsigned char* to, const unsigned char *from,
84
 
                              uint32_t param_data __attribute__((unused)),
85
 
                              bool low_byte_first __attribute__((unused)))
86
 
  {
87
 
    int64_t val;
88
 
#ifdef WORDS_BIGENDIAN
89
 
    if (low_byte_first)
90
 
      val = sint8korr(from);
91
 
    else
92
 
#endif
93
 
      int64_tget(val, from);
94
 
 
95
 
#ifdef WORDS_BIGENDIAN
96
 
    if (table->s->db_low_byte_first)
97
 
      int8store(to, val);
98
 
    else
99
 
#endif
100
 
      int64_tstore(to, val);
101
 
    return from + sizeof(val);
102
 
  }
103
 
};
104
 
 
105
 
#endif