mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-20 05:58:21 +08:00
mdbx: change mdbx_dkey().
This commit is contained in:
parent
f8eb858ef3
commit
5c5ef256b3
2
mdbx.h
2
mdbx.h
@ -1625,7 +1625,7 @@ LIBMDBX_API int mdbx_reader_list(MDB_env *env, MDB_msg_func *func, void *ctx);
|
|||||||
*/
|
*/
|
||||||
LIBMDBX_API int mdbx_reader_check(MDB_env *env, int *dead);
|
LIBMDBX_API int mdbx_reader_check(MDB_env *env, int *dead);
|
||||||
|
|
||||||
LIBMDBX_API char *mdbx_dkey(MDB_val *key, char *buf);
|
LIBMDBX_API char *mdbx_dkey(MDB_val *key, char *buf, const size_t bufsize);
|
||||||
|
|
||||||
LIBMDBX_API int mdbx_env_close_ex(MDB_env *env, int dont_sync);
|
LIBMDBX_API int mdbx_env_close_ex(MDB_env *env, int dont_sync);
|
||||||
|
|
||||||
|
33
src/mdbx.c
33
src/mdbx.c
@ -332,7 +332,7 @@ txnid_t mdbx_debug_edge;
|
|||||||
* @ingroup debug
|
* @ingroup debug
|
||||||
* Invoke a function to display a key in hex.
|
* Invoke a function to display a key in hex.
|
||||||
*/
|
*/
|
||||||
#define DKEY(x) mdbx_dkey(x, kbuf)
|
#define DKEY(x) mdbx_dkey(x, kbuf, sizeof(kbuf))
|
||||||
|
|
||||||
/** An invalid page number.
|
/** An invalid page number.
|
||||||
* Mainly used to denote an empty tree.
|
* Mainly used to denote an empty tree.
|
||||||
@ -821,7 +821,7 @@ static __inline pgno_t mdbx_dbg_pgno(MDB_page *mp) {
|
|||||||
* @param[in] buf the buffer to write into. Should always be #DKBUF.
|
* @param[in] buf the buffer to write into. Should always be #DKBUF.
|
||||||
* @return The key in hexadecimal form.
|
* @return The key in hexadecimal form.
|
||||||
*/
|
*/
|
||||||
char *mdbx_dkey(MDB_val *key, char *buf) {
|
char *mdbx_dkey(MDB_val *key, char *buf, const size_t bufsize) {
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
(void)key;
|
(void)key;
|
||||||
(void)buf;
|
(void)buf;
|
||||||
@ -833,17 +833,24 @@ char *mdbx_dkey(MDB_val *key, char *buf) {
|
|||||||
if (!key)
|
if (!key)
|
||||||
return "";
|
return "";
|
||||||
|
|
||||||
if (key->mv_size > DKBUF_MAXKEYSIZE)
|
const uint8_t *const data = key->mv_data;
|
||||||
return "MDB_MAXKEYSIZE";
|
bool is_ascii = true;
|
||||||
/* may want to make this a dynamic check: if the key is mostly
|
for (i = 0; is_ascii && i < key->mv_size; i++)
|
||||||
* printable characters, print it as-is instead of converting to hex. */
|
if (data[i] < ' ' || data[i] > 127)
|
||||||
#if 1
|
is_ascii = false;
|
||||||
|
|
||||||
|
if (is_ascii)
|
||||||
|
snprintf(buf, bufsize, "%.*s",
|
||||||
|
(key->mv_size > INT_MAX) ? INT_MAX : (int)key->mv_size, data);
|
||||||
|
else {
|
||||||
buf[0] = '\0';
|
buf[0] = '\0';
|
||||||
for (i = 0; i < key->mv_size; i++)
|
for (i = 0; i < key->mv_size; i++) {
|
||||||
ptr += sprintf(ptr, "%02x", ((unsigned char *)key->mv_data)[i]);
|
int len = snprintf(ptr, bufsize - (ptr - buf), "%02x", data[i]);
|
||||||
#else
|
if (len < 1)
|
||||||
sprintf(buf, "%.*s", key->mv_size, key->mv_data);
|
break;
|
||||||
#endif
|
ptr += len;
|
||||||
|
}
|
||||||
|
}
|
||||||
return buf;
|
return buf;
|
||||||
#endif /* _MSC_VER */
|
#endif /* _MSC_VER */
|
||||||
}
|
}
|
||||||
@ -6833,7 +6840,7 @@ static int mdbx_update_key(MDB_cursor *mc, MDB_val *key) {
|
|||||||
k2.mv_data = NODEKEY(node);
|
k2.mv_data = NODEKEY(node);
|
||||||
k2.mv_size = node->mn_ksize;
|
k2.mv_size = node->mn_ksize;
|
||||||
mdbx_debug("update key %u (ofs %u) [%s] to [%s] on page %zu", indx, ptr,
|
mdbx_debug("update key %u (ofs %u) [%s] to [%s] on page %zu", indx, ptr,
|
||||||
mdbx_dkey(&k2, kbuf2), DKEY(key), mp->mp_pgno);
|
mdbx_dkey(&k2, kbuf2, sizeof(kbuf2)), DKEY(key), mp->mp_pgno);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Sizes must be 2-byte aligned. */
|
/* Sizes must be 2-byte aligned. */
|
||||||
|
@ -113,8 +113,9 @@ int main(int argc, char *argv[]) {
|
|||||||
E(mdbx_cursor_get(cursor, &key, &data, MDB_FIRST));
|
E(mdbx_cursor_get(cursor, &key, &data, MDB_FIRST));
|
||||||
|
|
||||||
do {
|
do {
|
||||||
printf("key: %p %s, data: %p %.*s\n", key.mv_data, mdbx_dkey(&key, dkbuf),
|
printf("key: %p %s, data: %p %.*s\n", key.mv_data,
|
||||||
data.mv_data, (int)data.mv_size, (char *)data.mv_data);
|
mdbx_dkey(&key, dkbuf, sizeof(dkbuf)), data.mv_data,
|
||||||
|
(int)data.mv_size, (char *)data.mv_data);
|
||||||
} while ((rc = mdbx_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0);
|
} while ((rc = mdbx_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0);
|
||||||
CHECK(rc == MDB_NOTFOUND, "mdbx_cursor_get");
|
CHECK(rc == MDB_NOTFOUND, "mdbx_cursor_get");
|
||||||
mdbx_cursor_close(cursor);
|
mdbx_cursor_close(cursor);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user