From 476c5b02ea67240fdfb7e4021fe9b6ddbae3be3a Mon Sep 17 00:00:00 2001 From: Hallvard Furuseth Date: Tue, 19 May 2015 20:33:35 +0200 Subject: [PATCH] lmdb: ITS#8117 Fix MDB_INTEGERDUP keysize doc. Change-Id: I7cf7c456f35fe9c5449a37ad9130864617197726 --- lmdb.h | 14 +++++++------- mdb.c | 5 ++++- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/lmdb.h b/lmdb.h index b87d98ec..e7fce302 100644 --- a/lmdb.h +++ b/lmdb.h @@ -297,12 +297,12 @@ typedef void (MDB_rel_func)(MDB_val *item, void *oldptr, void *newptr, void *rel #define MDB_REVERSEKEY 0x02 /** use sorted duplicates */ #define MDB_DUPSORT 0x04 - /** numeric keys in native byte order. + /** numeric keys in native byte order: either unsigned int or size_t. * The keys must all be of the same size. */ #define MDB_INTEGERKEY 0x08 /** with #MDB_DUPSORT, sorted dup items have fixed size */ #define MDB_DUPFIXED 0x10 - /** with #MDB_DUPSORT, dups are numeric in native byte order */ + /** with #MDB_DUPSORT, dups are #MDB_INTEGERKEY-style integers */ #define MDB_INTEGERDUP 0x20 /** with #MDB_DUPSORT, use reverse string dups */ #define MDB_REVERSEDUP 0x40 @@ -1095,9 +1095,9 @@ int mdb_txn_renew(MDB_txn *txn); * keys may have multiple data items, stored in sorted order.) By default * keys must be unique and may have only a single data item. *
  • #MDB_INTEGERKEY - * Keys are binary integers in native byte order. Setting this option - * requires all keys to be the same size, typically sizeof(int) - * or sizeof(size_t). + * Keys are binary integers in native byte order, either unsigned int + * or size_t, and will be sorted as such. + * The keys must all be of the same size. *
  • #MDB_DUPFIXED * This flag may only be used in combination with #MDB_DUPSORT. This option * tells the library that the data items for this database are all the same @@ -1105,8 +1105,8 @@ int mdb_txn_renew(MDB_txn *txn); * all data items are the same size, the #MDB_GET_MULTIPLE and #MDB_NEXT_MULTIPLE * cursor operations may be used to retrieve multiple items at once. *
  • #MDB_INTEGERDUP - * This option specifies that duplicate data items are also integers, and - * should be sorted as such. + * This option specifies that duplicate data items are binary integers, + * similar to #MDB_INTEGERKEY keys. *
  • #MDB_REVERSEDUP * This option specifies that duplicate data items should be compared as * strings in reverse order. diff --git a/mdb.c b/mdb.c index 37e5a39c..640cfc88 100644 --- a/mdb.c +++ b/mdb.c @@ -4796,7 +4796,10 @@ mdb_env_close_ex(MDB_env *env, int dont_sync) free(env); } -/** Compare two items pointing at aligned size_t's or unsigned's */ +/** Compare two items pointing at aligned unsigned int's. + * + * This is also set as #MDB_INTEGERDUP|#MDB_DUPFIXED's #MDB_dbx.%md_dcmp. + */ static int mdb_cmp_int_a(const MDB_val *a, const MDB_val *b) {