~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/base.h

  • Committer: Brian Aker
  • Date: 2009-07-11 19:23:04 UTC
  • mfrom: (1089.1.14 merge)
  • Revision ID: brian@gaz-20090711192304-ootijyl5yf9jq9kd
Merge Brian

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* Copyright (C) 2000 MySQL AB
2
 
 
3
 
   This program is free software; you can redistribute it and/or modify
4
 
   it under the terms of the GNU General Public License as published by
5
 
   the Free Software Foundation; version 2 of the License.
6
 
 
7
 
   This program is distributed in the hope that it will be useful,
8
 
   but WITHOUT ANY WARRANTY; without even the implied warranty of
9
 
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10
 
   GNU General Public License for more details.
11
 
 
12
 
   You should have received a copy of the GNU General Public License
13
 
   along with this program; if not, write to the Free Software
14
 
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
 
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
 
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
 
3
 *
 
4
 *  Copyright (C) 2008 Sun Microsystems
 
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; version 2 of the License.
 
9
 *
 
10
 *  This program is distributed in the hope that it will be useful,
 
11
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
 *  GNU General Public License for more details.
 
14
 *
 
15
 *  You should have received a copy of the GNU General Public License
 
16
 *  along with this program; if not, write to the Free Software
 
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
18
 */
15
19
 
16
20
/* This file includes constants used with all databases */
17
21
 
18
 
/** 
19
 
 * @TODO Name this file something better and split it out if necessary.  
20
 
 * base.h isn't descriptive, especially compared to global.h 
 
22
/**
 
23
 * @TODO Name this file something better and split it out if necessary.
 
24
 * base.h isn't descriptive, especially compared to global.h
21
25
 *
22
26
 * @TODO Convert HA_XXX defines into enums and/or bitmaps
23
27
 */
25
29
#ifndef DRIZZLE_SERVER_BASE_H
26
30
#define DRIZZLE_SERVER_BASE_H
27
31
 
28
 
#ifndef stdin                           /* Included first in handler */
29
32
#define CHSIZE_USED
30
 
#include <drizzled/global.h>
31
 
#include <mysys/my_dir.h>               /* This includes types */
32
 
#include <mysys/my_sys.h>
33
 
#include <mystrings/m_string.h>
34
 
#include <errno.h>
35
 
 
36
 
#ifndef EOVERFLOW
37
 
#define EOVERFLOW 84
38
 
#endif
39
 
 
40
 
#endif  /* stdin */
41
 
#include <mysys/my_list.h>
42
33
 
43
34
/* The following is bits in the flag parameter to ha_open() */
44
35
 
104
95
 
105
96
        /* Index and table build methods */
106
97
 
107
 
enum ha_build_method { 
108
 
  HA_BUILD_DEFAULT, 
 
98
enum ha_build_method {
 
99
  HA_BUILD_DEFAULT,
109
100
  HA_BUILD_ONLINE,
110
 
  HA_BUILD_OFFLINE 
 
101
  HA_BUILD_OFFLINE
111
102
};
112
103
 
113
104
        /* The following is parameter to ha_extra() */
150
141
  HA_EXTRA_CHANGE_KEY_TO_UNIQUE,
151
142
  HA_EXTRA_CHANGE_KEY_TO_DUP,
152
143
  /*
153
 
    When using HA_EXTRA_KEYREAD, overwrite only key member fields and keep 
 
144
    When using HA_EXTRA_KEYREAD, overwrite only key member fields and keep
154
145
    other fields intact. When this is off (by default) InnoDB will use memcpy
155
146
    to overwrite entire row.
156
147
  */
176
167
  HA_EXTRA_WRITE_CANNOT_REPLACE,
177
168
  /*
178
169
    Inform handler that delete_row()/update_row() cannot batch deletes/updates
179
 
    and should perform them immediately. This may be needed when table has 
 
170
    and should perform them immediately. This may be needed when table has
180
171
    AFTER DELETE/UPDATE triggers which access to subject table.
181
172
    These flags are reset by the handler::extra(HA_EXTRA_RESET) call.
182
173
  */
254
245
#define HA_VAR_LENGTH_KEY        8
255
246
#define HA_NULL_PART_KEY         64
256
247
#define HA_USES_COMMENT          4096
257
 
#define HA_USES_BLOCK_SIZE       ((uint) 32768)
 
248
#define HA_USES_BLOCK_SIZE       ((uint32_t) 32768)
258
249
#define HA_SORT_ALLOWS_SAME      512    /* Intern bit when sorting records */
259
250
 
260
251
        /* These flags can be added to key-seg-flag */
287
278
#define HA_OPTION_RELIES_ON_SQL_LAYER   512
288
279
#define HA_OPTION_NULL_FIELDS           1024
289
280
#define HA_OPTION_PAGE_CHECKSUM         2048
290
 
#define HA_OPTION_TEMP_COMPRESS_RECORD  ((uint) 16384)  /* set by isamchk */
291
 
#define HA_OPTION_READ_ONLY_DATA        ((uint) 32768)  /* Set by isamchk */
 
281
#define HA_OPTION_TEMP_COMPRESS_RECORD  ((uint32_t) 16384)      /* set by isamchk */
 
282
#define HA_OPTION_READ_ONLY_DATA        ((uint32_t) 32768)      /* Set by isamchk */
292
283
 
293
284
        /* Bits in flag to create() */
294
285
 
433
424
        /* Other constants */
434
425
 
435
426
#define HA_NAMELEN 64                   /* Max length of saved filename */
436
 
#define NO_SUCH_KEY (~(uint)0)          /* used as a key no. */
 
427
#define NO_SUCH_KEY (~(uint32_t)0)          /* used as a key no. */
437
428
 
438
429
typedef ulong key_part_map;
439
430
#define HA_WHOLE_KEY  (~(key_part_map)0)
508
499
/* X > key, i.e. not including the right endpoint */
509
500
#define NEAR_MAX        8
510
501
 
511
 
/* 
512
 
  This flag means that index is a unique index, and the interval is 
 
502
/*
 
503
  This flag means that index is a unique index, and the interval is
513
504
  equivalent to "AND(keypart_i = const_i)", where all of const_i are not NULLs.
514
505
*/
515
506
#define UNIQUE_RANGE    16
516
507
 
517
 
/* 
518
 
  This flag means that the interval is equivalent to 
519
 
  "AND(keypart_i = const_i)", where not all key parts may be used but all of 
 
508
/*
 
509
  This flag means that the interval is equivalent to
 
510
  "AND(keypart_i = const_i)", where not all key parts may be used but all of
520
511
  const_i are not NULLs.
521
512
*/
522
513
#define EQ_RANGE        32
523
514
 
524
515
/*
525
516
  This flag has the same meaning as UNIQUE_RANGE, except that for at least
526
 
  one keypart the condition is "keypart IS NULL". 
 
517
  one keypart the condition is "keypart IS NULL".
527
518
*/
528
519
#define NULL_RANGE      64
529
520
 
530
521
typedef struct st_key_range
531
522
{
532
 
  const uchar *key;
533
 
  uint length;
 
523
  const unsigned char *key;
 
524
  uint32_t length;
 
525
  enum ha_rkey_function flag;
534
526
  key_part_map keypart_map;
535
 
  enum ha_rkey_function flag;
536
527
} key_range;
537
528
 
538
529
typedef struct st_key_multi_range
540
531
  key_range start_key;
541
532
  key_range end_key;
542
533
  char  *ptr;                 /* Free to use by caller (ptr to row etc) */
543
 
  uint  range_flag;           /* key range flags see above */
 
534
  uint32_t  range_flag;           /* key range flags see above */
544
535
} KEY_MULTI_RANGE;
545
536
 
546
537
 
559
550
 
560
551
#define HA_VARCHAR_PACKLENGTH(field_length) ((field_length) < 256 ? 1 :2)
561
552
 
562
 
/* invalidator function reference for Query Cache */
563
 
typedef void (* invalidator_by_filename)(const char * filename);
564
 
 
565
553
#endif /* DRIZZLE_SERVER_BASE_H */