2007-09-06 20:13:56 +00:00
# ifndef _DB_H
# define _DB_H
2008-01-24 15:10:32 +00:00
/* This code generated by make_db_h. Copyright (c) 2007, 2008 Tokutek */
# ident "Copyright (c) 2007, 2008 Tokutek Inc. All rights reserved."
2007-09-06 20:13:56 +00:00
# include <sys/types.h>
2007-10-15 03:32:32 +00:00
/*stdio is needed for the FILE* in db->verify*/
# include <stdio.h>
2007-07-13 19:37:47 +00:00
# if defined(__cplusplus)
extern " C " {
# endif
2007-11-28 20:04:35 +00:00
# define TOKUDB 1
2013-04-16 23:57:48 -04:00
# define TOKUDB_NATIVE_H 1
2007-09-19 18:34:17 +00:00
# define DB_VERSION_MAJOR 4
2013-04-16 23:57:39 -04:00
# define DB_VERSION_MINOR 6
2013-04-16 23:57:39 -04:00
# define DB_VERSION_PATCH 19
2007-09-06 20:13:56 +00:00
# ifndef _TOKUDB_WRAP_H
2013-04-16 23:57:39 -04:00
# define DB_VERSION_STRING "Tokutek: TokuDB 4.6.19"
2007-11-14 17:52:59 +00:00
# else
# define DB_VERSION_STRING_ydb "Tokutek: TokuDB (wrapped bdb)"
2007-07-13 19:37:47 +00:00
# endif
2013-04-16 23:57:43 -04:00
# ifndef TOKU_OFF_T_DEFINED
# define TOKU_OFF_T_DEFINED
typedef int64_t toku_off_t ;
# endif
2007-09-06 20:13:56 +00:00
typedef struct __toku_db_env DB_ENV ;
typedef struct __toku_db_key_range DB_KEY_RANGE ;
typedef struct __toku_db_lsn DB_LSN ;
typedef struct __toku_db DB ;
typedef struct __toku_db_txn DB_TXN ;
typedef struct __toku_db_txn_active DB_TXN_ACTIVE ;
typedef struct __toku_db_txn_stat DB_TXN_STAT ;
typedef struct __toku_dbc DBC ;
typedef struct __toku_dbt DBT ;
2008-01-10 16:29:45 +00:00
typedef u_int32_t db_recno_t ;
2013-04-16 23:57:41 -04:00
typedef int ( * YDB_CALLBACK_FUNCTION ) ( DBT const * , DBT const * , void * ) ;
typedef int ( * YDB_HEAVISIDE_CALLBACK_FUNCTION ) ( DBT const * key , DBT const * value , void * extra_f , int r_h ) ;
typedef int ( * YDB_HEAVISIDE_FUNCTION ) ( const DBT * key , const DBT * value , void * extra_h ) ;
2013-04-16 23:57:48 -04:00
# include <tdb-internal.h>
2013-04-16 23:57:47 -04:00
typedef struct __toku_db_btree_stat64 {
u_int64_t bt_nkeys ; /* how many unique keys (guaranteed only to be an estimate, even when flattened) */
u_int64_t bt_ndata ; /* how many key-value pairs (an estimate, but exact when flattened) */
u_int64_t bt_dsize ; /* how big are the keys+values (not counting the lengths) (an estimate, unless flattened) */
u_int64_t bt_fsize ; /* how big is the underlying file */
} DB_BTREE_STAT64 ;
2007-07-13 19:37:47 +00:00
typedef enum {
2007-12-11 19:34:21 +00:00
DB_BTREE = 1 ,
DB_UNKNOWN = 5
2007-07-13 19:37:47 +00:00
} DBTYPE ;
2007-11-14 17:52:59 +00:00
# ifndef _TOKUDB_WRAP_H
2007-11-29 21:06:11 +00:00
# define DB_VERB_DEADLOCK 1
2013-04-16 23:57:39 -04:00
# define DB_VERB_RECOVERY 8
# define DB_VERB_REPLICATION 32
# define DB_VERB_WAITSFOR 64
# define DB_DBT_MALLOC 8
# define DB_DBT_REALLOC 64
# define DB_DBT_USERMEM 256
# define DB_DBT_DUPOK 2
2007-09-06 20:13:56 +00:00
# define DB_ARCH_ABS 1
# define DB_ARCH_LOG 4
# define DB_CREATE 1
2007-12-18 16:22:21 +00:00
# define DB_CXX_NO_EXCEPTIONS 1
2013-04-16 23:57:39 -04:00
# define DB_EXCL 16384
# define DB_PRIVATE 8388608
# define DB_RDONLY 32
# define DB_RECOVER 64
# define DB_THREAD 128
# define DB_TXN_NOSYNC 512
2007-09-06 20:13:56 +00:00
# define DB_LOCK_DEFAULT 1
2007-11-29 21:06:11 +00:00
# define DB_LOCK_OLDEST 7
# define DB_LOCK_RANDOM 8
2013-04-16 23:57:39 -04:00
# define DB_DUP 32768
# define DB_DUPSORT 65536
# define DB_KEYFIRST 13
# define DB_KEYLAST 14
# define DB_NODUPDATA 19
# define DB_NOOVERWRITE 20
2007-12-14 14:26:22 +00:00
# define DB_YESOVERWRITE 254
# define DB_OPFLAGS_MASK 255
2013-04-16 23:57:39 -04:00
# define DB_AUTO_COMMIT 33554432
# define DB_INIT_LOCK 131072
# define DB_INIT_LOG 262144
# define DB_INIT_MPOOL 524288
# define DB_INIT_TXN 2097152
# define DB_USE_ENVIRON 16384
# define DB_USE_ENVIRON_ROOT 32768
# define DB_READ_UNCOMMITTED 134217728
2007-11-29 21:06:11 +00:00
# define DB_KEYEXIST -30996
# define DB_LOCK_DEADLOCK -30995
2008-01-22 00:01:01 +00:00
# define DB_LOCK_NOTGRANTED -30994
2007-11-29 21:06:11 +00:00
# define DB_NOTFOUND -30989
2013-04-16 23:57:39 -04:00
# define DB_SECONDARY_BAD -30974
2007-11-30 05:04:06 +00:00
# define DB_DONOTINDEX -30998
2007-12-10 17:04:02 +00:00
# define DB_BUFFER_SMALL -30999
2007-09-06 20:13:56 +00:00
# define DB_BADFORMAT -30500
2007-11-28 20:04:35 +00:00
# define DB_DELETE_ANY 65536
2013-04-16 23:57:39 -04:00
# define DB_FIRST 7
# define DB_GET_BOTH 8
# define DB_GET_BOTH_RANGE 10
# define DB_LAST 15
# define DB_CURRENT 6
# define DB_NEXT 16
# define DB_NEXT_DUP 17
# define DB_NEXT_NODUP 18
# define DB_PREV 23
2013-04-16 23:57:41 -04:00
# define DB_PREV_DUP 24
2013-04-16 23:57:39 -04:00
# define DB_PREV_NODUP 25
# define DB_SET 26
# define DB_SET_RANGE 27
2008-02-03 18:26:01 +00:00
# define DB_CURRENT_BINDING 253
2013-04-16 23:57:39 -04:00
# define DB_RMW 1073741824
2008-06-10 15:39:31 +00:00
# define DB_PRELOCKED 0x00800000
2008-06-10 19:46:00 +00:00
# define DB_PRELOCKED_WRITE 0x00400000
2007-11-30 05:04:06 +00:00
# define DB_DBT_APPMALLOC 1
2013-04-16 23:57:39 -04:00
# define DB_DBT_MULTIPLE 16
# define DB_LOG_AUTOREMOVE 524288
# define DB_TXN_WRITE_NOSYNC 4096
# define DB_TXN_NOWAIT 1024
2008-02-08 19:11:33 +00:00
# define DB_TXN_SYNC 16384
2007-10-19 17:05:10 +00:00
# endif
2008-03-19 14:39:27 +00:00
/* TOKUDB specific error codes */
# define TOKUDB_OUT_OF_LOCKS -100000
2008-05-16 20:09:13 +00:00
# define TOKUDB_SUCCEEDED_EARLY -100001
2013-04-16 23:57:47 -04:00
# define TOKUDB_DICTIONARY_TOO_OLD -100004
2013-04-16 23:57:49 -04:00
# define TOKUDB_DICTIONARY_TOO_NEW -100005
# define TOKUDB_DICTIONARY_NO_HEADER -100006
2013-04-16 23:57:41 -04:00
# define TOKUDB_FOUND_BUT_REJECTED -100002
# define TOKUDB_USER_CALLBACK_ERROR -100003
2007-09-06 20:13:56 +00:00
/* in wrap mode, top-level function txn_begin is renamed, but the field isn't renamed, so we have to hack it here.*/
# ifdef _TOKUDB_WRAP_H
2007-07-17 15:38:36 +00:00
# undef txn_begin
# endif
2007-09-06 20:13:56 +00:00
struct __toku_db_env {
struct __toku_db_env_internal * i ;
2013-04-16 23:57:48 -04:00
# define db_env_struct_i(x) ((x)->i)
2013-04-16 23:57:49 -04:00
int ( * checkpointing_set_period ) ( DB_ENV * , u_int32_t ) /* Change the delay between automatic checkpoints. 0 means disabled. */ ;
int ( * checkpointing_get_period ) ( DB_ENV * , u_int32_t * ) /* Retrieve the delay between automatic checkpoints. 0 means disabled. */ ;
2013-04-16 23:57:47 -04:00
int ( * checkpointing_postpone ) ( DB_ENV * ) /* Use for 'rename table' or any other operation that must be disjoint from a checkpoint */ ;
int ( * checkpointing_resume ) ( DB_ENV * ) /* Alert tokudb 'postpone' is no longer necessary */ ;
int ( * checkpointing_begin_atomic_operation ) ( DB_ENV * ) /* Begin a set of operations (that must be atomic as far as checkpoints are concerned). i.e. inserting into every index in one table */ ;
int ( * checkpointing_end_atomic_operation ) ( DB_ENV * ) /* End a set of operations (that must be atomic as far as checkpoints are concerned). */ ;
int ( * set_default_bt_compare ) ( DB_ENV * , int ( * bt_compare ) ( DB * , const DBT * , const DBT * ) ) /* Set default (key) comparison function for all DBs in this environment. Required for RECOVERY since you cannot open the DBs manually. */ ;
int ( * set_default_dup_compare ) ( DB_ENV * , int ( * bt_compare ) ( DB * , const DBT * , const DBT * ) ) /* Set default (val) comparison function for all DBs in this environment. Required for RECOVERY since you cannot open the DBs manually. */ ;
2013-04-16 23:57:48 -04:00
void * app_private ;
void * api1_internal ;
int ( * close ) ( DB_ENV * , u_int32_t ) ;
void ( * err ) ( const DB_ENV * , int , const char * , . . . ) ;
int ( * get_cachesize ) ( DB_ENV * , u_int32_t * , u_int32_t * , int * ) ;
int ( * get_flags ) ( DB_ENV * , u_int32_t * ) ;
int ( * get_lg_max ) ( DB_ENV * , u_int32_t * ) ;
int ( * get_lk_max_locks ) ( DB_ENV * , u_int32_t * ) ;
int ( * log_archive ) ( DB_ENV * , char * * [ ] , u_int32_t ) ;
int ( * log_flush ) ( DB_ENV * , const DB_LSN * ) ;
int ( * open ) ( DB_ENV * , const char * , u_int32_t , int ) ;
int ( * set_cachesize ) ( DB_ENV * , u_int32_t , u_int32_t , int ) ;
int ( * set_data_dir ) ( DB_ENV * , const char * ) ;
void ( * set_errcall ) ( DB_ENV * , void ( * ) ( const DB_ENV * , const char * , const char * ) ) ;
void ( * set_errfile ) ( DB_ENV * , FILE * ) ;
void ( * set_errpfx ) ( DB_ENV * , const char * ) ;
int ( * set_flags ) ( DB_ENV * , u_int32_t , int ) ;
int ( * set_lg_bsize ) ( DB_ENV * , u_int32_t ) ;
int ( * set_lg_dir ) ( DB_ENV * , const char * ) ;
int ( * set_lg_max ) ( DB_ENV * , u_int32_t ) ;
int ( * set_lk_detect ) ( DB_ENV * , u_int32_t ) ;
int ( * set_lk_max_locks ) ( DB_ENV * , u_int32_t ) ;
int ( * set_tmp_dir ) ( DB_ENV * , const char * ) ;
int ( * set_verbose ) ( DB_ENV * , u_int32_t , int ) ;
int ( * txn_begin ) ( DB_ENV * , DB_TXN * , DB_TXN * * , u_int32_t ) ;
int ( * txn_checkpoint ) ( DB_ENV * , u_int32_t , u_int32_t , u_int32_t ) ;
int ( * txn_stat ) ( DB_ENV * , DB_TXN_STAT * * , u_int32_t ) ;
2007-09-06 20:13:56 +00:00
} ;
struct __toku_db_key_range {
2013-04-16 23:57:48 -04:00
double less ;
double equal ;
double greater ;
2007-09-06 20:13:56 +00:00
} ;
struct __toku_db_lsn {
} ;
2013-04-16 23:57:47 -04:00
struct __toku_dbt {
2013-04-16 23:57:48 -04:00
void * data ;
u_int32_t size ;
u_int32_t ulen ;
u_int32_t flags ;
2013-04-16 23:57:47 -04:00
} ;
2013-04-16 23:57:48 -04:00
typedef int ( * toku_dbt_upgradef ) ( DB * ,
u_int32_t old_version , const DBT * old_descriptor , const DBT * old_key , const DBT * old_val ,
u_int32_t new_version , const DBT * new_descriptor , const DBT * new_key , const DBT * new_val ) ;
2007-09-06 20:13:56 +00:00
struct __toku_db {
struct __toku_db_internal * i ;
2013-04-16 23:57:48 -04:00
# define db_struct_i(x) ((x)->i)
2008-05-13 13:09:22 +00:00
int ( * key_range64 ) ( DB * , DB_TXN * , DBT * , u_int64_t * less , u_int64_t * equal , u_int64_t * greater , int * is_exact ) ;
2013-04-16 23:57:47 -04:00
int ( * stat64 ) ( DB * , DB_TXN * , DB_BTREE_STAT64 * ) ;
2013-04-16 23:57:48 -04:00
void * app_private ;
DB_ENV * dbenv ;
2013-04-16 23:57:47 -04:00
int ( * pre_acquire_read_lock ) ( DB * , DB_TXN * , const DBT * , const DBT * , const DBT * , const DBT * ) ;
2008-07-09 16:55:59 +00:00
int ( * pre_acquire_table_lock ) ( DB * , DB_TXN * ) ;
const DBT * ( * dbt_pos_infty ) ( void ) /* Return the special DBT that refers to positive infinity in the lock table.*/ ;
const DBT * ( * dbt_neg_infty ) ( void ) /* Return the special DBT that refers to negative infinity in the lock table.*/ ;
2008-08-18 03:27:37 +00:00
int ( * delboth ) ( DB * , DB_TXN * , DBT * , DBT * , u_int32_t ) /* Delete the key/value pair. */ ;
2013-04-16 23:57:42 -04:00
int ( * row_size_supported ) ( DB * , u_int32_t ) /* Test whether a row size is supported. */ ;
2013-04-16 23:57:48 -04:00
const DBT * descriptor /* saved row/dictionary descriptor for aiding in comparisons */ ;
2013-04-16 23:57:48 -04:00
int ( * set_descriptor ) ( DB * , u_int32_t version , const DBT * descriptor , toku_dbt_upgradef dbt_userformat_upgrade ) /* set row/dictionary descriptor for a db. Available only while db is open */ ;
2013-04-16 23:57:48 -04:00
void * api_internal ;
int ( * close ) ( DB * , u_int32_t ) ;
int ( * cursor ) ( DB * , DB_TXN * , DBC * * , u_int32_t ) ;
int ( * del ) ( DB * , DB_TXN * , DBT * , u_int32_t ) ;
int ( * fd ) ( DB * , int * ) ;
int ( * get ) ( DB * , DB_TXN * , DBT * , DBT * , u_int32_t ) ;
int ( * get_flags ) ( DB * , u_int32_t * ) ;
int ( * get_pagesize ) ( DB * , u_int32_t * ) ;
int ( * key_range ) ( DB * , DB_TXN * , DBT * , DB_KEY_RANGE * , u_int32_t ) ;
int ( * open ) ( DB * , DB_TXN * , const char * , const char * , DBTYPE , u_int32_t , int ) ;
int ( * put ) ( DB * , DB_TXN * , DBT * , DBT * , u_int32_t ) ;
int ( * remove ) ( DB * , const char * , const char * , u_int32_t ) ;
int ( * rename ) ( DB * , const char * , const char * , const char * , u_int32_t ) ;
int ( * set_bt_compare ) ( DB * , int ( * ) ( DB * , const DBT * , const DBT * ) ) ;
int ( * set_dup_compare ) ( DB * , int ( * ) ( DB * , const DBT * , const DBT * ) ) ;
void ( * set_errfile ) ( DB * , FILE * ) ;
int ( * set_flags ) ( DB * , u_int32_t ) ;
int ( * set_pagesize ) ( DB * , u_int32_t ) ;
int ( * stat ) ( DB * , void * , u_int32_t ) ;
int ( * truncate ) ( DB * , DB_TXN * , u_int32_t * , u_int32_t ) ;
int ( * verify ) ( DB * , const char * , const char * , FILE * , u_int32_t ) ;
2007-09-06 20:13:56 +00:00
} ;
struct __toku_db_txn_active {
2013-04-16 23:57:48 -04:00
u_int32_t txnid ;
DB_LSN lsn ;
2007-09-06 20:13:56 +00:00
} ;
2013-04-16 23:57:38 -04:00
struct txn_stat {
u_int64_t rolltmp_raw_count ;
} ;
2007-09-06 20:13:56 +00:00
struct __toku_db_txn {
2013-04-16 23:57:48 -04:00
DB_ENV * mgrp /*In TokuDB, mgrp is a DB_ENV not a DB_TXNMGR*/ ;
DB_TXN * parent ;
struct __toku_db_txn_internal ii ;
# define db_txn_struct_i(x) (&(x)->ii)
2013-04-16 23:57:38 -04:00
int ( * txn_stat ) ( DB_TXN * , struct txn_stat * * ) ;
2013-04-16 23:57:48 -04:00
void * api_internal ;
int ( * abort ) ( DB_TXN * ) ;
int ( * commit ) ( DB_TXN * , u_int32_t ) ;
u_int32_t ( * id ) ( DB_TXN * ) ;
2007-09-06 20:13:56 +00:00
} ;
struct __toku_db_txn_stat {
2013-04-16 23:57:48 -04:00
u_int32_t st_nactive ;
DB_TXN_ACTIVE * st_txnarray ;
2007-09-06 20:13:56 +00:00
} ;
struct __toku_dbc {
2013-04-16 23:57:48 -04:00
DB * dbp ;
struct __toku_dbc_internal ii ;
# define dbc_struct_i(x) (&(x)->ii)
2013-04-16 23:57:41 -04:00
int ( * c_getf_first ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_last ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_next ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_next_dup ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_next_nodup ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_prev ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_prev_dup ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_prev_nodup ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_current ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_current_binding ) ( DBC * , u_int32_t , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_heaviside ) ( DBC * , u_int32_t , YDB_HEAVISIDE_CALLBACK_FUNCTION f , void * extra_f , YDB_HEAVISIDE_FUNCTION h , void * extra_h , int direction ) ;
int ( * c_getf_set ) ( DBC * , u_int32_t , DBT * , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_set_range ) ( DBC * , u_int32_t , DBT * , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_get_both ) ( DBC * , u_int32_t , DBT * , DBT * , YDB_CALLBACK_FUNCTION , void * ) ;
int ( * c_getf_get_both_range ) ( DBC * , u_int32_t , DBT * , DBT * , YDB_CALLBACK_FUNCTION , void * ) ;
2013-04-16 23:57:48 -04:00
int ( * c_close ) ( DBC * ) ;
int ( * c_count ) ( DBC * , db_recno_t * , u_int32_t ) ;
int ( * c_del ) ( DBC * , u_int32_t ) ;
int ( * c_get ) ( DBC * , DBT * , DBT * , u_int32_t ) ;
2007-09-06 20:13:56 +00:00
} ;
# ifdef _TOKUDB_WRAP_H
# define txn_begin txn_begin_tokudb
2007-07-17 15:38:36 +00:00
# endif
2008-03-05 11:54:58 +00:00
int db_env_create ( DB_ENV * * , u_int32_t ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
int db_create ( DB * * , DB_ENV * , u_int32_t ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
char * db_strerror ( int ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
const char * db_version ( int * , int * , int * ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
int log_compare ( const DB_LSN * , const DB_LSN * ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2008-03-09 02:39:37 +00:00
int db_env_set_func_fsync ( int ( * ) ( int ) ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2008-04-12 09:12:22 +00:00
int toku_set_trace_file ( char * fname ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
int toku_close_trace_file ( void ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2013-04-16 23:57:38 -04:00
int db_env_set_func_free ( void ( * ) ( void * ) ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2013-04-16 23:57:34 -04:00
int db_env_set_func_malloc ( void * ( * ) ( size_t ) ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2013-04-16 23:57:42 -04:00
int db_env_set_func_pwrite ( ssize_t ( * ) ( int , const void * , size_t , toku_off_t ) ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2013-04-16 23:57:38 -04:00
int db_env_set_func_write ( ssize_t ( * ) ( int , const void * , size_t ) ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2013-04-16 23:57:34 -04:00
int db_env_set_func_realloc ( void * ( * ) ( void * , size_t ) ) __attribute__ ( ( __visibility__ ( " default " ) ) ) ;
2007-07-13 19:37:47 +00:00
# if defined(__cplusplus)
}
# endif
# endif