mdbx: Merge branch 'devel'.

This commit is contained in:
Leo Yuriev 2017-07-21 22:47:49 +03:00
commit 83f73d8178
3 changed files with 40 additions and 1 deletions

View File

@ -20,6 +20,8 @@ src/tools/mdbx_load.1
src/tools/mdbx_load.c src/tools/mdbx_load.c
src/tools/mdbx_stat.1 src/tools/mdbx_stat.1
src/tools/mdbx_stat.c src/tools/mdbx_stat.c
src/tools/wingetopt.c
src/tools/wingetopt.h
src/version.c src/version.c
test/actor.cc test/actor.cc
test/base.h test/base.h

View File

@ -234,7 +234,8 @@ int main(int argc, char *argv[]) {
goto txn_abort; goto txn_abort;
} }
prstat(&mst); prstat(&mst);
while ((rc = mdbx_cursor_get(cursor, &key, &data, MDBX_NEXT)) == 0) { while ((rc = mdbx_cursor_get(cursor, &key, &data, MDBX_NEXT)) ==
MDBX_SUCCESS) {
if (user_break) { if (user_break) {
rc = MDBX_EINTR; rc = MDBX_EINTR;
break; break;
@ -274,6 +275,20 @@ int main(int argc, char *argv[]) {
} }
} }
mdbx_cursor_close(cursor); mdbx_cursor_close(cursor);
switch (rc) {
case MDBX_SUCCESS:
case MDBX_NOTFOUND:
break;
case MDBX_EINTR:
fprintf(stderr, "Interrupted by signal/user\n");
goto txn_abort;
default:
fprintf(stderr, "mdbx_cursor_get failed, error %d %s\n", rc,
mdbx_strerror(rc));
goto txn_abort;
}
if (envinfo) { if (envinfo) {
uint64_t value = mei.mi_mapsize / mst.ms_psize; uint64_t value = mei.mi_mapsize / mst.ms_psize;
double percent = value / 100.0; double percent = value / 100.0;

View File

@ -6,10 +6,32 @@
* Code given out at the 1985 UNIFORUM conference in Dallas. * Code given out at the 1985 UNIFORUM conference in Dallas.
*/ */
/*----------------------------------------------------------------------------*/
/* Microsoft compiler generates a lot of warning for self includes... */
#ifdef _MSC_VER
#pragma warning(push, 1)
#pragma warning(disable : 4548) /* expression before comma has no effect; \
expected expression with side - effect */
#pragma warning(disable : 4530) /* C++ exception handler used, but unwind \
* semantics are not enabled. Specify /EHsc */
#pragma warning(disable : 4577) /* 'noexcept' used with no exception handling \
* mode specified; termination on exception is \
* not guaranteed. Specify /EHsc */
#if !defined(_CRT_SECURE_NO_WARNINGS)
#define _CRT_SECURE_NO_WARNINGS
#endif
#endif /* _MSC_VER (warnings) */
#include "wingetopt.h" #include "wingetopt.h"
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#ifdef _MSC_VER
#pragma warning(pop)
#endif
/*----------------------------------------------------------------------------*/
#ifndef NULL #ifndef NULL
#define NULL 0 #define NULL 0
#endif #endif