mirror of
https://gitflic.ru/project/erthink/libmdbx.git
synced 2025-01-26 01:56:05 +00:00
mdbx-chk: не считаем ошибкой под-страницы без данных пользователя.
Коммитом 36a7e7ac24
был скорректирован
подсчет места занимаемого заголовками и данными. В частности, байты
занимаемые заголовков вложенной под-страницы теперь относится к
заголовкам, а не пользовательским данным.
Однако, в случае когда на под-странице, созданной для хранения куста
мульти-значений (MDBX_DUPSORT), после серии удалений остаётся одно
значение, которое в MDBX может нулевой длины, получается под-страница с
нулевым количеством пользовательских данных. Этот коммит исправляет
This commit is contained in:
parent
781b3f64d5
commit
0741c81cfd
@ -537,19 +537,8 @@ static int pgvisitor(const uint64_t pgno, const unsigned pgnumber,
|
|||||||
data_tree_problems += !is_gc_tree;
|
data_tree_problems += !is_gc_tree;
|
||||||
gc_tree_problems += is_gc_tree;
|
gc_tree_problems += is_gc_tree;
|
||||||
}
|
}
|
||||||
if (payload_bytes < 1) {
|
if (nentries < 1 || (pagetype == MDBX_page_branch && nentries < 2)) {
|
||||||
if (nentries > 1) {
|
problem_add("page", pgno, nentries ? "half-empty" : "empty",
|
||||||
problem_add("page", pgno, "zero size-of-entry",
|
|
||||||
"%s-page: payload %" PRIuPTR " bytes, %" PRIuPTR " entries",
|
|
||||||
pagetype_caption, payload_bytes, nentries);
|
|
||||||
/* if ((size_t)header_bytes + unused_bytes < page_size) {
|
|
||||||
// LY: hush a misuse error
|
|
||||||
page_bytes = page_size;
|
|
||||||
} */
|
|
||||||
data_tree_problems += !is_gc_tree;
|
|
||||||
gc_tree_problems += is_gc_tree;
|
|
||||||
} else {
|
|
||||||
problem_add("page", pgno, "empty",
|
|
||||||
"%s-page: payload %" PRIuPTR " bytes, %" PRIuPTR
|
"%s-page: payload %" PRIuPTR " bytes, %" PRIuPTR
|
||||||
" entries, deep %i",
|
" entries, deep %i",
|
||||||
pagetype_caption, payload_bytes, nentries, deep);
|
pagetype_caption, payload_bytes, nentries, deep);
|
||||||
@ -557,7 +546,6 @@ static int pgvisitor(const uint64_t pgno, const unsigned pgnumber,
|
|||||||
data_tree_problems += !is_gc_tree;
|
data_tree_problems += !is_gc_tree;
|
||||||
gc_tree_problems += is_gc_tree;
|
gc_tree_problems += is_gc_tree;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (pgnumber) {
|
if (pgnumber) {
|
||||||
if (page_bytes != page_size) {
|
if (page_bytes != page_size) {
|
||||||
|
Loading…
Reference in New Issue
Block a user