2011-08-09 16:13:55 +08:00
|
|
|
/* mdb.h - memory-mapped database library header file */
|
|
|
|
/*
|
|
|
|
* Copyright 2011 Howard Chu, Symas Corp.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
|
|
|
* Public License.
|
|
|
|
*
|
|
|
|
* A copy of this license is available in the file LICENSE in the
|
|
|
|
* top-level directory of the distribution or, alternatively, at
|
|
|
|
* <http://www.OpenLDAP.org/license.html>.
|
|
|
|
*
|
|
|
|
* This code is derived from btree.c written by Martin Hedenfalk.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2009, 2010 Martin Hedenfalk <martin@bzero.se>
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
2011-06-28 13:39:24 +08:00
|
|
|
#ifndef _MDB_H_
|
|
|
|
#define _MDB_H_
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
2011-08-12 11:23:39 +08:00
|
|
|
#define MDB_VERSION_MAJOR 0
|
|
|
|
#define MDB_VERSION_MINOR 8
|
|
|
|
#define MDB_VERSION_PATCH 0
|
2011-08-12 14:20:16 +08:00
|
|
|
#define MDB_VERINT(a,b,c) ((a << 24) | (b << 16) | c)
|
|
|
|
#define MDB_VERSION_FULL \
|
|
|
|
MDB_VERINT(MDB_VERSION_MAJOR,MDB_VERSION_MINOR,MDB_VERSION_PATCH)
|
|
|
|
#define MDB_VERSION_DATE "August 11, 2011"
|
|
|
|
#define MDB_VERSTR(a,b,c,d) "MDB " #a "." #b "." #c ": (" #d ")"
|
|
|
|
#define MDB_VERFOO(a,b,c,d) MDB_VERSTR(a,b,c,d)
|
|
|
|
#define MDB_VERSION_STRING \
|
|
|
|
MDB_VERFOO(MDB_VERSION_MAJOR,MDB_VERSION_MINOR,MDB_VERSION_PATCH,MDB_VERSION_DATE)
|
2011-08-12 11:23:39 +08:00
|
|
|
|
2011-06-28 13:39:24 +08:00
|
|
|
struct MDB_cursor;
|
|
|
|
struct MDB_txn;
|
|
|
|
struct MDB_env;
|
|
|
|
|
|
|
|
typedef struct MDB_cursor MDB_cursor;
|
|
|
|
typedef struct MDB_txn MDB_txn;
|
|
|
|
typedef struct MDB_env MDB_env;
|
|
|
|
|
2011-08-03 08:59:37 +08:00
|
|
|
typedef unsigned int MDB_dbi;
|
|
|
|
|
2011-06-28 13:39:24 +08:00
|
|
|
typedef struct MDB_val {
|
|
|
|
size_t mv_size;
|
2011-08-12 11:16:10 +08:00
|
|
|
void *mv_data;
|
2011-06-28 13:39:24 +08:00
|
|
|
} MDB_val;
|
|
|
|
|
|
|
|
typedef int (MDB_cmp_func)(const MDB_val *a, const MDB_val *b);
|
|
|
|
typedef void (MDB_rel_func)(void *ptr, void *oldptr);
|
|
|
|
|
2011-08-11 16:36:12 +08:00
|
|
|
#define MDB_NOOVERWRITE 0x10
|
|
|
|
#define MDB_NODUPDATA 0x20
|
|
|
|
#define MDB_DEL_DUP 0x40
|
2011-08-11 14:21:36 +08:00
|
|
|
|
2011-06-28 13:39:24 +08:00
|
|
|
typedef enum MDB_cursor_op { /* cursor operations */
|
|
|
|
MDB_FIRST,
|
2011-08-11 13:50:34 +08:00
|
|
|
MDB_GET_BOTH, /* position at key/data */
|
|
|
|
MDB_GET_BOTH_RANGE, /* position at key, nearest data */
|
2011-08-09 17:22:28 +08:00
|
|
|
MDB_LAST,
|
2011-08-11 13:50:34 +08:00
|
|
|
MDB_NEXT,
|
|
|
|
MDB_NEXT_DUP,
|
|
|
|
MDB_NEXT_NODUP,
|
2011-08-09 18:26:45 +08:00
|
|
|
MDB_PREV,
|
2011-08-11 13:50:34 +08:00
|
|
|
MDB_PREV_DUP,
|
|
|
|
MDB_PREV_NODUP,
|
|
|
|
MDB_SET, /* position at key, or fail */
|
|
|
|
MDB_SET_RANGE /* position at given key */
|
2011-06-28 13:39:24 +08:00
|
|
|
} MDB_cursor_op;
|
|
|
|
|
|
|
|
/* return codes */
|
2011-08-16 09:37:30 +08:00
|
|
|
/* BerkeleyDB uses -30800 to -30999, we'll go under them */
|
2011-06-28 13:39:24 +08:00
|
|
|
#define MDB_SUCCESS 0
|
2011-08-16 09:40:50 +08:00
|
|
|
#define MDB_KEYEXIST (-30799) /* key/data pair already exists */
|
|
|
|
#define MDB_NOTFOUND (-30798) /* key/data pair not found (EOF) */
|
|
|
|
#define MDB_PAGE_NOTFOUND (-30797) /* Requested page not found */
|
|
|
|
#define MDB_CORRUPTED (-30796) /* Located page was wrong type */
|
|
|
|
#define MDB_PANIC (-30795) /* Update of meta page failed, probably I/O error */
|
|
|
|
#define MDB_VERSION_MISMATCH (-30794) /* Environment version mismatch */
|
2011-06-28 13:39:24 +08:00
|
|
|
|
|
|
|
/* DB flags */
|
|
|
|
#define MDB_REVERSEKEY 0x02 /* use reverse string keys */
|
2011-08-04 02:51:36 +08:00
|
|
|
#define MDB_DUPSORT 0x04 /* use sorted duplicates */
|
2011-08-12 02:35:39 +08:00
|
|
|
#define MDB_INTEGERKEY 0x08 /* numeric keys in native byte order */
|
2011-06-28 13:39:24 +08:00
|
|
|
|
|
|
|
/* environment flags */
|
|
|
|
#define MDB_FIXEDMAP 0x01 /* mmap at a fixed address */
|
2011-08-08 13:37:45 +08:00
|
|
|
#define MDB_NOSYNC 0x10000 /* don't fsync after commit */
|
|
|
|
#define MDB_RDONLY 0x20000 /* read only */
|
|
|
|
|
|
|
|
/* DB or env flags */
|
|
|
|
#define MDB_CREATE 0x40000 /* create if not present */
|
2011-06-28 13:39:24 +08:00
|
|
|
|
|
|
|
typedef struct MDB_stat {
|
|
|
|
unsigned int ms_psize;
|
2011-07-03 19:22:10 +08:00
|
|
|
unsigned int ms_depth;
|
2011-06-28 13:39:24 +08:00
|
|
|
unsigned long ms_branch_pages;
|
|
|
|
unsigned long ms_leaf_pages;
|
|
|
|
unsigned long ms_overflow_pages;
|
|
|
|
unsigned long ms_entries;
|
|
|
|
} MDB_stat;
|
|
|
|
|
2011-08-12 14:20:16 +08:00
|
|
|
char *mdb_version(int *major, int *minor, int *patch);
|
2011-08-12 12:14:29 +08:00
|
|
|
int mdb_env_create(MDB_env **env);
|
|
|
|
int mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mode_t mode);
|
|
|
|
int mdb_env_stat(MDB_env *env, MDB_stat *stat);
|
2011-08-12 14:20:16 +08:00
|
|
|
int mdb_env_sync(MDB_env *env, int force);
|
2011-08-12 12:14:29 +08:00
|
|
|
void mdb_env_close(MDB_env *env);
|
|
|
|
int mdb_env_get_flags(MDB_env *env, unsigned int *flags);
|
|
|
|
int mdb_env_get_path(MDB_env *env, const char **path);
|
|
|
|
int mdb_env_set_mapsize(MDB_env *env, size_t size);
|
|
|
|
int mdb_env_set_maxreaders(MDB_env *env, int readers);
|
|
|
|
int mdb_env_get_maxreaders(MDB_env *env, int *readers);
|
|
|
|
int mdb_env_set_maxdbs(MDB_env *env, int dbs);
|
2011-06-28 13:39:24 +08:00
|
|
|
|
|
|
|
int mdb_txn_begin(MDB_env *env, int rdonly, MDB_txn **txn);
|
|
|
|
int mdb_txn_commit(MDB_txn *txn);
|
|
|
|
void mdb_txn_abort(MDB_txn *txn);
|
|
|
|
|
2011-08-03 08:59:37 +08:00
|
|
|
int mdb_open(MDB_txn *txn, const char *name, unsigned int flags, MDB_dbi *dbi);
|
|
|
|
int mdb_stat(MDB_txn *txn, MDB_dbi dbi, MDB_stat *stat);
|
2011-08-03 17:23:16 +08:00
|
|
|
void mdb_close(MDB_txn *txn, MDB_dbi dbi);
|
2011-06-28 13:39:24 +08:00
|
|
|
|
2011-08-04 02:51:36 +08:00
|
|
|
int mdb_set_compare(MDB_txn *txn, MDB_dbi dbi, MDB_cmp_func *cmp);
|
|
|
|
int mdb_set_dupsort(MDB_txn *txn, MDB_dbi dbi, MDB_cmp_func *cmp);
|
|
|
|
int mdb_set_relfunc(MDB_txn *txn, MDB_dbi dbi, MDB_rel_func *rel);
|
|
|
|
|
2011-08-03 08:59:37 +08:00
|
|
|
int mdb_get(MDB_txn *txn, MDB_dbi dbi, MDB_val *key, MDB_val *data);
|
|
|
|
int mdb_put(MDB_txn *txn, MDB_dbi dbi, MDB_val *key, MDB_val *data,
|
2011-06-28 13:39:24 +08:00
|
|
|
unsigned int flags);
|
2011-08-11 14:21:36 +08:00
|
|
|
int mdb_del(MDB_txn *txn, MDB_dbi dbi, MDB_val *key, MDB_val *data,
|
|
|
|
unsigned int flags);
|
2011-06-28 13:39:24 +08:00
|
|
|
|
2011-08-03 08:59:37 +08:00
|
|
|
int mdb_cursor_open(MDB_txn *txn, MDB_dbi dbi, MDB_cursor **cursor);
|
2011-06-28 13:39:24 +08:00
|
|
|
void mdb_cursor_close(MDB_cursor *cursor);
|
|
|
|
int mdb_cursor_get(MDB_cursor *cursor, MDB_val *key, MDB_val *data,
|
|
|
|
MDB_cursor_op op);
|
2011-08-11 19:46:14 +08:00
|
|
|
int mdb_cursor_count(MDB_cursor *cursor, unsigned long *countp);
|
2011-06-28 13:39:24 +08:00
|
|
|
|
2011-08-03 08:59:37 +08:00
|
|
|
int mdb_cmp(MDB_txn *txn, MDB_dbi dbi, const MDB_val *a, const MDB_val *b);
|
2011-06-28 13:39:24 +08:00
|
|
|
|
|
|
|
#endif /* _MDB_H_ */
|