mdbx: replace size_t with uint64_t/uint32_t in API.

This commit is contained in:
Leo Yuriev 2017-05-22 19:57:54 +03:00
parent 0c9832fc28
commit 994481e4f4
2 changed files with 20 additions and 21 deletions

37
mdbx.h
View File

@ -115,7 +115,7 @@ typedef struct MDB_env MDB_env;
typedef struct MDB_txn MDB_txn; typedef struct MDB_txn MDB_txn;
/* A handle for an individual database in the DB environment. */ /* A handle for an individual database in the DB environment. */
typedef unsigned MDB_dbi; typedef uint32_t MDB_dbi;
/* Opaque structure for navigating through a database */ /* Opaque structure for navigating through a database */
typedef struct MDB_cursor MDB_cursor; typedef struct MDB_cursor MDB_cursor;
@ -185,9 +185,8 @@ typedef int(MDB_cmp_func)(const MDB_val *a, const MDB_val *b);
#define MDB_REVERSEKEY 0x02u #define MDB_REVERSEKEY 0x02u
/* use sorted duplicates */ /* use sorted duplicates */
#define MDB_DUPSORT 0x04u #define MDB_DUPSORT 0x04u
/* numeric keys in native byte order, either unsigned int or mdbx_size_t. /* numeric keys in native byte order, either uint32_t or uint64_t.
* (lmdb expects 32-bit int <= size_t <= 32/64-bit mdbx_size_t.) * The keys must all be of the same size. */
* The keys must all be of the same size. */
#define MDB_INTEGERKEY 0x08u #define MDB_INTEGERKEY 0x08u
/* with MDB_DUPSORT, sorted dup items have fixed size */ /* with MDB_DUPSORT, sorted dup items have fixed size */
#define MDB_DUPFIXED 0x10u #define MDB_DUPFIXED 0x10u
@ -334,23 +333,23 @@ typedef enum MDB_cursor_op {
/* Statistics for a database in the environment */ /* Statistics for a database in the environment */
typedef struct MDBX_stat { typedef struct MDBX_stat {
unsigned ms_psize; /* Size of a database page. uint32_t ms_psize; /* Size of a database page.
* This is currently the same for all databases. */ * This is currently the same for all databases. */
unsigned ms_depth; /* Depth (height) of the B-tree */ uint32_t ms_depth; /* Depth (height) of the B-tree */
size_t ms_branch_pages; /* Number of internal (non-leaf) pages */ uint64_t ms_branch_pages; /* Number of internal (non-leaf) pages */
size_t ms_leaf_pages; /* Number of leaf pages */ uint64_t ms_leaf_pages; /* Number of leaf pages */
size_t ms_overflow_pages; /* Number of overflow pages */ uint64_t ms_overflow_pages; /* Number of overflow pages */
size_t ms_entries; /* Number of data items */ uint64_t ms_entries; /* Number of data items */
} MDBX_stat; } MDBX_stat;
/* Information about the environment */ /* Information about the environment */
typedef struct MDBX_envinfo { typedef struct MDBX_envinfo {
void *me_mapaddr; /* Address of map, if fixed */ void *me_mapaddr; /* Address of map, if fixed */
size_t me_mapsize; /* Size of the data memory map */ uint64_t me_mapsize; /* Size of the data memory map */
size_t me_last_pgno; /* ID of the last used page */ uint64_t me_last_pgno; /* ID of the last used page */
uint64_t me_last_txnid; /* ID of the last committed transaction */ uint64_t me_last_txnid; /* ID of the last committed transaction */
unsigned me_maxreaders; /* max reader slots in the environment */ uint32_t me_maxreaders; /* max reader slots in the environment */
unsigned me_numreaders; /* max reader slots used in the environment */ uint32_t me_numreaders; /* max reader slots used in the environment */
uint64_t me_tail_txnid; /* ID of the last reader transaction */ uint64_t me_tail_txnid; /* ID of the last reader transaction */
uint64_t me_meta1_txnid, me_meta1_sign; uint64_t me_meta1_txnid, me_meta1_sign;
uint64_t me_meta2_txnid, me_meta2_sign; uint64_t me_meta2_txnid, me_meta2_sign;
@ -917,7 +916,7 @@ LIBMDBX_API MDB_env *mdbx_txn_env(MDB_txn *txn);
* [in] txn A transaction handle returned by mdbx_txn_begin() * [in] txn A transaction handle returned by mdbx_txn_begin()
* *
* Returns A transaction ID, valid if input is an active transaction. */ * Returns A transaction ID, valid if input is an active transaction. */
LIBMDBX_API size_t mdbx_txn_id(MDB_txn *txn); LIBMDBX_API uint64_t mdbx_txn_id(MDB_txn *txn);
/* Commit all the operations of a transaction into the database. /* Commit all the operations of a transaction into the database.
* *
@ -1419,7 +1418,7 @@ LIBMDBX_API int mdbx_cursor_del(MDB_cursor *cursor, unsigned flags);
* possible errors are: * possible errors are:
* - EINVAL - cursor is not initialized, * - EINVAL - cursor is not initialized,
* or an invalid parameter was specified. */ * or an invalid parameter was specified. */
LIBMDBX_API int mdbx_cursor_count(MDB_cursor *cursor, size_t *countp); LIBMDBX_API int mdbx_cursor_count(MDB_cursor *cursor, uint64_t *countp);
/* Compare two data items according to a particular database. /* Compare two data items according to a particular database.
* *
@ -1523,7 +1522,7 @@ LIBMDBX_API int mdbx_txn_straggler(MDB_txn *txn, int *percent);
* 1 on success (reader was killed), * 1 on success (reader was killed),
* >1 on success (reader was SURE killed). */ * >1 on success (reader was SURE killed). */
typedef int(MDBX_oom_func)(MDB_env *env, int pid, mdbx_tid_t thread_id, typedef int(MDBX_oom_func)(MDB_env *env, int pid, mdbx_tid_t thread_id,
size_t txn, unsigned gap, int retry); uint64_t txn, unsigned gap, int retry);
/* Set the OOM callback. /* Set the OOM callback.
* *
@ -1560,7 +1559,7 @@ typedef void MDBX_debug_func(int type, const char *function, int line,
LIBMDBX_API int mdbx_setup_debug(int flags, MDBX_debug_func *logger, LIBMDBX_API int mdbx_setup_debug(int flags, MDBX_debug_func *logger,
long edge_txn); long edge_txn);
typedef int MDBX_pgvisitor_func(size_t pgno, unsigned pgnumber, void *ctx, typedef int MDBX_pgvisitor_func(uint64_t pgno, unsigned pgnumber, void *ctx,
const char *dbi, const char *type, int nentries, const char *dbi, const char *type, int nentries,
int payload_bytes, int header_bytes, int payload_bytes, int header_bytes,
int unused_bytes); int unused_bytes);

View File

@ -2452,7 +2452,7 @@ MDB_env *mdbx_txn_env(MDB_txn *txn) {
return txn->mt_env; return txn->mt_env;
} }
size_t mdbx_txn_id(MDB_txn *txn) { uint64_t mdbx_txn_id(MDB_txn *txn) {
if (unlikely(!txn || txn->mt_signature != MDBX_MT_SIGNATURE)) if (unlikely(!txn || txn->mt_signature != MDBX_MT_SIGNATURE))
return ~(txnid_t)0; return ~(txnid_t)0;
return txn->mt_txnid; return txn->mt_txnid;
@ -6839,7 +6839,7 @@ int mdbx_cursor_renew(MDB_txn *txn, MDB_cursor *mc) {
} }
/* Return the count of duplicate data items for the current key */ /* Return the count of duplicate data items for the current key */
int mdbx_cursor_count(MDB_cursor *mc, size_t *countp) { int mdbx_cursor_count(MDB_cursor *mc, uint64_t *countp) {
if (unlikely(mc == NULL || countp == NULL)) if (unlikely(mc == NULL || countp == NULL))
return MDBX_EINVAL; return MDBX_EINVAL;