~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/internal/my_sys.h

Merge Monty.

Show diffs side-by-side

added added

removed removed

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