mirror of
https://github.com/isar/libmdbx.git
synced 2025-04-04 04:02:57 +08:00
mdbx-tools: добавление опции -c
(concise) в mdbx_dump
.
This commit is contained in:
parent
ef9fd1f3fb
commit
db44f4ed71
@ -12,6 +12,8 @@ mdbx_dump \- MDBX environment export tool
|
|||||||
[\c
|
[\c
|
||||||
.BR \-q ]
|
.BR \-q ]
|
||||||
[\c
|
[\c
|
||||||
|
.BR \-c ]
|
||||||
|
[\c
|
||||||
.BI \-f \ file\fR]
|
.BI \-f \ file\fR]
|
||||||
[\c
|
[\c
|
||||||
.BR \-l ]
|
.BR \-l ]
|
||||||
@ -41,6 +43,9 @@ Write the library version number to the standard output, and exit.
|
|||||||
.BR \-q
|
.BR \-q
|
||||||
Be quiet.
|
Be quiet.
|
||||||
.TP
|
.TP
|
||||||
|
.BR \-c
|
||||||
|
Concise mode without repeating keys in a dump, but incompatible with Berkeley DB and LMDB.
|
||||||
|
.TP
|
||||||
.BR \-f \ file
|
.BR \-f \ file
|
||||||
Write to the specified file instead of to the standard output.
|
Write to the specified file instead of to the standard output.
|
||||||
.TP
|
.TP
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#define PRINT 1
|
#define PRINT 1
|
||||||
#define GLOBAL 2
|
#define GLOBAL 2
|
||||||
|
#define CONCISE 4
|
||||||
static int mode = GLOBAL;
|
static int mode = GLOBAL;
|
||||||
|
|
||||||
typedef struct flagbit {
|
typedef struct flagbit {
|
||||||
@ -55,42 +56,23 @@ static void signal_handler(int sig) {
|
|||||||
|
|
||||||
#endif /* !WINDOWS */
|
#endif /* !WINDOWS */
|
||||||
|
|
||||||
static const char hexc[] = "0123456789abcdef";
|
static void dumpval(const MDBX_val *v) {
|
||||||
|
static const char digits[] = "0123456789abcdef";
|
||||||
static void dumpbyte(unsigned char c) {
|
|
||||||
putchar(hexc[c >> 4]);
|
|
||||||
putchar(hexc[c & 15]);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void text(MDBX_val *v) {
|
|
||||||
unsigned char *c, *end;
|
|
||||||
|
|
||||||
putchar(' ');
|
putchar(' ');
|
||||||
c = v->iov_base;
|
for (const unsigned char *c = v->iov_base, *end = c + v->iov_len; c < end; ++c) {
|
||||||
end = c + v->iov_len;
|
if (mode & PRINT) {
|
||||||
while (c < end) {
|
if (isprint(*c) && *c != '\\') {
|
||||||
if (isprint(*c) && *c != '\\') {
|
putchar(*c);
|
||||||
putchar(*c);
|
continue;
|
||||||
} else {
|
} else
|
||||||
putchar('\\');
|
putchar('\\');
|
||||||
dumpbyte(*c);
|
|
||||||
}
|
}
|
||||||
c++;
|
putchar(digits[*c >> 4]);
|
||||||
|
putchar(digits[*c & 15]);
|
||||||
}
|
}
|
||||||
putchar('\n');
|
putchar('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
static void dumpval(MDBX_val *v) {
|
|
||||||
unsigned char *c, *end;
|
|
||||||
|
|
||||||
putchar(' ');
|
|
||||||
c = v->iov_base;
|
|
||||||
end = c + v->iov_len;
|
|
||||||
while (c < end)
|
|
||||||
dumpbyte(*c++);
|
|
||||||
putchar('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
bool quiet = false, rescue = false;
|
bool quiet = false, rescue = false;
|
||||||
const char *prog;
|
const char *prog;
|
||||||
static void error(const char *func, int rc) {
|
static void error(const char *func, int rc) {
|
||||||
@ -185,12 +167,19 @@ static int dump_tbl(MDBX_txn *txn, MDBX_dbi dbi, char *name) {
|
|||||||
rc = MDBX_EINTR;
|
rc = MDBX_EINTR;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (mode & PRINT) {
|
dumpval(&key);
|
||||||
text(&key);
|
dumpval(&data);
|
||||||
text(&data);
|
if ((flags & MDBX_DUPSORT) && (mode & CONCISE)) {
|
||||||
} else {
|
while ((rc = mdbx_cursor_get(cursor, &key, &data, MDBX_NEXT_DUP)) == MDBX_SUCCESS) {
|
||||||
dumpval(&key);
|
if (user_break) {
|
||||||
dumpval(&data);
|
rc = MDBX_EINTR;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
putchar(' ');
|
||||||
|
dumpval(&data);
|
||||||
|
}
|
||||||
|
if (rc != MDBX_NOTFOUND)
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
printf("DATA=END\n");
|
printf("DATA=END\n");
|
||||||
@ -206,10 +195,12 @@ static int dump_tbl(MDBX_txn *txn, MDBX_dbi dbi, char *name) {
|
|||||||
static void usage(void) {
|
static void usage(void) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"usage: %s "
|
"usage: %s "
|
||||||
"[-V] [-q] [-f file] [-l] [-p] [-r] [-a|-s table] [-u|U] "
|
"[-V] [-q] [-c] [-f file] [-l] [-p] [-r] [-a|-s table] [-u|U] "
|
||||||
"dbpath\n"
|
"dbpath\n"
|
||||||
" -V\t\tprint version and exit\n"
|
" -V\t\tprint version and exit\n"
|
||||||
" -q\t\tbe quiet\n"
|
" -q\t\tbe quiet\n"
|
||||||
|
" -c\t\tconcise mode without repeating keys,\n"
|
||||||
|
" \t\tbut incompatible with Berkeley DB and LMDB\n"
|
||||||
" -f\t\twrite to file instead of stdout\n"
|
" -f\t\twrite to file instead of stdout\n"
|
||||||
" -l\t\tlist tables and exit\n"
|
" -l\t\tlist tables and exit\n"
|
||||||
" -p\t\tuse printable characters\n"
|
" -p\t\tuse printable characters\n"
|
||||||
@ -268,6 +259,7 @@ int main(int argc, char *argv[]) {
|
|||||||
"s:"
|
"s:"
|
||||||
"V"
|
"V"
|
||||||
"r"
|
"r"
|
||||||
|
"c"
|
||||||
"q")) != EOF) {
|
"q")) != EOF) {
|
||||||
switch (i) {
|
switch (i) {
|
||||||
case 'V':
|
case 'V':
|
||||||
@ -298,6 +290,9 @@ int main(int argc, char *argv[]) {
|
|||||||
break;
|
break;
|
||||||
case 'n':
|
case 'n':
|
||||||
break;
|
break;
|
||||||
|
case 'c':
|
||||||
|
mode |= CONCISE;
|
||||||
|
break;
|
||||||
case 'p':
|
case 'p':
|
||||||
mode |= PRINT;
|
mode |= PRINT;
|
||||||
break;
|
break;
|
||||||
|
@ -380,7 +380,16 @@ __hot static int readline(MDBX_val *out, MDBX_val *buf) {
|
|||||||
return badend();
|
return badend();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (fgets(buf->iov_base, (int)buf->iov_len, stdin) == nullptr)
|
|
||||||
|
/* modern concise mode, where space in second position mean the same (previously) value */
|
||||||
|
c = fgetc(stdin);
|
||||||
|
if (c == EOF)
|
||||||
|
return errno ? errno : EOF;
|
||||||
|
if (c == ' ')
|
||||||
|
return (ungetc(c, stdin) == c) ? MDBX_SUCCESS : (errno ? errno : EOF);
|
||||||
|
|
||||||
|
*(char *)buf->iov_base = c;
|
||||||
|
if (fgets((char *)buf->iov_base + 1, (int)buf->iov_len - 1, stdin) == nullptr)
|
||||||
return errno ? errno : EOF;
|
return errno ? errno : EOF;
|
||||||
lineno++;
|
lineno++;
|
||||||
|
|
||||||
@ -721,8 +730,8 @@ int main(int argc, char *argv[]) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int batch = 0;
|
int batch = 0;
|
||||||
|
MDBX_val key = {.iov_base = nullptr, .iov_len = 0}, data = {.iov_base = nullptr, .iov_len = 0};
|
||||||
while (err == MDBX_SUCCESS) {
|
while (err == MDBX_SUCCESS) {
|
||||||
MDBX_val key, data;
|
|
||||||
err = readline(&key, &kbuf);
|
err = readline(&key, &kbuf);
|
||||||
if (err == EOF)
|
if (err == EOF)
|
||||||
break;
|
break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user