libmdbx 0.14.1.539 (2026-04-07T09:49:22+03:00)
One of the fastest compact embeddable key-value ACID storage engine without WAL.
Loading...
Searching...
No Matches
mdbx.h
Go to the documentation of this file.
1
37
38#pragma once
39/*
40 * Tested with, since 2026:
41 * - Elbrus LCC >= 1.28 (http://www.mcst.ru/lcc);
42 * - GNU C >= 11.3;
43 * - CLANG >= 14.0;
44 * - MSVC >= 19.44 (Visual Studio 2022 toolchain v143),
45 * before 2026:
46 * - Elbrus LCC >= 1.23 (http://www.mcst.ru/lcc);
47 * - GNU C >= 4.8;
48 * - CLANG >= 3.9;
49 * - MSVC >= 14.0 (Visual Studio 2015),
50 * but 19.2x could hang due optimizer bug;
51 * - AppleClang.
52 */
53
54#ifndef LIBMDBX_H
55#define LIBMDBX_H
56
57#if defined(__riscv) || defined(__riscv__) || defined(__RISCV) || defined(__RISCV__)
58#warning "The RISC-V architecture is intentionally insecure by design. \
59 Please delete this admonition at your own risk, \
60 if you make such decision informed and consciously. \
61 Refer to https://clck.ru/32d9xH for more information."
62#endif /* RISC-V */
63
64#ifdef _MSC_VER
65#pragma warning(push, 1)
66#pragma warning(disable : 4548) /* expression before comma has no effect; \
67 expected expression with side - effect */
68#pragma warning(disable : 4530) /* C++ exception handler used, but unwind \
69 * semantics are not enabled. Specify /EHsc */
70#pragma warning(disable : 4577) /* 'noexcept' used with no exception handling \
71 * mode specified; termination on exception is \
72 * not guaranteed. Specify /EHsc */
73#endif /* _MSC_VER (warnings) */
74
75/* *INDENT-OFF* */
76/* clang-format off */
157/* *INDENT-ON* */
158/* clang-format on */
159
160#include <stdarg.h>
161#include <stddef.h>
162#include <stdint.h>
163#if !defined(assert)
164#include <assert.h>
165#endif /* assert */
166
167#if defined(_WIN32) || defined(_WIN64)
168#include <windows.h>
169#include <winnt.h>
170#ifndef __mode_t_defined
171typedef unsigned short mdbx_mode_t;
172#else
173typedef mode_t mdbx_mode_t;
174#endif /* __mode_t_defined */
175typedef HANDLE mdbx_filehandle_t;
176typedef DWORD mdbx_pid_t;
177typedef DWORD mdbx_tid_t;
178#else /* Windows */
179#include <errno.h> /* for error codes */
180#include <pthread.h> /* for pthread_t */
181#include <sys/types.h> /* for pid_t */
182#include <sys/uio.h> /* for struct iovec */
183#define HAVE_STRUCT_IOVEC 1
185typedef pid_t mdbx_pid_t;
186typedef pthread_t mdbx_tid_t;
187typedef mode_t mdbx_mode_t;
188#endif /* !Windows */
189
190#ifdef _MSC_VER
191#pragma warning(pop)
192#endif
193
194#define MDBX_AMALGAMATED_SOURCE 1
195
200
201/*----------------------------------------------------------------------------*/
202
203#ifndef __has_attribute
204#define __has_attribute(x) (0)
205#endif /* __has_attribute */
206
207#ifndef __has_c_attribute
208#define __has_c_attribute(x) (0)
209#define __has_c_attribute_qualified(x) 0
210#elif !defined(__STDC_VERSION__) || __STDC_VERSION__ < 202311L
211#define __has_c_attribute_qualified(x) 0
212#elif defined(_MSC_VER)
213/* MSVC don't support `namespace::attr` syntax */
214#define __has_c_attribute_qualified(x) 0
215#else
216#define __has_c_attribute_qualified(x) __has_c_attribute(x)
217#endif /* __has_c_attribute */
218
219#ifndef __has_cpp_attribute
220#define __has_cpp_attribute(x) 0
221#define __has_cpp_attribute_qualified(x) 0
222#elif defined(_MSC_VER) || (__clang__ && __clang__ < 14)
223/* MSVC don't support `namespace::attr` syntax */
224#define __has_cpp_attribute_qualified(x) 0
225#else
226#define __has_cpp_attribute_qualified(x) __has_cpp_attribute(x)
227#endif /* __has_cpp_attribute */
228
229#ifndef __has_C23_or_CXX_attribute
230#if defined(__cplusplus)
231#define __has_C23_or_CXX_attribute(x) __has_cpp_attribute_qualified(x)
232#else
233#define __has_C23_or_CXX_attribute(x) __has_c_attribute_qualified(x)
234#endif
235#endif /* __has_C23_or_CXX_attribute */
236
237#ifndef __has_feature
238#define __has_feature(x) (0)
239#define __has_exceptions_disabled (0)
240#elif !defined(__has_exceptions_disabled)
241#define __has_exceptions_disabled (__has_feature(cxx_noexcept) && !__has_feature(cxx_exceptions))
242#endif /* __has_feature */
243
244#ifndef __has_extension
245#define __has_extension(x) __has_feature(x)
246#endif /* __has_extension */
247
248#ifndef __has_builtin
249#define __has_builtin(x) (0)
250#endif /* __has_builtin */
251
258#if defined(DOXYGEN)
259#define MDBX_PURE_FUNCTION [[gnu::pure]]
260#elif __has_C23_or_CXX_attribute(gnu::pure)
261#define MDBX_PURE_FUNCTION [[gnu::pure]]
262#elif (defined(__GNUC__) || __has_attribute(__pure__)) && \
263 (!defined(__clang__) /* https://bugs.llvm.org/show_bug.cgi?id=43275 */ || !defined(__cplusplus) || \
264 __has_exceptions_disabled)
265#define MDBX_PURE_FUNCTION __attribute__((__pure__))
266#else
267#define MDBX_PURE_FUNCTION
268#endif /* MDBX_PURE_FUNCTION */
269
273#if defined(DOXYGEN)
274#define MDBX_NOTHROW_PURE_FUNCTION [[gnu::pure, gnu::nothrow]]
275#elif __has_C23_or_CXX_attribute(gnu::pure)
276#if __has_C23_or_CXX_attribute(gnu::nothrow)
277#define MDBX_NOTHROW_PURE_FUNCTION [[gnu::pure, gnu::nothrow]]
278#else
279#define MDBX_NOTHROW_PURE_FUNCTION [[gnu::pure]]
280#endif
281#elif defined(__GNUC__) || (__has_attribute(__pure__) && __has_attribute(__nothrow__))
282#define MDBX_NOTHROW_PURE_FUNCTION __attribute__((__pure__, __nothrow__))
283#elif __has_cpp_attribute(pure)
284#define MDBX_NOTHROW_PURE_FUNCTION [[pure]]
285#else
286#define MDBX_NOTHROW_PURE_FUNCTION
287#endif /* MDBX_NOTHROW_PURE_FUNCTION */
288
299#if defined(DOXYGEN)
300#define MDBX_CONST_FUNCTION [[gnu::const]]
301#elif __has_C23_or_CXX_attribute(gnu::const)
302#define MDBX_CONST_FUNCTION [[gnu::const]]
303#elif (defined(__GNUC__) || __has_attribute(__const__)) && \
304 (!defined(__clang__) /* https://bugs.llvm.org/show_bug.cgi?id=43275 */ || !defined(__cplusplus) || \
305 __has_exceptions_disabled)
306#define MDBX_CONST_FUNCTION __attribute__((__const__))
307#else
308#define MDBX_CONST_FUNCTION MDBX_PURE_FUNCTION
309#endif /* MDBX_CONST_FUNCTION */
310
314#if defined(DOXYGEN)
315#define MDBX_NOTHROW_CONST_FUNCTION [[gnu::const, gnu::nothrow]]
316#elif __has_C23_or_CXX_attribute(gnu::const)
317#if __has_C23_or_CXX_attribute(gnu::nothrow)
318#define MDBX_NOTHROW_CONST_FUNCTION [[gnu::const, gnu::nothrow]]
319#else
320#define MDBX_NOTHROW_CONST_FUNCTION [[gnu::const]]
321#endif
322#elif defined(__GNUC__) || (__has_attribute(__const__) && __has_attribute(__nothrow__))
323#define MDBX_NOTHROW_CONST_FUNCTION __attribute__((__const__, __nothrow__))
324#elif __has_cpp_attribute_qualified(const)
325#define MDBX_NOTHROW_CONST_FUNCTION [[const]]
326#else
327#define MDBX_NOTHROW_CONST_FUNCTION MDBX_NOTHROW_PURE_FUNCTION
328#endif /* MDBX_NOTHROW_CONST_FUNCTION */
329
333#ifndef MDBX_DEPRECATED
334#ifdef __deprecated
335#define MDBX_DEPRECATED __deprecated
336#elif defined(DOXYGEN) || ((!defined(__GNUC__) || (defined(__clang__) && __clang__ > 19) || __GNUC__ > 5) && \
337 ((defined(__cplusplus) && __cplusplus >= 201403L && __has_cpp_attribute(deprecated) && \
338 __has_cpp_attribute(deprecated) >= 201309L) || \
339 (!defined(__cplusplus) && defined(__STDC_VERSION__) && __STDC_VERSION__ >= 202304L)))
340#define MDBX_DEPRECATED [[deprecated]]
341#elif (defined(__GNUC__) && __GNUC__ > 5) || \
342 (__has_attribute(__deprecated__) && (!defined(__GNUC__) || defined(__clang__) || __GNUC__ > 5))
343#define MDBX_DEPRECATED __attribute__((__deprecated__))
344#elif defined(_MSC_VER)
345#define MDBX_DEPRECATED __declspec(deprecated)
346#else
347#define MDBX_DEPRECATED
348#endif
349#endif /* MDBX_DEPRECATED */
350
351#ifndef MDBX_DEPRECATED_ENUM
352#ifdef __deprecated_enum
353#define MDBX_DEPRECATED_ENUM __deprecated_enum
354#elif defined(DOXYGEN) || \
355 (!defined(_MSC_VER) || (defined(__cplusplus) && __cplusplus >= 201403L && __has_cpp_attribute(deprecated) && \
356 __has_cpp_attribute(deprecated) >= 201309L))
357#define MDBX_DEPRECATED_ENUM MDBX_DEPRECATED
358#else
359#define MDBX_DEPRECATED_ENUM /* avoid madness MSVC */
360#endif
361#endif /* MDBX_DEPRECATED_ENUM */
362
363#ifndef __dll_export
364#if defined(_WIN32) || defined(_WIN64) || defined(__CYGWIN__) || defined(__MINGW__) || defined(__MINGW32__) || \
365 defined(__MINGW64__)
366#if defined(__GNUC__) || __has_attribute(__dllexport__)
367#define __dll_export __attribute__((__dllexport__))
368#elif defined(_MSC_VER)
369#define __dll_export __declspec(dllexport)
370#else
371#define __dll_export
372#endif
373#elif defined(__GNUC__) || defined(__clang__) || __has_attribute(__visibility__)
374#define __dll_export __attribute__((__visibility__("default")))
375#else
376#define __dll_export
377#endif
378#endif /* __dll_export */
379
380#ifndef __dll_import
381#if defined(_WIN32) || defined(_WIN64) || defined(__CYGWIN__) || defined(__MINGW__) || defined(__MINGW32__) || \
382 defined(__MINGW64__)
383#if defined(__GNUC__) || __has_attribute(__dllimport__)
384#define __dll_import __attribute__((__dllimport__))
385#elif defined(_MSC_VER)
386#define __dll_import __declspec(dllimport)
387#else
388#define __dll_import
389#endif
390#else
391#define __dll_import
392#endif
393#endif /* __dll_import */
394
399#if defined(LIBMDBX_INTERNALS) && !defined(LIBMDBX_NO_EXPORTS_LEGACY_API)
400#define LIBMDBX_INLINE_API(TYPE, NAME, ARGS) \
401 /* proto of exported which uses common impl */ LIBMDBX_API TYPE NAME ARGS; \
402 /* definition of common impl */ static __inline TYPE __inline_##NAME ARGS
403#else
404#define LIBMDBX_INLINE_API(TYPE, NAME, ARGS) static __inline TYPE NAME ARGS
405#endif /* LIBMDBX_INLINE_API */
406
408#ifndef MDBX_STRINGIFY
409#define MDBX_STRINGIFY_HELPER(x) #x
410#define MDBX_STRINGIFY(x) MDBX_STRINGIFY_HELPER(x)
411#endif /* MDBX_STRINGIFY */
412
413/*----------------------------------------------------------------------------*/
414
415#ifndef __cplusplus
416#ifndef bool
417#define bool _Bool
418#endif
419#ifndef true
420#define true (1)
421#endif
422#ifndef false
423#define false (0)
424#endif
425#endif /* bool without __cplusplus */
426
428#if defined(DOXYGEN)
429#define MDBX_CXX17_NOEXCEPT noexcept
430#elif !defined(__cpp_noexcept_function_type) || __cpp_noexcept_function_type < 201510L
431#define MDBX_CXX17_NOEXCEPT
432#else
433#define MDBX_CXX17_NOEXCEPT noexcept
434#endif /* MDBX_CXX17_NOEXCEPT */
435
437#if defined(DOXYGEN)
438#define MDBX_CXX01_CONSTEXPR constexpr
439#define MDBX_CXX01_CONSTEXPR_VAR constexpr
440#elif !defined(__cplusplus)
441#define MDBX_CXX01_CONSTEXPR __inline
442#define MDBX_CXX01_CONSTEXPR_VAR const
443#elif !defined(DOXYGEN) && \
444 ((__cplusplus < 201103L && defined(__cpp_constexpr) && __cpp_constexpr < 200704L) || \
445 (defined(__LCC__) && __LCC__ < 124) || \
446 (defined(__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ < 407) && !defined(__clang__) && !defined(__LCC__)) || \
447 (defined(_MSC_VER) && _MSC_VER < 1910) || (defined(__clang__) && __clang_major__ < 4))
448#define MDBX_CXX01_CONSTEXPR inline
449#define MDBX_CXX01_CONSTEXPR_VAR const
450#else
451#define MDBX_CXX01_CONSTEXPR constexpr
452#define MDBX_CXX01_CONSTEXPR_VAR constexpr
453#endif /* MDBX_CXX01_CONSTEXPR */
454
457#if defined(DOXYGEN)
458#define MDBX_CXX11_CONSTEXPR constexpr
459#define MDBX_CXX11_CONSTEXPR_VAR constexpr
460#elif !defined(__cplusplus)
461#define MDBX_CXX11_CONSTEXPR __inline
462#define MDBX_CXX11_CONSTEXPR_VAR const
463#elif !defined(DOXYGEN) && \
464 (!defined(__cpp_constexpr) || __cpp_constexpr < 201304L || (defined(__LCC__) && __LCC__ < 124) || \
465 (defined(__GNUC__) && __GNUC__ < 6 && !defined(__clang__) && !defined(__LCC__)) || \
466 (defined(_MSC_VER) && _MSC_VER < 1910) || (defined(__clang__) && __clang_major__ < 5))
467#define MDBX_CXX11_CONSTEXPR inline
468#define MDBX_CXX11_CONSTEXPR_VAR const
469#else
470#define MDBX_CXX11_CONSTEXPR constexpr
471#define MDBX_CXX11_CONSTEXPR_VAR constexpr
472#endif /* MDBX_CXX11_CONSTEXPR */
473
476#if defined(DOXYGEN)
477#define MDBX_CXX14_CONSTEXPR constexpr
478#define MDBX_CXX14_CONSTEXPR_VAR constexpr
479#elif !defined(__cplusplus)
480#define MDBX_CXX14_CONSTEXPR __inline
481#define MDBX_CXX14_CONSTEXPR_VAR const
482#elif defined(DOXYGEN) || \
483 defined(__cpp_constexpr) && __cpp_constexpr >= 201304L && \
484 ((defined(_MSC_VER) && _MSC_VER >= 1910) || (defined(__clang__) && __clang_major__ > 4) || \
485 (defined(__GNUC__) && __GNUC__ > 6) || (!defined(__GNUC__) && !defined(__clang__) && !defined(_MSC_VER)))
486#define MDBX_CXX14_CONSTEXPR constexpr
487#define MDBX_CXX14_CONSTEXPR_VAR constexpr
488#else
489#define MDBX_CXX14_CONSTEXPR inline
490#define MDBX_CXX14_CONSTEXPR_VAR const
491#endif /* MDBX_CXX14_CONSTEXPR */
492
493#if defined(__noreturn)
494#define MDBX_NORETURN __noreturn
495#elif defined(_Noreturn)
496#define MDBX_NORETURN _Noreturn
497#elif defined(DOXYGEN) || (defined(__cplusplus) && __cplusplus >= 201103L) || \
498 (!defined(__cplusplus) && defined(__STDC_VERSION__) && __STDC_VERSION__ > 202005L)
499#define MDBX_NORETURN [[noreturn]]
500#elif defined(__GNUC__) || __has_attribute(__noreturn__)
501#define MDBX_NORETURN __attribute__((__noreturn__))
502#elif defined(_MSC_VER) && !defined(__clang__)
503#define MDBX_NORETURN __declspec(noreturn)
504#else
505#define MDBX_NORETURN
506#endif /* MDBX_NORETURN */
507
508#ifndef MDBX_PRINTF_ARGS
509#if defined(__GNUC__) || __has_attribute(__format__) || defined(DOXYGEN)
510#if defined(__MINGW__) || defined(__MINGW32__) || defined(__MINGW64__)
511#define MDBX_PRINTF_ARGS(format_index, first_arg) __attribute__((__format__(__gnu_printf__, format_index, first_arg)))
512#else
513#define MDBX_PRINTF_ARGS(format_index, first_arg) __attribute__((__format__(__printf__, format_index, first_arg)))
514#endif /* MinGW */
515#else
516#define MDBX_PRINTF_ARGS(format_index, first_arg)
517#endif
518#endif /* MDBX_PRINTF_ARGS */
519
520#if defined(DOXYGEN) || \
521 (defined(__cplusplus) && __cplusplus >= 201603L && __has_cpp_attribute(maybe_unused) && \
522 __has_cpp_attribute(maybe_unused) >= 201603L && (!defined(__clang__) || __clang__ > 19)) || \
523 (!defined(__cplusplus) && defined(__STDC_VERSION__) && __STDC_VERSION__ > 202005L)
524#define MDBX_MAYBE_UNUSED [[maybe_unused]]
525#elif defined(__GNUC__) || __has_attribute(__unused__)
526#define MDBX_MAYBE_UNUSED __attribute__((__unused__))
527#else
528#define MDBX_MAYBE_UNUSED
529#endif /* MDBX_MAYBE_UNUSED */
530
531#if __has_attribute(no_sanitize) || defined(DOXYGEN)
532#define MDBX_NOSANITIZE_ENUM __attribute((__no_sanitize__("enum")))
533#else
534#define MDBX_NOSANITIZE_ENUM
535#endif /* MDBX_NOSANITIZE_ENUM */
536
537/* Oh, below are some songs and dances since:
538 * - C++ requires explicit definition of the necessary operators.
539 * - the proper implementation of DEFINE_ENUM_FLAG_OPERATORS for C++ required
540 * the constexpr feature which is broken in most old compilers;
541 * - DEFINE_ENUM_FLAG_OPERATORS may be defined broken as in the Windows SDK. */
542#if !defined(DEFINE_ENUM_FLAG_OPERATORS) && !defined(DOXYGEN)
543
544#ifdef __cplusplus
545#if !defined(__cpp_constexpr) || __cpp_constexpr < 200704L || (defined(__LCC__) && __LCC__ < 124) || \
546 (defined(__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ < 407) && !defined(__clang__) && !defined(__LCC__)) || \
547 (defined(_MSC_VER) && _MSC_VER < 1910) || (defined(__clang__) && __clang_major__ < 4)
548/* The constexpr feature is not available or (may be) broken */
549#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 0
550#else
551/* C always allows these operators for enums */
552#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 1
553#endif /* __cpp_constexpr */
554
557#define DEFINE_ENUM_FLAG_OPERATORS(ENUM) \
558 extern "C++" { \
559 MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator|(ENUM a, ENUM b) { return ENUM(unsigned(a) | unsigned(b)); } \
560 MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator|=(ENUM &a, ENUM b) { return a = a | b; } \
561 MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator&(ENUM a, ENUM b) { return ENUM(unsigned(a) & unsigned(b)); } \
562 MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator&(ENUM a, unsigned b) { return ENUM(unsigned(a) & b); } \
563 MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator&(unsigned a, ENUM b) { return ENUM(a & unsigned(b)); } \
564 MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator&=(ENUM &a, ENUM b) { return a = a & b; } \
565 MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator&=(ENUM &a, unsigned b) { return a = a & b; } \
566 MDBX_CXX01_CONSTEXPR unsigned operator~(ENUM a) { return ~unsigned(a); } \
567 MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator^(ENUM a, ENUM b) { return ENUM(unsigned(a) ^ unsigned(b)); } \
568 MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator^=(ENUM &a, ENUM b) { return a = a ^ b; } \
569 }
570#else /* __cplusplus */
571/* nope for C since it always allows these operators for enums */
572#define DEFINE_ENUM_FLAG_OPERATORS(ENUM)
573#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 1
574#endif /* !__cplusplus */
575
576#elif !defined(CONSTEXPR_ENUM_FLAGS_OPERATIONS)
577
578#ifdef __cplusplus
579/* DEFINE_ENUM_FLAG_OPERATORS may be defined broken as in the Windows SDK */
580#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 0
581#else
582/* C always allows these operators for enums */
583#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 1
584#endif
585
586#endif /* DEFINE_ENUM_FLAG_OPERATORS */
587
588#ifndef MDBX_LIKELY
589#if defined(DOXYGEN) || (defined(__GNUC__) || __has_builtin(__builtin_expect)) && !defined(__COVERITY__)
590#define MDBX_LIKELY(cond) __builtin_expect(!!(cond), 1)
591#else
592#define MDBX_LIKELY(x) (x)
593#endif
594#endif /* MDBX_LIKELY */
595
596#ifndef MDBX_UNLIKELY
597#if defined(DOXYGEN) || (defined(__GNUC__) || __has_builtin(__builtin_expect)) && !defined(__COVERITY__)
598#define MDBX_UNLIKELY(cond) __builtin_expect(!!(cond), 0)
599#else
600#define MDBX_UNLIKELY(x) (x)
601#endif
602#endif /* MDBX_UNLIKELY */
603
604#if defined(DOXYGEN) || (defined(MDBX_CHECKING) && MDBX_CHECKING > 0) || (defined(MDBX_DEBUG) && MDBX_DEBUG > 0)
605#define MDBX_INLINE_API_ASSERT(expr) \
606 do { \
607 if (MDBX_UNLIKELY(!(expr))) \
608 mdbx_assert_fail(#expr, __func__, __LINE__); \
609 } while (0)
610#else
611/* clang-format off */
612#define MDBX_INLINE_API_ASSERT(expr) do {} while(0)
613/* clang-format on */
614#endif /* MDBX_INLINE_API_ASSERT */
615
617
618/*----------------------------------------------------------------------------*/
619
622
623#ifdef __cplusplus
624extern "C" {
625#endif
626
627/* MDBX version 0.14.x, but it is unstable/under-development yet. */
628#define MDBX_VERSION_UNSTABLE
629#define MDBX_VERSION_MAJOR 0
630#define MDBX_VERSION_MINOR 14
631
632#ifndef LIBMDBX_API
633#if defined(LIBMDBX_EXPORTS) || defined(DOXYGEN)
634#define LIBMDBX_API __dll_export
635#elif defined(LIBMDBX_IMPORTS)
636#define LIBMDBX_API __dll_import
637#else
638#define LIBMDBX_API
639#endif
640#endif /* LIBMDBX_API */
641
642#ifdef __cplusplus
643#if defined(__clang__) || __has_attribute(type_visibility) || defined(DOXYGEN)
644#define LIBMDBX_API_TYPE LIBMDBX_API __attribute__((type_visibility("default")))
645#else
646#define LIBMDBX_API_TYPE LIBMDBX_API
647#endif
648#else
649#define LIBMDBX_API_TYPE
650#endif /* LIBMDBX_API_TYPE */
651
652#if defined(LIBMDBX_IMPORTS)
653#define LIBMDBX_VERINFO_API __dll_import
654#else
655#define LIBMDBX_VERINFO_API __dll_export
656#endif /* LIBMDBX_VERINFO_API */
657
660 uint16_t major;
661 uint16_t minor;
662 uint16_t patch;
663 uint16_t tweak;
664 const char *semver_prerelease;
665 struct {
666 const char *datetime;
667 const char *tree;
668 const char *commit;
669 const char *describe;
670 } git;
671 const char *sourcery;
673
678 const char *datetime;
679 const char *target;
680 const char *options;
681 const char *compiler;
682 const char *flags;
683 const char *metadata;
687
688#if (defined(_WIN32) || defined(_WIN64)) && !MDBX_BUILD_SHARED_LIBRARY
689/* MDBX internally uses global and thread local storage destructors to
690 * automatically (de)initialization, releasing reader lock table slots
691 * and so on.
692 *
693 * If MDBX built as a DLL this is done out-of-the-box by DllEntry() function,
694 * which called automatically by Windows core with passing corresponding reason
695 * argument.
696 *
697 * Otherwise, if MDBX was built not as a DLL, some black magic
698 * may be required depending of Windows version:
699 *
700 * - Modern Windows versions, including Windows Vista and later, provides
701 * support for "TLS Directory" (e.g .CRT$XL[A-Z] sections in executable
702 * or dll file). In this case, MDBX capable of doing all automatically,
703 * therefore you DON'T NEED to call mdbx_module_handler()
704 * so the MDBX_MANUAL_MODULE_HANDLER defined as 0.
705 *
706 * - Obsolete versions of Windows, prior to Windows Vista, REQUIRES calling
707 * mdbx_module_handler() manually from corresponding DllMain() or WinMain()
708 * of your DLL or application,
709 * so the MDBX_MANUAL_MODULE_HANDLER defined as 1.
710 *
711 * Therefore, building MDBX as a DLL is recommended for all version of Windows.
712 * So, if you doubt, just build MDBX as the separate DLL and don't care about
713 * the MDBX_MANUAL_MODULE_HANDLER. */
714
715#ifndef _WIN32_WINNT
716#error Non-dll build libmdbx requires target Windows version \
717 to be explicitly defined via _WIN32_WINNT for properly \
718 handling thread local storage destructors.
719#endif /* _WIN32_WINNT */
720
721#if _WIN32_WINNT >= 0x0600 /* Windows Vista */
722/* As described above mdbx_module_handler() is NOT needed for Windows Vista
723 * and later. */
724#define MDBX_MANUAL_MODULE_HANDLER 0
725#else
726/* As described above mdbx_module_handler() IS REQUIRED for Windows versions
727 * prior to Windows Vista. */
728#define MDBX_MANUAL_MODULE_HANDLER 1
729void LIBMDBX_API NTAPI mdbx_module_handler(PVOID module, DWORD reason, PVOID reserved);
730#endif
731
732#endif /* Windows && !DLL && MDBX_MANUAL_MODULE_HANDLER */
733
734/* OPACITY STRUCTURES *********************************************************/
735
740#ifndef __cplusplus
741typedef struct MDBX_env MDBX_env;
742#else
743struct MDBX_env;
744#endif
745
751#ifndef __cplusplus
752typedef struct MDBX_txn MDBX_txn;
753#else
754struct MDBX_txn;
755#endif
756
764typedef uint32_t MDBX_dbi;
765
770#ifndef __cplusplus
772#else
773struct MDBX_cursor;
774#endif
775
789#ifndef HAVE_STRUCT_IOVEC
790struct iovec {
791 void *iov_base;
792 size_t iov_len;
793};
794#define HAVE_STRUCT_IOVEC
795#endif /* HAVE_STRUCT_IOVEC */
796
797#if defined(__sun) || defined(__SVR4) || defined(__svr4__)
798/* The `iov_len` is signed on Sun/Solaris.
799 * So define custom MDBX_val to avoid a lot of warnings. */
800struct MDBX_val {
801 void *iov_base;
802 size_t iov_len;
803};
804#ifndef __cplusplus
805typedef struct MDBX_val MDBX_val;
806#endif
807#else /* SunOS */
808typedef struct iovec MDBX_val;
809#endif /* ! SunOS */
810
813 MDBX_MAX_DBI = UINT32_C(32765),
814
816 MDBX_MAXDATASIZE = UINT32_C(0x7fff0000),
817
820
823};
824
825/* THE FILES *******************************************************************
826 * At the file system level, the environment corresponds to a pair of files. */
827
828#ifndef MDBX_LOCKNAME
830#if !(defined(_WIN32) || defined(_WIN64))
831#define MDBX_LOCKNAME "/mdbx.lck"
832#else
833#define MDBX_LOCKNAME_W L"\\mdbx.lck"
834#define MDBX_LOCKNAME_A "\\mdbx.lck"
835#ifdef UNICODE
836#define MDBX_LOCKNAME MDBX_LOCKNAME_W
837#else
838#define MDBX_LOCKNAME MDBX_LOCKNAME_A
839#endif /* UNICODE */
840#endif /* Windows */
841#endif /* MDBX_LOCKNAME */
842#ifndef MDBX_DATANAME
845#if !(defined(_WIN32) || defined(_WIN64))
846#define MDBX_DATANAME "/mdbx.dat"
847#else
848#define MDBX_DATANAME_W L"\\mdbx.dat"
849#define MDBX_DATANAME_A "\\mdbx.dat"
850#ifdef UNICODE
851#define MDBX_DATANAME MDBX_DATANAME_W
852#else
853#define MDBX_DATANAME MDBX_DATANAME_A
854#endif /* UNICODE */
855#endif /* Windows */
856#endif /* MDBX_DATANAME */
857
858#ifndef MDBX_LOCK_SUFFIX
860#if !(defined(_WIN32) || defined(_WIN64))
861#define MDBX_LOCK_SUFFIX "-lck"
862#else
863#define MDBX_LOCK_SUFFIX_W L"-lck"
864#define MDBX_LOCK_SUFFIX_A "-lck"
865#ifdef UNICODE
866#define MDBX_LOCK_SUFFIX MDBX_LOCK_SUFFIX_W
867#else
868#define MDBX_LOCK_SUFFIX MDBX_LOCK_SUFFIX_A
869#endif /* UNICODE */
870#endif /* Windows */
871#endif /* MDBX_LOCK_SUFFIX */
872
873/* DEBUG & LOGGING ************************************************************/
874
878
884typedef enum MDBX_log_level {
889
895
901
907
912
917
922
927
928#ifdef ENABLE_UBSAN
929 MDBX_LOG_MAX = 7 /* avoid UBSAN false-positive trap by a tests */,
930#endif /* ENABLE_UBSAN */
931
935
943typedef enum MDBX_debug_flags {
945
949
954
958
962
965
968
972
973#ifdef ENABLE_UBSAN
974 MDBX_DBG_MAX = ((unsigned)MDBX_LOG_MAX) << 16 | 127 /* avoid UBSAN false-positive trap by a tests */,
975#endif /* ENABLE_UBSAN */
976
980DEFINE_ENUM_FLAG_OPERATORS(MDBX_debug_flags)
981
982
996typedef void (*MDBX_debug_func)(MDBX_log_level_t loglevel, const char *function, int line, const char *fmt,
997 va_list args) MDBX_CXX17_NOEXCEPT;
998
1000#define MDBX_LOGGER_DONTCHANGE ((MDBX_debug_func)(intptr_t)-1)
1001#define MDBX_LOGGER_NOFMT_DONTCHANGE ((MDBX_debug_func_nofmt)(intptr_t)-1)
1002
1009
1010typedef void (*MDBX_debug_func_nofmt)(MDBX_log_level_t loglevel, const char *function, int line, const char *msg,
1011 unsigned length) MDBX_CXX17_NOEXCEPT;
1012
1014 MDBX_debug_func_nofmt logger, char *logger_buffer, size_t logger_buffer_size);
1015
1030typedef void (*MDBX_panic_func)(const char *msg, const char *function, unsigned line, const void *obj,
1031 const char *obj_class) MDBX_CXX17_NOEXCEPT;
1032
1034MDBX_NORETURN LIBMDBX_API void mdbx_assert_fail(const char *msg, const char *func, unsigned line);
1035
1040
1050LIBMDBX_API const char *mdbx_dump_val(const MDBX_val *key, char *const buf, const size_t bufsize);
1051
1053
1058typedef enum MDBX_env_flags {
1060
1066 MDBX_VALIDATION = UINT32_C(0x00002000),
1067
1084 MDBX_NOSUBDIR = UINT32_C(0x4000),
1085
1102 MDBX_RDONLY = UINT32_C(0x20000),
1103
1132 MDBX_EXCLUSIVE = UINT32_C(0x400000),
1133
1147 MDBX_ACCEDE = UINT32_C(0x40000000),
1148
1178 MDBX_WRITEMAP = UINT32_C(0x80000),
1179
1228 MDBX_NOSTICKYTHREADS = UINT32_C(0x200000),
1229
1231 MDBX_NOTLS MDBX_DEPRECATED_ENUM = MDBX_NOSTICKYTHREADS,
1232
1252 MDBX_NORDAHEAD = UINT32_C(0x800000),
1253
1275 MDBX_NOMEMINIT = UINT32_C(0x1000000),
1276
1288 MDBX_COALESCE MDBX_DEPRECATED_ENUM = UINT32_C(0x2000000),
1289
1312 MDBX_LIFORECLAIM = UINT32_C(0x4000000),
1313
1315 MDBX_PAGEPERTURB = UINT32_C(0x8000000),
1316
1317 /* SYNC MODES****************************************************************/
1359
1370
1387 MDBX_NOMETASYNC = UINT32_C(0x40000),
1388
1438 MDBX_SAFE_NOSYNC = UINT32_C(0x10000),
1439
1446
1489
1492DEFINE_ENUM_FLAG_OPERATORS(MDBX_env_flags)
1493
1494
1498typedef enum MDBX_txn_flags {
1504
1510
1517#if CONSTEXPR_ENUM_FLAGS_OPERATIONS || defined(DOXYGEN)
1519#else
1520 MDBX_TXN_RDONLY_PREPARE = uint32_t(MDBX_RDONLY) | uint32_t(MDBX_NOMEMINIT),
1521#endif
1522
1524 MDBX_TXN_TRY = UINT32_C(0x10000000),
1525
1528
1532
1536
1537 /* Transaction state flags ---------------------------------------------- */
1538
1542 MDBX_TXN_INVALID = INT32_MIN,
1543
1548
1553
1558
1563
1568
1573
1580
1587
1593DEFINE_ENUM_FLAG_OPERATORS(MDBX_txn_flags)
1594
1595
1599typedef enum MDBX_db_flags {
1602
1604 MDBX_REVERSEKEY = UINT32_C(0x02),
1605
1607 MDBX_DUPSORT = UINT32_C(0x04),
1608
1614 MDBX_INTEGERKEY = UINT32_C(0x08),
1615
1618 MDBX_DUPFIXED = UINT32_C(0x10),
1619
1623 MDBX_INTEGERDUP = UINT32_C(0x20),
1624
1626 MDBX_REVERSEDUP = UINT32_C(0x40),
1627
1629 MDBX_CREATE = UINT32_C(0x40000),
1630
1643DEFINE_ENUM_FLAG_OPERATORS(MDBX_db_flags)
1644
1645
1649typedef enum MDBX_put_flags {
1652
1654 MDBX_NOOVERWRITE = UINT32_C(0x10),
1655
1658 MDBX_NODUPDATA = UINT32_C(0x20),
1659
1664 MDBX_CURRENT = UINT32_C(0x40),
1665
1669 MDBX_ALLDUPS = UINT32_C(0x80),
1670
1673 MDBX_RESERVE = UINT32_C(0x10000),
1674
1677 MDBX_APPEND = UINT32_C(0x20000),
1678
1682 MDBX_APPENDDUP = UINT32_C(0x40000),
1683
1686 MDBX_MULTIPLE = UINT32_C(0x80000)
1688DEFINE_ENUM_FLAG_OPERATORS(MDBX_put_flags)
1689
1690
1724DEFINE_ENUM_FLAG_OPERATORS(MDBX_copy_flags)
1725
1726
1851
1857typedef enum MDBX_error {
1860
1863
1866
1869
1872
1875
1878
1881
1884 MDBX_PANIC = -30795,
1885
1888
1891
1894
1897
1900
1903
1907
1910
1919
1927
1930
1935
1939
1943
1946
1949
1952 MDBX_BUSY = -30778,
1953
1956
1959
1964
1968
1971
1975
1979
1982
1987
1990
1994
1997 MDBX_OUSTED = -30411,
1998
2001
2005
2006 /* The last of MDBX-added error codes */
2008
2009#if defined(_WIN32) || defined(_WIN64)
2010 MDBX_ENODATA = ERROR_HANDLE_EOF,
2011 MDBX_EINVAL = ERROR_INVALID_PARAMETER,
2012 MDBX_EACCESS = ERROR_ACCESS_DENIED,
2013 MDBX_ENOMEM = ERROR_OUTOFMEMORY,
2014 MDBX_EROFS = ERROR_FILE_READ_ONLY,
2015 MDBX_ENOSYS = ERROR_NOT_SUPPORTED,
2016 MDBX_EIO = ERROR_WRITE_FAULT,
2017 MDBX_EPERM = ERROR_INVALID_FUNCTION,
2018 MDBX_EINTR = ERROR_CANCELLED,
2019 MDBX_ENOFILE = ERROR_FILE_NOT_FOUND,
2020 MDBX_EREMOTE = ERROR_REMOTE_STORAGE_MEDIA_ERROR,
2021 MDBX_EDEADLK = ERROR_POSSIBLE_DEADLOCK
2022#else /* Windows */
2023#if defined(ENODATA) || defined(DOXYGEN)
2024 MDBX_ENODATA = ENODATA,
2025#else
2026 MDBX_ENODATA = 9919 /* for compatibility with LLVM's C++ libraries/headers */,
2027#endif /* ENODATA */
2028 MDBX_EINVAL = EINVAL,
2030 MDBX_ENOMEM = ENOMEM,
2031 MDBX_EROFS = EROFS,
2032#if defined(ENOTSUP) || defined(DOXYGEN)
2033 MDBX_ENOSYS = ENOTSUP,
2034#else
2035 MDBX_ENOSYS = ENOSYS,
2036#endif /* ENOTSUP */
2038 MDBX_EPERM = EPERM,
2039 MDBX_EINTR = EINTR,
2041#if defined(EREMOTEIO) || defined(DOXYGEN)
2043 MDBX_EREMOTE = EREMOTEIO,
2044#else
2045 MDBX_EREMOTE = ENOTBLK,
2046#endif /* EREMOTEIO */
2048#endif /* !Windows */
2049} MDBX_error_t;
2050
2055MDBX_DEPRECATED static __inline int MDBX_MAP_RESIZED_is_deprecated(void) { return MDBX_UNABLE_EXTEND_MAPSIZE; }
2056#define MDBX_MAP_RESIZED MDBX_MAP_RESIZED_is_deprecated()
2057
2076LIBMDBX_API const char *mdbx_strerror(int errnum);
2077
2102LIBMDBX_API const char *mdbx_strerror_r(int errnum, char *buf, size_t buflen);
2104
2105#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
2110LIBMDBX_API const char *mdbx_strerror_ANSI2OEM(int errnum);
2111
2116LIBMDBX_API const char *mdbx_strerror_r_ANSI2OEM(int errnum, char *buf, size_t buflen);
2117#endif /* Bit of Windows' madness */
2118
2134
2449
2460LIBMDBX_API int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64_t value);
2461
2472LIBMDBX_API int mdbx_env_get_option(const MDBX_env *env, const MDBX_option_t option, uint64_t *pvalue);
2473
2549LIBMDBX_API int mdbx_env_open(MDBX_env *env, const char *pathname, MDBX_env_flags_t flags, mdbx_mode_t mode);
2550
2551#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
2555LIBMDBX_API int mdbx_env_openW(MDBX_env *env, const wchar_t *pathname, MDBX_env_flags_t flags, mdbx_mode_t mode);
2556#define mdbx_env_openT(env, pathname, flags, mode) mdbx_env_openW(env, pathname, flags, mode)
2557#else
2558#define mdbx_env_openT(env, pathname, flags, mode) mdbx_env_open(env, pathname, flags, mode)
2559#endif /* Windows */
2560
2578
2599
2600#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
2605LIBMDBX_API int mdbx_env_deleteW(const wchar_t *pathname, MDBX_env_delete_mode_t mode);
2606#define mdbx_env_deleteT(pathname, mode) mdbx_env_deleteW(pathname, mode)
2607#else
2608#define mdbx_env_deleteT(pathname, mode) mdbx_env_delete(pathname, mode)
2609#endif /* Windows */
2610
2664LIBMDBX_API int mdbx_env_copy(MDBX_env *env, const char *dest, MDBX_copy_flags_t flags);
2665
2720
2721#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
2726LIBMDBX_API int mdbx_env_copyW(MDBX_env *env, const wchar_t *dest, MDBX_copy_flags_t flags);
2727#define mdbx_env_copyT(env, dest, flags) mdbx_env_copyW(env, dest, flags)
2728
2734#define mdbx_txn_copy2pathnameT(txn, dest, flags) mdbx_txn_copy2pathnameW(txn, dest, path)
2735#else
2736#define mdbx_env_copyT(env, dest, flags) mdbx_env_copy(env, dest, flags)
2737#define mdbx_txn_copy2pathnameT(txn, dest, flags) mdbx_txn_copy2pathname(txn, dest, path)
2738#endif /* Windows */
2739
2765
2790
2795 uint32_t ms_psize;
2797 uint32_t ms_depth;
2799 uint64_t ms_leaf_pages;
2801 uint64_t ms_entries;
2802 uint64_t ms_mod_txnid;
2803};
2804#ifndef __cplusplus
2806typedef struct MDBX_stat MDBX_stat;
2807#endif
2808
2828LIBMDBX_API int mdbx_env_stat_ex(const MDBX_env *env, const MDBX_txn *txn, MDBX_stat *stat, size_t bytes);
2829
2833MDBX_DEPRECATED inline int mdbx_env_stat(const MDBX_env *env, MDBX_stat *stat, size_t bytes) {
2834 return mdbx_env_stat_ex(env, NULL, stat, bytes);
2835}
2836
2841 struct {
2842 uint64_t lower;
2843 uint64_t upper;
2844 uint64_t current;
2845 uint64_t shrink;
2846 uint64_t grow;
2848 uint64_t mi_mapsize;
2849 uint64_t mi_dxb_fsize;
2851 uint64_t mi_last_pgno;
2856 uint32_t mi_maxreaders;
2857 uint32_t mi_numreaders;
2860 uint32_t mi_sys_upcblk;
2861 uint32_t mi_sys_ioblk;
2862
2871 struct {
2872 struct {
2873 uint64_t x, y;
2874 } current, meta[3];
2876
2893 uint32_t mi_mode;
2894
2900 struct {
2901 uint64_t newly;
2902 uint64_t cow;
2903 uint64_t clone;
2905 uint64_t split;
2906 uint64_t merge;
2907 uint64_t spill;
2908 uint64_t unspill;
2909 uint64_t wops;
2911 uint64_t prefault;
2912 uint64_t mincore;
2913 uint64_t msync;
2914 uint64_t fsync;
2916
2917 /* GUID of the database DXB file. */
2918 struct {
2919 uint64_t x, y;
2921};
2922#ifndef __cplusplus
2924typedef struct MDBX_envinfo MDBX_envinfo;
2925#endif
2926
2947LIBMDBX_API int mdbx_env_info_ex(const MDBX_env *env, const MDBX_txn *txn, MDBX_envinfo *info, size_t bytes);
2951MDBX_DEPRECATED inline int mdbx_env_info(const MDBX_env *env, MDBX_envinfo *info, size_t bytes) {
2952 return mdbx_env_info_ex(env, NULL, info, bytes);
2953}
2954
2991LIBMDBX_API int mdbx_env_sync_ex(MDBX_env *env, bool force, bool nonblock);
2992
2996inline int mdbx_env_sync(MDBX_env * env) { return mdbx_env_sync_ex(env, true, false); }
2997
3001inline int mdbx_env_sync_poll(MDBX_env * env) { return mdbx_env_sync_ex(env, false, true); }
3002
3026inline int mdbx_env_set_syncbytes(MDBX_env * env, size_t threshold) {
3027 return mdbx_env_set_option(env, MDBX_opt_sync_bytes, threshold);
3028}
3029
3044inline int mdbx_env_get_syncbytes(const MDBX_env *env, size_t *threshold) {
3045 int rc = MDBX_EINVAL;
3046 if (threshold) {
3047 uint64_t proxy = 0;
3048 rc = mdbx_env_get_option(env, MDBX_opt_sync_bytes, &proxy);
3049 MDBX_INLINE_API_ASSERT(proxy <= SIZE_MAX);
3050 *threshold = (size_t)proxy;
3051 }
3052 return rc;
3053}
3054
3085inline int mdbx_env_set_syncperiod(MDBX_env * env, unsigned seconds_16dot16) {
3086 return mdbx_env_set_option(env, MDBX_opt_sync_period, seconds_16dot16);
3087}
3088
3105inline int mdbx_env_get_syncperiod(const MDBX_env *env, unsigned *period_seconds_16dot16) {
3106 int rc = MDBX_EINVAL;
3107 if (period_seconds_16dot16) {
3108 uint64_t proxy = 0;
3109 rc = mdbx_env_get_option(env, MDBX_opt_sync_period, &proxy);
3110 MDBX_INLINE_API_ASSERT(proxy <= UINT32_MAX);
3111 *period_seconds_16dot16 = (unsigned)proxy;
3112 }
3113 return rc;
3114}
3115
3155LIBMDBX_API int mdbx_env_close_ex(MDBX_env *env, bool dont_sync);
3156
3160inline int mdbx_env_close(MDBX_env * env) { return mdbx_env_close_ex(env, false); }
3161
3162#if defined(DOXYGEN) || !(defined(_WIN32) || defined(_WIN64))
3222#endif /* Windows */
3223
3272DEFINE_ENUM_FLAG_OPERATORS(MDBX_warmup_flags)
3273
3274
3305 unsigned timeout_seconds_16dot16);
3306
3328
3339LIBMDBX_API int mdbx_env_get_flags(const MDBX_env *env, unsigned *flags);
3340
3354LIBMDBX_API int mdbx_env_get_path(const MDBX_env *env, const char **dest);
3355
3356#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
3361LIBMDBX_API int mdbx_env_get_pathW(const MDBX_env *env, const wchar_t **dest);
3362#define mdbx_env_get_pathT(env, dest) mdbx_env_get_pathW(env, dest)
3363#else
3364#define mdbx_env_get_pathT(env, dest) mdbx_env_get_path(env, dest)
3365#endif /* Windows */
3366
3380
3577LIBMDBX_API int mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now, intptr_t size_upper,
3578 intptr_t growth_step, intptr_t shrink_threshold, intptr_t pagesize);
3579
3582MDBX_DEPRECATED inline int mdbx_env_set_mapsize(MDBX_env * env, size_t size) {
3583 return mdbx_env_set_geometry(env, size, size, size, -1, -1, -1);
3584}
3585
3601LIBMDBX_API int mdbx_is_readahead_reasonable(size_t volume, intptr_t redundancy);
3602
3606
3610
3615
3620
3626
3631
3637
3642
3648 MDBX_db_flags_t flags);
3649
3656
3661
3685inline int mdbx_env_set_maxreaders(MDBX_env * env, unsigned readers) {
3686 return mdbx_env_set_option(env, MDBX_opt_max_readers, readers);
3687}
3688
3700inline int mdbx_env_get_maxreaders(const MDBX_env *env, unsigned *readers) {
3701 int rc = MDBX_EINVAL;
3702 if (readers) {
3703 uint64_t proxy = 0;
3704 rc = mdbx_env_get_option(env, MDBX_opt_max_readers, &proxy);
3705 *readers = (unsigned)proxy;
3706 }
3707 return rc;
3708}
3709
3731inline int mdbx_env_set_maxdbs(MDBX_env * env, MDBX_dbi dbs) {
3732 return mdbx_env_set_option(env, MDBX_opt_max_db, dbs);
3733}
3734
3745inline int mdbx_env_get_maxdbs(const MDBX_env *env, MDBX_dbi *dbs) {
3746 int rc = MDBX_EINVAL;
3747 if (dbs) {
3748 uint64_t proxy = 0;
3749 rc = mdbx_env_get_option(env, MDBX_opt_max_db, &proxy);
3750 *dbs = (MDBX_dbi)proxy;
3751 }
3752 return rc;
3753}
3754
3760
3775LIBMDBX_API int mdbx_get_sysraminfo(intptr_t *page_size, intptr_t *total_pages, intptr_t *avail_pages);
3776
3787
3798
3803
3814
3826
3836
3845
3905 void *context);
3906
3961inline int mdbx_txn_begin(MDBX_env * env, MDBX_txn *parent, MDBX_txn_flags_t flags, MDBX_txn **txn) {
3962 return mdbx_txn_begin_ex(env, parent, flags, txn, NULL);
3963}
3964
4016LIBMDBX_API int mdbx_txn_clone(const MDBX_txn *origin, MDBX_txn **in_out_clone, void *context);
4017
4028
4040
4047 uint64_t txn_id;
4048
4054
4058
4061
4065
4073
4080
4087
4090 uint64_t txn_pget;
4091};
4092#ifndef __cplusplus
4094typedef struct MDBX_txn_info MDBX_txn_info;
4095#endif
4096
4110LIBMDBX_API int mdbx_txn_info(const MDBX_txn *txn, MDBX_txn_info *info, bool scan_rlt);
4111
4117
4128
4141
4149 uint32_t preparation;
4153 uint32_t audit;
4156 uint32_t write;
4159 uint32_t sync;
4161 uint32_t ending;
4163 uint32_t whole;
4165 uint32_t gc_cputime;
4166
4175 struct {
4177 uint32_t wloops;
4179 uint32_t coalescences;
4182 uint32_t wipes;
4185 uint32_t flushes;
4188 uint32_t kicks;
4189
4191 uint32_t work_counter;
4193 uint32_t work_rtime_monotonic;
4196 uint32_t work_xtime_cpu;
4198 uint32_t work_rsteps;
4200 uint32_t work_xpages;
4202 uint32_t work_majflt;
4203
4205 uint32_t self_counter;
4208 uint32_t self_rtime_monotonic;
4211 uint32_t self_xtime_cpu;
4214 uint32_t self_rsteps;
4216 uint32_t self_xpages;
4218 uint32_t self_majflt;
4220 struct {
4221 uint32_t time;
4222 uint64_t volume;
4223 uint32_t calls;
4224 } pnl_merge_work, pnl_merge_self;
4225
4226 uint32_t max_reader_lag;
4228 uint32_t max_retained_pages;
4230};
4231#ifndef __cplusplus
4234#endif
4235
4289
4325
4362
4426LIBMDBX_API int mdbx_txn_amend(MDBX_txn *read_txn, MDBX_txn **ptr_write_txn, MDBX_txn_flags_t flags, void *context);
4427
4454
4505inline int mdbx_txn_commit(MDBX_txn * txn) { return mdbx_txn_commit_ex(txn, NULL); }
4506
4519
4562inline int mdbx_txn_abort(MDBX_txn * txn) { return mdbx_txn_abort_ex(txn, NULL); }
4563
4576
4611
4644LIBMDBX_API int mdbx_txn_park(MDBX_txn *txn, bool autounpark);
4645
4677LIBMDBX_API int mdbx_txn_unpark(MDBX_txn *txn, bool restart_if_ousted);
4678
4703
4729
4741 uint64_t x, y, z, v;
4742};
4743#ifndef __cplusplus
4745typedef struct MDBX_canary MDBX_canary;
4746#endif
4747
4767
4779
4800typedef int (*MDBX_cmp_func)(const MDBX_val *a, const MDBX_val *b) MDBX_CXX17_NOEXCEPT;
4801
4895LIBMDBX_API int mdbx_dbi_open(MDBX_txn *txn, const char *name, MDBX_db_flags_t flags, MDBX_dbi *dbi);
4899
4918MDBX_DEPRECATED LIBMDBX_API int mdbx_dbi_open_ex(MDBX_txn *txn, const char *name, MDBX_db_flags_t flags, MDBX_dbi *dbi,
4919 MDBX_cmp_func keycmp, MDBX_cmp_func datacmp);
4922MDBX_DEPRECATED LIBMDBX_API int mdbx_dbi_open_ex2(MDBX_txn *txn, const MDBX_val *name, MDBX_db_flags_t flags,
4923 MDBX_dbi *dbi, MDBX_cmp_func keycmp, MDBX_cmp_func datacmp);
4924
4938LIBMDBX_API int mdbx_dbi_rename(MDBX_txn *txn, MDBX_dbi dbi, const char *name);
4942
4958typedef int (*MDBX_table_enum_func)(void *ctx, const MDBX_txn *txn, const MDBX_val *name, MDBX_db_flags_t flags,
4959 const struct MDBX_stat *stat, MDBX_dbi dbi) MDBX_CXX17_NOEXCEPT;
4960
4979
4992
4994
4995MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API uint64_t mdbx_key_from_ptrdouble(const double *const ieee754_64bit);
4996
4998
4999MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API uint32_t mdbx_key_from_ptrfloat(const float *const ieee754_32bit);
5000
5001MDBX_NOTHROW_CONST_FUNCTION inline uint64_t mdbx_key_from_int64(const int64_t i64) {
5002 return UINT64_C(0x8000000000000000) + i64;
5003}
5004
5005MDBX_NOTHROW_CONST_FUNCTION inline uint32_t mdbx_key_from_int32(const int32_t i32) {
5006 return UINT32_C(0x80000000) + i32;
5007}
5008
5009
5016
5018
5020
5022
5025
5040LIBMDBX_API int mdbx_dbi_stat(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_stat *stat, size_t bytes);
5041
5057LIBMDBX_API int mdbx_dbi_dupsort_depthmask(const MDBX_txn *txn, MDBX_dbi dbi, uint32_t *mask);
5058
5062typedef enum MDBX_dbi_state {
5072DEFINE_ENUM_FLAG_OPERATORS(MDBX_dbi_state)
5073
5074
5085LIBMDBX_API int mdbx_dbi_flags_ex(const MDBX_txn *txn, MDBX_dbi dbi, unsigned *flags, unsigned *state);
5090inline int mdbx_dbi_flags(const MDBX_txn *txn, MDBX_dbi dbi, unsigned *flags) {
5091 unsigned state;
5092 return mdbx_dbi_flags_ex(txn, dbi, flags, &state);
5093}
5094
5121
5133LIBMDBX_API int mdbx_drop(MDBX_txn *txn, MDBX_dbi dbi, bool del);
5134
5171LIBMDBX_API int mdbx_get(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data);
5172
5202LIBMDBX_API int mdbx_get_ex(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_val *key, MDBX_val *data, size_t *values_count);
5203
5233
5247typedef struct MDBX_cache_entry {
5248 uint64_t trunk_txnid;
5252 size_t offset;
5254 uint32_t length;
5256
5262 entry->offset = 0;
5263 entry->length = 0;
5264 entry->trunk_txnid = 0;
5265 entry->last_confirmed_txnid = 0;
5266}
5267
5342
5353
5379 volatile MDBX_cache_entry_t *entry);
5380
5406 MDBX_val *data, MDBX_cache_entry_t *entry);
5407
5489LIBMDBX_API int mdbx_put(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data, MDBX_put_flags_t flags);
5490
5535LIBMDBX_API int mdbx_replace(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *new_data, MDBX_val *old_data,
5536 MDBX_put_flags_t flags);
5537
5540typedef int (*MDBX_preserve_func)(void *context, MDBX_val *target, const void *src, size_t bytes);
5541
5595LIBMDBX_API int mdbx_replace_ex(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *new_data,
5596 MDBX_val *old_data, MDBX_put_flags_t flags, MDBX_preserve_func preserver,
5597 void *preserver_context);
5598
5624LIBMDBX_API int mdbx_del(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, const MDBX_val *data);
5625
5649
5660
5671
5702
5729
5741
5773
5794
5817
5840LIBMDBX_API int mdbx_txn_release_all_cursors_ex(const MDBX_txn *txn, bool unbind, size_t *count);
5841
5862inline int mdbx_txn_release_all_cursors(const MDBX_txn *txn, bool unbind) {
5863 return mdbx_txn_release_all_cursors_ex(txn, unbind, NULL);
5864}
5865
5891
5897
5903
5915
5934LIBMDBX_API int mdbx_cursor_compare(const MDBX_cursor *left, const MDBX_cursor *right, bool ignore_multival);
5935
5968
5982
6010typedef int (*MDBX_predicate_func)(void *context, MDBX_val *key, MDBX_val *value, void *arg) MDBX_CXX17_NOEXCEPT;
6011
6063LIBMDBX_API int mdbx_cursor_scan(MDBX_cursor *cursor, MDBX_predicate_func predicate, void *context,
6064 MDBX_cursor_op start_op, MDBX_cursor_op turn_op, void *arg);
6065
6136 MDBX_cursor_op from_op, MDBX_val *from_key, MDBX_val *from_value,
6137 MDBX_cursor_op turn_op, void *arg);
6138
6180LIBMDBX_API int mdbx_cursor_get_batch(MDBX_cursor *cursor, size_t *count, MDBX_val *pairs, size_t limit,
6181 MDBX_cursor_op op);
6182
6264
6296
6317
6344LIBMDBX_API int mdbx_cursor_bunch_delete(MDBX_cursor *cursor, MDBX_bunch_action_t action, uint64_t *number_of_affected);
6345
6363LIBMDBX_API int mdbx_cursor_count(const MDBX_cursor *cursor, size_t *count);
6364
6387LIBMDBX_API int mdbx_cursor_count_ex(const MDBX_cursor *cursor, size_t *count, MDBX_stat *stat, size_t bytes);
6388
6402
6415
6430
6441
6455
6480
6500LIBMDBX_API int mdbx_estimate_distance(const MDBX_cursor *first, const MDBX_cursor *last, ptrdiff_t *distance_items);
6501
6523 ptrdiff_t *distance_items);
6524
6549LIBMDBX_API int mdbx_estimate_range(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *begin_key,
6550 const MDBX_val *begin_data, const MDBX_val *end_key, const MDBX_val *end_data,
6551 ptrdiff_t *distance_items);
6552
6555#define MDBX_EPSILON ((MDBX_val *)((ptrdiff_t)-1))
6556
6591
6612LIBMDBX_API int mdbx_dbi_sequence(MDBX_txn *txn, MDBX_dbi dbi, uint64_t *result, uint64_t increment);
6613
6630 const MDBX_val *b);
6631
6635
6652 const MDBX_val *b);
6653
6657
6683typedef int (*MDBX_reader_list_func)(void *ctx, int num, int slot, mdbx_pid_t pid, mdbx_tid_t thread, uint64_t txnid,
6684 uint64_t lag, size_t bytes_used, size_t bytes_retained) MDBX_CXX17_NOEXCEPT;
6685
6698
6708
6721MDBX_DEPRECATED LIBMDBX_API int mdbx_txn_straggler(const MDBX_txn *txn, int *percent);
6722
6742
6757
6831typedef int (*MDBX_hsr_func)(const MDBX_env *env, const MDBX_txn *txn, mdbx_pid_t pid, mdbx_tid_t tid, uint64_t laggard,
6832 unsigned gap, size_t space, int retry) MDBX_CXX17_NOEXCEPT;
6833
6853
6867
6873
6878LIBMDBX_API int mdbx_txn_lock(MDBX_env *env, bool dont_wait);
6879
6885
6896LIBMDBX_API int mdbx_env_open_for_recovery(MDBX_env *env, const char *pathname, unsigned target_meta, bool writeable);
6897
6898#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
6903LIBMDBX_API int mdbx_env_open_for_recoveryW(MDBX_env *env, const wchar_t *pathname, unsigned target_meta,
6904 bool writeable);
6905#define mdbx_env_open_for_recoveryT(env, pathname, target_mets, writeable) \
6906 mdbx_env_open_for_recoveryW(env, pathname, target_mets, writeable)
6907#else
6908#define mdbx_env_open_for_recoveryT(env, pathname, target_mets, writeable) \
6909 mdbx_env_open_for_recovery(env, pathname, target_mets, writeable)
6910#endif /* Windows */
6911
6917LIBMDBX_API int mdbx_env_turn_for_recovery(MDBX_env *env, unsigned target_meta);
6918
6945LIBMDBX_API int mdbx_preopen_snapinfo(const char *pathname, MDBX_envinfo *info, size_t bytes);
6946#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
6951LIBMDBX_API int mdbx_preopen_snapinfoW(const wchar_t *pathname, MDBX_envinfo *info, size_t bytes);
6952#define mdbx_preopen_snapinfoT(pathname, info, bytes) mdbx_preopen_snapinfoW(pathname, info, bytes)
6953#else
6954#define mdbx_preopen_snapinfoT(pathname, info, bytes) mdbx_preopen_snapinfo(pathname, info, bytes)
6955#endif /* Windows */
6956
6979DEFINE_ENUM_FLAG_OPERATORS(MDBX_chk_flags)
6980
6981
6999
7017
7021typedef struct MDBX_chk_line {
7022 struct MDBX_chk_context *ctx;
7024 char *begin, *end, *out;
7026
7030typedef struct MDBX_chk_issue {
7031 struct MDBX_chk_issue *next;
7032 size_t count;
7033 const char *caption;
7035
7039typedef struct MDBX_chk_scope {
7041 struct MDBX_chk_internal *internal;
7042 const void *object;
7046 union {
7047 void *ptr;
7048 size_t number;
7049 } usr_z, usr_v, usr_o;
7051
7056typedef struct MDBX_chk_user_table_cookie MDBX_chk_user_table_cookie_t;
7057
7063 struct {
7064 size_t begin, end, amount, count;
7066};
7067
7071typedef struct MDBX_chk_table {
7073
7075#define MDBX_CHK_MAIN ((void *)((ptrdiff_t)0))
7077#define MDBX_CHK_GC ((void *)((ptrdiff_t)-1))
7079#define MDBX_CHK_META ((void *)((ptrdiff_t)-2))
7080
7083 int id;
7084
7086 struct {
7087 size_t all, empty, broken;
7088 size_t branch, leaf;
7090 } pages;
7114
7142
7155typedef struct MDBX_chk_callbacks {
7157 int (*scope_push)(MDBX_chk_context_t *ctx, MDBX_chk_scope_t *outer, MDBX_chk_scope_t *inner, const char *fmt,
7158 va_list args);
7161 void (*issue)(MDBX_chk_context_t *ctx, const char *object, uint64_t entry_number, const char *issue,
7162 const char *extra_fmt, va_list extra_args);
7164 int (*table_conclude)(MDBX_chk_context_t *ctx, const MDBX_chk_table_t *table, MDBX_cursor *cursor, int err);
7166
7167 int (*table_handle_kv)(MDBX_chk_context_t *ctx, const MDBX_chk_table_t *table, size_t entry_number,
7168 const MDBX_val *key, const MDBX_val *value);
7169
7172
7176 void (*print_chars)(MDBX_chk_line_t *, const char *str, size_t len);
7177 void (*print_format)(MDBX_chk_line_t *, const char *fmt, va_list args);
7178 void (*print_size)(MDBX_chk_line_t *, const char *prefix, const uint64_t value, const char *suffix);
7180
7205 const MDBX_chk_flags_t flags, MDBX_chk_severity_t verbosity,
7206 unsigned timeout_seconds_16dot16);
7207
7219
7228LIBMDBX_API const char *mdbx_ratio2digits(uint64_t numerator, uint64_t denominator, int precision, char *buffer,
7229 size_t buffer_size);
7230
7238LIBMDBX_API const char *mdbx_ratio2percents(uint64_t value, uint64_t whole, char *buffer, size_t buffer_size);
7239
7241
7259typedef int (*MDBX_gc_iter_func)(void *ctx, const MDBX_txn *txn, uint64_t span_txnid, size_t span_pgno,
7260 size_t span_length, bool span_is_reclaimable) MDBX_CXX17_NOEXCEPT;
7261
7265typedef struct MDBX_gc_info {
7269 size_t pages_gc;
7271 struct {
7272 size_t pages;
7273 struct MDBX_chk_histogram
7276 } gc_reclaimable;
7280
7312LIBMDBX_API int mdbx_gc_info(MDBX_txn *txn, MDBX_gc_info_t *info, size_t bytes, MDBX_gc_iter_func iter_func,
7313 void *iter_ctx);
7314
7334DEFINE_ENUM_FLAG_OPERATORS(MDBX_defrag_stopping_reasons)
7335
7336
7340typedef struct MDBX_defrag_result {
7345
7348
7351
7355
7358
7361
7365
7369
7379
7383
7385 unsigned cycles;
7386
7390
7394
7414typedef int (*MDBX_defrag_notify_func)(void *ctx, const MDBX_defrag_result_t *progress) MDBX_CXX17_NOEXCEPT;
7415
7505LIBMDBX_API int mdbx_env_defrag(MDBX_env *env, size_t defrag_atleast, size_t time_atleast_dot16, size_t defrag_enough,
7506 size_t time_limit_dot16, intptr_t acceptable_backlash, intptr_t preferred_batch,
7507 MDBX_defrag_notify_func progress_callback, void *ctx, MDBX_defrag_result_t *result);
7508
7510
7511#ifdef __cplusplus
7512} /* extern "C" */
7513#endif
7514
7515#endif /* LIBMDBX_H */
#define MDBX_INLINE_API_ASSERT(expr)
Definition mdbx.h:605
#define MDBX_NOTHROW_CONST_FUNCTION
The 'const nothrow' function attribute for optimization.
Definition mdbx.h:315
#define MDBX_CXX17_NOEXCEPT
Definition mdbx.h:429
#define MDBX_NOTHROW_PURE_FUNCTION
The 'pure nothrow' function attribute for optimization.
Definition mdbx.h:274
#define MDBX_NORETURN
Definition mdbx.h:499
uint64_t mi_mapsize
Definition mdbx.h:2848
uint32_t wipes
The number of previous reliable/stable committed points erased when working in MDBX_UTTERLY_NOSYNC mo...
size_t pages_scheduled
Definition mdbx.h:7350
uint64_t txn_space_dirty
Definition mdbx.h:4086
struct MDBX_envinfo::@012005163333303136244023145022271211024347140371 mi_geo
uint32_t gc_cputime
User-mode CPU time spent on GC update.
Definition mdbx.h:4165
const char * describe
struct MDBX_chk_histogram pgno_distribution
uint32_t mi_dxb_pagesize
Definition mdbx.h:2858
uint32_t mi_maxreaders
Definition mdbx.h:2856
MDBX_error_t errcode
Definition mdbx.h:5349
uint64_t v
Definition mdbx.h:4741
uint64_t obstructed_txnid
Definition mdbx.h:7372
intptr_t pages_shrinked
Definition mdbx.h:7344
size_t obstructed_span
Definition mdbx.h:7368
uint32_t coalescences
The number of iterations of merging GC items.
uint32_t mi_numreaders
Definition mdbx.h:2857
uint16_t patch
Definition mdbx.h:662
const char * metadata
Definition mdbx.h:683
uint32_t mi_since_sync_seconds16dot16
Definition mdbx.h:2884
uint32_t length
Definition mdbx.h:5254
uint32_t self_xpages
The number of page sequences allocation requests for the GC itself.
uint16_t major
Definition mdbx.h:660
uint64_t txn_reader_lag
Definition mdbx.h:4053
uint64_t mi_meta_txnid[3]
Definition mdbx.h:2855
MDBX_cache_status_t status
Definition mdbx.h:5351
uint64_t txn_space_leftover
Definition mdbx.h:4079
struct MDBX_envinfo::@366225332126364017271247035205240304242123014254 mi_pgop_stat
uint64_t txn_space_used
Definition mdbx.h:4057
const char * datetime
Definition mdbx.h:678
mdbx_tid_t obstructor_tid
Definition mdbx.h:7375
size_t pages_total
Definition mdbx.h:7266
uint64_t mi_recent_txnid
Definition mdbx.h:2852
size_t pages_moved
Definition mdbx.h:7347
uint64_t mi_autosync_threshold
Definition mdbx.h:2880
size_t pages_allocated
Definition mdbx.h:7268
const char * semver_prerelease
Definition mdbx.h:664
uint32_t wloops
The number of GC update iterations is greater than 1 if there were repeats/restarts.
size_t pages_gc
Definition mdbx.h:7269
uint64_t ms_branch_pages
Definition mdbx.h:2798
uint64_t ms_entries
Definition mdbx.h:2801
uint32_t gc_wallclock
Duration of GC update by wall clock.
Definition mdbx.h:4151
unsigned rough_estimation_cycle_progress_permille
Definition mdbx.h:7382
uint16_t minor
Definition mdbx.h:661
uint64_t txn_pget
Definition mdbx.h:4090
size_t offset
Definition mdbx.h:5252
uint32_t mi_since_reader_check_seconds16dot16
Definition mdbx.h:2890
uint64_t y
Definition mdbx.h:4741
size_t max_retained_pages
Definition mdbx.h:7278
size_t max_reader_lag
Definition mdbx.h:7277
uint64_t last_confirmed_txnid
Definition mdbx.h:5250
unsigned stopping_reasons
Definition mdbx.h:7389
struct MDBX_envinfo::@041066021046127331076001156004251200350305323267 mi_dxbid
uint32_t sync
Duration of syncing written data to the disk/storage, i.e. the duration of a fdatasync() or a msync()...
Definition mdbx.h:4159
uint32_t mi_sys_ioblk
Definition mdbx.h:2861
mdbx_pid_t obstructor_pid
Definition mdbx.h:7378
uint64_t txn_space_limit_soft
Definition mdbx.h:4060
uint32_t mi_mode
Definition mdbx.h:2893
size_t pages_retained
Definition mdbx.h:7354
const char * options
Definition mdbx.h:680
uint64_t txn_id
Definition mdbx.h:4047
const char * sourcery
Definition mdbx.h:671
uint64_t mi_latter_reader_txnid
Definition mdbx.h:2853
uint64_t ms_overflow_pages
Definition mdbx.h:2800
uint32_t self_rsteps
The number of search iterations inside the GC when allocating pages for the purposes of maintaining a...
struct MDBX_envinfo::@036110245144360117333346206230046231375034327042 mi_bootid
A mostly unique ID that is regenerated on each boot.
uint32_t self_majflt
The number of page faults within the GC when allocating and preparing pages for the GC itself.
uint32_t work_majflt
The number of page faults inside the GC when allocating and preparing pages for user's data.
uint32_t preparation
Duration of preparation (commit child transactions, update table's records and cursors destroying).
Definition mdbx.h:4149
uint32_t mi_sys_upcblk
Definition mdbx.h:2860
uint64_t z
Definition mdbx.h:4741
unsigned cycles
Definition mdbx.h:7385
uint64_t txn_space_limit_hard
Definition mdbx.h:4064
uint32_t whole
The total duration of a commit.
Definition mdbx.h:4163
uint32_t flushes
The number of forced commits to disk to avoid the database growth when working outside of MDBX_UTTERL...
uint32_t work_xpages
The number of requests to allocate page sequences for the sake of user's data.
const char * flags
Definition mdbx.h:682
uint32_t self_counter
The GC's slow path execution count is for the purposes of maintaining and updating the GC itself.
size_t pages_whole
Definition mdbx.h:7360
struct MDBX_chk_histogram span_histogram
uint32_t self_rtime_monotonic
The time "by the wall clock" spent reading and searching inside the GC for the purposes of maintainin...
struct MDBX_commit_latency::@063112077126007214166021162020057361221355030117 gc_prof
Information for GC profiling.
uint64_t mi_meta_sign[3]
Definition mdbx.h:2855
uint32_t ms_psize
Definition mdbx.h:2795
uint32_t kicks
The number of accesses to the Handle-Slow-Readers mechanism to avoid void the database growth.
uint32_t audit
Duration of internal audit if enabled.
Definition mdbx.h:4153
size_t obstructed_pgno
Definition mdbx.h:7364
uint16_t tweak
Definition mdbx.h:663
const char * target
Definition mdbx.h:679
uint32_t write
Duration of writing dirty/modified data pages to a filesystem, i.e. the summary duration of a write()...
Definition mdbx.h:4156
uint64_t txn_space_retired
Definition mdbx.h:4072
uint32_t ms_depth
Definition mdbx.h:2797
uint64_t mi_dxb_fallocated
Definition mdbx.h:2850
uint64_t mi_last_pgno
Definition mdbx.h:2851
uint32_t work_counter
Number of slow/deep path GC search for the sake of placement user's data.
uint32_t self_xtime_cpu
The CPU time in user mode spent preparing pages taken from the GC for the purposes of maintaining and...
uint32_t ending
Duration of transaction ending (releasing resources).
Definition mdbx.h:4161
uint64_t ms_mod_txnid
Definition mdbx.h:2802
uint32_t work_rsteps
The number of search iterations inside GC when allocating pages for the sake of user's data.
size_t pages_backed
Definition mdbx.h:7267
uint64_t trunk_txnid
Definition mdbx.h:5248
const char * datetime
uint64_t mi_self_latter_reader_txnid
Definition mdbx.h:2854
uint64_t ms_leaf_pages
Definition mdbx.h:2799
uint64_t mi_dxb_fsize
Definition mdbx.h:2849
uint64_t x
Definition mdbx.h:4741
uint32_t mi_autosync_period_seconds16dot16
Definition mdbx.h:2887
uint64_t mi_unsync_volume
Definition mdbx.h:2878
uint32_t mi_sys_pagesize
Definition mdbx.h:2859
size_t pages_left
Definition mdbx.h:7357
struct MDBX_version_info::@246336125106374236367351214106016351032060025144 git
uint32_t work_rtime_monotonic
The time "by the wall clock" spent reading and searching inside the GC for the user's data.
uint32_t work_xtime_cpu
The CPU time in user mode spent for preparing pages taken from the GC for user data,...
size_t spent_time_dot16
Definition mdbx.h:7392
const char * compiler
Definition mdbx.h:681
MDBX_constants
Definition mdbx.h:811
mode_t mdbx_mode_t
Definition mdbx.h:187
LIBMDBX_API MDBX_hsr_func mdbx_env_get_hsr(const MDBX_env *env)
Gets current Handle-Slow-Readers callback used to resolve database full/overflow issue due to a reade...
#define LIBMDBX_API
Definition mdbx.h:634
struct iovec MDBX_val
Generic structure used for passing keys and data in and out of the table. .
Definition mdbx.h:808
LIBMDBX_VERINFO_API const struct MDBX_version_info mdbx_version
libmdbx version information
pthread_t mdbx_tid_t
Definition mdbx.h:186
LIBMDBX_VERINFO_API const struct MDBX_build_info mdbx_build
libmdbx build information
struct MDBX_env MDBX_env
Opaque structure for a database environment.
Definition mdbx.h:741
int mdbx_filehandle_t
Definition mdbx.h:184
LIBMDBX_API const char * mdbx_liberr2str(int errnum)
pid_t mdbx_pid_t
Definition mdbx.h:185
LIBMDBX_API int mdbx_env_openW(MDBX_env *env, const wchar_t *pathname, MDBX_env_flags_t flags, mdbx_mode_t mode)
Open an environment instance.
#define LIBMDBX_VERINFO_API
Definition mdbx.h:655
@ MDBX_MAX_PAGESIZE
Definition mdbx.h:822
@ MDBX_MAXDATASIZE
Definition mdbx.h:816
@ MDBX_MAX_DBI
Definition mdbx.h:813
@ MDBX_MIN_PAGESIZE
Definition mdbx.h:819
libmdbx build information
Definition mdbx.h:677
Lightweight transparent cache entry structure used by mdbx_cache_get().
Definition mdbx.h:5247
Pair of error code and cache status as a result of mdbx_cache_get().
Definition mdbx.h:5347
The fours integers markers (aka "canary") associated with the environment.
Definition mdbx.h:4740
Latency of commit stages in 1/65536 of seconds units.
Definition mdbx.h:4146
The numerical metrics of progress and result of database defragmentation.
Definition mdbx.h:7340
Information about the environment.
Definition mdbx.h:2840
Information about Garbage Collection and page usage.
Definition mdbx.h:7265
Statistics for a table in the environment.
Definition mdbx.h:2794
Information about the transaction.
Definition mdbx.h:4044
libmdbx version information,
Definition mdbx.h:659
MDBX_bunch_action_t
Modes for deleting bunches of neighboring items with self-documenting names.
Definition mdbx.h:6304
LIBMDBX_API int mdbx_cursor_del(MDBX_cursor *cursor, MDBX_put_flags_t flags)
Delete current key/data pair.
int(* MDBX_preserve_func)(void *context, MDBX_val *target, const void *src, size_t bytes)
A data preservation callback for using within mdbx_replace_ex().
Definition mdbx.h:5540
LIBMDBX_API int mdbx_dbi_sequence(MDBX_txn *txn, MDBX_dbi dbi, uint64_t *result, uint64_t increment)
Sequence generation for a table.
LIBMDBX_API int mdbx_cursor_scan(MDBX_cursor *cursor, MDBX_predicate_func predicate, void *context, MDBX_cursor_op start_op, MDBX_cursor_op turn_op, void *arg)
Scans the table using the passed predicate, reducing the associated overhead.
LIBMDBX_API int mdbx_get_equal_or_great(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_val *key, MDBX_val *data)
Get equal or great item from a table.
LIBMDBX_API int mdbx_canary_put(MDBX_txn *txn, const MDBX_canary *canary)
Set integers markers (aka "canary") associated with the environment.
LIBMDBX_API int mdbx_canary_get(const MDBX_txn *txn, MDBX_canary *canary)
Returns fours integers markers (aka "canary") associated with the environment.
MDBX_put_flags_t
Data changing flags.
Definition mdbx.h:1649
LIBMDBX_API MDBX_cache_result_t mdbx_cache_get(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data, volatile MDBX_cache_entry_t *entry)
Gets items from a table using cache including multithreaded cases.
LIBMDBX_API int mdbx_replace_ex(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *new_data, MDBX_val *old_data, MDBX_put_flags_t flags, MDBX_preserve_func preserver, void *preserver_context)
Replaces item in a table using preservation callback for an original data.
LIBMDBX_API int mdbx_cursor_get_batch(MDBX_cursor *cursor, size_t *count, MDBX_val *pairs, size_t limit, MDBX_cursor_op op)
Retrieve multiple non-dupsort key/value pairs by cursor.
LIBMDBX_API int mdbx_cursor_count(const MDBX_cursor *cursor, size_t *count)
Return count values (aka duplicates) for current key.
int(* MDBX_cmp_func)(const MDBX_val *a, const MDBX_val *b) noexcept
A callback function used to compare two keys in a table.
Definition mdbx.h:4800
int(* MDBX_predicate_func)(void *context, MDBX_val *key, MDBX_val *value, void *arg) noexcept
The type of predicative callback functions used by mdbx_cursor_scan() and mdbx_cursor_scan_from() to ...
Definition mdbx.h:6010
LIBMDBX_API int mdbx_cursor_count_ex(const MDBX_cursor *cursor, size_t *count, MDBX_stat *stat, size_t bytes)
Return count values (aka duplicates) and nested b-tree statistics for current key.
MDBX_cache_status_t
Cache entry status returned by mdbx_cache_get().
Definition mdbx.h:5272
LIBMDBX_API MDBX_cache_result_t mdbx_cache_get_SingleThreaded(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data, MDBX_cache_entry_t *entry)
Gets items from a table using cache within single-thread cases only.
LIBMDBX_API int mdbx_cmp(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *a, const MDBX_val *b)
Compare two keys according to a particular table.
void mdbx_cache_init(MDBX_cache_entry_t *entry)
Initializes the cache entry before the first use.
Definition mdbx.h:5261
LIBMDBX_API int mdbx_del(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, const MDBX_val *data)
Delete items from a table.
LIBMDBX_API int mdbx_replace(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *new_data, MDBX_val *old_data, MDBX_put_flags_t flags)
Replaces item in a table.
LIBMDBX_API int mdbx_get_ex(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_val *key, MDBX_val *data, size_t *values_count)
Get items from a table and optionally number of data items for a given key.
LIBMDBX_API int mdbx_cursor_scan_from(MDBX_cursor *cursor, MDBX_predicate_func predicate, void *context, MDBX_cursor_op from_op, MDBX_val *from_key, MDBX_val *from_value, MDBX_cursor_op turn_op, void *arg)
LIBMDBX_API int mdbx_cursor_bunch_delete(MDBX_cursor *cursor, MDBX_bunch_action_t action, uint64_t *number_of_affected)
Quickly removes bunches of neighboring items.
LIBMDBX_API int mdbx_cursor_put(MDBX_cursor *cursor, const MDBX_val *key, MDBX_val *data, MDBX_put_flags_t flags)
Store by cursor.
LIBMDBX_API int mdbx_put(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data, MDBX_put_flags_t flags)
Store items into a table.
LIBMDBX_API int mdbx_drop(MDBX_txn *txn, MDBX_dbi dbi, bool del)
Empty or delete and close a table.
LIBMDBX_API int mdbx_dcmp(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *a, const MDBX_val *b)
Compare two data items according to a particular table.
LIBMDBX_API int mdbx_cursor_get(MDBX_cursor *cursor, MDBX_val *key, MDBX_val *data, MDBX_cursor_op op)
Retrieve by cursor.
LIBMDBX_API int mdbx_get(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data)
Get items from a table.
@ MDBX_DELETE_AFTER_INCLUDING
Definition mdbx.h:6313
@ MDBX_DELETE_BEFORE_INCLUDING
Definition mdbx.h:6312
@ MDBX_DELETE_WHOLE
Definition mdbx.h:6315
@ MDBX_DELETE_BEFORE_EXCLUDING
Definition mdbx.h:6311
@ MDBX_DELETE_CURRENT_VALUE
Definition mdbx.h:6305
@ MDBX_DELETE_CURRENT_MULTIVAL_BEFORE_EXCLUDING
Definition mdbx.h:6306
@ MDBX_DELETE_AFTER_EXCLUDING
Definition mdbx.h:6314
@ MDBX_DELETE_CURRENT_MULTIVAL_ALL
Definition mdbx.h:6310
@ MDBX_DELETE_CURRENT_MULTIVAL_BEFORE_INCLUDING
Definition mdbx.h:6307
@ MDBX_DELETE_CURRENT_MULTIVAL_AFTER_INCLUDING
Definition mdbx.h:6308
@ MDBX_DELETE_CURRENT_MULTIVAL_AFTER_EXCLUDING
Definition mdbx.h:6309
@ MDBX_MULTIPLE
Definition mdbx.h:1686
@ MDBX_ALLDUPS
Definition mdbx.h:1669
@ MDBX_CURRENT
Definition mdbx.h:1664
@ MDBX_APPENDDUP
Definition mdbx.h:1682
@ MDBX_NODUPDATA
Definition mdbx.h:1658
@ MDBX_APPEND
Definition mdbx.h:1677
@ MDBX_UPSERT
Definition mdbx.h:1651
@ MDBX_RESERVE
Definition mdbx.h:1673
@ MDBX_NOOVERWRITE
Definition mdbx.h:1654
@ MDBX_CACHE_DIRTY
The result of getting a value is correct, but it cannot be cached since the changes have not been com...
Definition mdbx.h:5314
@ MDBX_CACHE_UNABLE
The result of getting a value is correct, but it cannot be cached since there the ABA-like issue is i...
Definition mdbx.h:5296
@ MDBX_CACHE_HIT
The result of getting a value is correct and was retrieved from the cache entry which is untouched.
Definition mdbx.h:5322
@ MDBX_CACHE_CONFIRMED
The result of getting a value is correct and has been retrieved from the cache, which has been altere...
Definition mdbx.h:5330
@ MDBX_CACHE_ERROR
The error other than MDBX_NOTFOUND has occurred.
Definition mdbx.h:5277
@ MDBX_CACHE_RACE
The result was obtained by bypassing the cache, because the given cache entry being updated by anothe...
Definition mdbx.h:5305
@ MDBX_CACHE_BEHIND
The result was obtained by bypassing the cache, because the transaction is too old to using the cache...
Definition mdbx.h:5285
@ MDBX_CACHE_REFRESHED
The result of getting a value is correct and corresponds to the fresh data readed from the database,...
Definition mdbx.h:5340
LIBMDBX_API int mdbx_cursor_on_first_dup(const MDBX_cursor *cursor)
Determines whether the cursor is on the first or single multi-value corresponding to the key.
LIBMDBX_API int mdbx_cursor_open(MDBX_txn *txn, MDBX_dbi dbi, MDBX_cursor **cursor)
Create a cursor handle for the specified transaction and DBI handle.
int mdbx_txn_release_all_cursors(const MDBX_txn *txn, bool unbind)
Unbind or closes all cursors of a given transaction and of all its parent transactions if ones are.
Definition mdbx.h:5862
LIBMDBX_API int mdbx_cursor_unbind(MDBX_cursor *cursor)
Unbind cursor from a transaction.
LIBMDBX_API MDBX_cursor * mdbx_cursor_create(void *context)
Create a cursor handle but not bind it to transaction nor DBI-handle.
LIBMDBX_API MDBX_dbi mdbx_cursor_dbi(const MDBX_cursor *cursor)
Return the cursor's table handle.
MDBX_cursor_op
Cursor operationsThis is the set of all operations for retrieving data using a cursor.
Definition mdbx.h:1730
LIBMDBX_API int mdbx_cursor_compare(const MDBX_cursor *left, const MDBX_cursor *right, bool ignore_multival)
Compares the position of the cursors.
LIBMDBX_API int mdbx_cursor_on_last_dup(const MDBX_cursor *cursor)
Determines whether the cursor is on the last or single multi-value corresponding to the key.
LIBMDBX_API int mdbx_cursor_on_first(const MDBX_cursor *cursor)
Determines whether the cursor is pointed to the first key-value pair or not.
LIBMDBX_API int mdbx_cursor_bind(MDBX_txn *txn, MDBX_cursor *cursor, MDBX_dbi dbi)
Bind cursor to specified transaction and DBI-handle.
LIBMDBX_API int mdbx_cursor_reset(MDBX_cursor *cursor)
Resets the cursor state.
LIBMDBX_API int mdbx_txn_release_all_cursors_ex(const MDBX_txn *txn, bool unbind, size_t *count)
Unbind or closes all cursors of a given transaction and of all its parent transactions if ones are.
struct MDBX_cursor MDBX_cursor
Opaque structure for navigating through a table.
Definition mdbx.h:771
LIBMDBX_API int mdbx_cursor_set_userctx(MDBX_cursor *cursor, void *ctx)
Set application information associated with the cursor.
LIBMDBX_API int mdbx_cursor_eof(const MDBX_cursor *cursor)
Determines whether the cursor is pointed to a key-value pair or not, i.e. was not positioned or point...
LIBMDBX_API int mdbx_cursor_close2(MDBX_cursor *cursor)
Closes a cursor handle with returning error code.
LIBMDBX_API void * mdbx_cursor_get_userctx(const MDBX_cursor *cursor)
Get the application information associated with the MDBX_cursor.
LIBMDBX_API int mdbx_cursor_renew(MDBX_txn *txn, MDBX_cursor *cursor)
Renew a cursor handle for use within the given transaction.
LIBMDBX_API void mdbx_cursor_close(MDBX_cursor *cursor)
Closes a cursor handle without returning error code.
LIBMDBX_API MDBX_txn * mdbx_cursor_txn(const MDBX_cursor *cursor)
Return the cursor's transaction handle.
LIBMDBX_API int mdbx_cursor_on_last(const MDBX_cursor *cursor)
Determines whether the cursor is pointed to the last key-value pair or not.
LIBMDBX_API int mdbx_cursor_copy(const MDBX_cursor *src, MDBX_cursor *dest)
Copy cursor position and state.
@ MDBX_SET_LOWERBOUND
Definition mdbx.h:1807
@ MDBX_SEEK_AND_GET_MULTIPLE
Definition mdbx.h:1849
@ MDBX_GET_CURRENT
Definition mdbx.h:1745
@ MDBX_GET_BOTH
Definition mdbx.h:1738
@ MDBX_TO_KEY_EQUAL
Definition mdbx.h:1826
@ MDBX_GET_BOTH_RANGE
Definition mdbx.h:1742
@ MDBX_SET_KEY
Definition mdbx.h:1785
@ MDBX_FIRST_DUP
Definition mdbx.h:1735
@ MDBX_TO_KEY_LESSER_OR_EQUAL
Definition mdbx.h:1825
@ MDBX_GET_MULTIPLE
Definition mdbx.h:1750
@ MDBX_TO_EXACT_KEY_VALUE_GREATER_THAN
Definition mdbx.h:1836
@ MDBX_NEXT_NODUP
Definition mdbx.h:1770
@ MDBX_TO_EXACT_KEY_VALUE_LESSER_OR_EQUAL
Definition mdbx.h:1833
@ MDBX_TO_EXACT_KEY_VALUE_EQUAL
Definition mdbx.h:1834
@ MDBX_TO_PAIR_LESSER_OR_EQUAL
Definition mdbx.h:1841
@ MDBX_PREV_MULTIPLE
Definition mdbx.h:1793
@ MDBX_SET_RANGE
Definition mdbx.h:1788
@ MDBX_LAST_DUP
Definition mdbx.h:1756
@ MDBX_PREV
Definition mdbx.h:1773
@ MDBX_TO_PAIR_GREATER_OR_EQUAL
Definition mdbx.h:1843
@ MDBX_TO_PAIR_GREATER_THAN
Definition mdbx.h:1844
@ MDBX_LAST
Definition mdbx.h:1753
@ MDBX_TO_KEY_LESSER_THAN
Definition mdbx.h:1824
@ MDBX_PREV_DUP
Definition mdbx.h:1776
@ MDBX_TO_EXACT_KEY_VALUE_LESSER_THAN
Definition mdbx.h:1832
@ MDBX_SET
Definition mdbx.h:1782
@ MDBX_NEXT
Definition mdbx.h:1759
@ MDBX_TO_KEY_GREATER_OR_EQUAL
Definition mdbx.h:1827
@ MDBX_TO_PAIR_LESSER_THAN
Definition mdbx.h:1840
@ MDBX_NEXT_MULTIPLE
Definition mdbx.h:1767
@ MDBX_PREV_NODUP
Definition mdbx.h:1779
@ MDBX_TO_PAIR_EQUAL
Definition mdbx.h:1842
@ MDBX_NEXT_DUP
Definition mdbx.h:1762
@ MDBX_TO_EXACT_KEY_VALUE_GREATER_OR_EQUAL
Definition mdbx.h:1835
@ MDBX_SET_UPPERBOUND
Definition mdbx.h:1821
@ MDBX_TO_KEY_GREATER_THAN
Definition mdbx.h:1828
@ MDBX_FIRST
Definition mdbx.h:1732
LIBMDBX_API int mdbx_dbi_open_ex(MDBX_txn *txn, const char *name, MDBX_db_flags_t flags, MDBX_dbi *dbi, MDBX_cmp_func keycmp, MDBX_cmp_func datacmp)
Open or Create a named table in the environment with using custom comparison functions.
LIBMDBX_API int mdbx_dbi_rename(MDBX_txn *txn, MDBX_dbi dbi, const char *name)
Renames the table using the DBI descriptor.
LIBMDBX_API int mdbx_dbi_rename2(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *name)
Renames the table using the DBI descriptor.
LIBMDBX_API int mdbx_dbi_open_ex2(MDBX_txn *txn, const MDBX_val *name, MDBX_db_flags_t flags, MDBX_dbi *dbi, MDBX_cmp_func keycmp, MDBX_cmp_func datacmp)
Open or Create a named table in the environment with using custom comparison functions.
LIBMDBX_API int mdbx_dbi_close(MDBX_env *env, MDBX_dbi dbi)
Close a table handle. Normally unnecessary.
LIBMDBX_API int mdbx_dbi_open(MDBX_txn *txn, const char *name, MDBX_db_flags_t flags, MDBX_dbi *dbi)
Open or Create a named table in the environment.
LIBMDBX_API int mdbx_dbi_open2(MDBX_txn *txn, const MDBX_val *name, MDBX_db_flags_t flags, MDBX_dbi *dbi)
Open or Create a named table in the environment.
uint32_t MDBX_dbi
A handle for an individual table (key-value spaces) in the environment.
Definition mdbx.h:764
MDBX_db_flags_t
Table flags.
Definition mdbx.h:1599
@ MDBX_INTEGERDUP
Definition mdbx.h:1623
@ MDBX_DB_ACCEDE
Definition mdbx.h:1641
@ MDBX_DB_DEFAULTS
Definition mdbx.h:1601
@ MDBX_REVERSEKEY
Definition mdbx.h:1604
@ MDBX_DUPFIXED
Definition mdbx.h:1618
@ MDBX_INTEGERKEY
Definition mdbx.h:1614
@ MDBX_REVERSEDUP
Definition mdbx.h:1626
@ MDBX_CREATE
Definition mdbx.h:1629
@ MDBX_DUPSORT
Definition mdbx.h:1607
LIBMDBX_API const char * mdbx_dump_val(const MDBX_val *key, char *const buf, const size_t bufsize)
Dump given MDBX_val to the buffer.
LIBMDBX_API int mdbx_setup_debug(MDBX_log_level_t log_level, MDBX_debug_flags_t debug_flags, MDBX_debug_func logger)
Setup global log-level, debug options and debug logger.
MDBX_NORETURN LIBMDBX_API void mdbx_assert_fail(const char *msg, const char *func, unsigned line)
Auxiliary function for MDBX_INLINE_API_ASSERT().
void(* MDBX_panic_func)(const char *msg, const char *function, unsigned line, const void *obj, const char *obj_class) noexcept
A callback function for most assertion failures, called before printing the message and aborting.
Definition mdbx.h:1030
LIBMDBX_API int mdbx_setup_debug_nofmt(MDBX_log_level_t log_level, MDBX_debug_flags_t debug_flags, MDBX_debug_func_nofmt logger, char *logger_buffer, size_t logger_buffer_size)
void(* MDBX_debug_func_nofmt)(MDBX_log_level_t loglevel, const char *function, int line, const char *msg, unsigned length) noexcept
Definition mdbx.h:1010
MDBX_log_level_t
Definition mdbx.h:884
void(* MDBX_debug_func)(MDBX_log_level_t loglevel, const char *function, int line, const char *fmt, va_list args) noexcept
A debug-logger callback function, called before printing the message and aborting.
Definition mdbx.h:996
MDBX_debug_flags_t
Runtime debug flags.
Definition mdbx.h:943
LIBMDBX_API void mdbx_set_panic(MDBX_panic_func func)
Sets or reset the callback for panic() and assert() for the current process.
@ MDBX_LOG_EXTRA
Definition mdbx.h:926
@ MDBX_LOG_WARN
Definition mdbx.h:900
@ MDBX_LOG_TRACE
Definition mdbx.h:921
@ MDBX_LOG_DEBUG
Definition mdbx.h:916
@ MDBX_LOG_FATAL
Definition mdbx.h:888
@ MDBX_LOG_ERROR
Definition mdbx.h:894
@ MDBX_LOG_NOTICE
Definition mdbx.h:906
@ MDBX_LOG_DONTCHANGE
Definition mdbx.h:933
@ MDBX_LOG_VERBOSE
Definition mdbx.h:911
@ MDBX_DBG_ASSERT
Definition mdbx.h:948
@ MDBX_DBG_DONT_UPGRADE
Definition mdbx.h:971
@ MDBX_DBG_LEGACY_OVERLAP
Definition mdbx.h:967
@ MDBX_DBG_LEGACY_MULTIOPEN
Definition mdbx.h:964
@ MDBX_DBG_NONE
Definition mdbx.h:944
@ MDBX_DBG_DUMP
Definition mdbx.h:961
@ MDBX_DBG_DONTCHANGE
Definition mdbx.h:978
@ MDBX_DBG_AUDIT
Definition mdbx.h:953
@ MDBX_DBG_JITTER
Definition mdbx.h:957
LIBMDBX_API const char * mdbx_strerror(int errnum)
Return a string describing a given error code.
LIBMDBX_API const char * mdbx_strerror_ANSI2OEM(int errnum)
MDBX_error_t
Errors and return codes.
Definition mdbx.h:1857
LIBMDBX_API int mdbx_env_set_hsr(MDBX_env *env, MDBX_hsr_func hsr_callback)
Sets a Handle-Slow-Readers callback to resolve database full/overflow issue due to a reader(s) which ...
LIBMDBX_API const char * mdbx_strerror_r(int errnum, char *buf, size_t buflen)
Return a string describing a given error code.
int(* MDBX_hsr_func)(const MDBX_env *env, const MDBX_txn *txn, mdbx_pid_t pid, mdbx_tid_t tid, uint64_t laggard, unsigned gap, size_t space, int retry) noexcept
A Handle-Slow-Readers callback function to resolve database full/overflow issue due to a reader(s) wh...
Definition mdbx.h:6831
LIBMDBX_API const char * mdbx_strerror_r_ANSI2OEM(int errnum, char *buf, size_t buflen)
@ MDBX_PANIC
Definition mdbx.h:1884
@ MDBX_FIRST_LMDB_ERRCODE
Definition mdbx.h:1871
@ MDBX_EKEYMISMATCH
Definition mdbx.h:1970
@ MDBX_UNABLE_EXTEND_MAPSIZE
Definition mdbx.h:1918
@ MDBX_EACCESS
Definition mdbx.h:2029
@ MDBX_EIO
Definition mdbx.h:2037
@ MDBX_PAGE_NOTFOUND
Definition mdbx.h:1877
@ MDBX_TXN_FULL
Definition mdbx.h:1902
@ MDBX_DUPLICATED_CLK
Definition mdbx.h:1989
@ MDBX_VERSION_MISMATCH
Definition mdbx.h:1887
@ MDBX_WANNA_RECOVERY
Definition mdbx.h:1967
@ MDBX_TXN_OVERLAPPING
Definition mdbx.h:1981
@ MDBX_EREMOTE
Definition mdbx.h:2043
@ MDBX_TOO_LARGE
Definition mdbx.h:1974
@ MDBX_EBADSIGN
Definition mdbx.h:1963
@ MDBX_CURSOR_FULL
Definition mdbx.h:1906
@ MDBX_ENOFILE
Definition mdbx.h:2040
@ MDBX_BAD_TXN
Definition mdbx.h:1934
@ MDBX_ENODATA
Definition mdbx.h:2024
@ MDBX_LAST_LMDB_ERRCODE
Definition mdbx.h:1948
@ MDBX_CORRUPTED
Definition mdbx.h:1880
@ MDBX_EPERM
Definition mdbx.h:2038
@ MDBX_THREAD_MISMATCH
Definition mdbx.h:1978
@ MDBX_BACKLOG_DEPLETED
Definition mdbx.h:1986
@ MDBX_SUCCESS
Definition mdbx.h:1859
@ MDBX_NOTFOUND
Definition mdbx.h:1874
@ MDBX_LAGGARD_READER
Definition mdbx.h:2004
@ MDBX_RESULT_TRUE
Definition mdbx.h:1865
@ MDBX_INVALID
Definition mdbx.h:1890
@ MDBX_BAD_VALSIZE
Definition mdbx.h:1938
@ MDBX_BUSY
Definition mdbx.h:1952
@ MDBX_OUSTED
Definition mdbx.h:1997
@ MDBX_DBS_FULL
Definition mdbx.h:1896
@ MDBX_EINVAL
Definition mdbx.h:2028
@ MDBX_BAD_RSLOT
Definition mdbx.h:1929
@ MDBX_ENOMEM
Definition mdbx.h:2030
@ MDBX_FIRST_ADDED_ERRCODE
Definition mdbx.h:1955
@ MDBX_RESULT_FALSE
Definition mdbx.h:1862
@ MDBX_EINTR
Definition mdbx.h:2039
@ MDBX_READERS_FULL
Definition mdbx.h:1899
@ MDBX_LAST_ADDED_ERRCODE
Definition mdbx.h:2007
@ MDBX_BAD_DBI
Definition mdbx.h:1942
@ MDBX_KEYEXIST
Definition mdbx.h:1868
@ MDBX_DANGLING_DBI
Definition mdbx.h:1993
@ MDBX_EDEADLK
Definition mdbx.h:2047
@ MDBX_PAGE_FULL
Definition mdbx.h:1909
@ MDBX_MAP_FULL
Definition mdbx.h:1893
@ MDBX_PROBLEM
Definition mdbx.h:1945
@ MDBX_ENOSYS
Definition mdbx.h:2033
@ MDBX_EMULTIVAL
Definition mdbx.h:1958
@ MDBX_EROFS
Definition mdbx.h:2031
@ MDBX_MVCC_RETARDED
Definition mdbx.h:2000
@ MDBX_INCOMPATIBLE
Definition mdbx.h:1926
LIBMDBX_API int mdbx_reader_check(MDBX_env *env, int *dead)
Check for stale entries in the reader lock table.
LIBMDBX_API int mdbx_env_copy(MDBX_env *env, const char *dest, MDBX_copy_flags_t flags)
Copy an MDBX environment to the specified path, with options.
LIBMDBX_API int mdbx_txn_copy2pathname(MDBX_txn *txn, const char *dest, MDBX_copy_flags_t flags)
Copy an MDBX environment by given read transaction to the specified path, with options.
MDBX_copy_flags_t
Environment copy flags.
Definition mdbx.h:1693
LIBMDBX_API MDBX_cmp_func mdbx_get_datacmp(MDBX_db_flags_t flags)
Returns default internal data's comparator for given table flags.
LIBMDBX_API int mdbx_env_chk_encount_problem(MDBX_chk_context_t *ctx)
An auxiliary function to account issues detected by an application, including those coming to an appl...
int mdbx_env_sync(MDBX_env *env)
The shortcut to calling mdbx_env_sync_ex() with the force=true and nonblock=false arguments.
Definition mdbx.h:2996
int(* MDBX_defrag_notify_func)(void *ctx, const MDBX_defrag_result_t *progress) noexcept
A callback function to notify an application about the progress of defragmentation.
Definition mdbx.h:7414
LIBMDBX_API int mdbx_env_chk(MDBX_env *env, const MDBX_chk_callbacks_t *cb, MDBX_chk_context_t *ctx, const MDBX_chk_flags_t flags, MDBX_chk_severity_t verbosity, unsigned timeout_seconds_16dot16)
Checks the integrity of a database.
LIBMDBX_API const char * mdbx_ratio2digits(uint64_t numerator, uint64_t denominator, int precision, char *buffer, size_t buffer_size)
An auxiliary function for converting fractions to string of decimal digits without using floating-poi...
LIBMDBX_API int mdbx_is_readahead_reasonable(size_t volume, intptr_t redundancy)
Find out whether to use readahead or not, based on the given database size and the amount of availabl...
LIBMDBX_API int mdbx_thread_register(const MDBX_env *env)
Registers the current thread as a reader for the environment.
MDBX_chk_stage_t
The verification stages reported via callbacks during a database integrity check.
Definition mdbx.h:7003
LIBMDBX_API int mdbx_txn_unlock(MDBX_env *env)
Releases write-transaction lock. Provided for custom and/or complex locking scenarios.
int mdbx_env_sync_poll(MDBX_env *env)
The shortcut to calling mdbx_env_sync_ex() with the force=false and nonblock=true arguments.
Definition mdbx.h:3001
LIBMDBX_API const char * mdbx_ratio2percents(uint64_t value, uint64_t whole, char *buffer, size_t buffer_size)
An auxiliary function for converting fractions to percentage string without using floating-point oper...
struct MDBX_chk_user_table_cookie MDBX_chk_user_table_cookie_t
A custom type for binding additional data associated with a certain key-value table during a database...
Definition mdbx.h:7056
LIBMDBX_API int mdbx_env_defrag(MDBX_env *env, size_t defrag_atleast, size_t time_atleast_dot16, size_t defrag_enough, size_t time_limit_dot16, intptr_t acceptable_backlash, intptr_t preferred_batch, MDBX_defrag_notify_func progress_callback, void *ctx, MDBX_defrag_result_t *result)
Performs database defragmentation.
MDBX_chk_flags_t
Flags/options for checking the integrity of a database.
Definition mdbx.h:6961
LIBMDBX_API int mdbx_env_deleteW(const wchar_t *pathname, MDBX_env_delete_mode_t mode)
Delete the environment's files in a proper and multiprocess-safe way.
LIBMDBX_API MDBX_cmp_func mdbx_get_keycmp(MDBX_db_flags_t flags)
Returns default internal key's comparator for given table flags.
MDBX_chk_severity_t
Levels of logging/detailing of information supplied via callbacks during a database integrity check.
Definition mdbx.h:6984
LIBMDBX_API int mdbx_txn_lock(MDBX_env *env, bool dont_wait)
Acquires write-transaction lock. Provided for custom and/or complex locking scenarios.
LIBMDBX_API int mdbx_env_resurrect_after_fork(MDBX_env *env)
Restores an instance of the environment in a child process after forking the parent process using for...
MDBX_env_delete_mode_t
Deletion modes for mdbx_env_delete().
Definition mdbx.h:2564
LIBMDBX_API int mdbx_env_copy2fd(MDBX_env *env, mdbx_filehandle_t fd, MDBX_copy_flags_t flags)
Copy an environment to the specified file descriptor, with options.
MDBX_defrag_stopping_reasons_t
The returned reasons for stopping database defragmentation.
Definition mdbx.h:7320
LIBMDBX_API int mdbx_env_open_for_recovery(MDBX_env *env, const char *pathname, unsigned target_meta, bool writeable)
Open an environment instance using specific meta-page for checking and recovery.
LIBMDBX_API int mdbx_cursor_ignord(MDBX_cursor *cursor)
An auxiliary function for use in tools.
LIBMDBX_API int mdbx_env_copyW(MDBX_env *env, const wchar_t *dest, MDBX_copy_flags_t flags)
Copy an MDBX environment to the specified path, with options.
LIBMDBX_API int mdbx_thread_unregister(const MDBX_env *env)
Unregisters the current thread as a reader for the environment.
LIBMDBX_API int mdbx_env_sync_ex(MDBX_env *env, bool force, bool nonblock)
Flush the environment data buffers to disk.
LIBMDBX_API int mdbx_txn_copy2fd(MDBX_txn *txn, mdbx_filehandle_t fd, MDBX_copy_flags_t flags)
Copy an environment by given read transaction to the specified file descriptor, with options.
LIBMDBX_API int mdbx_env_delete(const char *pathname, MDBX_env_delete_mode_t mode)
Delete the environment's files in a proper and multiprocess-safe way.
LIBMDBX_API int mdbx_env_open_for_recoveryW(MDBX_env *env, const wchar_t *pathname, unsigned target_meta, bool writeable)
Open an environment instance using specific meta-page for checking and recovery.
LIBMDBX_API int mdbx_txn_copy2pathnameW(MDBX_txn *txn, const wchar_t *dest, MDBX_copy_flags_t flags)
Copy an MDBX environment by given read transaction to the specified path, with options.
@ MDBX_CP_DISPOSE_TXN
Definition mdbx.h:1712
@ MDBX_CP_DEFAULTS
Definition mdbx.h:1694
@ MDBX_CP_COMPACT
Definition mdbx.h:1698
@ MDBX_CP_RENEW_TXN
Definition mdbx.h:1717
@ MDBX_CP_THROTTLE_MVCC
Definition mdbx.h:1708
@ MDBX_CP_FORCE_DYNAMIC_SIZE
Definition mdbx.h:1701
@ MDBX_CP_DONT_FLUSH
Definition mdbx.h:1704
@ MDBX_CP_OVERWRITE
Definition mdbx.h:1721
@ MDBX_chk_gc
Definition mdbx.h:7009
@ MDBX_chk_init
Definition mdbx.h:7005
@ MDBX_chk_finalize
Definition mdbx.h:7015
@ MDBX_chk_space
Definition mdbx.h:7010
@ MDBX_chk_lock
Definition mdbx.h:7006
@ MDBX_chk_none
Definition mdbx.h:7004
@ MDBX_chk_maindb
Definition mdbx.h:7011
@ MDBX_chk_unlock
Definition mdbx.h:7014
@ MDBX_chk_meta
Definition mdbx.h:7007
@ MDBX_chk_conclude
Definition mdbx.h:7013
@ MDBX_chk_tree
Definition mdbx.h:7008
@ MDBX_chk_tables
Definition mdbx.h:7012
@ MDBX_CHK_SKIP_BTREE_TRAVERSAL
Definition mdbx.h:6969
@ MDBX_CHK_READWRITE
Definition mdbx.h:6966
@ MDBX_CHK_DEFAULTS
Definition mdbx.h:6963
@ MDBX_CHK_SKIP_KV_TRAVERSAL
Definition mdbx.h:6972
@ MDBX_CHK_IGNORE_ORDER
Definition mdbx.h:6977
@ MDBX_chk_processing
Definition mdbx.h:6993
@ MDBX_chk_result
Definition mdbx.h:6991
@ MDBX_chk_details
Definition mdbx.h:6996
@ MDBX_chk_extra
Definition mdbx.h:6997
@ MDBX_chk_severity_prio_shift
Definition mdbx.h:6985
@ MDBX_chk_severity_kind_mask
Definition mdbx.h:6986
@ MDBX_chk_notice
Definition mdbx.h:6990
@ MDBX_chk_resolution
Definition mdbx.h:6992
@ MDBX_chk_warning
Definition mdbx.h:6989
@ MDBX_chk_fatal
Definition mdbx.h:6987
@ MDBX_chk_info
Definition mdbx.h:6994
@ MDBX_chk_error
Definition mdbx.h:6988
@ MDBX_chk_verbose
Definition mdbx.h:6995
@ MDBX_ENV_WAIT_FOR_UNUSED
Wait until other processes closes the environment before deletion.
Definition mdbx.h:2576
@ MDBX_ENV_JUST_DELETE
Just delete the environment's files and directory if any.
Definition mdbx.h:2571
@ MDBX_ENV_ENSURE_UNUSED
Make sure that the environment is not being used by other processes, or return an error otherwise.
Definition mdbx.h:2574
@ MDBX_defrag_time_limit
Definition mdbx.h:7330
@ MDBX_defrag_enough_threshold
Definition mdbx.h:7329
@ MDBX_defrag_error
Definition mdbx.h:7332
@ MDBX_defrag_laggard_reader
Definition mdbx.h:7327
@ MDBX_defrag_aborted
Definition mdbx.h:7331
@ MDBX_defrag_noobstacles
Definition mdbx.h:7321
@ MDBX_defrag_discontinued
Definition mdbx.h:7326
@ MDBX_defrag_large_chunk
Definition mdbx.h:7323
@ MDBX_defrag_step_size
Definition mdbx.h:7322
LIBMDBX_API int mdbx_env_create(MDBX_env **penv)
Create an MDBX environment instance.
int mdbx_env_close(MDBX_env *env)
The shortcut to calling mdbx_env_close_ex() with the dont_sync=false argument.
Definition mdbx.h:3160
MDBX_env_flags_t
Environment flags.
Definition mdbx.h:1058
LIBMDBX_API int mdbx_env_close_ex(MDBX_env *env, bool dont_sync)
Close the environment and release the memory map.
LIBMDBX_API int mdbx_preopen_snapinfoW(const wchar_t *pathname, MDBX_envinfo *info, size_t bytes)
Gets basic information about the database without opening it.
LIBMDBX_API int mdbx_env_open(MDBX_env *env, const char *pathname, MDBX_env_flags_t flags, mdbx_mode_t mode)
Open an environment instance.
LIBMDBX_API int mdbx_preopen_snapinfo(const char *pathname, MDBX_envinfo *info, size_t bytes)
Gets basic information about the database without opening it.
@ MDBX_NORDAHEAD
Definition mdbx.h:1252
@ MDBX_ENV_DEFAULTS
Definition mdbx.h:1059
@ MDBX_COALESCE
Definition mdbx.h:1288
@ MDBX_NOMETASYNC
Definition mdbx.h:1387
@ MDBX_LIFORECLAIM
Definition mdbx.h:1312
@ MDBX_SAFE_NOSYNC
Definition mdbx.h:1438
@ MDBX_NOTLS
Definition mdbx.h:1231
@ MDBX_SYNC_DURABLE
Definition mdbx.h:1369
@ MDBX_PAGEPERTURB
Definition mdbx.h:1315
@ MDBX_WRITEMAP
Definition mdbx.h:1178
@ MDBX_NOSTICKYTHREADS
Definition mdbx.h:1228
@ MDBX_EXCLUSIVE
Definition mdbx.h:1132
@ MDBX_NOMEMINIT
Definition mdbx.h:1275
@ MDBX_MAPASYNC
Definition mdbx.h:1445
@ MDBX_ACCEDE
Definition mdbx.h:1147
@ MDBX_NOSUBDIR
Definition mdbx.h:1084
@ MDBX_RDONLY
Definition mdbx.h:1102
@ MDBX_UTTERLY_NOSYNC
Definition mdbx.h:1488
@ MDBX_VALIDATION
Definition mdbx.h:1066
LIBMDBX_API int mdbx_estimate_distance(const MDBX_cursor *first, const MDBX_cursor *last, ptrdiff_t *distance_items)
Estimates the distance between cursors as a number of elements.
LIBMDBX_API int mdbx_estimate_move(const MDBX_cursor *cursor, MDBX_val *key, MDBX_val *data, MDBX_cursor_op move_op, ptrdiff_t *distance_items)
Estimates the move distance.
LIBMDBX_API int mdbx_estimate_range(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *begin_key, const MDBX_val *begin_data, const MDBX_val *end_key, const MDBX_val *end_data, ptrdiff_t *distance_items)
Estimates the size of a range as a number of elements.
int mdbx_env_set_mapsize(MDBX_env *env, size_t size)
Definition mdbx.h:3582
int mdbx_env_set_maxdbs(MDBX_env *env, MDBX_dbi dbs)
Set the maximum number of named tables for the environment.
Definition mdbx.h:3731
LIBMDBX_API int mdbx_env_warmup(const MDBX_env *env, const MDBX_txn *txn, MDBX_warmup_flags_t flags, unsigned timeout_seconds_16dot16)
Warms up the database by loading pages into memory, optionally lock ones.
LIBMDBX_API int mdbx_env_get_option(const MDBX_env *env, const MDBX_option_t option, uint64_t *pvalue)
Gets the value of extra runtime options from an environment.
int mdbx_env_set_syncperiod(MDBX_env *env, unsigned seconds_16dot16)
Sets relative period since the last unsteady commit to force flush the data buffers to disk,...
Definition mdbx.h:3085
MDBX_option_t
MDBX environment extra runtime options.
Definition mdbx.h:2138
LIBMDBX_API int mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now, intptr_t size_upper, intptr_t growth_step, intptr_t shrink_threshold, intptr_t pagesize)
Set all size-related parameters of environment, including page size and the min/max size of the memor...
int mdbx_env_set_syncbytes(MDBX_env *env, size_t threshold)
Sets threshold to force flush the data buffers to disk, even any of MDBX_SAFE_NOSYNC flag in the envi...
Definition mdbx.h:3026
MDBX_warmup_flags_t
Warming up options.
Definition mdbx.h:3228
LIBMDBX_API int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64_t value)
Sets the value of a extra runtime options for an environment.
LIBMDBX_API int mdbx_env_set_userctx(MDBX_env *env, void *ctx)
Sets application information (a context pointer) associated with the environment.
int mdbx_env_set_maxreaders(MDBX_env *env, unsigned readers)
Set the maximum number of threads/reader slots for for all processes interacts with the database.
Definition mdbx.h:3685
LIBMDBX_API int mdbx_env_set_flags(MDBX_env *env, MDBX_env_flags_t flags, bool onoff)
Set environment flags.
@ MDBX_opt_txn_dp_initial
Controls the in-process initial allocation size for dirty pages list of a write transaction....
Definition mdbx.h:2243
@ MDBX_opt_subpage_room_threshold
Sets the minimum amount of free space on a leaf page in the absence of which the nested pages are pla...
Definition mdbx.h:2405
@ MDBX_opt_subpage_limit
Specifies the maximum size of nested pages used to accommodate a small number of multi-values associa...
Definition mdbx.h:2398
@ MDBX_opt_txn_dp_limit
Controls the in-process limit of dirty pages for a write transaction.
Definition mdbx.h:2239
@ MDBX_opt_prefer_waf_insteadof_balance
Controls the choice between striving for uniformity of page filling/density, either for reducing the ...
Definition mdbx.h:2384
@ MDBX_opt_prefault_write_enable
Controls prevention of page-faults of reclaimed and allocated pages in the MDBX_WRITEMAP mode by clea...
Definition mdbx.h:2343
@ MDBX_opt_max_db
Controls the maximum number of named tables for the environment.
Definition mdbx.h:2147
@ MDBX_opt_subpage_reserve_prereq
Sets the minimum amount of free space on the main page, if available, to reserve space in the subpage...
Definition mdbx.h:2419
@ MDBX_opt_sync_bytes
Controls interprocess/shared threshold to force flush the data buffers to disk, if MDBX_SAFE_NOSYNC i...
Definition mdbx.h:2170
@ MDBX_opt_spill_min_denominator
Controls the in-process how minimal part of the dirty pages should be spilled when necessary.
Definition mdbx.h:2275
@ MDBX_opt_spill_parent4child_denominator
Controls the in-process how much of the parent transaction dirty pages will be spilled while start ea...
Definition mdbx.h:2298
@ MDBX_opt_split_reserve
Sets the space reservation in 1/65536 of page size when splitting page along the edge.
Definition mdbx.h:2447
@ MDBX_opt_loose_limit
Controls the in-process limit to grow a cache of dirty pages for reuse in the current transaction.
Definition mdbx.h:2210
@ MDBX_opt_rp_augment_limit
Controls the in-process limit to grow a list of reclaimed/recycled page's numbers for finding a seque...
Definition mdbx.h:2197
@ MDBX_opt_max_readers
Defines the maximum number of threads/reader slots for all processes interacting with the database.
Definition mdbx.h:2164
@ MDBX_opt_subpage_reserve_limit
Sets the limit for reserving space on nested pages.
Definition mdbx.h:2425
@ MDBX_opt_spill_max_denominator
Controls the in-process how maximal part of the dirty pages may be spilled when necessary.
Definition mdbx.h:2259
@ MDBX_opt_sync_period
Controls interprocess/shared relative period since the last unsteady commit to force flush the data b...
Definition mdbx.h:2176
@ MDBX_opt_dp_reserve_limit
Controls the in-process limit of a pre-allocated memory items for dirty pages.
Definition mdbx.h:2224
@ MDBX_opt_writethrough_threshold
Controls the choosing between use write-through disk writes and usual ones with followed flush by the...
Definition mdbx.h:2338
@ MDBX_opt_gc_time_limit
Controls the in-process spending time limit of searching consecutive pages inside GC.
Definition mdbx.h:2362
@ MDBX_opt_merge_threshold
Controls the in-process threshold of semi-empty pages merge.
Definition mdbx.h:2310
@ MDBX_warmup_touchlimit
Definition mdbx.h:3267
@ MDBX_warmup_force
Definition mdbx.h:3237
@ MDBX_warmup_oomsafe
Definition mdbx.h:3244
@ MDBX_warmup_release
Definition mdbx.h:3270
@ MDBX_warmup_lock
Definition mdbx.h:3259
@ MDBX_warmup_default
Definition mdbx.h:3231
LIBMDBX_API int mdbx_env_get_path(const MDBX_env *env, const char **dest)
Return the path that was used in mdbx_env_open().
LIBMDBX_API int mdbx_dbi_stat(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_stat *stat, size_t bytes)
Retrieve statistics for a table.
LIBMDBX_API intptr_t mdbx_limits_keysize_min(MDBX_db_flags_t flags)
Returns minimal key size in bytes for given table flags.
LIBMDBX_API uint64_t mdbx_txn_id(const MDBX_txn *txn)
Return the transaction's ID.
LIBMDBX_API intptr_t mdbx_limits_valsize_max(intptr_t pagesize, MDBX_db_flags_t flags)
Returns maximal data size in bytes for given page size and table flags, or -1 if pagesize is invalid.
LIBMDBX_API int mdbx_env_info_ex(const MDBX_env *env, const MDBX_txn *txn, MDBX_envinfo *info, size_t bytes)
Return information about the MDBX environment.
int mdbx_env_get_maxreaders(const MDBX_env *env, unsigned *readers)
Get the maximum number of threads/reader slots for the environment.
Definition mdbx.h:3700
int mdbx_env_get_syncperiod(const MDBX_env *env, unsigned *period_seconds_16dot16)
Get relative period since the last unsteady commit to force flush the data buffers to disk,...
Definition mdbx.h:3105
LIBMDBX_API int mdbx_env_get_maxkeysize_ex(const MDBX_env *env, MDBX_db_flags_t flags)
Returns the maximum size of keys can put.
LIBMDBX_API int mdbx_txn_straggler(const MDBX_txn *txn, int *percent)
Returns a lag of the reading for the given transaction.
LIBMDBX_API int mdbx_env_get_maxvalsize_ex(const MDBX_env *env, MDBX_db_flags_t flags)
Returns the maximum size of data we can put.
LIBMDBX_API int mdbx_env_stat_ex(const MDBX_env *env, const MDBX_txn *txn, MDBX_stat *stat, size_t bytes)
Return statistics about the MDBX environment.
int mdbx_dbi_flags(const MDBX_txn *txn, MDBX_dbi dbi, unsigned *flags)
The shortcut to calling mdbx_dbi_flags_ex() with state=NULL for discarding it result.
Definition mdbx.h:5090
LIBMDBX_API int mdbx_gc_info(MDBX_txn *txn, MDBX_gc_info_t *info, size_t bytes, MDBX_gc_iter_func iter_func, void *iter_ctx)
Provides information of Garbage Collection and page usage.
LIBMDBX_API int mdbx_env_get_pairsize4page_max(const MDBX_env *env, MDBX_db_flags_t flags)
Returns maximal size of key-value pair to fit in a single page for specified table flags.
LIBMDBX_API intptr_t mdbx_limits_valsize_min(MDBX_db_flags_t flags)
Returns minimal data size in bytes for given table flags.
int mdbx_env_info(const MDBX_env *env, MDBX_envinfo *info, size_t bytes)
Return information about the MDBX environment.
Definition mdbx.h:2951
int(* MDBX_gc_iter_func)(void *ctx, const MDBX_txn *txn, uint64_t span_txnid, size_t span_pgno, size_t span_length, bool span_is_reclaimable) noexcept
A callback function for iterating GC entries.
Definition mdbx.h:7259
int mdbx_env_get_syncbytes(const MDBX_env *env, size_t *threshold)
Get threshold to force flush the data buffers to disk, even any of MDBX_SAFE_NOSYNC flag in the envir...
Definition mdbx.h:3044
LIBMDBX_API intptr_t mdbx_limits_valsize4page_max(intptr_t pagesize, MDBX_db_flags_t flags)
Returns maximal data size in bytes to fit in a leaf-page or single large/overflow-page with the given...
LIBMDBX_API intptr_t mdbx_limits_txnsize_max(intptr_t pagesize)
Returns maximal write transaction size (i.e. limit for summary volume of dirty pages) in bytes for gi...
intptr_t mdbx_limits_pgsize_max(void)
Returns the maximal database page size in bytes.
Definition mdbx.h:3609
LIBMDBX_API int mdbx_dbi_dupsort_depthmask(const MDBX_txn *txn, MDBX_dbi dbi, uint32_t *mask)
Retrieve depth (bitmask) information of nested dupsort (multi-value) B+trees for given table.
LIBMDBX_API int mdbx_txn_info(const MDBX_txn *txn, MDBX_txn_info *info, bool scan_rlt)
Return information about the MDBX transaction.
LIBMDBX_API int mdbx_is_dirty(const MDBX_txn *txn, const void *ptr)
Determines whether the given address is on a dirty database page of the transaction or not.
MDBX_dbi_state_t
DBI state bits returted by mdbx_dbi_flags_ex()
Definition mdbx.h:5062
LIBMDBX_API int mdbx_env_get_valsize4page_max(const MDBX_env *env, MDBX_db_flags_t flags)
Returns maximal data size in bytes to fit in a leaf-page or single large/overflow-page for specified ...
intptr_t mdbx_limits_pgsize_min(void)
Returns the minimal database page size in bytes.
Definition mdbx.h:3605
LIBMDBX_API int mdbx_env_get_maxkeysize(const MDBX_env *env)
LIBMDBX_API int mdbx_env_get_fd(const MDBX_env *env, mdbx_filehandle_t *fd)
Return the file descriptor for the given environment.
LIBMDBX_API int mdbx_enumerate_tables(const MDBX_txn *txn, MDBX_table_enum_func func, void *ctx)
Enumerates user's named tables in a database.
LIBMDBX_API void * mdbx_env_get_userctx(const MDBX_env *env)
Returns an application information (a context pointer) associated with the environment.
int mdbx_env_get_maxdbs(const MDBX_env *env, MDBX_dbi *dbs)
Get the maximum number of named tables for the environment.
Definition mdbx.h:3745
LIBMDBX_API int mdbx_env_get_pathW(const MDBX_env *env, const wchar_t **dest)
Return the path that was used in mdbx_env_open().
LIBMDBX_API intptr_t mdbx_limits_keysize_max(intptr_t pagesize, MDBX_db_flags_t flags)
Returns maximal key size in bytes for given page size and table flags, or -1 if pagesize is invalid.
LIBMDBX_API size_t mdbx_default_pagesize(void)
Returns the default size of database page for the current system.
int(* MDBX_table_enum_func)(void *ctx, const MDBX_txn *txn, const MDBX_val *name, MDBX_db_flags_t flags, const struct MDBX_stat *stat, MDBX_dbi dbi) noexcept
A callback function for listing user's named tables.
Definition mdbx.h:4958
LIBMDBX_API int mdbx_get_sysraminfo(intptr_t *page_size, intptr_t *total_pages, intptr_t *avail_pages)
Returns basic information about system RAM. This function provides a portable way to get information ...
int mdbx_env_stat(const MDBX_env *env, MDBX_stat *stat, size_t bytes)
Return statistics about the MDBX environment.
Definition mdbx.h:2833
LIBMDBX_API intptr_t mdbx_limits_pairsize4page_max(intptr_t pagesize, MDBX_db_flags_t flags)
Returns maximal size of key-value pair to fit in a single page with the given size and table flags,...
LIBMDBX_API intptr_t mdbx_limits_dbsize_max(intptr_t pagesize)
Returns maximal database size in bytes for given page size, or -1 if pagesize is invalid.
LIBMDBX_API intptr_t mdbx_limits_dbsize_min(intptr_t pagesize)
Returns minimal database size in bytes for given page size, or -1 if pagesize is invalid.
LIBMDBX_API int mdbx_env_get_flags(const MDBX_env *env, unsigned *flags)
Get environment flags.
LIBMDBX_API int mdbx_dbi_flags_ex(const MDBX_txn *txn, MDBX_dbi dbi, unsigned *flags, unsigned *state)
Retrieve the DB flags and status for a table handle.
LIBMDBX_API int mdbx_reader_list(const MDBX_env *env, MDBX_reader_list_func func, void *ctx)
Enumerate the entries in the reader lock table.
int(* MDBX_reader_list_func)(void *ctx, int num, int slot, mdbx_pid_t pid, mdbx_tid_t thread, uint64_t txnid, uint64_t lag, size_t bytes_used, size_t bytes_retained) noexcept
A callback function used to enumerate the reader lock table.
Definition mdbx.h:6683
@ MDBX_DBI_DIRTY
Definition mdbx.h:5064
@ MDBX_DBI_FRESH
Definition mdbx.h:5068
@ MDBX_DBI_STALE
Definition mdbx.h:5066
@ MDBX_DBI_CREAT
Definition mdbx.h:5070
LIBMDBX_API int mdbx_txn_break(MDBX_txn *txn)
Marks transaction as broken to prevent further operations.
LIBMDBX_API int mdbx_txn_set_userctx(MDBX_txn *txn, void *ctx)
Sets application information associated (a context pointer) with the transaction.
LIBMDBX_API int mdbx_txn_clone(const MDBX_txn *origin, MDBX_txn **in_out_clone, void *context)
Starts a read-only clone of a given transaction.
LIBMDBX_API int mdbx_txn_park(MDBX_txn *txn, bool autounpark)
Puts the reading transaction in a "parked" state.
LIBMDBX_API int mdbx_txn_begin_ex(MDBX_env *env, MDBX_txn *parent, MDBX_txn_flags_t flags, MDBX_txn **txn, void *context)
Create a transaction with a user provided context pointer for use with the environment.
LIBMDBX_API int mdbx_txn_refresh(MDBX_txn *txn)
Refresh a read-only transaction for a recent data.
int mdbx_txn_commit(MDBX_txn *txn)
Commits all the operations of the transaction into the database.
Definition mdbx.h:4505
LIBMDBX_API int mdbx_txn_commit_ex(MDBX_txn *txn, MDBX_commit_latency *latency)
Commits all changes of the transaction into a database with collecting latencies information.
LIBMDBX_API int mdbx_txn_rollback(MDBX_txn *txn)
Rolls back all uncommitted changes within the write transaction and keeps it running.
LIBMDBX_API int mdbx_txn_abort_ex(MDBX_txn *txn, MDBX_commit_latency *latency)
Abandons all the operations of the transaction instead of saving ones with collecting latencies infor...
LIBMDBX_API MDBX_env * mdbx_txn_env(const MDBX_txn *txn)
Returns the transaction's MDBX_env.
LIBMDBX_API int mdbx_txn_checkpoint(MDBX_txn *txn, MDBX_txn_flags_t weakening_durability, MDBX_commit_latency *latency)
Commits all the operations of the transaction and immediately starts next without releasing any locks...
LIBMDBX_API int mdbx_txn_unpark(MDBX_txn *txn, bool restart_if_ousted)
Unparks a previously parked reading transaction.
MDBX_txn_flags_t
Definition mdbx.h:1498
LIBMDBX_API void * mdbx_txn_get_userctx(const MDBX_txn *txn)
Returns an application information (a context pointer) associated with the transaction.
int mdbx_txn_abort(MDBX_txn *txn)
Abandons all the operations of the transaction instead of saving ones.
Definition mdbx.h:4562
int mdbx_txn_begin(MDBX_env *env, MDBX_txn *parent, MDBX_txn_flags_t flags, MDBX_txn **txn)
Create a transaction for use with the environment.
Definition mdbx.h:3961
LIBMDBX_API int mdbx_txn_amend(MDBX_txn *read_txn, MDBX_txn **ptr_write_txn, MDBX_txn_flags_t flags, void *context)
Starts a writing transaction to amending data in the MVCC-snapshot used by the read-only transaction.
struct MDBX_txn MDBX_txn
Opaque structure for a transaction handle.
Definition mdbx.h:752
LIBMDBX_API int mdbx_txn_commit_embark_read(MDBX_txn **ptxn, MDBX_commit_latency *latency)
Commits all the operations of the transaction and immediately starts read transaction before release ...
LIBMDBX_API int mdbx_txn_reset(MDBX_txn *txn)
Reset a read-only transaction.
LIBMDBX_API int mdbx_txn_renew(MDBX_txn *txn)
Renew a read-only transaction.
LIBMDBX_API MDBX_txn_flags_t mdbx_txn_flags(const MDBX_txn *txn)
Return the transaction's flags.
@ MDBX_TXN_RDONLY
Definition mdbx.h:1509
@ MDBX_TXN_ERROR
Definition mdbx.h:1552
@ MDBX_TXN_NOMETASYNC
Definition mdbx.h:1531
@ MDBX_TXN_SPILLS
Definition mdbx.h:1562
@ MDBX_TXN_OUSTED
Definition mdbx.h:1586
@ MDBX_TXN_NOWEAKING
Definition mdbx.h:1527
@ MDBX_TXN_HAS_CHILD
Definition mdbx.h:1567
@ MDBX_TXN_RDONLY_PREPARE
Definition mdbx.h:1518
@ MDBX_TXN_INVALID
Definition mdbx.h:1542
@ MDBX_TXN_BLOCKED
Definition mdbx.h:1591
@ MDBX_TXN_PARKED
Definition mdbx.h:1572
@ MDBX_TXN_NOSYNC
Definition mdbx.h:1535
@ MDBX_TXN_DIRTY
Definition mdbx.h:1557
@ MDBX_TXN_READWRITE
Definition mdbx.h:1503
@ MDBX_TXN_AUTOUNPARK
Definition mdbx.h:1579
@ MDBX_TXN_TRY
Definition mdbx.h:1524
@ MDBX_TXN_FINISHED
Definition mdbx.h:1547
MDBX_chk_severity_t verbosity
Definition mdbx.h:7044
MDBX_txn * txn
Definition mdbx.h:7121
void(* issue)(MDBX_chk_context_t *ctx, const char *object, uint64_t entry_number, const char *issue, const char *extra_fmt, va_list extra_args)
Definition mdbx.h:7161
struct MDBX_chk_histogram tree_density
struct MDBX_chk_histogram::@167152105014034103340112155364354016331236072167 ranges[9]
void(* print_size)(MDBX_chk_line_t *, const char *prefix, const uint64_t value, const char *suffix)
Definition mdbx.h:7178
void(* print_done)(MDBX_chk_line_t *)
Definition mdbx.h:7175
struct MDBX_chk_internal * internal
Definition mdbx.h:7119
uint8_t scope_nesting
Definition mdbx.h:7123
char * end
Definition mdbx.h:7024
uint8_t scope_depth
Definition mdbx.h:7023
struct MDBX_chk_histogram key_len
struct MDBX_chk_histogram large_or_nested_density
int(* stage_begin)(MDBX_chk_context_t *ctx, MDBX_chk_stage_t)
Definition mdbx.h:7170
int(* stage_end)(MDBX_chk_context_t *ctx, MDBX_chk_stage_t, int err)
Definition mdbx.h:7171
int(* table_conclude)(MDBX_chk_context_t *ctx, const MDBX_chk_table_t *table, MDBX_cursor *cursor, int err)
Definition mdbx.h:7164
void(* print_format)(MDBX_chk_line_t *, const char *fmt, va_list args)
Definition mdbx.h:7177
struct MDBX_chk_histogram histogram_pgno_payload
struct MDBX_chk_internal * internal
Definition mdbx.h:7041
char * begin
Definition mdbx.h:7024
size_t le1_count
Definition mdbx.h:7062
int(* scope_push)(MDBX_chk_context_t *ctx, MDBX_chk_scope_t *outer, MDBX_chk_scope_t *inner, const char *fmt, va_list args)
Definition mdbx.h:7157
struct MDBX_chk_histogram histogram_pgno_retained
size_t subtotal_issues
Definition mdbx.h:7045
uint8_t severity
Definition mdbx.h:7023
MDBX_chk_user_table_cookie_t * cookie
Definition mdbx.h:7072
void(* scope_pop)(MDBX_chk_context_t *ctx, MDBX_chk_scope_t *outer, MDBX_chk_scope_t *inner)
Definition mdbx.h:7160
struct MDBX_chk_histogram pgno
struct MDBX_chk_context * ctx
Definition mdbx.h:7022
MDBX_db_flags_t flags
Definition mdbx.h:7082
int(* scope_conclude)(MDBX_chk_context_t *ctx, MDBX_chk_scope_t *outer, MDBX_chk_scope_t *inner, int err)
Definition mdbx.h:7159
size_t le1_amount
Definition mdbx.h:7062
void(* print_flush)(MDBX_chk_line_t *)
Definition mdbx.h:7174
struct MDBX_chk_issue * next
Definition mdbx.h:7031
struct MDBX_chk_histogram large_pages
char * out
Definition mdbx.h:7024
struct MDBX_chk_histogram val_len
void(* print_chars)(MDBX_chk_line_t *, const char *str, size_t len)
Definition mdbx.h:7176
const MDBX_chk_table_t *const * tables
const void * object
Definition mdbx.h:7042
size_t count
Definition mdbx.h:7062
const char * caption
Definition mdbx.h:7033
MDBX_chk_stage_t stage
Definition mdbx.h:7043
struct MDBX_chk_histogram histogram_page_age
struct MDBX_chk_histogram height
struct MDBX_chk_histogram multival
struct MDBX_chk_histogram nested_height_or_gc_span_length
MDBX_env * env
Definition mdbx.h:7120
uint8_t empty
Definition mdbx.h:7023
size_t amount
Definition mdbx.h:7062
MDBX_chk_scope_t * scope
Definition mdbx.h:7122
MDBX_chk_issue_t * issues
Definition mdbx.h:7040
size_t payload_bytes
Definition mdbx.h:7085
size_t count
Definition mdbx.h:7032
MDBX_val name
Definition mdbx.h:7081
size_t lost_bytes
Definition mdbx.h:7085
bool(* check_break)(MDBX_chk_context_t *ctx)
Definition mdbx.h:7156
void(* table_dispose)(MDBX_chk_context_t *ctx, const MDBX_chk_table_t *table)
Definition mdbx.h:7165
int(* table_handle_kv)(MDBX_chk_context_t *ctx, const MDBX_chk_table_t *table, size_t entry_number, const MDBX_val *key, const MDBX_val *value)
Definition mdbx.h:7167
int id
Definition mdbx.h:7083
struct MDBX_chk_histogram page_age
LIBMDBX_API int mdbx_env_turn_for_recovery(MDBX_env *env, unsigned target_meta)
Turn database to the specified meta-page.
A set of callback functions used for checking the integrity of a database.
Definition mdbx.h:7155
The context for checking the integrity of a database.
Definition mdbx.h:7118
A histogram with some statistical information collected during a database integrity check.
Definition mdbx.h:7061
An issue problem was discovered during a database integrity check.
Definition mdbx.h:7030
A virtual row of the report generated during a database integrity check.
Definition mdbx.h:7021
A hierarchical context during a database integrity check.
Definition mdbx.h:7039
Information about a certain key-value table during a database integrity check.
Definition mdbx.h:7071
LIBMDBX_API float mdbx_float_from_key(const MDBX_val)
LIBMDBX_API int32_t mdbx_int32_from_key(const MDBX_val)
LIBMDBX_API int64_t mdbx_int64_from_key(const MDBX_val)
LIBMDBX_API double mdbx_double_from_key(const MDBX_val)
LIBMDBX_API int64_t mdbx_jsonInteger_from_key(const MDBX_val)
uint64_t mdbx_key_from_int64(const int64_t i64)
Definition mdbx.h:5001
LIBMDBX_API uint32_t mdbx_key_from_ptrfloat(const float *const ieee754_32bit)
LIBMDBX_API uint64_t mdbx_key_from_double(const double ieee754_64bit)
LIBMDBX_API uint32_t mdbx_key_from_float(const float ieee754_32bit)
LIBMDBX_API uint64_t mdbx_key_from_ptrdouble(const double *const ieee754_64bit)
uint32_t mdbx_key_from_int32(const int32_t i32)
Definition mdbx.h:5005
LIBMDBX_API uint64_t mdbx_key_from_jsonInteger(const int64_t json_integer)