~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/field/size.h

[patch 125/129] Merge patch for revision 1943 from InnoDB SVN:
revno: 1943
revision-id: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6207
parent: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6202
committer: vasil
timestamp: Fri 2009-11-20 08:19:14 +0000
message:
  branches/zip: Merge r6198:6206 from branches/5.1:
  
  (r6203 was skipped as it is already in branches/zip)
  
    ------------------------------------------------------------------------
    r6200 | vasil | 2009-11-19 12:14:23 +0200 (Thu, 19 Nov 2009) | 4 lines
    Changed paths:
       M /branches/5.1/btr/btr0btr.c
    
    branches/5.1:
    
    White space fixup - indent under the opening (
    
    ------------------------------------------------------------------------
    r6203 | jyang | 2009-11-19 15:12:22 +0200 (Thu, 19 Nov 2009) | 8 lines
    Changed paths:
       M /branches/5.1/btr/btr0btr.c
    
    branches/5.1: Use btr_free_root() instead of fseg_free() for
    the fix of bug #48469, because fseg_free() is not defined
    in the zip branch. And we could save one mini-trasaction started
    by fseg_free().
    
    Approved by Marko.
    
    
    ------------------------------------------------------------------------
    r6205 | jyang | 2009-11-20 07:55:48 +0200 (Fri, 20 Nov 2009) | 11 lines
    Changed paths:
       M /branches/5.1/handler/ha_innodb.cc
    
    branches/5.1: Add a special case to handle the Duplicated Key error
    and return DB_ERROR instead. This is to avoid a possible SIGSEGV
    by mysql error handling re-entering the storage layer for dup key
    info without proper table handle.
    This is to prevent a server crash when error situation in bug
    #45961 "DDL on partitioned innodb tables leaves data dictionary
    in an inconsistent state" happens.
    
    rb://157 approved by Sunny Bains.
    
    
    ------------------------------------------------------------------------
    r6206 | jyang | 2009-11-20 09:38:43 +0200 (Fri, 20 Nov 2009) | 5 lines
    Changed paths:
       M /branches/5.1/handler/ha_innodb.cc
    
    branches/5.1: Fix a minor code formating issue for 
    the parenthesis iplacement of the if condition in
    rename_table().
    
    
    ------------------------------------------------------------------------
modified:
  handler/ha_innodb.cc           2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fhandler%2Fha_innodb.cc
diff:
=== modified file 'handler/ha_innodb.cc'

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 DRIZZLED_FIELD_SIZE_H
22
 
#define DRIZZLED_FIELD_SIZE_H
23
 
 
24
 
#include <drizzled/field/num.h>
25
 
 
26
 
namespace drizzled
27
 
{
28
 
namespace field
29
 
{
30
 
 
31
 
class Size :public Field_num {
32
 
public:
33
 
 
34
 
  using Field::val_int;
35
 
  using Field::val_str;
36
 
  using Field::cmp;
37
 
  using Field::store;
38
 
  using Field::pack;
39
 
  using Field::unpack;
40
 
 
41
 
  Size(unsigned char *ptr_arg, uint32_t len_arg,
42
 
        unsigned char *null_ptr_arg,
43
 
        unsigned char null_bit_arg,
44
 
        enum utype unireg_check_arg,
45
 
        const char *field_name_arg);
46
 
 
47
 
  Size(uint32_t len_arg,bool maybe_null_arg,
48
 
        const char *field_name_arg,
49
 
        bool unsigned_arg);
50
 
 
51
 
  enum Item_result result_type () const { return INT_RESULT; }
52
 
  enum_field_types type() const { return DRIZZLE_TYPE_LONGLONG;}
53
 
  enum ha_base_keytype key_type() const
54
 
  { return unsigned_flag ? HA_KEYTYPE_ULONGLONG : HA_KEYTYPE_LONGLONG; }
55
 
  int store(const char *to,uint32_t length, const CHARSET_INFO * const charset);
56
 
  int store(double nr);
57
 
  int store(int64_t nr, bool unsigned_val);
58
 
  int reset(void)
59
 
  {
60
 
    ptr[0]=ptr[1]=ptr[2]=ptr[3]=ptr[4]=ptr[5]=ptr[6]=ptr[7]=0;
61
 
    return 0;
62
 
  }
63
 
  double val_real(void) const;
64
 
  int64_t val_int(void) const;
65
 
  String *val_str(String*,String *) const;
66
 
  int cmp(const unsigned char *,const unsigned char *);
67
 
  void sort_string(unsigned char *buff,uint32_t length);
68
 
  uint32_t pack_length() const { return 8; }
69
 
  void sql_type(String &str) const;
70
 
  bool can_be_compared_as_int64_t() const { return true; }
71
 
  uint32_t max_display_length() { return MY_INT64_NUM_DECIMAL_DIGITS+1; } // +1 for sign
72
 
  virtual unsigned char *pack(unsigned char* to, const unsigned char *from,
73
 
                              uint32_t max_length,
74
 
                              bool low_byte_first);
75
 
 
76
 
  virtual const unsigned char *unpack(unsigned char* to, const unsigned char *from,
77
 
                                      uint32_t param_data,
78
 
                                      bool low_byte_first);
79
 
 
80
 
};
81
 
 
82
 
} /* namespace field */
83
 
} /* namespace drizzled */
84
 
 
85
 
#endif /* DRIZZLED_FIELD_SIZE_H */