mirror of
https://github.com/isar/libmdbx.git
synced 2025-12-18 17:52:22 +08:00
Compare commits
11 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5bb92a4277 | ||
|
|
c381573d1f | ||
|
|
31873e8e2c | ||
|
|
e94d6efec6 | ||
|
|
7eb1b36309 | ||
|
|
0c4b39bd11 | ||
|
|
2bccc85ff8 | ||
|
|
df08b5144c | ||
|
|
9baca673ac | ||
|
|
55893f8c39 | ||
|
|
70042069eb |
9
.circleci/config.yml
Normal file
9
.circleci/config.yml
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
version: 2
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
docker:
|
||||||
|
- image: circleci/buildpack-deps:artful
|
||||||
|
steps:
|
||||||
|
- checkout
|
||||||
|
- run: make all lmdb
|
||||||
|
- run: make check
|
||||||
2
Makefile
2
Makefile
@@ -71,7 +71,7 @@ clean:
|
|||||||
|
|
||||||
tests: $(TESTS)
|
tests: $(TESTS)
|
||||||
|
|
||||||
check: tests
|
check: tests mdbx_chk
|
||||||
[ -d testdb ] || mkdir testdb && rm -f testdb/* \
|
[ -d testdb ] || mkdir testdb && rm -f testdb/* \
|
||||||
&& echo "*** LMDB-TEST-0" && ./mtest0 && ./mdbx_chk -v testdb \
|
&& echo "*** LMDB-TEST-0" && ./mtest0 && ./mdbx_chk -v testdb \
|
||||||
&& echo "*** LMDB-TEST-1" && ./mtest1 && ./mdbx_chk -v testdb \
|
&& echo "*** LMDB-TEST-1" && ./mtest1 && ./mdbx_chk -v testdb \
|
||||||
|
|||||||
10
README.md
10
README.md
@@ -5,8 +5,16 @@ Extended LMDB, aka "Расширенная LMDB".
|
|||||||
*The Future will Positive. Всё будет хорошо.*
|
*The Future will Positive. Всё будет хорошо.*
|
||||||
[](https://travis-ci.org/leo-yuriev/libmdbx)
|
[](https://travis-ci.org/leo-yuriev/libmdbx)
|
||||||
|
|
||||||
English version by Google [is here](https://translate.googleusercontent.com/translate_c?act=url&ie=UTF8&sl=ru&tl=en&u=https://github.com/leo-yuriev/libmdbx/tree/stable%2F0.0).
|
## Project Status for now
|
||||||
|
|
||||||
|
- The stable versions (the _stable/*_ branches) of are frozen, i.e. no new features or API changes, but only bug fixes.
|
||||||
|
- The next (the _devel_ branch) version **is under active development**, i.e. current API and set of features are extreme volatile.
|
||||||
|
- The immediate goal of development is formation of the stable API and the stable internal database format, which allows realise all planned features.
|
||||||
|
- Planned features: Integrity check by Merkle tree, Support for raw block devices, Separate place for large data items, Using "roaring bitmaps" for garbage collector, Non-linear page reclaiming, Asynchronous lazy data flush to disk(s), etc.
|
||||||
|
|
||||||
|
-----
|
||||||
|
|
||||||
|
English version by Google [is here](https://translate.googleusercontent.com/translate_c?act=url&ie=UTF8&sl=ru&tl=en&u=https://github.com/leo-yuriev/libmdbx/tree/stable%2F0.0).
|
||||||
|
|
||||||
## Кратко
|
## Кратко
|
||||||
|
|
||||||
|
|||||||
14
circle.yml
14
circle.yml
@@ -1,14 +0,0 @@
|
|||||||
machine:
|
|
||||||
timezone:
|
|
||||||
Europe/Moscow
|
|
||||||
|
|
||||||
database:
|
|
||||||
override:
|
|
||||||
|
|
||||||
compile:
|
|
||||||
override:
|
|
||||||
- make all lmdb
|
|
||||||
|
|
||||||
test:
|
|
||||||
override:
|
|
||||||
- make check
|
|
||||||
84
mdb.c
84
mdb.c
@@ -44,10 +44,8 @@
|
|||||||
# define _GNU_SOURCE
|
# define _GNU_SOURCE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* LY: Please do not ask us for Windows support, just never!
|
|
||||||
* But you can make a fork for Windows, or become maintainer for FreeBSD... */
|
|
||||||
#ifndef __gnu_linux__
|
#ifndef __gnu_linux__
|
||||||
# warning "This version of ReOpenMDBX supports only GNU Linux"
|
# warning "This version of libmdbx supports only GNU Linux"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
@@ -56,21 +54,21 @@
|
|||||||
#include "./defs.h"
|
#include "./defs.h"
|
||||||
|
|
||||||
#if !__GNUC_PREREQ(4,2)
|
#if !__GNUC_PREREQ(4,2)
|
||||||
/* LY: Actualy ReOpenMDBX was not tested with compilers
|
/* LY: Actualy libmdbx was not tested with compilers
|
||||||
* older than GCC 4.4 (from RHEL6).
|
* older than GCC 4.4 (from RHEL6).
|
||||||
* But you could remove this #error and try to continue at your own risk.
|
* But you could remove this #error and try to continue at your own risk.
|
||||||
* In such case please don't rise up an issues related ONLY to old compilers.
|
* In such case please don't rise up an issues related ONLY to old compilers.
|
||||||
*/
|
*/
|
||||||
# warning "ReOpenMDBX required at least GCC 4.2 compatible C/C++ compiler."
|
# warning "libmdbx required at least GCC 4.2 compatible C/C++ compiler."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !__GLIBC_PREREQ(2,12)
|
#if !__GLIBC_PREREQ(2,12)
|
||||||
/* LY: Actualy ReOpenMDBX was not tested with something
|
/* LY: Actualy libmdbx was not tested with something
|
||||||
* older than glibc 2.12 (from RHEL6).
|
* older than glibc 2.12 (from RHEL6).
|
||||||
* But you could remove this #error and try to continue at your own risk.
|
* But you could remove this #error and try to continue at your own risk.
|
||||||
* In such case please don't rise up an issues related ONLY to old systems.
|
* In such case please don't rise up an issues related ONLY to old systems.
|
||||||
*/
|
*/
|
||||||
# warning "ReOpenMDBX required at least GLIBC 2.12."
|
# warning "libmdbx required at least GLIBC 2.12."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MDB_DEBUG
|
#if MDB_DEBUG
|
||||||
@@ -1026,17 +1024,19 @@ typedef struct MDB_xcursor {
|
|||||||
unsigned char mx_dbflag;
|
unsigned char mx_dbflag;
|
||||||
} MDB_xcursor;
|
} MDB_xcursor;
|
||||||
|
|
||||||
/** Check if there is an inited xcursor, so #XCURSOR_REFRESH() is proper */
|
/** Check if there is an inited xcursor */
|
||||||
#define XCURSOR_INITED(mc) \
|
#define XCURSOR_INITED(mc) \
|
||||||
((mc)->mc_xcursor && ((mc)->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED))
|
((mc)->mc_xcursor && ((mc)->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED))
|
||||||
|
|
||||||
/** Update sub-page pointer, if any, in \b mc->mc_xcursor. Needed
|
/** Update the xcursor's sub-page pointer, if any, in \b mc. Needed
|
||||||
* when the node which contains the sub-page may have moved. Called
|
* when the node which contains the sub-page may have moved. Called
|
||||||
* with \b mp = mc->mc_pg[mc->mc_top], \b ki = mc->mc_ki[mc->mc_top].
|
* with leaf page \b mp = mc->mc_pg[\b top].
|
||||||
*/
|
*/
|
||||||
#define XCURSOR_REFRESH(mc, mp, ki) do { \
|
#define XCURSOR_REFRESH(mc, top, mp) do { \
|
||||||
MDB_page *xr_pg = (mp); \
|
MDB_page *xr_pg = (mp); \
|
||||||
MDB_node *xr_node = NODEPTR(xr_pg, ki); \
|
MDB_node *xr_node; \
|
||||||
|
if (!XCURSOR_INITED(mc) || (mc)->mc_ki[top] >= NUMKEYS(xr_pg)) break; \
|
||||||
|
xr_node = NODEPTR(xr_pg, (mc)->mc_ki[top]); \
|
||||||
if ((xr_node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) \
|
if ((xr_node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) \
|
||||||
(mc)->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(xr_node); \
|
(mc)->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(xr_node); \
|
||||||
} while (0)
|
} while (0)
|
||||||
@@ -2138,6 +2138,10 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
|
|||||||
/* If mc is updating the freeDB, then the freelist cannot play
|
/* If mc is updating the freeDB, then the freelist cannot play
|
||||||
* catch-up with itself by growing while trying to save it. */
|
* catch-up with itself by growing while trying to save it. */
|
||||||
flags &= ~(MDBX_ALLOC_GC | MDBX_ALLOC_KICK | MDBX_COALESCE | MDBX_LIFORECLAIM);
|
flags &= ~(MDBX_ALLOC_GC | MDBX_ALLOC_KICK | MDBX_COALESCE | MDBX_LIFORECLAIM);
|
||||||
|
} else if (unlikely(txn->mt_dbs[FREE_DBI].md_entries == 0)) {
|
||||||
|
/* avoid (recursive) search inside empty tree and while tree is updating,
|
||||||
|
* https://github.com/leo-yuriev/libmdbx/issues/31 */
|
||||||
|
flags &= ~MDBX_ALLOC_GC;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2608,8 +2612,8 @@ done:
|
|||||||
if (m2 == mc) continue;
|
if (m2 == mc) continue;
|
||||||
if (m2->mc_pg[mc->mc_top] == mp) {
|
if (m2->mc_pg[mc->mc_top] == mp) {
|
||||||
m2->mc_pg[mc->mc_top] = np;
|
m2->mc_pg[mc->mc_top] = np;
|
||||||
if (XCURSOR_INITED(m2) && IS_LEAF(np))
|
if (IS_LEAF(np))
|
||||||
XCURSOR_REFRESH(m2, np, m2->mc_ki[mc->mc_top]);
|
XCURSOR_REFRESH(m2, mc->mc_top, np);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -6673,6 +6677,11 @@ fetchm:
|
|||||||
rc = MDB_INCOMPATIBLE;
|
rc = MDB_INCOMPATIBLE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (mc->mc_ki[mc->mc_top] >= NUMKEYS(mc->mc_pg[mc->mc_top])) {
|
||||||
|
mc->mc_ki[mc->mc_top] = NUMKEYS(mc->mc_pg[mc->mc_top]);
|
||||||
|
rc = MDB_NOTFOUND;
|
||||||
|
break;
|
||||||
|
}
|
||||||
{
|
{
|
||||||
MDB_node *leaf = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]);
|
MDB_node *leaf = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]);
|
||||||
if (!F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
if (!F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
||||||
@@ -7023,7 +7032,8 @@ more:
|
|||||||
offset *= 4; /* space for 4 more */
|
offset *= 4; /* space for 4 more */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/* FALLTHRU: Big enough MDB_DUPFIXED sub-page */
|
/* Big enough MDB_DUPFIXED sub-page */
|
||||||
|
/* fallthrough */
|
||||||
case MDB_CURRENT | MDB_NODUPDATA:
|
case MDB_CURRENT | MDB_NODUPDATA:
|
||||||
case MDB_CURRENT:
|
case MDB_CURRENT:
|
||||||
fp->mp_flags |= P_DIRTY;
|
fp->mp_flags |= P_DIRTY;
|
||||||
@@ -7074,8 +7084,9 @@ prep_subDB:
|
|||||||
} else {
|
} else {
|
||||||
memcpy((char *)mp + mp->mp_upper + PAGEBASE, (char *)fp + fp->mp_upper + PAGEBASE,
|
memcpy((char *)mp + mp->mp_upper + PAGEBASE, (char *)fp + fp->mp_upper + PAGEBASE,
|
||||||
olddata.mv_size - fp->mp_upper - PAGEBASE);
|
olddata.mv_size - fp->mp_upper - PAGEBASE);
|
||||||
|
memcpy((char *)(&mp->mp_ptrs), (char *)(&fp->mp_ptrs), NUMKEYS(fp) * sizeof(mp->mp_ptrs[0]));
|
||||||
for (i=0; i<NUMKEYS(fp); i++)
|
for (i=0; i<NUMKEYS(fp); i++)
|
||||||
mp->mp_ptrs[i] = fp->mp_ptrs[i] + offset;
|
mp->mp_ptrs[i] += offset;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -7203,8 +7214,7 @@ new_sub:
|
|||||||
if (m3->mc_ki[i] >= mc->mc_ki[i] && insert_key) {
|
if (m3->mc_ki[i] >= mc->mc_ki[i] && insert_key) {
|
||||||
m3->mc_ki[i]++;
|
m3->mc_ki[i]++;
|
||||||
}
|
}
|
||||||
if (XCURSOR_INITED(m3))
|
XCURSOR_REFRESH(m3, i, mp);
|
||||||
XCURSOR_REFRESH(m3, mp, m3->mc_ki[i]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -7245,7 +7255,6 @@ put_sub:
|
|||||||
MDB_xcursor *mx = mc->mc_xcursor;
|
MDB_xcursor *mx = mc->mc_xcursor;
|
||||||
unsigned i = mc->mc_top;
|
unsigned i = mc->mc_top;
|
||||||
MDB_page *mp = mc->mc_pg[i];
|
MDB_page *mp = mc->mc_pg[i];
|
||||||
int nkeys = NUMKEYS(mp);
|
|
||||||
|
|
||||||
for (m2 = mc->mc_txn->mt_cursors[mc->mc_dbi]; m2; m2=m2->mc_next) {
|
for (m2 = mc->mc_txn->mt_cursors[mc->mc_dbi]; m2; m2=m2->mc_next) {
|
||||||
if (m2 == mc || m2->mc_snum < mc->mc_snum) continue;
|
if (m2 == mc || m2->mc_snum < mc->mc_snum) continue;
|
||||||
@@ -7253,8 +7262,8 @@ put_sub:
|
|||||||
if (m2->mc_pg[i] == mp) {
|
if (m2->mc_pg[i] == mp) {
|
||||||
if (m2->mc_ki[i] == mc->mc_ki[i]) {
|
if (m2->mc_ki[i] == mc->mc_ki[i]) {
|
||||||
mdb_xcursor_init2(m2, mx, dupdata_flag);
|
mdb_xcursor_init2(m2, mx, dupdata_flag);
|
||||||
} else if (!insert_key && m2->mc_ki[i] < nkeys) {
|
} else if (!insert_key) {
|
||||||
XCURSOR_REFRESH(m2, mp, m2->mc_ki[i]);
|
XCURSOR_REFRESH(m2, i, mp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -7364,12 +7373,7 @@ mdb_cursor_del(MDB_cursor *mc, unsigned flags)
|
|||||||
if (m2 == mc || m2->mc_snum < mc->mc_snum) continue;
|
if (m2 == mc || m2->mc_snum < mc->mc_snum) continue;
|
||||||
if (!(m2->mc_flags & C_INITIALIZED)) continue;
|
if (!(m2->mc_flags & C_INITIALIZED)) continue;
|
||||||
if (m2->mc_pg[mc->mc_top] == mp) {
|
if (m2->mc_pg[mc->mc_top] == mp) {
|
||||||
MDB_node *n2 = leaf;
|
XCURSOR_REFRESH(m2, mc->mc_top, mp);
|
||||||
if (m2->mc_ki[mc->mc_top] != mc->mc_ki[mc->mc_top]) {
|
|
||||||
n2 = NODEPTR(mp, m2->mc_ki[mc->mc_top]);
|
|
||||||
if (n2->mn_flags & F_SUBDATA) continue;
|
|
||||||
}
|
|
||||||
m2->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(n2);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -8273,8 +8277,8 @@ mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft)
|
|||||||
m3->mc_ki[csrc->mc_top] = cdst->mc_ki[cdst->mc_top];
|
m3->mc_ki[csrc->mc_top] = cdst->mc_ki[cdst->mc_top];
|
||||||
m3->mc_ki[csrc->mc_top-1]++;
|
m3->mc_ki[csrc->mc_top-1]++;
|
||||||
}
|
}
|
||||||
if (XCURSOR_INITED(m3) && IS_LEAF(mps))
|
if (IS_LEAF(mps))
|
||||||
XCURSOR_REFRESH(m3, m3->mc_pg[csrc->mc_top], m3->mc_ki[csrc->mc_top]);
|
XCURSOR_REFRESH(m3, csrc->mc_top, m3->mc_pg[csrc->mc_top]);
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
/* Adding on the right, bump others down */
|
/* Adding on the right, bump others down */
|
||||||
@@ -8295,8 +8299,8 @@ mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft)
|
|||||||
} else {
|
} else {
|
||||||
m3->mc_ki[csrc->mc_top]--;
|
m3->mc_ki[csrc->mc_top]--;
|
||||||
}
|
}
|
||||||
if (XCURSOR_INITED(m3) && IS_LEAF(mps))
|
if (IS_LEAF(mps))
|
||||||
XCURSOR_REFRESH(m3, m3->mc_pg[csrc->mc_top], m3->mc_ki[csrc->mc_top]);
|
XCURSOR_REFRESH(m3, csrc->mc_top, m3->mc_pg[csrc->mc_top]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -8494,8 +8498,8 @@ mdb_page_merge(MDB_cursor *csrc, MDB_cursor *cdst)
|
|||||||
m3->mc_ki[top-1] > csrc->mc_ki[top-1]) {
|
m3->mc_ki[top-1] > csrc->mc_ki[top-1]) {
|
||||||
m3->mc_ki[top-1]--;
|
m3->mc_ki[top-1]--;
|
||||||
}
|
}
|
||||||
if (XCURSOR_INITED(m3) && IS_LEAF(psrc))
|
if (IS_LEAF(psrc))
|
||||||
XCURSOR_REFRESH(m3, m3->mc_pg[top], m3->mc_ki[top]);
|
XCURSOR_REFRESH(m3, top, m3->mc_pg[top]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
@@ -8757,8 +8761,7 @@ mdb_cursor_del0(MDB_cursor *mc)
|
|||||||
} else if (m3->mc_ki[mc->mc_top] > ki) {
|
} else if (m3->mc_ki[mc->mc_top] > ki) {
|
||||||
m3->mc_ki[mc->mc_top]--;
|
m3->mc_ki[mc->mc_top]--;
|
||||||
}
|
}
|
||||||
if (XCURSOR_INITED(m3))
|
XCURSOR_REFRESH(m3, mc->mc_top, mp);
|
||||||
XCURSOR_REFRESH(m3, m3->mc_pg[mc->mc_top], m3->mc_ki[mc->mc_top]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -9299,8 +9302,8 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno
|
|||||||
m3->mc_ki[ptop] >= mc->mc_ki[ptop]) {
|
m3->mc_ki[ptop] >= mc->mc_ki[ptop]) {
|
||||||
m3->mc_ki[ptop]++;
|
m3->mc_ki[ptop]++;
|
||||||
}
|
}
|
||||||
if (XCURSOR_INITED(m3) && IS_LEAF(mp))
|
if (IS_LEAF(mp))
|
||||||
XCURSOR_REFRESH(m3, m3->mc_pg[mc->mc_top], m3->mc_ki[mc->mc_top]);
|
XCURSOR_REFRESH(m3, mc->mc_top, m3->mc_pg[mc->mc_top]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mdb_debug("mp left: %d, rp left: %d", SIZELEFT(mp), SIZELEFT(rp));
|
mdb_debug("mp left: %d, rp left: %d", SIZELEFT(mp), SIZELEFT(rp));
|
||||||
@@ -10205,8 +10208,11 @@ int mdb_dbi_open(MDB_txn *txn, const char *name, unsigned flags, MDB_dbi *dbi)
|
|||||||
MDB_node *node = NODEPTR(mc.mc_pg[mc.mc_top], mc.mc_ki[mc.mc_top]);
|
MDB_node *node = NODEPTR(mc.mc_pg[mc.mc_top], mc.mc_ki[mc.mc_top]);
|
||||||
if (unlikely((node->mn_flags & (F_DUPDATA|F_SUBDATA)) != F_SUBDATA))
|
if (unlikely((node->mn_flags & (F_DUPDATA|F_SUBDATA)) != F_SUBDATA))
|
||||||
return MDB_INCOMPATIBLE;
|
return MDB_INCOMPATIBLE;
|
||||||
} else if (! (rc == MDB_NOTFOUND && (flags & MDB_CREATE))) {
|
} else {
|
||||||
return rc;
|
if (rc != MDB_NOTFOUND || !(flags & MDB_CREATE))
|
||||||
|
return rc;
|
||||||
|
if (F_ISSET(txn->mt_flags, MDB_TXN_RDONLY))
|
||||||
|
return EACCES;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Done here so we cannot fail after creating a new DB */
|
/* Done here so we cannot fail after creating a new DB */
|
||||||
|
|||||||
@@ -186,7 +186,7 @@ int main(int argc, char *argv[])
|
|||||||
break;
|
break;
|
||||||
case 'l':
|
case 'l':
|
||||||
list = 1;
|
list = 1;
|
||||||
/*FALLTHROUGH*/;
|
/* fallthrough */
|
||||||
case 'a':
|
case 'a':
|
||||||
if (subname)
|
if (subname)
|
||||||
usage(prog);
|
usage(prog);
|
||||||
|
|||||||
1
mtest0.c
1
mtest0.c
@@ -21,6 +21,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
|
|||||||
1
mtest1.c
1
mtest1.c
@@ -20,6 +20,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
1
mtest2.c
1
mtest2.c
@@ -23,6 +23,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
1
mtest3.c
1
mtest3.c
@@ -23,6 +23,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
1
mtest4.c
1
mtest4.c
@@ -23,6 +23,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
1
mtest5.c
1
mtest5.c
@@ -23,6 +23,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
1
mtest6.c
1
mtest6.c
@@ -23,6 +23,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
1
mtest7.c
1
mtest7.c
@@ -18,6 +18,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
1
mtest8.c
1
mtest8.c
@@ -18,6 +18,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <sys/sysmacros.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
||||||
|
|||||||
Reference in New Issue
Block a user