lmdb 0.7.3 → 0.7.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +12 -4
- data/Rakefile +48 -0
- data/ext/lmdb_ext/extconf.rb +27 -10
- data/ext/lmdb_ext/lmdb_ext.c +22 -8
- data/lib/lmdb/database.rb +2 -1
- data/lib/lmdb/version.rb +1 -1
- data/lmdb.gemspec +4 -1
- data/spec/lmdb_spec.rb +9 -0
- data/vendor/liblmdb/VERSION +1 -0
- data/vendor/{libraries/liblmdb → liblmdb}/lmdb.h +18 -63
- data/vendor/{libraries/liblmdb → liblmdb}/mdb.c +583 -1480
- data/vendor/{libraries/liblmdb → liblmdb}/midl.c +0 -62
- data/vendor/{libraries/liblmdb → liblmdb}/midl.h +4 -16
- metadata +7 -34
- data/CONTRIBUTORS +0 -8
- data/behaviour.org +0 -35
- data/ext/lmdb_ext/prototypes.sh +0 -4
- data/vendor/libraries/liblmdb/.gitignore +0 -24
- data/vendor/libraries/liblmdb/COPYRIGHT +0 -20
- data/vendor/libraries/liblmdb/Doxyfile +0 -1631
- data/vendor/libraries/liblmdb/LICENSE +0 -47
- data/vendor/libraries/liblmdb/Makefile +0 -118
- data/vendor/libraries/liblmdb/intro.doc +0 -192
- data/vendor/libraries/liblmdb/mdb_copy.1 +0 -61
- data/vendor/libraries/liblmdb/mdb_copy.c +0 -84
- data/vendor/libraries/liblmdb/mdb_drop.1 +0 -40
- data/vendor/libraries/liblmdb/mdb_drop.c +0 -135
- data/vendor/libraries/liblmdb/mdb_dump.1 +0 -81
- data/vendor/libraries/liblmdb/mdb_dump.c +0 -319
- data/vendor/libraries/liblmdb/mdb_load.1 +0 -84
- data/vendor/libraries/liblmdb/mdb_load.c +0 -492
- data/vendor/libraries/liblmdb/mdb_stat.1 +0 -70
- data/vendor/libraries/liblmdb/mdb_stat.c +0 -264
- data/vendor/libraries/liblmdb/mtest.c +0 -177
- data/vendor/libraries/liblmdb/mtest2.c +0 -124
- data/vendor/libraries/liblmdb/mtest3.c +0 -133
- data/vendor/libraries/liblmdb/mtest4.c +0 -168
- data/vendor/libraries/liblmdb/mtest5.c +0 -135
- data/vendor/libraries/liblmdb/mtest6.c +0 -141
- data/vendor/libraries/liblmdb/sample-bdb.txt +0 -73
- data/vendor/libraries/liblmdb/sample-mdb.txt +0 -62
- data/vendor/libraries/liblmdb/tooltag +0 -27
|
@@ -1,264 +0,0 @@
|
|
|
1
|
-
/* mdb_stat.c - memory-mapped database status tool */
|
|
2
|
-
/*
|
|
3
|
-
* Copyright 2011-2021 Howard Chu, Symas Corp.
|
|
4
|
-
* All rights reserved.
|
|
5
|
-
*
|
|
6
|
-
* Redistribution and use in source and binary forms, with or without
|
|
7
|
-
* modification, are permitted only as authorized by the OpenLDAP
|
|
8
|
-
* Public License.
|
|
9
|
-
*
|
|
10
|
-
* A copy of this license is available in the file LICENSE in the
|
|
11
|
-
* top-level directory of the distribution or, alternatively, at
|
|
12
|
-
* <http://www.OpenLDAP.org/license.html>.
|
|
13
|
-
*/
|
|
14
|
-
#include <stdio.h>
|
|
15
|
-
#include <stdlib.h>
|
|
16
|
-
#include <string.h>
|
|
17
|
-
#include <unistd.h>
|
|
18
|
-
#include "lmdb.h"
|
|
19
|
-
|
|
20
|
-
#define Z MDB_FMT_Z
|
|
21
|
-
#define Yu MDB_PRIy(u)
|
|
22
|
-
|
|
23
|
-
static void prstat(MDB_stat *ms)
|
|
24
|
-
{
|
|
25
|
-
#if 0
|
|
26
|
-
printf(" Page size: %u\n", ms->ms_psize);
|
|
27
|
-
#endif
|
|
28
|
-
printf(" Tree depth: %u\n", ms->ms_depth);
|
|
29
|
-
printf(" Branch pages: %"Yu"\n", ms->ms_branch_pages);
|
|
30
|
-
printf(" Leaf pages: %"Yu"\n", ms->ms_leaf_pages);
|
|
31
|
-
printf(" Overflow pages: %"Yu"\n", ms->ms_overflow_pages);
|
|
32
|
-
printf(" Entries: %"Yu"\n", ms->ms_entries);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
static void usage(char *prog)
|
|
36
|
-
{
|
|
37
|
-
fprintf(stderr, "usage: %s [-V] [-n] [-e] [-r[r]] [-f[f[f]]] [-v] [-a|-s subdb] dbpath\n", prog);
|
|
38
|
-
exit(EXIT_FAILURE);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
int main(int argc, char *argv[])
|
|
42
|
-
{
|
|
43
|
-
int i, rc;
|
|
44
|
-
MDB_env *env;
|
|
45
|
-
MDB_txn *txn;
|
|
46
|
-
MDB_dbi dbi;
|
|
47
|
-
MDB_stat mst;
|
|
48
|
-
MDB_envinfo mei;
|
|
49
|
-
char *prog = argv[0];
|
|
50
|
-
char *envname;
|
|
51
|
-
char *subname = NULL;
|
|
52
|
-
int alldbs = 0, envinfo = 0, envflags = 0, freinfo = 0, rdrinfo = 0;
|
|
53
|
-
|
|
54
|
-
if (argc < 2) {
|
|
55
|
-
usage(prog);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/* -a: print stat of main DB and all subDBs
|
|
59
|
-
* -s: print stat of only the named subDB
|
|
60
|
-
* -e: print env info
|
|
61
|
-
* -f: print freelist info
|
|
62
|
-
* -r: print reader info
|
|
63
|
-
* -n: use NOSUBDIR flag on env_open
|
|
64
|
-
* -v: use previous snapshot
|
|
65
|
-
* -V: print version and exit
|
|
66
|
-
* (default) print stat of only the main DB
|
|
67
|
-
*/
|
|
68
|
-
while ((i = getopt(argc, argv, "Vaefnrs:v")) != EOF) {
|
|
69
|
-
switch(i) {
|
|
70
|
-
case 'V':
|
|
71
|
-
printf("%s\n", MDB_VERSION_STRING);
|
|
72
|
-
exit(0);
|
|
73
|
-
break;
|
|
74
|
-
case 'a':
|
|
75
|
-
if (subname)
|
|
76
|
-
usage(prog);
|
|
77
|
-
alldbs++;
|
|
78
|
-
break;
|
|
79
|
-
case 'e':
|
|
80
|
-
envinfo++;
|
|
81
|
-
break;
|
|
82
|
-
case 'f':
|
|
83
|
-
freinfo++;
|
|
84
|
-
break;
|
|
85
|
-
case 'n':
|
|
86
|
-
envflags |= MDB_NOSUBDIR;
|
|
87
|
-
break;
|
|
88
|
-
case 'v':
|
|
89
|
-
envflags |= MDB_PREVSNAPSHOT;
|
|
90
|
-
break;
|
|
91
|
-
case 'r':
|
|
92
|
-
rdrinfo++;
|
|
93
|
-
break;
|
|
94
|
-
case 's':
|
|
95
|
-
if (alldbs)
|
|
96
|
-
usage(prog);
|
|
97
|
-
subname = optarg;
|
|
98
|
-
break;
|
|
99
|
-
default:
|
|
100
|
-
usage(prog);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
if (optind != argc - 1)
|
|
105
|
-
usage(prog);
|
|
106
|
-
|
|
107
|
-
envname = argv[optind];
|
|
108
|
-
rc = mdb_env_create(&env);
|
|
109
|
-
if (rc) {
|
|
110
|
-
fprintf(stderr, "mdb_env_create failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
111
|
-
return EXIT_FAILURE;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
if (alldbs || subname) {
|
|
115
|
-
mdb_env_set_maxdbs(env, 4);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
rc = mdb_env_open(env, envname, envflags | MDB_RDONLY, 0664);
|
|
119
|
-
if (rc) {
|
|
120
|
-
fprintf(stderr, "mdb_env_open failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
121
|
-
goto env_close;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
if (envinfo) {
|
|
125
|
-
(void)mdb_env_stat(env, &mst);
|
|
126
|
-
(void)mdb_env_info(env, &mei);
|
|
127
|
-
printf("Environment Info\n");
|
|
128
|
-
printf(" Map address: %p\n", mei.me_mapaddr);
|
|
129
|
-
printf(" Map size: %"Yu"\n", mei.me_mapsize);
|
|
130
|
-
printf(" Page size: %u\n", mst.ms_psize);
|
|
131
|
-
printf(" Max pages: %"Yu"\n", mei.me_mapsize / mst.ms_psize);
|
|
132
|
-
printf(" Number of pages used: %"Yu"\n", mei.me_last_pgno+1);
|
|
133
|
-
printf(" Last transaction ID: %"Yu"\n", mei.me_last_txnid);
|
|
134
|
-
printf(" Max readers: %u\n", mei.me_maxreaders);
|
|
135
|
-
printf(" Number of readers used: %u\n", mei.me_numreaders);
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
if (rdrinfo) {
|
|
139
|
-
printf("Reader Table Status\n");
|
|
140
|
-
rc = mdb_reader_list(env, (MDB_msg_func *)fputs, stdout);
|
|
141
|
-
if (rdrinfo > 1) {
|
|
142
|
-
int dead;
|
|
143
|
-
mdb_reader_check(env, &dead);
|
|
144
|
-
printf(" %d stale readers cleared.\n", dead);
|
|
145
|
-
rc = mdb_reader_list(env, (MDB_msg_func *)fputs, stdout);
|
|
146
|
-
}
|
|
147
|
-
if (!(subname || alldbs || freinfo))
|
|
148
|
-
goto env_close;
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
rc = mdb_txn_begin(env, NULL, MDB_RDONLY, &txn);
|
|
152
|
-
if (rc) {
|
|
153
|
-
fprintf(stderr, "mdb_txn_begin failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
154
|
-
goto env_close;
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
if (freinfo) {
|
|
158
|
-
MDB_cursor *cursor;
|
|
159
|
-
MDB_val key, data;
|
|
160
|
-
mdb_size_t pages = 0, *iptr;
|
|
161
|
-
|
|
162
|
-
printf("Freelist Status\n");
|
|
163
|
-
dbi = 0;
|
|
164
|
-
rc = mdb_cursor_open(txn, dbi, &cursor);
|
|
165
|
-
if (rc) {
|
|
166
|
-
fprintf(stderr, "mdb_cursor_open failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
167
|
-
goto txn_abort;
|
|
168
|
-
}
|
|
169
|
-
rc = mdb_stat(txn, dbi, &mst);
|
|
170
|
-
if (rc) {
|
|
171
|
-
fprintf(stderr, "mdb_stat failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
172
|
-
goto txn_abort;
|
|
173
|
-
}
|
|
174
|
-
prstat(&mst);
|
|
175
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) {
|
|
176
|
-
iptr = data.mv_data;
|
|
177
|
-
pages += *iptr;
|
|
178
|
-
if (freinfo > 1) {
|
|
179
|
-
char *bad = "";
|
|
180
|
-
mdb_size_t pg, prev;
|
|
181
|
-
ssize_t i, j, span = 0;
|
|
182
|
-
j = *iptr++;
|
|
183
|
-
for (i = j, prev = 1; --i >= 0; ) {
|
|
184
|
-
pg = iptr[i];
|
|
185
|
-
if (pg <= prev)
|
|
186
|
-
bad = " [bad sequence]";
|
|
187
|
-
prev = pg;
|
|
188
|
-
pg += span;
|
|
189
|
-
for (; i >= span && iptr[i-span] == pg; span++, pg++) ;
|
|
190
|
-
}
|
|
191
|
-
printf(" Transaction %"Yu", %"Z"d pages, maxspan %"Z"d%s\n",
|
|
192
|
-
*(mdb_size_t *)key.mv_data, j, span, bad);
|
|
193
|
-
if (freinfo > 2) {
|
|
194
|
-
for (--j; j >= 0; ) {
|
|
195
|
-
pg = iptr[j];
|
|
196
|
-
for (span=1; --j >= 0 && iptr[j] == pg+span; span++) ;
|
|
197
|
-
printf(span>1 ? " %9"Yu"[%"Z"d]\n" : " %9"Yu"\n",
|
|
198
|
-
pg, span);
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
mdb_cursor_close(cursor);
|
|
204
|
-
printf(" Free pages: %"Yu"\n", pages);
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
rc = mdb_open(txn, subname, 0, &dbi);
|
|
208
|
-
if (rc) {
|
|
209
|
-
fprintf(stderr, "mdb_open failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
210
|
-
goto txn_abort;
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
rc = mdb_stat(txn, dbi, &mst);
|
|
214
|
-
if (rc) {
|
|
215
|
-
fprintf(stderr, "mdb_stat failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
216
|
-
goto txn_abort;
|
|
217
|
-
}
|
|
218
|
-
printf("Status of %s\n", subname ? subname : "Main DB");
|
|
219
|
-
prstat(&mst);
|
|
220
|
-
|
|
221
|
-
if (alldbs) {
|
|
222
|
-
MDB_cursor *cursor;
|
|
223
|
-
MDB_val key;
|
|
224
|
-
|
|
225
|
-
rc = mdb_cursor_open(txn, dbi, &cursor);
|
|
226
|
-
if (rc) {
|
|
227
|
-
fprintf(stderr, "mdb_cursor_open failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
228
|
-
goto txn_abort;
|
|
229
|
-
}
|
|
230
|
-
while ((rc = mdb_cursor_get(cursor, &key, NULL, MDB_NEXT_NODUP)) == 0) {
|
|
231
|
-
char *str;
|
|
232
|
-
MDB_dbi db2;
|
|
233
|
-
if (memchr(key.mv_data, '\0', key.mv_size))
|
|
234
|
-
continue;
|
|
235
|
-
str = malloc(key.mv_size+1);
|
|
236
|
-
memcpy(str, key.mv_data, key.mv_size);
|
|
237
|
-
str[key.mv_size] = '\0';
|
|
238
|
-
rc = mdb_open(txn, str, 0, &db2);
|
|
239
|
-
if (rc == MDB_SUCCESS)
|
|
240
|
-
printf("Status of %s\n", str);
|
|
241
|
-
free(str);
|
|
242
|
-
if (rc) continue;
|
|
243
|
-
rc = mdb_stat(txn, db2, &mst);
|
|
244
|
-
if (rc) {
|
|
245
|
-
fprintf(stderr, "mdb_stat failed, error %d %s\n", rc, mdb_strerror(rc));
|
|
246
|
-
goto txn_abort;
|
|
247
|
-
}
|
|
248
|
-
prstat(&mst);
|
|
249
|
-
mdb_close(env, db2);
|
|
250
|
-
}
|
|
251
|
-
mdb_cursor_close(cursor);
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
if (rc == MDB_NOTFOUND)
|
|
255
|
-
rc = MDB_SUCCESS;
|
|
256
|
-
|
|
257
|
-
mdb_close(env, dbi);
|
|
258
|
-
txn_abort:
|
|
259
|
-
mdb_txn_abort(txn);
|
|
260
|
-
env_close:
|
|
261
|
-
mdb_env_close(env);
|
|
262
|
-
|
|
263
|
-
return rc ? EXIT_FAILURE : EXIT_SUCCESS;
|
|
264
|
-
}
|
|
@@ -1,177 +0,0 @@
|
|
|
1
|
-
/* mtest.c - memory-mapped database tester/toy */
|
|
2
|
-
/*
|
|
3
|
-
* Copyright 2011-2021 Howard Chu, Symas Corp.
|
|
4
|
-
* All rights reserved.
|
|
5
|
-
*
|
|
6
|
-
* Redistribution and use in source and binary forms, with or without
|
|
7
|
-
* modification, are permitted only as authorized by the OpenLDAP
|
|
8
|
-
* Public License.
|
|
9
|
-
*
|
|
10
|
-
* A copy of this license is available in the file LICENSE in the
|
|
11
|
-
* top-level directory of the distribution or, alternatively, at
|
|
12
|
-
* <http://www.OpenLDAP.org/license.html>.
|
|
13
|
-
*/
|
|
14
|
-
#include <stdio.h>
|
|
15
|
-
#include <stdlib.h>
|
|
16
|
-
#include <time.h>
|
|
17
|
-
#include "lmdb.h"
|
|
18
|
-
|
|
19
|
-
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
|
20
|
-
#define RES(err, expr) ((rc = expr) == (err) || (CHECK(!rc, #expr), 0))
|
|
21
|
-
#define CHECK(test, msg) ((test) ? (void)0 : ((void)fprintf(stderr, \
|
|
22
|
-
"%s:%d: %s: %s\n", __FILE__, __LINE__, msg, mdb_strerror(rc)), abort()))
|
|
23
|
-
|
|
24
|
-
int main(int argc,char * argv[])
|
|
25
|
-
{
|
|
26
|
-
int i = 0, j = 0, rc;
|
|
27
|
-
MDB_env *env;
|
|
28
|
-
MDB_dbi dbi;
|
|
29
|
-
MDB_val key, data;
|
|
30
|
-
MDB_txn *txn;
|
|
31
|
-
MDB_stat mst;
|
|
32
|
-
MDB_cursor *cursor, *cur2;
|
|
33
|
-
MDB_cursor_op op;
|
|
34
|
-
int count;
|
|
35
|
-
int *values;
|
|
36
|
-
char sval[32] = "";
|
|
37
|
-
|
|
38
|
-
srand(time(NULL));
|
|
39
|
-
|
|
40
|
-
count = (rand()%384) + 64;
|
|
41
|
-
values = (int *)malloc(count*sizeof(int));
|
|
42
|
-
|
|
43
|
-
for(i = 0;i<count;i++) {
|
|
44
|
-
values[i] = rand()%1024;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
E(mdb_env_create(&env));
|
|
48
|
-
E(mdb_env_set_maxreaders(env, 1));
|
|
49
|
-
E(mdb_env_set_mapsize(env, 10485760));
|
|
50
|
-
E(mdb_env_open(env, "./testdb", MDB_FIXEDMAP /*|MDB_NOSYNC*/, 0664));
|
|
51
|
-
|
|
52
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
53
|
-
E(mdb_dbi_open(txn, NULL, 0, &dbi));
|
|
54
|
-
|
|
55
|
-
key.mv_size = sizeof(int);
|
|
56
|
-
key.mv_data = sval;
|
|
57
|
-
|
|
58
|
-
printf("Adding %d values\n", count);
|
|
59
|
-
for (i=0;i<count;i++) {
|
|
60
|
-
sprintf(sval, "%03x %d foo bar", values[i], values[i]);
|
|
61
|
-
/* Set <data> in each iteration, since MDB_NOOVERWRITE may modify it */
|
|
62
|
-
data.mv_size = sizeof(sval);
|
|
63
|
-
data.mv_data = sval;
|
|
64
|
-
if (RES(MDB_KEYEXIST, mdb_put(txn, dbi, &key, &data, MDB_NOOVERWRITE))) {
|
|
65
|
-
j++;
|
|
66
|
-
data.mv_size = sizeof(sval);
|
|
67
|
-
data.mv_data = sval;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
if (j) printf("%d duplicates skipped\n", j);
|
|
71
|
-
E(mdb_txn_commit(txn));
|
|
72
|
-
E(mdb_env_stat(env, &mst));
|
|
73
|
-
|
|
74
|
-
E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn));
|
|
75
|
-
E(mdb_cursor_open(txn, dbi, &cursor));
|
|
76
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) {
|
|
77
|
-
printf("key: %p %.*s, data: %p %.*s\n",
|
|
78
|
-
key.mv_data, (int) key.mv_size, (char *) key.mv_data,
|
|
79
|
-
data.mv_data, (int) data.mv_size, (char *) data.mv_data);
|
|
80
|
-
}
|
|
81
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
82
|
-
mdb_cursor_close(cursor);
|
|
83
|
-
mdb_txn_abort(txn);
|
|
84
|
-
|
|
85
|
-
j=0;
|
|
86
|
-
key.mv_data = sval;
|
|
87
|
-
for (i= count - 1; i > -1; i-= (rand()%5)) {
|
|
88
|
-
j++;
|
|
89
|
-
txn=NULL;
|
|
90
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
91
|
-
sprintf(sval, "%03x ", values[i]);
|
|
92
|
-
if (RES(MDB_NOTFOUND, mdb_del(txn, dbi, &key, NULL))) {
|
|
93
|
-
j--;
|
|
94
|
-
mdb_txn_abort(txn);
|
|
95
|
-
} else {
|
|
96
|
-
E(mdb_txn_commit(txn));
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
free(values);
|
|
100
|
-
printf("Deleted %d values\n", j);
|
|
101
|
-
|
|
102
|
-
E(mdb_env_stat(env, &mst));
|
|
103
|
-
E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn));
|
|
104
|
-
E(mdb_cursor_open(txn, dbi, &cursor));
|
|
105
|
-
printf("Cursor next\n");
|
|
106
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) {
|
|
107
|
-
printf("key: %.*s, data: %.*s\n",
|
|
108
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
109
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
110
|
-
}
|
|
111
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
112
|
-
printf("Cursor last\n");
|
|
113
|
-
E(mdb_cursor_get(cursor, &key, &data, MDB_LAST));
|
|
114
|
-
printf("key: %.*s, data: %.*s\n",
|
|
115
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
116
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
117
|
-
printf("Cursor prev\n");
|
|
118
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_PREV)) == 0) {
|
|
119
|
-
printf("key: %.*s, data: %.*s\n",
|
|
120
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
121
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
122
|
-
}
|
|
123
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
124
|
-
printf("Cursor last/prev\n");
|
|
125
|
-
E(mdb_cursor_get(cursor, &key, &data, MDB_LAST));
|
|
126
|
-
printf("key: %.*s, data: %.*s\n",
|
|
127
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
128
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
129
|
-
E(mdb_cursor_get(cursor, &key, &data, MDB_PREV));
|
|
130
|
-
printf("key: %.*s, data: %.*s\n",
|
|
131
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
132
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
133
|
-
|
|
134
|
-
mdb_cursor_close(cursor);
|
|
135
|
-
mdb_txn_abort(txn);
|
|
136
|
-
|
|
137
|
-
printf("Deleting with cursor\n");
|
|
138
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
139
|
-
E(mdb_cursor_open(txn, dbi, &cur2));
|
|
140
|
-
for (i=0; i<50; i++) {
|
|
141
|
-
if (RES(MDB_NOTFOUND, mdb_cursor_get(cur2, &key, &data, MDB_NEXT)))
|
|
142
|
-
break;
|
|
143
|
-
printf("key: %p %.*s, data: %p %.*s\n",
|
|
144
|
-
key.mv_data, (int) key.mv_size, (char *) key.mv_data,
|
|
145
|
-
data.mv_data, (int) data.mv_size, (char *) data.mv_data);
|
|
146
|
-
E(mdb_del(txn, dbi, &key, NULL));
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
printf("Restarting cursor in txn\n");
|
|
150
|
-
for (op=MDB_FIRST, i=0; i<=32; op=MDB_NEXT, i++) {
|
|
151
|
-
if (RES(MDB_NOTFOUND, mdb_cursor_get(cur2, &key, &data, op)))
|
|
152
|
-
break;
|
|
153
|
-
printf("key: %p %.*s, data: %p %.*s\n",
|
|
154
|
-
key.mv_data, (int) key.mv_size, (char *) key.mv_data,
|
|
155
|
-
data.mv_data, (int) data.mv_size, (char *) data.mv_data);
|
|
156
|
-
}
|
|
157
|
-
mdb_cursor_close(cur2);
|
|
158
|
-
E(mdb_txn_commit(txn));
|
|
159
|
-
|
|
160
|
-
printf("Restarting cursor outside txn\n");
|
|
161
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
162
|
-
E(mdb_cursor_open(txn, dbi, &cursor));
|
|
163
|
-
for (op=MDB_FIRST, i=0; i<=32; op=MDB_NEXT, i++) {
|
|
164
|
-
if (RES(MDB_NOTFOUND, mdb_cursor_get(cursor, &key, &data, op)))
|
|
165
|
-
break;
|
|
166
|
-
printf("key: %p %.*s, data: %p %.*s\n",
|
|
167
|
-
key.mv_data, (int) key.mv_size, (char *) key.mv_data,
|
|
168
|
-
data.mv_data, (int) data.mv_size, (char *) data.mv_data);
|
|
169
|
-
}
|
|
170
|
-
mdb_cursor_close(cursor);
|
|
171
|
-
mdb_txn_abort(txn);
|
|
172
|
-
|
|
173
|
-
mdb_dbi_close(env, dbi);
|
|
174
|
-
mdb_env_close(env);
|
|
175
|
-
|
|
176
|
-
return 0;
|
|
177
|
-
}
|
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
/* mtest2.c - memory-mapped database tester/toy */
|
|
2
|
-
/*
|
|
3
|
-
* Copyright 2011-2021 Howard Chu, Symas Corp.
|
|
4
|
-
* All rights reserved.
|
|
5
|
-
*
|
|
6
|
-
* Redistribution and use in source and binary forms, with or without
|
|
7
|
-
* modification, are permitted only as authorized by the OpenLDAP
|
|
8
|
-
* Public License.
|
|
9
|
-
*
|
|
10
|
-
* A copy of this license is available in the file LICENSE in the
|
|
11
|
-
* top-level directory of the distribution or, alternatively, at
|
|
12
|
-
* <http://www.OpenLDAP.org/license.html>.
|
|
13
|
-
*/
|
|
14
|
-
|
|
15
|
-
/* Just like mtest.c, but using a subDB instead of the main DB */
|
|
16
|
-
|
|
17
|
-
#include <stdio.h>
|
|
18
|
-
#include <stdlib.h>
|
|
19
|
-
#include <time.h>
|
|
20
|
-
#include "lmdb.h"
|
|
21
|
-
|
|
22
|
-
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
|
23
|
-
#define RES(err, expr) ((rc = expr) == (err) || (CHECK(!rc, #expr), 0))
|
|
24
|
-
#define CHECK(test, msg) ((test) ? (void)0 : ((void)fprintf(stderr, \
|
|
25
|
-
"%s:%d: %s: %s\n", __FILE__, __LINE__, msg, mdb_strerror(rc)), abort()))
|
|
26
|
-
|
|
27
|
-
int main(int argc,char * argv[])
|
|
28
|
-
{
|
|
29
|
-
int i = 0, j = 0, rc;
|
|
30
|
-
MDB_env *env;
|
|
31
|
-
MDB_dbi dbi;
|
|
32
|
-
MDB_val key, data;
|
|
33
|
-
MDB_txn *txn;
|
|
34
|
-
MDB_stat mst;
|
|
35
|
-
MDB_cursor *cursor;
|
|
36
|
-
int count;
|
|
37
|
-
int *values;
|
|
38
|
-
char sval[32] = "";
|
|
39
|
-
|
|
40
|
-
srand(time(NULL));
|
|
41
|
-
|
|
42
|
-
count = (rand()%384) + 64;
|
|
43
|
-
values = (int *)malloc(count*sizeof(int));
|
|
44
|
-
|
|
45
|
-
for(i = 0;i<count;i++) {
|
|
46
|
-
values[i] = rand()%1024;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
E(mdb_env_create(&env));
|
|
50
|
-
E(mdb_env_set_maxreaders(env, 1));
|
|
51
|
-
E(mdb_env_set_mapsize(env, 10485760));
|
|
52
|
-
E(mdb_env_set_maxdbs(env, 4));
|
|
53
|
-
E(mdb_env_open(env, "./testdb", MDB_FIXEDMAP|MDB_NOSYNC, 0664));
|
|
54
|
-
|
|
55
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
56
|
-
E(mdb_dbi_open(txn, "id1", MDB_CREATE, &dbi));
|
|
57
|
-
|
|
58
|
-
key.mv_size = sizeof(int);
|
|
59
|
-
key.mv_data = sval;
|
|
60
|
-
|
|
61
|
-
printf("Adding %d values\n", count);
|
|
62
|
-
for (i=0;i<count;i++) {
|
|
63
|
-
sprintf(sval, "%03x %d foo bar", values[i], values[i]);
|
|
64
|
-
data.mv_size = sizeof(sval);
|
|
65
|
-
data.mv_data = sval;
|
|
66
|
-
if (RES(MDB_KEYEXIST, mdb_put(txn, dbi, &key, &data, MDB_NOOVERWRITE)))
|
|
67
|
-
j++;
|
|
68
|
-
}
|
|
69
|
-
if (j) printf("%d duplicates skipped\n", j);
|
|
70
|
-
E(mdb_txn_commit(txn));
|
|
71
|
-
E(mdb_env_stat(env, &mst));
|
|
72
|
-
|
|
73
|
-
E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn));
|
|
74
|
-
E(mdb_cursor_open(txn, dbi, &cursor));
|
|
75
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) {
|
|
76
|
-
printf("key: %p %.*s, data: %p %.*s\n",
|
|
77
|
-
key.mv_data, (int) key.mv_size, (char *) key.mv_data,
|
|
78
|
-
data.mv_data, (int) data.mv_size, (char *) data.mv_data);
|
|
79
|
-
}
|
|
80
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
81
|
-
mdb_cursor_close(cursor);
|
|
82
|
-
mdb_txn_abort(txn);
|
|
83
|
-
|
|
84
|
-
j=0;
|
|
85
|
-
key.mv_data = sval;
|
|
86
|
-
for (i= count - 1; i > -1; i-= (rand()%5)) {
|
|
87
|
-
j++;
|
|
88
|
-
txn=NULL;
|
|
89
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
90
|
-
sprintf(sval, "%03x ", values[i]);
|
|
91
|
-
if (RES(MDB_NOTFOUND, mdb_del(txn, dbi, &key, NULL))) {
|
|
92
|
-
j--;
|
|
93
|
-
mdb_txn_abort(txn);
|
|
94
|
-
} else {
|
|
95
|
-
E(mdb_txn_commit(txn));
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
free(values);
|
|
99
|
-
printf("Deleted %d values\n", j);
|
|
100
|
-
|
|
101
|
-
E(mdb_env_stat(env, &mst));
|
|
102
|
-
E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn));
|
|
103
|
-
E(mdb_cursor_open(txn, dbi, &cursor));
|
|
104
|
-
printf("Cursor next\n");
|
|
105
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) {
|
|
106
|
-
printf("key: %.*s, data: %.*s\n",
|
|
107
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
108
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
109
|
-
}
|
|
110
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
111
|
-
printf("Cursor prev\n");
|
|
112
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_PREV)) == 0) {
|
|
113
|
-
printf("key: %.*s, data: %.*s\n",
|
|
114
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
115
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
116
|
-
}
|
|
117
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
118
|
-
mdb_cursor_close(cursor);
|
|
119
|
-
mdb_txn_abort(txn);
|
|
120
|
-
|
|
121
|
-
mdb_dbi_close(env, dbi);
|
|
122
|
-
mdb_env_close(env);
|
|
123
|
-
return 0;
|
|
124
|
-
}
|
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
/* mtest3.c - memory-mapped database tester/toy */
|
|
2
|
-
/*
|
|
3
|
-
* Copyright 2011-2021 Howard Chu, Symas Corp.
|
|
4
|
-
* All rights reserved.
|
|
5
|
-
*
|
|
6
|
-
* Redistribution and use in source and binary forms, with or without
|
|
7
|
-
* modification, are permitted only as authorized by the OpenLDAP
|
|
8
|
-
* Public License.
|
|
9
|
-
*
|
|
10
|
-
* A copy of this license is available in the file LICENSE in the
|
|
11
|
-
* top-level directory of the distribution or, alternatively, at
|
|
12
|
-
* <http://www.OpenLDAP.org/license.html>.
|
|
13
|
-
*/
|
|
14
|
-
|
|
15
|
-
/* Tests for sorted duplicate DBs */
|
|
16
|
-
#include <stdio.h>
|
|
17
|
-
#include <stdlib.h>
|
|
18
|
-
#include <string.h>
|
|
19
|
-
#include <time.h>
|
|
20
|
-
#include "lmdb.h"
|
|
21
|
-
|
|
22
|
-
#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr)
|
|
23
|
-
#define RES(err, expr) ((rc = expr) == (err) || (CHECK(!rc, #expr), 0))
|
|
24
|
-
#define CHECK(test, msg) ((test) ? (void)0 : ((void)fprintf(stderr, \
|
|
25
|
-
"%s:%d: %s: %s\n", __FILE__, __LINE__, msg, mdb_strerror(rc)), abort()))
|
|
26
|
-
|
|
27
|
-
int main(int argc,char * argv[])
|
|
28
|
-
{
|
|
29
|
-
int i = 0, j = 0, rc;
|
|
30
|
-
MDB_env *env;
|
|
31
|
-
MDB_dbi dbi;
|
|
32
|
-
MDB_val key, data;
|
|
33
|
-
MDB_txn *txn;
|
|
34
|
-
MDB_stat mst;
|
|
35
|
-
MDB_cursor *cursor;
|
|
36
|
-
int count;
|
|
37
|
-
int *values;
|
|
38
|
-
char sval[32];
|
|
39
|
-
char kval[sizeof(int)];
|
|
40
|
-
|
|
41
|
-
srand(time(NULL));
|
|
42
|
-
|
|
43
|
-
memset(sval, 0, sizeof(sval));
|
|
44
|
-
|
|
45
|
-
count = (rand()%384) + 64;
|
|
46
|
-
values = (int *)malloc(count*sizeof(int));
|
|
47
|
-
|
|
48
|
-
for(i = 0;i<count;i++) {
|
|
49
|
-
values[i] = rand()%1024;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
E(mdb_env_create(&env));
|
|
53
|
-
E(mdb_env_set_mapsize(env, 10485760));
|
|
54
|
-
E(mdb_env_set_maxdbs(env, 4));
|
|
55
|
-
E(mdb_env_open(env, "./testdb", MDB_FIXEDMAP|MDB_NOSYNC, 0664));
|
|
56
|
-
|
|
57
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
58
|
-
E(mdb_dbi_open(txn, "id2", MDB_CREATE|MDB_DUPSORT, &dbi));
|
|
59
|
-
|
|
60
|
-
key.mv_size = sizeof(int);
|
|
61
|
-
key.mv_data = kval;
|
|
62
|
-
data.mv_size = sizeof(sval);
|
|
63
|
-
data.mv_data = sval;
|
|
64
|
-
|
|
65
|
-
printf("Adding %d values\n", count);
|
|
66
|
-
for (i=0;i<count;i++) {
|
|
67
|
-
if (!(i & 0x0f))
|
|
68
|
-
sprintf(kval, "%03x", values[i]);
|
|
69
|
-
sprintf(sval, "%03x %d foo bar", values[i], values[i]);
|
|
70
|
-
if (RES(MDB_KEYEXIST, mdb_put(txn, dbi, &key, &data, MDB_NODUPDATA)))
|
|
71
|
-
j++;
|
|
72
|
-
}
|
|
73
|
-
if (j) printf("%d duplicates skipped\n", j);
|
|
74
|
-
E(mdb_txn_commit(txn));
|
|
75
|
-
E(mdb_env_stat(env, &mst));
|
|
76
|
-
|
|
77
|
-
E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn));
|
|
78
|
-
E(mdb_cursor_open(txn, dbi, &cursor));
|
|
79
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) {
|
|
80
|
-
printf("key: %p %.*s, data: %p %.*s\n",
|
|
81
|
-
key.mv_data, (int) key.mv_size, (char *) key.mv_data,
|
|
82
|
-
data.mv_data, (int) data.mv_size, (char *) data.mv_data);
|
|
83
|
-
}
|
|
84
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
85
|
-
mdb_cursor_close(cursor);
|
|
86
|
-
mdb_txn_abort(txn);
|
|
87
|
-
|
|
88
|
-
j=0;
|
|
89
|
-
|
|
90
|
-
for (i= count - 1; i > -1; i-= (rand()%5)) {
|
|
91
|
-
j++;
|
|
92
|
-
txn=NULL;
|
|
93
|
-
E(mdb_txn_begin(env, NULL, 0, &txn));
|
|
94
|
-
sprintf(kval, "%03x", values[i & ~0x0f]);
|
|
95
|
-
sprintf(sval, "%03x %d foo bar", values[i], values[i]);
|
|
96
|
-
key.mv_size = sizeof(int);
|
|
97
|
-
key.mv_data = kval;
|
|
98
|
-
data.mv_size = sizeof(sval);
|
|
99
|
-
data.mv_data = sval;
|
|
100
|
-
if (RES(MDB_NOTFOUND, mdb_del(txn, dbi, &key, &data))) {
|
|
101
|
-
j--;
|
|
102
|
-
mdb_txn_abort(txn);
|
|
103
|
-
} else {
|
|
104
|
-
E(mdb_txn_commit(txn));
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
free(values);
|
|
108
|
-
printf("Deleted %d values\n", j);
|
|
109
|
-
|
|
110
|
-
E(mdb_env_stat(env, &mst));
|
|
111
|
-
E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn));
|
|
112
|
-
E(mdb_cursor_open(txn, dbi, &cursor));
|
|
113
|
-
printf("Cursor next\n");
|
|
114
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) {
|
|
115
|
-
printf("key: %.*s, data: %.*s\n",
|
|
116
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
117
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
118
|
-
}
|
|
119
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
120
|
-
printf("Cursor prev\n");
|
|
121
|
-
while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_PREV)) == 0) {
|
|
122
|
-
printf("key: %.*s, data: %.*s\n",
|
|
123
|
-
(int) key.mv_size, (char *) key.mv_data,
|
|
124
|
-
(int) data.mv_size, (char *) data.mv_data);
|
|
125
|
-
}
|
|
126
|
-
CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get");
|
|
127
|
-
mdb_cursor_close(cursor);
|
|
128
|
-
mdb_txn_abort(txn);
|
|
129
|
-
|
|
130
|
-
mdb_dbi_close(env, dbi);
|
|
131
|
-
mdb_env_close(env);
|
|
132
|
-
return 0;
|
|
133
|
-
}
|