~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to mysys/my_sys.h

  • Committer: Jay Pipes
  • Date: 2008-09-11 16:03:22 UTC
  • mto: (383.5.1 trunk)
  • mto: This revision was merged to the branch mainline in revision 386.
  • Revision ID: jay@mysql.com-20080911160322-vrl0k1djo6q6ytv1
Removed SQL_MODE variances from comment_table.test and ensured correct error thrown when a comment that is too long was input.  After moving to proto buffer definition for table, the 2048 length will go away.

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_INTERNAL_MY_SYS_H
22
 
#define DRIZZLED_INTERNAL_MY_SYS_H
23
 
 
24
 
#ifdef __cplusplus
25
 
# include <cstdio>
26
 
#else
27
 
# include <stdio.h>
 
1
/* Copyright (C) 2000-2003 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 */
 
15
 
 
16
#ifndef _my_sys_h
 
17
#define _my_sys_h
 
18
C_MODE_START
 
19
 
 
20
#ifdef HAVE_AIOWAIT
 
21
#include <sys/asynch.h>                 /* Used by record-cache */
 
22
typedef struct my_aio_result {
 
23
  aio_result_t result;
 
24
  int          pending;
 
25
} my_aio_result;
28
26
#endif
29
27
 
30
28
#include <errno.h>
31
 
 
32
 
#include "drizzled/internal/my_pthread.h"
33
 
 
34
 
#include "drizzled/charset_info.h"                    /* for CHARSET_INFO */
 
29
#define my_errno (errno)
 
30
 
 
31
#include <mysys/my_pthread.h>
 
32
 
 
33
#include <mystrings/m_ctype.h>                    /* for CHARSET_INFO */
35
34
#include <stdarg.h>
36
 
#include "drizzled/typelib.h"
37
 
#include "drizzled/internal/aio_result.h"
38
 
 
39
 
#include "drizzled/memory/root.h"
40
 
#include "drizzled/error.h"
41
 
 
42
 
#ifndef errno                           /* did we already get it? */
43
 
#ifdef HAVE_ERRNO_AS_DEFINE
44
 
#include <errno.h>                      /* errno is a define */
45
 
#else
46
 
extern int errno;                       /* declare errno */
47
 
#endif
48
 
#endif                                  /* #ifndef errno */
49
 
 
50
 
#include <drizzled/dynamic_array.h>
51
 
 
52
 
#ifdef HAVE_SYS_MMAN_H 
53
 
#include <sys/mman.h>
54
 
#endif
55
 
 
56
 
#include "drizzled/qsort_cmp.h"
57
 
 
58
 
namespace drizzled
59
 
{
60
 
namespace internal
61
 
{
62
 
 
63
 
#ifndef MAP_NOSYNC
64
 
#define MAP_NOSYNC      0
65
 
#endif
66
 
#ifndef MAP_NORESERVE
67
 
#define MAP_NORESERVE 0         /* For irix and AIX */
68
 
#endif
69
 
 
70
 
/*
71
 
  EDQUOT is used only in 3 C files only in mysys/. If it does not exist on
72
 
  system, we set it to some value which can never happen.
73
 
*/
74
 
#ifndef EDQUOT
75
 
#define EDQUOT (-1)
76
 
#endif
77
 
 
78
 
/* Sun Studio does not inject this into main namespace yet */
79
 
#if defined(__cplusplus)
80
 
  using std::FILE;
81
 
#endif
82
 
 
83
 
#define MY_INIT(name);          { ::drizzled::internal::my_progname= name; ::drizzled::internal::my_init(); }
84
 
 
 
35
#include <mysys/typelib.h>
 
36
 
 
37
#define MY_INIT(name);          { my_progname= name; my_init(); }
 
38
 
 
39
#define ERRMSGSIZE      (SC_MAXWIDTH)   /* Max length of a error message */
 
40
#define NRERRBUFFS      (2)     /* Buffers for parameters */
 
41
#define MY_FILE_ERROR   ((size_t) -1)
85
42
 
86
43
        /* General bitmaps for my_func's */
87
44
#define MY_FFNF         1       /* Fatal if file not found */
92
49
#define MY_WAIT_IF_FULL 32      /* Wait and try again if disk full error */
93
50
#define MY_IGNORE_BADFD 32      /* my_sync: ignore 'bad descriptor' errors */
94
51
#define MY_SYNC_DIR     1024    /* my_create/delete/rename: sync directory */
 
52
#define MY_RAID         64      /* Support for RAID */
95
53
#define MY_FULL_IO     512      /* For my_read - loop intil I/O is complete */
96
54
#define MY_DONT_CHECK_FILESIZE 128 /* Option to init_io_cache() */
97
55
#define MY_LINK_WARNING 32      /* my_redel() gives warning if links */
98
56
#define MY_COPYTIME     64      /* my_redel() copys time */
99
57
#define MY_DELETE_OLD   256     /* my_create_with_symlink() */
 
58
#define MY_RESOLVE_LINK 128     /* my_realpath(); Only resolve links */
100
59
#define MY_HOLD_ORIGINAL_MODES 128  /* my_copy() holds to file modes */
101
60
#define MY_REDEL_MAKE_BACKUP 256
 
61
#define MY_SEEK_NOT_DONE 32     /* my_lock may have to do a seek */
102
62
#define MY_DONT_WAIT    64      /* my_lock() don't wait if can't lock */
 
63
#define MY_ZEROFILL     32      /* my_malloc(), fill array with zero */
 
64
#define MY_ALLOW_ZERO_PTR 64    /* my_realloc() ; zero ptr -> malloc */
 
65
#define MY_FREE_ON_ERROR 128    /* my_realloc() ; Free old ptr on error */
 
66
#define MY_HOLD_ON_ERROR 256    /* my_realloc() ; Return old ptr on error */
103
67
#define MY_DONT_OVERWRITE_FILE 1024     /* my_copy: Don't overwrite file */
104
68
#define MY_THREADSAFE 2048      /* my_seek(): lock fd mutex */
105
69
 
 
70
#define MY_CHECK_ERROR  1       /* Params to my_end; Check open-close */
 
71
#define MY_GIVE_INFO    2       /* Give time info about process*/
 
72
 
 
73
#define MY_REMOVE_NONE    0     /* Params for modify_defaults_file */
 
74
#define MY_REMOVE_OPTION  1
 
75
#define MY_REMOVE_SECTION 2
 
76
 
 
77
#define ME_HIGHBYTE     8       /* Shift for colours */
 
78
#define ME_NOCUR        1       /* Don't use curses message */
106
79
#define ME_OLDWIN       2       /* Use old window */
107
80
#define ME_BELL         4       /* Ring bell then printing message */
108
81
#define ME_HOLDTANG     8       /* Don't delete last keys */
 
82
#define ME_WAITTOT      16      /* Wait for errtime secs of for a action */
109
83
#define ME_WAITTANG     32      /* Wait for a user action  */
110
84
#define ME_NOREFRESH    64      /* Dont refresh screen */
111
85
#define ME_NOINPUT      128     /* Dont use the input libary */
 
86
#define ME_COLOUR1      ((1 << ME_HIGHBYTE))    /* Possibly error-colours */
 
87
#define ME_COLOUR2      ((2 << ME_HIGHBYTE))
 
88
#define ME_COLOUR3      ((3 << ME_HIGHBYTE))
 
89
#define ME_FATALERROR   1024    /* Fatal statement error */
112
90
 
113
91
        /* Bits in last argument to fn_format */
114
92
#define MY_REPLACE_DIR          1       /* replace dir in name with 'dir' */
115
93
#define MY_REPLACE_EXT          2       /* replace extension with 'ext' */
116
94
#define MY_UNPACK_FILENAME      4       /* Unpack name (~ -> home) */
 
95
#define MY_PACK_FILENAME        8       /* Pack name (home -> ~) */
117
96
#define MY_RESOLVE_SYMLINKS     16      /* Resolve all symbolic links */
118
97
#define MY_RETURN_REAL_PATH     32      /* return full path for file */
119
98
#define MY_SAFE_PATH            64      /* Return NULL if too long path */
121
100
#define MY_APPEND_EXT           256     /* add 'ext' as additional extension*/
122
101
 
123
102
 
 
103
        /* My seek flags */
 
104
#define MY_SEEK_SET     0
 
105
#define MY_SEEK_CUR     1
 
106
#define MY_SEEK_END     2
 
107
 
124
108
        /* Some constants */
125
109
#define MY_WAIT_FOR_USER_TO_FIX_PANIC   60      /* in seconds */
126
110
#define MY_WAIT_GIVE_USER_A_MESSAGE     10      /* Every 10 times of prev */
 
111
#define MIN_COMPRESS_LENGTH             50      /* Don't compress small bl. */
127
112
#define DFLT_INIT_HITS  3
128
113
 
 
114
        /* root_alloc flags */
 
115
#define MY_KEEP_PREALLOC        1
 
116
#define MY_MARK_BLOCKS_FREE     2  /* move used to free list and reuse them */
 
117
 
129
118
        /* Internal error numbers (for assembler functions) */
130
119
#define MY_ERRNO_EDOM           33
131
120
#define MY_ERRNO_ERANGE         34
137
126
#define GETDATE_GMT             8
138
127
#define GETDATE_FIXEDLENGTH     16
139
128
 
140
 
 
141
 
typedef uint64_t my_off_t;
142
 
 
 
129
        /* defines when allocating data */
 
130
#ifdef SAFEMALLOC
 
131
#else
 
132
#define my_checkmalloc()
 
133
#undef TERMINATE
 
134
#define TERMINATE(A,B) {}
 
135
#define QUICK_SAFEMALLOC
 
136
#define NORMAL_SAFEMALLOC
 
137
extern void *my_malloc(size_t Size,myf MyFlags);
 
138
#define my_malloc_ci(SZ,FLAG) my_malloc( SZ, FLAG )
 
139
extern void *my_realloc(void *oldpoint, size_t Size, myf MyFlags);
 
140
extern void my_no_flags_free(void *ptr);
 
141
extern void *my_memdup(const void *from,size_t length,myf MyFlags);
 
142
extern char *my_strdup(const char *from,myf MyFlags);
 
143
extern char *my_strndup(const char *from, size_t length,
 
144
                                   myf MyFlags);
 
145
/* we do use FG (as a no-op) in below so that a typo on FG is caught */
 
146
#define my_free(PTR,FG) ((void)FG,my_no_flags_free(PTR))
 
147
#define CALLER_INFO_PROTO   /* nothing */
 
148
#define CALLER_INFO         /* nothing */
 
149
#define ORIG_CALLER_INFO    /* nothing */
143
150
#define TRASH(A,B) /* nothing */
144
 
 
 
151
#endif
 
152
 
 
153
#ifdef HAVE_ALLOCA
 
154
#if defined(__GNUC__) && !defined(HAVE_ALLOCA_H) && ! defined(alloca)
 
155
#define alloca __builtin_alloca
 
156
#endif /* GNUC */
 
157
#define my_alloca(SZ) alloca((size_t) (SZ))
 
158
#define my_afree(PTR) {}
 
159
#else
 
160
#define my_alloca(SZ) my_malloc(SZ,MYF(0))
 
161
#define my_afree(PTR) my_free(PTR,MYF(MY_WME))
 
162
#endif /* HAVE_ALLOCA */
 
163
 
 
164
#ifndef errno                           /* did we already get it? */
 
165
#ifdef HAVE_ERRNO_AS_DEFINE
 
166
#include <errno.h>                      /* errno is a define */
 
167
#else
 
168
extern int errno;                       /* declare errno */
 
169
#endif
 
170
#endif                                  /* #ifndef errno */
 
171
extern char errbuff[NRERRBUFFS][ERRMSGSIZE];
145
172
extern char *home_dir;                  /* Home directory for user */
146
173
extern const char *my_progname;         /* program-name (printed in errors) */
147
 
extern uint32_t my_file_limit;
 
174
extern void (*error_handler_hook)(uint my_err, const char *str,myf MyFlags);
 
175
extern void (*fatal_error_handler_hook)(uint my_err, const char *str,
 
176
                                        myf MyFlags);
 
177
extern uint my_file_limit;
 
178
extern uint32_t my_thread_stack_size;
 
179
 
 
180
/* charsets */
 
181
extern const CHARSET_INFO *default_charset_info;
 
182
extern CHARSET_INFO *all_charsets[256];
 
183
extern CHARSET_INFO compiled_charsets[];
148
184
 
149
185
/* statistics */
 
186
extern uint32_t my_file_opened,my_stream_opened, my_tmp_file_created;
 
187
extern uint32_t    my_file_total_opened;
150
188
extern uint     mysys_usage_id;
151
189
extern bool     my_init_done;
152
190
 
 
191
                                        /* Point to current my_message() */
 
192
extern void (*my_sigtstp_cleanup)(void),
 
193
                                        /* Executed before jump to shell */
 
194
            (*my_sigtstp_restart)(void),
 
195
            (*my_abort_hook)(int);
153
196
                                        /* Executed when comming from shell */
154
197
extern int my_umask,            /* Default creation mask  */
155
198
           my_umask_dir,
171
214
 
172
215
extern bool timed_mutexes;
173
216
 
174
 
typedef class wild_file_pack    /* Struct to hold info when selecting files */
 
217
typedef struct wild_file_pack   /* Struct to hold info when selecting files */
175
218
{
176
 
public:
177
219
  uint          wilds;          /* How many wildcards */
178
220
  uint          not_pos;        /* Start of not-theese-files */
179
221
  char *        *wild;          /* Pointer to wildcards */
180
 
 
181
 
  wild_file_pack():
182
 
    wilds(0),
183
 
    not_pos(0),
184
 
    wild(NULL)
185
 
  {}
186
 
 
187
222
} WF_PACK;
188
223
 
 
224
enum loglevel {
 
225
   ERROR_LEVEL,
 
226
   WARNING_LEVEL,
 
227
   INFORMATION_LEVEL
 
228
};
 
229
 
189
230
enum cache_type
190
231
{
191
 
  TYPE_NOT_SET= 0,
192
 
  READ_CACHE,
193
 
  WRITE_CACHE,
194
 
  READ_FIFO,
195
 
  READ_NET,
196
 
  WRITE_NET
197
 
};
 
232
  TYPE_NOT_SET= 0, READ_CACHE, WRITE_CACHE,
 
233
  SEQ_READ_APPEND               /* sequential read or append */,
 
234
  READ_FIFO, READ_NET,WRITE_NET};
198
235
 
199
 
typedef struct record_cache     /* Used when cacheing records */
 
236
typedef struct st_record_cache  /* Used when cacheing records */
200
237
{
201
 
public:
202
 
  int file;
 
238
  File file;
203
239
  int   rc_seek,error,inited;
204
240
  uint  rc_length,read_length,reclength;
205
241
  my_off_t rc_record_pos,end_of_file;
206
 
  unsigned char *rc_buff,*rc_buff2,*rc_pos,*rc_end,*rc_request_pos;
 
242
  uchar *rc_buff,*rc_buff2,*rc_pos,*rc_end,*rc_request_pos;
207
243
#ifdef HAVE_AIOWAIT
208
244
  int   use_async_io;
209
245
  my_aio_result aio_result;
210
246
#endif
211
247
  enum cache_type type;
212
 
 
213
 
  record_cache():
214
 
    file(0),
215
 
    rc_seek(0),
216
 
    error(0),
217
 
    inited(0),
218
 
    rc_length(0),
219
 
    read_length(0),
220
 
    reclength(0),
221
 
    rc_record_pos(0),
222
 
    end_of_file(0),
223
 
    rc_buff(NULL),
224
 
    rc_buff2(NULL),
225
 
    rc_pos(NULL),
226
 
    rc_end(NULL),
227
 
    rc_request_pos(NULL)
228
 
  {}
229
 
 
230
248
} RECORD_CACHE;
231
249
 
 
250
enum file_type
 
251
{
 
252
  UNOPEN = 0, FILE_BY_OPEN, FILE_BY_CREATE, STREAM_BY_FOPEN, STREAM_BY_FDOPEN,
 
253
  FILE_BY_MKSTEMP, FILE_BY_DUP
 
254
};
 
255
 
 
256
struct st_my_file_info
 
257
{
 
258
  char *                name;
 
259
  enum file_type        type;
 
260
#if !defined(HAVE_PREAD)
 
261
  pthread_mutex_t       mutex;
 
262
#endif
 
263
};
 
264
 
 
265
extern struct st_my_file_info *my_file_info;
 
266
 
 
267
typedef struct st_dynamic_array
 
268
{
 
269
  uchar *buffer;
 
270
  uint elements,max_element;
 
271
  uint alloc_increment;
 
272
  uint size_of_element;
 
273
} DYNAMIC_ARRAY;
 
274
 
 
275
typedef struct st_my_tmpdir
 
276
{
 
277
  DYNAMIC_ARRAY full_list;
 
278
  char **list;
 
279
  uint cur, max;
 
280
  pthread_mutex_t mutex;
 
281
} MY_TMPDIR;
 
282
 
 
283
struct st_io_cache;
 
284
typedef int (*IO_CACHE_CALLBACK)(struct st_io_cache*);
 
285
 
 
286
typedef struct st_io_cache_share
 
287
{
 
288
  pthread_mutex_t       mutex;           /* To sync on reads into buffer. */
 
289
  pthread_cond_t        cond;            /* To wait for signals. */
 
290
  pthread_cond_t        cond_writer;     /* For a synchronized writer. */
 
291
  /* Offset in file corresponding to the first byte of buffer. */
 
292
  my_off_t              pos_in_file;
 
293
  /* If a synchronized write cache is the source of the data. */
 
294
  struct st_io_cache    *source_cache;
 
295
  uchar                 *buffer;         /* The read buffer. */
 
296
  uchar                 *read_end;       /* Behind last valid byte of buffer. */
 
297
  int                   running_threads; /* threads not in lock. */
 
298
  int                   total_threads;   /* threads sharing the cache. */
 
299
  int                   error;           /* Last error. */
 
300
#ifdef NOT_YET_IMPLEMENTED
 
301
  /* whether the structure should be free'd */
 
302
  bool alloced;
 
303
#endif
 
304
} IO_CACHE_SHARE;
 
305
 
 
306
typedef struct st_io_cache              /* Used when cacheing files */
 
307
{
 
308
  /* Offset in file corresponding to the first byte of uchar* buffer. */
 
309
  my_off_t pos_in_file;
 
310
  /*
 
311
    The offset of end of file for READ_CACHE and WRITE_CACHE.
 
312
    For SEQ_READ_APPEND it the maximum of the actual end of file and
 
313
    the position represented by read_end.
 
314
  */
 
315
  my_off_t end_of_file;
 
316
  /* Points to current read position in the buffer */
 
317
  uchar *read_pos;
 
318
  /* the non-inclusive boundary in the buffer for the currently valid read */
 
319
  uchar  *read_end;
 
320
  uchar  *buffer;                               /* The read buffer */
 
321
  /* Used in ASYNC_IO */
 
322
  uchar  *request_pos;
 
323
 
 
324
  /* Only used in WRITE caches and in SEQ_READ_APPEND to buffer writes */
 
325
  uchar  *write_buffer;
 
326
  /*
 
327
    Only used in SEQ_READ_APPEND, and points to the current read position
 
328
    in the write buffer. Note that reads in SEQ_READ_APPEND caches can
 
329
    happen from both read buffer (uchar* buffer) and write buffer
 
330
    (uchar* write_buffer).
 
331
  */
 
332
  uchar *append_read_pos;
 
333
  /* Points to current write position in the write buffer */
 
334
  uchar *write_pos;
 
335
  /* The non-inclusive boundary of the valid write area */
 
336
  uchar *write_end;
 
337
 
 
338
  /*
 
339
    Current_pos and current_end are convenience variables used by
 
340
    my_b_tell() and other routines that need to know the current offset
 
341
    current_pos points to &write_pos, and current_end to &write_end in a
 
342
    WRITE_CACHE, and &read_pos and &read_end respectively otherwise
 
343
  */
 
344
  uchar  **current_pos, **current_end;
 
345
  /*
 
346
    The lock is for append buffer used in SEQ_READ_APPEND cache
 
347
    need mutex copying from append buffer to read buffer.
 
348
  */
 
349
  pthread_mutex_t append_buffer_lock;
 
350
  /*
 
351
    The following is used when several threads are reading the
 
352
    same file in parallel. They are synchronized on disk
 
353
    accesses reading the cached part of the file asynchronously.
 
354
    It should be set to NULL to disable the feature.  Only
 
355
    READ_CACHE mode is supported.
 
356
  */
 
357
  IO_CACHE_SHARE *share;
 
358
  /*
 
359
    A caller will use my_b_read() macro to read from the cache
 
360
    if the data is already in cache, it will be simply copied with
 
361
    memcpy() and internal variables will be accordinging updated with
 
362
    no functions invoked. However, if the data is not fully in the cache,
 
363
    my_b_read() will call read_function to fetch the data. read_function
 
364
    must never be invoked directly.
 
365
  */
 
366
  int (*read_function)(struct st_io_cache *,uchar *,size_t);
 
367
  /*
 
368
    Same idea as in the case of read_function, except my_b_write() needs to
 
369
    be replaced with my_b_append() for a SEQ_READ_APPEND cache
 
370
  */
 
371
  int (*write_function)(struct st_io_cache *,const uchar *,size_t);
 
372
  /*
 
373
    Specifies the type of the cache. Depending on the type of the cache
 
374
    certain operations might not be available and yield unpredicatable
 
375
    results. Details to be documented later
 
376
  */
 
377
  enum cache_type type;
 
378
  /*
 
379
    Callbacks when the actual read I/O happens. These were added and
 
380
    are currently used for binary logging of LOAD DATA INFILE - when a
 
381
    block is read from the file, we create a block create/append event, and
 
382
    when IO_CACHE is closed, we create an end event. These functions could,
 
383
    of course be used for other things
 
384
  */
 
385
  IO_CACHE_CALLBACK pre_read;
 
386
  IO_CACHE_CALLBACK post_read;
 
387
  IO_CACHE_CALLBACK pre_close;
 
388
  /*
 
389
    Counts the number of times, when we were forced to use disk. We use it to
 
390
    increase the binlog_cache_disk_use status variable.
 
391
  */
 
392
  uint32_t disk_writes;
 
393
  void* arg;                            /* for use by pre/post_read */
 
394
  char *file_name;                      /* if used with 'open_cached_file' */
 
395
  char *dir,*prefix;
 
396
  File file; /* file descriptor */
 
397
  /*
 
398
    seek_not_done is set by my_b_seek() to inform the upcoming read/write
 
399
    operation that a seek needs to be preformed prior to the actual I/O
 
400
    error is 0 if the cache operation was successful, -1 if there was a
 
401
    "hard" error, and the actual number of I/O-ed bytes if the read/write was
 
402
    partial.
 
403
  */
 
404
  int   seek_not_done,error;
 
405
  /* buffer_length is memory size allocated for buffer or write_buffer */
 
406
  size_t        buffer_length;
 
407
  /* read_length is the same as buffer_length except when we use async io */
 
408
  size_t  read_length;
 
409
  myf   myflags;                        /* Flags used to my_read/my_write */
 
410
  /*
 
411
    alloced_buffer is 1 if the buffer was allocated by init_io_cache() and
 
412
    0 if it was supplied by the user.
 
413
    Currently READ_NET is the only one that will use a buffer allocated
 
414
    somewhere else
 
415
  */
 
416
  bool alloced_buffer;
 
417
#ifdef HAVE_AIOWAIT
 
418
  /*
 
419
    As inidicated by ifdef, this is for async I/O, which is not currently
 
420
    used (because it's not reliable on all systems)
 
421
  */
 
422
  uint inited;
 
423
  my_off_t aio_read_pos;
 
424
  my_aio_result aio_result;
 
425
#endif
 
426
} IO_CACHE;
 
427
 
 
428
typedef int (*qsort2_cmp)(const void *, const void *, const void *);
232
429
 
233
430
        /* defines for mf_iocache */
234
431
 
251
448
 
252
449
#define my_b_get(info) \
253
450
  ((info)->read_pos != (info)->read_end ?\
254
 
   ((info)->read_pos++, (int) (unsigned char) (info)->read_pos[-1]) :\
 
451
   ((info)->read_pos++, (int) (uchar) (info)->read_pos[-1]) :\
255
452
   _my_b_get(info))
256
453
 
 
454
        /* my_b_write_byte dosn't have any err-check */
 
455
#define my_b_write_byte(info,chr) \
 
456
  (((info)->write_pos < (info)->write_end) ?\
 
457
   ((*(info)->write_pos++)=(chr)) :\
 
458
   (_my_b_write(info,0,0) , ((*(info)->write_pos++)=(chr))))
 
459
 
 
460
#define my_b_fill_cache(info) \
 
461
  (((info)->read_end=(info)->read_pos),(*(info)->read_function)(info,0,0))
 
462
 
257
463
#define my_b_tell(info) ((info)->pos_in_file + \
258
464
                         (size_t) (*(info)->current_pos - (info)->request_pos))
259
465
 
 
466
#define my_b_get_buffer_start(info) (info)->request_pos 
 
467
#define my_b_get_bytes_in_buffer(info) (char*) (info)->read_end -   \
 
468
  (char*) my_b_get_buffer_start(info)
 
469
#define my_b_get_pos_in_file(info) (info)->pos_in_file
 
470
 
 
471
/* tell write offset in the SEQ_APPEND cache */
 
472
int      my_b_copy_to_file(IO_CACHE *cache, FILE *file);
 
473
my_off_t my_b_append_tell(IO_CACHE* info);
 
474
my_off_t my_b_safe_tell(IO_CACHE* info); /* picks the correct tell() */
 
475
 
260
476
#define my_b_bytes_in_cache(info) (size_t) (*(info)->current_end - \
261
477
                                          *(info)->current_pos)
262
478
 
266
482
typedef int (*Process_option_func)(void *ctx, const char *group_name,
267
483
                                   const char *option);
268
484
 
269
 
int handle_default_option(void *in_ctx, const char *group_name,
270
 
                          const char *option);
271
 
 
 
485
#include <mysys/my_alloc.h>
272
486
 
273
487
 
274
488
        /* Prototypes for mysys and my_func functions */
275
489
 
276
490
extern int my_copy(const char *from,const char *to,myf MyFlags);
277
491
extern int my_delete(const char *name,myf MyFlags);
278
 
extern int my_open(const char *FileName,int Flags,myf MyFlags);
279
 
extern int my_register_filename(int fd, const char *FileName,
280
 
                                 uint32_t error_message_number, myf MyFlags);
281
 
extern int my_create(const char *FileName,int CreateFlags,
 
492
extern int my_getwd(char * buf,size_t size,myf MyFlags);
 
493
extern int my_setwd(const char *dir,myf MyFlags);
 
494
extern void *my_once_alloc(size_t Size,myf MyFlags);
 
495
extern void my_once_free(void);
 
496
extern char *my_once_strdup(const char *src,myf myflags);
 
497
extern void *my_once_memdup(const void *src, size_t len, myf myflags);
 
498
extern File my_open(const char *FileName,int Flags,myf MyFlags);
 
499
extern File my_register_filename(File fd, const char *FileName,
 
500
                                 enum file_type type_of_file,
 
501
                                 uint error_message_number, myf MyFlags);
 
502
extern File my_create(const char *FileName,int CreateFlags,
282
503
                      int AccessFlags, myf MyFlags);
283
 
extern int my_close(int Filedes,myf MyFlags);
 
504
extern int my_close(File Filedes,myf MyFlags);
 
505
extern File my_dup(File file, myf MyFlags);
284
506
extern int my_mkdir(const char *dir, int Flags, myf MyFlags);
 
507
extern int my_readlink(char *to, const char *filename, myf MyFlags);
285
508
extern int my_realpath(char *to, const char *filename, myf MyFlags);
286
 
extern int my_create_with_symlink(const char *linkname, const char *filename,
 
509
extern File my_create_with_symlink(const char *linkname, const char *filename,
287
510
                                   int createflags, int access_flags,
288
511
                                   myf MyFlags);
289
512
extern int my_delete_with_symlink(const char *name, myf MyFlags);
290
513
extern int my_rename_with_symlink(const char *from,const char *to,myf MyFlags);
291
 
extern size_t my_read(int Filedes,unsigned char *Buffer,size_t Count,myf MyFlags);
 
514
extern int my_symlink(const char *content, const char *linkname, myf MyFlags);
 
515
extern size_t my_read(File Filedes,uchar *Buffer,size_t Count,myf MyFlags);
292
516
extern int my_rename(const char *from,const char *to,myf MyFlags);
293
 
extern size_t my_write(int Filedes,const unsigned char *Buffer,size_t Count,
 
517
extern my_off_t my_seek(File fd,my_off_t pos,int whence,myf MyFlags);
 
518
extern my_off_t my_tell(File fd,myf MyFlags);
 
519
extern size_t my_write(File Filedes,const uchar *Buffer,size_t Count,
294
520
                     myf MyFlags);
295
 
extern int _sanity(const char *sFile, uint32_t uLine);
 
521
extern size_t my_fwrite(FILE *stream,const uchar *Buffer,size_t Count,
 
522
                      myf MyFlags);
 
523
extern my_off_t my_fseek(FILE *stream,my_off_t pos,int whence,myf MyFlags);
 
524
extern void *_mymalloc(size_t uSize,const char *sFile,
 
525
                       uint uLine, myf MyFlag);
 
526
extern void *_myrealloc(void *pPtr,size_t uSize,const char *sFile,
 
527
                       uint uLine, myf MyFlag);
 
528
extern void * my_multi_malloc _VARARGS((myf MyFlags, ...));
 
529
extern void _myfree(void *pPtr,const char *sFile,uint uLine, myf MyFlag);
 
530
extern int _sanity(const char *sFile, uint uLine);
 
531
extern void *_my_memdup(const void *from, size_t length,
 
532
                        const char *sFile, uint uLine,myf MyFlag);
 
533
extern char * _my_strdup(const char *from, const char *sFile, uint uLine,
 
534
                         myf MyFlag);
 
535
extern char *_my_strndup(const char *from, size_t length,
 
536
                         const char *sFile, uint uLine,
 
537
                         myf MyFlag);
296
538
 
 
539
#define my_access access
297
540
extern int check_if_legal_filename(const char *path);
298
541
extern int check_if_legal_tablename(const char *path);
299
542
 
300
543
#define my_delete_allow_opened(fname,flags)  my_delete((fname),(flags))
301
544
 
302
 
extern int my_sync(int fd, myf my_flags);
 
545
#ifndef TERMINATE
 
546
extern void TERMINATE(FILE *file, uint flag);
 
547
#endif
 
548
extern void init_glob_errs(void);
 
549
extern FILE *my_fopen(const char *FileName,int Flags,myf MyFlags);
 
550
extern int my_fclose(FILE *fd,myf MyFlags);
 
551
extern int my_sync(File fd, myf my_flags);
303
552
extern int my_sync_dir(const char *dir_name, myf my_flags);
304
553
extern int my_sync_dir_by_file(const char *file_name, myf my_flags);
 
554
extern void my_error _VARARGS((int nr,myf MyFlags, ...));
 
555
extern void my_printf_error _VARARGS((uint my_err, const char *format,
 
556
                                      myf MyFlags, ...))
 
557
                                      __attribute__((format(printf, 2, 4)));
 
558
extern int my_error_register(const char **errmsgs, int first, int last);
 
559
extern const char **my_error_unregister(int first, int last);
 
560
extern void my_message(uint my_err, const char *str,myf MyFlags);
 
561
extern void my_message_no_curses(uint my_err, const char *str,myf MyFlags);
305
562
extern bool my_init(void);
306
 
extern void my_end(void);
 
563
extern void my_end(int infoflag);
307
564
extern int my_redel(const char *from, const char *to, int MyFlags);
308
565
extern int my_copystat(const char *from, const char *to, int MyFlags);
309
 
extern char * my_filename(int fd);
310
 
 
311
 
extern void my_remember_signal(int signal_number,void (*func)(int));
 
566
extern char * my_filename(File fd);
 
567
 
 
568
#ifdef EXTRA_DEBUG
 
569
void my_print_open_files(void);
 
570
#else
 
571
#define my_print_open_files()
 
572
#endif
 
573
 
 
574
extern bool init_tmpdir(MY_TMPDIR *tmpdir, const char *pathlist);
 
575
extern char *my_tmpdir(MY_TMPDIR *tmpdir);
 
576
extern void free_tmpdir(MY_TMPDIR *tmpdir);
 
577
 
 
578
extern void my_remember_signal(int signal_number,sig_handler (*func)(int));
312
579
extern size_t dirname_part(char * to,const char *name, size_t *to_res_length);
313
580
extern size_t dirname_length(const char *name);
314
581
#define base_name(A) (A+dirname_length(A))
315
 
bool test_if_hard_path(const char *dir_name);
316
 
 
 
582
extern int test_if_hard_path(const char *dir_name);
 
583
extern bool has_path(const char *name);
317
584
extern char *convert_dirname(char *to, const char *from, const char *from_end);
 
585
extern void to_unix_path(char * name);
318
586
extern char * fn_ext(const char *name);
319
587
extern char * fn_same(char * toname,const char *name,int flag);
320
588
extern char * fn_format(char * to,const char *name,const char *dir,
321
 
                           const char *form, uint32_t flag);
 
589
                           const char *form, uint flag);
322
590
extern size_t strlength(const char *str);
 
591
extern void pack_dirname(char * to,const char *from);
323
592
extern size_t unpack_dirname(char * to,const char *from);
 
593
extern size_t cleanup_dirname(char * to,const char *from);
 
594
extern size_t system_filename(char * to,const char *from);
324
595
extern size_t unpack_filename(char * to,const char *from);
325
596
extern char * intern_filename(char * to,const char *from);
 
597
extern char * directory_file_name(char * dst, const char *src);
326
598
extern int pack_filename(char * to, const char *name, size_t max_length);
 
599
extern char * my_path(char * to,const char *progname,
 
600
                         const char *own_pathname_part);
327
601
extern char * my_load_path(char * to, const char *path,
328
602
                              const char *own_path_prefix);
329
603
extern int wild_compare(const char *str,const char *wildstr,
330
604
                        bool str_is_pattern);
331
605
extern WF_PACK *wf_comp(char * str);
332
 
extern int wf_test(wild_file_pack *wf_pack,const char *name);
333
 
extern void wf_end(wild_file_pack *buffer);
 
606
extern int wf_test(struct wild_file_pack *wf_pack,const char *name);
 
607
extern void wf_end(struct wild_file_pack *buffer);
334
608
extern bool array_append_string_unique(const char *str,
335
609
                                          const char **array, size_t size);
336
610
extern void get_date(char * to,int timeflag,time_t use_time);
337
 
extern int init_record_cache(RECORD_CACHE *info,size_t cachesize,int file,
 
611
extern void soundex(CHARSET_INFO *, char * out_pntr, char * in_pntr,
 
612
                    bool remove_garbage);
 
613
extern int init_record_cache(RECORD_CACHE *info,size_t cachesize,File file,
338
614
                             size_t reclength,enum cache_type type,
339
615
                             bool use_async_io);
340
 
extern int read_cache_record(RECORD_CACHE *info,unsigned char *to);
 
616
extern int read_cache_record(RECORD_CACHE *info,uchar *to);
341
617
extern int end_record_cache(RECORD_CACHE *info);
342
618
extern int write_cache_record(RECORD_CACHE *info,my_off_t filepos,
343
 
                              const unsigned char *record,size_t length);
 
619
                              const uchar *record,size_t length);
344
620
extern int flush_write_cache(RECORD_CACHE *info);
345
 
extern void sigtstp_handler(int signal_number);
 
621
extern sig_handler sigtstp_handler(int signal_number);
346
622
extern void handle_recived_signals(void);
347
623
 
348
 
extern void my_set_alarm_variable(int signo);
349
 
extern void my_string_ptr_sort(unsigned char *base,uint32_t items,size_t size);
350
 
extern void radixsort_for_str_ptr(unsigned char* base[], uint32_t number_of_elements,
351
 
                                  size_t size_of_element,unsigned char *buffer[]);
352
 
extern void my_qsort(void *base_ptr, size_t total_elems, size_t size,
353
 
                     qsort_cmp cmp);
354
 
extern void my_qsort2(void *base_ptr, size_t total_elems, size_t size,
355
 
                      qsort2_cmp cmp, void *cmp_argument);
 
624
extern sig_handler my_set_alarm_variable(int signo);
 
625
extern void my_string_ptr_sort(uchar *base,uint items,size_t size);
 
626
extern void radixsort_for_str_ptr(uchar* base[], uint number_of_elements,
 
627
                                  size_t size_of_element,uchar *buffer[]);
 
628
extern qsort_t my_qsort(void *base_ptr, size_t total_elems, size_t size,
 
629
                        qsort_cmp cmp);
 
630
extern qsort_t my_qsort2(void *base_ptr, size_t total_elems, size_t size,
 
631
                         qsort2_cmp cmp, void *cmp_argument);
356
632
extern qsort2_cmp get_ptr_compare(size_t);
357
 
void my_store_ptr(unsigned char *buff, size_t pack_length, my_off_t pos);
358
 
my_off_t my_get_ptr(unsigned char *ptr, size_t pack_length);
359
 
int create_temp_file(char *to, const char *dir, const char *pfx, myf MyFlags);
360
 
 
 
633
void my_store_ptr(uchar *buff, size_t pack_length, my_off_t pos);
 
634
my_off_t my_get_ptr(uchar *ptr, size_t pack_length);
 
635
extern int init_io_cache(IO_CACHE *info,File file,size_t cachesize,
 
636
                         enum cache_type type,my_off_t seek_offset,
 
637
                         bool use_async_io, myf cache_myflags);
 
638
extern bool reinit_io_cache(IO_CACHE *info,enum cache_type type,
 
639
                               my_off_t seek_offset,bool use_async_io,
 
640
                               bool clear_cache);
 
641
extern void setup_io_cache(IO_CACHE* info);
 
642
extern int _my_b_read(IO_CACHE *info,uchar *Buffer,size_t Count);
 
643
extern int _my_b_read_r(IO_CACHE *info,uchar *Buffer,size_t Count);
 
644
extern void init_io_cache_share(IO_CACHE *read_cache, IO_CACHE_SHARE *cshare,
 
645
                                IO_CACHE *write_cache, uint num_threads);
 
646
extern void remove_io_thread(IO_CACHE *info);
 
647
extern int _my_b_seq_read(IO_CACHE *info,uchar *Buffer,size_t Count);
 
648
extern int _my_b_net_read(IO_CACHE *info,uchar *Buffer,size_t Count);
 
649
extern int _my_b_get(IO_CACHE *info);
 
650
extern int _my_b_async_read(IO_CACHE *info,uchar *Buffer,size_t Count);
 
651
extern int _my_b_write(IO_CACHE *info,const uchar *Buffer,size_t Count);
 
652
extern int my_b_append(IO_CACHE *info,const uchar *Buffer,size_t Count);
 
653
extern int my_b_safe_write(IO_CACHE *info,const uchar *Buffer,size_t Count);
 
654
 
 
655
extern int my_block_write(IO_CACHE *info, const uchar *Buffer,
 
656
                          size_t Count, my_off_t pos);
 
657
extern int my_b_flush_io_cache(IO_CACHE *info, int need_append_buffer_lock);
 
658
 
 
659
#define flush_io_cache(info) my_b_flush_io_cache((info),1)
 
660
 
 
661
extern int end_io_cache(IO_CACHE *info);
 
662
extern size_t my_b_fill(IO_CACHE *info);
 
663
extern void my_b_seek(IO_CACHE *info,my_off_t pos);
 
664
extern size_t my_b_gets(IO_CACHE *info, char *to, size_t max_length);
 
665
extern my_off_t my_b_filelength(IO_CACHE *info);
 
666
extern size_t my_b_printf(IO_CACHE *info, const char* fmt, ...);
 
667
extern size_t my_b_vprintf(IO_CACHE *info, const char* fmt, va_list ap);
 
668
extern bool open_cached_file(IO_CACHE *cache,const char *dir,
 
669
                                 const char *prefix, size_t cache_size,
 
670
                                 myf cache_myflags);
 
671
extern bool real_open_cached_file(IO_CACHE *cache);
 
672
extern void close_cached_file(IO_CACHE *cache);
 
673
File create_temp_file(char *to, const char *dir, const char *pfx,
 
674
                      int mode, myf MyFlags);
 
675
#define my_init_dynamic_array(A,B,C,D) init_dynamic_array2(A,B,NULL,C,D CALLER_INFO)
 
676
#define my_init_dynamic_array_ci(A,B,C,D) init_dynamic_array2(A,B,NULL,C,D ORIG_CALLER_INFO)
 
677
#define my_init_dynamic_array2(A,B,C,D,E) init_dynamic_array2(A,B,C,D,E CALLER_INFO)
 
678
#define my_init_dynamic_array2_ci(A,B,C,D,E) init_dynamic_array2(A,B,C,D,E ORIG_CALLER_INFO)
 
679
extern bool init_dynamic_array2(DYNAMIC_ARRAY *array,uint element_size,
 
680
                                   void *init_buffer, uint init_alloc, 
 
681
                                   uint alloc_increment
 
682
                                   CALLER_INFO_PROTO);
 
683
/* init_dynamic_array() function is deprecated */
 
684
extern bool init_dynamic_array(DYNAMIC_ARRAY *array,uint element_size,
 
685
                                  uint init_alloc,uint alloc_increment
 
686
                                  CALLER_INFO_PROTO);
 
687
extern bool insert_dynamic(DYNAMIC_ARRAY *array,uchar * element);
 
688
extern uchar *alloc_dynamic(DYNAMIC_ARRAY *array);
 
689
extern uchar *pop_dynamic(DYNAMIC_ARRAY*);
 
690
extern bool set_dynamic(DYNAMIC_ARRAY *array,uchar * element,uint array_index);
 
691
extern bool allocate_dynamic(DYNAMIC_ARRAY *array, uint max_elements);
 
692
extern void get_dynamic(DYNAMIC_ARRAY *array,uchar * element,uint array_index);
 
693
extern void delete_dynamic(DYNAMIC_ARRAY *array);
 
694
extern void delete_dynamic_element(DYNAMIC_ARRAY *array, uint array_index);
 
695
extern void freeze_size(DYNAMIC_ARRAY *array);
 
696
extern int  get_index_dynamic(DYNAMIC_ARRAY *array, uchar * element);
 
697
#define dynamic_array_ptr(array,array_index) ((array)->buffer+(array_index)*(array)->size_of_element)
 
698
#define dynamic_element(array,array_index,type) ((type)((array)->buffer) +(array_index))
 
699
#define push_dynamic(A,B) insert_dynamic((A),(B))
 
700
#define reset_dynamic(array) ((array)->elements= 0)
 
701
#define sort_dynamic(A,cmp) my_qsort((A)->buffer, (A)->elements, (A)->size_of_element, (cmp))
 
702
 
 
703
#define my_malloc_lock(A,B) my_malloc((A),(B))
 
704
#define my_free_lock(A,B) my_free((A),(B))
 
705
#define alloc_root_inited(A) ((A)->min_malloc != 0)
 
706
#define ALLOC_ROOT_MIN_BLOCK_SIZE (MALLOC_OVERHEAD + sizeof(USED_MEM) + 8)
 
707
#define clear_alloc_root(A) do { (A)->free= (A)->used= (A)->pre_alloc= 0; (A)->min_malloc=0;} while(0)
 
708
extern void init_alloc_root(MEM_ROOT *mem_root, size_t block_size,
 
709
                            size_t pre_alloc_size);
 
710
extern void *alloc_root(MEM_ROOT *mem_root, size_t Size);
 
711
extern void *multi_alloc_root(MEM_ROOT *mem_root, ...);
 
712
extern void free_root(MEM_ROOT *root, myf MyFLAGS);
 
713
extern void set_prealloc_root(MEM_ROOT *root, char *ptr);
 
714
extern void reset_root_defaults(MEM_ROOT *mem_root, size_t block_size,
 
715
                                size_t prealloc_size);
 
716
extern char *strdup_root(MEM_ROOT *root,const char *str);
 
717
extern char *strmake_root(MEM_ROOT *root,const char *str,size_t len);
 
718
extern void *memdup_root(MEM_ROOT *root,const void *str, size_t len);
361
719
extern int get_defaults_options(int argc, char **argv,
362
720
                                char **defaults, char **extra_defaults,
363
721
                                char **group_suffix);
364
722
extern int load_defaults(const char *conf_file, const char **groups,
365
723
                         int *argc, char ***argv);
 
724
extern int modify_defaults_file(const char *file_location, const char *option,
 
725
                                const char *option_value,
 
726
                                const char *section_name, int remove_option);
366
727
extern int my_search_option_files(const char *conf_file, int *argc,
367
 
                                  char ***argv, uint32_t *args_used,
 
728
                                  char ***argv, uint *args_used,
368
729
                                  Process_option_func func, void *func_ctx);
369
730
extern void free_defaults(char **argv);
370
731
extern void my_print_default_files(const char *conf_file);
371
732
extern void print_defaults(const char *conf_file, const char **groups);
372
 
extern ha_checksum my_checksum(ha_checksum crc, const unsigned char *mem,
 
733
extern bool my_compress(uchar *, size_t *, size_t *);
 
734
extern bool my_uncompress(uchar *, size_t , size_t *);
 
735
extern uchar *my_compress_alloc(const uchar *packet, size_t *len,
 
736
                                size_t *complen);
 
737
extern ha_checksum my_checksum(ha_checksum crc, const uchar *mem,
373
738
                               size_t count);
374
739
extern void my_sleep(uint32_t m_seconds);
375
 
 
376
 
 
 
740
extern uint my_set_max_open_files(uint files);
 
741
void my_free_open_file_info(void);
 
742
 
 
743
extern time_t my_time(myf flags);
 
744
extern uint64_t my_getsystime(void);
 
745
extern uint64_t my_micro_time(void);
 
746
extern uint64_t my_micro_time_and_time(time_t *time_arg);
 
747
time_t my_time_possible_from_micro(uint64_t microtime);
 
748
extern bool my_gethwaddr(uchar *to);
 
749
 
 
750
#ifdef HAVE_SYS_MMAN_H
 
751
#include <sys/mman.h>
 
752
 
 
753
#ifndef MAP_NOSYNC
 
754
#define MAP_NOSYNC      0
 
755
#endif
 
756
#ifndef MAP_NORESERVE
 
757
#define MAP_NORESERVE 0         /* For irix and AIX */
 
758
#endif
 
759
 
 
760
#ifdef HAVE_MMAP64
 
761
#define my_mmap(a,b,c,d,e,f)    mmap64(a,b,c,d,e,f)
 
762
#else
 
763
#define my_mmap(a,b,c,d,e,f)    mmap(a,b,c,d,e,f)
 
764
#endif
 
765
#define my_munmap(a,b)          munmap((a),(b))
 
766
 
 
767
#else
 
768
/* not a complete set of mmap() flags, but only those that nesessary */
 
769
#define PROT_READ        1
 
770
#define PROT_WRITE       2
 
771
#define MAP_NORESERVE    0
 
772
#define MAP_SHARED       0x0001
 
773
#define MAP_PRIVATE      0x0002
 
774
#define MAP_NOSYNC       0x0800
 
775
#define MAP_FAILED       ((void *)-1)
 
776
#define MS_SYNC          0x0000
 
777
#define HAVE_MMAP
 
778
 
 
779
void *my_mmap(void *, size_t, int, int, int, my_off_t);
 
780
int my_munmap(void *, size_t);
 
781
#endif
 
782
 
 
783
/* character sets */
 
784
extern uint get_charset_number(const char *cs_name, uint cs_flags);
 
785
extern uint get_collation_number(const char *name);
 
786
extern const char *get_charset_name(uint cs_number);
 
787
 
 
788
extern const CHARSET_INFO *get_charset(uint cs_number, myf flags);
 
789
extern const CHARSET_INFO *get_charset_by_name(const char *cs_name, myf flags);
 
790
extern const CHARSET_INFO *get_charset_by_csname(const char *cs_name, uint cs_flags, myf my_flags);
 
791
 
 
792
extern bool resolve_charset(const char *cs_name,
 
793
                            const CHARSET_INFO *default_cs,
 
794
                            const CHARSET_INFO **cs);
 
795
extern bool resolve_collation(const char *cl_name,
 
796
                             const CHARSET_INFO *default_cl,
 
797
                             const CHARSET_INFO **cl);
 
798
 
 
799
extern void free_charsets(void);
 
800
extern char *get_charsets_dir(char *buf);
 
801
extern bool my_charset_same(const CHARSET_INFO *cs1, const CHARSET_INFO *cs2);
 
802
extern bool init_compiled_charsets(myf flags);
 
803
extern void add_compiled_collation(CHARSET_INFO *cs);
 
804
extern size_t escape_string_for_drizzle(const CHARSET_INFO *charset_info,
 
805
                                        char *to, size_t to_length,
 
806
                                        const char *from, size_t length);
 
807
extern size_t escape_quotes_for_drizzle(const CHARSET_INFO *charset_info,
 
808
                                        char *to, size_t to_length,
 
809
                                        const char *from, size_t length);
377
810
 
378
811
extern void thd_increment_bytes_sent(uint32_t length);
379
812
extern void thd_increment_bytes_received(uint32_t length);
380
813
extern void thd_increment_net_big_packet_count(uint32_t length);
381
814
 
382
 
} /* namespace internal */
383
 
} /* namespace drizzled */
384
 
 
385
 
#endif /* DRIZZLED_INTERNAL_MY_SYS_H */
 
815
C_MODE_END
 
816
#endif /* _my_sys_h */