LMDB  1.0
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
lmdb.h
Go to the documentation of this file.
1 
168 #ifndef _LMDB_H_
169 #define _LMDB_H_
170 
171 #include <sys/types.h>
172 #include <inttypes.h>
173 #include <limits.h>
174 
175 #ifdef __cplusplus
176 extern "C" {
177 #endif
178 
180 #ifdef _MSC_VER
181 typedef int mdb_mode_t;
182 #else
183 typedef mode_t mdb_mode_t;
184 #endif
185 
186 #ifdef _WIN32
187 # define MDB_FMT_Z "I"
188 #else
189 # define MDB_FMT_Z "z"
190 #endif
191 
192 #if !defined(MDB_RPAGE_CACHE) || (defined(MDB_VL32) && !(MDB_RPAGE_CACHE))
193 
194 #define MDB_RPAGE_CACHE 1
195 #endif
196 
197 #ifndef MDB_VL32
198 
203 typedef size_t mdb_size_t;
204 # define MDB_SIZE_MAX SIZE_MAX
206 # define MDB_PRIy(t) MDB_FMT_Z #t
207 
208 # define MDB_SCNy(t) MDB_FMT_Z #t
209 #else
210 typedef uint64_t mdb_size_t;
211 # define MDB_SIZE_MAX UINT64_MAX
212 # define MDB_PRIy(t) PRI##t##64
213 # define MDB_SCNy(t) SCN##t##64
214 # define mdb_env_create mdb_env_create_vl32
215 #endif
216 
221 #ifdef _WIN32
222 typedef void *mdb_filehandle_t;
223 #else
224 typedef int mdb_filehandle_t;
225 #endif
226 
235 #define MDB_VERSION_MAJOR 1
236 
237 #define MDB_VERSION_MINOR 0
238 
239 #define MDB_VERSION_PATCH 0
240 
242 #define MDB_VERINT(a,b,c) (((a) << 24) | ((b) << 16) | (c))
243 
245 #define MDB_VERSION_FULL \
246  MDB_VERINT(MDB_VERSION_MAJOR,MDB_VERSION_MINOR,MDB_VERSION_PATCH)
247 
249 #define MDB_VERSION_DATE "April 28, 2026"
250 
252 #define MDB_VERSTR(a,b,c,d) "LMDB " #a "." #b "." #c ": (" d ")"
253 
255 #define MDB_VERFOO(a,b,c,d) MDB_VERSTR(a,b,c,d)
256 
258 #define MDB_VERSION_STRING \
259  MDB_VERFOO(MDB_VERSION_MAJOR,MDB_VERSION_MINOR,MDB_VERSION_PATCH,MDB_VERSION_DATE)
260 
267 typedef struct MDB_env MDB_env;
268 
274 typedef struct MDB_txn MDB_txn;
275 
277 typedef unsigned int MDB_dbi;
278 
280 typedef struct MDB_cursor MDB_cursor;
281 
293 typedef struct MDB_val {
294  size_t mv_size;
295  void *mv_data;
296 } MDB_val;
297 
299 typedef int (MDB_cmp_func)(const MDB_val *a, const MDB_val *b);
300 
315 typedef void (MDB_rel_func)(MDB_val *item, void *oldptr, void *newptr, void *relctx);
316 
317 #if MDB_RPAGE_CACHE
318 
330 typedef int (MDB_enc_func)(const MDB_val *src, MDB_val *dst, const MDB_val *key, int encdec);
331 
341 typedef void (MDB_sum_func)(const MDB_val *src, MDB_val *dst, const MDB_val *key);
342 #endif
343 
348 #define MDB_FIXEDMAP 0x01
349 
350 #define MDB_ENCRYPT 0x2000U
351 
352 #define MDB_NOSUBDIR 0x4000
353 
354 #define MDB_NOSYNC 0x10000
355 
356 #define MDB_RDONLY 0x20000
357 
358 #define MDB_NOMETASYNC 0x40000
359 
360 #define MDB_WRITEMAP 0x80000
361 
362 #define MDB_MAPASYNC 0x100000
363 
364 #define MDB_NOTLS 0x200000
365 
366 #define MDB_NOLOCK 0x400000
367 
368 #define MDB_NORDAHEAD 0x800000
369 
370 #define MDB_NOMEMINIT 0x1000000
371 
372 #define MDB_PREVSNAPSHOT 0x2000000
373 
374 #define MDB_REMAP_CHUNKS 0x4000000
375 
381 #define MDB_REVERSEKEY 0x02
382 
383 #define MDB_DUPSORT 0x04
384 
387 #define MDB_INTEGERKEY 0x08
388 
389 #define MDB_DUPFIXED 0x10
390 
391 #define MDB_INTEGERDUP 0x20
392 
393 #define MDB_REVERSEDUP 0x40
394 
395 #define MDB_CREATE 0x40000
396 
402 #define MDB_NOOVERWRITE 0x10
403 
407 #define MDB_NODUPDATA 0x20
408 
409 #define MDB_CURRENT 0x40
410 
413 #define MDB_RESERVE 0x10000
414 
415 #define MDB_APPEND 0x20000
416 
417 #define MDB_APPENDDUP 0x40000
418 
419 #define MDB_MULTIPLE 0x80000
420 /* @} */
421 
428 #define MDB_CP_COMPACT 0x01
429 /* @} */
430 
436 typedef enum MDB_cursor_op {
465 } MDB_cursor_op;
466 
473 #define MDB_SUCCESS 0
474 
475 #define MDB_KEYEXIST (-30799)
476 
477 #define MDB_NOTFOUND (-30798)
478 
479 #define MDB_PAGE_NOTFOUND (-30797)
480 
481 #define MDB_CORRUPTED (-30796)
482 
483 #define MDB_PANIC (-30795)
484 
485 #define MDB_VERSION_MISMATCH (-30794)
486 
487 #define MDB_INVALID (-30793)
488 
489 #define MDB_MAP_FULL (-30792)
490 
491 #define MDB_DBS_FULL (-30791)
492 
493 #define MDB_READERS_FULL (-30790)
494 
495 #define MDB_TLS_FULL (-30789)
496 
497 #define MDB_TXN_FULL (-30788)
498 
499 #define MDB_CURSOR_FULL (-30787)
500 
501 #define MDB_PAGE_FULL (-30786)
502 
503 #define MDB_MAP_RESIZED (-30785)
504 
512 #define MDB_INCOMPATIBLE (-30784)
513 
514 #define MDB_BAD_RSLOT (-30783)
515 
516 #define MDB_BAD_TXN (-30782)
517 
518 #define MDB_BAD_VALSIZE (-30781)
519 
520 #define MDB_BAD_DBI (-30780)
521 
522 #define MDB_PROBLEM (-30779)
523 
524 #define MDB_BAD_CHECKSUM (-30778)
525 
526 #define MDB_CRYPTO_FAIL (-30777)
527 
528 #define MDB_ENV_ENCRYPTION (-30776)
529 
530 #define MDB_TXN_PENDING (-30775)
531 
532 #define MDB_CANT_ROLLBACK (-30774)
533 
534 #define MDB_DBIS_BUSY (-30773)
535 
536 #define MDB_SHORT_WRITE (-30772)
537 
538 #define MDB_ENV_BUSY (-30771)
539 
540 #define MDB_IS_READONLY (-30770)
541 
542 #define MDB_ADDR_BUSY (-30769)
543 
544 #define MDB_LAST_ERRCODE MDB_ADDR_BUSY
545 
548 typedef struct MDB_stat {
549  unsigned int ms_psize;
551  unsigned int ms_depth;
552  mdb_size_t ms_branch_pages;
553  mdb_size_t ms_leaf_pages;
554  mdb_size_t ms_overflow_pages;
555  mdb_size_t ms_entries;
556 } MDB_stat;
557 
559 typedef struct MDB_envinfo {
560  void *me_mapaddr;
561  mdb_size_t me_mapsize;
562  mdb_size_t me_last_pgno;
563  mdb_size_t me_last_txnid;
564  unsigned int me_maxreaders;
565  unsigned int me_numreaders;
566 } MDB_envinfo;
567 
575 char *mdb_version(int *major, int *minor, int *patch);
576 
587 char *mdb_strerror(int err);
588 
600 int mdb_env_create(MDB_env **env);
601 
729 int mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mdb_mode_t mode);
730 
745 int mdb_env_copy(MDB_env *env, const char *path);
746 
760 int mdb_env_copyfd(MDB_env *env, mdb_filehandle_t fd);
761 
785 int mdb_env_copy2(MDB_env *env, const char *path, unsigned int flags);
786 
804 int mdb_env_copyfd2(MDB_env *env, mdb_filehandle_t fd, unsigned int flags);
805 
822 int mdb_env_incr_dumpfd(MDB_env *env, mdb_filehandle_t fd, size_t txnid);
823 
840 int mdb_env_incr_dump(MDB_env *env, const char *path, size_t txnid);
841 
853 int mdb_env_incr_loadfd(MDB_env *env, mdb_filehandle_t fd);
854 
861 int mdb_env_stat(MDB_env *env, MDB_stat *stat);
862 
869 int mdb_env_info(MDB_env *env, MDB_envinfo *stat);
870 
890 int mdb_env_sync(MDB_env *env, int force);
891 
900 void mdb_env_close(MDB_env *env);
901 
916 int mdb_env_set_flags(MDB_env *env, unsigned int flags, int onoff);
917 
928 int mdb_env_get_flags(MDB_env *env, unsigned int *flags);
929 
942 int mdb_env_get_path(MDB_env *env, const char **path);
943 
958 int mdb_env_get_fd(MDB_env *env, mdb_filehandle_t *fd);
959 
992 int mdb_env_set_mapsize(MDB_env *env, mdb_size_t size);
993 
994 
1002 int mdb_env_set_pagesize(MDB_env *env, int size);
1003 
1021 int mdb_env_set_maxreaders(MDB_env *env, unsigned int readers);
1022 
1033 int mdb_env_get_maxreaders(MDB_env *env, unsigned int *readers);
1034 
1053 int mdb_env_set_maxdbs(MDB_env *env, MDB_dbi dbs);
1054 
1063 
1070 int mdb_env_set_userctx(MDB_env *env, void *ctx);
1071 
1077 void *mdb_env_get_userctx(MDB_env *env);
1078 
1085 typedef void MDB_assert_func(MDB_env *env, const char *msg);
1086 
1094 int mdb_env_set_assert(MDB_env *env, MDB_assert_func *func);
1095 
1096 #if MDB_RPAGE_CACHE
1097 
1108 int mdb_env_set_encrypt(MDB_env *env, MDB_enc_func *func, const MDB_val *key, unsigned int size);
1109 
1118 int mdb_env_set_checksum(MDB_env *env, MDB_sum_func *func, unsigned int size);
1119 #endif
1120 
1163 int mdb_txn_begin(MDB_env *env, MDB_txn *parent, unsigned int flags, MDB_txn **txn);
1164 
1169 MDB_env *mdb_txn_env(MDB_txn *txn);
1170 
1180 mdb_size_t mdb_txn_id(MDB_txn *txn);
1181 
1188 int mdb_txn_flags(MDB_txn *txn, unsigned int *flags);
1189 
1206 int mdb_txn_commit(MDB_txn *txn);
1207 
1229 int mdb_txn_prepare(MDB_txn *txn);
1230 
1255 int mdb_env_rollback(MDB_env *env, mdb_size_t txnid);
1256 
1265 void mdb_txn_abort(MDB_txn *txn);
1266 
1284 void mdb_txn_reset(MDB_txn *txn);
1285 
1300 int mdb_txn_renew(MDB_txn *txn);
1301 
1303 #define mdb_open(txn,name,flags,dbi) mdb_dbi_open(txn,name,flags,dbi)
1304 
1305 #define mdb_close(env,dbi) mdb_dbi_close(env,dbi)
1306 
1378 int mdb_dbi_open(MDB_txn *txn, const char *name, unsigned int flags, MDB_dbi *dbi);
1379 
1392 int mdb_stat(MDB_txn *txn, MDB_dbi dbi, MDB_stat *stat);
1393 
1401 int mdb_dbi_flags(MDB_txn *txn, MDB_dbi dbi, unsigned int *flags);
1402 
1419 void mdb_dbi_close(MDB_env *env, MDB_dbi dbi);
1420 
1430 int mdb_drop(MDB_txn *txn, MDB_dbi dbi, int del);
1431 
1451 int mdb_set_compare(MDB_txn *txn, MDB_dbi dbi, MDB_cmp_func *cmp);
1452 
1474 int mdb_set_dupsort(MDB_txn *txn, MDB_dbi dbi, MDB_cmp_func *cmp);
1475 
1494 int mdb_set_relfunc(MDB_txn *txn, MDB_dbi dbi, MDB_rel_func *rel);
1495 
1510 int mdb_set_relctx(MDB_txn *txn, MDB_dbi dbi, void *ctx);
1511 
1538 int mdb_get(MDB_txn *txn, MDB_dbi dbi, MDB_val *key, MDB_val *data);
1539 
1587 int mdb_put(MDB_txn *txn, MDB_dbi dbi, MDB_val *key, MDB_val *data,
1588  unsigned int flags);
1589 
1612 int mdb_del(MDB_txn *txn, MDB_dbi dbi, MDB_val *key, MDB_val *data);
1613 
1636 int mdb_cursor_open(MDB_txn *txn, MDB_dbi dbi, MDB_cursor **cursor);
1637 
1644 void mdb_cursor_close(MDB_cursor *cursor);
1645 
1662 int mdb_cursor_renew(MDB_txn *txn, MDB_cursor *cursor);
1663 
1669 
1674 MDB_dbi mdb_cursor_dbi(MDB_cursor *cursor);
1675 
1681 int mdb_cursor_is_db(MDB_cursor *cursor);
1682 
1702 int mdb_cursor_get(MDB_cursor *cursor, MDB_val *key, MDB_val *data,
1703  MDB_cursor_op op);
1704 
1764 int mdb_cursor_put(MDB_cursor *cursor, MDB_val *key, MDB_val *data,
1765  unsigned int flags);
1766 
1788 int mdb_cursor_del(MDB_cursor *cursor, unsigned int flags);
1789 
1802 int mdb_cursor_count(MDB_cursor *cursor, mdb_size_t *countp);
1803 
1814 int mdb_cmp(MDB_txn *txn, MDB_dbi dbi, const MDB_val *a, const MDB_val *b);
1815 
1826 int mdb_dcmp(MDB_txn *txn, MDB_dbi dbi, const MDB_val *a, const MDB_val *b);
1827 
1834 typedef int (MDB_msg_func)(const char *msg, void *ctx);
1835 
1843 int mdb_reader_list(MDB_env *env, MDB_msg_func *func, void *ctx);
1844 
1851 int mdb_reader_check(MDB_env *env, int *dead);
1866 typedef int (MDB_str2key_func)(const char *passwd, MDB_val *key);
1867 
1873 typedef struct MDB_crypto_funcs {
1874  MDB_str2key_func *mcf_str2key;
1875  MDB_enc_func *mcf_encfunc;
1876  MDB_sum_func *mcf_sumfunc;
1881 
1889 
1899 void *mdb_modload(const char *file, const char *symname,
1900  MDB_crypto_funcs **mcf_ptr, char **errmsg);
1901 
1908 void mdb_modunload(void *handle);
1909 
1918 void mdb_modsetup(MDB_env *env, MDB_crypto_funcs *mcf_ptr, const char *passphrase);
1919 
1922 #ifdef __cplusplus
1923 }
1924 #endif
1925 
1934 #endif /* _LMDB_H_ */