summaryrefslogtreecommitdiffstats
path: root/mbbsd
diff options
context:
space:
mode:
Diffstat (limited to 'mbbsd')
-rw-r--r--mbbsd/cache.c14
-rw-r--r--mbbsd/read.c3
2 files changed, 13 insertions, 4 deletions
diff --git a/mbbsd/cache.c b/mbbsd/cache.c
index 288c38cf..e76110b8 100644
--- a/mbbsd/cache.c
+++ b/mbbsd/cache.c
@@ -520,12 +520,20 @@ touchdircache(int bid)
void
load_fileheader_cache(int bid, char *direct)
{
- int num = getbtotal(bid);
- int n = num - DIRCACHESIZE + 1;
+ int num = getbtotal(bid), n_bottom = getbottomtotal(bid);
+ int n = num - DIRCACHESIZE + n_bottom + 1;
+ int dirsize = DIRCACHESIZE-n_bottom;
if (SHM->Bbusystate != 1 && COMMON_TIME - SHM->busystate_b[bid - 1] >= 10) {
SHM->busystate_b[bid - 1] = COMMON_TIME;
+ if(n_bottom)
+ {
+ char path[256];
+ setbfile(path, currboard, ".BOTTOM");
+ get_records(path, &SHM->dircache[bid - 1][dirsize],
+ sizeof(fileheader_t), 1, n_bottom);
+ }
get_records(direct, SHM->dircache[bid - 1],
- sizeof(fileheader_t), n < 1 ? 1 : n, DIRCACHESIZE);
+ sizeof(fileheader_t), n < 1 ? 1 : n, dirsize);
SHM->busystate_b[bid - 1] = 0;
} else {
safe_sleep(1);
diff --git a/mbbsd/read.c b/mbbsd/read.c
index fb3e15d2..52f329ff 100644
--- a/mbbsd/read.c
+++ b/mbbsd/read.c
@@ -794,7 +794,7 @@ i_read(int cmdmode, char *direct, void (*dotitle) (), void (*doentry) (), onekey
{
keeploc_t *locmem = NULL;
int recbase = 0, mode, ch;
- int num = 0, entries = 0;
+ int num = 0, entries = 0, n_bottom=0;
int i;
int jump = 0;
char genbuf[4];
@@ -822,6 +822,7 @@ i_read(int cmdmode, char *direct, void (*dotitle) (), void (*doentry) (), onekey
setbottomtotal(currbid);
last_line = get_num_records(currdirect, FHSZ);
}
+ last_line += (n_bottom = getbottomtotal(currbid));
}
else
last_line = get_num_records(currdirect, FHSZ);