2020-07-25 04:30:44 +03:00
|
|
|
|
/**
|
2020-07-11 22:27:29 +03:00
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
_libmdbx_ (aka MDBX) is an extremely fast, compact, powerful, embeddable,
|
2020-07-21 01:24:29 +03:00
|
|
|
|
transactional [key-value
|
2024-05-19 22:07:58 +03:00
|
|
|
|
store](https://en.wikipedia.org/wiki/Key-value_database), with [Apache 2.0
|
|
|
|
|
license](./LICENSE). _MDBX_ has a specific set of properties and capabilities,
|
|
|
|
|
focused on creating unique lightweight solutions with extraordinary performance.
|
2020-07-11 22:27:29 +03:00
|
|
|
|
|
|
|
|
|
_libmdbx_ is superior to [LMDB](https://bit.ly/26ts7tL) in terms of features
|
|
|
|
|
and reliability, not inferior in performance. In comparison to LMDB, _libmdbx_
|
|
|
|
|
makes many things just work perfectly, not silently and catastrophically
|
|
|
|
|
break down. _libmdbx_ supports Linux, Windows, MacOS, OSX, iOS, Android,
|
|
|
|
|
FreeBSD, DragonFly, Solaris, OpenSolaris, OpenIndiana, NetBSD, OpenBSD and other
|
|
|
|
|
systems compliant with POSIX.1-2008.
|
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
Please visit https://libmdbx.dqdkfa.ru for more information, documentation,
|
|
|
|
|
C++ API description and links to the origin git repo with the source code.
|
|
|
|
|
Questions, feedback and suggestions are welcome to the Telegram' group
|
|
|
|
|
https://t.me/libmdbx.
|
2022-04-21 14:50:30 +03:00
|
|
|
|
|
2024-12-06 18:18:36 +03:00
|
|
|
|
Donations are welcome to ETH `0xD104d8f8B2dC312aaD74899F83EBf3EEBDC1EA3A`.
|
|
|
|
|
Всё будет хорошо!
|
2020-07-21 01:24:29 +03:00
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
\note The origin has been migrated to
|
|
|
|
|
[GitFlic](https://gitflic.ru/project/erthink/libmdbx) since on 2022-04-15 the
|
|
|
|
|
Github administration, without any warning nor explanation, deleted libmdbx
|
|
|
|
|
along with a lot of other projects, simultaneously blocking access for many
|
|
|
|
|
developers. For the same reason ~~Github~~ is blacklisted forever.
|
2020-07-21 01:24:29 +03:00
|
|
|
|
|
|
|
|
|
\section copyright LICENSE & COPYRIGHT
|
2024-05-19 22:07:58 +03:00
|
|
|
|
\copyright SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
\note Please refer to the COPYRIGHT file for explanations license change,
|
|
|
|
|
credits and acknowledgments.
|
|
|
|
|
\author Леонид Юрьев aka Leonid Yuriev <leo@yuriev.ru> \date 2015-2024
|
2020-07-11 22:27:29 +03:00
|
|
|
|
|
|
|
|
|
*******************************************************************************/
|
2017-09-17 15:07:32 +03:00
|
|
|
|
|
2017-02-21 20:16:54 +03:00
|
|
|
|
#pragma once
|
2017-05-24 01:07:15 +03:00
|
|
|
|
#ifndef LIBMDBX_H
|
|
|
|
|
#define LIBMDBX_H
|
2017-03-16 18:09:27 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#if defined(__riscv) || defined(__riscv__) || defined(__RISCV) || defined(__RISCV__)
|
2022-11-29 01:16:36 +03:00
|
|
|
|
#warning "The RISC-V architecture is intentionally insecure by design. \
|
2022-11-09 12:39:06 +03:00
|
|
|
|
Please delete this admonition at your own risk, \
|
|
|
|
|
if you make such decision informed and consciously. \
|
2022-11-29 01:16:36 +03:00
|
|
|
|
Refer to https://clck.ru/32d9xH for more information."
|
2022-11-09 12:39:06 +03:00
|
|
|
|
#endif /* RISC-V */
|
|
|
|
|
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
|
#pragma warning(push, 1)
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#pragma warning(disable : 4548) /* expression before comma has no effect; \
|
2017-07-03 12:50:48 +03:00
|
|
|
|
expected expression with side - effect */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#pragma warning(disable : 4530) /* C++ exception handler used, but unwind \
|
2017-05-24 13:59:50 +03:00
|
|
|
|
* semantics are not enabled. Specify /EHsc */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#pragma warning(disable : 4577) /* 'noexcept' used with no exception handling \
|
|
|
|
|
* mode specified; termination on exception is \
|
2017-05-24 13:59:50 +03:00
|
|
|
|
* not guaranteed. Specify /EHsc */
|
|
|
|
|
#endif /* _MSC_VER (warnings) */
|
|
|
|
|
|
2020-08-25 18:27:07 +03:00
|
|
|
|
/* *INDENT-OFF* */
|
|
|
|
|
/* clang-format off */
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/**
|
|
|
|
|
\file mdbx.h
|
2024-05-19 22:07:58 +03:00
|
|
|
|
\brief The libmdbx C API header file.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
|
|
|
|
|
\defgroup c_api C API
|
|
|
|
|
@{
|
2020-07-28 15:05:35 +03:00
|
|
|
|
\defgroup c_err Error handling
|
2020-08-07 11:33:51 +03:00
|
|
|
|
\defgroup c_opening Opening & Closing
|
2020-07-25 04:30:44 +03:00
|
|
|
|
\defgroup c_transactions Transactions
|
2024-08-03 13:25:44 +03:00
|
|
|
|
\defgroup c_dbi Tables
|
2020-09-26 18:28:09 +03:00
|
|
|
|
\defgroup c_crud Create/Read/Update/Delete (see Quick Reference in details)
|
2020-08-25 18:27:07 +03:00
|
|
|
|
|
|
|
|
|
\details
|
|
|
|
|
\anchor c_crud_hints
|
2020-09-26 18:28:09 +03:00
|
|
|
|
# Quick Reference for Insert/Update/Delete operations
|
2020-08-25 18:27:07 +03:00
|
|
|
|
|
|
|
|
|
Historically, libmdbx inherits the API basis from LMDB, where it is often
|
|
|
|
|
difficult to select flags/options and functions for the desired operation.
|
|
|
|
|
So it is recommend using this hints.
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
## Tables with UNIQUE keys
|
2020-08-25 18:27:07 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
In tables created without the \ref MDBX_DUPSORT option, keys are always
|
2020-08-25 18:27:07 +03:00
|
|
|
|
unique. Thus always a single value corresponds to the each key, and so there
|
|
|
|
|
are only a few cases of changing data.
|
|
|
|
|
|
|
|
|
|
| Case | Flags to use | Result |
|
|
|
|
|
|---------------------------------------------|---------------------|------------------------|
|
|
|
|
|
| _INSERTING_|||
|
|
|
|
|
|Key is absent → Insertion |\ref MDBX_NOOVERWRITE|Insertion |
|
|
|
|
|
|Key exist → Error since key present |\ref MDBX_NOOVERWRITE|Error \ref MDBX_KEYEXIST and return Present value|
|
|
|
|
|
| _UPSERTING_|||
|
|
|
|
|
|Key is absent → Insertion |\ref MDBX_UPSERT |Insertion |
|
|
|
|
|
|Key exist → Update |\ref MDBX_UPSERT |Update |
|
|
|
|
|
| _UPDATING_|||
|
|
|
|
|
|Key is absent → Error since no such key |\ref MDBX_CURRENT |Error \ref MDBX_NOTFOUND|
|
|
|
|
|
|Key exist → Update |\ref MDBX_CURRENT |Update value |
|
|
|
|
|
| _DELETING_|||
|
|
|
|
|
|Key is absent → Error since no such key |\ref mdbx_del() or \ref mdbx_replace()|Error \ref MDBX_NOTFOUND|
|
|
|
|
|
|Key exist → Delete by key |\ref mdbx_del() with the parameter `data = NULL`|Deletion|
|
2024-12-06 22:15:23 +03:00
|
|
|
|
|Key exist → Delete by key with data matching check|\ref mdbx_del() with the parameter `data` filled with the value which should be match for deletion|Deletion or \ref MDBX_NOTFOUND if the value does not match|
|
2020-08-25 18:27:07 +03:00
|
|
|
|
|Delete at the current cursor position |\ref mdbx_cursor_del() with \ref MDBX_CURRENT flag|Deletion|
|
|
|
|
|
|Extract (read & delete) value by the key |\ref mdbx_replace() with zero flag and parameter `new_data = NULL`|Returning a deleted value|
|
|
|
|
|
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
## Tables with NON-UNIQUE keys
|
2020-08-25 18:27:07 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
In tables created with the \ref MDBX_DUPSORT (Sorted Duplicates) option, keys
|
|
|
|
|
may be non unique. Such non-unique keys in a key-value table may be treated
|
2020-08-25 18:27:07 +03:00
|
|
|
|
as a duplicates or as like a multiple values corresponds to keys.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| Case | Flags to use | Result |
|
|
|
|
|
|---------------------------------------------|---------------------|------------------------|
|
|
|
|
|
| _INSERTING_|||
|
|
|
|
|
|Key is absent → Insertion |\ref MDBX_NOOVERWRITE|Insertion|
|
|
|
|
|
|Key exist → Needn't to add new values |\ref MDBX_NOOVERWRITE|Error \ref MDBX_KEYEXIST with returning the first value from those already present|
|
|
|
|
|
| _UPSERTING_|||
|
|
|
|
|
|Key is absent → Insertion |\ref MDBX_UPSERT |Insertion|
|
|
|
|
|
|Key exist → Wanna to add new values |\ref MDBX_UPSERT |Add one more value to the key|
|
|
|
|
|
|Key exist → Replace all values with a new one|\ref MDBX_UPSERT + \ref MDBX_ALLDUPS|Overwrite by single new value|
|
|
|
|
|
| _UPDATING_|||
|
|
|
|
|
|Key is absent → Error since no such key |\ref MDBX_CURRENT |Error \ref MDBX_NOTFOUND|
|
|
|
|
|
|Key exist, Single value → Update |\ref MDBX_CURRENT |Update single value |
|
|
|
|
|
|Key exist, Multiple values → Replace all values with a new one|\ref MDBX_CURRENT + \ref MDBX_ALLDUPS|Overwrite by single new value|
|
|
|
|
|
|Key exist, Multiple values → Error since it is unclear which of the values should be updated|\ref mdbx_put() with \ref MDBX_CURRENT|Error \ref MDBX_EMULTIVAL|
|
|
|
|
|
|Key exist, Multiple values → Update particular entry of multi-value|\ref mdbx_replace() with \ref MDBX_CURRENT + \ref MDBX_NOOVERWRITE and the parameter `old_value` filled with the value that wanna to update|Update one multi-value entry|
|
|
|
|
|
|Key exist, Multiple values → Update the current entry of multi-value|\ref mdbx_cursor_put() with \ref MDBX_CURRENT|Update one multi-value entry|
|
|
|
|
|
| _DELETING_|||
|
|
|
|
|
|Key is absent → Error since no such key |\ref mdbx_del() or \ref mdbx_replace()|Error \ref MDBX_NOTFOUND|
|
|
|
|
|
|Key exist → Delete all values corresponds given key|\ref mdbx_del() with the parameter `data = NULL`|Deletion|
|
2020-09-26 18:28:09 +03:00
|
|
|
|
|Key exist → Delete particular value corresponds given key|\ref mdbx_del() with the parameter `data` filled with the value that wanna to delete, or \ref mdbx_replace() with \ref MDBX_CURRENT + \ref MDBX_NOOVERWRITE and the `old_value` parameter filled with the value that wanna to delete and `new_data = NULL`| Deletion or \ref MDBX_NOTFOUND if no such key-value pair|
|
2020-08-25 18:27:07 +03:00
|
|
|
|
|Delete one value at the current cursor position|\ref mdbx_cursor_del() with \ref MDBX_CURRENT flag|Deletion only the current entry|
|
2024-12-06 22:15:23 +03:00
|
|
|
|
|Delete all values of key at the current cursor position|\ref mdbx_cursor_del() with \ref MDBX_ALLDUPS flag|Deletion all duplicates of key (all multi-values) at the current cursor position|
|
2020-08-25 18:27:07 +03:00
|
|
|
|
|
2020-07-25 04:30:44 +03:00
|
|
|
|
\defgroup c_cursors Cursors
|
2020-07-28 15:05:35 +03:00
|
|
|
|
\defgroup c_statinfo Statistics & Information
|
|
|
|
|
\defgroup c_settings Settings
|
2020-07-25 04:30:44 +03:00
|
|
|
|
\defgroup c_debug Logging and runtime debug
|
|
|
|
|
\defgroup c_rqest Range query estimation
|
2020-07-28 15:05:35 +03:00
|
|
|
|
\defgroup c_extra Extra operations
|
2020-07-25 04:30:44 +03:00
|
|
|
|
*/
|
2020-08-25 18:27:07 +03:00
|
|
|
|
/* *INDENT-ON* */
|
|
|
|
|
/* clang-format on */
|
|
|
|
|
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
#include <stddef.h>
|
|
|
|
|
#include <stdint.h>
|
2021-12-03 16:46:33 +03:00
|
|
|
|
#if !defined(NDEBUG) && !defined(assert)
|
|
|
|
|
#include <assert.h>
|
|
|
|
|
#endif /* NDEBUG */
|
2017-05-24 13:59:50 +03:00
|
|
|
|
|
|
|
|
|
#if defined(_WIN32) || defined(_WIN64)
|
|
|
|
|
#include <windows.h>
|
|
|
|
|
#include <winnt.h>
|
2017-08-16 11:19:25 +03:00
|
|
|
|
#ifndef __mode_t_defined
|
2020-08-22 20:19:46 +03:00
|
|
|
|
typedef unsigned short mdbx_mode_t;
|
|
|
|
|
#else
|
|
|
|
|
typedef mode_t mdbx_mode_t;
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#endif /* __mode_t_defined */
|
2017-05-24 13:59:50 +03:00
|
|
|
|
typedef HANDLE mdbx_filehandle_t;
|
|
|
|
|
typedef DWORD mdbx_pid_t;
|
|
|
|
|
typedef DWORD mdbx_tid_t;
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else /* Windows */
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#include <errno.h> /* for error codes */
|
|
|
|
|
#include <pthread.h> /* for pthread_t */
|
|
|
|
|
#include <sys/types.h> /* for pid_t */
|
2020-09-21 23:51:47 -04:00
|
|
|
|
#include <sys/uio.h> /* for struct iovec */
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#define HAVE_STRUCT_IOVEC 1
|
|
|
|
|
typedef int mdbx_filehandle_t;
|
|
|
|
|
typedef pid_t mdbx_pid_t;
|
|
|
|
|
typedef pthread_t mdbx_tid_t;
|
2020-08-22 20:19:46 +03:00
|
|
|
|
typedef mode_t mdbx_mode_t;
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#endif /* !Windows */
|
2017-03-16 18:09:27 +03:00
|
|
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#pragma warning(pop)
|
|
|
|
|
#endif
|
|
|
|
|
|
2022-04-23 17:50:28 +03:00
|
|
|
|
/** end of c_api @}
|
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \defgroup api_macros Common Macros
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* @{ */
|
2020-07-21 01:24:29 +03:00
|
|
|
|
|
2019-09-15 17:16:31 +03:00
|
|
|
|
/*----------------------------------------------------------------------------*/
|
2017-05-24 13:59:50 +03:00
|
|
|
|
|
|
|
|
|
#ifndef __has_attribute
|
|
|
|
|
#define __has_attribute(x) (0)
|
2019-11-29 22:54:26 +03:00
|
|
|
|
#endif /* __has_attribute */
|
|
|
|
|
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#ifndef __has_c_attribute
|
|
|
|
|
#define __has_c_attribute(x) (0)
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#define __has_c_attribute_qualified(x) 0
|
|
|
|
|
#elif !defined(__STDC_VERSION__) || __STDC_VERSION__ < 202311L
|
|
|
|
|
#define __has_c_attribute_qualified(x) 0
|
|
|
|
|
#elif defined(_MSC_VER)
|
|
|
|
|
/* MSVC don't support `namespace::attr` syntax */
|
|
|
|
|
#define __has_c_attribute_qualified(x) 0
|
|
|
|
|
#else
|
|
|
|
|
#define __has_c_attribute_qualified(x) __has_c_attribute(x)
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#endif /* __has_c_attribute */
|
|
|
|
|
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#ifndef __has_cpp_attribute
|
|
|
|
|
#define __has_cpp_attribute(x) 0
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#define __has_cpp_attribute_qualified(x) 0
|
|
|
|
|
#elif defined(_MSC_VER)
|
|
|
|
|
/* MSVC don't support `namespace::attr` syntax */
|
|
|
|
|
#define __has_cpp_attribute_qualified(x) 0
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#else
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#define __has_cpp_attribute_qualified(x) __has_cpp_attribute(x)
|
|
|
|
|
#endif /* __has_cpp_attribute */
|
2024-10-10 06:16:49 +03:00
|
|
|
|
|
|
|
|
|
#ifndef __has_C23_or_CXX_attribute
|
|
|
|
|
#if defined(__cplusplus)
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#define __has_C23_or_CXX_attribute(x) __has_cpp_attribute_qualified(x)
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#else
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#define __has_C23_or_CXX_attribute(x) __has_c_attribute_qualified(x)
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#endif
|
|
|
|
|
#endif /* __has_C23_or_CXX_attribute */
|
|
|
|
|
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#ifndef __has_feature
|
|
|
|
|
#define __has_feature(x) (0)
|
2024-10-23 11:26:09 +03:00
|
|
|
|
#define __has_exceptions_disabled (0)
|
2024-11-22 18:33:18 +03:00
|
|
|
|
#elif !defined(__has_exceptions_disabled)
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define __has_exceptions_disabled (__has_feature(cxx_noexcept) && !__has_feature(cxx_exceptions))
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#endif /* __has_feature */
|
|
|
|
|
|
|
|
|
|
#ifndef __has_extension
|
2024-10-23 11:26:09 +03:00
|
|
|
|
#define __has_extension(x) __has_feature(x)
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#endif /* __has_extension */
|
|
|
|
|
|
|
|
|
|
#ifndef __has_builtin
|
|
|
|
|
#define __has_builtin(x) (0)
|
|
|
|
|
#endif /* __has_builtin */
|
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** \brief The 'pure' function attribute for optimization.
|
|
|
|
|
* \details Many functions have no effects except the return value and their
|
2020-08-21 18:01:16 +03:00
|
|
|
|
* return value depends only on the parameters and/or global variables.
|
|
|
|
|
* Such a function can be subject to common subexpression elimination
|
|
|
|
|
* and loop optimization just as an arithmetic operator would be.
|
|
|
|
|
* These functions should be declared with the attribute pure. */
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_PURE_FUNCTION [[gnu::pure]]
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#elif __has_C23_or_CXX_attribute(gnu::pure)
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#define MDBX_PURE_FUNCTION [[gnu::pure]]
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif (defined(__GNUC__) || __has_attribute(__pure__)) && \
|
|
|
|
|
(!defined(__clang__) /* https://bugs.llvm.org/show_bug.cgi?id=43275 */ || !defined(__cplusplus) || \
|
|
|
|
|
__has_exceptions_disabled)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_PURE_FUNCTION __attribute__((__pure__))
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_PURE_FUNCTION
|
|
|
|
|
#endif /* MDBX_PURE_FUNCTION */
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** \brief The 'pure nothrow' function attribute for optimization.
|
|
|
|
|
* \details Like \ref MDBX_PURE_FUNCTION with addition `noexcept` restriction
|
2020-08-21 18:01:16 +03:00
|
|
|
|
* that is compatible to CLANG and proposed [[pure]]. */
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_NOTHROW_PURE_FUNCTION [[gnu::pure, gnu::nothrow]]
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#elif __has_C23_or_CXX_attribute(gnu::pure)
|
|
|
|
|
#if __has_C23_or_CXX_attribute(gnu::nothrow)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NOTHROW_PURE_FUNCTION [[gnu::pure, gnu::nothrow]]
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NOTHROW_PURE_FUNCTION [[gnu::pure]]
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#endif
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif defined(__GNUC__) || (__has_attribute(__pure__) && __has_attribute(__nothrow__))
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#define MDBX_NOTHROW_PURE_FUNCTION __attribute__((__pure__, __nothrow__))
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#elif __has_cpp_attribute(pure)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NOTHROW_PURE_FUNCTION [[pure]]
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NOTHROW_PURE_FUNCTION
|
|
|
|
|
#endif /* MDBX_NOTHROW_PURE_FUNCTION */
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** \brief The 'const' function attribute for optimization.
|
|
|
|
|
* \details Many functions do not examine any values except their arguments,
|
2020-08-21 18:01:16 +03:00
|
|
|
|
* and have no effects except the return value. Basically this is just
|
|
|
|
|
* slightly more strict class than the PURE attribute, since function
|
|
|
|
|
* is not allowed to read global memory.
|
|
|
|
|
*
|
|
|
|
|
* Note that a function that has pointer arguments and examines the
|
|
|
|
|
* data pointed to must not be declared const. Likewise, a function
|
|
|
|
|
* that calls a non-const function usually must not be const.
|
|
|
|
|
* It does not make sense for a const function to return void. */
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_CONST_FUNCTION [[gnu::const]]
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#elif __has_C23_or_CXX_attribute(gnu::const)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CONST_FUNCTION [[gnu::const]]
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif (defined(__GNUC__) || __has_attribute(__const__)) && \
|
|
|
|
|
(!defined(__clang__) /* https://bugs.llvm.org/show_bug.cgi?id=43275 */ || !defined(__cplusplus) || \
|
|
|
|
|
__has_exceptions_disabled)
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#define MDBX_CONST_FUNCTION __attribute__((__const__))
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CONST_FUNCTION MDBX_PURE_FUNCTION
|
|
|
|
|
#endif /* MDBX_CONST_FUNCTION */
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** \brief The 'const nothrow' function attribute for optimization.
|
|
|
|
|
* \details Like \ref MDBX_CONST_FUNCTION with addition `noexcept` restriction
|
2020-08-21 18:01:16 +03:00
|
|
|
|
* that is compatible to CLANG and future [[const]]. */
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_NOTHROW_CONST_FUNCTION [[gnu::const, gnu::nothrow]]
|
2024-10-10 06:16:49 +03:00
|
|
|
|
#elif __has_C23_or_CXX_attribute(gnu::const)
|
|
|
|
|
#if __has_C23_or_CXX_attribute(gnu::nothrow)
|
|
|
|
|
#define MDBX_NOTHROW_CONST_FUNCTION [[gnu::const, gnu::nothrow]]
|
|
|
|
|
#else
|
|
|
|
|
#define MDBX_NOTHROW_CONST_FUNCTION [[gnu::const]]
|
|
|
|
|
#endif
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif defined(__GNUC__) || (__has_attribute(__const__) && __has_attribute(__nothrow__))
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NOTHROW_CONST_FUNCTION __attribute__((__const__, __nothrow__))
|
2024-11-19 01:24:40 +03:00
|
|
|
|
#elif __has_cpp_attribute_qualified(const)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NOTHROW_CONST_FUNCTION [[const]]
|
2020-08-21 18:01:16 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NOTHROW_CONST_FUNCTION MDBX_NOTHROW_PURE_FUNCTION
|
2020-11-28 09:48:24 +03:00
|
|
|
|
#endif /* MDBX_NOTHROW_CONST_FUNCTION */
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** \brief The 'deprecated' attribute to produce warnings when used.
|
|
|
|
|
* \note This macro may be predefined as empty to avoid "deprecated" warnings.
|
|
|
|
|
*/
|
|
|
|
|
#ifndef MDBX_DEPRECATED
|
2020-07-07 19:33:17 +03:00
|
|
|
|
#ifdef __deprecated
|
|
|
|
|
#define MDBX_DEPRECATED __deprecated
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif defined(DOXYGEN) || ((!defined(__GNUC__) || defined(__clang__) || __GNUC__ > 5) && \
|
|
|
|
|
((defined(__cplusplus) && __cplusplus >= 201403L && __has_cpp_attribute(deprecated) && \
|
|
|
|
|
__has_cpp_attribute(deprecated) >= 201309L) || \
|
|
|
|
|
(!defined(__cplusplus) && defined(__STDC_VERSION__) && __STDC_VERSION__ >= 202304L)))
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#define MDBX_DEPRECATED [[deprecated]]
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif (defined(__GNUC__) && __GNUC__ > 5) || \
|
|
|
|
|
(__has_attribute(__deprecated__) && (!defined(__GNUC__) || defined(__clang__) || __GNUC__ > 5))
|
2020-07-07 19:33:17 +03:00
|
|
|
|
#define MDBX_DEPRECATED __attribute__((__deprecated__))
|
2019-11-29 22:54:26 +03:00
|
|
|
|
#elif defined(_MSC_VER)
|
2020-07-07 19:33:17 +03:00
|
|
|
|
#define MDBX_DEPRECATED __declspec(deprecated)
|
2019-11-29 22:54:26 +03:00
|
|
|
|
#else
|
2020-07-07 19:33:17 +03:00
|
|
|
|
#define MDBX_DEPRECATED
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#endif
|
2020-07-07 19:33:17 +03:00
|
|
|
|
#endif /* MDBX_DEPRECATED */
|
2017-05-24 13:59:50 +03:00
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
#ifndef MDBX_DEPRECATED_ENUM
|
2024-11-22 20:15:29 +03:00
|
|
|
|
#ifdef __deprecated_enum
|
|
|
|
|
#define MDBX_DEPRECATED_ENUM __deprecated_enum
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif defined(DOXYGEN) || \
|
|
|
|
|
(!defined(_MSC_VER) || (defined(__cplusplus) && __cplusplus >= 201403L && __has_cpp_attribute(deprecated) && \
|
2024-11-09 22:09:37 +03:00
|
|
|
|
__has_cpp_attribute(deprecated) >= 201309L))
|
2024-05-19 22:07:58 +03:00
|
|
|
|
#define MDBX_DEPRECATED_ENUM MDBX_DEPRECATED
|
|
|
|
|
#else
|
|
|
|
|
#define MDBX_DEPRECATED_ENUM /* avoid madness MSVC */
|
|
|
|
|
#endif
|
|
|
|
|
#endif /* MDBX_DEPRECATED_ENUM */
|
|
|
|
|
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#ifndef __dll_export
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(__CYGWIN__) || defined(__MINGW__) || defined(__MINGW32__) || \
|
|
|
|
|
defined(__MINGW64__)
|
2020-02-08 12:41:41 +03:00
|
|
|
|
#if defined(__GNUC__) || __has_attribute(__dllexport__)
|
|
|
|
|
#define __dll_export __attribute__((__dllexport__))
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#elif defined(_MSC_VER)
|
|
|
|
|
#define __dll_export __declspec(dllexport)
|
|
|
|
|
#else
|
|
|
|
|
#define __dll_export
|
2017-03-16 18:09:27 +03:00
|
|
|
|
#endif
|
2019-08-25 03:05:58 +03:00
|
|
|
|
#elif defined(__GNUC__) || __has_attribute(__visibility__)
|
|
|
|
|
#define __dll_export __attribute__((__visibility__("default")))
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#else
|
|
|
|
|
#define __dll_export
|
|
|
|
|
#endif
|
|
|
|
|
#endif /* __dll_export */
|
|
|
|
|
|
|
|
|
|
#ifndef __dll_import
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(__CYGWIN__) || defined(__MINGW__) || defined(__MINGW32__) || \
|
|
|
|
|
defined(__MINGW64__)
|
2020-02-08 12:41:41 +03:00
|
|
|
|
#if defined(__GNUC__) || __has_attribute(__dllimport__)
|
|
|
|
|
#define __dll_import __attribute__((__dllimport__))
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#elif defined(_MSC_VER)
|
|
|
|
|
#define __dll_import __declspec(dllimport)
|
|
|
|
|
#else
|
|
|
|
|
#define __dll_import
|
|
|
|
|
#endif
|
|
|
|
|
#else
|
|
|
|
|
#define __dll_import
|
|
|
|
|
#endif
|
|
|
|
|
#endif /* __dll_import */
|
2017-03-16 18:09:27 +03:00
|
|
|
|
|
2020-10-14 18:15:50 +03:00
|
|
|
|
/** \brief Auxiliary macro for robustly define the both inline version of API
|
|
|
|
|
* function and non-inline fallback dll-exported version for applications linked
|
2024-05-19 22:07:58 +03:00
|
|
|
|
* with old version of libmdbx, with a strictly ODR-common implementation. Thus,
|
|
|
|
|
* we emulate __extern_inline for all compilers, including non-GNU ones. */
|
2021-02-02 00:25:48 +03:00
|
|
|
|
#if defined(LIBMDBX_INTERNALS) && !defined(LIBMDBX_NO_EXPORTS_LEGACY_API)
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define LIBMDBX_INLINE_API(TYPE, NAME, ARGS) \
|
|
|
|
|
/* proto of exported which uses common impl */ LIBMDBX_API TYPE NAME ARGS; \
|
2020-10-14 18:15:50 +03:00
|
|
|
|
/* definition of common impl */ static __inline TYPE __inline_##NAME ARGS
|
2021-02-02 00:25:48 +03:00
|
|
|
|
#else
|
|
|
|
|
#define LIBMDBX_INLINE_API(TYPE, NAME, ARGS) static __inline TYPE NAME ARGS
|
2020-10-14 18:15:50 +03:00
|
|
|
|
#endif /* LIBMDBX_INLINE_API */
|
|
|
|
|
|
2021-07-25 15:11:05 +03:00
|
|
|
|
/** \brief Converts a macro argument into a string constant. */
|
|
|
|
|
#ifndef MDBX_STRINGIFY
|
|
|
|
|
#define MDBX_STRINGIFY_HELPER(x) #x
|
|
|
|
|
#define MDBX_STRINGIFY(x) MDBX_STRINGIFY_HELPER(x)
|
|
|
|
|
#endif /* MDBX_STRINGIFY */
|
|
|
|
|
|
2019-09-15 17:16:31 +03:00
|
|
|
|
/*----------------------------------------------------------------------------*/
|
2017-05-24 13:59:50 +03:00
|
|
|
|
|
2020-07-19 10:41:15 +03:00
|
|
|
|
#ifndef __cplusplus
|
|
|
|
|
#ifndef bool
|
|
|
|
|
#define bool _Bool
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef true
|
|
|
|
|
#define true (1)
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef false
|
|
|
|
|
#define false (0)
|
|
|
|
|
#endif
|
|
|
|
|
#endif /* bool without __cplusplus */
|
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** Workaround for old compilers without support for C++17 `noexcept`. */
|
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_CXX17_NOEXCEPT noexcept
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif !defined(__cpp_noexcept_function_type) || __cpp_noexcept_function_type < 201510L
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX17_NOEXCEPT
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX17_NOEXCEPT noexcept
|
|
|
|
|
#endif /* MDBX_CXX17_NOEXCEPT */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** Workaround for old compilers without support for any kind of `constexpr`. */
|
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_CXX01_CONSTEXPR constexpr
|
|
|
|
|
#define MDBX_CXX01_CONSTEXPR_VAR constexpr
|
|
|
|
|
#elif !defined(__cplusplus)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX01_CONSTEXPR __inline
|
|
|
|
|
#define MDBX_CXX01_CONSTEXPR_VAR const
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif !defined(DOXYGEN) && \
|
|
|
|
|
((__cplusplus < 201103L && defined(__cpp_constexpr) && __cpp_constexpr < 200704L) || \
|
|
|
|
|
(defined(__LCC__) && __LCC__ < 124) || \
|
|
|
|
|
(defined(__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ < 407) && !defined(__clang__) && !defined(__LCC__)) || \
|
|
|
|
|
(defined(_MSC_VER) && _MSC_VER < 1910) || (defined(__clang__) && __clang_major__ < 4))
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX01_CONSTEXPR inline
|
|
|
|
|
#define MDBX_CXX01_CONSTEXPR_VAR const
|
2020-09-13 18:59:33 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX01_CONSTEXPR constexpr
|
|
|
|
|
#define MDBX_CXX01_CONSTEXPR_VAR constexpr
|
|
|
|
|
#endif /* MDBX_CXX01_CONSTEXPR */
|
2020-09-13 18:59:33 +03:00
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** Workaround for old compilers without properly support for C++11 `constexpr`.
|
|
|
|
|
*/
|
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_CXX11_CONSTEXPR constexpr
|
|
|
|
|
#define MDBX_CXX11_CONSTEXPR_VAR constexpr
|
|
|
|
|
#elif !defined(__cplusplus)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX11_CONSTEXPR __inline
|
|
|
|
|
#define MDBX_CXX11_CONSTEXPR_VAR const
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif !defined(DOXYGEN) && \
|
|
|
|
|
(!defined(__cpp_constexpr) || __cpp_constexpr < 201304L || (defined(__LCC__) && __LCC__ < 124) || \
|
|
|
|
|
(defined(__GNUC__) && __GNUC__ < 6 && !defined(__clang__) && !defined(__LCC__)) || \
|
|
|
|
|
(defined(_MSC_VER) && _MSC_VER < 1910) || (defined(__clang__) && __clang_major__ < 5))
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX11_CONSTEXPR inline
|
|
|
|
|
#define MDBX_CXX11_CONSTEXPR_VAR const
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX11_CONSTEXPR constexpr
|
|
|
|
|
#define MDBX_CXX11_CONSTEXPR_VAR constexpr
|
|
|
|
|
#endif /* MDBX_CXX11_CONSTEXPR */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
/** Workaround for old compilers without properly support for C++14 `constexpr`.
|
|
|
|
|
*/
|
|
|
|
|
#if defined(DOXYGEN)
|
|
|
|
|
#define MDBX_CXX14_CONSTEXPR constexpr
|
|
|
|
|
#define MDBX_CXX14_CONSTEXPR_VAR constexpr
|
|
|
|
|
#elif !defined(__cplusplus)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX14_CONSTEXPR __inline
|
|
|
|
|
#define MDBX_CXX14_CONSTEXPR_VAR const
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif defined(DOXYGEN) || \
|
|
|
|
|
defined(__cpp_constexpr) && __cpp_constexpr >= 201304L && \
|
|
|
|
|
((defined(_MSC_VER) && _MSC_VER >= 1910) || (defined(__clang__) && __clang_major__ > 4) || \
|
|
|
|
|
(defined(__GNUC__) && __GNUC__ > 6) || (!defined(__GNUC__) && !defined(__clang__) && !defined(_MSC_VER)))
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX14_CONSTEXPR constexpr
|
|
|
|
|
#define MDBX_CXX14_CONSTEXPR_VAR constexpr
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_CXX14_CONSTEXPR inline
|
|
|
|
|
#define MDBX_CXX14_CONSTEXPR_VAR const
|
|
|
|
|
#endif /* MDBX_CXX14_CONSTEXPR */
|
|
|
|
|
|
|
|
|
|
#if defined(__noreturn)
|
|
|
|
|
#define MDBX_NORETURN __noreturn
|
|
|
|
|
#elif defined(_Noreturn)
|
|
|
|
|
#define MDBX_NORETURN _Noreturn
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#elif defined(DOXYGEN) || (defined(__cplusplus) && __cplusplus >= 201103L) || \
|
|
|
|
|
(!defined(__cplusplus) && defined(__STDC_VERSION__) && __STDC_VERSION__ > 202005L)
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#define MDBX_NORETURN [[noreturn]]
|
2020-08-22 20:19:46 +03:00
|
|
|
|
#elif defined(__GNUC__) || __has_attribute(__noreturn__)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NORETURN __attribute__((__noreturn__))
|
2020-08-22 20:19:46 +03:00
|
|
|
|
#elif defined(_MSC_VER) && !defined(__clang__)
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NORETURN __declspec(noreturn)
|
2020-08-22 20:19:46 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_NORETURN
|
|
|
|
|
#endif /* MDBX_NORETURN */
|
2020-08-22 20:19:46 +03:00
|
|
|
|
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#ifndef MDBX_PRINTF_ARGS
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#if defined(__GNUC__) || __has_attribute(__format__) || defined(DOXYGEN)
|
2022-03-30 18:13:08 +03:00
|
|
|
|
#if defined(__MINGW__) || defined(__MINGW32__) || defined(__MINGW64__)
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define MDBX_PRINTF_ARGS(format_index, first_arg) __attribute__((__format__(__gnu_printf__, format_index, first_arg)))
|
2022-03-30 18:13:08 +03:00
|
|
|
|
#else
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define MDBX_PRINTF_ARGS(format_index, first_arg) __attribute__((__format__(__printf__, format_index, first_arg)))
|
2022-03-31 00:31:49 +03:00
|
|
|
|
#endif /* MinGW */
|
2020-09-10 15:35:43 +03:00
|
|
|
|
#else
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#define MDBX_PRINTF_ARGS(format_index, first_arg)
|
2020-09-10 15:35:43 +03:00
|
|
|
|
#endif
|
2020-09-14 16:40:46 +03:00
|
|
|
|
#endif /* MDBX_PRINTF_ARGS */
|
2020-09-10 15:35:43 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#if defined(DOXYGEN) || \
|
|
|
|
|
(defined(__cplusplus) && __cplusplus >= 201603L && __has_cpp_attribute(maybe_unused) && \
|
|
|
|
|
__has_cpp_attribute(maybe_unused) >= 201603L) || \
|
|
|
|
|
(!defined(__cplusplus) && defined(__STDC_VERSION__) && __STDC_VERSION__ > 202005L)
|
2021-05-11 20:14:09 +03:00
|
|
|
|
#define MDBX_MAYBE_UNUSED [[maybe_unused]]
|
|
|
|
|
#elif defined(__GNUC__) || __has_attribute(__unused__)
|
|
|
|
|
#define MDBX_MAYBE_UNUSED __attribute__((__unused__))
|
|
|
|
|
#else
|
|
|
|
|
#define MDBX_MAYBE_UNUSED
|
|
|
|
|
#endif /* MDBX_MAYBE_UNUSED */
|
|
|
|
|
|
2022-04-23 19:40:26 +03:00
|
|
|
|
#if __has_attribute(no_sanitize) || defined(DOXYGEN)
|
2021-08-14 16:02:33 +03:00
|
|
|
|
#define MDBX_NOSANITIZE_ENUM __attribute((__no_sanitize__("enum")))
|
|
|
|
|
#else
|
|
|
|
|
#define MDBX_NOSANITIZE_ENUM
|
|
|
|
|
#endif /* MDBX_NOSANITIZE_ENUM */
|
|
|
|
|
|
2020-10-10 20:07:00 +03:00
|
|
|
|
/* Oh, below are some songs and dances since:
|
|
|
|
|
* - C++ requires explicit definition of the necessary operators.
|
|
|
|
|
* - the proper implementation of DEFINE_ENUM_FLAG_OPERATORS for C++ required
|
|
|
|
|
* the constexpr feature which is broken in most old compilers;
|
|
|
|
|
* - DEFINE_ENUM_FLAG_OPERATORS may be defined broken as in the Windows SDK. */
|
2024-06-20 12:50:22 +03:00
|
|
|
|
#if !defined(DEFINE_ENUM_FLAG_OPERATORS) && !defined(DOXYGEN)
|
2020-10-10 20:07:00 +03:00
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#if !defined(__cpp_constexpr) || __cpp_constexpr < 200704L || (defined(__LCC__) && __LCC__ < 124) || \
|
|
|
|
|
(defined(__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ < 407) && !defined(__clang__) && !defined(__LCC__)) || \
|
|
|
|
|
(defined(_MSC_VER) && _MSC_VER < 1910) || (defined(__clang__) && __clang_major__ < 4)
|
2020-10-10 20:07:00 +03:00
|
|
|
|
/* The constexpr feature is not available or (may be) broken */
|
|
|
|
|
#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 0
|
|
|
|
|
#else
|
|
|
|
|
/* C always allows these operators for enums */
|
|
|
|
|
#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 1
|
|
|
|
|
#endif /* __cpp_constexpr */
|
|
|
|
|
|
2020-07-21 01:24:29 +03:00
|
|
|
|
/// Define operator overloads to enable bit operations on enum values that are
|
|
|
|
|
/// used to define flags (based on Microsoft's DEFINE_ENUM_FLAG_OPERATORS).
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define DEFINE_ENUM_FLAG_OPERATORS(ENUM) \
|
|
|
|
|
extern "C++" { \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator|(ENUM a, ENUM b) { return ENUM(unsigned(a) | unsigned(b)); } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator|=(ENUM &a, ENUM b) { return a = a | b; } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator&(ENUM a, ENUM b) { return ENUM(unsigned(a) & unsigned(b)); } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator&(ENUM a, unsigned b) { return ENUM(unsigned(a) & b); } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator&(unsigned a, ENUM b) { return ENUM(a & unsigned(b)); } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator&=(ENUM &a, ENUM b) { return a = a & b; } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator&=(ENUM &a, unsigned b) { return a = a & b; } \
|
|
|
|
|
MDBX_CXX01_CONSTEXPR unsigned operator~(ENUM a) { return ~unsigned(a); } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX01_CONSTEXPR ENUM operator^(ENUM a, ENUM b) { return ENUM(unsigned(a) ^ unsigned(b)); } \
|
|
|
|
|
MDBX_NOSANITIZE_ENUM MDBX_CXX14_CONSTEXPR ENUM &operator^=(ENUM &a, ENUM b) { return a = a ^ b; } \
|
2020-07-08 02:26:46 +03:00
|
|
|
|
}
|
2020-10-10 20:07:00 +03:00
|
|
|
|
#else /* __cplusplus */
|
|
|
|
|
/* nope for C since it always allows these operators for enums */
|
|
|
|
|
#define DEFINE_ENUM_FLAG_OPERATORS(ENUM)
|
|
|
|
|
#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 1
|
|
|
|
|
#endif /* !__cplusplus */
|
|
|
|
|
|
|
|
|
|
#elif !defined(CONSTEXPR_ENUM_FLAGS_OPERATIONS)
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
/* DEFINE_ENUM_FLAG_OPERATORS may be defined broken as in the Windows SDK */
|
|
|
|
|
#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 0
|
|
|
|
|
#else
|
|
|
|
|
/* C always allows these operators for enums */
|
|
|
|
|
#define CONSTEXPR_ENUM_FLAGS_OPERATIONS 1
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif /* DEFINE_ENUM_FLAG_OPERATORS */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2022-04-23 17:50:28 +03:00
|
|
|
|
/** end of api_macros @} */
|
2020-09-07 01:54:36 +03:00
|
|
|
|
|
2020-07-08 02:26:46 +03:00
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \addtogroup c_api
|
|
|
|
|
* @{ */
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
2023-04-23 20:23:04 +03:00
|
|
|
|
/* MDBX version 0.13.x */
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#define MDBX_VERSION_MAJOR 0
|
2023-04-23 20:23:04 +03:00
|
|
|
|
#define MDBX_VERSION_MINOR 13
|
2017-05-24 13:59:50 +03:00
|
|
|
|
|
2019-09-10 02:19:35 +03:00
|
|
|
|
#ifndef LIBMDBX_API
|
2024-10-18 18:38:36 +03:00
|
|
|
|
#if defined(LIBMDBX_EXPORTS) || defined(DOXYGEN)
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#define LIBMDBX_API __dll_export
|
|
|
|
|
#elif defined(LIBMDBX_IMPORTS)
|
|
|
|
|
#define LIBMDBX_API __dll_import
|
|
|
|
|
#else
|
|
|
|
|
#define LIBMDBX_API
|
2019-09-10 02:19:35 +03:00
|
|
|
|
#endif
|
2017-05-24 13:59:50 +03:00
|
|
|
|
#endif /* LIBMDBX_API */
|
2015-10-13 15:46:59 +03:00
|
|
|
|
|
2020-08-22 20:19:46 +03:00
|
|
|
|
#ifdef __cplusplus
|
2024-10-18 18:38:36 +03:00
|
|
|
|
#if defined(__clang__) || __has_attribute(type_visibility) || defined(DOXYGEN)
|
2020-08-22 20:19:46 +03:00
|
|
|
|
#define LIBMDBX_API_TYPE LIBMDBX_API __attribute__((type_visibility("default")))
|
|
|
|
|
#else
|
|
|
|
|
#define LIBMDBX_API_TYPE LIBMDBX_API
|
|
|
|
|
#endif
|
|
|
|
|
#else
|
|
|
|
|
#define LIBMDBX_API_TYPE
|
|
|
|
|
#endif /* LIBMDBX_API_TYPE */
|
|
|
|
|
|
2019-10-24 11:51:25 +03:00
|
|
|
|
#if defined(LIBMDBX_IMPORTS)
|
|
|
|
|
#define LIBMDBX_VERINFO_API __dll_import
|
|
|
|
|
#else
|
|
|
|
|
#define LIBMDBX_VERINFO_API __dll_export
|
|
|
|
|
#endif /* LIBMDBX_VERINFO_API */
|
|
|
|
|
|
2024-11-24 20:46:21 +03:00
|
|
|
|
/** \brief libmdbx version information, \see https://semver.org/ */
|
2020-07-21 01:24:29 +03:00
|
|
|
|
extern LIBMDBX_VERINFO_API const struct MDBX_version_info {
|
2024-11-24 20:46:21 +03:00
|
|
|
|
uint16_t major; /**< Major version number */
|
|
|
|
|
uint16_t minor; /**< Minor version number */
|
|
|
|
|
uint16_t patch; /**< Patch number */
|
|
|
|
|
uint16_t tweak; /**< Tweak number */
|
|
|
|
|
const char *semver_prerelease; /**< Semantic Versioning `pre-release` */
|
2020-07-21 01:24:29 +03:00
|
|
|
|
struct {
|
|
|
|
|
const char *datetime; /**< committer date, strict ISO-8601 format */
|
|
|
|
|
const char *tree; /**< commit hash (hexadecimal digits) */
|
|
|
|
|
const char *commit; /**< tree hash, i.e. digest of the source code */
|
|
|
|
|
const char *describe; /**< git-describe string */
|
|
|
|
|
} git; /**< source information from git */
|
|
|
|
|
const char *sourcery; /**< sourcery anchor for pinning */
|
2020-09-07 01:54:36 +03:00
|
|
|
|
} /** \brief libmdbx version information */ mdbx_version;
|
2020-07-21 01:24:29 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief libmdbx build information
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \attention Some strings could be NULL in case no corresponding information
|
|
|
|
|
* was provided at build time (i.e. flags). */
|
2020-07-21 01:24:29 +03:00
|
|
|
|
extern LIBMDBX_VERINFO_API const struct MDBX_build_info {
|
|
|
|
|
const char *datetime; /**< build timestamp (ISO-8601 or __DATE__ __TIME__) */
|
|
|
|
|
const char *target; /**< cpu/arch-system-config triplet */
|
|
|
|
|
const char *options; /**< mdbx-related options */
|
|
|
|
|
const char *compiler; /**< compiler */
|
|
|
|
|
const char *flags; /**< CFLAGS and CXXFLAGS */
|
2024-11-19 22:42:08 +03:00
|
|
|
|
const char *metadata; /**< an extra/custom information provided via
|
|
|
|
|
the MDBX_BUILD_METADATA definition
|
|
|
|
|
during library build */
|
2020-09-07 01:54:36 +03:00
|
|
|
|
} /** \brief libmdbx build information */ mdbx_build;
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2021-05-08 17:44:21 +03:00
|
|
|
|
#if (defined(_WIN32) || defined(_WIN64)) && !MDBX_BUILD_SHARED_LIBRARY
|
2019-09-12 03:30:10 +03:00
|
|
|
|
/* MDBX internally uses global and thread local storage destructors to
|
|
|
|
|
* automatically (de)initialization, releasing reader lock table slots
|
|
|
|
|
* and so on.
|
|
|
|
|
*
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* If MDBX built as a DLL this is done out-of-the-box by DllEntry() function,
|
2019-09-12 03:30:10 +03:00
|
|
|
|
* which called automatically by Windows core with passing corresponding reason
|
|
|
|
|
* argument.
|
|
|
|
|
*
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* Otherwise, if MDBX was built not as a DLL, some black magic
|
2019-09-12 03:30:10 +03:00
|
|
|
|
* may be required depending of Windows version:
|
2021-05-08 17:44:21 +03:00
|
|
|
|
*
|
2019-09-12 03:30:10 +03:00
|
|
|
|
* - Modern Windows versions, including Windows Vista and later, provides
|
|
|
|
|
* support for "TLS Directory" (e.g .CRT$XL[A-Z] sections in executable
|
|
|
|
|
* or dll file). In this case, MDBX capable of doing all automatically,
|
2021-05-08 17:44:21 +03:00
|
|
|
|
* therefore you DON'T NEED to call mdbx_module_handler()
|
|
|
|
|
* so the MDBX_MANUAL_MODULE_HANDLER defined as 0.
|
|
|
|
|
*
|
2019-09-12 03:30:10 +03:00
|
|
|
|
* - Obsolete versions of Windows, prior to Windows Vista, REQUIRES calling
|
2021-05-08 17:44:21 +03:00
|
|
|
|
* mdbx_module_handler() manually from corresponding DllMain() or WinMain()
|
|
|
|
|
* of your DLL or application,
|
|
|
|
|
* so the MDBX_MANUAL_MODULE_HANDLER defined as 1.
|
2019-09-12 03:30:10 +03:00
|
|
|
|
*
|
|
|
|
|
* Therefore, building MDBX as a DLL is recommended for all version of Windows.
|
2021-05-08 17:44:21 +03:00
|
|
|
|
* So, if you doubt, just build MDBX as the separate DLL and don't care about
|
|
|
|
|
* the MDBX_MANUAL_MODULE_HANDLER. */
|
2018-06-12 22:56:26 +03:00
|
|
|
|
|
2021-05-08 15:27:57 +03:00
|
|
|
|
#ifndef _WIN32_WINNT
|
|
|
|
|
#error Non-dll build libmdbx requires target Windows version \
|
|
|
|
|
to be explicitly defined via _WIN32_WINNT for properly \
|
|
|
|
|
handling thread local storage destructors.
|
2021-05-08 17:44:21 +03:00
|
|
|
|
#endif /* _WIN32_WINNT */
|
|
|
|
|
|
2021-05-08 15:27:57 +03:00
|
|
|
|
#if _WIN32_WINNT >= 0x0600 /* Windows Vista */
|
2021-05-08 17:44:21 +03:00
|
|
|
|
/* As described above mdbx_module_handler() is NOT needed for Windows Vista
|
2019-09-12 03:30:10 +03:00
|
|
|
|
* and later. */
|
2021-05-08 17:44:21 +03:00
|
|
|
|
#define MDBX_MANUAL_MODULE_HANDLER 0
|
2019-09-12 03:30:10 +03:00
|
|
|
|
#else
|
2021-05-08 17:44:21 +03:00
|
|
|
|
/* As described above mdbx_module_handler() IS REQUIRED for Windows versions
|
2019-09-12 03:30:10 +03:00
|
|
|
|
* prior to Windows Vista. */
|
2021-05-08 17:44:21 +03:00
|
|
|
|
#define MDBX_MANUAL_MODULE_HANDLER 1
|
2024-12-11 21:22:04 +03:00
|
|
|
|
void LIBMDBX_API NTAPI mdbx_module_handler(PVOID module, DWORD reason, PVOID reserved);
|
2018-06-12 17:05:25 +03:00
|
|
|
|
#endif
|
2021-05-08 17:44:21 +03:00
|
|
|
|
|
|
|
|
|
#endif /* Windows && !DLL && MDBX_MANUAL_MODULE_HANDLER */
|
2018-06-12 17:05:25 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/* OPACITY STRUCTURES *********************************************************/
|
2017-04-24 17:52:56 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Opaque structure for a database environment.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \details An environment supports multiple key-value tables (aka key-value
|
|
|
|
|
* maps, spaces or sub-databases), all residing in the same shared-memory map.
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \see mdbx_env_create() \see mdbx_env_close() */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#ifndef __cplusplus
|
2017-05-24 01:42:10 +03:00
|
|
|
|
typedef struct MDBX_env MDBX_env;
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else
|
|
|
|
|
struct MDBX_env;
|
|
|
|
|
#endif
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Opaque structure for a transaction handle.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \details All table operations require a transaction handle. Transactions
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* may be read-only or read-write.
|
|
|
|
|
* \see mdbx_txn_begin() \see mdbx_txn_commit() \see mdbx_txn_abort() */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#ifndef __cplusplus
|
2017-05-23 21:36:09 +03:00
|
|
|
|
typedef struct MDBX_txn MDBX_txn;
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else
|
|
|
|
|
struct MDBX_txn;
|
|
|
|
|
#endif
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief A handle for an individual table (key-value spaces) in the
|
2022-01-25 20:09:17 +03:00
|
|
|
|
* environment.
|
|
|
|
|
* \ingroup c_dbi
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \details Zero handle is used internally (hidden Garbage Collection table).
|
2022-01-25 20:09:17 +03:00
|
|
|
|
* So, any valid DBI-handle great than 0 and less than or equal
|
|
|
|
|
* \ref MDBX_MAX_DBI.
|
|
|
|
|
* \see mdbx_dbi_open() \see mdbx_dbi_close() */
|
2017-05-24 01:42:10 +03:00
|
|
|
|
typedef uint32_t MDBX_dbi;
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Opaque structure for navigating through a table
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \ingroup c_cursors
|
2020-09-15 02:05:25 +03:00
|
|
|
|
* \see mdbx_cursor_create() \see mdbx_cursor_bind() \see mdbx_cursor_close()
|
|
|
|
|
*/
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#ifndef __cplusplus
|
2017-05-24 01:42:10 +03:00
|
|
|
|
typedef struct MDBX_cursor MDBX_cursor;
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else
|
|
|
|
|
struct MDBX_cursor;
|
|
|
|
|
#endif
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Generic structure used for passing keys and data in and out of the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table.
|
2020-09-07 01:54:36 +03:00
|
|
|
|
* \anchor MDBX_val \see mdbx::slice \see mdbx::buffer
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \details Values returned from the table are valid only until a subsequent
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* update operation, or the end of the transaction. Do not modify or
|
|
|
|
|
* free them, they commonly point into the database itself.
|
|
|
|
|
*
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* Key sizes must be between 0 and \ref mdbx_env_get_maxkeysize() inclusive.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* The same applies to data sizes in tables with the \ref MDBX_DUPSORT flag.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Other data items can in theory be from 0 to \ref MDBX_MAXDATASIZE bytes long.
|
2019-09-15 17:16:31 +03:00
|
|
|
|
*
|
2020-07-21 01:24:29 +03:00
|
|
|
|
* \note The notable difference between MDBX and LMDB is that MDBX support zero
|
2019-09-15 17:16:31 +03:00
|
|
|
|
* length keys. */
|
2017-03-16 18:09:27 +03:00
|
|
|
|
#ifndef HAVE_STRUCT_IOVEC
|
|
|
|
|
struct iovec {
|
2020-07-23 19:24:21 +03:00
|
|
|
|
void *iov_base; /**< pointer to some data */
|
|
|
|
|
size_t iov_len; /**< the length of data in bytes */
|
2017-03-16 18:09:27 +03:00
|
|
|
|
};
|
|
|
|
|
#define HAVE_STRUCT_IOVEC
|
|
|
|
|
#endif /* HAVE_STRUCT_IOVEC */
|
|
|
|
|
|
2019-11-09 10:50:43 +03:00
|
|
|
|
#if defined(__sun) || defined(__SVR4) || defined(__svr4__)
|
|
|
|
|
/* The `iov_len` is signed on Sun/Solaris.
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* So define custom MDBX_val to avoid a lot of warnings. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
struct MDBX_val {
|
2020-07-23 19:24:21 +03:00
|
|
|
|
void *iov_base; /**< pointer to some data */
|
|
|
|
|
size_t iov_len; /**< the length of data in bytes */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
};
|
|
|
|
|
#ifndef __cplusplus
|
|
|
|
|
typedef struct MDBX_val MDBX_val;
|
2019-11-09 10:50:43 +03:00
|
|
|
|
#endif
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else /* SunOS */
|
|
|
|
|
typedef struct iovec MDBX_val;
|
|
|
|
|
#endif /* ! SunOS */
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-07-08 02:26:46 +03:00
|
|
|
|
enum MDBX_constants {
|
2023-03-28 21:24:18 +03:00
|
|
|
|
/** The hard limit for DBI handles. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_MAX_DBI = UINT32_C(32765),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** The maximum size of a data item. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_MAXDATASIZE = UINT32_C(0x7fff0000),
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-07-08 02:26:46 +03:00
|
|
|
|
/** The minimal database page size in bytes. */
|
|
|
|
|
MDBX_MIN_PAGESIZE = 256,
|
|
|
|
|
|
|
|
|
|
/** The maximal database page size in bytes. */
|
|
|
|
|
MDBX_MAX_PAGESIZE = 65536,
|
|
|
|
|
};
|
2017-03-31 17:59:12 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/* THE FILES *******************************************************************
|
|
|
|
|
* At the file system level, the environment corresponds to a pair of files. */
|
2019-09-24 02:07:00 +03:00
|
|
|
|
|
2022-06-25 22:14:06 +03:00
|
|
|
|
#ifndef MDBX_LOCKNAME
|
2022-06-25 15:27:33 +03:00
|
|
|
|
/** \brief The name of the lock file in the environment
|
|
|
|
|
* without using \ref MDBX_NOSUBDIR */
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#if !(defined(_WIN32) || defined(_WIN64))
|
2020-07-23 19:24:21 +03:00
|
|
|
|
#define MDBX_LOCKNAME "/mdbx.lck"
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#else
|
2022-10-09 23:05:20 +03:00
|
|
|
|
#define MDBX_LOCKNAME_W L"\\mdbx.lck"
|
|
|
|
|
#define MDBX_LOCKNAME_A "\\mdbx.lck"
|
|
|
|
|
#ifdef UNICODE
|
|
|
|
|
#define MDBX_LOCKNAME MDBX_LOCKNAME_W
|
|
|
|
|
#else
|
|
|
|
|
#define MDBX_LOCKNAME MDBX_LOCKNAME_A
|
|
|
|
|
#endif /* UNICODE */
|
|
|
|
|
#endif /* Windows */
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* MDBX_LOCKNAME */
|
2022-06-25 22:14:06 +03:00
|
|
|
|
#ifndef MDBX_DATANAME
|
2022-06-25 15:27:33 +03:00
|
|
|
|
/** \brief The name of the data file in the environment
|
|
|
|
|
* without using \ref MDBX_NOSUBDIR */
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#if !(defined(_WIN32) || defined(_WIN64))
|
2020-07-23 19:24:21 +03:00
|
|
|
|
#define MDBX_DATANAME "/mdbx.dat"
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#else
|
2022-10-09 23:05:20 +03:00
|
|
|
|
#define MDBX_DATANAME_W L"\\mdbx.dat"
|
|
|
|
|
#define MDBX_DATANAME_A "\\mdbx.dat"
|
|
|
|
|
#ifdef UNICODE
|
|
|
|
|
#define MDBX_DATANAME MDBX_DATANAME_W
|
|
|
|
|
#else
|
|
|
|
|
#define MDBX_DATANAME MDBX_DATANAME_A
|
|
|
|
|
#endif /* UNICODE */
|
|
|
|
|
#endif /* Windows */
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* MDBX_DATANAME */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2022-06-25 22:14:06 +03:00
|
|
|
|
#ifndef MDBX_LOCK_SUFFIX
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The suffix of the lock file when \ref MDBX_NOSUBDIR is used */
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#if !(defined(_WIN32) || defined(_WIN64))
|
2020-07-23 19:24:21 +03:00
|
|
|
|
#define MDBX_LOCK_SUFFIX "-lck"
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#else
|
2022-10-09 23:05:20 +03:00
|
|
|
|
#define MDBX_LOCK_SUFFIX_W L"-lck"
|
|
|
|
|
#define MDBX_LOCK_SUFFIX_A "-lck"
|
|
|
|
|
#ifdef UNICODE
|
|
|
|
|
#define MDBX_LOCK_SUFFIX MDBX_LOCK_SUFFIX_W
|
|
|
|
|
#else
|
|
|
|
|
#define MDBX_LOCK_SUFFIX MDBX_LOCK_SUFFIX_A
|
|
|
|
|
#endif /* UNICODE */
|
|
|
|
|
#endif /* Windows */
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* MDBX_LOCK_SUFFIX */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
|
|
|
|
/* DEBUG & LOGGING ************************************************************/
|
|
|
|
|
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/** \addtogroup c_debug
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* \note Most of debug feature enabled only when libmdbx built with
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref MDBX_DEBUG build option. @{ */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Log level
|
|
|
|
|
* \note Levels detailed than (great than) \ref MDBX_LOG_NOTICE
|
|
|
|
|
* requires build libmdbx with \ref MDBX_DEBUG option. */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_log_level {
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Critical conditions, i.e. assertion failures.
|
|
|
|
|
* \note libmdbx always produces such messages regardless
|
|
|
|
|
* of \ref MDBX_DEBUG build option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_FATAL = 0,
|
|
|
|
|
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Enables logging for error conditions
|
|
|
|
|
* and \ref MDBX_LOG_FATAL.
|
|
|
|
|
* \note libmdbx always produces such messages regardless
|
|
|
|
|
* of \ref MDBX_DEBUG build option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_ERROR = 1,
|
|
|
|
|
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Enables logging for warning conditions
|
|
|
|
|
* and \ref MDBX_LOG_ERROR ... \ref MDBX_LOG_FATAL.
|
|
|
|
|
* \note libmdbx always produces such messages regardless
|
|
|
|
|
* of \ref MDBX_DEBUG build option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_WARN = 2,
|
|
|
|
|
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Enables logging for normal but significant condition
|
|
|
|
|
* and \ref MDBX_LOG_WARN ... \ref MDBX_LOG_FATAL.
|
|
|
|
|
* \note libmdbx always produces such messages regardless
|
|
|
|
|
* of \ref MDBX_DEBUG build option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_NOTICE = 3,
|
|
|
|
|
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Enables logging for verbose informational
|
|
|
|
|
* and \ref MDBX_LOG_NOTICE ... \ref MDBX_LOG_FATAL.
|
|
|
|
|
* \note Requires build libmdbx with \ref MDBX_DEBUG option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_VERBOSE = 4,
|
|
|
|
|
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Enables logging for debug-level messages
|
|
|
|
|
* and \ref MDBX_LOG_VERBOSE ... \ref MDBX_LOG_FATAL.
|
|
|
|
|
* \note Requires build libmdbx with \ref MDBX_DEBUG option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_DEBUG = 5,
|
|
|
|
|
|
2022-02-17 02:30:16 +03:00
|
|
|
|
/** Enables logging for trace debug-level messages
|
|
|
|
|
* and \ref MDBX_LOG_DEBUG ... \ref MDBX_LOG_FATAL.
|
|
|
|
|
* \note Requires build libmdbx with \ref MDBX_DEBUG option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_TRACE = 6,
|
|
|
|
|
|
|
|
|
|
/** Enables extra debug-level messages (dump pgno lists)
|
2022-02-17 02:30:16 +03:00
|
|
|
|
* and all other log-messages.
|
|
|
|
|
* \note Requires build libmdbx with \ref MDBX_DEBUG option. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_LOG_EXTRA = 7,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2021-08-14 16:03:12 +03:00
|
|
|
|
#ifdef ENABLE_UBSAN
|
|
|
|
|
MDBX_LOG_MAX = 7 /* avoid UBSAN false-positive trap by a tests */,
|
|
|
|
|
#endif /* ENABLE_UBSAN */
|
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** for \ref mdbx_setup_debug() only: Don't change current settings */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_LOG_DONTCHANGE = -1
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_log_level_t;
|
2019-09-24 02:07:00 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Runtime debug flags
|
2019-09-24 02:07:00 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \details `MDBX_DBG_DUMP` and `MDBX_DBG_LEGACY_MULTIOPEN` always have an
|
|
|
|
|
* effect, but `MDBX_DBG_ASSERT`, `MDBX_DBG_AUDIT` and `MDBX_DBG_JITTER` only if
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* libmdbx built with \ref MDBX_DEBUG. */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_debug_flags {
|
2021-08-14 16:03:12 +03:00
|
|
|
|
MDBX_DBG_NONE = 0,
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** Enable assertion checks.
|
2022-02-17 02:30:16 +03:00
|
|
|
|
* \note Always enabled for builds with `MDBX_FORCE_ASSERTIONS` option,
|
|
|
|
|
* otherwise requires build with \ref MDBX_DEBUG > 0 */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_DBG_ASSERT = 1,
|
|
|
|
|
|
|
|
|
|
/** Enable pages usage audit at commit transactions.
|
2022-02-17 02:30:16 +03:00
|
|
|
|
* \note Requires build with \ref MDBX_DEBUG > 0 */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_DBG_AUDIT = 2,
|
|
|
|
|
|
|
|
|
|
/** Enable small random delays in critical points.
|
2022-02-17 02:30:16 +03:00
|
|
|
|
* \note Requires build with \ref MDBX_DEBUG > 0 */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_DBG_JITTER = 4,
|
|
|
|
|
|
|
|
|
|
/** Include or not meta-pages in coredump files.
|
2022-03-22 20:40:30 +03:00
|
|
|
|
* \note May affect performance in \ref MDBX_WRITEMAP mode */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_DBG_DUMP = 8,
|
|
|
|
|
|
|
|
|
|
/** Allow multi-opening environment(s) */
|
|
|
|
|
MDBX_DBG_LEGACY_MULTIOPEN = 16,
|
|
|
|
|
|
2022-03-22 20:40:30 +03:00
|
|
|
|
/** Allow read and write transactions overlapping for the same thread. */
|
2020-07-28 15:05:35 +03:00
|
|
|
|
MDBX_DBG_LEGACY_OVERLAP = 32,
|
2021-08-14 16:03:12 +03:00
|
|
|
|
|
2022-03-22 20:40:30 +03:00
|
|
|
|
/** Don't auto-upgrade format signature.
|
|
|
|
|
* \note However a new write transactions will use and store
|
|
|
|
|
* the last signature regardless this flag */
|
|
|
|
|
MDBX_DBG_DONT_UPGRADE = 64,
|
|
|
|
|
|
2021-08-14 16:03:12 +03:00
|
|
|
|
#ifdef ENABLE_UBSAN
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DBG_MAX = ((unsigned)MDBX_LOG_MAX) << 16 | 127 /* avoid UBSAN false-positive trap by a tests */,
|
2021-08-14 16:03:12 +03:00
|
|
|
|
#endif /* ENABLE_UBSAN */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
|
|
|
|
/** for mdbx_setup_debug() only: Don't change current settings */
|
|
|
|
|
MDBX_DBG_DONTCHANGE = -1
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_debug_flags_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_debug_flags)
|
2019-09-24 02:07:00 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief A debug-logger callback function,
|
2019-09-24 02:07:00 +03:00
|
|
|
|
* called before printing the message and aborting.
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \see mdbx_setup_debug()
|
2019-09-24 02:07:00 +03:00
|
|
|
|
*
|
2022-11-04 21:06:24 +03:00
|
|
|
|
* \param [in] loglevel The severity of message.
|
|
|
|
|
* \param [in] function The function name which emits message,
|
|
|
|
|
* may be NULL.
|
|
|
|
|
* \param [in] line The source code line number which emits message,
|
|
|
|
|
* may be zero.
|
|
|
|
|
* \param [in] fmt The printf-like format string with message.
|
|
|
|
|
* \param [in] args The variable argument list respectively for the
|
|
|
|
|
* format-message string passed by `fmt` argument.
|
|
|
|
|
* Maybe NULL or invalid if the format-message string
|
|
|
|
|
* don't contain `%`-specification of arguments. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef void MDBX_debug_func(MDBX_log_level_t loglevel, const char *function, int line, const char *fmt,
|
2020-09-14 16:40:46 +03:00
|
|
|
|
va_list args) MDBX_CXX17_NOEXCEPT;
|
2019-09-24 02:07:00 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The "don't change `logger`" value for mdbx_setup_debug() */
|
2020-02-02 15:05:32 +03:00
|
|
|
|
#define MDBX_LOGGER_DONTCHANGE ((MDBX_debug_func *)(intptr_t)-1)
|
2024-03-25 18:39:56 +03:00
|
|
|
|
#define MDBX_LOGGER_NOFMT_DONTCHANGE ((MDBX_debug_func_nofmt *)(intptr_t)-1)
|
2020-02-02 15:05:32 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Setup global log-level, debug options and debug logger.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns The previously `debug_flags` in the 0-15 bits
|
|
|
|
|
* and `log_level` in the 16-31 bits. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_setup_debug(MDBX_log_level_t log_level, MDBX_debug_flags_t debug_flags, MDBX_debug_func *logger);
|
2019-09-24 02:07:00 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef void MDBX_debug_func_nofmt(MDBX_log_level_t loglevel, const char *function, int line, const char *msg,
|
2024-03-25 18:39:56 +03:00
|
|
|
|
unsigned length) MDBX_CXX17_NOEXCEPT;
|
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
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);
|
2024-03-25 18:39:56 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief A callback function for most MDBX assert() failures,
|
2019-09-24 02:07:00 +03:00
|
|
|
|
* called before printing the message and aborting.
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \see mdbx_env_set_assert()
|
2019-09-24 02:07:00 +03:00
|
|
|
|
*
|
2022-11-04 21:06:24 +03:00
|
|
|
|
* \param [in] env An environment handle.
|
|
|
|
|
* \param [in] msg The assertion message, not including newline.
|
|
|
|
|
* \param [in] function The function name where the assertion check failed,
|
|
|
|
|
* may be NULL.
|
|
|
|
|
* \param [in] line The line number in the source file
|
|
|
|
|
* where the assertion check failed, may be zero. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef void MDBX_assert_func(const MDBX_env *env, const char *msg, const char *function,
|
2020-09-14 16:40:46 +03:00
|
|
|
|
unsigned line) MDBX_CXX17_NOEXCEPT;
|
2019-09-24 02:07:00 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Set or reset the assert() callback of the environment.
|
2019-09-24 02:07:00 +03:00
|
|
|
|
*
|
|
|
|
|
* Does nothing if libmdbx was built with MDBX_DEBUG=0 or with NDEBUG,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* and will return `MDBX_ENOSYS` in such case.
|
2019-09-24 02:07:00 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] env An environment handle returned by mdbx_env_create().
|
|
|
|
|
* \param [in] func An MDBX_assert_func function, or 0.
|
2019-09-24 02:07:00 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2019-09-24 02:07:00 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_set_assert(MDBX_env *env, MDBX_assert_func *func);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Dump given MDBX_val to the buffer
|
2020-07-29 16:56:27 +03:00
|
|
|
|
*
|
|
|
|
|
* Dumps it as string if value is printable (all bytes in the range 0x20..0x7E),
|
|
|
|
|
* otherwise made hexadecimal dump. Requires at least 4 byte length buffer.
|
|
|
|
|
*
|
|
|
|
|
* \returns One of:
|
|
|
|
|
* - NULL if given buffer size less than 4 bytes;
|
|
|
|
|
* - pointer to constant string if given value NULL or empty;
|
|
|
|
|
* - otherwise pointer to given buffer. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API const char *mdbx_dump_val(const MDBX_val *key, char *const buf, const size_t bufsize);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-10 15:37:59 +03:00
|
|
|
|
/** \brief Panics with message and causes abnormal process termination. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NORETURN LIBMDBX_API void mdbx_panic(const char *fmt, ...) MDBX_PRINTF_ARGS(1, 2);
|
2020-09-10 15:37:59 +03:00
|
|
|
|
|
2022-06-01 18:55:18 +03:00
|
|
|
|
/** \brief Panics with asserton failed message and causes abnormal process
|
|
|
|
|
* termination. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NORETURN LIBMDBX_API void mdbx_assert_fail(const MDBX_env *env, const char *msg, const char *func, unsigned line);
|
2022-04-23 17:50:28 +03:00
|
|
|
|
/** end of c_debug @} */
|
2019-09-12 03:30:10 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Environment flags
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_opening
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \anchor env_flags
|
|
|
|
|
* \see mdbx_env_open() \see mdbx_env_set_flags() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_env_flags {
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_ENV_DEFAULTS = 0,
|
|
|
|
|
|
2022-07-09 19:40:09 +03:00
|
|
|
|
/** Extra validation of DB structure and pages content.
|
|
|
|
|
*
|
|
|
|
|
* The `MDBX_VALIDATION` enabled the simple safe/careful mode for working
|
|
|
|
|
* with damaged or untrusted DB. However, a notable performance
|
|
|
|
|
* degradation should be expected. */
|
2022-06-30 21:38:32 +03:00
|
|
|
|
MDBX_VALIDATION = UINT32_C(0x00002000),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** No environment directory.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* By default, MDBX creates its environment in a directory whose pathname is
|
|
|
|
|
* given in path, and creates its data and lock files under that directory.
|
|
|
|
|
* With this option, path is used as-is for the database main data file.
|
|
|
|
|
* The database lock file is the path with "-lck" appended.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - with `MDBX_NOSUBDIR` = in a filesystem we have the pair of MDBX-files
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* which names derived from given pathname by appending predefined suffixes.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - without `MDBX_NOSUBDIR` = in a filesystem we have the MDBX-directory with
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* given pathname, within that a pair of MDBX-files with predefined names.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* This flag affects only at new environment creating by \ref mdbx_env_open(),
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* otherwise at opening an existing environment libmdbx will choice this
|
|
|
|
|
* automatically. */
|
|
|
|
|
MDBX_NOSUBDIR = UINT32_C(0x4000),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Read only mode.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* Open the environment in read-only mode. No write operations will be
|
|
|
|
|
* allowed. MDBX will still modify the lock file - except on read-only
|
|
|
|
|
* filesystems, where MDBX does not use locks.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - with `MDBX_RDONLY` = open environment in read-only mode.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* MDBX supports pure read-only mode (i.e. without opening LCK-file) only
|
|
|
|
|
* when environment directory and/or both files are not writable (and the
|
|
|
|
|
* LCK-file may be missing). In such case allowing file(s) to be placed
|
|
|
|
|
* on a network read-only share.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - without `MDBX_RDONLY` = open environment in read-write mode.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* This flag affects only at environment opening but can't be changed after.
|
|
|
|
|
*/
|
|
|
|
|
MDBX_RDONLY = UINT32_C(0x20000),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Open environment in exclusive/monopolistic mode.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `MDBX_EXCLUSIVE` flag can be used as a replacement for `MDB_NOLOCK`,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* which don't supported by MDBX.
|
|
|
|
|
* In this way, you can get the minimal overhead, but with the correct
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* multi-process and multi-thread locking.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - with `MDBX_EXCLUSIVE` = open environment in exclusive/monopolistic mode
|
|
|
|
|
* or return \ref MDBX_BUSY if environment already used by other process.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* The main feature of the exclusive mode is the ability to open the
|
|
|
|
|
* environment placed on a network share.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - without `MDBX_EXCLUSIVE` = open environment in cooperative mode,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* i.e. for multi-process access/interaction/cooperation.
|
|
|
|
|
* The main requirements of the cooperative mode are:
|
|
|
|
|
*
|
|
|
|
|
* 1. data files MUST be placed in the LOCAL file system,
|
|
|
|
|
* but NOT on a network share.
|
|
|
|
|
* 2. environment MUST be opened only by LOCAL processes,
|
|
|
|
|
* but NOT over a network.
|
|
|
|
|
* 3. OS kernel (i.e. file system and memory mapping implementation) and
|
|
|
|
|
* all processes that open the given environment MUST be running
|
|
|
|
|
* in the physically single RAM with cache-coherency. The only
|
|
|
|
|
* exception for cache-consistency requirement is Linux on MIPS
|
|
|
|
|
* architecture, but this case has not been tested for a long time).
|
|
|
|
|
*
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* This flag affects only at environment opening but can't be changed after.
|
|
|
|
|
*/
|
|
|
|
|
MDBX_EXCLUSIVE = UINT32_C(0x400000),
|
|
|
|
|
|
2020-08-03 21:36:55 +03:00
|
|
|
|
/** Using database/environment which already opened by another process(es).
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-08-03 21:36:55 +03:00
|
|
|
|
* The `MDBX_ACCEDE` flag is useful to avoid \ref MDBX_INCOMPATIBLE error
|
|
|
|
|
* while opening the database/environment which is already used by another
|
|
|
|
|
* process(es) with unknown mode/flags. In such cases, if there is a
|
|
|
|
|
* difference in the specified flags (\ref MDBX_NOMETASYNC,
|
2022-06-22 18:33:00 +03:00
|
|
|
|
* \ref MDBX_SAFE_NOSYNC, \ref MDBX_UTTERLY_NOSYNC, \ref MDBX_LIFORECLAIM
|
|
|
|
|
* and \ref MDBX_NORDAHEAD), instead of returning an error,
|
2020-08-03 21:36:55 +03:00
|
|
|
|
* the database will be opened in a compatibility with the already used mode.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `MDBX_ACCEDE` has no effect if the current process is the only one either
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* opening the DB in read-only mode or other process(es) uses the DB in
|
|
|
|
|
* read-only mode. */
|
|
|
|
|
MDBX_ACCEDE = UINT32_C(0x40000000),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Map data into memory with write permission.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Use a writeable memory map unless \ref MDBX_RDONLY is set. This uses fewer
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* mallocs and requires much less work for tracking database pages, but
|
|
|
|
|
* loses protection from application bugs like wild pointer writes and other
|
|
|
|
|
* bad updates into the database. This may be slightly faster for DBs that
|
|
|
|
|
* fit entirely in RAM, but is slower for DBs larger than RAM. Also adds the
|
|
|
|
|
* possibility for stray application writes thru pointers to silently
|
|
|
|
|
* corrupt the database.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - with `MDBX_WRITEMAP` = all data will be mapped into memory in the
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* read-write mode. This offers a significant performance benefit, since the
|
|
|
|
|
* data will be modified directly in mapped memory and then flushed to disk
|
|
|
|
|
* by single system call, without any memory management nor copying.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - without `MDBX_WRITEMAP` = data will be mapped into memory in the
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* read-only mode. This requires stocking all modified database pages in
|
|
|
|
|
* memory and then writing them to disk through file operations.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \warning On the other hand, `MDBX_WRITEMAP` adds the possibility for stray
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* application writes thru pointers to silently corrupt the database.
|
2020-07-29 16:56:27 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \note The `MDBX_WRITEMAP` mode is incompatible with nested transactions,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* since this is unreasonable. I.e. nested transactions requires mallocation
|
|
|
|
|
* of database pages and more work for tracking ones, which neuters a
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* performance boost caused by the `MDBX_WRITEMAP` mode.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* This flag affects only at environment opening but can't be changed after.
|
|
|
|
|
*/
|
|
|
|
|
MDBX_WRITEMAP = UINT32_C(0x80000),
|
|
|
|
|
|
2024-04-02 00:22:09 +03:00
|
|
|
|
/** Отвязывает транзакции от потоков/threads насколько это возможно.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2024-05-19 22:07:58 +03:00
|
|
|
|
* Опция предназначена для приложений, которые мультиплексируют множество
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* пользовательских легковесных потоков выполнения по отдельным потокам
|
|
|
|
|
* операционной системы, например как это происходит в средах выполнения
|
|
|
|
|
* GoLang и Rust. Таким приложениям также рекомендуется сериализовать
|
|
|
|
|
* транзакции записи в одном потоке операционной системы, поскольку блокировка
|
|
|
|
|
* записи MDBX использует базовые системные примитивы синхронизации и ничего
|
|
|
|
|
* не знает о пользовательских потоках и/или легковесных потоков среды
|
|
|
|
|
* выполнения. Как минимум, обязательно требуется обеспечить завершение каждой
|
|
|
|
|
* пишущей транзакции строго в том же потоке операционной системы где она была
|
|
|
|
|
* запущена.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* \note Начиная с версии v0.13 опция `MDBX_NOSTICKYTHREADS` полностью
|
|
|
|
|
* заменяет опцию \ref MDBX_NOTLS.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* При использовании `MDBX_NOSTICKYTHREADS` транзакции становятся не
|
|
|
|
|
* ассоциированными с создавшими их потоками выполнения. Поэтому в функциях
|
|
|
|
|
* API не выполняется проверка соответствия транзакции и текущего потока
|
|
|
|
|
* выполнения. Большинство функций работающих с транзакциями и курсорами
|
|
|
|
|
* становится возможным вызывать из любых потоков выполнения. Однако, также
|
|
|
|
|
* становится невозможно обнаружить ошибки одновременного использования
|
|
|
|
|
* транзакций и/или курсоров в разных потоках.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* Использование `MDBX_NOSTICKYTHREADS` также сужает возможности по изменению
|
|
|
|
|
* размера БД, так как теряется возможность отслеживать работающие с БД потоки
|
|
|
|
|
* выполнения и приостанавливать их на время снятия отображения БД в ОЗУ. В
|
|
|
|
|
* частности, по этой причине на Windows уменьшение файла БД не возможно до
|
|
|
|
|
* закрытия БД последним работающим с ней процессом или до последующего
|
|
|
|
|
* открытия БД в режиме чтения-записи.
|
|
|
|
|
*
|
|
|
|
|
* \warning Вне зависимости от \ref MDBX_NOSTICKYTHREADS и \ref MDBX_NOTLS не
|
|
|
|
|
* допускается одновременно использование объектов API из разных потоков
|
|
|
|
|
* выполнения! Обеспечение всех мер для исключения одновременного
|
|
|
|
|
* использования объектов API из разных потоков выполнения целиком ложится на
|
|
|
|
|
* вас!
|
|
|
|
|
*
|
|
|
|
|
* \warning Транзакции записи могут быть завершены только в том же потоке
|
|
|
|
|
* выполнения где они были запущены. Это ограничение следует из требований
|
|
|
|
|
* большинства операционных систем о том, что захваченный примитив
|
|
|
|
|
* синхронизации (мьютекс, семафор, критическая секция) должен освобождаться
|
|
|
|
|
* только захватившим его потоком выполнения.
|
|
|
|
|
*
|
|
|
|
|
* \warning Создание курсора в контексте транзакции, привязка курсора к
|
|
|
|
|
* транзакции, отвязка курсора от транзакции и закрытие привязанного к
|
|
|
|
|
* транзакции курсора, являются операциями использующими как сам курсор так и
|
|
|
|
|
* соответствующую транзакцию. Аналогично, завершение или прерывание
|
|
|
|
|
* транзакции является операцией использующей как саму транзакцию, так и все
|
|
|
|
|
* привязанные к ней курсоры. Во избежание повреждения внутренних структур
|
|
|
|
|
* данных, непредсказуемого поведения, разрушение БД и потери данных следует
|
|
|
|
|
* не допускать возможности одновременного использования каких-либо курсора
|
|
|
|
|
* или транзакций из разных потоков выполнения.
|
|
|
|
|
*
|
|
|
|
|
* Читающие транзакции при использовании `MDBX_NOSTICKYTHREADS` перестают
|
|
|
|
|
* использовать TLS (Thread Local Storage), а слоты блокировок MVCC-снимков в
|
|
|
|
|
* таблице читателей привязываются только к транзакциям. Завершение каких-либо
|
|
|
|
|
* потоков не приводит к снятию блокировок MVCC-снимков до явного завершения
|
|
|
|
|
* транзакций, либо до завершения соответствующего процесса в целом.
|
|
|
|
|
*
|
|
|
|
|
* Для пишущих транзакций не выполняется проверка соответствия текущего потока
|
|
|
|
|
* выполнения и потока создавшего транзакцию. Однако, фиксация или прерывание
|
|
|
|
|
* пишущих транзакций должны выполняться строго в потоке запустившим
|
|
|
|
|
* транзакцию, так как эти операции связаны с захватом и освобождением
|
|
|
|
|
* примитивов синхронизации (мьютексов, критических секций), для которых
|
|
|
|
|
* большинство операционных систем требует освобождение только потоком
|
|
|
|
|
* захватившим ресурс.
|
|
|
|
|
*
|
|
|
|
|
* Этот флаг вступает в силу при открытии среды и не может быть изменен после.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*/
|
2024-04-02 00:22:09 +03:00
|
|
|
|
MDBX_NOSTICKYTHREADS = UINT32_C(0x200000),
|
2024-05-19 22:07:58 +03:00
|
|
|
|
|
2024-04-02 00:22:09 +03:00
|
|
|
|
/** \deprecated Please use \ref MDBX_NOSTICKYTHREADS instead. */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
MDBX_NOTLS MDBX_DEPRECATED_ENUM = MDBX_NOSTICKYTHREADS,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Don't do readahead.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* Turn off readahead. Most operating systems perform readahead on read
|
|
|
|
|
* requests by default. This option turns it off if the OS supports it.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* Turning it off may help random read performance when the DB is larger
|
|
|
|
|
* than RAM and system RAM is full.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* By default libmdbx dynamically enables/disables readahead depending on
|
|
|
|
|
* the actual database size and currently available memory. On the other
|
|
|
|
|
* hand, such automation has some limitation, i.e. could be performed only
|
|
|
|
|
* when DB size changing but can't tracks and reacts changing a free RAM
|
|
|
|
|
* availability, since it changes independently and asynchronously.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note The mdbx_is_readahead_reasonable() function allows to quickly find
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* out whether to use readahead or not based on the size of the data and the
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* amount of available memory.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* This flag affects only at environment opening and can't be changed after.
|
|
|
|
|
*/
|
|
|
|
|
MDBX_NORDAHEAD = UINT32_C(0x800000),
|
|
|
|
|
|
2021-03-20 01:24:21 +03:00
|
|
|
|
/** Don't initialize malloc'ed memory before writing to datafile.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2021-03-20 01:24:21 +03:00
|
|
|
|
* Don't initialize malloc'ed memory before writing to unused spaces in the
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* data file. By default, memory for pages written to the data file is
|
|
|
|
|
* obtained using malloc. While these pages may be reused in subsequent
|
2021-03-20 01:24:21 +03:00
|
|
|
|
* transactions, freshly malloc'ed pages will be initialized to zeroes before
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* use. This avoids persisting leftover data from other code (that used the
|
|
|
|
|
* heap and subsequently freed the memory) into the data file.
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* Note that many other system libraries may allocate and free memory from
|
|
|
|
|
* the heap for arbitrary uses. E.g., stdio may use the heap for file I/O
|
|
|
|
|
* buffers. This initialization step has a modest performance cost so some
|
|
|
|
|
* applications may want to disable it using this flag. This option can be a
|
|
|
|
|
* problem for applications which handle sensitive data like passwords, and
|
|
|
|
|
* it makes memory checkers like Valgrind noisy. This flag is not needed
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* with \ref MDBX_WRITEMAP, which writes directly to the mmap instead of using
|
|
|
|
|
* malloc for pages. The initialization is also skipped if \ref MDBX_RESERVE
|
|
|
|
|
* is used; the caller is expected to overwrite all of the memory that was
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* reserved in that case.
|
|
|
|
|
*
|
|
|
|
|
* This flag may be changed at any time using `mdbx_env_set_flags()`. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_NOMEMINIT = UINT32_C(0x1000000),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Aims to coalesce a Garbage Collection items.
|
2024-04-04 11:59:39 +03:00
|
|
|
|
* \deprecated Always enabled since v0.12 and deprecated since v0.13.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* With `MDBX_COALESCE` flag MDBX will aims to coalesce items while recycling
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* a Garbage Collection. Technically, when possible short lists of pages
|
|
|
|
|
* will be combined into longer ones, but to fit on one database page. As a
|
|
|
|
|
* result, there will be fewer items in Garbage Collection and a page lists
|
|
|
|
|
* are longer, which slightly increases the likelihood of returning pages to
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* Unallocated space and reducing the database file.
|
|
|
|
|
*
|
|
|
|
|
* This flag may be changed at any time using mdbx_env_set_flags(). */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
MDBX_COALESCE MDBX_DEPRECATED_ENUM = UINT32_C(0x2000000),
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** LIFO policy for recycling a Garbage Collection items.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `MDBX_LIFORECLAIM` flag turns on LIFO policy for recycling a Garbage
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* Collection items, instead of FIFO by default. On systems with a disk
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* write-back cache, this can significantly increase write performance, up
|
|
|
|
|
* to several times in a best case scenario.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* LIFO recycling policy means that for reuse pages will be taken which became
|
|
|
|
|
* unused the lastest (i.e. just now or most recently). Therefore the loop of
|
|
|
|
|
* database pages circulation becomes as short as possible. In other words,
|
|
|
|
|
* the number of pages, that are overwritten in memory and on disk during a
|
|
|
|
|
* series of write transactions, will be as small as possible. Thus creates
|
|
|
|
|
* ideal conditions for the efficient operation of the disk write-back cache.
|
|
|
|
|
*
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* \ref MDBX_LIFORECLAIM is compatible with all no-sync flags, but gives NO
|
|
|
|
|
* noticeable impact in combination with \ref MDBX_SAFE_NOSYNC or
|
|
|
|
|
* \ref MDBX_UTTERLY_NOSYNC. Because MDBX will reused pages only before the
|
|
|
|
|
* last "steady" MVCC-snapshot, i.e. the loop length of database pages
|
|
|
|
|
* circulation will be mostly defined by frequency of calling
|
2020-08-03 21:36:55 +03:00
|
|
|
|
* \ref mdbx_env_sync() rather than LIFO and FIFO difference.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* This flag may be changed at any time using mdbx_env_set_flags(). */
|
|
|
|
|
MDBX_LIFORECLAIM = UINT32_C(0x4000000),
|
|
|
|
|
|
|
|
|
|
/** Debugging option, fill/perturb released pages. */
|
|
|
|
|
MDBX_PAGEPERTURB = UINT32_C(0x8000000),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/* SYNC MODES****************************************************************/
|
|
|
|
|
/** \defgroup sync_modes SYNC MODES
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \attention Using any combination of \ref MDBX_SAFE_NOSYNC, \ref
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* MDBX_NOMETASYNC and especially \ref MDBX_UTTERLY_NOSYNC is always a deal to
|
|
|
|
|
* reduce durability for gain write performance. You must know exactly what
|
|
|
|
|
* you are doing and what risks you are taking!
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \note for LMDB users: \ref MDBX_SAFE_NOSYNC is NOT similar to LMDB_NOSYNC,
|
|
|
|
|
* but \ref MDBX_UTTERLY_NOSYNC is exactly match LMDB_NOSYNC. See details
|
|
|
|
|
* below.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
|
|
|
|
* THE SCENE:
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* - The DAT-file contains several MVCC-snapshots of B-tree at same time,
|
|
|
|
|
* each of those B-tree has its own root page.
|
|
|
|
|
* - Each of meta pages at the beginning of the DAT file contains a
|
|
|
|
|
* pointer to the root page of B-tree which is the result of the particular
|
|
|
|
|
* transaction, and a number of this transaction.
|
|
|
|
|
* - For data durability, MDBX must first write all MVCC-snapshot data
|
|
|
|
|
* pages and ensure that are written to the disk, then update a meta page
|
|
|
|
|
* with the new transaction number and a pointer to the corresponding new
|
|
|
|
|
* root page, and flush any buffers yet again.
|
|
|
|
|
* - Thus during commit a I/O buffers should be flushed to the disk twice;
|
|
|
|
|
* i.e. fdatasync(), FlushFileBuffers() or similar syscall should be
|
|
|
|
|
* called twice for each commit. This is very expensive for performance,
|
|
|
|
|
* but guaranteed durability even on unexpected system failure or power
|
|
|
|
|
* outage. Of course, provided that the operating system and the
|
|
|
|
|
* underlying hardware (e.g. disk) work correctly.
|
|
|
|
|
*
|
|
|
|
|
* TRADE-OFF:
|
|
|
|
|
* By skipping some stages described above, you can significantly benefit in
|
|
|
|
|
* speed, while partially or completely losing in the guarantee of data
|
|
|
|
|
* durability and/or consistency in the event of system or power failure.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* Moreover, if for any reason disk write order is not preserved, then at
|
|
|
|
|
* moment of a system crash, a meta-page with a pointer to the new B-tree may
|
|
|
|
|
* be written to disk, while the itself B-tree not yet. In that case, the
|
|
|
|
|
* database will be corrupted!
|
|
|
|
|
*
|
2020-09-07 12:30:50 +03:00
|
|
|
|
* \see MDBX_SYNC_DURABLE \see MDBX_NOMETASYNC \see MDBX_SAFE_NOSYNC
|
|
|
|
|
* \see MDBX_UTTERLY_NOSYNC
|
2020-07-08 02:26:46 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* @{ */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** Default robust and durable sync mode.
|
|
|
|
|
*
|
2020-09-07 12:30:50 +03:00
|
|
|
|
* Metadata is written and flushed to disk after a data is written and
|
|
|
|
|
* flushed, which guarantees the integrity of the database in the event
|
|
|
|
|
* of a crash at any time.
|
|
|
|
|
*
|
|
|
|
|
* \attention Please do not use other modes until you have studied all the
|
|
|
|
|
* details and are sure. Otherwise, you may lose your users' data, as happens
|
|
|
|
|
* in [Miranda NG](https://www.miranda-ng.org/) messenger. */
|
2020-09-07 01:54:36 +03:00
|
|
|
|
MDBX_SYNC_DURABLE = 0,
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Don't sync the meta-page after commit.
|
|
|
|
|
*
|
2020-09-07 01:54:36 +03:00
|
|
|
|
* Flush system buffers to disk only once per transaction commit, omit the
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* metadata flush. Defer that until the system flushes files to disk,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* or next non-\ref MDBX_RDONLY commit or \ref mdbx_env_sync(). Depending on
|
|
|
|
|
* the platform and hardware, with \ref MDBX_NOMETASYNC you may get a doubling
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* of write performance.
|
|
|
|
|
*
|
|
|
|
|
* This trade-off maintains database integrity, but a system crash may
|
|
|
|
|
* undo the last committed transaction. I.e. it preserves the ACI
|
|
|
|
|
* (atomicity, consistency, isolation) but not D (durability) database
|
|
|
|
|
* property.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `MDBX_NOMETASYNC` flag may be changed at any time using
|
|
|
|
|
* \ref mdbx_env_set_flags() or by passing to \ref mdbx_txn_begin() for
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* particular write transaction. \see sync_modes */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_NOMETASYNC = UINT32_C(0x40000),
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Don't sync anything but keep previous steady commits.
|
|
|
|
|
*
|
2020-10-27 19:59:11 +03:00
|
|
|
|
* Like \ref MDBX_UTTERLY_NOSYNC the `MDBX_SAFE_NOSYNC` flag disable similarly
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* flush system buffers to disk when committing a transaction. But there is a
|
|
|
|
|
* huge difference in how are recycled the MVCC snapshots corresponding to
|
|
|
|
|
* previous "steady" transactions (see below).
|
|
|
|
|
*
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* With \ref MDBX_WRITEMAP the `MDBX_SAFE_NOSYNC` instructs MDBX to use
|
|
|
|
|
* asynchronous mmap-flushes to disk. Asynchronous mmap-flushes means that
|
|
|
|
|
* actually all writes will scheduled and performed by operation system on it
|
|
|
|
|
* own manner, i.e. unordered. MDBX itself just notify operating system that
|
|
|
|
|
* it would be nice to write data to disk, but no more.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Depending on the platform and hardware, with `MDBX_SAFE_NOSYNC` you may get
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* a multiple increase of write performance, even 10 times or more.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
*
|
|
|
|
|
* In contrast to \ref MDBX_UTTERLY_NOSYNC mode, with `MDBX_SAFE_NOSYNC` flag
|
|
|
|
|
* MDBX will keeps untouched pages within B-tree of the last transaction
|
|
|
|
|
* "steady" which was synced to disk completely. This has big implications for
|
|
|
|
|
* both data durability and (unfortunately) performance:
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* - a system crash can't corrupt the database, but you will lose the last
|
|
|
|
|
* transactions; because MDBX will rollback to last steady commit since it
|
|
|
|
|
* kept explicitly.
|
|
|
|
|
* - the last steady transaction makes an effect similar to "long-lived" read
|
|
|
|
|
* transaction (see above in the \ref restrictions section) since prevents
|
|
|
|
|
* reuse of pages freed by newer write transactions, thus the any data
|
|
|
|
|
* changes will be placed in newly allocated pages.
|
|
|
|
|
* - to avoid rapid database growth, the system will sync data and issue
|
|
|
|
|
* a steady commit-point to resume reuse pages, each time there is
|
|
|
|
|
* insufficient space and before increasing the size of the file on disk.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* In other words, with `MDBX_SAFE_NOSYNC` flag MDBX insures you from the
|
|
|
|
|
* whole database corruption, at the cost increasing database size and/or
|
|
|
|
|
* number of disk IOPs. So, `MDBX_SAFE_NOSYNC` flag could be used with
|
|
|
|
|
* \ref mdbx_env_sync() as alternatively for batch committing or nested
|
|
|
|
|
* transaction (in some cases). As well, auto-sync feature exposed by
|
|
|
|
|
* \ref mdbx_env_set_syncbytes() and \ref mdbx_env_set_syncperiod() functions
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* could be very useful with `MDBX_SAFE_NOSYNC` flag.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2024-12-06 22:15:23 +03:00
|
|
|
|
* The number and volume of disk IOPs with MDBX_SAFE_NOSYNC flag will
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* exactly the as without any no-sync flags. However, you should expect a
|
|
|
|
|
* larger process's [work set](https://bit.ly/2kA2tFX) and significantly worse
|
|
|
|
|
* a [locality of reference](https://bit.ly/2mbYq2J), due to the more
|
|
|
|
|
* intensive allocation of previously unused pages and increase the size of
|
|
|
|
|
* the database.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `MDBX_SAFE_NOSYNC` flag may be changed at any time using
|
|
|
|
|
* \ref mdbx_env_set_flags() or by passing to \ref mdbx_txn_begin() for
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* particular write transaction. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_SAFE_NOSYNC = UINT32_C(0x10000),
|
|
|
|
|
|
2020-08-01 19:13:17 +03:00
|
|
|
|
/** \deprecated Please use \ref MDBX_SAFE_NOSYNC instead of `MDBX_MAPASYNC`.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* Since version 0.9.x the `MDBX_MAPASYNC` is deprecated and has the same
|
|
|
|
|
* effect as \ref MDBX_SAFE_NOSYNC with \ref MDBX_WRITEMAP. This just API
|
|
|
|
|
* simplification is for convenience and clarity. */
|
|
|
|
|
MDBX_MAPASYNC = MDBX_SAFE_NOSYNC,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Don't sync anything and wipe previous steady commits.
|
|
|
|
|
*
|
|
|
|
|
* Don't flush system buffers to disk when committing a transaction. This
|
|
|
|
|
* optimization means a system crash can corrupt the database, if buffers are
|
|
|
|
|
* not yet flushed to disk. Depending on the platform and hardware, with
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `MDBX_UTTERLY_NOSYNC` you may get a multiple increase of write performance,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* even 100 times or more.
|
|
|
|
|
*
|
|
|
|
|
* If the filesystem preserves write order (which is rare and never provided
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* unless explicitly noted) and the \ref MDBX_WRITEMAP and \ref
|
|
|
|
|
* MDBX_LIFORECLAIM flags are not used, then a system crash can't corrupt the
|
|
|
|
|
* database, but you can lose the last transactions, if at least one buffer is
|
|
|
|
|
* not yet flushed to disk. The risk is governed by how often the system
|
|
|
|
|
* flushes dirty buffers to disk and how often \ref mdbx_env_sync() is called.
|
|
|
|
|
* So, transactions exhibit ACI (atomicity, consistency, isolation) properties
|
|
|
|
|
* and only lose `D` (durability). I.e. database integrity is maintained, but
|
|
|
|
|
* a system crash may undo the final transactions.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* Otherwise, if the filesystem not preserves write order (which is
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* typically) or \ref MDBX_WRITEMAP or \ref MDBX_LIFORECLAIM flags are used,
|
|
|
|
|
* you should expect the corrupted database after a system crash.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* So, most important thing about `MDBX_UTTERLY_NOSYNC`:
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* - a system crash immediately after commit the write transaction
|
|
|
|
|
* high likely lead to database corruption.
|
|
|
|
|
* - successful completion of mdbx_env_sync(force = true) after one or
|
2020-10-20 15:42:50 +03:00
|
|
|
|
* more committed transactions guarantees consistency and durability.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* - BUT by committing two or more transactions you back database into
|
|
|
|
|
* a weak state, in which a system crash may lead to database corruption!
|
|
|
|
|
* In case single transaction after mdbx_env_sync, you may lose transaction
|
|
|
|
|
* itself, but not a whole database.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Nevertheless, `MDBX_UTTERLY_NOSYNC` provides "weak" durability in case
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* of an application crash (but no durability on system failure), and
|
|
|
|
|
* therefore may be very useful in scenarios where data durability is
|
|
|
|
|
* not required over a system failure (e.g for short-lived data), or if you
|
|
|
|
|
* can take such risk.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `MDBX_UTTERLY_NOSYNC` flag may be changed at any time using
|
|
|
|
|
* \ref mdbx_env_set_flags(), but don't has effect if passed to
|
|
|
|
|
* \ref mdbx_txn_begin() for particular write transaction. \see sync_modes */
|
2020-08-01 19:13:17 +03:00
|
|
|
|
MDBX_UTTERLY_NOSYNC = MDBX_SAFE_NOSYNC | UINT32_C(0x100000),
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2022-04-23 17:50:28 +03:00
|
|
|
|
/** end of sync_modes @} */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_env_flags_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_env_flags)
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-08-02 20:52:36 +03:00
|
|
|
|
/** Transaction flags
|
|
|
|
|
* \ingroup c_transactions
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \anchor txn_flags
|
|
|
|
|
* \see mdbx_txn_begin() \see mdbx_txn_flags() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_txn_flags {
|
2020-08-02 20:52:36 +03:00
|
|
|
|
/** Start read-write transaction.
|
|
|
|
|
*
|
|
|
|
|
* Only one write transaction may be active at a time. Writes are fully
|
|
|
|
|
* serialized, which guarantees that writers can never deadlock. */
|
|
|
|
|
MDBX_TXN_READWRITE = 0,
|
|
|
|
|
|
|
|
|
|
/** Start read-only transaction.
|
|
|
|
|
*
|
|
|
|
|
* There can be multiple read-only transactions simultaneously that do not
|
|
|
|
|
* block each other and a write transactions. */
|
|
|
|
|
MDBX_TXN_RDONLY = MDBX_RDONLY,
|
|
|
|
|
|
2020-08-22 20:19:46 +03:00
|
|
|
|
/** Prepare but not start read-only transaction.
|
|
|
|
|
*
|
|
|
|
|
* Transaction will not be started immediately, but created transaction handle
|
|
|
|
|
* will be ready for use with \ref mdbx_txn_renew(). This flag allows to
|
|
|
|
|
* preallocate memory and assign a reader slot, thus avoiding these operations
|
|
|
|
|
* at the next start of the transaction. */
|
2020-10-10 20:07:00 +03:00
|
|
|
|
#if CONSTEXPR_ENUM_FLAGS_OPERATIONS || defined(DOXYGEN)
|
2020-08-22 20:19:46 +03:00
|
|
|
|
MDBX_TXN_RDONLY_PREPARE = MDBX_RDONLY | MDBX_NOMEMINIT,
|
2020-10-10 20:07:00 +03:00
|
|
|
|
#else
|
|
|
|
|
MDBX_TXN_RDONLY_PREPARE = uint32_t(MDBX_RDONLY) | uint32_t(MDBX_NOMEMINIT),
|
2020-08-22 20:19:46 +03:00
|
|
|
|
#endif
|
2020-08-03 12:56:57 +03:00
|
|
|
|
|
2020-08-02 20:52:36 +03:00
|
|
|
|
/** Do not block when starting a write transaction. */
|
|
|
|
|
MDBX_TXN_TRY = UINT32_C(0x10000000),
|
|
|
|
|
|
|
|
|
|
/** Exactly the same as \ref MDBX_NOMETASYNC,
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but for this transaction only. */
|
2020-08-02 20:52:36 +03:00
|
|
|
|
MDBX_TXN_NOMETASYNC = MDBX_NOMETASYNC,
|
|
|
|
|
|
|
|
|
|
/** Exactly the same as \ref MDBX_SAFE_NOSYNC,
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but for this transaction only. */
|
|
|
|
|
MDBX_TXN_NOSYNC = MDBX_SAFE_NOSYNC,
|
|
|
|
|
|
|
|
|
|
/* Transaction state flags ---------------------------------------------- */
|
|
|
|
|
|
|
|
|
|
/** Transaction is invalid.
|
|
|
|
|
* \note Transaction state flag. Returned from \ref mdbx_txn_flags()
|
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
2022-05-03 14:16:19 +03:00
|
|
|
|
MDBX_TXN_INVALID = INT32_MIN,
|
2022-05-02 10:35:40 +03:00
|
|
|
|
|
|
|
|
|
/** Transaction is finished or never began.
|
2024-07-09 16:04:01 +03:00
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_FINISHED = 0x01,
|
|
|
|
|
|
|
|
|
|
/** Transaction is unusable after an error.
|
2024-07-09 16:04:01 +03:00
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_ERROR = 0x02,
|
|
|
|
|
|
|
|
|
|
/** Transaction must write, even if dirty list is empty.
|
2024-07-09 16:04:01 +03:00
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_DIRTY = 0x04,
|
|
|
|
|
|
|
|
|
|
/** Transaction or a parent has spilled pages.
|
2024-07-09 16:04:01 +03:00
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_SPILLS = 0x08,
|
|
|
|
|
|
|
|
|
|
/** Transaction has a nested child transaction.
|
2024-07-09 16:04:01 +03:00
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_HAS_CHILD = 0x10,
|
|
|
|
|
|
2024-07-09 16:04:01 +03:00
|
|
|
|
/** Transaction is parked by \ref mdbx_txn_park().
|
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_PARKED = 0x20,
|
|
|
|
|
|
|
|
|
|
/** Transaction is parked by \ref mdbx_txn_park() with `autounpark=true`,
|
|
|
|
|
* and therefore it can be used without explicitly calling
|
|
|
|
|
* \ref mdbx_txn_unpark() first.
|
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_AUTOUNPARK = 0x40,
|
|
|
|
|
|
|
|
|
|
/** The transaction was blocked using the \ref mdbx_txn_park() function,
|
|
|
|
|
* and then ousted by a write transaction because
|
|
|
|
|
* this transaction was interfered with garbage recycling.
|
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
|
|
|
|
MDBX_TXN_OUSTED = 0x80,
|
|
|
|
|
|
2022-05-02 10:35:40 +03:00
|
|
|
|
/** Most operations on the transaction are currently illegal.
|
2024-07-09 16:04:01 +03:00
|
|
|
|
* \note This is a transaction state flag. Returned from \ref mdbx_txn_flags()
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* but can't be used with \ref mdbx_txn_begin(). */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_TXN_BLOCKED = MDBX_TXN_FINISHED | MDBX_TXN_ERROR | MDBX_TXN_HAS_CHILD | MDBX_TXN_PARKED
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_txn_flags_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_txn_flags)
|
2020-08-02 20:52:36 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Table flags
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ingroup c_dbi
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \anchor db_flags
|
|
|
|
|
* \see mdbx_dbi_open() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_db_flags {
|
2022-04-13 11:04:23 +03:00
|
|
|
|
/** Variable length unique keys with usual byte-by-byte string comparison. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_DB_DEFAULTS = 0,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2021-11-12 19:38:48 +03:00
|
|
|
|
/** Use reverse string comparison for keys. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_REVERSEKEY = UINT32_C(0x02),
|
|
|
|
|
|
2021-11-12 19:38:48 +03:00
|
|
|
|
/** Use sorted duplicates, i.e. allow multi-values for a keys. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_DUPSORT = UINT32_C(0x04),
|
|
|
|
|
|
2021-12-03 20:39:10 +08:00
|
|
|
|
/** Numeric keys in native byte order either uint32_t or uint64_t
|
|
|
|
|
* (must be one of uint32_t or uint64_t, other integer types, for example,
|
|
|
|
|
* signed integer or uint16_t will not work).
|
|
|
|
|
* The keys must all be of the same size and must be aligned while passing as
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* arguments. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_INTEGERKEY = UINT32_C(0x08),
|
|
|
|
|
|
2021-11-12 19:38:48 +03:00
|
|
|
|
/** With \ref MDBX_DUPSORT; sorted dup items have fixed size. The data values
|
|
|
|
|
* must all be of the same size. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_DUPFIXED = UINT32_C(0x10),
|
|
|
|
|
|
2020-11-24 07:50:49 +03:00
|
|
|
|
/** With \ref MDBX_DUPSORT and with \ref MDBX_DUPFIXED; dups are fixed size
|
2021-11-12 19:38:48 +03:00
|
|
|
|
* like \ref MDBX_INTEGERKEY -style integers. The data values must all be of
|
|
|
|
|
* the same size and must be aligned while passing as arguments. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_INTEGERDUP = UINT32_C(0x20),
|
|
|
|
|
|
2021-11-12 19:38:48 +03:00
|
|
|
|
/** With \ref MDBX_DUPSORT; use reverse string comparison for data values. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_REVERSEDUP = UINT32_C(0x40),
|
|
|
|
|
|
2021-11-12 19:38:48 +03:00
|
|
|
|
/** Create DB if not already existing. */
|
2020-08-03 22:57:52 +03:00
|
|
|
|
MDBX_CREATE = UINT32_C(0x40000),
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Opens an existing table created with unknown flags.
|
2020-08-03 22:57:52 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* The `MDBX_DB_ACCEDE` flag is intend to open a existing table which
|
2020-08-03 22:57:52 +03:00
|
|
|
|
* was created with unknown flags (\ref MDBX_REVERSEKEY, \ref MDBX_DUPSORT,
|
|
|
|
|
* \ref MDBX_INTEGERKEY, \ref MDBX_DUPFIXED, \ref MDBX_INTEGERDUP and
|
|
|
|
|
* \ref MDBX_REVERSEDUP).
|
|
|
|
|
*
|
|
|
|
|
* In such cases, instead of returning the \ref MDBX_INCOMPATIBLE error, the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table will be opened with flags which it was created, and then an
|
2020-08-03 22:57:52 +03:00
|
|
|
|
* application could determine the actual flags by \ref mdbx_dbi_flags(). */
|
|
|
|
|
MDBX_DB_ACCEDE = MDBX_ACCEDE
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_db_flags_t;
|
2024-06-20 12:50:22 +03:00
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_db_flags)
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Data changing flags
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \ingroup c_crud
|
2021-01-26 20:14:21 +03:00
|
|
|
|
* \see \ref c_crud_hints "Quick reference for Insert/Update/Delete operations"
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \see mdbx_put() \see mdbx_cursor_put() \see mdbx_replace() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_put_flags {
|
2020-08-27 22:24:07 +03:00
|
|
|
|
/** Upsertion by default (without any other flags) */
|
|
|
|
|
MDBX_UPSERT = 0,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-08-27 22:24:07 +03:00
|
|
|
|
/** For insertion: Don't write if the key already exists. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_NOOVERWRITE = UINT32_C(0x10),
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Has effect only for \ref MDBX_DUPSORT tables.
|
2022-09-05 15:53:35 +03:00
|
|
|
|
* For upsertion: don't write if the key-value pair already exist. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_NODUPDATA = UINT32_C(0x20),
|
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** For upsertion: overwrite the current key/data pair.
|
|
|
|
|
* MDBX allows this flag for \ref mdbx_put() for explicit overwrite/update
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* without insertion.
|
|
|
|
|
* For deletion: remove only single entry at the current cursor position. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_CURRENT = UINT32_C(0x40),
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Has effect only for \ref MDBX_DUPSORT tables.
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* For deletion: remove all multi-values (aka duplicates) for given key.
|
|
|
|
|
* For upsertion: replace all multi-values for given key with a new one. */
|
|
|
|
|
MDBX_ALLDUPS = UINT32_C(0x80),
|
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** For upsertion: Just reserve space for data, don't copy it.
|
|
|
|
|
* Return a pointer to the reserved space. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_RESERVE = UINT32_C(0x10000),
|
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** Data is being appended.
|
|
|
|
|
* Don't split full pages, continue on a new instead. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_APPEND = UINT32_C(0x20000),
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Has effect only for \ref MDBX_DUPSORT tables.
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* Duplicate data is being appended.
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* Don't split full pages, continue on a new instead. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_APPENDDUP = UINT32_C(0x40000),
|
|
|
|
|
|
2020-08-27 22:24:07 +03:00
|
|
|
|
/** Only for \ref MDBX_DUPFIXED.
|
|
|
|
|
* Store multiple data items in one call. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_MULTIPLE = UINT32_C(0x80000)
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_put_flags_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_put_flags)
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Environment copy flags
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
* \see mdbx_env_copy() \see mdbx_env_copy2fd() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_copy_flags {
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_CP_DEFAULTS = 0,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
|
|
|
|
/** Copy with compactification: Omit free space from copy and renumber all
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* pages sequentially */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_CP_COMPACT = 1u,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2023-01-10 14:16:08 +03:00
|
|
|
|
/** Force to make resizable copy, i.e. dynamic size instead of fixed */
|
2024-08-02 12:12:29 +03:00
|
|
|
|
MDBX_CP_FORCE_DYNAMIC_SIZE = 2u,
|
|
|
|
|
|
|
|
|
|
/** Don't explicitly flush the written data to an output media */
|
|
|
|
|
MDBX_CP_DONT_FLUSH = 4u,
|
|
|
|
|
|
|
|
|
|
/** Use read transaction parking during copying MVCC-snapshot
|
2024-08-02 12:13:25 +03:00
|
|
|
|
* \see mdbx_txn_park() */
|
2024-08-02 12:12:29 +03:00
|
|
|
|
MDBX_CP_THROTTLE_MVCC = 8u,
|
|
|
|
|
|
|
|
|
|
/** Abort/dispose passed transaction after copy
|
2024-08-02 12:13:25 +03:00
|
|
|
|
* \see mdbx_txn_copy2fd() \see mdbx_txn_copy2pathname() */
|
2024-08-02 12:12:29 +03:00
|
|
|
|
MDBX_CP_DISPOSE_TXN = 16u,
|
|
|
|
|
|
|
|
|
|
/** Enable renew/restart read transaction in case it use outdated
|
2024-08-02 12:13:25 +03:00
|
|
|
|
* MVCC shapshot, otherwise the \ref MDBX_MVCC_RETARDED will be returned
|
|
|
|
|
* \see mdbx_txn_copy2fd() \see mdbx_txn_copy2pathname() */
|
2024-08-02 12:12:29 +03:00
|
|
|
|
MDBX_CP_RENEW_TXN = 32u
|
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_copy_flags_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_copy_flags)
|
2019-09-15 17:16:31 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Cursor operations
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_cursors
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* This is the set of all operations for retrieving data using a cursor.
|
2021-03-14 16:31:26 +03:00
|
|
|
|
* \see mdbx_cursor_get() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_cursor_op {
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Position at first key/data item */
|
|
|
|
|
MDBX_FIRST,
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \ref MDBX_DUPSORT -only: Position at first data item of current key. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_FIRST_DUP,
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \ref MDBX_DUPSORT -only: Position at key/data pair. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_GET_BOTH,
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \ref MDBX_DUPSORT -only: Position at given key and at first data greater
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* than or equal to specified data. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_GET_BOTH_RANGE,
|
|
|
|
|
|
|
|
|
|
/** Return key/data at current cursor position */
|
|
|
|
|
MDBX_GET_CURRENT,
|
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** \ref MDBX_DUPFIXED -only: Return up to a page of duplicate data items
|
|
|
|
|
* from current cursor position. Move cursor to prepare
|
|
|
|
|
* for \ref MDBX_NEXT_MULTIPLE. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_GET_MULTIPLE,
|
|
|
|
|
|
|
|
|
|
/** Position at last key/data item */
|
|
|
|
|
MDBX_LAST,
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \ref MDBX_DUPSORT -only: Position at last data item of current key. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_LAST_DUP,
|
|
|
|
|
|
|
|
|
|
/** Position at next data item */
|
|
|
|
|
MDBX_NEXT,
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \ref MDBX_DUPSORT -only: Position at next data item of current key. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_NEXT_DUP,
|
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** \ref MDBX_DUPFIXED -only: Return up to a page of duplicate data items
|
|
|
|
|
* from next cursor position. Move cursor to prepare
|
2020-08-22 20:19:46 +03:00
|
|
|
|
* for `MDBX_NEXT_MULTIPLE`. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_NEXT_MULTIPLE,
|
|
|
|
|
|
|
|
|
|
/** Position at first data item of next key */
|
|
|
|
|
MDBX_NEXT_NODUP,
|
|
|
|
|
|
|
|
|
|
/** Position at previous data item */
|
|
|
|
|
MDBX_PREV,
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \ref MDBX_DUPSORT -only: Position at previous data item of current key. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
MDBX_PREV_DUP,
|
|
|
|
|
|
|
|
|
|
/** Position at last data item of previous key */
|
|
|
|
|
MDBX_PREV_NODUP,
|
|
|
|
|
|
|
|
|
|
/** Position at specified key */
|
|
|
|
|
MDBX_SET,
|
|
|
|
|
|
|
|
|
|
/** Position at specified key, return both key and data */
|
|
|
|
|
MDBX_SET_KEY,
|
|
|
|
|
|
|
|
|
|
/** Position at first key greater than or equal to specified key. */
|
|
|
|
|
MDBX_SET_RANGE,
|
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** \ref MDBX_DUPFIXED -only: Position at previous page and return up to
|
|
|
|
|
* a page of duplicate data items. */
|
2020-11-17 08:01:08 +03:00
|
|
|
|
MDBX_PREV_MULTIPLE,
|
|
|
|
|
|
2021-12-13 03:40:12 +03:00
|
|
|
|
/** Positions cursor at first key-value pair greater than or equal to
|
|
|
|
|
* specified, return both key and data, and the return code depends on whether
|
|
|
|
|
* a exact match.
|
2020-11-17 08:01:08 +03:00
|
|
|
|
*
|
|
|
|
|
* For non DUPSORT-ed collections this work the same to \ref MDBX_SET_RANGE,
|
2021-12-13 03:40:12 +03:00
|
|
|
|
* but returns \ref MDBX_SUCCESS if key found exactly or
|
2020-11-17 08:01:08 +03:00
|
|
|
|
* \ref MDBX_RESULT_TRUE if greater key was found.
|
|
|
|
|
*
|
|
|
|
|
* For DUPSORT-ed a data value is taken into account for duplicates,
|
|
|
|
|
* i.e. for a pairs/tuples of a key and an each data value of duplicates.
|
2021-12-13 03:40:12 +03:00
|
|
|
|
* Returns \ref MDBX_SUCCESS if key-value pair found exactly or
|
2020-11-17 08:01:08 +03:00
|
|
|
|
* \ref MDBX_RESULT_TRUE if the next pair was returned. */
|
2021-12-13 03:40:12 +03:00
|
|
|
|
MDBX_SET_LOWERBOUND,
|
|
|
|
|
|
|
|
|
|
/** Positions cursor at first key-value pair greater than specified,
|
|
|
|
|
* return both key and data, and the return code depends on whether a
|
|
|
|
|
* upper-bound was found.
|
|
|
|
|
*
|
2023-11-13 12:52:17 +03:00
|
|
|
|
* For non DUPSORT-ed collections this work like \ref MDBX_SET_RANGE,
|
2021-12-13 03:40:12 +03:00
|
|
|
|
* but returns \ref MDBX_SUCCESS if the greater key was found or
|
|
|
|
|
* \ref MDBX_NOTFOUND otherwise.
|
|
|
|
|
*
|
|
|
|
|
* For DUPSORT-ed a data value is taken into account for duplicates,
|
|
|
|
|
* i.e. for a pairs/tuples of a key and an each data value of duplicates.
|
|
|
|
|
* Returns \ref MDBX_SUCCESS if the greater pair was returned or
|
|
|
|
|
* \ref MDBX_NOTFOUND otherwise. */
|
2023-11-13 12:52:17 +03:00
|
|
|
|
MDBX_SET_UPPERBOUND,
|
|
|
|
|
|
|
|
|
|
/* Doubtless cursor positioning at a specified key. */
|
|
|
|
|
MDBX_TO_KEY_LESSER_THAN,
|
|
|
|
|
MDBX_TO_KEY_LESSER_OR_EQUAL,
|
|
|
|
|
MDBX_TO_KEY_EQUAL,
|
|
|
|
|
MDBX_TO_KEY_GREATER_OR_EQUAL,
|
|
|
|
|
MDBX_TO_KEY_GREATER_THAN,
|
|
|
|
|
|
|
|
|
|
/* Doubtless cursor positioning at a specified key-value pair
|
|
|
|
|
* for dupsort/multi-value hives. */
|
|
|
|
|
MDBX_TO_EXACT_KEY_VALUE_LESSER_THAN,
|
|
|
|
|
MDBX_TO_EXACT_KEY_VALUE_LESSER_OR_EQUAL,
|
|
|
|
|
MDBX_TO_EXACT_KEY_VALUE_EQUAL,
|
|
|
|
|
MDBX_TO_EXACT_KEY_VALUE_GREATER_OR_EQUAL,
|
|
|
|
|
MDBX_TO_EXACT_KEY_VALUE_GREATER_THAN,
|
|
|
|
|
|
|
|
|
|
MDBX_TO_PAIR_LESSER_THAN,
|
|
|
|
|
MDBX_TO_PAIR_LESSER_OR_EQUAL,
|
|
|
|
|
MDBX_TO_PAIR_EQUAL,
|
|
|
|
|
MDBX_TO_PAIR_GREATER_OR_EQUAL,
|
|
|
|
|
MDBX_TO_PAIR_GREATER_THAN
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_cursor_op;
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Errors and return codes
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_err
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* BerkeleyDB uses -30800 to -30999, we'll go under them
|
|
|
|
|
* \see mdbx_strerror() \see mdbx_strerror_r() \see mdbx_liberr2str() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_error {
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Successful result */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_SUCCESS = 0,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** Alias for \ref MDBX_SUCCESS */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_RESULT_FALSE = MDBX_SUCCESS,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
|
|
|
|
/** Successful result with special meaning or a flag */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_RESULT_TRUE = -1,
|
2017-02-27 21:17:22 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** key/data pair already exists */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_KEYEXIST = -30799,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-08-22 20:19:46 +03:00
|
|
|
|
/** The first LMDB-compatible defined error code */
|
|
|
|
|
MDBX_FIRST_LMDB_ERRCODE = MDBX_KEYEXIST,
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** key/data pair not found (EOF) */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_NOTFOUND = -30798,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Requested page not found - this usually indicates corruption */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_PAGE_NOTFOUND = -30797,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Database is corrupted (page was wrong type and so on) */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_CORRUPTED = -30796,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** Environment had fatal error,
|
|
|
|
|
* i.e. update of meta page failed and so on. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_PANIC = -30795,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** DB file version mismatch with libmdbx */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_VERSION_MISMATCH = -30794,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** File is not a valid MDBX file */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_INVALID = -30793,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Environment mapsize reached */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_MAP_FULL = -30792,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Environment maxdbs reached */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_DBS_FULL = -30791,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Environment maxreaders reached */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_READERS_FULL = -30790,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Transaction has too many dirty pages, i.e transaction too big */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_TXN_FULL = -30788,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Cursor stack too deep - this usually indicates corruption,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* i.e branch-pages loop */
|
|
|
|
|
MDBX_CURSOR_FULL = -30787,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Page has not enough space - internal error */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_PAGE_FULL = -30786,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Database engine was unable to extend mapping, e.g. since address space
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* is unavailable or busy. This can mean:
|
|
|
|
|
* - Database size extended by other process beyond to environment mapsize
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* and engine was unable to extend mapping while starting read
|
|
|
|
|
* transaction. Environment should be reopened to continue.
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* - Engine was unable to extend mapping during write transaction
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* or explicit call of \ref mdbx_env_set_geometry(). */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_UNABLE_EXTEND_MAPSIZE = -30785,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Environment or table is not compatible with the requested operation
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* or the specified flags. This can mean:
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - The operation expects an \ref MDBX_DUPSORT / \ref MDBX_DUPFIXED
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - Opening a named DB when the unnamed DB has \ref MDBX_DUPSORT /
|
|
|
|
|
* \ref MDBX_INTEGERKEY.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* - Accessing a data record as a named table, or vice versa.
|
|
|
|
|
* - The table was dropped and recreated with different flags. */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_INCOMPATIBLE = -30784,
|
2020-04-19 14:56:58 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Invalid reuse of reader locktable slot,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* e.g. read-transaction already run for current thread */
|
|
|
|
|
MDBX_BAD_RSLOT = -30783,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Transaction is not valid for requested operation,
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* e.g. had errored and be must aborted, has a child/nested transaction,
|
|
|
|
|
* or is invalid */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_BAD_TXN = -30782,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Invalid size or alignment of key or data for target table,
|
|
|
|
|
* either invalid table name */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_BAD_VALSIZE = -30781,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** The specified DBI-handle is invalid
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* or changed by another thread/transaction */
|
|
|
|
|
MDBX_BAD_DBI = -30780,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Unexpected internal error, transaction should be aborted */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_PROBLEM = -30779,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** The last LMDB-compatible defined error code */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_LAST_LMDB_ERRCODE = MDBX_PROBLEM,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Another write transaction is running or environment is already used while
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* opening with \ref MDBX_EXCLUSIVE flag */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_BUSY = -30778,
|
2020-02-01 23:38:16 +03:00
|
|
|
|
|
2020-08-22 20:19:46 +03:00
|
|
|
|
/** The first of MDBX-added error codes */
|
|
|
|
|
MDBX_FIRST_ADDED_ERRCODE = MDBX_BUSY,
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** The specified key has more than one associated value */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_EMULTIVAL = -30421,
|
2020-01-26 14:26:00 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Bad signature of a runtime object(s), this can mean:
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* - memory corruption or double-free;
|
|
|
|
|
* - ABI version mismatch (rare case); */
|
|
|
|
|
MDBX_EBADSIGN = -30420,
|
2017-02-27 21:17:22 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Database should be recovered, but this could NOT be done for now
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* since it opened in read-only mode */
|
|
|
|
|
MDBX_WANNA_RECOVERY = -30419,
|
2017-02-27 21:17:22 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** The given key value is mismatched to the current cursor position */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_EKEYMISMATCH = -30418,
|
2017-05-17 20:54:16 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Database is too large for current system,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
* e.g. could NOT be mapped into RAM. */
|
|
|
|
|
MDBX_TOO_LARGE = -30417,
|
2017-05-22 14:02:33 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** A thread has attempted to use a not owned object,
|
mdbx: переработка инициализации, проверки и импорта dbi-хендлов в транзакциях.
Ранее инициализация в транзакциях структур данных, связанных с
dbi-хендлами и subDb, выполнялась непосредственно при запуске
транзакций. Что в сценариях с большим кол-вом dbi-дексприторов (например
libfpta) порождало заметные накладные расходы, которые расли линейно от
общего кол-ва открытых subDb, а не от реально используемых в транзакции.
При использовании одной-двух сотен хендлов, при старте каждой транзакции
могли копироваться и/или обнуляться десятки килобайт. Теперь этот
недостаток устранен.
Изменена схема инициализации, валидации и импорта хендлов открытых после
старта транзакции:
1) Инициализация теперь выполняется отложенна, а при старте транзации
обнуляется только массив с однобайтовыми статустами dbi-хендлов.
При этом доступнва опция сборки `MDBX_ENABLE_DBI_SPARSE`, при активации
которой используется битовая карты, что снижает объем инициализации
при старте транзакции в 8 раз (CHAR_BIT).
2) Переработана валидация dbi-хендлов на входах API, с уменьшением кол-ва
проверок и ветвлений до теоретического минимума.
3) Переработ импорт dbi-хендов открытых после старта транзакци, теперь
при этом не захватывается мьютекс.
2023-11-05 22:10:29 +03:00
|
|
|
|
* e.g. a transaction that started by another thread */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_THREAD_MISMATCH = -30416,
|
2017-06-05 22:45:13 +03:00
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Overlapping read and write transactions for the current thread */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_TXN_OVERLAPPING = -30415,
|
2017-06-06 17:05:30 +03:00
|
|
|
|
|
2022-12-08 12:58:56 +03:00
|
|
|
|
/** Внутренняя ошибка возвращаемая в случае нехватки запаса свободных страниц
|
|
|
|
|
* при обновлении GC. Используется как вспомогательное средство для отладки.
|
|
|
|
|
* \note С точки зрения пользователя семантически
|
|
|
|
|
* равнозначна \ref MDBX_PROBLEM. */
|
|
|
|
|
MDBX_BACKLOG_DEPLETED = -30414,
|
|
|
|
|
|
2023-01-05 22:33:56 +03:00
|
|
|
|
/** Alternative/Duplicate LCK-file is exists and should be removed manually */
|
|
|
|
|
MDBX_DUPLICATED_CLK = -30413,
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Some cursors and/or other resources should be closed before table or
|
2024-10-23 13:22:53 +03:00
|
|
|
|
* corresponding DBI-handle could be (re)used and/or closed. */
|
mdbx: переработка инициализации, проверки и импорта dbi-хендлов в транзакциях.
Ранее инициализация в транзакциях структур данных, связанных с
dbi-хендлами и subDb, выполнялась непосредственно при запуске
транзакций. Что в сценариях с большим кол-вом dbi-дексприторов (например
libfpta) порождало заметные накладные расходы, которые расли линейно от
общего кол-ва открытых subDb, а не от реально используемых в транзакции.
При использовании одной-двух сотен хендлов, при старте каждой транзакции
могли копироваться и/или обнуляться десятки килобайт. Теперь этот
недостаток устранен.
Изменена схема инициализации, валидации и импорта хендлов открытых после
старта транзакции:
1) Инициализация теперь выполняется отложенна, а при старте транзации
обнуляется только массив с однобайтовыми статустами dbi-хендлов.
При этом доступнва опция сборки `MDBX_ENABLE_DBI_SPARSE`, при активации
которой используется битовая карты, что снижает объем инициализации
при старте транзакции в 8 раз (CHAR_BIT).
2) Переработана валидация dbi-хендлов на входах API, с уменьшением кол-ва
проверок и ветвлений до теоретического минимума.
3) Переработ импорт dbi-хендов открытых после старта транзакци, теперь
при этом не захватывается мьютекс.
2023-11-05 22:10:29 +03:00
|
|
|
|
MDBX_DANGLING_DBI = -30412,
|
|
|
|
|
|
2024-07-24 15:27:48 +03:00
|
|
|
|
/** The parked read transaction was outed for the sake of
|
|
|
|
|
* recycling old MVCC snapshots. */
|
2024-07-09 16:04:01 +03:00
|
|
|
|
MDBX_OUSTED = -30411,
|
|
|
|
|
|
2024-08-02 12:12:29 +03:00
|
|
|
|
/** MVCC snapshot used by read transaction is outdated and could not be
|
|
|
|
|
* copied since corresponding meta-pages was overwritten. */
|
|
|
|
|
MDBX_MVCC_RETARDED = -30410,
|
|
|
|
|
|
2020-08-22 20:19:46 +03:00
|
|
|
|
/* The last of MDBX-added error codes */
|
2024-08-02 12:12:29 +03:00
|
|
|
|
MDBX_LAST_ADDED_ERRCODE = MDBX_MVCC_RETARDED,
|
2020-08-22 20:19:46 +03:00
|
|
|
|
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64)
|
|
|
|
|
MDBX_ENODATA = ERROR_HANDLE_EOF,
|
|
|
|
|
MDBX_EINVAL = ERROR_INVALID_PARAMETER,
|
|
|
|
|
MDBX_EACCESS = ERROR_ACCESS_DENIED,
|
|
|
|
|
MDBX_ENOMEM = ERROR_OUTOFMEMORY,
|
|
|
|
|
MDBX_EROFS = ERROR_FILE_READ_ONLY,
|
|
|
|
|
MDBX_ENOSYS = ERROR_NOT_SUPPORTED,
|
|
|
|
|
MDBX_EIO = ERROR_WRITE_FAULT,
|
|
|
|
|
MDBX_EPERM = ERROR_INVALID_FUNCTION,
|
|
|
|
|
MDBX_EINTR = ERROR_CANCELLED,
|
|
|
|
|
MDBX_ENOFILE = ERROR_FILE_NOT_FOUND,
|
2023-11-03 14:11:58 +03:00
|
|
|
|
MDBX_EREMOTE = ERROR_REMOTE_STORAGE_MEDIA_ERROR,
|
|
|
|
|
MDBX_EDEADLK = ERROR_POSSIBLE_DEADLOCK
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#else /* Windows */
|
|
|
|
|
#ifdef ENODATA
|
|
|
|
|
MDBX_ENODATA = ENODATA,
|
|
|
|
|
#else
|
2021-11-22 16:05:31 +03:00
|
|
|
|
MDBX_ENODATA = 9919 /* for compatibility with LLVM's C++ libraries/headers */,
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#endif /* ENODATA */
|
|
|
|
|
MDBX_EINVAL = EINVAL,
|
|
|
|
|
MDBX_EACCESS = EACCES,
|
|
|
|
|
MDBX_ENOMEM = ENOMEM,
|
|
|
|
|
MDBX_EROFS = EROFS,
|
|
|
|
|
MDBX_ENOSYS = ENOSYS,
|
|
|
|
|
MDBX_EIO = EIO,
|
|
|
|
|
MDBX_EPERM = EPERM,
|
|
|
|
|
MDBX_EINTR = EINTR,
|
|
|
|
|
MDBX_ENOFILE = ENOENT,
|
2023-11-03 14:11:58 +03:00
|
|
|
|
MDBX_EREMOTE = ENOTBLK,
|
|
|
|
|
MDBX_EDEADLK = EDEADLK
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#endif /* !Windows */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_error_t;
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/** MDBX_MAP_RESIZED
|
|
|
|
|
* \ingroup c_err
|
|
|
|
|
* \deprecated Please review your code to use MDBX_UNABLE_EXTEND_MAPSIZE
|
|
|
|
|
* instead. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DEPRECATED static __inline int MDBX_MAP_RESIZED_is_deprecated(void) { return MDBX_UNABLE_EXTEND_MAPSIZE; }
|
2020-07-08 02:26:46 +03:00
|
|
|
|
#define MDBX_MAP_RESIZED MDBX_MAP_RESIZED_is_deprecated()
|
2020-02-01 23:39:39 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return a string describing a given error code.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_err
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* This function is a superset of the ANSI C X3.159-1989 (ANSI C) `strerror()`
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* function. If the error code is greater than or equal to 0, then the string
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* returned by the system function `strerror()` is returned. If the error code
|
2017-05-24 01:42:10 +03:00
|
|
|
|
* is less than 0, an error string corresponding to the MDBX library error is
|
2017-04-26 18:12:48 +03:00
|
|
|
|
* returned. See errors for a list of MDBX-specific error codes.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `mdbx_strerror()` is NOT thread-safe because may share common internal buffer
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* for system messages. The returned string must NOT be modified by the
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* application, but MAY be modified by a subsequent call to
|
|
|
|
|
* \ref mdbx_strerror(), `strerror()` and other related functions.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \see mdbx_strerror_r()
|
2019-09-15 17:16:31 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] errnum The error code.
|
2019-09-15 17:16:31 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns "error message" The description of the error. */
|
2017-03-16 18:09:27 +03:00
|
|
|
|
LIBMDBX_API const char *mdbx_strerror(int errnum);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return a string describing a given error code.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_err
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* This function is a superset of the ANSI C X3.159-1989 (ANSI C) `strerror()`
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* function. If the error code is greater than or equal to 0, then the string
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* returned by the system function `strerror()` is returned. If the error code
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* is less than 0, an error string corresponding to the MDBX library error is
|
|
|
|
|
* returned. See errors for a list of MDBX-specific error codes.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* `mdbx_strerror_r()` is thread-safe since uses user-supplied buffer where
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* appropriate. The returned string must NOT be modified by the application,
|
|
|
|
|
* since it may be pointer to internal constant string. However, there is no
|
|
|
|
|
* restriction if the returned string points to the supplied buffer.
|
|
|
|
|
* \see mdbx_strerror()
|
|
|
|
|
*
|
2020-08-22 20:19:46 +03:00
|
|
|
|
* mdbx_liberr2str() returns string describing only MDBX error numbers but NULL
|
|
|
|
|
* for non-MDBX error codes. This function is thread-safe since return pointer
|
|
|
|
|
* to constant non-localized strings.
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] errnum The error code.
|
|
|
|
|
* \param [in,out] buf Buffer to store the error message.
|
|
|
|
|
* \param [in] buflen The size of buffer to store the message.
|
|
|
|
|
*
|
|
|
|
|
* \returns "error message" The description of the error. */
|
2017-03-16 18:09:27 +03:00
|
|
|
|
LIBMDBX_API const char *mdbx_strerror_r(int errnum, char *buf, size_t buflen);
|
2020-09-14 16:40:46 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API const char *mdbx_liberr2str(int errnum);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
|
|
|
|
/** Bit of Windows' madness. The similar to \ref mdbx_strerror() but returns
|
|
|
|
|
* Windows error-messages in the OEM-encoding for console utilities.
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_err
|
|
|
|
|
* \see mdbx_strerror_r_ANSI2OEM() */
|
2019-08-28 17:12:32 +03:00
|
|
|
|
LIBMDBX_API const char *mdbx_strerror_ANSI2OEM(int errnum);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** Bit of Windows' madness. The similar to \ref mdbx_strerror_r() but returns
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* Windows error-messages in the OEM-encoding for console utilities.
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_err
|
|
|
|
|
* \see mdbx_strerror_ANSI2OEM() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API const char *mdbx_strerror_r_ANSI2OEM(int errnum, char *buf, size_t buflen);
|
2019-09-15 17:16:31 +03:00
|
|
|
|
#endif /* Bit of Windows' madness */
|
2019-08-28 17:12:32 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Create an MDBX environment instance.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_opening
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* This function allocates memory for a \ref MDBX_env structure. To release
|
|
|
|
|
* the allocated memory and discard the handle, call \ref mdbx_env_close().
|
|
|
|
|
* Before the handle may be used, it must be opened using \ref mdbx_env_open().
|
2019-09-15 17:16:31 +03:00
|
|
|
|
*
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* Various other options may also need to be set before opening the handle,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* e.g. \ref mdbx_env_set_geometry(), \ref mdbx_env_set_maxreaders(),
|
|
|
|
|
* \ref mdbx_env_set_maxdbs(), depending on usage requirements.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] penv The address where the new handle will be stored.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns a non-zero error value on failure and 0 on success. */
|
2017-05-24 01:42:10 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_create(MDBX_env **penv);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2023-03-01 23:18:09 +03:00
|
|
|
|
/** \brief MDBX environment extra runtime options.
|
|
|
|
|
* \ingroup c_settings
|
|
|
|
|
* \see mdbx_env_set_option() \see mdbx_env_get_option() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_option {
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Controls the maximum number of named tables for the environment.
|
2020-12-08 00:01:29 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \details By default only unnamed key-value table could used and
|
2020-12-08 00:01:29 +03:00
|
|
|
|
* appropriate value should set by `MDBX_opt_max_db` to using any more named
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table(s). To reduce overhead, use the minimum sufficient value. This option
|
2020-12-08 00:01:29 +03:00
|
|
|
|
* may only set after \ref mdbx_env_create() and before \ref mdbx_env_open().
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_env_set_maxdbs() \see mdbx_env_get_maxdbs() */
|
|
|
|
|
MDBX_opt_max_db,
|
|
|
|
|
|
|
|
|
|
/** \brief Defines the maximum number of threads/reader slots
|
|
|
|
|
* for all processes interacting with the database.
|
|
|
|
|
*
|
|
|
|
|
* \details This defines the number of slots in the lock table that is used to
|
2024-12-06 22:15:23 +03:00
|
|
|
|
* track readers in the environment. The default is about 100 for 4K
|
2020-12-08 00:01:29 +03:00
|
|
|
|
* system page size. Starting a read-only transaction normally ties a lock
|
|
|
|
|
* table slot to the current thread until the environment closes or the thread
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* exits. If \ref MDBX_NOSTICKYTHREADS is in use, \ref mdbx_txn_begin()
|
|
|
|
|
* instead ties the slot to the \ref MDBX_txn object until it or the \ref
|
|
|
|
|
* MDBX_env object is destroyed. This option may only set after \ref
|
|
|
|
|
* mdbx_env_create() and before \ref mdbx_env_open(), and has an effect only
|
|
|
|
|
* when the database is opened by the first process interacts with the
|
|
|
|
|
* database.
|
2020-12-08 00:01:29 +03:00
|
|
|
|
*
|
|
|
|
|
* \see mdbx_env_set_maxreaders() \see mdbx_env_get_maxreaders() */
|
2020-10-20 14:29:06 +03:00
|
|
|
|
MDBX_opt_max_readers,
|
2020-11-21 17:22:28 +03:00
|
|
|
|
|
2020-12-08 00:01:29 +03:00
|
|
|
|
/** \brief Controls interprocess/shared threshold to force flush the data
|
|
|
|
|
* buffers to disk, if \ref MDBX_SAFE_NOSYNC is used.
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_env_set_syncbytes() \see mdbx_env_get_syncbytes() */
|
|
|
|
|
MDBX_opt_sync_bytes,
|
2020-11-21 17:53:17 +03:00
|
|
|
|
|
2020-12-08 00:01:29 +03:00
|
|
|
|
/** \brief Controls interprocess/shared relative period since the last
|
|
|
|
|
* unsteady commit to force flush the data buffers to disk,
|
|
|
|
|
* if \ref MDBX_SAFE_NOSYNC is used.
|
|
|
|
|
* \see mdbx_env_set_syncperiod() \see mdbx_env_get_syncperiod() */
|
|
|
|
|
MDBX_opt_sync_period,
|
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process limit to grow a list of reclaimed/recycled
|
|
|
|
|
* page's numbers for finding a sequence of contiguous pages for large data
|
|
|
|
|
* items.
|
2023-11-29 00:35:25 +03:00
|
|
|
|
* \see MDBX_opt_gc_time_limit
|
2020-12-08 00:01:29 +03:00
|
|
|
|
*
|
|
|
|
|
* \details A long values requires allocation of contiguous database pages.
|
|
|
|
|
* To find such sequences, it may be necessary to accumulate very large lists,
|
|
|
|
|
* especially when placing very long values (more than a megabyte) in a large
|
|
|
|
|
* databases (several tens of gigabytes), which is much expensive in extreme
|
|
|
|
|
* cases. This threshold allows you to avoid such costs by allocating new
|
|
|
|
|
* pages at the end of the database (with its possible growth on disk),
|
|
|
|
|
* instead of further accumulating/reclaiming Garbage Collection records.
|
|
|
|
|
*
|
|
|
|
|
* On the other hand, too small threshold will lead to unreasonable database
|
|
|
|
|
* growth, or/and to the inability of put long values.
|
|
|
|
|
*
|
|
|
|
|
* The `MDBX_opt_rp_augment_limit` controls described limit for the current
|
2023-11-28 21:33:57 +03:00
|
|
|
|
* process. By default this limit adjusted dynamically to 1/3 of current
|
|
|
|
|
* quantity of DB pages, which is usually enough for most cases. */
|
2020-11-21 17:53:17 +03:00
|
|
|
|
MDBX_opt_rp_augment_limit,
|
2020-12-02 21:33:30 +03:00
|
|
|
|
|
2021-01-22 23:52:03 +03:00
|
|
|
|
/** \brief Controls the in-process limit to grow a cache of dirty
|
|
|
|
|
* pages for reuse in the current transaction.
|
|
|
|
|
*
|
|
|
|
|
* \details A 'dirty page' refers to a page that has been updated in memory
|
|
|
|
|
* only, the changes to a dirty page are not yet stored on disk.
|
|
|
|
|
* To reduce overhead, it is reasonable to release not all such pages
|
|
|
|
|
* immediately, but to leave some ones in cache for reuse in the current
|
|
|
|
|
* transaction.
|
|
|
|
|
*
|
|
|
|
|
* The `MDBX_opt_loose_limit` allows you to set a limit for such cache inside
|
|
|
|
|
* the current process. Should be in the range 0..255, default is 64. */
|
|
|
|
|
MDBX_opt_loose_limit,
|
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process limit of a pre-allocated memory items
|
|
|
|
|
* for dirty pages.
|
2020-12-08 00:01:29 +03:00
|
|
|
|
*
|
|
|
|
|
* \details A 'dirty page' refers to a page that has been updated in memory
|
|
|
|
|
* only, the changes to a dirty page are not yet stored on disk.
|
|
|
|
|
* Without \ref MDBX_WRITEMAP dirty pages are allocated from memory and
|
|
|
|
|
* released when a transaction is committed. To reduce overhead, it is
|
2021-01-22 23:52:03 +03:00
|
|
|
|
* reasonable to release not all ones, but to leave some allocations in
|
|
|
|
|
* reserve for reuse in the next transaction(s).
|
2020-12-08 00:01:29 +03:00
|
|
|
|
*
|
2021-01-22 23:52:03 +03:00
|
|
|
|
* The `MDBX_opt_dp_reserve_limit` allows you to set a limit for such reserve
|
|
|
|
|
* inside the current process. Default is 1024. */
|
2020-12-08 00:01:29 +03:00
|
|
|
|
MDBX_opt_dp_reserve_limit,
|
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process limit of dirty pages
|
|
|
|
|
* for a write transaction.
|
|
|
|
|
*
|
|
|
|
|
* \details A 'dirty page' refers to a page that has been updated in memory
|
|
|
|
|
* only, the changes to a dirty page are not yet stored on disk.
|
|
|
|
|
* Without \ref MDBX_WRITEMAP dirty pages are allocated from memory and will
|
|
|
|
|
* be busy until are written to disk. Therefore for a large transactions is
|
|
|
|
|
* reasonable to limit dirty pages collecting above an some threshold but
|
|
|
|
|
* spill to disk instead.
|
|
|
|
|
*
|
|
|
|
|
* The `MDBX_opt_txn_dp_limit` controls described threshold for the current
|
2021-01-22 23:15:08 +03:00
|
|
|
|
* process. Default is 65536, it is usually enough for most cases. */
|
2020-12-02 21:33:30 +03:00
|
|
|
|
MDBX_opt_txn_dp_limit,
|
2020-12-08 00:01:29 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process initial allocation size for dirty pages
|
|
|
|
|
* list of a write transaction. Default is 1024. */
|
2020-12-02 21:33:30 +03:00
|
|
|
|
MDBX_opt_txn_dp_initial,
|
2021-01-22 17:25:44 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process how maximal part of the dirty pages may be
|
|
|
|
|
* spilled when necessary.
|
|
|
|
|
*
|
|
|
|
|
* \details The `MDBX_opt_spill_max_denominator` defines the denominator for
|
|
|
|
|
* limiting from the top for part of the current dirty pages may be spilled
|
|
|
|
|
* when the free room for a new dirty pages (i.e. distance to the
|
|
|
|
|
* `MDBX_opt_txn_dp_limit` threshold) is not enough to perform requested
|
|
|
|
|
* operation.
|
|
|
|
|
* Exactly `max_pages_to_spill = dirty_pages - dirty_pages / N`,
|
|
|
|
|
* where `N` is the value set by `MDBX_opt_spill_max_denominator`.
|
|
|
|
|
*
|
|
|
|
|
* Should be in the range 0..255, where zero means no limit, i.e. all dirty
|
|
|
|
|
* pages could be spilled. Default is 8, i.e. no more than 7/8 of the current
|
|
|
|
|
* dirty pages may be spilled when reached the condition described above. */
|
|
|
|
|
MDBX_opt_spill_max_denominator,
|
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process how minimal part of the dirty pages should
|
|
|
|
|
* be spilled when necessary.
|
|
|
|
|
*
|
|
|
|
|
* \details The `MDBX_opt_spill_min_denominator` defines the denominator for
|
|
|
|
|
* limiting from the bottom for part of the current dirty pages should be
|
|
|
|
|
* spilled when the free room for a new dirty pages (i.e. distance to the
|
|
|
|
|
* `MDBX_opt_txn_dp_limit` threshold) is not enough to perform requested
|
|
|
|
|
* operation.
|
|
|
|
|
* Exactly `min_pages_to_spill = dirty_pages / N`,
|
|
|
|
|
* where `N` is the value set by `MDBX_opt_spill_min_denominator`.
|
|
|
|
|
*
|
|
|
|
|
* Should be in the range 0..255, where zero means no restriction at the
|
|
|
|
|
* bottom. Default is 8, i.e. at least the 1/8 of the current dirty pages
|
|
|
|
|
* should be spilled when reached the condition described above. */
|
|
|
|
|
MDBX_opt_spill_min_denominator,
|
2021-01-22 18:18:52 +03:00
|
|
|
|
|
2021-01-23 01:13:20 +03:00
|
|
|
|
/** \brief Controls the in-process how much of the parent transaction dirty
|
2021-01-22 18:18:52 +03:00
|
|
|
|
* pages will be spilled while start each child transaction.
|
|
|
|
|
*
|
|
|
|
|
* \details The `MDBX_opt_spill_parent4child_denominator` defines the
|
2021-01-23 01:13:20 +03:00
|
|
|
|
* denominator to determine how much of parent transaction dirty pages will be
|
2021-01-22 18:18:52 +03:00
|
|
|
|
* spilled explicitly while start each child transaction.
|
|
|
|
|
* Exactly `pages_to_spill = dirty_pages / N`,
|
|
|
|
|
* where `N` is the value set by `MDBX_opt_spill_parent4child_denominator`.
|
|
|
|
|
*
|
|
|
|
|
* For a stack of nested transactions each dirty page could be spilled only
|
|
|
|
|
* once, and parent's dirty pages couldn't be spilled while child
|
|
|
|
|
* transaction(s) are running. Therefore a child transaction could reach
|
|
|
|
|
* \ref MDBX_TXN_FULL when parent(s) transaction has spilled too less (and
|
|
|
|
|
* child reach the limit of dirty pages), either when parent(s) has spilled
|
|
|
|
|
* too more (since child can't spill already spilled pages). So there is no
|
|
|
|
|
* universal golden ratio.
|
|
|
|
|
*
|
|
|
|
|
* Should be in the range 0..255, where zero means no explicit spilling will
|
|
|
|
|
* be performed during starting nested transactions.
|
|
|
|
|
* Default is 0, i.e. by default no spilling performed during starting nested
|
|
|
|
|
* transactions, that correspond historically behaviour. */
|
|
|
|
|
MDBX_opt_spill_parent4child_denominator,
|
2021-05-06 02:05:33 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process threshold of semi-empty pages merge.
|
|
|
|
|
* \details This option controls the in-process threshold of minimum page
|
|
|
|
|
* fill, as used space of percentage of a page. Neighbour pages emptier than
|
|
|
|
|
* this value are candidates for merging. The threshold value is specified
|
2024-05-19 22:07:58 +03:00
|
|
|
|
* in 1/65536 points of a whole page, which is equivalent to the 16-dot-16
|
|
|
|
|
* fixed point format.
|
|
|
|
|
* The specified value must be in the range from 12.5% (almost empty page)
|
|
|
|
|
* to 50% (half empty page) which corresponds to the range from 8192 and
|
|
|
|
|
* to 32768 in units respectively.
|
2024-04-05 00:08:09 +03:00
|
|
|
|
* \see MDBX_opt_prefer_waf_insteadof_balance */
|
2021-05-06 02:05:33 +03:00
|
|
|
|
MDBX_opt_merge_threshold_16dot16_percent,
|
2022-12-03 14:55:38 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Controls the choosing between use write-through disk writes and
|
|
|
|
|
* usual ones with followed flush by the `fdatasync()` syscall.
|
|
|
|
|
* \details Depending on the operating system, storage subsystem
|
|
|
|
|
* characteristics and the use case, higher performance can be achieved by
|
|
|
|
|
* either using write-through or a serie of usual/lazy writes followed by
|
|
|
|
|
* the flush-to-disk.
|
|
|
|
|
*
|
|
|
|
|
* Basically for N chunks the latency/cost of write-through is:
|
|
|
|
|
* latency = N * (emit + round-trip-to-storage + storage-execution);
|
|
|
|
|
* And for serie of lazy writes with flush is:
|
|
|
|
|
* latency = N * (emit + storage-execution) + flush + round-trip-to-storage.
|
|
|
|
|
*
|
|
|
|
|
* So, for large N and/or noteable round-trip-to-storage the write+flush
|
|
|
|
|
* approach is win. But for small N and/or near-zero NVMe-like latency
|
|
|
|
|
* the write-through is better.
|
|
|
|
|
*
|
|
|
|
|
* To solve this issue libmdbx provide `MDBX_opt_writethrough_threshold`:
|
|
|
|
|
* - when N described above less or equal specified threshold,
|
|
|
|
|
* a write-through approach will be used;
|
|
|
|
|
* - otherwise, when N great than specified threshold,
|
|
|
|
|
* a write-and-flush approach will be used.
|
|
|
|
|
*
|
|
|
|
|
* \note MDBX_opt_writethrough_threshold affects only \ref MDBX_SYNC_DURABLE
|
|
|
|
|
* mode without \ref MDBX_WRITEMAP, and not supported on Windows.
|
|
|
|
|
* On Windows a write-through is used always but \ref MDBX_NOMETASYNC could
|
|
|
|
|
* be used for switching to write-and-flush. */
|
|
|
|
|
MDBX_opt_writethrough_threshold,
|
2022-12-12 15:23:47 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Controls prevention of page-faults of reclaimed and allocated pages
|
|
|
|
|
* in the \ref MDBX_WRITEMAP mode by clearing ones through file handle before
|
|
|
|
|
* touching. */
|
|
|
|
|
MDBX_opt_prefault_write_enable,
|
2023-11-29 00:35:25 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Controls the in-process spending time limit of searching
|
|
|
|
|
* consecutive pages inside GC.
|
|
|
|
|
* \see MDBX_opt_rp_augment_limit
|
|
|
|
|
*
|
|
|
|
|
* \details Задаёт ограничение времени в 1/65536 долях секунды, которое может
|
|
|
|
|
* быть потрачено в ходе пишущей транзакции на поиск последовательностей
|
|
|
|
|
* страниц внутри GC/freelist после достижения ограничения задаваемого опцией
|
|
|
|
|
* \ref MDBX_opt_rp_augment_limit. Контроль по времени не выполняется при
|
|
|
|
|
* поиске/выделении одиночных страниц и выделении страниц под нужды GC (при
|
|
|
|
|
* обновлении GC в ходе фиксации транзакции).
|
|
|
|
|
*
|
|
|
|
|
* Задаваемый лимит времени исчисляется по "настенным часам" и контролируется
|
|
|
|
|
* в рамках транзакции, наследуется для вложенных транзакций и с
|
|
|
|
|
* аккумулированием в родительской при их фиксации. Контроль по времени
|
|
|
|
|
* производится только при достижении ограничения задаваемого опцией \ref
|
|
|
|
|
* MDBX_opt_rp_augment_limit. Это позволяет гибко управлять поведением
|
|
|
|
|
* используя обе опции.
|
|
|
|
|
*
|
|
|
|
|
* По умолчанию ограничение устанавливается в 0, что приводит к
|
|
|
|
|
* незамедлительной остановке поиска в GC при достижении \ref
|
|
|
|
|
* MDBX_opt_rp_augment_limit во внутреннем состоянии транзакции и
|
|
|
|
|
* соответствует поведению до появления опции `MDBX_opt_gc_time_limit`.
|
|
|
|
|
* С другой стороны, при минимальном значении (включая 0)
|
|
|
|
|
* `MDBX_opt_rp_augment_limit` переработка GC будет ограничиваться
|
|
|
|
|
* преимущественно затраченным временем. */
|
2024-04-05 00:08:09 +03:00
|
|
|
|
MDBX_opt_gc_time_limit,
|
|
|
|
|
|
|
|
|
|
/** \brief Управляет выбором между стремлением к равномерности наполнения
|
|
|
|
|
* страниц, либо уменьшением количества измененных и записанных страниц.
|
|
|
|
|
*
|
|
|
|
|
* \details После операций удаления страницы содержащие меньше минимума
|
|
|
|
|
* ключей, либо опустошенные до \ref MDBX_opt_merge_threshold_16dot16_percent
|
|
|
|
|
* подлежат слиянию с одной из соседних. Если страницы справа и слева от
|
|
|
|
|
* текущей обе «грязные» (были изменены в ходе транзакции и должны быть
|
|
|
|
|
* записаны на диск), либо обе «чисты» (не изменялись в текущей транзакции),
|
|
|
|
|
* то целью для слияния всегда выбирается менее заполненная страница.
|
|
|
|
|
* Когда же только одна из соседствующих является «грязной», а другая
|
|
|
|
|
* «чистой», то возможны две тактики выбора цели для слияния:
|
|
|
|
|
*
|
|
|
|
|
* - Если `MDBX_opt_prefer_waf_insteadof_balance = True`, то будет выбрана
|
|
|
|
|
* уже измененная страница, что НЕ УВЕЛИЧИТ количество измененных страниц
|
|
|
|
|
* и объем записи на диск при фиксации текущей транзакции, но в среднем
|
|
|
|
|
* будет УВЕЛИЧИВАТЬ неравномерность заполнения страниц.
|
|
|
|
|
*
|
|
|
|
|
* - Если `MDBX_opt_prefer_waf_insteadof_balance = False`, то будет выбрана
|
|
|
|
|
* менее заполненная страница, что УВЕЛИЧИТ количество измененных страниц
|
|
|
|
|
* и объем записи на диск при фиксации текущей транзакции, но в среднем
|
|
|
|
|
* будет УМЕНЬШАТЬ неравномерность заполнения страниц.
|
|
|
|
|
*
|
|
|
|
|
* \see MDBX_opt_merge_threshold_16dot16_percent */
|
2024-05-20 14:36:50 +03:00
|
|
|
|
MDBX_opt_prefer_waf_insteadof_balance,
|
|
|
|
|
|
|
|
|
|
/** \brief Задаёт в % максимальный размер вложенных страниц, используемых для
|
|
|
|
|
* размещения небольшого количества мульти-значений связанных с одном ключем.
|
|
|
|
|
*
|
|
|
|
|
* Использование вложенных страниц, вместо выноса значений на отдельные
|
|
|
|
|
* страницы вложенного дерева, позволяет уменьшить объем неиспользуемого места
|
|
|
|
|
* и этим увеличить плотность размещения данных.
|
|
|
|
|
*
|
|
|
|
|
* Но с увеличением размера вложенных страниц требуется больше листовых
|
|
|
|
|
* страниц основного дерева, что также увеличивает высоту основного дерева.
|
|
|
|
|
* Кроме этого, изменение данных на вложенных страницах требует дополнительных
|
|
|
|
|
* копирований, поэтому стоимость может быть больше во многих сценариях.
|
|
|
|
|
*
|
|
|
|
|
* min 12.5% (8192), max 100% (65535), default = 100% */
|
|
|
|
|
MDBX_opt_subpage_limit,
|
|
|
|
|
|
|
|
|
|
/** \brief Задаёт в % минимальный объём свободного места на основной странице,
|
|
|
|
|
* при отсутствии которого вложенные страницы выносятся в отдельное дерево.
|
|
|
|
|
*
|
|
|
|
|
* min 0, max 100% (65535), default = 0 */
|
|
|
|
|
MDBX_opt_subpage_room_threshold,
|
|
|
|
|
|
|
|
|
|
/** \brief Задаёт в % минимальный объём свободного места на основной странице,
|
|
|
|
|
* при наличии которого, производится резервирование места во вложенной.
|
|
|
|
|
*
|
|
|
|
|
* Если на основной странице свободного места недостаточно, то вложенная
|
|
|
|
|
* страница будет минимального размера. В свою очередь, при отсутствии резерва
|
|
|
|
|
* во вложенной странице, каждое добавлении в неё элементов будет требовать
|
|
|
|
|
* переформирования основной страниц с переносом всех узлов данных.
|
|
|
|
|
*
|
|
|
|
|
* Поэтому резервирование места, как правило, выгодно в сценариях с
|
|
|
|
|
* интенсивным добавлением коротких мульти-значений, например при
|
|
|
|
|
* индексировании. Но уменьшает плотность размещения данных, соответственно
|
|
|
|
|
* увеличивает объем БД и операций ввода-вывода.
|
|
|
|
|
*
|
|
|
|
|
* min 0, max 100% (65535), default = 42% (27525) */
|
|
|
|
|
MDBX_opt_subpage_reserve_prereq,
|
|
|
|
|
|
|
|
|
|
/** \brief Задаёт в % ограничение резервирования места на вложенных страницах.
|
|
|
|
|
*
|
|
|
|
|
* min 0, max 100% (65535), default = 4.2% (2753) */
|
|
|
|
|
MDBX_opt_subpage_reserve_limit
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_option_t;
|
2020-10-20 14:29:06 +03:00
|
|
|
|
|
2023-03-01 23:18:09 +03:00
|
|
|
|
/** \brief Sets the value of a extra runtime options for an environment.
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_settings
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
|
|
|
|
* \param [in] option The option from \ref MDBX_option_t to set value of it.
|
|
|
|
|
* \param [in] value The value of option to be set.
|
|
|
|
|
*
|
|
|
|
|
* \see MDBX_option_t
|
|
|
|
|
* \see mdbx_env_get_option()
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64_t value);
|
2021-05-03 14:19:34 +03:00
|
|
|
|
|
2023-03-01 23:18:09 +03:00
|
|
|
|
/** \brief Gets the value of extra runtime options from an environment.
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_settings
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
|
|
|
|
* \param [in] option The option from \ref MDBX_option_t to get value of it.
|
|
|
|
|
* \param [out] pvalue The address where the option's value will be stored.
|
|
|
|
|
*
|
|
|
|
|
* \see MDBX_option_t
|
|
|
|
|
* \see mdbx_env_get_option()
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_get_option(const MDBX_env *env, const MDBX_option_t option, uint64_t *pvalue);
|
2020-10-20 14:29:06 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Open an environment instance.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_opening
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Indifferently this function will fails or not, the \ref mdbx_env_close() must
|
|
|
|
|
* be called later to discard the \ref MDBX_env handle and release associated
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* resources.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note On Windows the \ref mdbx_env_openW() is recommended to use.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create()
|
|
|
|
|
*
|
2020-10-09 17:39:21 +03:00
|
|
|
|
* \param [in] pathname The pathname for the database or the directory in which
|
|
|
|
|
* the database files reside. In the case of directory it
|
|
|
|
|
* must already exist and be writable.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
*
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* \param [in] flags Specifies options for this environment.
|
|
|
|
|
* This parameter must be bitwise OR'ing together
|
|
|
|
|
* any constants described above in the \ref env_flags
|
|
|
|
|
* and \ref sync_modes sections.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
|
|
|
|
* Flags set by mdbx_env_set_flags() are also used:
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* - \ref MDBX_ENV_DEFAULTS, \ref MDBX_NOSUBDIR, \ref MDBX_RDONLY,
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* \ref MDBX_EXCLUSIVE, \ref MDBX_WRITEMAP, \ref MDBX_NOSTICKYTHREADS,
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* \ref MDBX_NORDAHEAD, \ref MDBX_NOMEMINIT, \ref MDBX_COALESCE,
|
|
|
|
|
* \ref MDBX_LIFORECLAIM. See \ref env_flags section.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* - \ref MDBX_SYNC_DURABLE, \ref MDBX_NOMETASYNC, \ref MDBX_SAFE_NOSYNC,
|
|
|
|
|
* \ref MDBX_UTTERLY_NOSYNC. See \ref sync_modes section.
|
2019-09-15 17:16:31 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \note `MDB_NOLOCK` flag don't supported by MDBX,
|
|
|
|
|
* try use \ref MDBX_EXCLUSIVE as a replacement.
|
2019-09-15 17:16:31 +03:00
|
|
|
|
*
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* \note MDBX don't allow to mix processes with different \ref MDBX_SAFE_NOSYNC
|
|
|
|
|
* flags on the same environment.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* In such case \ref MDBX_INCOMPATIBLE will be returned.
|
2019-09-15 17:16:31 +03:00
|
|
|
|
*
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* If the database is already exist and parameters specified early by
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref mdbx_env_set_geometry() are incompatible (i.e. for instance, different
|
|
|
|
|
* page size) then \ref mdbx_env_open() will return \ref MDBX_INCOMPATIBLE
|
|
|
|
|
* error.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] mode The UNIX permissions to set on created files.
|
|
|
|
|
* Zero value means to open existing, but do not create.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \return A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \retval MDBX_VERSION_MISMATCH The version of the MDBX library doesn't match
|
|
|
|
|
* the version that created the database environment.
|
|
|
|
|
* \retval MDBX_INVALID The environment file headers are corrupted.
|
|
|
|
|
* \retval MDBX_ENOENT The directory specified by the path parameter
|
|
|
|
|
* doesn't exist.
|
|
|
|
|
* \retval MDBX_EACCES The user didn't have permission to access
|
|
|
|
|
* the environment files.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \retval MDBX_BUSY The \ref MDBX_EXCLUSIVE flag was specified and the
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* environment is in use by another process,
|
|
|
|
|
* or the current process tries to open environment
|
|
|
|
|
* more than once.
|
|
|
|
|
* \retval MDBX_INCOMPATIBLE Environment is already opened by another process,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* but with different set of \ref MDBX_SAFE_NOSYNC,
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* \ref MDBX_UTTERLY_NOSYNC flags.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* Or if the database is already exist and parameters
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* specified early by \ref mdbx_env_set_geometry()
|
|
|
|
|
* are incompatible (i.e. different pagesize, etc).
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_WANNA_RECOVERY The \ref MDBX_RDONLY flag was specified but
|
|
|
|
|
* read-write access is required to rollback
|
|
|
|
|
* inconsistent state after a system crash.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_TOO_LARGE Database is too large for this process,
|
|
|
|
|
* i.e. 32-bit process tries to open >4Gb database.
|
|
|
|
|
*/
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_open(MDBX_env *env, const char *pathname, MDBX_env_flags_t flags, mdbx_mode_t mode);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2023-02-09 20:02:17 +03:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
|
|
|
|
/** \copydoc mdbx_env_open()
|
|
|
|
|
* \note Available only on Windows.
|
|
|
|
|
* \see mdbx_env_open() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_openW(MDBX_env *env, const wchar_t *pathname, MDBX_env_flags_t flags, mdbx_mode_t mode);
|
|
|
|
|
#define mdbx_env_openT(env, pathname, flags, mode) mdbx_env_openW(env, pathname, flags, mode)
|
2024-10-23 19:12:31 +03:00
|
|
|
|
#else
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define mdbx_env_openT(env, pathname, flags, mode) mdbx_env_open(env, pathname, flags, mode)
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* Windows */
|
|
|
|
|
|
2020-10-10 18:30:21 +03:00
|
|
|
|
/** \brief Deletion modes for \ref mdbx_env_delete().
|
2020-10-09 22:43:14 +03:00
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
* \see mdbx_env_delete() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_env_delete_mode {
|
2020-10-09 22:43:14 +03:00
|
|
|
|
/** \brief Just delete the environment's files and directory if any.
|
|
|
|
|
* \note On POSIX systems, processes already working with the database will
|
|
|
|
|
* continue to work without interference until it close the environment.
|
2024-03-21 23:15:11 +03:00
|
|
|
|
* \note On Windows, the behavior of `MDBX_ENV_JUST_DELETE` is different
|
2020-10-09 22:43:14 +03:00
|
|
|
|
* because the system does not support deleting files that are currently
|
|
|
|
|
* memory mapped. */
|
|
|
|
|
MDBX_ENV_JUST_DELETE = 0,
|
2020-10-10 18:30:21 +03:00
|
|
|
|
/** \brief Make sure that the environment is not being used by other
|
|
|
|
|
* processes, or return an error otherwise. */
|
2020-10-09 22:43:14 +03:00
|
|
|
|
MDBX_ENV_ENSURE_UNUSED = 1,
|
2020-10-10 18:30:21 +03:00
|
|
|
|
/** \brief Wait until other processes closes the environment before deletion.
|
|
|
|
|
*/
|
2020-10-09 22:43:14 +03:00
|
|
|
|
MDBX_ENV_WAIT_FOR_UNUSED = 2,
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_env_delete_mode_t;
|
2020-10-09 22:43:14 +03:00
|
|
|
|
|
2020-10-10 18:30:21 +03:00
|
|
|
|
/** \brief Delete the environment's files in a proper and multiprocess-safe way.
|
2020-10-09 22:43:14 +03:00
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
*
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note On Windows the \ref mdbx_env_deleteW() is recommended to use.
|
|
|
|
|
*
|
2020-10-09 22:43:14 +03:00
|
|
|
|
* \param [in] pathname The pathname for the database or the directory in which
|
|
|
|
|
* the database files reside.
|
|
|
|
|
*
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* \param [in] mode Specifies deletion mode for the environment. This
|
|
|
|
|
* parameter must be set to one of the constants described
|
2020-10-09 22:43:14 +03:00
|
|
|
|
* above in the \ref MDBX_env_delete_mode_t section.
|
|
|
|
|
*
|
|
|
|
|
* \note The \ref MDBX_ENV_JUST_DELETE don't supported on Windows since system
|
|
|
|
|
* unable to delete a memory-mapped files.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_RESULT_TRUE No corresponding files or directories were found,
|
|
|
|
|
* so no deletion was performed. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_delete(const char *pathname, MDBX_env_delete_mode_t mode);
|
2023-02-09 20:02:17 +03:00
|
|
|
|
|
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
|
|
|
|
/** \copydoc mdbx_env_delete()
|
2024-08-03 12:48:23 +03:00
|
|
|
|
* \ingroup c_extra
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note Available only on Windows.
|
|
|
|
|
* \see mdbx_env_delete() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_deleteW(const wchar_t *pathname, MDBX_env_delete_mode_t mode);
|
2024-10-23 19:12:31 +03:00
|
|
|
|
#define mdbx_env_deleteT(pathname, mode) mdbx_env_deleteW(pathname, mode)
|
|
|
|
|
#else
|
|
|
|
|
#define mdbx_env_deleteT(pathname, mode) mdbx_env_delete(pathname, mode)
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* Windows */
|
2020-10-09 22:43:14 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Copy an MDBX environment to the specified path, with options.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
|
|
|
|
* This function may be used to make a backup of an existing environment.
|
|
|
|
|
* No lockfile is created, since it gets recreated at need.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note This call can trigger significant file size growth if run in
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* parallel with write transactions, because it employs a read-only
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* transaction. See long-lived transactions under \ref restrictions section.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note On Windows the \ref mdbx_env_copyW() is recommended to use.
|
2024-08-02 12:12:29 +03:00
|
|
|
|
* \see mdbx_env_copy2fd()
|
|
|
|
|
* \see mdbx_txn_copy2pathname()
|
2023-02-09 20:02:17 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] env An environment handle returned by mdbx_env_create().
|
|
|
|
|
* It must have already been opened successfully.
|
|
|
|
|
* \param [in] dest The pathname of a file in which the copy will reside.
|
|
|
|
|
* This file must not be already exist, but parent directory
|
|
|
|
|
* must be writable.
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* \param [in] flags Specifies options for this operation. This parameter
|
|
|
|
|
* must be bitwise OR'ing together any of the constants
|
|
|
|
|
* described here:
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_CP_DEFAULTS
|
|
|
|
|
* Perform copy as-is without compaction, etc.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_CP_COMPACT
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* Perform compaction while copying: omit free pages and sequentially
|
|
|
|
|
* renumber all pages in output. This option consumes little bit more
|
|
|
|
|
* CPU for processing, but may running quickly than the default, on
|
|
|
|
|
* account skipping free pages.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_CP_FORCE_DYNAMIC_SIZE
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* Force to make resizable copy, i.e. dynamic size instead of fixed.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2024-08-03 14:50:22 +03:00
|
|
|
|
* - \ref MDBX_CP_DONT_FLUSH
|
|
|
|
|
* Don't explicitly flush the written data to an output media to reduce
|
|
|
|
|
* the time of the operation and the duration of the transaction.
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_CP_THROTTLE_MVCC
|
|
|
|
|
* Use read transaction parking during copying MVCC-snapshot
|
|
|
|
|
* to avoid stopping recycling and overflowing the database.
|
|
|
|
|
* This allows the writing transaction to oust the read
|
|
|
|
|
* transaction used to copy the database if copying takes so long
|
|
|
|
|
* that it will interfere with the recycling old MVCC snapshots
|
|
|
|
|
* and may lead to an overflow of the database.
|
|
|
|
|
* However, if the reading transaction is ousted the copy will
|
|
|
|
|
* be aborted until successful completion. Thus, this option
|
|
|
|
|
* allows copy the database without interfering with write
|
|
|
|
|
* transactions and a threat of database overflow, but at the cost
|
|
|
|
|
* that copying will be aborted to prevent such conditions.
|
|
|
|
|
* \see mdbx_txn_park()
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_copy(MDBX_env *env, const char *dest, MDBX_copy_flags_t flags);
|
2023-02-09 20:02:17 +03:00
|
|
|
|
|
2024-08-02 12:12:29 +03:00
|
|
|
|
/** \brief Copy an MDBX environment by given read transaction to the specified
|
|
|
|
|
* path, with options.
|
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
*
|
|
|
|
|
* This function may be used to make a backup of an existing environment.
|
|
|
|
|
* No lockfile is created, since it gets recreated at need.
|
|
|
|
|
* \note This call can trigger significant file size growth if run in
|
|
|
|
|
* parallel with write transactions, because it employs a read-only
|
|
|
|
|
* transaction. See long-lived transactions under \ref restrictions section.
|
|
|
|
|
*
|
|
|
|
|
* \note On Windows the \ref mdbx_txn_copy2pathnameW() is recommended to use.
|
|
|
|
|
* \see mdbx_txn_copy2fd()
|
|
|
|
|
* \see mdbx_env_copy()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
|
|
|
|
* \param [in] dest The pathname of a file in which the copy will reside.
|
|
|
|
|
* This file must not be already exist, but parent directory
|
|
|
|
|
* must be writable.
|
|
|
|
|
* \param [in] flags Specifies options for this operation. This parameter
|
|
|
|
|
* must be bitwise OR'ing together any of the constants
|
|
|
|
|
* described here:
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_CP_DEFAULTS
|
|
|
|
|
* Perform copy as-is without compaction, etc.
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_CP_COMPACT
|
|
|
|
|
* Perform compaction while copying: omit free pages and sequentially
|
|
|
|
|
* renumber all pages in output. This option consumes little bit more
|
|
|
|
|
* CPU for processing, but may running quickly than the default, on
|
|
|
|
|
* account skipping free pages.
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_CP_FORCE_DYNAMIC_SIZE
|
|
|
|
|
* Force to make resizable copy, i.e. dynamic size instead of fixed.
|
|
|
|
|
*
|
2024-08-03 14:50:22 +03:00
|
|
|
|
* - \ref MDBX_CP_DONT_FLUSH
|
|
|
|
|
* Don't explicitly flush the written data to an output media to reduce
|
|
|
|
|
* the time of the operation and the duration of the transaction.
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_CP_THROTTLE_MVCC
|
|
|
|
|
* Use read transaction parking during copying MVCC-snapshot
|
|
|
|
|
* to avoid stopping recycling and overflowing the database.
|
|
|
|
|
* This allows the writing transaction to oust the read
|
|
|
|
|
* transaction used to copy the database if copying takes so long
|
|
|
|
|
* that it will interfere with the recycling old MVCC snapshots
|
|
|
|
|
* and may lead to an overflow of the database.
|
|
|
|
|
* However, if the reading transaction is ousted the copy will
|
|
|
|
|
* be aborted until successful completion. Thus, this option
|
|
|
|
|
* allows copy the database without interfering with write
|
|
|
|
|
* transactions and a threat of database overflow, but at the cost
|
|
|
|
|
* that copying will be aborted to prevent such conditions.
|
|
|
|
|
* \see mdbx_txn_park()
|
|
|
|
|
*
|
2024-08-02 12:12:29 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_copy2pathname(MDBX_txn *txn, const char *dest, MDBX_copy_flags_t flags);
|
2024-08-02 12:12:29 +03:00
|
|
|
|
|
2023-02-09 20:02:17 +03:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
|
|
|
|
/** \copydoc mdbx_env_copy()
|
2024-08-03 12:48:23 +03:00
|
|
|
|
* \ingroup c_extra
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note Available only on Windows.
|
|
|
|
|
* \see mdbx_env_copy() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_copyW(MDBX_env *env, const wchar_t *dest, MDBX_copy_flags_t flags);
|
2024-10-23 19:12:31 +03:00
|
|
|
|
#define mdbx_env_copyT(env, dest, flags) mdbx_env_copyW(env, dest, flags)
|
2024-08-02 12:12:29 +03:00
|
|
|
|
|
|
|
|
|
/** \copydoc mdbx_txn_copy2pathname()
|
2024-08-03 12:48:23 +03:00
|
|
|
|
* \ingroup c_extra
|
2024-08-02 12:12:29 +03:00
|
|
|
|
* \note Available only on Windows.
|
|
|
|
|
* \see mdbx_txn_copy2pathname() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_copy2pathnameW(MDBX_txn *txn, const wchar_t *dest, MDBX_copy_flags_t flags);
|
|
|
|
|
#define mdbx_txn_copy2pathnameT(txn, dest, flags) mdbx_txn_copy2pathnameW(txn, dest, path)
|
2024-10-23 19:12:31 +03:00
|
|
|
|
#else
|
|
|
|
|
#define mdbx_env_copyT(env, dest, flags) mdbx_env_copy(env, dest, flags)
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define mdbx_txn_copy2pathnameT(txn, dest, flags) mdbx_txn_copy2pathname(txn, dest, path)
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* Windows */
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-10 01:15:35 +03:00
|
|
|
|
/** \brief Copy an environment to the specified file descriptor, with
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* options.
|
|
|
|
|
* \ingroup c_extra
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
|
|
|
|
* This function may be used to make a backup of an existing environment.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* No lockfile is created, since it gets recreated at need.
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \see mdbx_env_copy()
|
2024-08-02 12:12:29 +03:00
|
|
|
|
* \see mdbx_txn_copy2fd()
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note This call can trigger significant file size growth if run in
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* parallel with write transactions, because it employs a read-only
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* transaction. See long-lived transactions under \ref restrictions
|
|
|
|
|
* section.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note Fails if the environment has suffered a page leak and the destination
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* file descriptor is associated with a pipe, socket, or FIFO.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] env An environment handle returned by mdbx_env_create().
|
|
|
|
|
* It must have already been opened successfully.
|
|
|
|
|
* \param [in] fd The file descriptor to write the copy to. It must have
|
|
|
|
|
* already been opened for Write access.
|
|
|
|
|
* \param [in] flags Special options for this operation. \see mdbx_env_copy()
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_copy2fd(MDBX_env *env, mdbx_filehandle_t fd, MDBX_copy_flags_t flags);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-02 12:12:29 +03:00
|
|
|
|
/** \brief Copy an environment by given read transaction to the specified file
|
|
|
|
|
* descriptor, with options.
|
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
*
|
|
|
|
|
* This function may be used to make a backup of an existing environment.
|
|
|
|
|
* No lockfile is created, since it gets recreated at need.
|
|
|
|
|
* \see mdbx_txn_copy2pathname()
|
|
|
|
|
* \see mdbx_env_copy2fd()
|
|
|
|
|
*
|
|
|
|
|
* \note This call can trigger significant file size growth if run in
|
|
|
|
|
* parallel with write transactions, because it employs a read-only
|
|
|
|
|
* transaction. See long-lived transactions under \ref restrictions
|
|
|
|
|
* section.
|
|
|
|
|
*
|
|
|
|
|
* \note Fails if the environment has suffered a page leak and the destination
|
|
|
|
|
* file descriptor is associated with a pipe, socket, or FIFO.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
|
|
|
|
* \param [in] fd The file descriptor to write the copy to. It must have
|
|
|
|
|
* already been opened for Write access.
|
|
|
|
|
* \param [in] flags Special options for this operation. \see mdbx_env_copy()
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_copy2fd(MDBX_txn *txn, mdbx_filehandle_t fd, MDBX_copy_flags_t flags);
|
2024-08-02 12:12:29 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Statistics for a table in the environment
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see mdbx_env_stat_ex() \see mdbx_dbi_stat() */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
struct MDBX_stat {
|
2024-12-11 21:22:04 +03:00
|
|
|
|
uint32_t ms_psize; /**< Size of a table page. This is the same for all tables
|
|
|
|
|
in a database. */
|
|
|
|
|
uint32_t ms_depth; /**< Depth (height) of the B-tree */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t ms_branch_pages; /**< Number of internal (non-leaf) pages */
|
|
|
|
|
uint64_t ms_leaf_pages; /**< Number of leaf pages */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
uint64_t ms_overflow_pages; /**< Number of large/overflow pages */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t ms_entries; /**< Number of data items */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
uint64_t ms_mod_txnid; /**< Transaction ID of committed last modification */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
};
|
|
|
|
|
#ifndef __cplusplus
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/** \ingroup c_statinfo */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
typedef struct MDBX_stat MDBX_stat;
|
|
|
|
|
#endif
|
2019-09-15 17:16:31 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return statistics about the MDBX environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2022-10-29 14:07:56 +03:00
|
|
|
|
* At least one of `env` or `txn` argument must be non-null. If txn is passed
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* non-null then stat will be filled accordingly to the given transaction.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* Otherwise, if txn is null, then stat will be populated by a snapshot from
|
|
|
|
|
* the last committed write transaction, and at next time, other information
|
|
|
|
|
* can be returned.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Legacy mdbx_env_stat() correspond to calling \ref mdbx_env_stat_ex() with the
|
2020-08-03 21:36:55 +03:00
|
|
|
|
* null `txn` argument.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create()
|
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin()
|
|
|
|
|
* \param [out] stat The address of an \ref MDBX_stat structure where
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* the statistics will be copied
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] bytes The size of \ref MDBX_stat.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_stat_ex(const MDBX_env *env, const MDBX_txn *txn, MDBX_stat *stat, size_t bytes);
|
2020-10-14 18:15:50 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return statistics about the MDBX environment.
|
2020-08-07 11:33:51 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \deprecated Please use mdbx_env_stat_ex() instead. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DEPRECATED LIBMDBX_INLINE_API(int, mdbx_env_stat, (const MDBX_env *env, MDBX_stat *stat, size_t bytes)) {
|
2020-10-14 18:15:50 +03:00
|
|
|
|
return mdbx_env_stat_ex(env, NULL, stat, bytes);
|
|
|
|
|
}
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Information about the environment
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see mdbx_env_info_ex() */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
struct MDBX_envinfo {
|
2019-09-15 17:16:31 +03:00
|
|
|
|
struct {
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t lower; /**< Lower limit for datafile size */
|
|
|
|
|
uint64_t upper; /**< Upper limit for datafile size */
|
|
|
|
|
uint64_t current; /**< Current datafile size */
|
|
|
|
|
uint64_t shrink; /**< Shrink threshold for datafile */
|
|
|
|
|
uint64_t grow; /**< Growth step for datafile */
|
2019-09-15 17:16:31 +03:00
|
|
|
|
} mi_geo;
|
2024-12-11 21:22:04 +03:00
|
|
|
|
uint64_t mi_mapsize; /**< Size of the data memory map */
|
|
|
|
|
uint64_t mi_last_pgno; /**< Number of the last used page */
|
|
|
|
|
uint64_t mi_recent_txnid; /**< ID of the last committed transaction */
|
|
|
|
|
uint64_t mi_latter_reader_txnid; /**< ID of the last reader transaction */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t mi_self_latter_reader_txnid; /**< ID of the last reader transaction
|
|
|
|
|
of caller process */
|
2023-04-24 20:59:18 +03:00
|
|
|
|
uint64_t mi_meta_txnid[3], mi_meta_sign[3];
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint32_t mi_maxreaders; /**< Total reader slots in the environment */
|
|
|
|
|
uint32_t mi_numreaders; /**< Max reader slots used in the environment */
|
|
|
|
|
uint32_t mi_dxb_pagesize; /**< Database pagesize */
|
|
|
|
|
uint32_t mi_sys_pagesize; /**< System pagesize */
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief A mostly unique ID that is regenerated on each boot.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
|
|
|
|
As such it can be used to identify the local machine's current boot. MDBX
|
|
|
|
|
uses such when open the database to determine whether rollback required to
|
|
|
|
|
the last steady sync point or not. I.e. if current bootid is differ from the
|
|
|
|
|
value within a database then the system was rebooted and all changes since
|
|
|
|
|
last steady sync must be reverted for data integrity. Zeros mean that no
|
|
|
|
|
relevant information is available from the system. */
|
2019-11-17 23:41:14 +03:00
|
|
|
|
struct {
|
|
|
|
|
struct {
|
2020-09-26 01:45:00 +03:00
|
|
|
|
uint64_t x, y;
|
2023-04-24 20:59:18 +03:00
|
|
|
|
} current, meta[3];
|
2019-11-17 23:41:14 +03:00
|
|
|
|
} mi_bootid;
|
|
|
|
|
|
2020-07-23 19:24:21 +03:00
|
|
|
|
/** Bytes not explicitly synchronized to disk */
|
|
|
|
|
uint64_t mi_unsync_volume;
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** Current auto-sync threshold, see \ref mdbx_env_set_syncbytes(). */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t mi_autosync_threshold;
|
2022-10-11 13:11:12 +03:00
|
|
|
|
/** Time since entering to a "dirty" out-of-sync state in units of 1/65536 of
|
|
|
|
|
* second. In other words, this is the time since the last non-steady commit
|
|
|
|
|
* or zero if it was steady. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint32_t mi_since_sync_seconds16dot16;
|
|
|
|
|
/** Current auto-sync period in 1/65536 of second,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* see \ref mdbx_env_set_syncperiod(). */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint32_t mi_autosync_period_seconds16dot16;
|
|
|
|
|
/** Time since the last readers check in 1/65536 of second,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* see \ref mdbx_reader_check(). */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint32_t mi_since_reader_check_seconds16dot16;
|
2020-07-29 16:56:27 +03:00
|
|
|
|
/** Current environment mode.
|
|
|
|
|
* The same as \ref mdbx_env_get_flags() returns. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint32_t mi_mode;
|
2021-04-27 18:02:11 +03:00
|
|
|
|
|
|
|
|
|
/** Statistics of page operations.
|
|
|
|
|
* \details Overall statistics of page operations of all (running, completed
|
|
|
|
|
* and aborted) transactions in the current multi-process session (since the
|
2021-05-12 14:41:09 +03:00
|
|
|
|
* first process opened the database after everyone had previously closed it).
|
|
|
|
|
*/
|
2021-04-27 18:02:11 +03:00
|
|
|
|
struct {
|
2022-12-04 20:04:13 +03:00
|
|
|
|
uint64_t newly; /**< Quantity of a new pages added */
|
|
|
|
|
uint64_t cow; /**< Quantity of pages copied for update */
|
|
|
|
|
uint64_t clone; /**< Quantity of parent's dirty pages clones
|
|
|
|
|
for nested transactions */
|
|
|
|
|
uint64_t split; /**< Page splits */
|
|
|
|
|
uint64_t merge; /**< Page merges */
|
|
|
|
|
uint64_t spill; /**< Quantity of spilled dirty pages */
|
|
|
|
|
uint64_t unspill; /**< Quantity of unspilled/reloaded pages */
|
|
|
|
|
uint64_t wops; /**< Number of explicit write operations (not a pages)
|
|
|
|
|
to a disk */
|
|
|
|
|
uint64_t prefault; /**< Number of prefault write operations (not a pages) */
|
2022-12-05 10:41:05 +03:00
|
|
|
|
uint64_t mincore; /**< Number of mincore() calls */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
uint64_t msync; /**< Number of explicit msync-to-disk operations (not a pages) */
|
|
|
|
|
uint64_t fsync; /**< Number of explicit fsync-to-disk operations (not a pages) */
|
2021-04-27 18:02:11 +03:00
|
|
|
|
} mi_pgop_stat;
|
2024-07-06 10:46:42 +03:00
|
|
|
|
|
|
|
|
|
/* GUID of the database DXB file. */
|
|
|
|
|
struct {
|
|
|
|
|
uint64_t x, y;
|
|
|
|
|
} mi_dxbid;
|
2020-07-23 19:24:21 +03:00
|
|
|
|
};
|
|
|
|
|
#ifndef __cplusplus
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/** \ingroup c_statinfo */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
typedef struct MDBX_envinfo MDBX_envinfo;
|
|
|
|
|
#endif
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return information about the MDBX environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2022-10-29 14:07:56 +03:00
|
|
|
|
* At least one of `env` or `txn` argument must be non-null. If txn is passed
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* non-null then stat will be filled accordingly to the given transaction.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* Otherwise, if txn is null, then stat will be populated by a snapshot from
|
|
|
|
|
* the last committed write transaction, and at next time, other information
|
|
|
|
|
* can be returned.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-08-03 21:36:55 +03:00
|
|
|
|
* Legacy \ref mdbx_env_info() correspond to calling \ref mdbx_env_info_ex()
|
|
|
|
|
* with the null `txn` argument.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create()
|
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin()
|
|
|
|
|
* \param [out] info The address of an \ref MDBX_envinfo structure
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* where the information will be copied
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* \param [in] bytes The actual size of \ref MDBX_envinfo,
|
|
|
|
|
* this value is used to provide ABI compatibility.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_info_ex(const MDBX_env *env, const MDBX_txn *txn, MDBX_envinfo *info, size_t bytes);
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return information about the MDBX environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \deprecated Please use mdbx_env_info_ex() instead. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DEPRECATED LIBMDBX_INLINE_API(int, mdbx_env_info, (const MDBX_env *env, MDBX_envinfo *info, size_t bytes)) {
|
2020-10-14 18:15:50 +03:00
|
|
|
|
return mdbx_env_info_ex(env, NULL, info, bytes);
|
|
|
|
|
}
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Flush the environment data buffers to disk.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Unless the environment was opened with no-sync flags (\ref MDBX_NOMETASYNC,
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* \ref MDBX_SAFE_NOSYNC and \ref MDBX_UTTERLY_NOSYNC), then
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* data is always written an flushed to disk when \ref mdbx_txn_commit() is
|
|
|
|
|
* called. Otherwise \ref mdbx_env_sync() may be called to manually write and
|
|
|
|
|
* flush unsynced data to disk.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Besides, \ref mdbx_env_sync_ex() with argument `force=false` may be used to
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* provide polling mode for lazy/asynchronous sync in conjunction with
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref mdbx_env_set_syncbytes() and/or \ref mdbx_env_set_syncperiod().
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note This call is not valid if the environment was opened with MDBX_RDONLY.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create()
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \param [in] force If non-zero, force a flush. Otherwise, If force is
|
|
|
|
|
* zero, then will run in polling mode,
|
|
|
|
|
* i.e. it will check the thresholds that were
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* set \ref mdbx_env_set_syncbytes()
|
|
|
|
|
* and/or \ref mdbx_env_set_syncperiod() and perform flush
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* if at least one of the thresholds is reached.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] nonblock Don't wait if write transaction
|
|
|
|
|
* is running by other thread.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \returns A non-zero error value on failure and \ref MDBX_RESULT_TRUE or 0 on
|
|
|
|
|
* success. The \ref MDBX_RESULT_TRUE means no data pending for flush
|
|
|
|
|
* to disk, and 0 otherwise. Some possible errors are:
|
|
|
|
|
*
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \retval MDBX_EACCES The environment is read-only.
|
|
|
|
|
* \retval MDBX_BUSY The environment is used by other thread
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* and `nonblock=true`.
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified.
|
|
|
|
|
* \retval MDBX_EIO An error occurred during the flushing/writing data
|
|
|
|
|
* to a storage medium/disk. */
|
2020-08-04 01:06:01 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_sync_ex(MDBX_env *env, bool force, bool nonblock);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The shortcut to calling \ref mdbx_env_sync_ex() with
|
2020-08-03 21:36:55 +03:00
|
|
|
|
* the `force=true` and `nonblock=false` arguments.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_sync, (MDBX_env * env)) { return mdbx_env_sync_ex(env, true, false); }
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The shortcut to calling \ref mdbx_env_sync_ex() with
|
2020-08-03 21:36:55 +03:00
|
|
|
|
* the `force=false` and `nonblock=true` arguments.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_sync_poll, (MDBX_env * env)) { return mdbx_env_sync_ex(env, false, true); }
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Sets threshold to force flush the data buffers to disk, even any of
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* \ref MDBX_SAFE_NOSYNC flag in the environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_settings
|
2021-12-03 16:46:33 +03:00
|
|
|
|
* \see mdbx_env_get_syncbytes \see MDBX_opt_sync_bytes
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2019-12-15 15:13:46 +03:00
|
|
|
|
* The threshold value affects all processes which operates with given
|
|
|
|
|
* environment until the last process close environment or a new value will be
|
|
|
|
|
* settled.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* Data is always written to disk when \ref mdbx_txn_commit() is called, but
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* the operating system may keep it buffered. MDBX always flushes the OS buffers
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* upon commit as well, unless the environment was opened with
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* \ref MDBX_SAFE_NOSYNC, \ref MDBX_UTTERLY_NOSYNC
|
|
|
|
|
* or in part \ref MDBX_NOMETASYNC.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
|
|
|
|
* The default is 0, than mean no any threshold checked, and no additional
|
|
|
|
|
* flush will be made.
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] env An environment handle returned by mdbx_env_create().
|
|
|
|
|
* \param [in] threshold The size in bytes of summary changes when
|
|
|
|
|
* a synchronous flush would be made.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_set_syncbytes, (MDBX_env * env, size_t threshold)) {
|
2020-10-20 14:29:06 +03:00
|
|
|
|
return mdbx_env_set_option(env, MDBX_opt_sync_bytes, threshold);
|
|
|
|
|
}
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2021-12-03 16:46:33 +03:00
|
|
|
|
/** \brief Get threshold to force flush the data buffers to disk, even any of
|
|
|
|
|
* \ref MDBX_SAFE_NOSYNC flag in the environment.
|
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see mdbx_env_set_syncbytes() \see MDBX_opt_sync_bytes
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create().
|
|
|
|
|
* \param [out] threshold Address of an size_t to store
|
|
|
|
|
* the number of bytes of summary changes when
|
|
|
|
|
* a synchronous flush would be made.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_get_syncbytes, (const MDBX_env *env, size_t *threshold)) {
|
2021-12-03 16:46:33 +03:00
|
|
|
|
int rc = MDBX_EINVAL;
|
|
|
|
|
if (threshold) {
|
|
|
|
|
uint64_t proxy = 0;
|
|
|
|
|
rc = mdbx_env_get_option(env, MDBX_opt_sync_bytes, &proxy);
|
|
|
|
|
#ifdef assert
|
|
|
|
|
assert(proxy <= SIZE_MAX);
|
|
|
|
|
#endif /* assert */
|
|
|
|
|
*threshold = (size_t)proxy;
|
|
|
|
|
}
|
|
|
|
|
return rc;
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-25 01:13:11 +03:00
|
|
|
|
/** \brief Sets relative period since the last unsteady commit to force flush
|
|
|
|
|
* the data buffers to disk, even of \ref MDBX_SAFE_NOSYNC flag in the
|
|
|
|
|
* environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_settings
|
2021-12-03 16:46:33 +03:00
|
|
|
|
* \see mdbx_env_get_syncperiod \see MDBX_opt_sync_period
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* The relative period value affects all processes which operates with given
|
|
|
|
|
* environment until the last process close environment or a new value will be
|
|
|
|
|
* settled.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Data is always written to disk when \ref mdbx_txn_commit() is called, but the
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* operating system may keep it buffered. MDBX always flushes the OS buffers
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* upon commit as well, unless the environment was opened with
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* \ref MDBX_SAFE_NOSYNC or in part \ref MDBX_NOMETASYNC.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2019-09-30 02:40:19 +03:00
|
|
|
|
* Settled period don't checked asynchronously, but only by the
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref mdbx_txn_commit() and \ref mdbx_env_sync() functions. Therefore, in
|
|
|
|
|
* cases where transactions are committed infrequently and/or irregularly,
|
|
|
|
|
* polling by \ref mdbx_env_sync() may be a reasonable solution to timeout
|
|
|
|
|
* enforcement.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
|
|
|
|
* The default is 0, than mean no any timeout checked, and no additional
|
|
|
|
|
* flush will be made.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] seconds_16dot16 The period in 1/65536 of second when
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* a synchronous flush would be made since
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* the last unsteady commit.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_set_syncperiod, (MDBX_env * env, unsigned seconds_16dot16)) {
|
2020-10-20 14:29:06 +03:00
|
|
|
|
return mdbx_env_set_option(env, MDBX_opt_sync_period, seconds_16dot16);
|
|
|
|
|
}
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2021-12-03 16:46:33 +03:00
|
|
|
|
/** \brief Get relative period since the last unsteady commit to force flush
|
|
|
|
|
* the data buffers to disk, even of \ref MDBX_SAFE_NOSYNC flag in the
|
|
|
|
|
* environment.
|
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see mdbx_env_set_syncperiod() \see MDBX_opt_sync_period
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create().
|
|
|
|
|
* \param [out] period_seconds_16dot16 Address of an size_t to store
|
|
|
|
|
* the period in 1/65536 of second when
|
|
|
|
|
* a synchronous flush would be made since
|
|
|
|
|
* the last unsteady commit.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_get_syncperiod, (const MDBX_env *env, unsigned *period_seconds_16dot16)) {
|
2021-12-03 16:46:33 +03:00
|
|
|
|
int rc = MDBX_EINVAL;
|
|
|
|
|
if (period_seconds_16dot16) {
|
|
|
|
|
uint64_t proxy = 0;
|
|
|
|
|
rc = mdbx_env_get_option(env, MDBX_opt_sync_period, &proxy);
|
|
|
|
|
#ifdef assert
|
|
|
|
|
assert(proxy <= UINT32_MAX);
|
|
|
|
|
#endif /* assert */
|
|
|
|
|
*period_seconds_16dot16 = (unsigned)proxy;
|
|
|
|
|
}
|
|
|
|
|
return rc;
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Close the environment and release the memory map.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_opening
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Only a single thread may call this function. All transactions, tables,
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* and cursors must already be closed before calling this function. Attempts
|
2023-10-08 11:55:30 +03:00
|
|
|
|
* to use any such handles after calling this function is UB and would cause
|
|
|
|
|
* a `SIGSEGV`. The environment handle will be freed and must not be used again
|
|
|
|
|
* after this call.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by
|
|
|
|
|
* \ref mdbx_env_create().
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] dont_sync A dont'sync flag, if non-zero the last checkpoint
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* will be kept "as is" and may be still "weak" in the
|
|
|
|
|
* \ref MDBX_SAFE_NOSYNC or \ref MDBX_UTTERLY_NOSYNC
|
|
|
|
|
* modes. Such "weak" checkpoint will be ignored on
|
|
|
|
|
* opening next time, and transactions since the last
|
|
|
|
|
* non-weak checkpoint (meta-page update) will rolledback
|
|
|
|
|
* for consistency guarantee.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \retval MDBX_BUSY The write transaction is running by other thread,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* in such case \ref MDBX_env instance has NOT be destroyed
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* not released!
|
|
|
|
|
* \note If any OTHER error code was returned then
|
|
|
|
|
* given MDBX_env instance has been destroyed and released.
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_EBADSIGN Environment handle already closed or not valid,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* i.e. \ref mdbx_env_close() was already called for the
|
|
|
|
|
* `env` or was not created by \ref mdbx_env_create().
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_PANIC If \ref mdbx_env_close_ex() was called in the child
|
|
|
|
|
* process after `fork()`. In this case \ref MDBX_PANIC
|
|
|
|
|
* is expected, i.e. \ref MDBX_env instance was freed in
|
|
|
|
|
* proper manner.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
*
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \retval MDBX_EIO An error occurred during the flushing/writing data
|
|
|
|
|
* to a storage medium/disk. */
|
2020-08-04 01:06:01 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_close_ex(MDBX_env *env, bool dont_sync);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The shortcut to calling \ref mdbx_env_close_ex() with
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* the `dont_sync=false` argument.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_opening */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_close, (MDBX_env * env)) { return mdbx_env_close_ex(env, false); }
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-03-18 21:57:38 +03:00
|
|
|
|
#if defined(DOXYGEN) || !(defined(_WIN32) || defined(_WIN64))
|
|
|
|
|
/** \brief Восстанавливает экземпляр среды в дочернем процессе после ветвления
|
|
|
|
|
* родительского процесса посредством `fork()` и родственных системных вызовов.
|
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
*
|
|
|
|
|
* Без вызова \ref mdbx_env_resurrect_after_fork() использование открытого
|
|
|
|
|
* экземпляра среды в дочернем процессе не возможно, включая все выполняющиеся
|
|
|
|
|
* на момент ветвления транзакции.
|
|
|
|
|
*
|
|
|
|
|
* Выполняемые функцией действия можно рассматривать как повторное открытие БД
|
|
|
|
|
* в дочернем процессе, с сохранением заданных опций и адресов уже созданных
|
|
|
|
|
* экземпляров объектов связанных с API.
|
|
|
|
|
*
|
|
|
|
|
* \note Функция не доступна в ОС семейства Windows по причине отсутствия
|
|
|
|
|
* функционала ветвления процесса в API операционной системы.
|
|
|
|
|
*
|
|
|
|
|
* Ветвление не оказывает влияния на состояние MDBX-среды в родительском
|
|
|
|
|
* процессе. Все транзакции, которые были в родительском процессе на момент
|
|
|
|
|
* ветвления, после ветвления в родительском процессе продолжат выполняться без
|
|
|
|
|
* помех. Но в дочернем процессе все соответствующие транзакции безальтернативно
|
|
|
|
|
* перестают быть валидными, а попытка их использования приведет к возврату
|
|
|
|
|
* ошибки или отправке `SIGSEGV`.
|
|
|
|
|
*
|
|
|
|
|
* Использование экземпляра среды в дочернем процессе не возможно до вызова
|
|
|
|
|
* \ref mdbx_env_resurrect_after_fork(), так как в результате ветвления у
|
|
|
|
|
* процесса меняется PID, значение которого используется для организации
|
|
|
|
|
* совместно работы с БД, в том числе, для отслеживания процессов/потоков
|
|
|
|
|
* выполняющих читающие транзакции связанные с соответствующими снимками данных.
|
|
|
|
|
* Все активные на момент ветвления транзакции не могут продолжаться в дочернем
|
|
|
|
|
* процессе, так как не владеют какими-либо блокировками или каким-либо снимком
|
|
|
|
|
* данных и не удерживает его от переработки при сборке мусора.
|
|
|
|
|
*
|
|
|
|
|
* Функция \ref mdbx_env_resurrect_after_fork() восстанавливает переданный
|
|
|
|
|
* экземпляр среды в дочернем процессе после ветвления, а именно: обновляет
|
|
|
|
|
* используемые системные идентификаторы, повторно открывает дескрипторы файлов,
|
|
|
|
|
* производит захват необходимых блокировок связанных с LCK- и DXB-файлами БД,
|
|
|
|
|
* восстанавливает отображения в память страницы БД, таблицы читателей и
|
|
|
|
|
* служебных/вспомогательных данных в память. Однако унаследованные от
|
|
|
|
|
* родительского процесса транзакции не восстанавливаются, прием пишущие и
|
|
|
|
|
* читающие транзакции обрабатываются по-разному:
|
|
|
|
|
*
|
|
|
|
|
* - Пишущая транзакция, если таковая была на момент ветвления,
|
|
|
|
|
* прерывается в дочернем процессе с освобождение связанных с ней ресурсов,
|
|
|
|
|
* включая все вложенные транзакции.
|
|
|
|
|
*
|
|
|
|
|
* - Читающие же транзакции, если таковые были в родительском процессе,
|
|
|
|
|
* в дочернем процессе логически прерываются, но без освобождения ресурсов.
|
|
|
|
|
* Поэтому необходимо обеспечить вызов \ref mdbx_txn_abort() для каждой
|
|
|
|
|
* такой читающей транзакций в дочернем процессе, либо смириться с утечкой
|
|
|
|
|
* ресурсов до завершения дочернего процесса.
|
|
|
|
|
*
|
|
|
|
|
* Причина не-освобождения ресурсов читающих транзакций в том, что исторически
|
|
|
|
|
* MDBX не ведет какой-либо общий список экземпляров читающих, так как это не
|
|
|
|
|
* требуется для штатных режимов работы, но требует использования атомарных
|
|
|
|
|
* операций или дополнительных объектов синхронизации при создании/разрушении
|
|
|
|
|
* экземпляров \ref MDBX_txn.
|
|
|
|
|
*
|
|
|
|
|
* Вызов \ref mdbx_env_resurrect_after_fork() без ветвления, не в дочернем
|
|
|
|
|
* процессе, либо повторные вызовы не приводят к каким-либо действиям или
|
|
|
|
|
* изменениям.
|
|
|
|
|
*
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* \param [in,out] env Экземпляр среды созданный функцией
|
|
|
|
|
* \ref mdbx_env_create().
|
|
|
|
|
*
|
2024-07-05 20:33:43 +03:00
|
|
|
|
* \returns Ненулевое значение кода ошибки, либо 0 при успешном выполнении.
|
|
|
|
|
* Некоторые возможные ошибки таковы:
|
2024-03-18 21:57:38 +03:00
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_BUSY В родительском процессе БД была открыта
|
|
|
|
|
* в режиме \ref MDBX_EXCLUSIVE.
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_EBADSIGN При повреждении сигнатуры экземпляра объекта, а также
|
|
|
|
|
* в случае одновременного вызова \ref
|
|
|
|
|
* mdbx_env_resurrect_after_fork() из разных потоков.
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_PANIC Произошла критическая ошибка при восстановлении
|
|
|
|
|
* экземпляра среды, либо такая ошибка уже была
|
|
|
|
|
* до вызова функции. */
|
2023-11-11 20:08:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_resurrect_after_fork(MDBX_env *env);
|
|
|
|
|
#endif /* Windows */
|
|
|
|
|
|
2022-10-24 01:02:38 +03:00
|
|
|
|
/** \brief Warming up options
|
|
|
|
|
* \ingroup c_settings
|
|
|
|
|
* \anchor warmup_flags
|
|
|
|
|
* \see mdbx_env_warmup() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_warmup_flags {
|
2022-10-24 01:02:38 +03:00
|
|
|
|
/** By default \ref mdbx_env_warmup() just ask OS kernel to asynchronously
|
|
|
|
|
* prefetch database pages. */
|
|
|
|
|
MDBX_warmup_default = 0,
|
|
|
|
|
|
|
|
|
|
/** Peeking all pages of allocated portion of the database
|
|
|
|
|
* to force ones to be loaded into memory. However, the pages are just peeks
|
|
|
|
|
* sequentially, so unused pages that are in GC will be loaded in the same
|
|
|
|
|
* way as those that contain payload. */
|
|
|
|
|
MDBX_warmup_force = 1,
|
|
|
|
|
|
|
|
|
|
/** Using system calls to peeks pages instead of directly accessing ones,
|
|
|
|
|
* which at the cost of additional overhead avoids killing the current
|
|
|
|
|
* process by OOM-killer in a lack of memory condition.
|
|
|
|
|
* \note Has effect only on POSIX (non-Windows) systems with conjunction
|
|
|
|
|
* to \ref MDBX_warmup_force option. */
|
|
|
|
|
MDBX_warmup_oomsafe = 2,
|
|
|
|
|
|
|
|
|
|
/** Try to lock database pages in memory by `mlock()` on POSIX-systems
|
|
|
|
|
* or `VirtualLock()` on Windows. Please refer to description of these
|
|
|
|
|
* functions for reasonability of such locking and the information of
|
|
|
|
|
* effects, including the system as a whole.
|
|
|
|
|
*
|
|
|
|
|
* Such locking in memory requires that the corresponding resource limits
|
|
|
|
|
* (e.g. `RLIMIT_RSS`, `RLIMIT_MEMLOCK` or process working set size)
|
|
|
|
|
* and the availability of system RAM are sufficiently high.
|
|
|
|
|
*
|
|
|
|
|
* On successful, all currently allocated pages, both unused in GC and
|
|
|
|
|
* containing payload, will be locked in memory until the environment closes,
|
|
|
|
|
* or explicitly unblocked by using \ref MDBX_warmup_release, or the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* database geometry will changed, including its auto-shrinking. */
|
2022-10-24 01:02:38 +03:00
|
|
|
|
MDBX_warmup_lock = 4,
|
|
|
|
|
|
|
|
|
|
/** Alters corresponding current resource limits to be enough for lock pages
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* by \ref MDBX_warmup_lock. However, this option should be used in simpler
|
2022-10-24 01:02:38 +03:00
|
|
|
|
* applications since takes into account only current size of this environment
|
|
|
|
|
* disregarding all other factors. For real-world database application you
|
|
|
|
|
* will need full-fledged management of resources and their limits with
|
|
|
|
|
* respective engineering. */
|
|
|
|
|
MDBX_warmup_touchlimit = 8,
|
|
|
|
|
|
|
|
|
|
/** Release the lock that was performed before by \ref MDBX_warmup_lock. */
|
|
|
|
|
MDBX_warmup_release = 16,
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_warmup_flags_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_warmup_flags)
|
2022-10-24 01:02:38 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Warms up the database by loading pages into memory,
|
|
|
|
|
* optionally lock ones.
|
|
|
|
|
* \ingroup c_settings
|
2022-10-24 01:02:38 +03:00
|
|
|
|
*
|
|
|
|
|
* Depending on the specified flags, notifies OS kernel about following access,
|
|
|
|
|
* force loads the database pages, including locks ones in memory or releases
|
|
|
|
|
* such a lock. However, the function does not analyze the b-tree nor the GC.
|
|
|
|
|
* Therefore an unused pages that are in GC handled (i.e. will be loaded) in
|
|
|
|
|
* the same way as those that contain payload.
|
|
|
|
|
*
|
2022-10-29 14:07:56 +03:00
|
|
|
|
* At least one of `env` or `txn` argument must be non-null.
|
2022-10-24 01:02:38 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create().
|
|
|
|
|
* \param [in] txn A transaction handle returned
|
|
|
|
|
* by \ref mdbx_txn_begin().
|
|
|
|
|
* \param [in] flags The \ref warmup_flags, bitwise OR'ed together.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] timeout_seconds_16dot16 Optional timeout which checking only
|
|
|
|
|
* during explicitly peeking database pages
|
|
|
|
|
* for loading ones if the \ref MDBX_warmup_force
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* option was specified.
|
2022-10-24 01:02:38 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success.
|
|
|
|
|
* Some possible errors are:
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_ENOSYS The system does not support requested
|
|
|
|
|
* operation(s).
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_RESULT_TRUE The specified timeout is reached during load
|
|
|
|
|
* data into memory. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_warmup(const MDBX_env *env, const MDBX_txn *txn, MDBX_warmup_flags_t flags,
|
2022-10-24 01:02:38 +03:00
|
|
|
|
unsigned timeout_seconds_16dot16);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Set environment flags.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_settings
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
|
|
|
|
* This may be used to set some flags in addition to those from
|
2019-09-28 20:10:29 +03:00
|
|
|
|
* mdbx_env_open(), or to unset these flags.
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* \see mdbx_env_get_flags()
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note In contrast to LMDB, the MDBX serialize threads via mutex while
|
2019-09-28 20:10:29 +03:00
|
|
|
|
* changing the flags. Therefore this function will be blocked while a write
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* transaction running by other thread, or \ref MDBX_BUSY will be returned if
|
2019-09-28 20:10:29 +03:00
|
|
|
|
* function called within a write transaction.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create().
|
|
|
|
|
* \param [in] flags The \ref env_flags to change, bitwise OR'ed together.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] onoff A non-zero value sets the flags, zero clears them.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_set_flags(MDBX_env *env, MDBX_env_flags_t flags, bool onoff);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Get environment flags.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* \see mdbx_env_set_flags()
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] flags The address of an integer to store the flags.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2020-04-18 20:16:37 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_get_flags(const MDBX_env *env, unsigned *flags);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return the path that was used in mdbx_env_open().
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note On Windows the \ref mdbx_env_get_pathW() is recommended to use.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create()
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] dest Address of a string pointer to contain the path.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* This is the actual string in the environment, not a
|
|
|
|
|
* copy. It should not be altered in any way.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2020-04-18 20:16:37 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_get_path(const MDBX_env *env, const char **dest);
|
2023-02-09 20:02:17 +03:00
|
|
|
|
|
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
|
|
|
|
/** \copydoc mdbx_env_get_path()
|
2024-08-03 12:48:23 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note Available only on Windows.
|
|
|
|
|
* \see mdbx_env_get_path() */
|
2022-08-09 18:27:43 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_get_pathW(const MDBX_env *env, const wchar_t **dest);
|
2024-10-23 19:12:31 +03:00
|
|
|
|
#define mdbx_env_get_pathT(env, dest) mdbx_env_get_pathW(env, dest)
|
|
|
|
|
#else
|
|
|
|
|
#define mdbx_env_get_pathT(env, dest) mdbx_env_get_path(env, dest)
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* Windows */
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return the file descriptor for the given environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \note All MDBX file descriptors have `FD_CLOEXEC` and
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* couldn't be used after exec() and or `fork()`.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] fd Address of a int to contain the descriptor.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2020-04-18 20:16:37 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_get_fd(const MDBX_env *env, mdbx_filehandle_t *fd);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Set all size-related parameters of environment, including page size
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* and the min/max size of the memory map.
|
|
|
|
|
* \ingroup c_settings
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
|
|
|
|
* In contrast to LMDB, the MDBX provide automatic size management of an
|
|
|
|
|
* database according the given parameters, including shrinking and resizing
|
|
|
|
|
* on the fly. From user point of view all of these just working. Nevertheless,
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* it is reasonable to know some details in order to make optimal decisions
|
|
|
|
|
* when choosing parameters.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2023-03-17 10:54:40 +03:00
|
|
|
|
* \see mdbx_env_info_ex()
|
|
|
|
|
*
|
2022-02-02 14:04:56 +03:00
|
|
|
|
* Both \ref mdbx_env_set_geometry() and legacy \ref mdbx_env_set_mapsize() are
|
|
|
|
|
* inapplicable to read-only opened environment.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2022-02-02 14:04:56 +03:00
|
|
|
|
* Both \ref mdbx_env_set_geometry() and legacy \ref mdbx_env_set_mapsize()
|
|
|
|
|
* could be called either before or after \ref mdbx_env_open(), either within
|
|
|
|
|
* the write transaction running by current thread or not:
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2022-02-02 14:04:56 +03:00
|
|
|
|
* - In case \ref mdbx_env_set_geometry() or legacy \ref mdbx_env_set_mapsize()
|
|
|
|
|
* was called BEFORE \ref mdbx_env_open(), i.e. for closed environment, then
|
|
|
|
|
* the specified parameters will be used for new database creation,
|
|
|
|
|
* or will be applied during opening if database exists and no other process
|
|
|
|
|
* using it.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* If the database is already exist, opened with \ref MDBX_EXCLUSIVE or not
|
|
|
|
|
* used by any other process, and parameters specified by
|
|
|
|
|
* \ref mdbx_env_set_geometry() are incompatible (i.e. for instance,
|
|
|
|
|
* different page size) then \ref mdbx_env_open() will return
|
|
|
|
|
* \ref MDBX_INCOMPATIBLE error.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
|
|
|
|
* In another way, if database will opened read-only or will used by other
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* process during calling \ref mdbx_env_open() that specified parameters will
|
|
|
|
|
* silently discarded (open the database with \ref MDBX_EXCLUSIVE flag
|
|
|
|
|
* to avoid this).
|
|
|
|
|
*
|
2022-02-02 14:04:56 +03:00
|
|
|
|
* - In case \ref mdbx_env_set_geometry() or legacy \ref mdbx_env_set_mapsize()
|
|
|
|
|
* was called after \ref mdbx_env_open() WITHIN the write transaction running
|
|
|
|
|
* by current thread, then specified parameters will be applied as a part of
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* write transaction, i.e. will not be completely visible to any others
|
|
|
|
|
* processes until the current write transaction has been committed by the
|
|
|
|
|
* current process. However, if transaction will be aborted, then the
|
|
|
|
|
* database file will be reverted to the previous size not immediately, but
|
|
|
|
|
* when a next transaction will be committed or when the database will be
|
|
|
|
|
* opened next time.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
*
|
2022-02-02 14:04:56 +03:00
|
|
|
|
* - In case \ref mdbx_env_set_geometry() or legacy \ref mdbx_env_set_mapsize()
|
|
|
|
|
* was called after \ref mdbx_env_open() but OUTSIDE a write transaction,
|
|
|
|
|
* then MDBX will execute internal pseudo-transaction to apply new parameters
|
|
|
|
|
* (but only if anything has been changed), and changes be visible to any
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* others processes immediately after successful completion of function.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
|
|
|
|
* Essentially a concept of "automatic size management" is simple and useful:
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* - There are the lower and upper bounds of the database file size;
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* - There is the growth step by which the database file will be increased,
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* in case of lack of space;
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* - There is the threshold for unused space, beyond which the database file
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* will be shrunk;
|
|
|
|
|
* - The size of the memory map is also the maximum size of the database;
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* - MDBX will automatically manage both the size of the database and the size
|
|
|
|
|
* of memory map, according to the given parameters.
|
|
|
|
|
*
|
|
|
|
|
* So, there some considerations about choosing these parameters:
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* - The lower bound allows you to prevent database shrinking below certain
|
|
|
|
|
* reasonable size to avoid unnecessary resizing costs.
|
|
|
|
|
* - The upper bound allows you to prevent database growth above certain
|
|
|
|
|
* reasonable size. Besides, the upper bound defines the linear address space
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* reservation in each process that opens the database. Therefore changing
|
|
|
|
|
* the upper bound is costly and may be required reopening environment in
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* case of \ref MDBX_UNABLE_EXTEND_MAPSIZE errors, and so on. Therefore, this
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* value should be chosen reasonable large, to accommodate future growth of
|
|
|
|
|
* the database.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* - The growth step must be greater than zero to allow the database to grow,
|
|
|
|
|
* but also reasonable not too small, since increasing the size by little
|
|
|
|
|
* steps will result a large overhead.
|
|
|
|
|
* - The shrink threshold must be greater than zero to allow the database
|
|
|
|
|
* to shrink but also reasonable not too small (to avoid extra overhead) and
|
|
|
|
|
* not less than growth step to avoid up-and-down flouncing.
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* - The current size (i.e. `size_now` argument) is an auxiliary parameter for
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* simulation legacy \ref mdbx_env_set_mapsize() and as workaround Windows
|
|
|
|
|
* issues (see below).
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* Unfortunately, Windows has is a several issue
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* with resizing of memory-mapped file:
|
|
|
|
|
* - Windows unable shrinking a memory-mapped file (i.e memory-mapped section)
|
|
|
|
|
* in any way except unmapping file entirely and then map again. Moreover,
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* it is impossible in any way when a memory-mapped file is used more than
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* one process.
|
|
|
|
|
* - Windows does not provide the usual API to augment a memory-mapped file
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* (i.e. a memory-mapped partition), but only by using "Native API"
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* in an undocumented way.
|
2020-02-28 16:08:58 +03:00
|
|
|
|
*
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* MDBX bypasses all Windows issues, but at a cost:
|
|
|
|
|
* - Ability to resize database on the fly requires an additional lock
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* and release `SlimReadWriteLock` during each read-only transaction.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* - During resize all in-process threads should be paused and then resumed.
|
|
|
|
|
* - Shrinking of database file is performed only when it used by single
|
|
|
|
|
* process, i.e. when a database closes by the last process or opened
|
|
|
|
|
* by the first.
|
|
|
|
|
* = Therefore, the size_now argument may be useful to set database size
|
|
|
|
|
* by the first process which open a database, and thus avoid expensive
|
|
|
|
|
* remapping further.
|
|
|
|
|
*
|
|
|
|
|
* For create a new database with particular parameters, including the page
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* size, \ref mdbx_env_set_geometry() should be called after
|
2022-02-02 14:28:45 +03:00
|
|
|
|
* \ref mdbx_env_create() and before \ref mdbx_env_open(). Once the database is
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* created, the page size cannot be changed. If you do not specify all or some
|
|
|
|
|
* of the parameters, the corresponding default values will be used. For
|
|
|
|
|
* instance, the default for database size is 10485760 bytes.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
|
|
|
|
* If the mapsize is increased by another process, MDBX silently and
|
|
|
|
|
* transparently adopt these changes at next transaction start. However,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref mdbx_txn_begin() will return \ref MDBX_UNABLE_EXTEND_MAPSIZE if new
|
|
|
|
|
* mapping size could not be applied for current process (for instance if
|
|
|
|
|
* address space is busy). Therefore, in the case of
|
|
|
|
|
* \ref MDBX_UNABLE_EXTEND_MAPSIZE error you need close and reopen the
|
|
|
|
|
* environment to resolve error.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note Actual values may be different than your have specified because of
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* rounding to specified database page size, the system page size and/or the
|
|
|
|
|
* size of the system virtual memory management unit. You can get actual values
|
2023-03-17 10:54:40 +03:00
|
|
|
|
* by \ref mdbx_env_info_ex() or see by using the tool `mdbx_chk` with the `-v`
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* option.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Legacy \ref mdbx_env_set_mapsize() correspond to calling
|
|
|
|
|
* \ref mdbx_env_set_geometry() with the arguments `size_lower`, `size_now`,
|
|
|
|
|
* `size_upper` equal to the `size` and `-1` (i.e. default) for all other
|
|
|
|
|
* parameters.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create()
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-09-07 01:54:36 +03:00
|
|
|
|
* \param [in] size_lower The lower bound of database size in bytes.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* Zero value means "minimal acceptable",
|
|
|
|
|
* and negative means "keep current or use default".
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] size_now The size in bytes to setup the database size for
|
|
|
|
|
* now. Zero value means "minimal acceptable", and
|
|
|
|
|
* negative means "keep current or use default". So,
|
|
|
|
|
* it is recommended always pass -1 in this argument
|
|
|
|
|
* except some special cases.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-09-07 01:54:36 +03:00
|
|
|
|
* \param [in] size_upper The upper bound of database size in bytes.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* Zero value means "minimal acceptable",
|
|
|
|
|
* and negative means "keep current or use default".
|
|
|
|
|
* It is recommended to avoid change upper bound while
|
|
|
|
|
* database is used by other processes or threaded
|
|
|
|
|
* (i.e. just pass -1 in this argument except absolutely
|
2020-09-07 01:54:36 +03:00
|
|
|
|
* necessary). Otherwise you must be ready for
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref MDBX_UNABLE_EXTEND_MAPSIZE error(s), unexpected
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* pauses during remapping and/or system errors like
|
2020-09-07 01:54:36 +03:00
|
|
|
|
* "address busy", and so on. In other words, there
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* is no way to handle a growth of the upper bound
|
|
|
|
|
* robustly because there may be a lack of appropriate
|
|
|
|
|
* system resources (which are extremely volatile in
|
|
|
|
|
* a multi-process multi-threaded environment).
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] growth_step The growth step in bytes, must be greater than
|
|
|
|
|
* zero to allow the database to grow. Negative value
|
|
|
|
|
* means "keep current or use default".
|
|
|
|
|
*
|
|
|
|
|
* \param [in] shrink_threshold The shrink threshold in bytes, must be greater
|
2020-10-22 18:12:04 +07:00
|
|
|
|
* than zero to allow the database to shrink and
|
|
|
|
|
* greater than growth_step to avoid shrinking
|
|
|
|
|
* right after grow.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* Negative value means "keep current
|
2020-10-22 18:12:04 +07:00
|
|
|
|
* or use default". Default is 2*growth_step.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] pagesize The database page size for new database
|
2022-01-21 11:44:05 +03:00
|
|
|
|
* creation or -1 otherwise. Once the database
|
|
|
|
|
* is created, the page size cannot be changed.
|
|
|
|
|
* Must be power of 2 in the range between
|
|
|
|
|
* \ref MDBX_MIN_PAGESIZE and
|
2020-09-07 01:54:36 +03:00
|
|
|
|
* \ref MDBX_MAX_PAGESIZE. Zero value means
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* "minimal acceptable", and negative means
|
|
|
|
|
* "keep current or use default".
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified,
|
|
|
|
|
* or the environment has an active write transaction.
|
2022-03-29 00:31:37 +03:00
|
|
|
|
* \retval MDBX_EPERM Two specific cases for Windows:
|
|
|
|
|
* 1) Shrinking was disabled before via geometry settings
|
|
|
|
|
* and now it enabled, but there are reading threads that
|
|
|
|
|
* don't use the additional `SRWL` (which is required to
|
|
|
|
|
* avoid Windows issues).
|
|
|
|
|
* 2) Temporary close memory mapped is required to change
|
|
|
|
|
* geometry, but there read transaction(s) is running
|
|
|
|
|
* and no corresponding thread(s) could be suspended
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* since the \ref MDBX_NOSTICKYTHREADS mode is used.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_EACCESS The environment opened in read-only.
|
|
|
|
|
* \retval MDBX_MAP_FULL Specified size smaller than the space already
|
|
|
|
|
* consumed by the environment.
|
|
|
|
|
* \retval MDBX_TOO_LARGE Specified size is too large, i.e. too many pages for
|
|
|
|
|
* given size, or a 32-bit process requests too much
|
|
|
|
|
* bytes for the 32-bit address space. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
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);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \deprecated Please use \ref mdbx_env_set_geometry() instead.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_settings */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DEPRECATED LIBMDBX_INLINE_API(int, mdbx_env_set_mapsize, (MDBX_env * env, size_t size)) {
|
2020-10-14 18:15:50 +03:00
|
|
|
|
return mdbx_env_set_geometry(env, size, size, size, -1, -1, -1);
|
|
|
|
|
}
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Find out whether to use readahead or not, based on the given database
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* size and the amount of available memory.
|
|
|
|
|
* \ingroup c_extra
|
2019-10-12 14:16:45 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] volume The expected database size in bytes.
|
|
|
|
|
* \param [in] redundancy Additional reserve or overload in case of negative
|
|
|
|
|
* value.
|
2019-10-12 14:16:45 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \returns A \ref MDBX_RESULT_TRUE or \ref MDBX_RESULT_FALSE value,
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* otherwise the error code.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_RESULT_TRUE Readahead is reasonable.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \retval MDBX_RESULT_FALSE Readahead is NOT reasonable,
|
|
|
|
|
* i.e. \ref MDBX_NORDAHEAD is useful to
|
|
|
|
|
* open environment by \ref mdbx_env_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval Otherwise the error code. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_is_readahead_reasonable(size_t volume, intptr_t redundancy);
|
2019-10-12 14:16:45 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns the minimal database page size in bytes.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_INLINE_API(intptr_t, mdbx_limits_pgsize_min, (void)) { return MDBX_MIN_PAGESIZE; }
|
2019-09-06 21:02:12 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns the maximal database page size in bytes.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_INLINE_API(intptr_t, mdbx_limits_pgsize_max, (void)) { return MDBX_MAX_PAGESIZE; }
|
2019-09-06 21:02:12 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns minimal database size in bytes for given page size,
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* or -1 if pagesize is invalid.
|
|
|
|
|
* \ingroup c_statinfo */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_dbsize_min(intptr_t pagesize);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns maximal database size in bytes for given page size,
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* or -1 if pagesize is invalid.
|
|
|
|
|
* \ingroup c_statinfo */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_dbsize_max(intptr_t pagesize);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns maximal key size in bytes for given page size
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* and table flags, or -1 if pagesize is invalid.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see db_flags */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_keysize_max(intptr_t pagesize, MDBX_db_flags_t flags);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Returns minimal key size in bytes for given table flags.
|
2024-02-23 12:43:18 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see db_flags */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_keysize_min(MDBX_db_flags_t flags);
|
2024-02-23 12:43:18 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns maximal data size in bytes for given page size
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* and table flags, or -1 if pagesize is invalid.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see db_flags */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_valsize_max(intptr_t pagesize, MDBX_db_flags_t flags);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Returns minimal data size in bytes for given table flags.
|
2024-02-23 12:43:18 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see db_flags */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_valsize_min(MDBX_db_flags_t flags);
|
2024-02-23 12:43:18 +03:00
|
|
|
|
|
2022-09-30 14:06:55 +03:00
|
|
|
|
/** \brief Returns maximal size of key-value pair to fit in a single page with
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* the given size and table flags, or -1 if pagesize is invalid.
|
2022-09-30 14:06:55 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see db_flags */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_pairsize4page_max(intptr_t pagesize,
|
|
|
|
|
MDBX_db_flags_t flags);
|
2022-09-30 14:06:55 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Returns maximal data size in bytes to fit in a leaf-page or
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* single large/overflow-page with the given page size and table flags,
|
2022-09-30 14:06:55 +03:00
|
|
|
|
* or -1 if pagesize is invalid.
|
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see db_flags */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_valsize4page_max(intptr_t pagesize, MDBX_db_flags_t flags);
|
2022-09-30 14:06:55 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns maximal write transaction size (i.e. limit for summary volume
|
|
|
|
|
* of dirty pages) in bytes for given page size, or -1 if pagesize is invalid.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API intptr_t mdbx_limits_txnsize_max(intptr_t pagesize);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-12-08 00:01:29 +03:00
|
|
|
|
/** \brief Set the maximum number of threads/reader slots for for all processes
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* interacts with the database.
|
|
|
|
|
* \ingroup c_settings
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-12-08 00:01:29 +03:00
|
|
|
|
* \details This defines the number of slots in the lock table that is used to
|
2024-12-06 22:15:23 +03:00
|
|
|
|
* track readers in the environment. The default is about 100 for 4K system
|
2020-12-08 00:01:29 +03:00
|
|
|
|
* page size. Starting a read-only transaction normally ties a lock table slot
|
|
|
|
|
* to the current thread until the environment closes or the thread exits. If
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* \ref MDBX_NOSTICKYTHREADS is in use, \ref mdbx_txn_begin() instead ties the
|
|
|
|
|
* slot to the \ref MDBX_txn object until it or the \ref MDBX_env object is
|
|
|
|
|
* destroyed. This function may only be called after \ref mdbx_env_create() and
|
|
|
|
|
* before \ref mdbx_env_open(), and has an effect only when the database is
|
|
|
|
|
* opened by the first process interacts with the database.
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* \see mdbx_env_get_maxreaders()
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] readers The maximum number of reader lock table slots.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified.
|
|
|
|
|
* \retval MDBX_EPERM The environment is already open. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_set_maxreaders, (MDBX_env * env, unsigned readers)) {
|
2020-10-20 14:29:06 +03:00
|
|
|
|
return mdbx_env_set_option(env, MDBX_opt_max_readers, readers);
|
|
|
|
|
}
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Get the maximum number of threads/reader slots for the environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* \see mdbx_env_set_maxreaders()
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] readers Address of an integer to store the number of readers.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_get_maxreaders, (const MDBX_env *env, unsigned *readers)) {
|
2020-10-20 14:29:06 +03:00
|
|
|
|
int rc = MDBX_EINVAL;
|
|
|
|
|
if (readers) {
|
|
|
|
|
uint64_t proxy = 0;
|
|
|
|
|
rc = mdbx_env_get_option(env, MDBX_opt_max_readers, &proxy);
|
|
|
|
|
*readers = (unsigned)proxy;
|
|
|
|
|
}
|
|
|
|
|
return rc;
|
|
|
|
|
}
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Set the maximum number of named tables for the environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_settings
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This function is only needed if multiple tables will be used in the
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* environment. Simpler applications that use the environment as a single
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* unnamed table can ignore this option.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* This function may only be called after \ref mdbx_env_create() and before
|
|
|
|
|
* \ref mdbx_env_open().
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
|
|
|
|
* Currently a moderate number of slots are cheap but a huge number gets
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* expensive: 7-120 words per transaction, and every \ref mdbx_dbi_open()
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* does a linear search of the opened slots.
|
2020-07-27 16:26:19 +03:00
|
|
|
|
* \see mdbx_env_get_maxdbs()
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbs The maximum number of tables.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified.
|
|
|
|
|
* \retval MDBX_EPERM The environment is already open. */
|
2020-10-20 14:29:06 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_set_maxdbs, (MDBX_env * env, MDBX_dbi dbs)) {
|
2020-12-08 00:01:29 +03:00
|
|
|
|
return mdbx_env_set_option(env, MDBX_opt_max_db, dbs);
|
2020-10-20 14:29:06 +03:00
|
|
|
|
}
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Get the maximum number of named tables for the environment.
|
2020-07-27 16:26:19 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see mdbx_env_set_maxdbs()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [out] dbs Address to store the maximum number of tables.
|
2020-07-27 16:26:19 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_env_get_maxdbs, (const MDBX_env *env, MDBX_dbi *dbs)) {
|
2020-10-20 14:29:06 +03:00
|
|
|
|
int rc = MDBX_EINVAL;
|
|
|
|
|
if (dbs) {
|
|
|
|
|
uint64_t proxy = 0;
|
2020-12-08 00:01:29 +03:00
|
|
|
|
rc = mdbx_env_get_option(env, MDBX_opt_max_db, &proxy);
|
2020-10-20 14:29:06 +03:00
|
|
|
|
*dbs = (MDBX_dbi)proxy;
|
|
|
|
|
}
|
|
|
|
|
return rc;
|
|
|
|
|
}
|
2020-07-27 16:26:19 +03:00
|
|
|
|
|
2021-01-29 21:19:58 +03:00
|
|
|
|
/** \brief Returns the default size of database page for the current system.
|
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \details Default size of database page depends on the size of the system
|
|
|
|
|
* page and usually exactly match it. */
|
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API size_t mdbx_default_pagesize(void);
|
|
|
|
|
|
2021-04-07 01:45:14 +03:00
|
|
|
|
/** \brief Returns basic information about system RAM.
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* This function provides a portable way to get information about available RAM
|
|
|
|
|
* and can be useful in that it returns the same information that libmdbx uses
|
|
|
|
|
* internally to adjust various options and control readahead.
|
2021-04-07 01:45:14 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2021-05-03 14:19:34 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [out] page_size Optional address where the system page size
|
|
|
|
|
* will be stored.
|
|
|
|
|
* \param [out] total_pages Optional address where the number of total RAM
|
|
|
|
|
* pages will be stored.
|
|
|
|
|
* \param [out] avail_pages Optional address where the number of
|
|
|
|
|
* available/free RAM pages will be stored.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_get_sysraminfo(intptr_t *page_size, intptr_t *total_pages, intptr_t *avail_pages);
|
2021-04-07 01:45:14 +03:00
|
|
|
|
|
2021-05-03 14:19:34 +03:00
|
|
|
|
/** \brief Returns the maximum size of keys can put.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] flags Table options (\ref MDBX_DUPSORT, \ref MDBX_INTEGERKEY
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* and so on). \see db_flags
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns The maximum size of a key can write,
|
|
|
|
|
* or -1 if something is wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_env_get_maxkeysize_ex(const MDBX_env *env, MDBX_db_flags_t flags);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2021-05-03 14:19:34 +03:00
|
|
|
|
/** \brief Returns the maximum size of data we can put.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] flags Table options (\ref MDBX_DUPSORT, \ref MDBX_INTEGERKEY
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* and so on). \see db_flags
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns The maximum size of a data can write,
|
|
|
|
|
* or -1 if something is wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_env_get_maxvalsize_ex(const MDBX_env *env, MDBX_db_flags_t flags);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \deprecated Please use \ref mdbx_env_get_maxkeysize_ex()
|
|
|
|
|
* and/or \ref mdbx_env_get_maxvalsize_ex()
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION MDBX_DEPRECATED LIBMDBX_API int mdbx_env_get_maxkeysize(const MDBX_env *env);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2022-10-10 16:33:51 +03:00
|
|
|
|
/** \brief Returns maximal size of key-value pair to fit in a single page
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* for specified table flags.
|
2022-10-10 16:33:51 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] flags Table options (\ref MDBX_DUPSORT, \ref MDBX_INTEGERKEY
|
2022-10-10 16:33:51 +03:00
|
|
|
|
* and so on). \see db_flags
|
|
|
|
|
*
|
|
|
|
|
* \returns The maximum size of a data can write,
|
|
|
|
|
* or -1 if something is wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_env_get_pairsize4page_max(const MDBX_env *env, MDBX_db_flags_t flags);
|
2022-10-10 16:33:51 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Returns maximal data size in bytes to fit in a leaf-page or
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* single large/overflow-page for specified table flags.
|
2022-10-10 16:33:51 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] flags Table options (\ref MDBX_DUPSORT, \ref MDBX_INTEGERKEY
|
2022-10-10 16:33:51 +03:00
|
|
|
|
* and so on). \see db_flags
|
|
|
|
|
*
|
|
|
|
|
* \returns The maximum size of a data can write,
|
|
|
|
|
* or -1 if something is wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_env_get_valsize4page_max(const MDBX_env *env, MDBX_db_flags_t flags);
|
2022-10-10 16:33:51 +03:00
|
|
|
|
|
2021-05-03 14:19:34 +03:00
|
|
|
|
/** \brief Sets application information (a context pointer) associated with
|
|
|
|
|
* the environment.
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* \see mdbx_env_get_userctx()
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_settings
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] ctx An arbitrary pointer for whatever the application needs.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2017-05-24 01:42:10 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_set_userctx(MDBX_env *env, void *ctx);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2021-05-03 14:19:34 +03:00
|
|
|
|
/** \brief Returns an application information (a context pointer) associated
|
|
|
|
|
* with the environment.
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* \see mdbx_env_set_userctx()
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create()
|
2020-09-29 14:41:44 +03:00
|
|
|
|
* \returns The pointer set by \ref mdbx_env_set_userctx()
|
|
|
|
|
* or `NULL` if something wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API void *mdbx_env_get_userctx(const MDBX_env *env);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-10-14 18:15:50 +03:00
|
|
|
|
/** \brief Create a transaction with a user provided context pointer
|
|
|
|
|
* for use with the environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* The transaction handle may be discarded using \ref mdbx_txn_abort()
|
|
|
|
|
* or \ref mdbx_txn_commit().
|
2020-10-14 18:15:50 +03:00
|
|
|
|
* \see mdbx_txn_begin()
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note A transaction and its cursors must only be used by a single thread,
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* and a thread may only have a single transaction at a time unless
|
|
|
|
|
* the \ref MDBX_NOSTICKYTHREADS is used.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note Cursors may not span transactions.
|
|
|
|
|
*
|
2020-10-14 18:15:50 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] parent If this parameter is non-NULL, the new transaction will
|
|
|
|
|
* be a nested transaction, with the transaction indicated
|
|
|
|
|
* by parent as its parent. Transactions may be nested
|
|
|
|
|
* to any level. A parent transaction and its cursors may
|
|
|
|
|
* not issue any other operations than mdbx_txn_commit and
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref mdbx_txn_abort() while it has active child
|
|
|
|
|
* transactions.
|
2020-10-14 18:15:50 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] flags Special options for this transaction. This parameter
|
|
|
|
|
* must be set to 0 or by bitwise OR'ing together one
|
|
|
|
|
* or more of the values described here:
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_RDONLY This transaction will not perform
|
|
|
|
|
* any write operations.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-08-02 20:52:36 +03:00
|
|
|
|
* - \ref MDBX_TXN_TRY Do not block when starting
|
|
|
|
|
* a write transaction.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-08-01 19:13:17 +03:00
|
|
|
|
* - \ref MDBX_SAFE_NOSYNC, \ref MDBX_NOMETASYNC.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* Do not sync data to disk corresponding
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* to \ref MDBX_NOMETASYNC or \ref MDBX_SAFE_NOSYNC
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* description. \see sync_modes
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \param [out] txn Address where the new \ref MDBX_txn handle
|
|
|
|
|
* will be stored.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-10-14 18:15:50 +03:00
|
|
|
|
* \param [in] context A pointer to application context to be associated with
|
|
|
|
|
* created transaction and could be retrieved by
|
|
|
|
|
* \ref mdbx_txn_get_userctx() until transaction finished.
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_PANIC A fatal error occurred earlier and the
|
|
|
|
|
* environment must be shut down.
|
|
|
|
|
* \retval MDBX_UNABLE_EXTEND_MAPSIZE Another process wrote data beyond
|
|
|
|
|
* this MDBX_env's mapsize and this
|
|
|
|
|
* environment map must be resized as well.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* See \ref mdbx_env_set_mapsize().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_READERS_FULL A read-only transaction was requested and
|
|
|
|
|
* the reader lock table is full.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* See \ref mdbx_env_set_maxreaders().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_ENOMEM Out of memory.
|
|
|
|
|
* \retval MDBX_BUSY The write transaction is already started by the
|
|
|
|
|
* current thread. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_begin_ex(MDBX_env *env, MDBX_txn *parent, MDBX_txn_flags_t flags, MDBX_txn **txn,
|
2020-10-14 18:15:50 +03:00
|
|
|
|
void *context);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-10-14 18:15:50 +03:00
|
|
|
|
/** \brief Create a transaction for use with the environment.
|
2020-09-29 14:41:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
|
|
|
|
*
|
|
|
|
|
* The transaction handle may be discarded using \ref mdbx_txn_abort()
|
|
|
|
|
* or \ref mdbx_txn_commit().
|
2020-10-14 18:15:50 +03:00
|
|
|
|
* \see mdbx_txn_begin_ex()
|
2020-09-29 14:41:44 +03:00
|
|
|
|
*
|
|
|
|
|
* \note A transaction and its cursors must only be used by a single thread,
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* and a thread may only have a single transaction at a time unless
|
|
|
|
|
* the \ref MDBX_NOSTICKYTHREADS is used.
|
2020-09-29 14:41:44 +03:00
|
|
|
|
*
|
|
|
|
|
* \note Cursors may not span transactions.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
|
|
|
|
*
|
|
|
|
|
* \param [in] parent If this parameter is non-NULL, the new transaction will
|
|
|
|
|
* be a nested transaction, with the transaction indicated
|
|
|
|
|
* by parent as its parent. Transactions may be nested
|
|
|
|
|
* to any level. A parent transaction and its cursors may
|
|
|
|
|
* not issue any other operations than mdbx_txn_commit and
|
|
|
|
|
* \ref mdbx_txn_abort() while it has active child
|
|
|
|
|
* transactions.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] flags Special options for this transaction. This parameter
|
|
|
|
|
* must be set to 0 or by bitwise OR'ing together one
|
|
|
|
|
* or more of the values described here:
|
|
|
|
|
* - \ref MDBX_RDONLY This transaction will not perform
|
|
|
|
|
* any write operations.
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_TXN_TRY Do not block when starting
|
|
|
|
|
* a write transaction.
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_SAFE_NOSYNC, \ref MDBX_NOMETASYNC.
|
|
|
|
|
* Do not sync data to disk corresponding
|
|
|
|
|
* to \ref MDBX_NOMETASYNC or \ref MDBX_SAFE_NOSYNC
|
|
|
|
|
* description. \see sync_modes
|
|
|
|
|
*
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \param [out] txn Address where the new \ref MDBX_txn handle
|
|
|
|
|
* will be stored.
|
2020-09-29 14:41:44 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_PANIC A fatal error occurred earlier and the
|
|
|
|
|
* environment must be shut down.
|
|
|
|
|
* \retval MDBX_UNABLE_EXTEND_MAPSIZE Another process wrote data beyond
|
|
|
|
|
* this MDBX_env's mapsize and this
|
|
|
|
|
* environment map must be resized as well.
|
|
|
|
|
* See \ref mdbx_env_set_mapsize().
|
|
|
|
|
* \retval MDBX_READERS_FULL A read-only transaction was requested and
|
|
|
|
|
* the reader lock table is full.
|
|
|
|
|
* See \ref mdbx_env_set_maxreaders().
|
|
|
|
|
* \retval MDBX_ENOMEM Out of memory.
|
|
|
|
|
* \retval MDBX_BUSY The write transaction is already started by the
|
|
|
|
|
* current thread. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_txn_begin, (MDBX_env * env, MDBX_txn *parent, MDBX_txn_flags_t flags, MDBX_txn **txn)) {
|
2020-10-14 18:15:50 +03:00
|
|
|
|
return mdbx_txn_begin_ex(env, parent, flags, txn, NULL);
|
|
|
|
|
}
|
2020-09-29 14:41:44 +03:00
|
|
|
|
|
2021-05-03 14:19:34 +03:00
|
|
|
|
/** \brief Sets application information associated (a context pointer) with the
|
|
|
|
|
* transaction.
|
2020-09-29 14:41:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
|
|
|
|
* \see mdbx_txn_get_userctx()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn An transaction handle returned by \ref mdbx_txn_begin_ex()
|
|
|
|
|
* or \ref mdbx_txn_begin().
|
|
|
|
|
* \param [in] ctx An arbitrary pointer for whatever the application needs.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_txn_set_userctx(MDBX_txn *txn, void *ctx);
|
|
|
|
|
|
2021-05-03 14:19:34 +03:00
|
|
|
|
/** \brief Returns an application information (a context pointer) associated
|
|
|
|
|
* with the transaction.
|
2020-09-29 14:41:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
|
|
|
|
* \see mdbx_txn_set_userctx()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn An transaction handle returned by \ref mdbx_txn_begin_ex()
|
|
|
|
|
* or \ref mdbx_txn_begin().
|
|
|
|
|
* \returns The pointer which was passed via the `context` parameter
|
|
|
|
|
* of `mdbx_txn_begin_ex()` or set by \ref mdbx_txn_set_userctx(),
|
|
|
|
|
* or `NULL` if something wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API void *mdbx_txn_get_userctx(const MDBX_txn *txn);
|
2020-09-29 14:41:44 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Information about the transaction
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see mdbx_txn_info */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
struct MDBX_txn_info {
|
|
|
|
|
/** The ID of the transaction. For a READ-ONLY transaction, this corresponds
|
|
|
|
|
to the snapshot being read. */
|
|
|
|
|
uint64_t txn_id;
|
|
|
|
|
|
2020-09-29 19:24:57 +03:00
|
|
|
|
/** For READ-ONLY transaction: the lag from a recent MVCC-snapshot, i.e. the
|
2020-10-24 01:04:49 +03:00
|
|
|
|
number of committed transaction since read transaction started.
|
|
|
|
|
For WRITE transaction (provided if `scan_rlt=true`): the lag of the oldest
|
|
|
|
|
reader from current transaction (i.e. at least 1 if any reader running). */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t txn_reader_lag;
|
|
|
|
|
|
|
|
|
|
/** Used space by this transaction, i.e. corresponding to the last used
|
|
|
|
|
* database page. */
|
|
|
|
|
uint64_t txn_space_used;
|
|
|
|
|
|
|
|
|
|
/** Current size of database file. */
|
|
|
|
|
uint64_t txn_space_limit_soft;
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** Upper bound for size the database file, i.e. the value `size_upper`
|
2020-09-21 23:51:47 -04:00
|
|
|
|
argument of the appropriate call of \ref mdbx_env_set_geometry(). */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t txn_space_limit_hard;
|
|
|
|
|
|
|
|
|
|
/** For READ-ONLY transaction: The total size of the database pages that were
|
|
|
|
|
retired by committed write transactions after the reader's MVCC-snapshot,
|
|
|
|
|
i.e. the space which would be freed after the Reader releases the
|
|
|
|
|
MVCC-snapshot for reuse by completion read transaction.
|
|
|
|
|
For WRITE transaction: The summarized size of the database pages that were
|
|
|
|
|
retired for now due Copy-On-Write during this transaction. */
|
|
|
|
|
uint64_t txn_space_retired;
|
|
|
|
|
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/** For READ-ONLY transaction: the space available for writer(s) and that
|
2020-09-29 19:24:57 +03:00
|
|
|
|
must be exhausted for reason to call the Handle-Slow-Readers callback for
|
2020-10-24 01:04:49 +03:00
|
|
|
|
this read transaction.
|
|
|
|
|
For WRITE transaction: the space inside transaction
|
2020-09-29 19:24:57 +03:00
|
|
|
|
that left to `MDBX_TXN_FULL` error. */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
uint64_t txn_space_leftover;
|
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** For READ-ONLY transaction (provided if `scan_rlt=true`): The space that
|
2020-07-23 19:24:21 +03:00
|
|
|
|
actually become available for reuse when only this transaction will be
|
|
|
|
|
finished.
|
|
|
|
|
For WRITE transaction: The summarized size of the dirty database
|
|
|
|
|
pages that generated during this transaction. */
|
|
|
|
|
uint64_t txn_space_dirty;
|
|
|
|
|
};
|
|
|
|
|
#ifndef __cplusplus
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/** \ingroup c_statinfo */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
typedef struct MDBX_txn_info MDBX_txn_info;
|
|
|
|
|
#endif
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return information about the MDBX transaction.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin()
|
|
|
|
|
* \param [out] info The address of an \ref MDBX_txn_info structure
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* where the information will be copied.
|
|
|
|
|
* \param [in] scan_rlt The boolean flag controls the scan of the read lock
|
|
|
|
|
* table to provide complete information. Such scan
|
|
|
|
|
* is relatively expensive and you can avoid it
|
|
|
|
|
* if corresponding fields are not needed.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* See description of \ref MDBX_txn_info.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_info(const MDBX_txn *txn, MDBX_txn_info *info, bool scan_rlt);
|
2019-09-21 13:08:23 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns the transaction's MDBX_env.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API MDBX_env *mdbx_txn_env(const MDBX_txn *txn);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return the transaction's flags.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2018-03-19 17:03:41 +03:00
|
|
|
|
*
|
2022-05-02 10:35:40 +03:00
|
|
|
|
* This returns the flags, including internal, associated with this transaction.
|
2018-03-19 17:03:41 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2018-03-19 17:03:41 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A transaction flags, valid if input is an valid transaction,
|
2023-10-11 12:27:31 +03:00
|
|
|
|
* otherwise \ref MDBX_TXN_INVALID. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API MDBX_txn_flags_t mdbx_txn_flags(const MDBX_txn *txn);
|
2018-03-19 17:03:41 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return the transaction's ID.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* This returns the identifier associated with this transaction. For a
|
|
|
|
|
* read-only transaction, this corresponds to the snapshot being read;
|
|
|
|
|
* concurrent readers will frequently have the same transaction ID.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A transaction ID, valid if input is an active transaction,
|
|
|
|
|
* otherwise 0. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API uint64_t mdbx_txn_id(const MDBX_txn *txn);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-10-15 19:23:14 +03:00
|
|
|
|
/** \brief Latency of commit stages in 1/65536 of seconds units.
|
|
|
|
|
* \warning This structure may be changed in future releases.
|
2022-04-30 15:52:37 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-10-15 19:23:14 +03:00
|
|
|
|
* \see mdbx_txn_commit_ex() */
|
|
|
|
|
struct MDBX_commit_latency {
|
|
|
|
|
/** \brief Duration of preparation (commit child transactions, update
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table's records and cursors destroying). */
|
2020-10-15 19:23:14 +03:00
|
|
|
|
uint32_t preparation;
|
2022-11-06 16:35:06 +03:00
|
|
|
|
/** \brief Duration of GC update by wall clock. */
|
|
|
|
|
uint32_t gc_wallclock;
|
2020-10-15 19:23:14 +03:00
|
|
|
|
/** \brief Duration of internal audit if enabled. */
|
|
|
|
|
uint32_t audit;
|
2021-11-19 18:36:14 +03:00
|
|
|
|
/** \brief Duration of writing dirty/modified data pages to a filesystem,
|
|
|
|
|
* i.e. the summary duration of a `write()` syscalls during commit. */
|
2020-10-15 19:23:14 +03:00
|
|
|
|
uint32_t write;
|
2021-11-19 18:36:14 +03:00
|
|
|
|
/** \brief Duration of syncing written data to the disk/storage, i.e.
|
|
|
|
|
* the duration of a `fdatasync()` or a `msync()` syscall during commit. */
|
2020-10-15 19:23:14 +03:00
|
|
|
|
uint32_t sync;
|
|
|
|
|
/** \brief Duration of transaction ending (releasing resources). */
|
|
|
|
|
uint32_t ending;
|
|
|
|
|
/** \brief The total duration of a commit. */
|
|
|
|
|
uint32_t whole;
|
2022-11-06 16:35:06 +03:00
|
|
|
|
/** \brief User-mode CPU time spent on GC update. */
|
|
|
|
|
uint32_t gc_cputime;
|
|
|
|
|
|
|
|
|
|
/** \brief Информация для профилирования работы GC.
|
|
|
|
|
* \note Статистика является общей для всех процессов работающих с одним
|
|
|
|
|
* файлом БД и хранится в LCK-файле. Данные аккумулируются при фиксации всех
|
|
|
|
|
* транзакций, но только в сборках libmdbx c установленной опцией
|
|
|
|
|
* \ref MDBX_ENABLE_PROFGC. Собранная статистика возвращаются любому процессу
|
|
|
|
|
* при использовании \ref mdbx_txn_commit_ex() и одновременно обнуляется
|
|
|
|
|
* при завершении транзакций верхнего уровня (не вложенных). */
|
|
|
|
|
struct {
|
|
|
|
|
/** \brief Количество итераций обновления GC,
|
|
|
|
|
* больше 1 если были повторы/перезапуски. */
|
|
|
|
|
uint32_t wloops;
|
|
|
|
|
/** \brief Количество итераций слияния записей GC. */
|
|
|
|
|
uint32_t coalescences;
|
|
|
|
|
/** \brief Количество уничтожений предыдущих надежных/устойчивых
|
|
|
|
|
* точек фиксации при работе в режиме \ref MDBX_UTTERLY_NOSYNC. */
|
|
|
|
|
uint32_t wipes;
|
|
|
|
|
/** \brief Количество принудительных фиксаций на диск
|
|
|
|
|
* во избежания приращения БД при работе вне режима
|
|
|
|
|
* \ref MDBX_UTTERLY_NOSYNC. */
|
|
|
|
|
uint32_t flushes;
|
|
|
|
|
/** \brief Количество обращений к механизму Handle-Slow-Readers
|
|
|
|
|
* во избежания приращения БД.
|
|
|
|
|
* \see MDBX_hsr_func */
|
|
|
|
|
uint32_t kicks;
|
|
|
|
|
|
|
|
|
|
/** \brief Счетчик выполнения по медленному пути (slow path execution count)
|
|
|
|
|
* GC ради данных пользователя. */
|
|
|
|
|
uint32_t work_counter;
|
|
|
|
|
/** \brief Время "по настенным часам" затраченное на чтение и поиск внутри
|
|
|
|
|
* GC ради данных пользователя. */
|
|
|
|
|
uint32_t work_rtime_monotonic;
|
2022-12-03 15:35:27 +03:00
|
|
|
|
/** \brief Время ЦПУ в режиме пользователе затраченное
|
2022-11-06 16:35:06 +03:00
|
|
|
|
* на подготовку страниц извлекаемых из GC для данных пользователя,
|
|
|
|
|
* включая подкачку с диска. */
|
2022-12-03 15:35:27 +03:00
|
|
|
|
uint32_t work_xtime_cpu;
|
2022-11-06 16:35:06 +03:00
|
|
|
|
/** \brief Количество итераций поиска внутри GC при выделении страниц
|
|
|
|
|
* ради данных пользователя. */
|
|
|
|
|
uint32_t work_rsteps;
|
|
|
|
|
/** \brief Количество запросов на выделение последовательностей страниц
|
|
|
|
|
* ради данных пользователя. */
|
|
|
|
|
uint32_t work_xpages;
|
|
|
|
|
/** \brief Количество страничных промахов (page faults) внутри GC
|
|
|
|
|
* при выделении и подготовки страниц для данных пользователя. */
|
|
|
|
|
uint32_t work_majflt;
|
|
|
|
|
|
|
|
|
|
/** \brief Счетчик выполнения по медленному пути (slow path execution count)
|
|
|
|
|
* GC для целей поддержки и обновления самой GC. */
|
|
|
|
|
uint32_t self_counter;
|
|
|
|
|
/** \brief Время "по настенным часам" затраченное на чтение и поиск внутри
|
|
|
|
|
* GC для целей поддержки и обновления самой GC. */
|
|
|
|
|
uint32_t self_rtime_monotonic;
|
2022-12-03 15:35:27 +03:00
|
|
|
|
/** \brief Время ЦПУ в режиме пользователе затраченное на подготовку
|
2022-11-06 16:35:06 +03:00
|
|
|
|
* страниц извлекаемых из GC для целей поддержки и обновления самой GC,
|
|
|
|
|
* включая подкачку с диска. */
|
2022-12-03 15:35:27 +03:00
|
|
|
|
uint32_t self_xtime_cpu;
|
2022-11-06 16:35:06 +03:00
|
|
|
|
/** \brief Количество итераций поиска внутри GC при выделении страниц
|
|
|
|
|
* для целей поддержки и обновления самой GC. */
|
|
|
|
|
uint32_t self_rsteps;
|
|
|
|
|
/** \brief Количество запросов на выделение последовательностей страниц
|
|
|
|
|
* для самой GC. */
|
|
|
|
|
uint32_t self_xpages;
|
|
|
|
|
/** \brief Количество страничных промахов (page faults) внутри GC
|
|
|
|
|
* при выделении и подготовки страниц для самой GC. */
|
|
|
|
|
uint32_t self_majflt;
|
2024-12-16 16:43:49 +03:00
|
|
|
|
/* Для разборок с pnl_merge() */
|
|
|
|
|
struct {
|
|
|
|
|
uint32_t time;
|
|
|
|
|
uint64_t volume;
|
|
|
|
|
uint32_t calls;
|
|
|
|
|
} pnl_merge_work, pnl_merge_self;
|
2022-11-06 16:35:06 +03:00
|
|
|
|
} gc_prof;
|
2020-10-15 19:23:14 +03:00
|
|
|
|
};
|
|
|
|
|
#ifndef __cplusplus
|
|
|
|
|
/** \ingroup c_statinfo */
|
|
|
|
|
typedef struct MDBX_commit_latency MDBX_commit_latency;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/** \brief Commit all the operations of a transaction into the database and
|
|
|
|
|
* collect latency information.
|
|
|
|
|
* \see mdbx_txn_commit()
|
2022-04-30 15:52:37 +03:00
|
|
|
|
* \ingroup c_transactions
|
2020-10-15 19:23:14 +03:00
|
|
|
|
* \warning This function may be changed in future releases. */
|
|
|
|
|
LIBMDBX_API int mdbx_txn_commit_ex(MDBX_txn *txn, MDBX_commit_latency *latency);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Commit all the operations of a transaction into the database.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-04-24 12:37:29 +03:00
|
|
|
|
* If the current thread is not eligible to manage the transaction then
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* the \ref MDBX_THREAD_MISMATCH error will returned. Otherwise the transaction
|
2020-04-24 12:37:29 +03:00
|
|
|
|
* will be committed and its handle is freed. If the transaction cannot
|
|
|
|
|
* be committed, it will be aborted with the corresponding error returned.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Thus, a result other than \ref MDBX_THREAD_MISMATCH means that the
|
|
|
|
|
* transaction is terminated:
|
2020-04-24 12:37:29 +03:00
|
|
|
|
* - Resources are released;
|
|
|
|
|
* - Transaction handle is invalid;
|
|
|
|
|
* - Cursor(s) associated with transaction must not be used, except with
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* mdbx_cursor_renew() and \ref mdbx_cursor_close().
|
|
|
|
|
* Such cursor(s) must be closed explicitly by \ref mdbx_cursor_close()
|
|
|
|
|
* before or after transaction commit, either can be reused with
|
|
|
|
|
* \ref mdbx_cursor_renew() until it will be explicitly closed by
|
|
|
|
|
* \ref mdbx_cursor_close().
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_RESULT_TRUE Transaction was aborted since it should
|
|
|
|
|
* be aborted due to previous errors.
|
|
|
|
|
* \retval MDBX_PANIC A fatal error occurred earlier
|
|
|
|
|
* and the environment must be shut down.
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* \retval MDBX_BAD_TXN Transaction is already finished or never began.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_EBADSIGN Transaction object has invalid signature,
|
|
|
|
|
* e.g. transaction was already terminated
|
|
|
|
|
* or memory was corrupted.
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL Transaction handle is NULL.
|
|
|
|
|
* \retval MDBX_ENOSPC No more disk space.
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \retval MDBX_EIO An error occurred during the flushing/writing
|
|
|
|
|
* data to a storage medium/disk.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_ENOMEM Out of memory. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_txn_commit, (MDBX_txn * txn)) { return mdbx_txn_commit_ex(txn, NULL); }
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Abandon all the operations of the transaction instead of saving them.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* The transaction handle is freed. It and its cursors must not be used again
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* after this call, except with \ref mdbx_cursor_renew() and
|
|
|
|
|
* \ref mdbx_cursor_close().
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-04-24 12:37:29 +03:00
|
|
|
|
* If the current thread is not eligible to manage the transaction then
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* the \ref MDBX_THREAD_MISMATCH error will returned. Otherwise the transaction
|
2020-04-24 12:37:29 +03:00
|
|
|
|
* will be aborted and its handle is freed. Thus, a result other than
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref MDBX_THREAD_MISMATCH means that the transaction is terminated:
|
2020-04-24 12:37:29 +03:00
|
|
|
|
* - Resources are released;
|
|
|
|
|
* - Transaction handle is invalid;
|
|
|
|
|
* - Cursor(s) associated with transaction must not be used, except with
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref mdbx_cursor_renew() and \ref mdbx_cursor_close().
|
|
|
|
|
* Such cursor(s) must be closed explicitly by \ref mdbx_cursor_close()
|
|
|
|
|
* before or after transaction abort, either can be reused with
|
|
|
|
|
* \ref mdbx_cursor_renew() until it will be explicitly closed by
|
|
|
|
|
* \ref mdbx_cursor_close().
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_PANIC A fatal error occurred earlier and
|
|
|
|
|
* the environment must be shut down.
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* \retval MDBX_BAD_TXN Transaction is already finished or never began.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_EBADSIGN Transaction object has invalid signature,
|
|
|
|
|
* e.g. transaction was already terminated
|
|
|
|
|
* or memory was corrupted.
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL Transaction handle is NULL. */
|
2017-05-23 21:36:09 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_abort(MDBX_txn *txn);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Marks transaction as broken.
|
2020-08-28 20:30:01 +03:00
|
|
|
|
* \ingroup c_transactions
|
|
|
|
|
*
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* Function keeps the transaction handle and corresponding locks, but makes
|
|
|
|
|
* impossible to perform any operations within a broken transaction.
|
2020-08-28 20:30:01 +03:00
|
|
|
|
* Broken transaction must then be aborted explicitly later.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_txn_abort() \see mdbx_txn_reset() \see mdbx_txn_commit()
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_txn_break(MDBX_txn *txn);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Reset a read-only transaction.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Abort the read-only transaction like \ref mdbx_txn_abort(), but keep the
|
|
|
|
|
* transaction handle. Therefore \ref mdbx_txn_renew() may reuse the handle.
|
|
|
|
|
* This saves allocation overhead if the process will start a new read-only
|
2024-04-02 00:22:09 +03:00
|
|
|
|
* transaction soon, and also locking overhead if \ref MDBX_NOSTICKYTHREADS is
|
|
|
|
|
* in use. The reader table lock is released, but the table slot stays tied to
|
|
|
|
|
* its thread or \ref MDBX_txn. Use \ref mdbx_txn_abort() to discard a reset
|
2024-07-09 16:04:01 +03:00
|
|
|
|
* handle, and to free its lock table slot if \ref MDBX_NOSTICKYTHREADS
|
|
|
|
|
* is in use.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* Cursors opened within the transaction must not be used again after this
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* call, except with \ref mdbx_cursor_renew() and \ref mdbx_cursor_close().
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* Reader locks generally don't interfere with writers, but they keep old
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* versions of database pages allocated. Thus they prevent the old pages from
|
|
|
|
|
* being reused when writers commit new data, and so under heavy load the
|
|
|
|
|
* database size may grow much more rapidly than otherwise.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_PANIC A fatal error occurred earlier and
|
|
|
|
|
* the environment must be shut down.
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* \retval MDBX_BAD_TXN Transaction is already finished or never began.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_EBADSIGN Transaction object has invalid signature,
|
|
|
|
|
* e.g. transaction was already terminated
|
|
|
|
|
* or memory was corrupted.
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL Transaction handle is NULL. */
|
2017-05-23 21:36:09 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_reset(MDBX_txn *txn);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-07-09 16:04:01 +03:00
|
|
|
|
/** \brief Переводит читающую транзакцию в "припаркованное" состояние.
|
|
|
|
|
* \ingroup c_transactions
|
|
|
|
|
*
|
|
|
|
|
* Выполняющиеся читающие транзакции не позволяют перерабатывать старые
|
|
|
|
|
* MVCC-снимки данных, начиная с самой старой используемой/читаемой версии и все
|
|
|
|
|
* последующие. Припаркованная же транзакция может быть вытеснена транзакцией
|
|
|
|
|
* записи, если будет мешать переработке мусора (старых MVCC-снимков данных).
|
|
|
|
|
* А если вытеснения не произойдет, то восстановление (перевод в рабочее
|
|
|
|
|
* состояние и продолжение выполнение) читающей транзакции будет существенно
|
|
|
|
|
* дешевле. Таким образом, парковка транзакций позволяет предотвратить
|
|
|
|
|
* негативные последствия связанные с остановкой переработки мусора,
|
|
|
|
|
* одновременно сохранив накладные расходы на минимальном уровне.
|
|
|
|
|
*
|
|
|
|
|
* Для продолжения выполнения (чтения и/или использования данных) припаркованная
|
|
|
|
|
* транзакция должна быть восстановлена посредством \ref mdbx_txn_unpark().
|
|
|
|
|
* Для удобства использования и предотвращения лишних вызовов API, посредством
|
|
|
|
|
* параметра `autounpark`, предусмотрена возможность автоматической
|
|
|
|
|
* «распарковки» при использовании припаркованной транзакции в функциях API
|
|
|
|
|
* предполагающих чтение данных.
|
|
|
|
|
*
|
|
|
|
|
* \warning До восстановления/распарковки транзакции, вне зависимости от
|
|
|
|
|
* аргумента `autounpark`, нельзя допускать разыменования указателей полученных
|
|
|
|
|
* ранее при чтении данных в рамках припаркованной транзакции, так как
|
|
|
|
|
* MVCC-снимок в котором размещены эти данные не удерживается и может
|
|
|
|
|
* переработан в любой момент.
|
|
|
|
|
*
|
|
|
|
|
* Припаркованная транзакция без "распарковки" может быть прервана, сброшена
|
|
|
|
|
* или перезапущена в любой момент посредством \ref mdbx_txn_abort(),
|
|
|
|
|
* \ref mdbx_txn_reset() и \ref mdbx_txn_renew(), соответственно.
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_txn_unpark()
|
|
|
|
|
* \see mdbx_txn_flags()
|
2024-07-13 17:03:06 +03:00
|
|
|
|
* \see mdbx_env_set_hsr()
|
|
|
|
|
* \see <a href="intro.html#long-lived-read">Long-lived read transactions</a>
|
2024-07-09 16:04:01 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] txn Транзакция чтения запущенная посредством
|
|
|
|
|
* \ref mdbx_txn_begin().
|
|
|
|
|
*
|
|
|
|
|
* \param [in] autounpark Позволяет включить автоматическую
|
|
|
|
|
* распарковку/восстановление транзакции при вызове
|
|
|
|
|
* функций API предполагающих чтение данных.
|
|
|
|
|
*
|
|
|
|
|
* \returns Ненулевое значение кода ошибки, либо 0 при успешном выполнении. */
|
|
|
|
|
LIBMDBX_API int mdbx_txn_park(MDBX_txn *txn, bool autounpark);
|
|
|
|
|
|
|
|
|
|
/** \brief Распарковывает ранее припаркованную читающую транзакцию.
|
|
|
|
|
* \ingroup c_transactions
|
|
|
|
|
*
|
|
|
|
|
* Функция пытается восстановить ранее припаркованную транзакцию. Если
|
|
|
|
|
* припаркованная транзакция была вытеснена ради переработки старых
|
|
|
|
|
* MVCC-снимков, то в зависимости от аргумента `restart_if_ousted` выполняется
|
|
|
|
|
* её перезапуск аналогично \ref mdbx_txn_renew(), либо транзакция сбрасывается
|
|
|
|
|
* и возвращается код ошибки \ref MDBX_OUSTED.
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_txn_park()
|
|
|
|
|
* \see mdbx_txn_flags()
|
2024-07-13 17:03:06 +03:00
|
|
|
|
* \see <a href="intro.html#long-lived-read">Long-lived read transactions</a>
|
2024-07-09 16:04:01 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] txn Транзакция чтения запущенная посредством
|
|
|
|
|
* \ref mdbx_txn_begin() и затем припаркованная
|
|
|
|
|
* посредством \ref mdbx_txn_park.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] restart_if_ousted Позволяет сразу выполнить перезапуск
|
|
|
|
|
* транзакции, если она была вынестена.
|
|
|
|
|
*
|
|
|
|
|
* \returns Ненулевое значение кода ошибки, либо 0 при успешном выполнении.
|
|
|
|
|
* Некоторые специфичекие коды результата:
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_SUCCESS Припаркованная транзакция успешно восстановлена,
|
|
|
|
|
* либо она не была припаркована.
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_OUSTED Читающая транзакция была вытеснена пишущей
|
|
|
|
|
* транзакцией ради переработки старых MVCC-снимков,
|
|
|
|
|
* а аргумент `restart_if_ousted` был задан `false`.
|
|
|
|
|
* Транзакция сбрасывается в состояние аналогичное
|
|
|
|
|
* после вызова \ref mdbx_txn_reset(), но экземпляр
|
|
|
|
|
* (хендл) не освобождается и может быть использован
|
|
|
|
|
* повторно посредством \ref mdbx_txn_renew(), либо
|
|
|
|
|
* освобожден посредством \ref mdbx_txn_abort().
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_RESULT_TRUE Читающая транзакция была вынеснена, но теперь
|
|
|
|
|
* перезапущена для чтения другого (последнего)
|
|
|
|
|
* MVCC-снимка, так как restart_if_ousted` был задан
|
|
|
|
|
* `true`.
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_BAD_TXN Транзакция уже завершена, либо не была запущена. */
|
|
|
|
|
LIBMDBX_API int mdbx_txn_unpark(MDBX_txn *txn, bool restart_if_ousted);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Renew a read-only transaction.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_transactions
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
|
|
|
|
* This acquires a new reader lock for a transaction handle that had been
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* released by \ref mdbx_txn_reset(). It must be called before a reset
|
|
|
|
|
* transaction may be used again.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_PANIC A fatal error occurred earlier and
|
|
|
|
|
* the environment must be shut down.
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* \retval MDBX_BAD_TXN Transaction is already finished or never began.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_EBADSIGN Transaction object has invalid signature,
|
|
|
|
|
* e.g. transaction was already terminated
|
|
|
|
|
* or memory was corrupted.
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL Transaction handle is NULL. */
|
2017-05-23 21:36:09 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_renew(MDBX_txn *txn);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The fours integers markers (aka "canary") associated with the
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* environment.
|
|
|
|
|
* \ingroup c_crud
|
2023-06-01 08:47:02 +03:00
|
|
|
|
* \see mdbx_canary_put()
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* \see mdbx_canary_get()
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* The `x`, `y` and `z` values could be set by \ref mdbx_canary_put(), while the
|
|
|
|
|
* 'v' will be always set to the transaction number. Updated values becomes
|
|
|
|
|
* visible outside the current transaction only after it was committed. Current
|
|
|
|
|
* values could be retrieved by \ref mdbx_canary_get(). */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
struct MDBX_canary {
|
2019-09-18 04:00:16 +03:00
|
|
|
|
uint64_t x, y, z, v;
|
2020-07-23 19:24:21 +03:00
|
|
|
|
};
|
|
|
|
|
#ifndef __cplusplus
|
2020-07-25 04:30:44 +03:00
|
|
|
|
/** \ingroup c_crud */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
typedef struct MDBX_canary MDBX_canary;
|
|
|
|
|
#endif
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Set integers markers (aka "canary") associated with the environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \see mdbx_canary_get()
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin()
|
|
|
|
|
* \param [in] canary A optional pointer to \ref MDBX_canary structure for `x`,
|
|
|
|
|
* `y` and `z` values from.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* - If canary is NOT NULL then the `x`, `y` and `z` values will be
|
|
|
|
|
* updated from given canary argument, but the 'v' be always set
|
|
|
|
|
* to the current transaction number if at least one `x`, `y` or
|
|
|
|
|
* `z` values have changed (i.e. if `x`, `y` and `z` have the same
|
|
|
|
|
* values as currently present then nothing will be changes or
|
|
|
|
|
* updated).
|
|
|
|
|
* - if canary is NULL then the `v` value will be explicitly update
|
|
|
|
|
* to the current transaction number without changes `x`, `y` nor
|
|
|
|
|
* `z`.
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_canary_put(MDBX_txn *txn, const MDBX_canary *canary);
|
2019-09-26 20:00:22 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns fours integers markers (aka "canary") associated with the
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2023-06-01 08:47:02 +03:00
|
|
|
|
* \see mdbx_canary_put()
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2023-06-01 08:47:02 +03:00
|
|
|
|
* \param [in] canary The address of an \ref MDBX_canary structure where the
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* information will be copied.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_canary_get(const MDBX_txn *txn, MDBX_canary *canary);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief A callback function used to compare two keys in a table
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_crud
|
|
|
|
|
* \see mdbx_cmp() \see mdbx_get_keycmp()
|
2021-07-20 01:50:54 +03:00
|
|
|
|
* \see mdbx_get_datacmp \see mdbx_dcmp()
|
|
|
|
|
*
|
|
|
|
|
* \anchor avoid_custom_comparators
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \deprecated It is recommend not using custom comparison functions, but
|
|
|
|
|
* instead converting the keys to one of the forms that are suitable for
|
|
|
|
|
* built-in comparators (for instance take look to the \ref value2key).
|
2021-07-20 01:50:54 +03:00
|
|
|
|
* The reasons to not using custom comparators are:
|
|
|
|
|
* - The order of records could not be validated without your code.
|
|
|
|
|
* So `mdbx_chk` utility will reports "wrong order" errors
|
2021-11-26 23:46:50 +03:00
|
|
|
|
* and the `-i` option is required to suppress ones.
|
2021-07-20 01:50:54 +03:00
|
|
|
|
* - A records could not be ordered or sorted without your code.
|
2021-11-26 23:46:50 +03:00
|
|
|
|
* So `mdbx_load` utility should be used with `-a` option to preserve
|
|
|
|
|
* input data order.
|
|
|
|
|
* - However, the custom comparators feature will never be removed.
|
|
|
|
|
* You have been warned but still can use custom comparators knowing
|
|
|
|
|
* about the issues noted above. In this case you should ignore `deprecated`
|
|
|
|
|
* warnings or define `MDBX_DEPRECATED` macro to empty to avoid ones. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef int(MDBX_cmp_func)(const MDBX_val *a, const MDBX_val *b) MDBX_CXX17_NOEXCEPT;
|
2019-09-24 02:07:00 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Open or Create a named table in the environment.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_dbi
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* A table handle denotes the name and parameters of a table,
|
|
|
|
|
* independently of whether such a table exists. The table handle may be
|
|
|
|
|
* discarded by calling \ref mdbx_dbi_close(). The old table handle is
|
|
|
|
|
* returned if the table was already open. The handle may only be closed
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* once.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-21 01:24:29 +03:00
|
|
|
|
* \note A notable difference between MDBX and LMDB is that MDBX make handles
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* opened for existing tables immediately available for other transactions,
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* regardless this transaction will be aborted or reset. The REASON for this is
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* to avoiding the requirement for multiple opening a same handles in
|
|
|
|
|
* concurrent read transactions, and tracking of such open but hidden handles
|
|
|
|
|
* until the completion of read transactions which opened them.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Nevertheless, the handle for the NEWLY CREATED table will be invisible
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* for other transactions until the this write transaction is successfully
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* committed. If the write transaction is aborted the handle will be closed
|
|
|
|
|
* automatically. After a successful commit the such handle will reside in the
|
|
|
|
|
* shared environment, and may be used by other transactions.
|
|
|
|
|
*
|
|
|
|
|
* In contrast to LMDB, the MDBX allow this function to be called from multiple
|
|
|
|
|
* concurrent transactions or threads in the same process.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* To use named table (with name != NULL), \ref mdbx_env_set_maxdbs()
|
2017-05-17 20:06:57 +03:00
|
|
|
|
* must be called before opening the environment. Table names are
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* keys in the internal unnamed table, and may be read but not written.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] name The name of the table to open. If only a single
|
|
|
|
|
* table is needed in the environment,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* this value may be NULL.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] flags Special options for this table. This parameter must
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* be bitwise OR'ing together any of the constants
|
|
|
|
|
* described here:
|
|
|
|
|
*
|
|
|
|
|
* - \ref MDBX_DB_DEFAULTS
|
|
|
|
|
* Keys are arbitrary byte strings and compared from beginning to end.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_REVERSEKEY
|
2022-04-13 11:04:23 +03:00
|
|
|
|
* Keys are arbitrary byte strings to be compared in reverse order,
|
|
|
|
|
* from the end of the strings to the beginning.
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* - \ref MDBX_INTEGERKEY
|
|
|
|
|
* Keys are binary integers in native byte order, either uint32_t or
|
|
|
|
|
* uint64_t, and will be sorted as such. The keys must all be of the
|
|
|
|
|
* same size and must be aligned while passing as arguments.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_DUPSORT
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Duplicate keys may be used in the table. Or, from another point of
|
2017-05-17 20:06:57 +03:00
|
|
|
|
* view, keys may have multiple data items, stored in sorted order. By
|
|
|
|
|
* default keys must be unique and may have only a single data item.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_DUPFIXED
|
|
|
|
|
* This flag may only be used in combination with \ref MDBX_DUPSORT. This
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* option tells the library that the data items for this table are
|
2017-05-17 20:06:57 +03:00
|
|
|
|
* all the same size, which allows further optimizations in storage and
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* retrieval. When all data items are the same size, the
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref MDBX_GET_MULTIPLE, \ref MDBX_NEXT_MULTIPLE and
|
|
|
|
|
* \ref MDBX_PREV_MULTIPLE cursor operations may be used to retrieve
|
|
|
|
|
* multiple items at once.
|
|
|
|
|
* - \ref MDBX_INTEGERDUP
|
2017-05-17 20:06:57 +03:00
|
|
|
|
* This option specifies that duplicate data items are binary integers,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* similar to \ref MDBX_INTEGERKEY keys. The data values must all be of the
|
2020-01-26 14:26:00 +03:00
|
|
|
|
* same size and must be aligned while passing as arguments.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_REVERSEDUP
|
2017-05-17 20:06:57 +03:00
|
|
|
|
* This option specifies that duplicate data items should be compared as
|
|
|
|
|
* strings in reverse order (the comparison is performed in the direction
|
|
|
|
|
* from the last byte to the first).
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_CREATE
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Create the named table if it doesn't exist. This option is not
|
2017-05-17 20:06:57 +03:00
|
|
|
|
* allowed in a read-only transaction or a read-only environment.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [out] dbi Address where the new \ref MDBX_dbi handle
|
|
|
|
|
* will be stored.
|
2020-01-22 03:43:09 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* For \ref mdbx_dbi_open_ex() additional arguments allow you to set custom
|
2020-01-22 03:43:09 +03:00
|
|
|
|
* comparison functions for keys and values (for multimaps).
|
2021-07-20 01:50:54 +03:00
|
|
|
|
* \see avoid_custom_comparators
|
2020-01-22 03:43:09 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_NOTFOUND The specified table doesn't exist in the
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* environment and \ref MDBX_CREATE was not specified.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_DBS_FULL Too many tables have been opened.
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \see mdbx_env_set_maxdbs()
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_INCOMPATIBLE Table is incompatible with given flags,
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* i.e. the passed flags is different with which the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table was created, or the table was already
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* opened with a different comparison function(s).
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_open(MDBX_txn *txn, const char *name, MDBX_db_flags_t flags, MDBX_dbi *dbi);
|
2024-08-03 12:48:23 +03:00
|
|
|
|
/** \copydoc mdbx_dbi_open()
|
|
|
|
|
* \ingroup c_dbi */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_open2(MDBX_txn *txn, const MDBX_val *name, MDBX_db_flags_t flags, MDBX_dbi *dbi);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 12:48:23 +03:00
|
|
|
|
/** \brief Open or Create a named table in the environment
|
|
|
|
|
* with using custom comparison functions.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_dbi
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2024-08-03 12:48:23 +03:00
|
|
|
|
* \deprecated Please \ref avoid_custom_comparators
|
|
|
|
|
* "avoid using custom comparators" and use \ref mdbx_dbi_open() instead.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] name The name of the table to open. If only a single
|
|
|
|
|
* table is needed in the environment,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* this value may be NULL.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] flags Special options for this table.
|
|
|
|
|
* \param [in] keycmp Optional custom key comparison function for a table.
|
|
|
|
|
* \param [in] datacmp Optional custom data comparison function for a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \param [out] dbi Address where the new MDBX_dbi handle will be stored.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DEPRECATED 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);
|
2024-08-03 12:48:23 +03:00
|
|
|
|
/** \copydoc mdbx_dbi_open_ex()
|
|
|
|
|
* \ingroup c_dbi */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DEPRECATED 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);
|
2020-07-25 04:30:44 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Переименовает таблицу по DBI-дескриптору
|
|
|
|
|
*
|
2024-03-21 22:01:07 +03:00
|
|
|
|
* \ingroup c_dbi
|
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Переименовывает пользовательскую именованную таблицу связанную с передаваемым
|
2024-03-21 22:01:07 +03:00
|
|
|
|
* DBI-дескриптором.
|
|
|
|
|
*
|
|
|
|
|
* \param [in,out] txn Пишущая транзакция запущенная посредством
|
|
|
|
|
* \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi Дескриптор таблицы
|
2024-03-21 22:01:07 +03:00
|
|
|
|
* открытый посредством \ref mdbx_dbi_open().
|
|
|
|
|
*
|
|
|
|
|
* \param [in] name Новое имя для переименования.
|
|
|
|
|
*
|
2024-07-05 20:33:43 +03:00
|
|
|
|
* \returns Ненулевое значение кода ошибки, либо 0 при успешном выполнении. */
|
2023-11-01 01:07:01 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_rename(MDBX_txn *txn, MDBX_dbi dbi, const char *name);
|
2024-08-03 12:48:23 +03:00
|
|
|
|
/** \copydoc mdbx_dbi_rename()
|
|
|
|
|
* \ingroup c_dbi */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_rename2(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *name);
|
2023-11-01 01:07:01 +03:00
|
|
|
|
|
2024-07-05 00:25:28 +03:00
|
|
|
|
/** \brief Функция обратного вызова для перечисления
|
|
|
|
|
* пользовательских именованных таблиц.
|
|
|
|
|
*
|
|
|
|
|
* \ingroup c_statinfo
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \see mdbx_enumerate_tables()
|
2024-07-05 00:25:28 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] ctx Указатель на контекст переданный аналогичным
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* параметром в \ref mdbx_enumerate_tables().
|
2024-07-05 00:25:28 +03:00
|
|
|
|
* \param [in] txn Транзазакция.
|
|
|
|
|
* \param [in] name Имя таблицы.
|
|
|
|
|
* \param [in] flags Флаги \ref MDBX_db_flags_t.
|
|
|
|
|
* \param [in] stat Базовая информация \ref MDBX_stat о таблице.
|
|
|
|
|
* \param [in] dbi Отличное от 0 значение DBI-дескриптора,
|
|
|
|
|
* если таковой был открыт для этой таблицы.
|
|
|
|
|
* Либо 0 если такого открытого дескриптора нет.
|
|
|
|
|
*
|
|
|
|
|
* \returns Ноль при успехе и продолжении перечисления, при возвращении другого
|
|
|
|
|
* значения оно будет немедленно возвращено вызывающему
|
|
|
|
|
* без продолжения перечисления. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef 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) MDBX_CXX17_NOEXCEPT;
|
2024-07-05 00:25:28 +03:00
|
|
|
|
|
2024-07-13 16:13:11 +03:00
|
|
|
|
/** \brief Перечисляет пользовательские именнованные таблицы.
|
|
|
|
|
*
|
|
|
|
|
* Производит перечисление пользовательских именнованных таблиц, вызывая
|
|
|
|
|
* специфицируемую пользователем функцию-визитер для каждой именованной таблицы.
|
|
|
|
|
* Перечисление продолжается до исчерпания именованных таблиц, либо до возврата
|
|
|
|
|
* отличного от нуля результата из заданной пользователем функции, которое будет
|
|
|
|
|
* сразу возвращено в качестве результата.
|
|
|
|
|
*
|
2024-07-05 00:25:28 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \see MDBX_table_enum_func
|
2024-07-05 00:25:28 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] txn Транзакция запущенная посредством
|
|
|
|
|
* \ref mdbx_txn_begin().
|
2024-07-13 16:13:11 +03:00
|
|
|
|
* \param [in] func Указатель на пользовательскую функцию
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* с сигнатурой \ref MDBX_table_enum_func,
|
2024-07-05 00:25:28 +03:00
|
|
|
|
* которая будет вызвана для каждой таблицы.
|
|
|
|
|
* \param [in] ctx Указатель на некоторый контект, который будет передан
|
2024-07-13 16:13:11 +03:00
|
|
|
|
* в функцию `func()` как есть.
|
2024-07-05 00:25:28 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns Ненулевое значение кода ошибки, либо 0 при успешном выполнении. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_enumerate_tables(const MDBX_txn *txn, MDBX_table_enum_func *func, void *ctx);
|
2024-07-05 00:25:28 +03:00
|
|
|
|
|
2021-07-20 01:50:54 +03:00
|
|
|
|
/** \defgroup value2key Value-to-Key functions
|
|
|
|
|
* \brief Value-to-Key functions to
|
|
|
|
|
* \ref avoid_custom_comparators "avoid using custom comparators"
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \see key2value
|
|
|
|
|
* @{
|
2020-01-22 03:43:09 +03:00
|
|
|
|
*
|
2020-07-29 16:56:27 +03:00
|
|
|
|
* The \ref mdbx_key_from_jsonInteger() build a keys which are comparable with
|
|
|
|
|
* keys created by \ref mdbx_key_from_double(). So this allows mixing `int64_t`
|
|
|
|
|
* and IEEE754 double values in one index for JSON-numbers with restriction for
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* integer numbers range corresponding to RFC-7159, i.e. \f$[-2^{53}+1,
|
|
|
|
|
* 2^{53}-1]\f$. See bottom of page 6 at https://tools.ietf.org/html/rfc7159 */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API uint64_t mdbx_key_from_jsonInteger(const int64_t json_integer);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API uint64_t mdbx_key_from_double(const double ieee754_64bit);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API uint64_t mdbx_key_from_ptrdouble(const double *const ieee754_64bit);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API uint32_t mdbx_key_from_float(const float ieee754_32bit);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API uint32_t mdbx_key_from_ptrfloat(const float *const ieee754_32bit);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_INLINE_API(uint64_t, mdbx_key_from_int64, (const int64_t i64)) {
|
2020-01-22 03:43:09 +03:00
|
|
|
|
return UINT64_C(0x8000000000000000) + i64;
|
|
|
|
|
}
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_INLINE_API(uint32_t, mdbx_key_from_int32, (const int32_t i32)) {
|
2020-01-22 03:43:09 +03:00
|
|
|
|
return UINT32_C(0x80000000) + i32;
|
|
|
|
|
}
|
2022-04-23 17:50:28 +03:00
|
|
|
|
/** end of value2key @} */
|
2020-01-22 03:43:09 +03:00
|
|
|
|
|
2021-07-20 01:50:54 +03:00
|
|
|
|
/** \defgroup key2value Key-to-Value functions
|
|
|
|
|
* \brief Key-to-Value functions to
|
|
|
|
|
* \ref avoid_custom_comparators "avoid using custom comparators"
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \see value2key
|
|
|
|
|
* @{ */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int64_t mdbx_jsonInteger_from_key(const MDBX_val);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API double mdbx_double_from_key(const MDBX_val);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API float mdbx_float_from_key(const MDBX_val);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int32_t mdbx_int32_from_key(const MDBX_val);
|
2020-08-21 18:01:16 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int64_t mdbx_int64_from_key(const MDBX_val);
|
2022-04-23 17:50:28 +03:00
|
|
|
|
/** end of value2key @} */
|
2020-06-23 23:50:37 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Retrieve statistics for a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [out] stat The address of an \ref MDBX_stat structure where
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* the statistics will be copied.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] bytes The size of \ref MDBX_stat.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_stat(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_stat *stat, size_t bytes);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Retrieve depth (bitmask) information of nested dupsort (multi-value)
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* B+trees for given table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-05-23 15:10:51 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] mask The address of an uint32_t value where the bitmask
|
|
|
|
|
* will be stored.
|
2020-05-23 15:10:51 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_RESULT_TRUE The dbi isn't a dupsort (multi-value) table. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_dupsort_depthmask(const MDBX_txn *txn, MDBX_dbi dbi, uint32_t *mask);
|
2020-05-23 15:10:51 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief DBI state bits returted by \ref mdbx_dbi_flags_ex()
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see mdbx_dbi_flags_ex() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_dbi_state {
|
2020-07-08 02:26:46 +03:00
|
|
|
|
/** DB was written in this txn */
|
|
|
|
|
MDBX_DBI_DIRTY = 0x01,
|
2023-10-13 09:36:01 +03:00
|
|
|
|
/** Cached Named-DB record is older than txnID */
|
2020-07-08 02:26:46 +03:00
|
|
|
|
MDBX_DBI_STALE = 0x02,
|
|
|
|
|
/** Named-DB handle opened in this txn */
|
|
|
|
|
MDBX_DBI_FRESH = 0x04,
|
|
|
|
|
/** Named-DB handle created in this txn */
|
|
|
|
|
MDBX_DBI_CREAT = 0x08,
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_dbi_state_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_dbi_state)
|
2020-07-08 02:26:46 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Retrieve the DB flags and status for a table handle.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2024-07-04 14:03:54 +03:00
|
|
|
|
* \see MDBX_db_flags_t
|
|
|
|
|
* \see MDBX_dbi_state_t
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] flags Address where the flags will be returned.
|
|
|
|
|
* \param [out] state Address where the state will be returned.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_flags_ex(const MDBX_txn *txn, MDBX_dbi dbi, unsigned *flags, unsigned *state);
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The shortcut to calling \ref mdbx_dbi_flags_ex() with `state=NULL`
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* for discarding it result.
|
2024-07-04 14:03:54 +03:00
|
|
|
|
* \ingroup c_statinfo
|
|
|
|
|
* \see MDBX_db_flags_t */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_INLINE_API(int, mdbx_dbi_flags, (const MDBX_txn *txn, MDBX_dbi dbi, unsigned *flags)) {
|
2020-10-14 18:15:50 +03:00
|
|
|
|
unsigned state;
|
|
|
|
|
return mdbx_dbi_flags_ex(txn, dbi, flags, &state);
|
|
|
|
|
}
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Close a table handle. Normally unnecessary.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_dbi
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Closing a table handle is not necessary, but lets \ref mdbx_dbi_open()
|
2020-09-10 01:15:35 +03:00
|
|
|
|
* reuse the handle value. Usually it's better to set a bigger
|
|
|
|
|
* \ref mdbx_env_set_maxdbs(), unless that value would be large.
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note Use with care.
|
2024-10-23 13:22:53 +03:00
|
|
|
|
* This call is synchronized via mutex with \ref mdbx_dbi_open(), but NOT with
|
|
|
|
|
* any transaction(s) running by other thread(s).
|
|
|
|
|
* So the `mdbx_dbi_close()` MUST NOT be called in-parallel/concurrently
|
|
|
|
|
* with any transactions using the closing dbi-handle, nor during other thread
|
|
|
|
|
* commit/abort a write transacton(s). The "next" version of libmdbx (\ref
|
|
|
|
|
* MithrilDB) will solve this issue.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
|
|
|
|
* Handles should only be closed if no other threads are going to reference
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* the table handle or one of its cursors any further. Do not close a handle
|
|
|
|
|
* if an existing transaction has modified its table. Doing so can cause
|
|
|
|
|
* misbehavior from table corruption to errors like \ref MDBX_BAD_DBI
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* (since the DB name is gone).
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2019-09-30 02:40:19 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2017-05-24 01:42:10 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_close(MDBX_env *env, MDBX_dbi dbi);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Empty or delete and close a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* \see mdbx_dbi_close() \see mdbx_dbi_open()
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] del `false` to empty the DB, `true` to delete it
|
|
|
|
|
* from the environment and close the DB handle.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2020-07-19 10:41:15 +03:00
|
|
|
|
LIBMDBX_API int mdbx_drop(MDBX_txn *txn, MDBX_dbi dbi, bool del);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Get items from a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This function retrieves key/data pairs from the table. The address
|
2017-05-17 20:06:57 +03:00
|
|
|
|
* and length of the data associated with the specified key are returned
|
|
|
|
|
* in the structure to which data refers.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* If the table supports duplicate keys (\ref MDBX_DUPSORT) then the
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* first data item for the key will be returned. Retrieval of other
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* items requires the use of \ref mdbx_cursor_get().
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note The memory pointed to by the returned values is owned by the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table. The caller MUST not dispose of the memory, and MUST not modify it
|
2023-10-08 11:55:30 +03:00
|
|
|
|
* in any way regardless in a read-only nor read-write transactions!
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* For case a table opened without the \ref MDBX_WRITEMAP modification
|
|
|
|
|
* attempts likely will cause a `SIGSEGV`. However, when a table opened with
|
2023-10-08 11:55:30 +03:00
|
|
|
|
* the \ref MDBX_WRITEMAP or in case values returned inside read-write
|
|
|
|
|
* transaction are located on a "dirty" (modified and pending to commit) pages,
|
|
|
|
|
* such modification will silently accepted and likely will lead to DB and/or
|
|
|
|
|
* data corruption.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \note Values returned from the table are valid only until a
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* subsequent update operation, or the end of the transaction.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
|
|
|
|
* \param [in] key The key to search for in the table.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in,out] data The data corresponding to the key.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_NOTFOUND The key was not in the table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_get(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Get items from a table
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* and optionally number of data items for a given key.
|
2020-09-25 01:13:11 +03:00
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Briefly this function does the same as \ref mdbx_get() with a few
|
|
|
|
|
* differences:
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* 1. If values_count is NOT NULL, then returns the count
|
|
|
|
|
* of multi-values/duplicates for a given key.
|
|
|
|
|
* 2. Updates BOTH the key and the data for pointing to the actual key-value
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* pair inside the table.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned
|
|
|
|
|
* by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
|
|
|
|
* \param [in,out] key The key to search for in the table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \param [in,out] data The data corresponding to the key.
|
|
|
|
|
* \param [out] values_count The optional address to return number of values
|
|
|
|
|
* associated with given key:
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* = 0 - in case \ref MDBX_NOTFOUND error;
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* = 1 - exactly for tables
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* WITHOUT \ref MDBX_DUPSORT;
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* >= 1 for tables WITH \ref MDBX_DUPSORT.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_NOTFOUND The key was not in the table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_get_ex(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_val *key, MDBX_val *data, size_t *values_count);
|
2019-09-26 20:00:22 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Get equal or great item from a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Briefly this function does the same as \ref mdbx_get() with a few
|
|
|
|
|
* differences:
|
2020-08-22 20:19:46 +03:00
|
|
|
|
* 1. Return equal or great (due comparison function) key-value
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* pair, but not only exactly matching with the key.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* 2. On success return \ref MDBX_SUCCESS if key found exactly,
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* and \ref MDBX_RESULT_TRUE otherwise. Moreover, for tables with
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref MDBX_DUPSORT flag the data argument also will be used to match over
|
|
|
|
|
* multi-value/duplicates, and \ref MDBX_SUCCESS will be returned only when
|
|
|
|
|
* BOTH the key and the data match exactly.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* 3. Updates BOTH the key and the data for pointing to the actual key-value
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* pair inside the table.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned
|
|
|
|
|
* by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
|
|
|
|
* \param [in,out] key The key to search for in the table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \param [in,out] data The data corresponding to the key.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \returns A non-zero error value on failure and \ref MDBX_RESULT_FALSE
|
|
|
|
|
* or \ref MDBX_RESULT_TRUE on success (as described above).
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* Some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_NOTFOUND The key was not in the table.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_get_equal_or_great(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_val *key, MDBX_val *data);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Store items into a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This function stores key/data pairs in the table. The default behavior
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* is to enter the new key/data pair, replacing any previously existing key
|
|
|
|
|
* if duplicates are disallowed, or adding a duplicate data item if
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* duplicates are allowed (see \ref MDBX_DUPSORT).
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned
|
|
|
|
|
* by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
|
|
|
|
* \param [in] key The key to store in the table.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in,out] data The data to store.
|
|
|
|
|
* \param [in] flags Special options for this operation.
|
|
|
|
|
* This parameter must be set to 0 or by bitwise OR'ing
|
|
|
|
|
* together one or more of the values described here:
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_NODUPDATA
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* Enter the new key-value pair only if it does not already appear
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* in the table. This flag may only be specified if the table
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* was opened with \ref MDBX_DUPSORT. The function will return
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \ref MDBX_KEYEXIST if the key/data pair already appears in the table.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_NOOVERWRITE
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* Enter the new key/data pair only if the key does not already appear
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* in the table. The function will return \ref MDBX_KEYEXIST if the key
|
|
|
|
|
* already appears in the table, even if the table supports
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* duplicates (see \ref MDBX_DUPSORT). The data parameter will be set
|
|
|
|
|
* to point to the existing item.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_CURRENT
|
|
|
|
|
* Update an single existing entry, but not add new ones. The function will
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* return \ref MDBX_NOTFOUND if the given key not exist in the table.
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* In case multi-values for the given key, with combination of
|
|
|
|
|
* the \ref MDBX_ALLDUPS will replace all multi-values,
|
|
|
|
|
* otherwise return the \ref MDBX_EMULTIVAL.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_RESERVE
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* Reserve space for data of the given size, but don't copy the given
|
|
|
|
|
* data. Instead, return a pointer to the reserved space, which the
|
|
|
|
|
* caller can fill in later - before the next update operation or the
|
|
|
|
|
* transaction ends. This saves an extra memcpy if the data is being
|
|
|
|
|
* generated later. MDBX does nothing else with this memory, the caller
|
|
|
|
|
* is expected to modify all of the space requested. This flag must not
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* be specified if the table was opened with \ref MDBX_DUPSORT.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_APPEND
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Append the given key/data pair to the end of the table. This option
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* allows fast bulk loading when keys are already known to be in the
|
|
|
|
|
* correct order. Loading unsorted keys with this flag will cause
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* a \ref MDBX_EKEYMISMATCH error.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_APPENDDUP
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* As above, but for sorted dup data.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* - \ref MDBX_MULTIPLE
|
|
|
|
|
* Store multiple contiguous data elements in a single request. This flag
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* may only be specified if the table was opened with
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* \ref MDBX_DUPFIXED. With combination the \ref MDBX_ALLDUPS
|
|
|
|
|
* will replace all multi-values.
|
|
|
|
|
* The data argument must be an array of two \ref MDBX_val. The `iov_len`
|
|
|
|
|
* of the first \ref MDBX_val must be the size of a single data element.
|
|
|
|
|
* The `iov_base` of the first \ref MDBX_val must point to the beginning
|
|
|
|
|
* of the array of contiguous data elements which must be properly aligned
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* in case of table with \ref MDBX_INTEGERDUP flag.
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* The `iov_len` of the second \ref MDBX_val must be the count of the
|
|
|
|
|
* number of data elements to store. On return this field will be set to
|
|
|
|
|
* the count of the number of elements actually written. The `iov_base` of
|
|
|
|
|
* the second \ref MDBX_val is unused.
|
|
|
|
|
*
|
2021-01-26 20:14:21 +03:00
|
|
|
|
* \see \ref c_crud_hints "Quick reference for Insert/Update/Delete operations"
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \retval MDBX_KEYEXIST The key/value pair already exists in the table.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \retval MDBX_MAP_FULL The database is full, see \ref mdbx_env_set_mapsize().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_TXN_FULL The transaction has too many dirty pages.
|
|
|
|
|
* \retval MDBX_EACCES An attempt was made to write
|
|
|
|
|
* in a read-only transaction.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_put(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *data, MDBX_put_flags_t flags);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Replace items in a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
|
|
|
|
* This function allows to update or delete an existing value at the same time
|
|
|
|
|
* as the previous value is retrieved. If the argument new_data equal is NULL
|
|
|
|
|
* zero, the removal is performed, otherwise the update/insert.
|
|
|
|
|
*
|
|
|
|
|
* The current value may be in an already changed (aka dirty) page. In this
|
|
|
|
|
* case, the page will be overwritten during the update, and the old value will
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* be lost. Therefore, an additional buffer must be passed via old_data
|
|
|
|
|
* argument initially to copy the old value. If the buffer passed in is too
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* small, the function will return \ref MDBX_RESULT_TRUE by setting iov_len
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* field pointed by old_data argument to the appropriate value, without
|
|
|
|
|
* performing any changes.
|
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* For tables with non-unique keys (i.e. with \ref MDBX_DUPSORT flag),
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* another use case is also possible, when by old_data argument selects a
|
|
|
|
|
* specific item from multi-value/duplicates with the same key for deletion or
|
|
|
|
|
* update. To select this scenario in flags should simultaneously specify
|
|
|
|
|
* \ref MDBX_CURRENT and \ref MDBX_NOOVERWRITE. This combination is chosen
|
|
|
|
|
* because it makes no sense, and thus allows you to identify the request of
|
|
|
|
|
* such a scenario.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn A transaction handle returned
|
|
|
|
|
* by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
|
|
|
|
* \param [in] key The key to store in the table.
|
2020-08-22 20:19:46 +03:00
|
|
|
|
* \param [in] new_data The data to store, if NULL then deletion will
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* be performed.
|
|
|
|
|
* \param [in,out] old_data The buffer for retrieve previous value as describe
|
|
|
|
|
* above.
|
|
|
|
|
* \param [in] flags Special options for this operation.
|
|
|
|
|
* This parameter must be set to 0 or by bitwise
|
|
|
|
|
* OR'ing together one or more of the values
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* described in \ref mdbx_put() description above,
|
|
|
|
|
* and additionally
|
|
|
|
|
* (\ref MDBX_CURRENT | \ref MDBX_NOOVERWRITE)
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* combination for selection particular item from
|
|
|
|
|
* multi-value/duplicates.
|
|
|
|
|
*
|
2021-01-26 20:14:21 +03:00
|
|
|
|
* \see \ref c_crud_hints "Quick reference for Insert/Update/Delete operations"
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_replace(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, MDBX_val *new_data, MDBX_val *old_data,
|
2020-08-04 01:06:01 +03:00
|
|
|
|
MDBX_put_flags_t flags);
|
2019-09-26 20:00:22 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef int (*MDBX_preserve_func)(void *context, MDBX_val *target, const void *src, size_t bytes);
|
|
|
|
|
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,
|
2020-08-22 20:19:46 +03:00
|
|
|
|
void *preserver_context);
|
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Delete items from a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This function removes key/data pairs from the table.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \note The data parameter is NOT ignored regardless the table does
|
2017-02-21 20:16:54 +03:00
|
|
|
|
* support sorted duplicate data items or not. If the data parameter
|
2020-06-04 12:59:05 +03:00
|
|
|
|
* is non-NULL only the matching data item will be deleted. Otherwise, if data
|
|
|
|
|
* parameter is NULL, any/all value(s) for specified key will be deleted.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* This function will return \ref MDBX_NOTFOUND if the specified key/data
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* pair is not in the table.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2021-01-26 20:14:21 +03:00
|
|
|
|
* \see \ref c_crud_hints "Quick reference for Insert/Update/Delete operations"
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
|
|
|
|
* \param [in] key The key to delete from the table.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] data The data to delete.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_EACCES An attempt was made to write
|
|
|
|
|
* in a read-only transaction.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_del(MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *key, const MDBX_val *data);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2023-10-13 09:36:01 +03:00
|
|
|
|
/** \brief Create a cursor handle but not bind it to transaction nor DBI-handle.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_cursors
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* A cursor cannot be used when its table handle is closed. Nor when its
|
2022-01-24 18:16:09 +03:00
|
|
|
|
* transaction has ended, except with \ref mdbx_cursor_bind() and \ref
|
|
|
|
|
* mdbx_cursor_renew(). Also it can be discarded with \ref mdbx_cursor_close().
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* A cursor must be closed explicitly always, before or after its transaction
|
2020-09-15 02:05:25 +03:00
|
|
|
|
* ends. It can be reused with \ref mdbx_cursor_bind()
|
|
|
|
|
* or \ref mdbx_cursor_renew() before finally closing it.
|
|
|
|
|
*
|
|
|
|
|
* \note In contrast to LMDB, the MDBX required that any opened cursors can be
|
|
|
|
|
* reused and must be freed explicitly, regardless ones was opened in a
|
|
|
|
|
* read-only or write transaction. The REASON for this is eliminates ambiguity
|
|
|
|
|
* which helps to avoid errors such as: use-after-free, double-free, i.e.
|
|
|
|
|
* memory corruption and segfaults.
|
|
|
|
|
*
|
2020-09-29 20:58:09 +03:00
|
|
|
|
* \param [in] context A pointer to application context to be associated with
|
|
|
|
|
* created cursor and could be retrieved by
|
|
|
|
|
* \ref mdbx_cursor_get_userctx() until cursor closed.
|
|
|
|
|
*
|
2020-09-15 02:05:25 +03:00
|
|
|
|
* \returns Created cursor handle or NULL in case out of memory. */
|
2020-09-29 20:58:09 +03:00
|
|
|
|
LIBMDBX_API MDBX_cursor *mdbx_cursor_create(void *context);
|
|
|
|
|
|
2023-10-13 09:36:01 +03:00
|
|
|
|
/** \brief Set application information associated with the cursor.
|
2021-01-26 22:17:52 +03:00
|
|
|
|
* \ingroup c_cursors
|
2020-09-29 20:58:09 +03:00
|
|
|
|
* \see mdbx_cursor_get_userctx()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] cursor An cursor handle returned by \ref mdbx_cursor_create()
|
|
|
|
|
* or \ref mdbx_cursor_open().
|
|
|
|
|
* \param [in] ctx An arbitrary pointer for whatever the application needs.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_cursor_set_userctx(MDBX_cursor *cursor, void *ctx);
|
|
|
|
|
|
|
|
|
|
/** \brief Get the application information associated with the MDBX_cursor.
|
2021-01-26 22:17:52 +03:00
|
|
|
|
* \ingroup c_cursors
|
2020-09-29 20:58:09 +03:00
|
|
|
|
* \see mdbx_cursor_set_userctx()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] cursor An cursor handle returned by \ref mdbx_cursor_create()
|
|
|
|
|
* or \ref mdbx_cursor_open().
|
|
|
|
|
* \returns The pointer which was passed via the `context` parameter
|
|
|
|
|
* of `mdbx_cursor_create()` or set by \ref mdbx_cursor_set_userctx(),
|
|
|
|
|
* or `NULL` if something wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API void *mdbx_cursor_get_userctx(const MDBX_cursor *cursor);
|
2020-09-15 02:05:25 +03:00
|
|
|
|
|
2023-10-13 09:36:01 +03:00
|
|
|
|
/** \brief Bind cursor to specified transaction and DBI-handle.
|
2020-09-15 02:05:25 +03:00
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
*
|
|
|
|
|
* Using of the `mdbx_cursor_bind()` is equivalent to calling
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \ref mdbx_cursor_renew() but with specifying an arbitrary DBI-handle.
|
2020-09-15 02:05:25 +03:00
|
|
|
|
*
|
2022-01-24 18:16:09 +03:00
|
|
|
|
* A cursor may be associated with a new transaction, and referencing a new or
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* the same table handle as it was created with. This may be done whether the
|
2022-01-24 18:16:09 +03:00
|
|
|
|
* previous transaction is live or dead.
|
2020-09-15 02:05:25 +03:00
|
|
|
|
*
|
|
|
|
|
* \note In contrast to LMDB, the MDBX required that any opened cursors can be
|
|
|
|
|
* reused and must be freed explicitly, regardless ones was opened in a
|
|
|
|
|
* read-only or write transaction. The REASON for this is eliminates ambiguity
|
|
|
|
|
* which helps to avoid errors such as: use-after-free, double-free, i.e.
|
|
|
|
|
* memory corruption and segfaults.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_create().
|
2020-09-15 02:05:25 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_bind(const MDBX_txn *txn, MDBX_cursor *cursor, MDBX_dbi dbi);
|
2020-09-15 02:05:25 +03:00
|
|
|
|
|
2023-10-13 17:36:21 +03:00
|
|
|
|
/** \brief Unbind cursor from a transaction.
|
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
*
|
|
|
|
|
* Unbinded cursor is disassociated with any transactions but still holds
|
|
|
|
|
* the original DBI-handle internally. Thus it could be renewed with any running
|
|
|
|
|
* transaction or closed.
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_cursor_renew()
|
|
|
|
|
* \see mdbx_cursor_bind()
|
|
|
|
|
* \see mdbx_cursor_close()
|
2024-05-19 22:07:58 +03:00
|
|
|
|
* \see mdbx_cursor_reset()
|
2023-10-13 17:36:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \note In contrast to LMDB, the MDBX required that any opened cursors can be
|
|
|
|
|
* reused and must be freed explicitly, regardless ones was opened in a
|
|
|
|
|
* read-only or write transaction. The REASON for this is eliminates ambiguity
|
|
|
|
|
* which helps to avoid errors such as: use-after-free, double-free, i.e.
|
|
|
|
|
* memory corruption and segfaults.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_cursor_unbind(MDBX_cursor *cursor);
|
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
/** \brief Сбрасывает состояние курсора.
|
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
*
|
|
|
|
|
* В результате сброса курсор становится неустановленным и не позволяет
|
|
|
|
|
* выполнять операции относительного позиционирования, получения или изменения
|
|
|
|
|
* данных, до установки на позицию не зависящую от текущей. Что позволяет
|
|
|
|
|
* приложению пресекать дальнейшие операции без предварительного
|
|
|
|
|
* позиционирования курсора.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] cursor Указатель на курсор.
|
|
|
|
|
*
|
|
|
|
|
* \returns Результат операции сканирования, либо код ошибки. */
|
|
|
|
|
LIBMDBX_API int mdbx_cursor_reset(MDBX_cursor *cursor);
|
|
|
|
|
|
2020-09-15 02:05:25 +03:00
|
|
|
|
/** \brief Create a cursor handle for the specified transaction and DBI handle.
|
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
*
|
|
|
|
|
* Using of the `mdbx_cursor_open()` is equivalent to calling
|
|
|
|
|
* \ref mdbx_cursor_create() and then \ref mdbx_cursor_bind() functions.
|
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* A cursor cannot be used when its table handle is closed. Nor when its
|
2022-01-24 18:16:09 +03:00
|
|
|
|
* transaction has ended, except with \ref mdbx_cursor_bind() and \ref
|
|
|
|
|
* mdbx_cursor_renew(). Also it can be discarded with \ref mdbx_cursor_close().
|
2020-09-15 02:05:25 +03:00
|
|
|
|
*
|
|
|
|
|
* A cursor must be closed explicitly always, before or after its transaction
|
|
|
|
|
* ends. It can be reused with \ref mdbx_cursor_bind()
|
|
|
|
|
* or \ref mdbx_cursor_renew() before finally closing it.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note In contrast to LMDB, the MDBX required that any opened cursors can be
|
2019-09-30 02:40:19 +03:00
|
|
|
|
* reused and must be freed explicitly, regardless ones was opened in a
|
|
|
|
|
* read-only or write transaction. The REASON for this is eliminates ambiguity
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* which helps to avoid errors such as: use-after-free, double-free, i.e.
|
|
|
|
|
* memory corruption and segfaults.
|
2019-09-30 02:40:19 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [out] cursor Address where the new \ref MDBX_cursor handle will be
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* stored.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_open(const MDBX_txn *txn, MDBX_dbi dbi, MDBX_cursor **cursor);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Close a cursor handle.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_cursors
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* The cursor handle will be freed and must not be used again after this call,
|
|
|
|
|
* but its transaction may still be live.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note In contrast to LMDB, the MDBX required that any opened cursors can be
|
2019-09-30 02:40:19 +03:00
|
|
|
|
* reused and must be freed explicitly, regardless ones was opened in a
|
|
|
|
|
* read-only or write transaction. The REASON for this is eliminates ambiguity
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* which helps to avoid errors such as: use-after-free, double-free, i.e.
|
|
|
|
|
* memory corruption and segfaults.
|
2019-09-30 02:40:19 +03:00
|
|
|
|
*
|
2020-09-29 20:14:08 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open()
|
|
|
|
|
* or \ref mdbx_cursor_create(). */
|
2017-05-24 01:42:10 +03:00
|
|
|
|
LIBMDBX_API void mdbx_cursor_close(MDBX_cursor *cursor);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2023-10-13 22:38:51 +03:00
|
|
|
|
/** \brief Unbind or closes all cursors of a given transaction.
|
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
*
|
|
|
|
|
* Unbinds either closes all cursors associated (opened or renewed) with
|
|
|
|
|
* a given transaction in a bulk with minimal overhead.
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_cursor_unbind()
|
|
|
|
|
* \see mdbx_cursor_close()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
|
|
|
|
* \param [in] unbind If non-zero, unbinds cursors and leaves ones reusable.
|
|
|
|
|
* Otherwise close and dispose cursors.
|
|
|
|
|
*
|
|
|
|
|
* \returns A negative error value on failure or the number of closed cursors
|
|
|
|
|
* on success, some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_BAD_TXN Given transaction is invalid or has
|
|
|
|
|
* a child/nested transaction transaction. */
|
|
|
|
|
LIBMDBX_API int mdbx_txn_release_all_cursors(const MDBX_txn *txn, bool unbind);
|
|
|
|
|
|
2023-10-13 09:36:01 +03:00
|
|
|
|
/** \brief Renew a cursor handle for use within the given transaction.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_cursors
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* A cursor may be associated with a new transaction whether the previous
|
|
|
|
|
* transaction is running or finished.
|
2020-09-15 02:05:25 +03:00
|
|
|
|
*
|
|
|
|
|
* Using of the `mdbx_cursor_renew()` is equivalent to calling
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \ref mdbx_cursor_bind() with the DBI-handle that previously
|
2020-09-15 02:05:25 +03:00
|
|
|
|
* the cursor was used with.
|
2019-09-30 02:40:19 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note In contrast to LMDB, the MDBX allow any cursor to be re-used by using
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ref mdbx_cursor_renew(), to avoid unnecessary malloc/free overhead until it
|
|
|
|
|
* freed by \ref mdbx_cursor_close().
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
2023-10-13 09:36:01 +03:00
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified.
|
|
|
|
|
* \retval MDBX_BAD_DBI The cursor was not bound to a DBI-handle
|
|
|
|
|
* or such a handle became invalid. */
|
2023-10-14 09:04:06 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_renew(const MDBX_txn *txn, MDBX_cursor *cursor);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Return the cursor's transaction handle.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_cursors
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open(). */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API MDBX_txn *mdbx_cursor_txn(const MDBX_cursor *cursor);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Return the cursor's table handle.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_cursors
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open(). */
|
2020-04-18 20:16:37 +03:00
|
|
|
|
LIBMDBX_API MDBX_dbi mdbx_cursor_dbi(const MDBX_cursor *cursor);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-11-04 18:15:14 +03:00
|
|
|
|
/** \brief Copy cursor position and state.
|
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
*
|
|
|
|
|
* \param [in] src A source cursor handle returned
|
|
|
|
|
* by \ref mdbx_cursor_create() or \ref mdbx_cursor_open().
|
|
|
|
|
*
|
|
|
|
|
* \param [in,out] dest A destination cursor handle returned
|
|
|
|
|
* by \ref mdbx_cursor_create() or \ref mdbx_cursor_open().
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_cursor_copy(const MDBX_cursor *src, MDBX_cursor *dest);
|
|
|
|
|
|
2024-03-21 21:28:12 +03:00
|
|
|
|
/** \brief Сравнивает позицию курсоров.
|
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
*
|
|
|
|
|
* Функция предназначена для сравнения позиций двух
|
|
|
|
|
* инициализированных/установленных курсоров, связанных с одной транзакцией и
|
|
|
|
|
* одной таблицей (DBI-дескриптором).
|
|
|
|
|
* Если же курсоры связаны с разными транзакциями, либо с разными таблицами,
|
|
|
|
|
* либо один из них не инициализирован, то результат сравнения не определен
|
|
|
|
|
* (поведением может быть изменено в последующих версиях).
|
|
|
|
|
*
|
|
|
|
|
* \param [in] left Левый курсор для сравнения позиций.
|
|
|
|
|
* \param [in] right Правый курсор для сравнения позиций.
|
|
|
|
|
* \param [in] ignore_multival Булевой флаг, влияющий на результат только при
|
|
|
|
|
* сравнении курсоров для таблиц с мульти-значениями, т.е. с флагом
|
|
|
|
|
* \ref MDBX_DUPSORT. В случае `true`, позиции курсоров сравниваются
|
|
|
|
|
* только по ключам, без учета позиционирования среди мульти-значений.
|
|
|
|
|
* Иначе, в случае `false`, при совпадении позиций по ключам,
|
|
|
|
|
* сравниваются также позиции по мульти-значениям.
|
|
|
|
|
*
|
|
|
|
|
* \retval Значение со знаком в семантике оператора `<=>` (меньше нуля, ноль,
|
|
|
|
|
* либо больше нуля) как результат сравнения позиций курсоров. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_compare(const MDBX_cursor *left, const MDBX_cursor *right, bool ignore_multival);
|
2023-11-18 01:55:29 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Retrieve by cursor.
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This function retrieves key/data pairs from the table. The address and
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* length of the key are returned in the object to which key refers (except
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* for the case of the \ref MDBX_SET option, in which the key object is
|
|
|
|
|
* unchanged), and the address and length of the data are returned in the object
|
2020-08-27 13:16:45 +03:00
|
|
|
|
* to which data refers.
|
|
|
|
|
* \see mdbx_get()
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2023-10-08 11:55:30 +03:00
|
|
|
|
* \note The memory pointed to by the returned values is owned by the
|
|
|
|
|
* database. The caller MUST not dispose of the memory, and MUST not modify it
|
|
|
|
|
* in any way regardless in a read-only nor read-write transactions!
|
|
|
|
|
* For case a database opened without the \ref MDBX_WRITEMAP modification
|
|
|
|
|
* attempts likely will cause a `SIGSEGV`. However, when a database opened with
|
|
|
|
|
* the \ref MDBX_WRITEMAP or in case values returned inside read-write
|
|
|
|
|
* transaction are located on a "dirty" (modified and pending to commit) pages,
|
|
|
|
|
* such modification will silently accepted and likely will lead to DB and/or
|
|
|
|
|
* data corruption.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in,out] key The key for a retrieved item.
|
|
|
|
|
* \param [in,out] data The data of a retrieved item.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] op A cursor operation \ref MDBX_cursor_op.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_NOTFOUND No matching key found.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_get(MDBX_cursor *cursor, MDBX_val *key, MDBX_val *data, MDBX_cursor_op op);
|
2024-03-22 17:27:37 +03:00
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
/** \brief Служебная функция для использования в утилитах.
|
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
*
|
|
|
|
|
* При использовании определяемых пользователем функций сравнения (aka custom
|
|
|
|
|
* comparison functions) проверка порядка ключей может приводить к неверным
|
|
|
|
|
* результатам и возврате ошибки \ref MDBX_CORRUPTED.
|
|
|
|
|
*
|
|
|
|
|
* Эта функция отключает контроль порядка следования ключей на страницах при
|
|
|
|
|
* чтении страниц БД для этого курсора, и таким образом, позволяет прочитать
|
|
|
|
|
* данные при отсутствии/недоступности использованных функций сравнения.
|
|
|
|
|
* \see avoid_custom_comparators
|
|
|
|
|
*
|
|
|
|
|
* \returns Результат операции сканирования, либо код ошибки. */
|
|
|
|
|
LIBMDBX_API int mdbx_cursor_ignord(MDBX_cursor *cursor);
|
|
|
|
|
|
2024-03-22 17:27:37 +03:00
|
|
|
|
/** \brief Тип предикативных функций обратного вызова используемых
|
|
|
|
|
* \ref mdbx_cursor_scan() и \ref mdbx_cursor_scan_from() для пробирования
|
|
|
|
|
* пар ключ-значения.
|
|
|
|
|
* \ingroup c_crud
|
|
|
|
|
*
|
|
|
|
|
* \param [in,out] context Указатель на контекст с необходимой для оценки
|
|
|
|
|
* информацией, который полностью подготавливается
|
|
|
|
|
* и контролируется вами.
|
|
|
|
|
* \param [in] key Ключ для оценки пользовательской функцией.
|
|
|
|
|
* \param [in] value Значение для оценки пользовательской функцией.
|
|
|
|
|
* \param [in,out] arg Дополнительный аргумент предикативной функции,
|
|
|
|
|
* который полностью подготавливается
|
|
|
|
|
* и контролируется вами.
|
|
|
|
|
*
|
|
|
|
|
* \returns Результат проверки соответствия переданной пары ключ-значения
|
|
|
|
|
* искомой цели. Иначе код ошибки, который прерывает сканирование и возвращается
|
|
|
|
|
* без изменения в качестве результата из функций \ref mdbx_cursor_scan()
|
|
|
|
|
* или \ref mdbx_cursor_scan_from().
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_RESULT_TRUE если переданная пара ключ-значение соответствует
|
|
|
|
|
* искомой и следует завершить сканирование.
|
|
|
|
|
* \retval MDBX_RESULT_FALSE если переданная пара ключ-значение НЕ соответствует
|
|
|
|
|
* искомой и следует продолжать сканирование.
|
|
|
|
|
* \retval ИНАЧЕ любое другое значение, отличное от \ref MDBX_RESULT_TRUE
|
|
|
|
|
* и \ref MDBX_RESULT_FALSE, считается индикатором ошибки
|
|
|
|
|
* и возвращается без изменений в качестве результата сканирования.
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_cursor_scan()
|
|
|
|
|
* \see mdbx_cursor_scan_from() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef int(MDBX_predicate_func)(void *context, MDBX_val *key, MDBX_val *value, void *arg) MDBX_CXX17_NOEXCEPT;
|
2024-03-22 17:27:37 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Сканирует таблицу с использованием передаваемого предиката,
|
|
|
|
|
* с уменьшением сопутствующих накладных расходов.
|
|
|
|
|
* \ingroup c_crud
|
|
|
|
|
*
|
|
|
|
|
* Реализует функционал сходный с шаблоном `std::find_if<>()` с использованием
|
|
|
|
|
* курсора и пользовательской предикативной функции, экономя при этом
|
|
|
|
|
* на сопутствующих накладных расходах, в том числе, не выполняя часть проверок
|
|
|
|
|
* внутри цикла итерации записей и потенциально уменьшая количество
|
|
|
|
|
* DSO-трансграничных вызовов.
|
|
|
|
|
*
|
|
|
|
|
* Функция принимает курсор, который должен быть привязан к некоторой транзакции
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* и DBI-дескриптору таблицы, выполняет первоначальное позиционирование курсора
|
|
|
|
|
* определяемое аргументом `start_op`. Далее, производится оценка каждой пары
|
|
|
|
|
* ключ-значения посредством предоставляемой вами предикативной функции
|
|
|
|
|
* `predicate` и затем, при необходимости, переход к следующему элементу
|
|
|
|
|
* посредством операции `turn_op`, до наступления одного из четырех событий:
|
2024-03-22 17:27:37 +03:00
|
|
|
|
* - достигается конец данных;
|
|
|
|
|
* - возникнет ошибка при позиционировании курсора;
|
|
|
|
|
* - оценочная функция вернет \ref MDBX_RESULT_TRUE, сигнализируя
|
|
|
|
|
* о необходимости остановить дальнейшее сканирование;
|
|
|
|
|
* - оценочная функция возвратит значение отличное от \ref MDBX_RESULT_FALSE
|
|
|
|
|
* и \ref MDBX_RESULT_TRUE сигнализируя об ошибке.
|
|
|
|
|
*
|
|
|
|
|
* \param [in,out] cursor Курсор для выполнения операции сканирования,
|
|
|
|
|
* связанный с активной транзакцией и DBI-дескриптором
|
|
|
|
|
* таблицы. Например, курсор созданный
|
|
|
|
|
* посредством \ref mdbx_cursor_open().
|
|
|
|
|
* \param [in] predicate Предикативная функция для оценки итерируемых
|
|
|
|
|
* пар ключ-значения,
|
|
|
|
|
* более подробно смотрите \ref MDBX_predicate_func.
|
|
|
|
|
* \param [in,out] context Указатель на контекст с необходимой для оценки
|
|
|
|
|
* информацией, который полностью подготавливается
|
|
|
|
|
* и контролируется вами.
|
|
|
|
|
* \param [in] start_op Стартовая операция позиционирования курсора,
|
|
|
|
|
* более подробно смотрите \ref MDBX_cursor_op.
|
|
|
|
|
* Для сканирования без изменения исходной позиции
|
|
|
|
|
* курсора используйте \ref MDBX_GET_CURRENT.
|
|
|
|
|
* Допустимые значения \ref MDBX_FIRST,
|
|
|
|
|
* \ref MDBX_FIRST_DUP, \ref MDBX_LAST,
|
|
|
|
|
* \ref MDBX_LAST_DUP, \ref MDBX_GET_CURRENT,
|
|
|
|
|
* а также \ref MDBX_GET_MULTIPLE.
|
|
|
|
|
* \param [in] turn_op Операция позиционирования курсора для перехода
|
|
|
|
|
* к следующему элементу. Допустимые значения
|
|
|
|
|
* \ref MDBX_NEXT, \ref MDBX_NEXT_DUP,
|
|
|
|
|
* \ref MDBX_NEXT_NODUP, \ref MDBX_PREV,
|
|
|
|
|
* \ref MDBX_PREV_DUP, \ref MDBX_PREV_NODUP, а также
|
|
|
|
|
* \ref MDBX_NEXT_MULTIPLE и \ref MDBX_PREV_MULTIPLE.
|
|
|
|
|
* \param [in,out] arg Дополнительный аргумент предикативной функции,
|
|
|
|
|
* который полностью подготавливается
|
|
|
|
|
* и контролируется вами.
|
|
|
|
|
*
|
|
|
|
|
* \note При использовании \ref MDBX_GET_MULTIPLE, \ref MDBX_NEXT_MULTIPLE
|
|
|
|
|
* или \ref MDBX_PREV_MULTIPLE внимательно учитывайте пакетную специфику
|
|
|
|
|
* передачи значений через параметры предикативной функции.
|
|
|
|
|
*
|
|
|
|
|
* \see MDBX_predicate_func
|
|
|
|
|
* \see mdbx_cursor_scan_from
|
|
|
|
|
*
|
|
|
|
|
* \returns Результат операции сканирования, либо код ошибки.
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_RESULT_TRUE если найдена пара ключ-значение, для которой
|
|
|
|
|
* предикативная функция вернула \ref MDBX_RESULT_TRUE.
|
|
|
|
|
* \retval MDBX_RESULT_FALSE если если подходящая пара ключ-значения НЕ найдена,
|
|
|
|
|
* в процессе поиска достигнут конец данных, либо нет данных для поиска.
|
|
|
|
|
* \retval ИНАЧЕ любое другое значение, отличное от \ref MDBX_RESULT_TRUE
|
|
|
|
|
* и \ref MDBX_RESULT_FALSE, является кодом ошибки при позиционировании
|
|
|
|
|
* курса, либо определяемым пользователем кодом остановки поиска
|
|
|
|
|
* или ошибочной ситуации. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
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);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-03-22 17:27:37 +03:00
|
|
|
|
/** Сканирует таблицу с использованием передаваемого предиката,
|
|
|
|
|
* начиная с передаваемой пары ключ-значение,
|
|
|
|
|
* с уменьшением сопутствующих накладных расходов.
|
|
|
|
|
* \ingroup c_crud
|
|
|
|
|
*
|
|
|
|
|
* Функция принимает курсор, который должен быть привязан к некоторой транзакции
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* и DBI-дескриптору таблицы, выполняет первоначальное позиционирование курсора
|
|
|
|
|
* определяемое аргументом `from_op`. а также аргументами `from_key` и
|
|
|
|
|
* `from_value`. Далее, производится оценка каждой пары ключ-значения
|
|
|
|
|
* посредством предоставляемой вами предикативной функции `predicate` и затем,
|
|
|
|
|
* при необходимости, переход к следующему элементу посредством операции
|
|
|
|
|
* `turn_op`, до наступления одного из четырех событий:
|
2024-03-22 17:27:37 +03:00
|
|
|
|
* - достигается конец данных;
|
|
|
|
|
* - возникнет ошибка при позиционировании курсора;
|
|
|
|
|
* - оценочная функция вернет \ref MDBX_RESULT_TRUE, сигнализируя
|
|
|
|
|
* о необходимости остановить дальнейшее сканирование;
|
|
|
|
|
* - оценочная функция возвратит значение отличное от \ref MDBX_RESULT_FALSE
|
|
|
|
|
* и \ref MDBX_RESULT_TRUE сигнализируя об ошибке.
|
|
|
|
|
*
|
|
|
|
|
* \param [in,out] cursor Курсор для выполнения операции сканирования,
|
|
|
|
|
* связанный с активной транзакцией и DBI-дескриптором
|
|
|
|
|
* таблицы. Например, курсор созданный
|
|
|
|
|
* посредством \ref mdbx_cursor_open().
|
|
|
|
|
* \param [in] predicate Предикативная функция для оценки итерируемых
|
|
|
|
|
* пар ключ-значения,
|
|
|
|
|
* более подробно смотрите \ref MDBX_predicate_func.
|
|
|
|
|
* \param [in,out] context Указатель на контекст с необходимой для оценки
|
|
|
|
|
* информацией, который полностью подготавливается
|
|
|
|
|
* и контролируется вами.
|
|
|
|
|
* \param [in] from_op Операция позиционирования курсора к исходной
|
|
|
|
|
* позиции, более подробно смотрите
|
|
|
|
|
* \ref MDBX_cursor_op.
|
|
|
|
|
* Допустимые значения \ref MDBX_GET_BOTH,
|
|
|
|
|
* \ref MDBX_GET_BOTH_RANGE, \ref MDBX_SET_KEY,
|
|
|
|
|
* \ref MDBX_SET_LOWERBOUND, \ref MDBX_SET_UPPERBOUND,
|
|
|
|
|
* \ref MDBX_TO_KEY_LESSER_THAN,
|
|
|
|
|
* \ref MDBX_TO_KEY_LESSER_OR_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_KEY_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_KEY_GREATER_OR_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_KEY_GREATER_THAN,
|
|
|
|
|
* \ref MDBX_TO_EXACT_KEY_VALUE_LESSER_THAN,
|
|
|
|
|
* \ref MDBX_TO_EXACT_KEY_VALUE_LESSER_OR_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_EXACT_KEY_VALUE_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_EXACT_KEY_VALUE_GREATER_OR_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_EXACT_KEY_VALUE_GREATER_THAN,
|
|
|
|
|
* \ref MDBX_TO_PAIR_LESSER_THAN,
|
|
|
|
|
* \ref MDBX_TO_PAIR_LESSER_OR_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_PAIR_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_PAIR_GREATER_OR_EQUAL,
|
|
|
|
|
* \ref MDBX_TO_PAIR_GREATER_THAN,
|
|
|
|
|
* а также \ref MDBX_GET_MULTIPLE.
|
|
|
|
|
* \param [in,out] from_key Указатель на ключ используемый как для исходного
|
|
|
|
|
* позиционирования, так и для последующих итераций
|
|
|
|
|
* перехода.
|
|
|
|
|
* \param [in,out] from_value Указатель на значние используемое как для
|
|
|
|
|
* исходного позиционирования, так и для последующих
|
|
|
|
|
* итераций перехода.
|
|
|
|
|
* \param [in] turn_op Операция позиционирования курсора для перехода
|
|
|
|
|
* к следующему элементу. Допустимые значения
|
|
|
|
|
* \ref MDBX_NEXT, \ref MDBX_NEXT_DUP,
|
|
|
|
|
* \ref MDBX_NEXT_NODUP, \ref MDBX_PREV,
|
|
|
|
|
* \ref MDBX_PREV_DUP, \ref MDBX_PREV_NODUP, а также
|
|
|
|
|
* \ref MDBX_NEXT_MULTIPLE и \ref MDBX_PREV_MULTIPLE.
|
|
|
|
|
* \param [in,out] arg Дополнительный аргумент предикативной функции,
|
|
|
|
|
* который полностью подготавливается
|
|
|
|
|
* и контролируется вами.
|
|
|
|
|
*
|
|
|
|
|
* \note При использовании \ref MDBX_GET_MULTIPLE, \ref MDBX_NEXT_MULTIPLE
|
|
|
|
|
* или \ref MDBX_PREV_MULTIPLE внимательно учитывайте пакетную специфику
|
|
|
|
|
* передачи значений через параметры предикативной функции.
|
|
|
|
|
*
|
|
|
|
|
* \see MDBX_predicate_func
|
|
|
|
|
* \see mdbx_cursor_scan
|
|
|
|
|
*
|
|
|
|
|
* \returns Результат операции сканирования, либо код ошибки.
|
|
|
|
|
*
|
|
|
|
|
* \retval MDBX_RESULT_TRUE если найдена пара ключ-значение, для которой
|
|
|
|
|
* предикативная функция вернула \ref MDBX_RESULT_TRUE.
|
|
|
|
|
* \retval MDBX_RESULT_FALSE если если подходящая пара ключ-значения НЕ найдена,
|
|
|
|
|
* в процессе поиска достигнут конец данных, либо нет данных для поиска.
|
|
|
|
|
* \retval ИНАЧЕ любое другое значение, отличное от \ref MDBX_RESULT_TRUE
|
|
|
|
|
* и \ref MDBX_RESULT_FALSE, является кодом ошибки при позиционировании
|
|
|
|
|
* курса, либо определяемым пользователем кодом остановки поиска
|
|
|
|
|
* или ошибочной ситуации. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
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,
|
2023-11-18 23:20:53 +03:00
|
|
|
|
MDBX_cursor_op turn_op, void *arg);
|
|
|
|
|
|
2021-12-11 02:56:19 +03:00
|
|
|
|
/** \brief Retrieve multiple non-dupsort key/value pairs by cursor.
|
|
|
|
|
* \ingroup c_crud
|
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This function retrieves multiple key/data pairs from the table without
|
|
|
|
|
* \ref MDBX_DUPSORT option. For `MDBX_DUPSORT` tables please
|
2021-12-11 02:56:19 +03:00
|
|
|
|
* use \ref MDBX_GET_MULTIPLE and \ref MDBX_NEXT_MULTIPLE.
|
|
|
|
|
*
|
|
|
|
|
* The number of key and value items is returned in the `size_t count`
|
|
|
|
|
* refers. The addresses and lengths of the keys and values are returned in the
|
|
|
|
|
* array to which `pairs` refers.
|
|
|
|
|
* \see mdbx_cursor_get()
|
|
|
|
|
*
|
2023-10-08 11:55:30 +03:00
|
|
|
|
* \note The memory pointed to by the returned values is owned by the
|
|
|
|
|
* database. The caller MUST not dispose of the memory, and MUST not modify it
|
|
|
|
|
* in any way regardless in a read-only nor read-write transactions!
|
|
|
|
|
* For case a database opened without the \ref MDBX_WRITEMAP modification
|
|
|
|
|
* attempts likely will cause a `SIGSEGV`. However, when a database opened with
|
|
|
|
|
* the \ref MDBX_WRITEMAP or in case values returned inside read-write
|
|
|
|
|
* transaction are located on a "dirty" (modified and pending to commit) pages,
|
|
|
|
|
* such modification will silently accepted and likely will lead to DB and/or
|
|
|
|
|
* data corruption.
|
|
|
|
|
*
|
2021-12-11 02:56:19 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
|
|
|
|
* \param [out] count The number of key and value item returned, on success
|
|
|
|
|
* it always be the even because the key-value
|
|
|
|
|
* pairs are returned.
|
|
|
|
|
* \param [in,out] pairs A pointer to the array of key value pairs.
|
|
|
|
|
* \param [in] limit The size of pairs buffer as the number of items,
|
|
|
|
|
* but not a pairs.
|
|
|
|
|
* \param [in] op A cursor operation \ref MDBX_cursor_op (only
|
2024-05-19 22:07:58 +03:00
|
|
|
|
* \ref MDBX_FIRST and \ref MDBX_NEXT are supported).
|
2021-12-11 02:56:19 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
2024-05-19 22:07:58 +03:00
|
|
|
|
* \retval MDBX_NOTFOUND No any key-value pairs are available.
|
2021-12-11 02:56:19 +03:00
|
|
|
|
* \retval MDBX_ENODATA The cursor is already at the end of data.
|
2024-05-19 22:07:58 +03:00
|
|
|
|
* \retval MDBX_RESULT_TRUE The returned chunk is the last one,
|
|
|
|
|
* and there are no pairs left.
|
2021-12-11 02:56:19 +03:00
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_get_batch(MDBX_cursor *cursor, size_t *count, MDBX_val *pairs, size_t limit,
|
2021-12-11 02:56:19 +03:00
|
|
|
|
MDBX_cursor_op op);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Store by cursor.
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This function stores key/data pairs into the table. The cursor is
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* positioned at the new item, or on failure usually near it.
|
2017-05-19 16:20:02 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] key The key operated on.
|
|
|
|
|
* \param [in,out] data The data operated on.
|
|
|
|
|
* \param [in] flags Options for this operation. This parameter
|
|
|
|
|
* must be set to 0 or by bitwise OR'ing together
|
|
|
|
|
* one or more of the values described here:
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_CURRENT
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* Replace the item at the current cursor position. The key parameter
|
|
|
|
|
* must still be provided, and must match it, otherwise the function
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* return \ref MDBX_EKEYMISMATCH. With combination the
|
|
|
|
|
* \ref MDBX_ALLDUPS will replace all multi-values.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note MDBX allows (unlike LMDB) you to change the size of the data and
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* automatically handles reordering for sorted duplicates
|
|
|
|
|
* (see \ref MDBX_DUPSORT).
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_NODUPDATA
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* Enter the new key-value pair only if it does not already appear in the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* table. This flag may only be specified if the table was opened
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* with \ref MDBX_DUPSORT. The function will return \ref MDBX_KEYEXIST
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* if the key/data pair already appears in the table.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_NOOVERWRITE
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* Enter the new key/data pair only if the key does not already appear
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* in the table. The function will return \ref MDBX_KEYEXIST if the key
|
|
|
|
|
* already appears in the table, even if the table supports
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* duplicates (\ref MDBX_DUPSORT).
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_RESERVE
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* Reserve space for data of the given size, but don't copy the given
|
|
|
|
|
* data. Instead, return a pointer to the reserved space, which the
|
|
|
|
|
* caller can fill in later - before the next update operation or the
|
|
|
|
|
* transaction ends. This saves an extra memcpy if the data is being
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* generated later. This flag must not be specified if the table
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* was opened with \ref MDBX_DUPSORT.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_APPEND
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Append the given key/data pair to the end of the table. No key
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* comparisons are performed. This option allows fast bulk loading when
|
|
|
|
|
* keys are already known to be in the correct order. Loading unsorted
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* keys with this flag will cause a \ref MDBX_KEYEXIST error.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_APPENDDUP
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* As above, but for sorted dup data.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* - \ref MDBX_MULTIPLE
|
2017-05-22 20:02:36 +03:00
|
|
|
|
* Store multiple contiguous data elements in a single request. This flag
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* may only be specified if the table was opened with
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* \ref MDBX_DUPFIXED. With combination the \ref MDBX_ALLDUPS
|
|
|
|
|
* will replace all multi-values.
|
|
|
|
|
* The data argument must be an array of two \ref MDBX_val. The `iov_len`
|
|
|
|
|
* of the first \ref MDBX_val must be the size of a single data element.
|
|
|
|
|
* The `iov_base` of the first \ref MDBX_val must point to the beginning
|
|
|
|
|
* of the array of contiguous data elements which must be properly aligned
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* in case of table with \ref MDBX_INTEGERDUP flag.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* The `iov_len` of the second \ref MDBX_val must be the count of the
|
|
|
|
|
* number of data elements to store. On return this field will be set to
|
|
|
|
|
* the count of the number of elements actually written. The `iov_base` of
|
|
|
|
|
* the second \ref MDBX_val is unused.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2021-01-26 20:14:21 +03:00
|
|
|
|
* \see \ref c_crud_hints "Quick reference for Insert/Update/Delete operations"
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EKEYMISMATCH The given key value is mismatched to the current
|
|
|
|
|
* cursor position
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \retval MDBX_MAP_FULL The database is full,
|
|
|
|
|
* see \ref mdbx_env_set_mapsize().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_TXN_FULL The transaction has too many dirty pages.
|
|
|
|
|
* \retval MDBX_EACCES An attempt was made to write in a read-only
|
|
|
|
|
* transaction.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_put(MDBX_cursor *cursor, const MDBX_val *key, MDBX_val *data, MDBX_put_flags_t flags);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Delete current key/data pair.
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* This function deletes the key/data pair to which the cursor refers. This
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* does not invalidate the cursor, so operations such as \ref MDBX_NEXT can
|
|
|
|
|
* still be used on it. Both \ref MDBX_NEXT and \ref MDBX_GET_CURRENT will
|
|
|
|
|
* return the same record after this operation.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by mdbx_cursor_open().
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \param [in] flags Options for this operation. This parameter must be set
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* to one of the values described here.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-08-27 22:24:07 +03:00
|
|
|
|
* - \ref MDBX_CURRENT Delete only single entry at current cursor position.
|
|
|
|
|
* - \ref MDBX_ALLDUPS
|
|
|
|
|
* or \ref MDBX_NODUPDATA (supported for compatibility)
|
2020-06-04 12:59:05 +03:00
|
|
|
|
* Delete all of the data items for the current key. This flag has effect
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* only for table(s) was created with \ref MDBX_DUPSORT.
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2021-01-26 20:14:21 +03:00
|
|
|
|
* \see \ref c_crud_hints "Quick reference for Insert/Update/Delete operations"
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \retval MDBX_MAP_FULL The database is full,
|
|
|
|
|
* see \ref mdbx_env_set_mapsize().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_TXN_FULL The transaction has too many dirty pages.
|
|
|
|
|
* \retval MDBX_EACCES An attempt was made to write in a read-only
|
|
|
|
|
* transaction.
|
|
|
|
|
* \retval MDBX_EINVAL An invalid parameter was specified. */
|
2020-08-04 01:06:01 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_del(MDBX_cursor *cursor, MDBX_put_flags_t flags);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-12-16 11:54:24 +03:00
|
|
|
|
/** \brief Return count values (aka duplicates) for current key.
|
2021-05-03 14:19:34 +03:00
|
|
|
|
* \ingroup c_crud
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2024-12-16 11:54:24 +03:00
|
|
|
|
* \see mdbx_cursor_count_ex
|
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* This call is valid for all tables, but reasonable only for that support
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* sorted duplicate data items \ref MDBX_DUPSORT.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2024-12-18 01:25:50 +03:00
|
|
|
|
* \param [out] count Address where the count will be stored.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL Cursor is not initialized, or an invalid parameter
|
|
|
|
|
* was specified. */
|
2024-12-18 01:25:50 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_count(const MDBX_cursor *cursor, size_t *count);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-12-16 11:54:24 +03:00
|
|
|
|
/** \brief Return count values (aka duplicates) and nested b-tree statistics for current key.
|
|
|
|
|
* \ingroup c_crud
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_dbi_stat
|
|
|
|
|
* \see mdbx_dbi_dupsort_depthmask
|
|
|
|
|
* \see mdbx_cursor_count
|
|
|
|
|
*
|
|
|
|
|
* This call is valid for all tables, but reasonable only for that support
|
|
|
|
|
* sorted duplicate data items \ref MDBX_DUPSORT.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2024-12-18 01:25:50 +03:00
|
|
|
|
* \param [out] count Address where the count will be stored.
|
2024-12-16 11:54:24 +03:00
|
|
|
|
* \param [out] stat The address of an \ref MDBX_stat structure where
|
|
|
|
|
* the statistics of a nested b-tree will be copied.
|
|
|
|
|
* \param [in] bytes The size of \ref MDBX_stat.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_THREAD_MISMATCH Given transaction is not owned
|
|
|
|
|
* by current thread.
|
|
|
|
|
* \retval MDBX_EINVAL Cursor is not initialized, or an invalid parameter
|
|
|
|
|
* was specified. */
|
2024-12-18 01:25:50 +03:00
|
|
|
|
LIBMDBX_API int mdbx_cursor_count_ex(const MDBX_cursor *cursor, size_t *count, MDBX_stat *stat, size_t bytes);
|
2024-12-16 11:54:24 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Determines whether the cursor is pointed to a key-value pair or not,
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* i.e. was not positioned or points to the end of data.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_cursors
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \returns A \ref MDBX_RESULT_TRUE or \ref MDBX_RESULT_FALSE value,
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* otherwise the error code.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_RESULT_TRUE No more data available or cursor not
|
|
|
|
|
* positioned
|
|
|
|
|
* \retval MDBX_RESULT_FALSE A data is available
|
|
|
|
|
* \retval Otherwise the error code */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_cursor_eof(const MDBX_cursor *cursor);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Determines whether the cursor is pointed to the first key-value pair
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* or not.
|
|
|
|
|
* \ingroup c_cursors
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A MDBX_RESULT_TRUE or MDBX_RESULT_FALSE value,
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* otherwise the error code.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_RESULT_TRUE Cursor positioned to the first key-value pair
|
2020-08-21 18:01:16 +03:00
|
|
|
|
* \retval MDBX_RESULT_FALSE Cursor NOT positioned to the first key-value
|
|
|
|
|
* pair \retval Otherwise the error code */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_cursor_on_first(const MDBX_cursor *cursor);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2024-04-01 14:35:21 +03:00
|
|
|
|
/** \brief Определяет стоит ли курсор на первом или единственном
|
|
|
|
|
* мульти-значении соответствующем ключу.
|
2024-03-22 22:29:16 +03:00
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
* \param [in] cursor Курсор созданный посредством \ref mdbx_cursor_open().
|
|
|
|
|
* \returns Значание \ref MDBX_RESULT_TRUE, либо \ref MDBX_RESULT_FALSE,
|
|
|
|
|
* иначе код ошибки.
|
|
|
|
|
* \retval MDBX_RESULT_TRUE курсор установлен на первом или единственном
|
|
|
|
|
* мульти-значении соответствующем ключу.
|
|
|
|
|
* \retval MDBX_RESULT_FALSE курсор НЕ установлен на первом или единственном
|
|
|
|
|
* мульти-значении соответствующем ключу.
|
|
|
|
|
* \retval ИНАЧЕ код ошибки. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_cursor_on_first_dup(const MDBX_cursor *cursor);
|
2023-11-18 02:34:07 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Determines whether the cursor is pointed to the last key-value pair
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* or not.
|
|
|
|
|
* \ingroup c_cursors
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] cursor A cursor handle returned by \ref mdbx_cursor_open().
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \returns A \ref MDBX_RESULT_TRUE or \ref MDBX_RESULT_FALSE value,
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* otherwise the error code.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_RESULT_TRUE Cursor positioned to the last key-value pair
|
|
|
|
|
* \retval MDBX_RESULT_FALSE Cursor NOT positioned to the last key-value pair
|
|
|
|
|
* \retval Otherwise the error code */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_cursor_on_last(const MDBX_cursor *cursor);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Определяет стоит ли курсор на последнем или единственном
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* мульти-значении соответствующем ключу.
|
|
|
|
|
* \ingroup c_cursors
|
|
|
|
|
* \param [in] cursor Курсор созданный посредством \ref mdbx_cursor_open().
|
|
|
|
|
* \returns Значание \ref MDBX_RESULT_TRUE, либо \ref MDBX_RESULT_FALSE,
|
|
|
|
|
* иначе код ошибки.
|
|
|
|
|
* \retval MDBX_RESULT_TRUE курсор установлен на последнем или единственном
|
2024-03-22 22:29:16 +03:00
|
|
|
|
* мульти-значении соответствующем ключу.
|
|
|
|
|
* \retval MDBX_RESULT_FALSE курсор НЕ установлен на последнем или единственном
|
|
|
|
|
* мульти-значении соответствующем ключу.
|
|
|
|
|
* \retval ИНАЧЕ код ошибки. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_cursor_on_last_dup(const MDBX_cursor *cursor);
|
2023-11-18 02:34:07 +03:00
|
|
|
|
|
2020-07-28 15:05:35 +03:00
|
|
|
|
/** \addtogroup c_rqest
|
|
|
|
|
* \details \note The estimation result varies greatly depending on the filling
|
|
|
|
|
* of specific pages and the overall balance of the b-tree:
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
|
|
|
|
* 1. The number of items is estimated by analyzing the height and fullness of
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* the b-tree. The accuracy of the result directly depends on the balance of
|
|
|
|
|
* the b-tree, which in turn is determined by the history of previous
|
|
|
|
|
* insert/delete operations and the nature of the data (i.e. variability of
|
|
|
|
|
* keys length and so on). Therefore, the accuracy of the estimation can vary
|
|
|
|
|
* greatly in a particular situation.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
|
|
|
|
* 2. To understand the potential spread of results, you should consider a
|
|
|
|
|
* possible situations basing on the general criteria for splitting and merging
|
|
|
|
|
* b-tree pages:
|
|
|
|
|
* - the page is split into two when there is no space for added data;
|
|
|
|
|
* - two pages merge if the result fits in half a page;
|
|
|
|
|
* - thus, the b-tree can consist of an arbitrary combination of pages filled
|
|
|
|
|
* both completely and only 1/4. Therefore, in the worst case, the result
|
|
|
|
|
* can diverge 4 times for each level of the b-tree excepting the first and
|
|
|
|
|
* the last.
|
|
|
|
|
*
|
|
|
|
|
* 3. In practice, the probability of extreme cases of the above situation is
|
|
|
|
|
* close to zero and in most cases the error does not exceed a few percent. On
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* the other hand, it's just a chance you shouldn't overestimate. */
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Estimates the distance between cursors as a number of elements.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \ingroup c_rqest
|
|
|
|
|
*
|
|
|
|
|
* This function performs a rough estimate based only on b-tree pages that are
|
|
|
|
|
* common for the both cursor's stacks. The results of such estimation can be
|
|
|
|
|
* used to build and/or optimize query execution plans.
|
|
|
|
|
*
|
|
|
|
|
* Please see notes on accuracy of the result in the details
|
|
|
|
|
* of \ref c_rqest section.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* Both cursors must be initialized for the same table and the same
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* transaction.
|
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] first The first cursor for estimation.
|
|
|
|
|
* \param [in] last The second cursor for estimation.
|
|
|
|
|
* \param [out] distance_items The pointer to store estimated distance value,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* i.e. `*distance_items = distance(first, last)`.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_estimate_distance(const MDBX_cursor *first, const MDBX_cursor *last, ptrdiff_t *distance_items);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Estimates the move distance.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_rqest
|
|
|
|
|
*
|
|
|
|
|
* This function performs a rough estimate distance between the current
|
|
|
|
|
* cursor position and next position after the specified move-operation with
|
|
|
|
|
* given key and data. The results of such estimation can be used to build
|
|
|
|
|
* and/or optimize query execution plans. Current cursor position and state are
|
|
|
|
|
* preserved.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Please see notes on accuracy of the result in the details
|
|
|
|
|
* of \ref c_rqest section.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] cursor Cursor for estimation.
|
|
|
|
|
* \param [in,out] key The key for a retrieved item.
|
|
|
|
|
* \param [in,out] data The data of a retrieved item.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] move_op A cursor operation \ref MDBX_cursor_op.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] distance_items A pointer to store estimated move distance
|
|
|
|
|
* as the number of elements.
|
2019-09-18 04:00:16 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_estimate_move(const MDBX_cursor *cursor, MDBX_val *key, MDBX_val *data, MDBX_cursor_op move_op,
|
2019-09-18 04:00:16 +03:00
|
|
|
|
ptrdiff_t *distance_items);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Estimates the size of a range as a number of elements.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_rqest
|
|
|
|
|
*
|
|
|
|
|
* The results of such estimation can be used to build and/or optimize query
|
|
|
|
|
* execution plans.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* Please see notes on accuracy of the result in the details
|
|
|
|
|
* of \ref c_rqest section.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] txn A transaction handle returned
|
|
|
|
|
* by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \param [in] begin_key The key of range beginning or NULL for explicit FIRST.
|
|
|
|
|
* \param [in] begin_data Optional additional data to seeking among sorted
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* duplicates.
|
|
|
|
|
* Only for \ref MDBX_DUPSORT, NULL otherwise.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \param [in] end_key The key of range ending or NULL for explicit LAST.
|
|
|
|
|
* \param [in] end_data Optional additional data to seeking among sorted
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* duplicates.
|
|
|
|
|
* Only for \ref MDBX_DUPSORT, NULL otherwise.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] distance_items A pointer to store range estimation result.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
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,
|
2020-07-23 19:24:21 +03:00
|
|
|
|
ptrdiff_t *distance_items);
|
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief The EPSILON value for mdbx_estimate_range()
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_rqest */
|
2020-07-23 19:24:21 +03:00
|
|
|
|
#define MDBX_EPSILON ((MDBX_val *)((ptrdiff_t)-1))
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Determines whether the given address is on a dirty database page of
|
2022-01-25 20:25:10 +03:00
|
|
|
|
* the transaction or not.
|
|
|
|
|
* \ingroup c_statinfo
|
2020-07-25 04:30:44 +03:00
|
|
|
|
*
|
|
|
|
|
* Ultimately, this allows to avoid copy data from non-dirty pages.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
|
|
|
|
* "Dirty" pages are those that have already been changed during a write
|
|
|
|
|
* transaction. Accordingly, any further changes may result in such pages being
|
|
|
|
|
* overwritten. Therefore, all functions libmdbx performing changes inside the
|
|
|
|
|
* database as arguments should NOT get pointers to data in those pages. In
|
|
|
|
|
* turn, "not dirty" pages before modification will be copied.
|
|
|
|
|
*
|
|
|
|
|
* In other words, data from dirty pages must either be copied before being
|
|
|
|
|
* passed as arguments for further processing or rejected at the argument
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* validation stage. Thus, `mdbx_is_dirty()` allows you to get rid of
|
|
|
|
|
* unnecessary copying, and perform a more complete check of the arguments.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \note The address passed must point to the beginning of the data. This is
|
|
|
|
|
* the only way to ensure that the actual page header is physically located in
|
|
|
|
|
* the same memory page, including for multi-pages with long data.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \note In rare cases the function may return a false positive answer
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* (\ref MDBX_RESULT_TRUE when data is NOT on a dirty page), but never a false
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* negative if the arguments are correct.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] ptr The address of data to check.
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A MDBX_RESULT_TRUE or MDBX_RESULT_FALSE value,
|
2024-04-01 14:35:21 +03:00
|
|
|
|
* otherwise the error code.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval MDBX_RESULT_TRUE Given address is on the dirty page.
|
|
|
|
|
* \retval MDBX_RESULT_FALSE Given address is NOT on the dirty page.
|
|
|
|
|
* \retval Otherwise the error code. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_is_dirty(const MDBX_txn *txn, const void *ptr);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Sequence generation for a table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2019-09-26 20:00:22 +03:00
|
|
|
|
*
|
|
|
|
|
* The function allows to create a linear sequence of unique positive integers
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* for each table. The function can be called for a read transaction to
|
2019-09-26 20:00:22 +03:00
|
|
|
|
* retrieve the current sequence value, and the increment must be zero.
|
|
|
|
|
* Sequence changes become visible outside the current write transaction after
|
|
|
|
|
* it is committed, and discarded on abort.
|
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned
|
|
|
|
|
* by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] result The optional address where the value of sequence
|
|
|
|
|
* before the change will be stored.
|
|
|
|
|
* \param [in] increment Value to increase the sequence,
|
|
|
|
|
* must be 0 for read-only transactions.
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* some possible errors are:
|
|
|
|
|
* \retval MDBX_RESULT_TRUE Increasing the sequence has resulted in an
|
|
|
|
|
* overflow and therefore cannot be executed. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_dbi_sequence(MDBX_txn *txn, MDBX_dbi dbi, uint64_t *result, uint64_t increment);
|
2019-09-18 04:00:16 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Compare two keys according to a particular table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2021-07-20 01:50:54 +03:00
|
|
|
|
* \see MDBX_cmp_func
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
|
|
|
|
* This returns a comparison as if the two data items were keys in the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* specified table.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2024-12-06 22:15:23 +03:00
|
|
|
|
* \warning There is a Undefined behavior if one of arguments is invalid.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] a The first item to compare.
|
|
|
|
|
* \param [in] b The second item to compare.
|
|
|
|
|
*
|
|
|
|
|
* \returns < 0 if a < b, 0 if a == b, > 0 if a > b */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_cmp(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *a,
|
2020-09-14 16:40:46 +03:00
|
|
|
|
const MDBX_val *b);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Returns default internal key's comparator for given table flags.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API MDBX_cmp_func *mdbx_get_keycmp(MDBX_db_flags_t flags);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Compare two data items according to a particular table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_crud
|
2021-07-20 01:50:54 +03:00
|
|
|
|
* \see MDBX_cmp_func
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2019-09-18 04:00:16 +03:00
|
|
|
|
* This returns a comparison as if the two items were data items of the
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* specified table.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2024-12-06 22:15:23 +03:00
|
|
|
|
* \warning There is a Undefined behavior if one of arguments is invalid.
|
2017-05-22 20:02:36 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2024-08-03 13:25:44 +03:00
|
|
|
|
* \param [in] dbi A table handle returned by \ref mdbx_dbi_open().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] a The first item to compare.
|
|
|
|
|
* \param [in] b The second item to compare.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns < 0 if a < b, 0 if a == b, > 0 if a > b */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API int mdbx_dcmp(const MDBX_txn *txn, MDBX_dbi dbi, const MDBX_val *a,
|
2020-09-14 16:40:46 +03:00
|
|
|
|
const MDBX_val *b);
|
2020-07-23 19:24:21 +03:00
|
|
|
|
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** \brief Returns default internal data's comparator for given table flags
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_CONST_FUNCTION LIBMDBX_API MDBX_cmp_func *mdbx_get_datacmp(MDBX_db_flags_t flags);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief A callback function used to enumerate the reader lock table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2022-04-20 18:03:06 +03:00
|
|
|
|
* \param [in] ctx An arbitrary context pointer for the callback.
|
|
|
|
|
* \param [in] num The serial number during enumeration,
|
|
|
|
|
* starting from 1.
|
|
|
|
|
* \param [in] slot The reader lock table slot number.
|
|
|
|
|
* \param [in] txnid The ID of the transaction being read,
|
|
|
|
|
* i.e. the MVCC-snapshot number.
|
|
|
|
|
* \param [in] lag The lag from a recent MVCC-snapshot,
|
|
|
|
|
* i.e. the number of committed write transactions
|
|
|
|
|
* since the current read transaction started.
|
|
|
|
|
* \param [in] pid The reader process ID.
|
|
|
|
|
* \param [in] thread The reader thread ID.
|
|
|
|
|
* \param [in] bytes_used The number of last used page
|
|
|
|
|
* in the MVCC-snapshot which being read,
|
2023-01-10 14:16:08 +03:00
|
|
|
|
* i.e. database file can't be shrunk beyond this.
|
2022-04-20 18:03:06 +03:00
|
|
|
|
* \param [in] bytes_retained The total size of the database pages that were
|
|
|
|
|
* retired by committed write transactions after
|
|
|
|
|
* the reader's MVCC-snapshot,
|
|
|
|
|
* i.e. the space which would be freed after
|
|
|
|
|
* the Reader releases the MVCC-snapshot
|
|
|
|
|
* for reuse by completion read transaction.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
2020-08-23 12:40:41 +03:00
|
|
|
|
* \returns < 0 on failure, >= 0 on success. \see mdbx_reader_list() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef 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) MDBX_CXX17_NOEXCEPT;
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-25 01:13:11 +03:00
|
|
|
|
/** \brief Enumerate the entries in the reader lock table.
|
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
|
|
|
|
* \param [in] func A \ref MDBX_reader_list_func function.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] ctx An arbitrary context pointer for the enumeration
|
|
|
|
|
* function.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* or \ref MDBX_RESULT_TRUE if the reader lock table is empty. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_reader_list(const MDBX_env *env, MDBX_reader_list_func *func, void *ctx);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Check for stale entries in the reader lock table.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] dead Number of stale slots that were cleared.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
2020-07-30 01:17:03 +03:00
|
|
|
|
* or \ref MDBX_RESULT_TRUE if a dead reader(s) found or mutex was recovered. */
|
2017-05-24 01:42:10 +03:00
|
|
|
|
LIBMDBX_API int mdbx_reader_check(MDBX_env *env, int *dead);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Returns a lag of the reading for the given transaction.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_statinfo
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
|
|
|
|
* Returns an information for estimate how much given read-only
|
|
|
|
|
* transaction is lagging relative the to actual head.
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \deprecated Please use \ref mdbx_txn_info() instead.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] txn A transaction handle returned by \ref mdbx_txn_begin().
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [out] percent Percentage of page allocation in the database.
|
2017-04-26 18:12:48 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns Number of transactions committed after the given was started for
|
|
|
|
|
* read, or negative value on failure. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_DEPRECATED LIBMDBX_API int mdbx_txn_straggler(const MDBX_txn *txn, int *percent);
|
2016-11-21 19:32:12 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Registers the current thread as a reader for the environment.
|
2020-07-30 01:17:03 +03:00
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
*
|
|
|
|
|
* To perform read operations without blocking, a reader slot must be assigned
|
|
|
|
|
* for each thread. However, this assignment requires a short-term lock
|
|
|
|
|
* acquisition which is performed automatically. This function allows you to
|
|
|
|
|
* assign the reader slot in advance and thus avoid capturing the blocker when
|
|
|
|
|
* the read transaction starts firstly from current thread.
|
|
|
|
|
* \see mdbx_thread_unregister()
|
|
|
|
|
*
|
|
|
|
|
* \note Threads are registered automatically the first time a read transaction
|
|
|
|
|
* starts. Therefore, there is no need to use this function, except in
|
|
|
|
|
* special cases.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success,
|
|
|
|
|
* or \ref MDBX_RESULT_TRUE if thread is already registered. */
|
2020-09-10 01:15:35 +03:00
|
|
|
|
LIBMDBX_API int mdbx_thread_register(const MDBX_env *env);
|
2020-07-30 01:17:03 +03:00
|
|
|
|
|
2020-09-07 01:54:36 +03:00
|
|
|
|
/** \brief Unregisters the current thread as a reader for the environment.
|
2020-07-30 01:17:03 +03:00
|
|
|
|
* \ingroup c_extra
|
|
|
|
|
*
|
|
|
|
|
* To perform read operations without blocking, a reader slot must be assigned
|
|
|
|
|
* for each thread. However, the assigned reader slot will remain occupied until
|
|
|
|
|
* the thread ends or the environment closes. This function allows you to
|
|
|
|
|
* explicitly release the assigned reader slot.
|
|
|
|
|
* \see mdbx_thread_register()
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
|
|
|
|
*
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success, or
|
2020-09-21 23:51:47 -04:00
|
|
|
|
* \ref MDBX_RESULT_TRUE if thread is not registered or already unregistered. */
|
2020-09-10 01:15:35 +03:00
|
|
|
|
LIBMDBX_API int mdbx_thread_unregister(const MDBX_env *env);
|
2020-07-30 01:17:03 +03:00
|
|
|
|
|
2020-09-29 19:24:57 +03:00
|
|
|
|
/** \brief A Handle-Slow-Readers callback function to resolve database
|
|
|
|
|
* full/overflow issue due to a reader(s) which prevents the old data from being
|
|
|
|
|
* recycled.
|
|
|
|
|
* \ingroup c_err
|
2019-09-28 19:03:02 +03:00
|
|
|
|
*
|
|
|
|
|
* Read transactions prevent reuse of pages freed by newer write transactions,
|
|
|
|
|
* thus the database can grow quickly. This callback will be called when there
|
2020-09-29 19:24:57 +03:00
|
|
|
|
* is not enough space in the database (i.e. before increasing the database size
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* or before \ref MDBX_MAP_FULL error) and thus can be used to resolve issues
|
|
|
|
|
* with a "long-lived" read transactions.
|
2022-02-08 14:37:11 +03:00
|
|
|
|
* \see mdbx_env_set_hsr()
|
|
|
|
|
* \see mdbx_env_get_hsr()
|
2024-07-13 17:03:06 +03:00
|
|
|
|
* \see mdbx_txn_park()
|
2022-02-08 14:37:11 +03:00
|
|
|
|
* \see <a href="intro.html#long-lived-read">Long-lived read transactions</a>
|
2020-09-29 19:24:57 +03:00
|
|
|
|
*
|
|
|
|
|
* Using this callback you can choose how to resolve the situation:
|
|
|
|
|
* - abort the write transaction with an error;
|
|
|
|
|
* - wait for the read transaction(s) to complete;
|
|
|
|
|
* - notify a thread performing a long-lived read transaction
|
|
|
|
|
* and wait for an effect;
|
|
|
|
|
* - kill the thread or whole process that performs the long-lived read
|
|
|
|
|
* transaction;
|
2019-09-28 19:03:02 +03:00
|
|
|
|
*
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* Depending on the arguments and needs, your implementation may wait,
|
|
|
|
|
* terminate a process or thread that is performing a long read, or perform
|
|
|
|
|
* some other action. In doing so it is important that the returned code always
|
|
|
|
|
* corresponds to the performed action.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2020-09-29 19:24:57 +03:00
|
|
|
|
* \param [in] txn The current write transaction which internally at
|
|
|
|
|
* the \ref MDBX_MAP_FULL condition.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] pid A pid of the reader process.
|
|
|
|
|
* \param [in] tid A thread_id of the reader thread.
|
2020-09-29 19:24:57 +03:00
|
|
|
|
* \param [in] laggard An oldest read transaction number on which stalled.
|
2020-10-20 15:42:50 +03:00
|
|
|
|
* \param [in] gap A lag from the last committed txn.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \param [in] space A space that actually become available for reuse after
|
|
|
|
|
* this reader finished. The callback function can take
|
|
|
|
|
* this value into account to evaluate the impact that
|
|
|
|
|
* a long-running transaction has.
|
|
|
|
|
* \param [in] retry A retry number starting from 0.
|
2022-07-08 23:11:16 +03:00
|
|
|
|
* If callback has returned 0 at least once, then at end of
|
|
|
|
|
* current handling loop the callback function will be
|
|
|
|
|
* called additionally with negative `retry` value to notify
|
|
|
|
|
* about the end of loop. The callback function can use this
|
|
|
|
|
* fact to implement timeout reset logic while waiting for
|
|
|
|
|
* a readers.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \returns The RETURN CODE determines the further actions libmdbx and must
|
|
|
|
|
* match the action which was executed by the callback:
|
|
|
|
|
*
|
|
|
|
|
* \retval -2 or less An error condition and the reader was not killed.
|
|
|
|
|
*
|
|
|
|
|
* \retval -1 The callback was unable to solve the problem and
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* agreed on \ref MDBX_MAP_FULL error;
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* libmdbx should increase the database size or
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* return \ref MDBX_MAP_FULL error.
|
2020-07-23 19:24:21 +03:00
|
|
|
|
*
|
|
|
|
|
* \retval 0 (zero) The callback solved the problem or just waited for
|
2019-09-28 19:03:02 +03:00
|
|
|
|
* a while, libmdbx should rescan the reader lock table and
|
|
|
|
|
* retry. This also includes a situation when corresponding
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* transaction terminated in normal way by
|
|
|
|
|
* \ref mdbx_txn_abort() or \ref mdbx_txn_reset(),
|
|
|
|
|
* and my be restarted. I.e. reader slot don't needed
|
|
|
|
|
* to be cleaned from transaction.
|
2019-09-28 19:03:02 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval 1 Transaction aborted asynchronous and reader slot
|
|
|
|
|
* should be cleared immediately, i.e. read transaction
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* will not continue but \ref mdbx_txn_abort()
|
2022-06-30 21:38:32 +03:00
|
|
|
|
* nor \ref mdbx_txn_reset() will be called later.
|
2019-09-28 19:03:02 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \retval 2 or great The reader process was terminated or killed,
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* and libmdbx should entirely reset reader registration.
|
|
|
|
|
*/
|
2024-12-11 21:22:04 +03:00
|
|
|
|
typedef 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) MDBX_CXX17_NOEXCEPT;
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2020-09-29 19:24:57 +03:00
|
|
|
|
/** \brief Sets a Handle-Slow-Readers callback to resolve database full/overflow
|
|
|
|
|
* issue due to a reader(s) which prevents the old data from being recycled.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_err
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-09-29 19:24:57 +03:00
|
|
|
|
* The callback will only be triggered when the database is full due to a
|
|
|
|
|
* reader(s) prevents the old data from being recycled.
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2022-02-08 14:37:11 +03:00
|
|
|
|
* \see MDBX_hsr_func
|
2020-09-29 19:24:57 +03:00
|
|
|
|
* \see mdbx_env_get_hsr()
|
2024-07-13 17:03:06 +03:00
|
|
|
|
* \see mdbx_txn_park()
|
2022-02-08 14:37:11 +03:00
|
|
|
|
* \see <a href="intro.html#long-lived-read">Long-lived read transactions</a>
|
2020-09-29 19:24:57 +03:00
|
|
|
|
*
|
|
|
|
|
* \param [in] env An environment handle returned
|
|
|
|
|
* by \ref mdbx_env_create().
|
|
|
|
|
* \param [in] hsr_callback A \ref MDBX_hsr_func function
|
|
|
|
|
* or NULL to disable.
|
2017-05-23 22:07:35 +03:00
|
|
|
|
*
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2020-09-29 19:24:57 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_set_hsr(MDBX_env *env, MDBX_hsr_func *hsr_callback);
|
2016-11-21 19:32:12 +03:00
|
|
|
|
|
2020-09-29 19:24:57 +03:00
|
|
|
|
/** \brief Gets current Handle-Slow-Readers callback used to resolve database
|
|
|
|
|
* full/overflow issue due to a reader(s) which prevents the old data from being
|
|
|
|
|
* recycled.
|
2022-02-08 14:37:11 +03:00
|
|
|
|
* \see MDBX_hsr_func
|
2020-09-29 19:24:57 +03:00
|
|
|
|
* \see mdbx_env_set_hsr()
|
2024-07-13 17:03:06 +03:00
|
|
|
|
* \see mdbx_txn_park()
|
2022-02-08 14:37:11 +03:00
|
|
|
|
* \see <a href="intro.html#long-lived-read">Long-lived read transactions</a>
|
2017-02-21 20:16:54 +03:00
|
|
|
|
*
|
2020-07-28 15:05:35 +03:00
|
|
|
|
* \param [in] env An environment handle returned by \ref mdbx_env_create().
|
2017-05-17 20:06:57 +03:00
|
|
|
|
*
|
2020-09-29 19:24:57 +03:00
|
|
|
|
* \returns A MDBX_hsr_func function or NULL if disabled
|
|
|
|
|
* or something wrong. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_NOTHROW_PURE_FUNCTION LIBMDBX_API MDBX_hsr_func *mdbx_env_get_hsr(const MDBX_env *env);
|
2017-02-21 20:16:54 +03:00
|
|
|
|
|
2023-03-28 21:24:18 +03:00
|
|
|
|
/** \defgroup chk Checking and Recovery
|
|
|
|
|
* Basically this is internal API for `mdbx_chk` tool, etc.
|
|
|
|
|
* You should avoid to use it, except some extremal special cases.
|
2020-07-25 04:30:44 +03:00
|
|
|
|
* \ingroup c_extra
|
2020-07-23 19:24:21 +03:00
|
|
|
|
* @{ */
|
2019-09-26 20:00:22 +03:00
|
|
|
|
|
2023-03-28 21:24:18 +03:00
|
|
|
|
/** \brief Acquires write-transaction lock.
|
|
|
|
|
* Provided for custom and/or complex locking scenarios.
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
|
|
|
|
LIBMDBX_API int mdbx_txn_lock(MDBX_env *env, bool dont_wait);
|
|
|
|
|
|
|
|
|
|
/** \brief Releases write-transaction lock.
|
|
|
|
|
* Provided for custom and/or complex locking scenarios.
|
|
|
|
|
* \returns A non-zero error value on failure and 0 on success. */
|
2023-10-10 23:14:40 +03:00
|
|
|
|
LIBMDBX_API int mdbx_txn_unlock(MDBX_env *env);
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
2020-09-19 00:18:55 +03:00
|
|
|
|
/** \brief Open an environment instance using specific meta-page
|
|
|
|
|
* for checking and recovery.
|
|
|
|
|
*
|
2020-09-23 02:54:48 +03:00
|
|
|
|
* This function mostly of internal API for `mdbx_chk` utility and subject to
|
|
|
|
|
* change at any time. Do not use this function to avoid shooting your own
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* leg(s).
|
|
|
|
|
*
|
|
|
|
|
* \note On Windows the \ref mdbx_env_open_for_recoveryW() is recommended
|
|
|
|
|
* to use. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_open_for_recovery(MDBX_env *env, const char *pathname, unsigned target_meta, bool writeable);
|
2023-02-09 20:02:17 +03:00
|
|
|
|
|
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
|
|
|
|
/** \copydoc mdbx_env_open_for_recovery()
|
2024-08-03 12:48:23 +03:00
|
|
|
|
* \ingroup c_extra
|
2023-02-09 20:02:17 +03:00
|
|
|
|
* \note Available only on Windows.
|
|
|
|
|
* \see mdbx_env_open_for_recovery() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_open_for_recoveryW(MDBX_env *env, const wchar_t *pathname, unsigned target_meta,
|
2022-08-09 18:27:43 +03:00
|
|
|
|
bool writeable);
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define mdbx_env_open_for_recoveryT(env, pathname, target_mets, writeable) \
|
2024-10-23 19:12:31 +03:00
|
|
|
|
mdbx_env_open_for_recoveryW(env, pathname, target_mets, writeable)
|
|
|
|
|
#else
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define mdbx_env_open_for_recoveryT(env, pathname, target_mets, writeable) \
|
2024-10-23 19:12:31 +03:00
|
|
|
|
mdbx_env_open_for_recovery(env, pathname, target_mets, writeable)
|
2022-08-09 18:27:43 +03:00
|
|
|
|
#endif /* Windows */
|
2020-09-19 00:18:55 +03:00
|
|
|
|
|
2020-09-23 02:54:48 +03:00
|
|
|
|
/** \brief Turn database to the specified meta-page.
|
|
|
|
|
*
|
|
|
|
|
* This function mostly of internal API for `mdbx_chk` utility and subject to
|
|
|
|
|
* change at any time. Do not use this function to avoid shooting your own
|
|
|
|
|
* leg(s). */
|
|
|
|
|
LIBMDBX_API int mdbx_env_turn_for_recovery(MDBX_env *env, unsigned target_meta);
|
|
|
|
|
|
2024-03-24 11:11:19 +03:00
|
|
|
|
/** \brief Получает базовую информацию о БД не открывая её.
|
|
|
|
|
* \ingroup c_opening
|
|
|
|
|
*
|
|
|
|
|
* Назначение функции в получении базовой информации без открытия БД и
|
|
|
|
|
* отображения данных в память (что может быть достаточно затратным действием
|
|
|
|
|
* для ядра ОС). Полученная таким образом информация может быть полезной для
|
|
|
|
|
* подстройки опций работы с БД перед её открытием, а также в сценариях файловых
|
|
|
|
|
* менеджерах и прочих вспомогательных утилитах.
|
|
|
|
|
*
|
|
|
|
|
* \todo Добавить в API возможность установки обратного вызова для ревизии опций
|
|
|
|
|
* работы с БД в процессе её открытия (при удержании блокировок).
|
|
|
|
|
*
|
|
|
|
|
* \param [in] pathname Путь к директории или файлу БД.
|
2024-04-04 17:32:49 +03:00
|
|
|
|
* \param [out] info Указатель на структуру \ref MDBX_envinfo
|
2024-03-24 11:11:19 +03:00
|
|
|
|
* для получения информации.
|
2024-04-04 17:32:49 +03:00
|
|
|
|
* \param [in] bytes Актуальный размер структуры \ref MDBX_envinfo, это
|
2024-03-24 11:11:19 +03:00
|
|
|
|
* значение используется для обеспечения совместимости
|
|
|
|
|
* ABI.
|
|
|
|
|
*
|
|
|
|
|
* \note Заполняется только некоторые поля структуры \ref MDBX_envinfo, значения
|
|
|
|
|
* которых возможно получить без отображения файлов БД в память и без захвата
|
|
|
|
|
* блокировок: размер страницы БД, геометрия БД, размер распределенного места
|
|
|
|
|
* (номер последней распределенной страницы), номер последней транзакции и
|
|
|
|
|
* boot-id.
|
|
|
|
|
*
|
|
|
|
|
* \warning Полученная информация является снимком на время выполнения функции и
|
|
|
|
|
* может быть в любой момент изменена работающим с БД процессом. В том числе,
|
|
|
|
|
* нет препятствий к тому, чтобы другой процесс удалил БД и создал её заново с
|
|
|
|
|
* другим размером страницы и/или изменением любых других параметров.
|
|
|
|
|
*
|
2024-07-05 20:33:43 +03:00
|
|
|
|
* \returns Ненулевое значение кода ошибки, либо 0 при успешном выполнении. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_preopen_snapinfo(const char *pathname, MDBX_envinfo *info, size_t bytes);
|
2024-03-05 01:56:04 +03:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64) || defined(DOXYGEN)
|
|
|
|
|
/** \copydoc mdbx_preopen_snapinfo()
|
2024-08-03 12:48:23 +03:00
|
|
|
|
* \ingroup c_opening
|
2024-03-05 01:56:04 +03:00
|
|
|
|
* \note Available only on Windows.
|
|
|
|
|
* \see mdbx_preopen_snapinfo() */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
LIBMDBX_API int mdbx_preopen_snapinfoW(const wchar_t *pathname, MDBX_envinfo *info, size_t bytes);
|
|
|
|
|
#define mdbx_preopen_snapinfoT(pathname, info, bytes) mdbx_preopen_snapinfoW(pathname, info, bytes)
|
2024-10-23 19:12:31 +03:00
|
|
|
|
#else
|
2024-12-11 21:22:04 +03:00
|
|
|
|
#define mdbx_preopen_snapinfoT(pathname, info, bytes) mdbx_preopen_snapinfo(pathname, info, bytes)
|
2024-03-05 01:56:04 +03:00
|
|
|
|
#endif /* Windows */
|
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Флаги/опции для проверки целостности базы данных.
|
|
|
|
|
* \note Данный API еще не зафиксирован, в последующих версиях могут быть
|
|
|
|
|
* незначительные доработки и изменения.
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* \see mdbx_env_chk() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_chk_flags {
|
2023-03-28 21:24:18 +03:00
|
|
|
|
/** Режим проверки по-умолчанию, в том числе в режиме только-чтения. */
|
|
|
|
|
MDBX_CHK_DEFAULTS = 0,
|
|
|
|
|
|
|
|
|
|
/** Проверка в режиме чтения-записи, с захватом блокировки и приостановки
|
|
|
|
|
* пишущих транзакций. */
|
|
|
|
|
MDBX_CHK_READWRITE = 1,
|
|
|
|
|
|
|
|
|
|
/** Пропустить обход дерева страниц. */
|
|
|
|
|
MDBX_CHK_SKIP_BTREE_TRAVERSAL = 2,
|
|
|
|
|
|
|
|
|
|
/** Пропустить просмотр записей ключ-значение. */
|
|
|
|
|
MDBX_CHK_SKIP_KV_TRAVERSAL = 4,
|
|
|
|
|
|
|
|
|
|
/** Игнорировать порядок ключей и записей.
|
|
|
|
|
* \note Требуется при проверке унаследованных БД созданных с использованием
|
|
|
|
|
* нестандартных (пользовательских) функций сравнения ключей или значений. */
|
|
|
|
|
MDBX_CHK_IGNORE_ORDER = 8
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_chk_flags_t;
|
|
|
|
|
DEFINE_ENUM_FLAG_OPERATORS(MDBX_chk_flags)
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Уровни логирование/детализации информации,
|
2024-04-01 14:29:52 +03:00
|
|
|
|
* поставляемой через обратные вызовы при проверке целостности базы данных.
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* \see mdbx_env_chk() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_chk_severity {
|
2023-03-28 21:24:18 +03:00
|
|
|
|
MDBX_chk_severity_prio_shift = 4,
|
|
|
|
|
MDBX_chk_severity_kind_mask = 0xF,
|
|
|
|
|
MDBX_chk_fatal = 0x00u,
|
|
|
|
|
MDBX_chk_error = 0x11u,
|
|
|
|
|
MDBX_chk_warning = 0x22u,
|
|
|
|
|
MDBX_chk_notice = 0x33u,
|
|
|
|
|
MDBX_chk_result = 0x44u,
|
|
|
|
|
MDBX_chk_resolution = 0x55u,
|
|
|
|
|
MDBX_chk_processing = 0x56u,
|
|
|
|
|
MDBX_chk_info = 0x67u,
|
|
|
|
|
MDBX_chk_verbose = 0x78u,
|
|
|
|
|
MDBX_chk_details = 0x89u,
|
|
|
|
|
MDBX_chk_extra = 0x9Au
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_chk_severity_t;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Стадии проверки,
|
2024-04-01 14:29:52 +03:00
|
|
|
|
* сообщаемые через обратные вызовы при проверке целостности базы данных.
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* \see mdbx_env_chk() */
|
2024-05-19 22:07:58 +03:00
|
|
|
|
typedef enum MDBX_chk_stage {
|
2023-03-28 21:24:18 +03:00
|
|
|
|
MDBX_chk_none,
|
|
|
|
|
MDBX_chk_init,
|
|
|
|
|
MDBX_chk_lock,
|
|
|
|
|
MDBX_chk_meta,
|
2024-05-19 22:07:58 +03:00
|
|
|
|
MDBX_chk_tree,
|
|
|
|
|
MDBX_chk_gc,
|
2023-03-28 21:24:18 +03:00
|
|
|
|
MDBX_chk_space,
|
2024-05-19 22:07:58 +03:00
|
|
|
|
MDBX_chk_maindb,
|
2024-08-03 13:25:44 +03:00
|
|
|
|
MDBX_chk_tables,
|
2023-03-28 21:24:18 +03:00
|
|
|
|
MDBX_chk_conclude,
|
|
|
|
|
MDBX_chk_unlock,
|
|
|
|
|
MDBX_chk_finalize
|
2024-05-19 22:07:58 +03:00
|
|
|
|
} MDBX_chk_stage_t;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Виртуальная строка отчета, формируемого при проверке целостности базы
|
|
|
|
|
* данных. \see mdbx_env_chk() */
|
2023-03-28 21:24:18 +03:00
|
|
|
|
typedef struct MDBX_chk_line {
|
|
|
|
|
struct MDBX_chk_context *ctx;
|
|
|
|
|
uint8_t severity, scope_depth, empty;
|
|
|
|
|
char *begin, *end, *out;
|
|
|
|
|
} MDBX_chk_line_t;
|
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Проблема обнаруженная при проверке целостности базы данных.
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* \see mdbx_env_chk() */
|
|
|
|
|
typedef struct MDBX_chk_issue {
|
|
|
|
|
struct MDBX_chk_issue *next;
|
|
|
|
|
size_t count;
|
|
|
|
|
const char *caption;
|
|
|
|
|
} MDBX_chk_issue_t;
|
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Иерархический контекст при проверке целостности базы данных.
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* \see mdbx_env_chk() */
|
|
|
|
|
typedef struct MDBX_chk_scope {
|
|
|
|
|
MDBX_chk_issue_t *issues;
|
|
|
|
|
struct MDBX_chk_internal *internal;
|
|
|
|
|
const void *object;
|
2024-05-19 22:07:58 +03:00
|
|
|
|
MDBX_chk_stage_t stage;
|
|
|
|
|
MDBX_chk_severity_t verbosity;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
size_t subtotal_issues;
|
|
|
|
|
union {
|
|
|
|
|
void *ptr;
|
|
|
|
|
size_t number;
|
|
|
|
|
} usr_z, usr_v, usr_o;
|
|
|
|
|
} MDBX_chk_scope_t;
|
|
|
|
|
|
|
|
|
|
/** \brief Пользовательский тип для привязки дополнительных данных,
|
2024-04-01 14:29:52 +03:00
|
|
|
|
* связанных с некоторой таблицей ключ-значение, при проверке целостности базы
|
|
|
|
|
* данных. \see mdbx_env_chk() */
|
2024-08-03 13:25:44 +03:00
|
|
|
|
typedef struct MDBX_chk_user_table_cookie MDBX_chk_user_table_cookie_t;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Гистограмма с некоторой статистической информацией,
|
|
|
|
|
* собираемой при проверке целостности БД.
|
|
|
|
|
* \see mdbx_env_chk() */
|
|
|
|
|
struct MDBX_chk_histogram {
|
|
|
|
|
size_t amount, count, ones, pad;
|
|
|
|
|
struct {
|
|
|
|
|
size_t begin, end, amount, count;
|
|
|
|
|
} ranges[9];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/** \brief Информация о некоторой таблицей ключ-значение,
|
2024-04-01 14:29:52 +03:00
|
|
|
|
* при проверке целостности базы данных.
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* \see mdbx_env_chk() */
|
2024-08-03 13:25:44 +03:00
|
|
|
|
typedef struct MDBX_chk_table {
|
|
|
|
|
MDBX_chk_user_table_cookie_t *cookie;
|
2023-04-24 20:59:18 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Pseudo-name for MainDB */
|
|
|
|
|
#define MDBX_CHK_MAIN ((void *)((ptrdiff_t)0))
|
|
|
|
|
/** \brief Pseudo-name for GarbageCollectorDB */
|
|
|
|
|
#define MDBX_CHK_GC ((void *)((ptrdiff_t)-1))
|
|
|
|
|
/** \brief Pseudo-name for MetaPages */
|
|
|
|
|
#define MDBX_CHK_META ((void *)((ptrdiff_t)-2))
|
|
|
|
|
|
2023-03-28 21:24:18 +03:00
|
|
|
|
MDBX_val name;
|
|
|
|
|
MDBX_db_flags_t flags;
|
|
|
|
|
int id;
|
|
|
|
|
|
|
|
|
|
size_t payload_bytes, lost_bytes;
|
|
|
|
|
struct {
|
|
|
|
|
size_t all, empty, other;
|
|
|
|
|
size_t branch, leaf;
|
|
|
|
|
size_t nested_branch, nested_leaf, nested_subleaf;
|
|
|
|
|
} pages;
|
|
|
|
|
struct {
|
|
|
|
|
/// Tree deep histogram
|
|
|
|
|
struct MDBX_chk_histogram deep;
|
|
|
|
|
/// Histogram of large/overflow pages length
|
|
|
|
|
struct MDBX_chk_histogram large_pages;
|
|
|
|
|
/// Histogram of nested trees height, span length for GC
|
|
|
|
|
struct MDBX_chk_histogram nested_tree;
|
|
|
|
|
/// Keys length histogram
|
|
|
|
|
struct MDBX_chk_histogram key_len;
|
|
|
|
|
/// Values length histogram
|
|
|
|
|
struct MDBX_chk_histogram val_len;
|
|
|
|
|
} histogram;
|
2024-08-03 13:25:44 +03:00
|
|
|
|
} MDBX_chk_table_t;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Контекст проверки целостности базы данных.
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* \see mdbx_env_chk() */
|
|
|
|
|
typedef struct MDBX_chk_context {
|
|
|
|
|
struct MDBX_chk_internal *internal;
|
|
|
|
|
MDBX_env *env;
|
|
|
|
|
MDBX_txn *txn;
|
|
|
|
|
MDBX_chk_scope_t *scope;
|
2023-04-24 20:59:18 +03:00
|
|
|
|
uint8_t scope_nesting;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
struct {
|
|
|
|
|
size_t total_payload_bytes;
|
2024-08-03 13:25:44 +03:00
|
|
|
|
size_t table_total, table_processed;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
size_t total_unused_bytes, unused_pages;
|
2024-12-11 21:22:04 +03:00
|
|
|
|
size_t processed_pages, reclaimable_pages, gc_pages, alloc_pages, backed_pages;
|
|
|
|
|
size_t problems_meta, tree_problems, gc_tree_problems, kv_tree_problems, problems_gc, problems_kv, total_problems;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
uint64_t steady_txnid, recent_txnid;
|
2024-08-03 13:25:44 +03:00
|
|
|
|
/** Указатель на массив размером table_total с указателями на экземпляры
|
|
|
|
|
* структур MDBX_chk_table_t с информацией о всех таблицах ключ-значение,
|
2023-03-28 21:24:18 +03:00
|
|
|
|
* включая MainDB и GC/FreeDB. */
|
2024-08-03 13:25:44 +03:00
|
|
|
|
const MDBX_chk_table_t *const *tables;
|
2023-03-28 21:24:18 +03:00
|
|
|
|
} result;
|
|
|
|
|
} MDBX_chk_context_t;
|
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Набор функций обратного вызова используемых при проверке целостности
|
|
|
|
|
* базы данных.
|
|
|
|
|
*
|
|
|
|
|
* Функции обратного вызова предназначены для организации взаимодействия с кодом
|
|
|
|
|
* приложения. В том числе, для интеграции логики приложения проверяющей
|
|
|
|
|
* целостность стуктуры данных выше уровня ключ-значение, подготовки и
|
|
|
|
|
* структурированного вывода информации как о ходе, так и результатов проверки.
|
|
|
|
|
*
|
|
|
|
|
* Все функции обратного вызова опциональны, неиспользуемые указатели должны
|
|
|
|
|
* быть установлены в `nullptr`.
|
|
|
|
|
*
|
|
|
|
|
* \note Данный API еще не зафиксирован, в последующих версиях могут быть
|
|
|
|
|
* незначительные доработки и изменения.
|
|
|
|
|
*
|
|
|
|
|
* \see mdbx_env_chk() */
|
2023-03-28 21:24:18 +03:00
|
|
|
|
typedef struct MDBX_chk_callbacks {
|
|
|
|
|
bool (*check_break)(MDBX_chk_context_t *ctx);
|
2024-12-11 21:22:04 +03:00
|
|
|
|
int (*scope_push)(MDBX_chk_context_t *ctx, MDBX_chk_scope_t *outer, MDBX_chk_scope_t *inner, const char *fmt,
|
|
|
|
|
va_list args);
|
|
|
|
|
int (*scope_conclude)(MDBX_chk_context_t *ctx, MDBX_chk_scope_t *outer, MDBX_chk_scope_t *inner, int err);
|
|
|
|
|
void (*scope_pop)(MDBX_chk_context_t *ctx, MDBX_chk_scope_t *outer, MDBX_chk_scope_t *inner);
|
|
|
|
|
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);
|
|
|
|
|
MDBX_chk_user_table_cookie_t *(*table_filter)(MDBX_chk_context_t *ctx, const MDBX_val *name, MDBX_db_flags_t flags);
|
|
|
|
|
int (*table_conclude)(MDBX_chk_context_t *ctx, const MDBX_chk_table_t *table, MDBX_cursor *cursor, int err);
|
2024-08-03 13:25:44 +03:00
|
|
|
|
void (*table_dispose)(MDBX_chk_context_t *ctx, const MDBX_chk_table_t *table);
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
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);
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
2024-05-19 22:07:58 +03:00
|
|
|
|
int (*stage_begin)(MDBX_chk_context_t *ctx, MDBX_chk_stage_t);
|
|
|
|
|
int (*stage_end)(MDBX_chk_context_t *ctx, MDBX_chk_stage_t, int err);
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
2024-12-11 21:22:04 +03:00
|
|
|
|
MDBX_chk_line_t *(*print_begin)(MDBX_chk_context_t *ctx, MDBX_chk_severity_t severity);
|
2023-04-24 20:59:18 +03:00
|
|
|
|
void (*print_flush)(MDBX_chk_line_t *);
|
|
|
|
|
void (*print_done)(MDBX_chk_line_t *);
|
|
|
|
|
void (*print_chars)(MDBX_chk_line_t *, const char *str, size_t len);
|
|
|
|
|
void (*print_format)(MDBX_chk_line_t *, const char *fmt, va_list args);
|
2024-12-11 21:22:04 +03:00
|
|
|
|
void (*print_size)(MDBX_chk_line_t *, const char *prefix, const uint64_t value, const char *suffix);
|
2023-03-28 21:24:18 +03:00
|
|
|
|
} MDBX_chk_callbacks_t;
|
|
|
|
|
|
2024-04-01 14:29:52 +03:00
|
|
|
|
/** \brief Проверяет целостность базы данных.
|
|
|
|
|
*
|
|
|
|
|
* Взаимодействие с кодом приложения реализуется через функции обратного вызова,
|
|
|
|
|
* предоставляемые приложением посредством параметра `cb`. В ходе такого
|
|
|
|
|
* взаимодействия приложение может контролировать ход проверки, в том числе,
|
|
|
|
|
* пропускать/фильтровать обработку отдельных элементов, а также реализовать
|
|
|
|
|
* дополнительную верификацию структуры и/или информации с учетом назначения и
|
|
|
|
|
* семантической значимости для приложения. Например, приложение может выполнить
|
|
|
|
|
* проверку собственных индексов и корректность записей в БД. Именно с этой
|
|
|
|
|
* целью функционал проверки целостности был доработан для интенсивного
|
|
|
|
|
* использования обратных вызовов и перенесен из утилиты `mdbx_chk` в основную
|
|
|
|
|
* библиотеку.
|
|
|
|
|
*
|
|
|
|
|
* Проверка выполняется в несколько стадий, начиная с инициализации и до
|
2024-06-20 12:50:22 +03:00
|
|
|
|
* завершения, более подробно см \ref MDBX_chk_stage_t. О начале и завершении
|
2024-04-01 14:29:52 +03:00
|
|
|
|
* каждой стадии код приложения уведомляется через соответствующие функции
|
|
|
|
|
* обратного вызова, более подробно см \ref MDBX_chk_callbacks_t.
|
|
|
|
|
*
|
|
|
|
|
* \param [in] env Указатель на экземпляр среды.
|
|
|
|
|
* \param [in] cb Набор функций обратного вызова.
|
|
|
|
|
* \param [in,out] ctx Контекст проверки целостности базы данных,
|
|
|
|
|
* где будут формироваться результаты проверки.
|
|
|
|
|
* \param [in] flags Флаги/опции проверки целостности базы данных.
|
|
|
|
|
* \param [in] verbosity Необходимый уровень детализации информации о ходе
|
|
|
|
|
* и результатах проверки.
|
|
|
|
|
* \param [in] timeout_seconds_16dot16 Ограничение длительности в 1/65536 долях
|
|
|
|
|
* секунды для выполнения проверки,
|
|
|
|
|
* либо 0 при отсутствии ограничения.
|
|
|
|
|
* \returns Нулевое значение в случае успеха, иначе код ошибки. */
|
2024-12-11 21:22:04 +03:00
|
|
|
|
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,
|
2023-03-28 21:24:18 +03:00
|
|
|
|
unsigned timeout_seconds_16dot16);
|
2024-04-01 14:29:52 +03:00
|
|
|
|
|
|
|
|
|
/** \brief Вспомогательная функция для подсчета проблем детектируемых
|
|
|
|
|
* приложением, в том числе, поступающим к приложению через логирование.
|
|
|
|
|
* \see mdbx_env_chk()
|
|
|
|
|
* \see MDBX_debug_func
|
|
|
|
|
* \returns Нулевое значение в случае успеха, иначе код ошибки. */
|
2024-04-01 12:46:23 +03:00
|
|
|
|
LIBMDBX_API int mdbx_env_chk_encount_problem(MDBX_chk_context_t *ctx);
|
2023-03-28 21:24:18 +03:00
|
|
|
|
|
|
|
|
|
/** end of chk @} */
|
2016-11-21 20:50:39 +03:00
|
|
|
|
|
2022-04-23 17:50:28 +03:00
|
|
|
|
/** end of c_api @} */
|
2020-07-21 01:24:29 +03:00
|
|
|
|
|
2016-11-21 19:32:12 +03:00
|
|
|
|
#ifdef __cplusplus
|
2020-08-22 20:19:46 +03:00
|
|
|
|
} /* extern "C" */
|
2016-11-21 19:32:12 +03:00
|
|
|
|
#endif
|
|
|
|
|
|
2017-05-24 01:07:15 +03:00
|
|
|
|
#endif /* LIBMDBX_H */
|