1
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2008 Sun Microsystems, Inc.
4
* Copyright (C) 2008 Sun Microsystems
6
6
* This program is free software; you can redistribute it and/or modify
7
7
* it under the terms of the GNU General Public License as published by
22
22
variables must declare the size_of() member function.
27
25
#ifndef DRIZZLED_FIELD_H
28
26
#define DRIZZLED_FIELD_H
30
28
#include "drizzled/sql_error.h"
31
#include "drizzled/type/decimal.h"
29
#include "drizzled/decimal.h"
32
30
#include "drizzled/key_map.h"
31
#include "drizzled/sql_bitmap.h"
33
32
#include "drizzled/sql_list.h"
34
33
#include "drizzled/structs.h"
35
34
#include "drizzled/charset_info.h"
36
35
#include "drizzled/item_result.h"
37
#include "drizzled/charset_info.h"
42
#include "drizzled/visibility.h"
51
47
#define ASSERT_COLUMN_MARKED_FOR_READ assert(!getTable() || (getTable()->read_set == NULL || isReadSet()))
52
48
#define ASSERT_COLUMN_MARKED_FOR_WRITE assert(!getTable() || (getTable()->write_set == NULL || isWriteSet()))
54
#define ASSERT_COLUMN_MARKED_FOR_READ assert(getTable())
55
#define ASSERT_COLUMN_MARKED_FOR_WRITE assert(getTable())
50
#define ASSERT_COLUMN_MARKED_FOR_READ
51
#define ASSERT_COLUMN_MARKED_FOR_WRITE
58
54
typedef struct st_typelib TYPELIB;
80
76
* The store_xxx() methods take various input and convert
81
77
* the input into the raw bytes stored in the ptr member variable.
83
class DRIZZLED_API Field
85
81
/* Prevent use of these */
86
82
Field(const Field&);
87
83
void operator=(Field &);
90
85
unsigned char *ptr; /**< Position to field in record. Stores raw field value */
91
86
unsigned char *null_ptr; /**< Byte where null_bit is */
147
141
utype unireg_check;
148
142
uint32_t field_length; /**< Length of this field in bytes */
151
bool isUnsigned() const
153
return flags & UNSIGNED_FLAG;
157
144
uint16_t field_index; /**< Index of this Field in Table::fields array */
161
uint16_t position() const
166
void setPosition(uint32_t arg)
171
145
unsigned char null_bit; /**< Bit used to test null bit */
173
147
If true, this field was created in create_tmp_field_from_item from a NULL
183
157
static void *operator new(size_t size, memory::Root *mem_root);
184
158
static void operator delete(void *, size_t)
186
static void operator delete(void *, memory::Root *)
189
161
Field(unsigned char *ptr_arg,
190
162
uint32_t length_arg,
193
165
utype unireg_check_arg,
194
166
const char *field_name_arg);
195
167
virtual ~Field() {}
197
bool hasDefault() const
199
return not (flags & NO_DEFAULT_VALUE_FLAG);
202
168
/* Store functions returns 1 on overflow and -1 on fatal error */
203
169
virtual int store(const char *to,
205
171
const CHARSET_INFO * const cs)=0;
206
172
virtual int store(double nr)=0;
207
173
virtual int store(int64_t nr, bool unsigned_val)=0;
208
virtual int store_decimal(const type::Decimal *d)=0;
209
int store_and_check(enum_check_fields check_level,
212
const CHARSET_INFO * const cs);
174
virtual int store_decimal(const my_decimal *d)=0;
175
int store(const char *to,
177
const CHARSET_INFO * const cs,
178
enum_check_fields check_level);
214
180
This is called when storing a date in a string.
217
183
Needs to be changed if/when we want to support different time formats.
219
virtual int store_time(type::Time <ime, type::timestamp_t t_type);
220
virtual double val_real()=0;
221
virtual int64_t val_int()=0;
222
virtual type::Decimal *val_decimal(type::Decimal *);
223
String *val_str_internal(String *str)
185
virtual int store_time(DRIZZLE_TIME *ltime, enum enum_drizzle_timestamp_type t_type);
186
virtual double val_real(void)=0;
187
virtual int64_t val_int(void)=0;
188
virtual my_decimal *val_decimal(my_decimal *);
189
inline String *val_str(String *str)
225
191
return val_str(str, str);
229
194
val_str(buf1, buf2) gets two buffers and should use them as follows:
230
195
if it needs a temp buffer to convert result to string - use buf1
238
203
This trickery is used to decrease a number of malloc calls.
240
205
virtual String *val_str(String*, String *)=0;
243
207
str_needs_quotes() returns true if the value returned by val_str() needs
244
208
to be quoted when used in constructing an SQL query.
247
211
virtual Item_result result_type () const=0;
248
212
virtual Item_result cmp_type () const { return result_type(); }
249
213
virtual Item_result cast_to_int_type () const { return result_type(); }
252
215
Check whether a field type can be partially indexed by a key.
295
258
virtual bool eq_def(Field *field);
297
virtual bool is_timestamp() const
303
261
* Returns size (in bytes) used to store field data in memory
304
262
* (i.e. it returns the maximum size of the field in a row of the table,
342
300
virtual uint32_t key_length() const;
343
301
virtual enum_field_types type() const =0;
344
302
virtual enum_field_types real_type() const;
345
virtual int cmp_max(const unsigned char *a, const unsigned char *b, uint32_t max_len);
303
inline int cmp(const unsigned char *str) { return cmp(ptr,str); }
304
virtual int cmp_max(const unsigned char *a, const unsigned char *b,
346
306
virtual int cmp(const unsigned char *,const unsigned char *)=0;
347
int cmp_internal(const unsigned char *str) { return cmp(ptr,str); }
348
307
virtual int cmp_binary(const unsigned char *a,const unsigned char *b,
349
308
uint32_t max_length=UINT32_MAX);
350
309
virtual int cmp_offset(uint32_t row_offset);
396
355
uint32_t new_null_bit);
397
356
/** This is used to generate a field in Table from TableShare */
398
357
Field *clone(memory::Root *mem_root, Table *new_table);
399
void move_field(unsigned char *ptr_arg,unsigned char *null_ptr_arg,unsigned char null_bit_arg)
358
inline void move_field(unsigned char *ptr_arg,unsigned char *null_ptr_arg,unsigned char null_bit_arg)
402
361
null_ptr= null_ptr_arg;
403
362
null_bit= null_bit_arg;
405
void move_field(unsigned char *ptr_arg) { ptr=ptr_arg; }
364
inline void move_field(unsigned char *ptr_arg) { ptr=ptr_arg; }
406
365
virtual void move_field_offset(ptrdiff_t ptr_diff)
408
367
ptr= ADD_TO_PTR(ptr,ptr_diff, unsigned char*);
478
437
return return_value;
481
String *val_str_internal(String *str, const unsigned char *new_ptr)
439
inline String *val_str(String *str, const unsigned char *new_ptr)
483
441
unsigned char *old_ptr= ptr;
484
442
ptr= const_cast<unsigned char*>(new_ptr);
485
val_str_internal(str);
591
549
return max_length;
594
uint32_t offset(const unsigned char *record)
552
inline uint32_t offset(const unsigned char *record)
596
554
return (uint32_t) (ptr - record);
598
556
void copy_from_tmp(int offset);
599
557
uint32_t fill_cache_field(CacheField *copy);
600
virtual bool get_date(type::Time <ime,uint32_t fuzzydate);
601
virtual bool get_time(type::Time <ime);
558
virtual bool get_date(DRIZZLE_TIME *ltime,uint32_t fuzzydate);
559
virtual bool get_time(DRIZZLE_TIME *ltime);
602
560
virtual const CHARSET_INFO *charset(void) const { return &my_charset_bin; }
603
561
virtual const CHARSET_INFO *sort_charset(void) const { return charset(); }
604
562
virtual bool has_charset(void) const { return false; }
650
608
void set_datetime_warning(DRIZZLE_ERROR::enum_warning_level,
651
drizzled::error_t code,
653
611
uint32_t str_len,
654
type::timestamp_t ts_type,
612
enum enum_drizzle_timestamp_type ts_type,
655
613
int cuted_increment);
657
615
Produce warning or note about integer datetime value saved into field.
670
628
void set_datetime_warning(DRIZZLE_ERROR::enum_warning_level,
671
drizzled::error_t code,
673
type::timestamp_t ts_type,
631
enum enum_drizzle_timestamp_type ts_type,
674
632
int cuted_increment);
676
634
Produce warning or note about double datetime data saved into field.
688
646
void set_datetime_warning(DRIZZLE_ERROR::enum_warning_level,
689
const drizzled::error_t code,
691
type::timestamp_t ts_type);
692
bool check_overflow(int op_result)
649
enum enum_drizzle_timestamp_type ts_type);
650
inline bool check_overflow(int op_result)
694
652
return (op_result == E_DEC_OVERFLOW);
724
682
value converted from val
726
int64_t convert_decimal2int64_t(const type::Decimal *val,
684
int64_t convert_decimal2int64_t(const my_decimal *val,
727
685
bool unsigned_flag,
729
687
/* The max. number of characters */
730
uint32_t char_length() const
688
inline uint32_t char_length() const
732
690
return field_length / charset()->mbmaxlen;
735
enum column_format_type column_format() const
693
inline enum column_format_type column_format() const
737
695
return (enum column_format_type)
738
696
((flags >> COLUMN_FORMAT_FLAGS) & COLUMN_FORMAT_MASK);
759
717
bool isWriteSet();
760
718
void setReadSet(bool arg= true);
761
719
void setWriteSet(bool arg= true);
765
void pack_num(uint64_t arg, unsigned char *destination= NULL);
766
void pack_num(uint32_t arg, unsigned char *destination= NULL);
767
uint64_t unpack_num(uint64_t &destination, const unsigned char *arg= NULL) const;
768
uint32_t unpack_num(uint32_t &destination, const unsigned char *arg= NULL) const;
771
std::ostream& operator<<(std::ostream& output, const Field &field);
773
722
} /* namespace drizzled */
775
724
/** @TODO Why is this in the middle of the file???*/
755
* A class for quick copying data to fields
757
class CopyField :public memory::SqlAlloc
760
Convenience definition of a copy function returned by
763
typedef void Copy_func(CopyField*);
764
Copy_func *get_copy_func(Field *to, Field *from);
766
unsigned char *from_ptr;
767
unsigned char *to_ptr;
768
unsigned char *from_null_ptr;
769
unsigned char *to_null_ptr;
773
uint32_t from_length;
777
String tmp; // For items
781
void set(Field *to,Field *from,bool save); // Field to field
782
void set(unsigned char *to,Field *from); // Field to string
783
void (*do_copy)(CopyField *);
784
void (*do_copy2)(CopyField *); // Used to handle null values
805
787
uint32_t pack_length_to_packflag(uint32_t type);
806
788
uint32_t calc_pack_length(enum_field_types type,uint32_t length);
807
789
int set_field_to_null(Field *field);