2007-11-29 14:18:54 +00:00
|
|
|
/* -*- mode: C; c-basic-offset: 4 -*- */
|
2007-07-13 19:37:47 +00:00
|
|
|
#ifndef BRT_H
|
|
|
|
#define BRT_H
|
2008-01-24 15:10:32 +00:00
|
|
|
#ident "Copyright (c) 2007, 2008 Tokutek Inc. All rights reserved."
|
2007-07-13 19:37:47 +00:00
|
|
|
|
|
|
|
// This must be first to make the 64-bit file mode work right in Linux
|
|
|
|
#define _FILE_OFFSET_BITS 64
|
|
|
|
#include "brttypes.h"
|
|
|
|
#include "ybt.h"
|
2007-09-06 20:13:56 +00:00
|
|
|
#include "../include/db.h"
|
2007-07-13 19:37:47 +00:00
|
|
|
#include "cachetable.h"
|
2007-09-28 17:11:22 +00:00
|
|
|
#include "log.h"
|
2008-01-25 15:43:37 +00:00
|
|
|
#include "brt-search.h"
|
2007-11-21 13:07:49 +00:00
|
|
|
|
2007-11-29 15:09:14 +00:00
|
|
|
int toku_open_brt (const char *fname, const char *dbname, int is_create, BRT *, int nodesize, CACHETABLE, TOKUTXN, int(*)(DB*,const DBT*,const DBT*), DB*);
|
2007-11-14 17:58:38 +00:00
|
|
|
|
2007-11-29 14:44:03 +00:00
|
|
|
int toku_brt_create(BRT *);
|
2007-11-29 19:32:53 +00:00
|
|
|
int toku_brt_set_flags(BRT, unsigned int flags);
|
|
|
|
int toku_brt_get_flags(BRT, unsigned int *flags);
|
|
|
|
int toku_brt_set_nodesize(BRT, unsigned int nodesize);
|
|
|
|
int toku_brt_get_nodesize(BRT, unsigned int *nodesize);
|
2007-11-29 15:09:14 +00:00
|
|
|
int toku_brt_set_bt_compare(BRT, int (*bt_compare)(DB *, const DBT*, const DBT*));
|
|
|
|
int toku_brt_set_dup_compare(BRT, int (*dup_compare)(DB *, const DBT*, const DBT*));
|
2007-11-14 17:58:38 +00:00
|
|
|
int brt_set_cachetable(BRT, CACHETABLE);
|
2008-01-24 13:51:34 +00:00
|
|
|
int toku_brt_open(BRT, const char *fname, const char *fname_in_env, const char *dbname, int is_create, int only_create, int load_flags, CACHETABLE ct, TOKUTXN txn, DB *db);
|
2007-11-29 15:09:14 +00:00
|
|
|
int toku_brt_remove_subdb(BRT brt, const char *dbname, u_int32_t flags);
|
|
|
|
|
|
|
|
int toku_brt_insert (BRT, DBT *, DBT *, TOKUTXN);
|
|
|
|
int toku_brt_lookup (BRT brt, DBT *k, DBT *v);
|
2008-01-28 20:49:10 +00:00
|
|
|
int toku_brt_delete (BRT brt, DBT *k, TOKUTXN);
|
|
|
|
int toku_brt_delete_both (BRT brt, DBT *k, DBT *v, TOKUTXN);
|
2007-11-29 15:09:14 +00:00
|
|
|
int toku_close_brt (BRT);
|
|
|
|
int toku_dump_brt (BRT brt);
|
2007-07-13 19:37:47 +00:00
|
|
|
void brt_fsync (BRT); /* fsync, but don't clear the caches. */
|
|
|
|
|
|
|
|
void brt_flush (BRT); /* fsync and clear the caches. */
|
|
|
|
|
2007-09-21 17:55:49 +00:00
|
|
|
/* create and initialize a cache table
|
2007-11-14 17:58:38 +00:00
|
|
|
cachesize is the upper limit on the size of the size of the values in the table
|
|
|
|
pass 0 if you want the default */
|
|
|
|
|
2007-11-29 14:44:03 +00:00
|
|
|
int toku_brt_create_cachetable(CACHETABLE *t, long cachesize, LSN initial_lsn, TOKULOGGER);
|
2007-09-21 17:55:49 +00:00
|
|
|
|
2007-11-29 14:44:03 +00:00
|
|
|
extern int toku_brt_debug_mode;
|
2007-11-20 00:35:31 +00:00
|
|
|
int toku_verify_brt (BRT brt);
|
2007-07-13 19:37:47 +00:00
|
|
|
|
2007-11-28 19:00:21 +00:00
|
|
|
//int show_brt_blocknumbers(BRT);
|
2007-07-13 19:37:47 +00:00
|
|
|
|
|
|
|
typedef struct brt_cursor *BRT_CURSOR;
|
2007-11-29 14:44:03 +00:00
|
|
|
int toku_brt_cursor (BRT, BRT_CURSOR*);
|
|
|
|
int toku_brt_cursor_get (BRT_CURSOR cursor, DBT *kbt, DBT *vbt, int brtc_flags, TOKUTXN);
|
2008-01-28 20:49:10 +00:00
|
|
|
int toku_brt_cursor_delete(BRT_CURSOR cursor, int flags, TOKUTXN);
|
2007-11-29 14:44:03 +00:00
|
|
|
int toku_brt_cursor_close (BRT_CURSOR curs);
|
2008-02-11 20:00:19 +00:00
|
|
|
BOOL toku_brt_cursor_uninitialized(BRT_CURSOR c);
|
2007-07-13 19:37:47 +00:00
|
|
|
|
2007-11-14 17:58:38 +00:00
|
|
|
typedef struct brtenv *BRTENV;
|
|
|
|
int brtenv_checkpoint (BRTENV env);
|
|
|
|
|
2007-11-28 19:00:21 +00:00
|
|
|
extern int toku_brt_do_push_cmd; // control whether push occurs eagerly.
|
|
|
|
|
2007-12-10 18:54:12 +00:00
|
|
|
|
|
|
|
int toku_brt_dbt_set_key (BRT, DBT*, bytevec val, ITEMLEN vallen);
|
|
|
|
int toku_brt_dbt_set_value (BRT, DBT*, bytevec val, ITEMLEN vallen);
|
|
|
|
|
2008-01-11 14:38:49 +00:00
|
|
|
int toku_brt_get_fd(BRT, int *);
|
|
|
|
|
2007-07-13 19:37:47 +00:00
|
|
|
#endif
|