mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-20 05:08:21 +08:00
mdbx: add mdbx_dbi_sequence().
This commit is contained in:
parent
dfc3020426
commit
1b490fda24
3
mdbx.h
3
mdbx.h
@ -1759,6 +1759,9 @@ LIBMDBX_API int mdbx_dbi_open_ex(MDB_txn *txn, const char *name, unsigned flags,
|
|||||||
MDB_dbi *dbi, MDB_cmp_func *keycmp,
|
MDB_dbi *dbi, MDB_cmp_func *keycmp,
|
||||||
MDB_cmp_func *datacmp);
|
MDB_cmp_func *datacmp);
|
||||||
|
|
||||||
|
LIBMDBX_API int mdbx_dbi_sequence(MDB_txn *txn, MDB_dbi dbi, uint64_t *result,
|
||||||
|
uint64_t increment);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -246,6 +246,7 @@ typedef struct MDB_db {
|
|||||||
uint32_t md_xsize; /**< also ksize for LEAF2 pages */
|
uint32_t md_xsize; /**< also ksize for LEAF2 pages */
|
||||||
uint16_t md_flags; /**< @ref mdbx_dbi_open */
|
uint16_t md_flags; /**< @ref mdbx_dbi_open */
|
||||||
uint16_t md_depth; /**< depth of this tree */
|
uint16_t md_depth; /**< depth of this tree */
|
||||||
|
uint64_t md_seq; /* table sequence counter */
|
||||||
pgno_t md_branch_pages; /**< number of internal pages */
|
pgno_t md_branch_pages; /**< number of internal pages */
|
||||||
pgno_t md_leaf_pages; /**< number of leaf pages */
|
pgno_t md_leaf_pages; /**< number of leaf pages */
|
||||||
pgno_t md_overflow_pages; /**< number of overflow pages */
|
pgno_t md_overflow_pages; /**< number of overflow pages */
|
||||||
|
39
src/mdbx.c
39
src/mdbx.c
@ -9073,6 +9073,7 @@ int mdbx_drop(MDB_txn *txn, MDB_dbi dbi, int del) {
|
|||||||
txn->mt_dbs[dbi].md_overflow_pages = 0;
|
txn->mt_dbs[dbi].md_overflow_pages = 0;
|
||||||
txn->mt_dbs[dbi].md_entries = 0;
|
txn->mt_dbs[dbi].md_entries = 0;
|
||||||
txn->mt_dbs[dbi].md_root = P_INVALID;
|
txn->mt_dbs[dbi].md_root = P_INVALID;
|
||||||
|
txn->mt_dbs[dbi].md_seq = 0;
|
||||||
|
|
||||||
txn->mt_flags |= MDB_TXN_DIRTY;
|
txn->mt_flags |= MDB_TXN_DIRTY;
|
||||||
}
|
}
|
||||||
@ -10241,3 +10242,41 @@ int mdbx_dbi_open_ex(MDB_txn *txn, const char *name, unsigned flags,
|
|||||||
}
|
}
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int mdbx_dbi_sequence(MDB_txn *txn, MDB_dbi dbi, uint64_t *result,
|
||||||
|
uint64_t increment) {
|
||||||
|
if (unlikely(!txn))
|
||||||
|
return EINVAL;
|
||||||
|
|
||||||
|
if (unlikely(txn->mt_signature != MDBX_MT_SIGNATURE))
|
||||||
|
return MDBX_EBADSIGN;
|
||||||
|
|
||||||
|
if (unlikely(!TXN_DBI_EXIST(txn, dbi, DB_USRVALID)))
|
||||||
|
return EINVAL;
|
||||||
|
|
||||||
|
if (unlikely(TXN_DBI_CHANGED(txn, dbi)))
|
||||||
|
return MDB_BAD_DBI;
|
||||||
|
|
||||||
|
MDB_db *dbs = &txn->mt_dbs[dbi];
|
||||||
|
if (likely(result))
|
||||||
|
*result = dbs->md_seq;
|
||||||
|
|
||||||
|
if (likely(increment > 0)) {
|
||||||
|
if (unlikely(txn->mt_flags & MDB_TXN_BLOCKED))
|
||||||
|
return MDB_BAD_TXN;
|
||||||
|
|
||||||
|
if (unlikely(F_ISSET(txn->mt_flags, MDB_TXN_RDONLY)))
|
||||||
|
return EACCES;
|
||||||
|
|
||||||
|
uint64_t new = dbs->md_seq + increment;
|
||||||
|
if (unlikely(new < increment))
|
||||||
|
return MDBX_RESULT_TRUE;
|
||||||
|
|
||||||
|
assert(new > dbs->md_seq);
|
||||||
|
dbs->md_seq = new;
|
||||||
|
txn->mt_flags |= MDB_TXN_DIRTY;
|
||||||
|
txn->mt_dbflags[dbi] |= DB_DIRTY;
|
||||||
|
}
|
||||||
|
|
||||||
|
return MDB_SUCCESS;
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user