From 251d34d6e61ae4ca5ddbb3ae6708c38c3ff7ac6d Mon Sep 17 00:00:00 2001 From: Leonid Yuriev Date: Mon, 2 Mar 2020 13:50:33 +0300 Subject: [PATCH] mdbx-doc: more for custom comparators. Change-Id: I3326c5bdedbbdb01b1865bff68aa7ba8bc7056cc --- mdbx.h | 11 ++++++++--- src/tools/mdbx_load.c | 3 ++- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/mdbx.h b/mdbx.h index b2c3bea0..6b7582d2 100644 --- a/mdbx.h +++ b/mdbx.h @@ -2590,9 +2590,14 @@ typedef int(MDBX_cmp_func)(const MDBX_val *a, const MDBX_val *b); * comparison functions for keys and values (for multimaps). * However, I recommend not using custom comparison functions, but instead * converting the keys to one of the forms that are suitable for built-in - * comparators. The main reason for this is that you can't use mdbx_chk tools - * with a custom comparators. For instance take look to the mdbx_key_from_xxx() - * functions. + * comparators (for instance take look to the mdbx_key_from_xxx() + * functions). The reasons to not using custom comparators are: + * - The order of records could not be validated without your code. + * So mdbx_chk utility will reports "wrong order" errors + * and the '-i' option is required to ignore ones. + * - A records could not be ordered or sorted without your code. + * So mdbx_load utility should be used with '-a' option to preserve + * input data order. * * [in] keycmp Optional custom key comparison function for a database. * [in] datacmp Optional custom data comparison function for a database, takes diff --git a/src/tools/mdbx_load.c b/src/tools/mdbx_load.c index 449848e7..c0bd33cc 100644 --- a/src/tools/mdbx_load.c +++ b/src/tools/mdbx_load.c @@ -339,7 +339,8 @@ static void usage(void) { "dbpath\n" " -V\t\tprint version and exit\n" " -q\t\tbe quiet\n" - " -a\t\tappend records in input order\n" + " -a\t\tappend records in input order (required for custom " + "comparators)\n" " -f file\tread from file instead of stdin\n" " -s name\tload into named subDB\n" " -N\t\tuse NOOVERWRITE on puts\n"