summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/modes.h1
-rw-r--r--mbbsd/read.c31
2 files changed, 25 insertions, 7 deletions
diff --git a/include/modes.h b/include/modes.h
index cc4e8ad8..4c629f2f 100644
--- a/include/modes.h
+++ b/include/modes.h
@@ -14,6 +14,7 @@
#define PART_REDRAW 10
#define TITLE_REDRAW 11
#define READ_SKIP 12
+#define HEADERS_RELOAD 13
/* user ¾Þ§@ª¬ºA»P¼Ò¦¡ */
#define IDLE 0
diff --git a/mbbsd/read.c b/mbbsd/read.c
index 02f86b08..5fcf885c 100644
--- a/mbbsd/read.c
+++ b/mbbsd/read.c
@@ -229,7 +229,7 @@ fixkeep(char *s, int first)
/* calc cursor pos and show cursor correctly */
static int
-cursor_pos(keeploc_t * locmem, int val, int from_top)
+cursor_pos(keeploc_t * locmem, int val, int from_top, int isshow)
{
int top=locmem->top_ln;
if (!last_line)
@@ -242,16 +242,19 @@ cursor_pos(keeploc_t * locmem, int val, int from_top)
if (val <= 0)
val = 1;
if (val >= top && val < top + p_lines) {
- cursor_clear(3 + locmem->crs_ln - top, 0);
+ if(isshow)
+ {
+ cursor_clear(3 + locmem->crs_ln - top, 0);
+ cursor_show(3 + val - top, 0);
+ }
locmem->crs_ln = val;
- cursor_show(3 + val - top, 0);
return DONOTHING;
}
locmem->top_ln = val - from_top;
if (locmem->top_ln <= 0)
locmem->top_ln = 1;
locmem->crs_ln = val;
- return PARTUPDATE;
+ return isshow ? PARTUPDATE : HEADERS_RELOAD;
}
static int
@@ -415,7 +418,7 @@ i_read_key(onekey_t * rcmdlist, keeploc_t * locmem,
int ch, new_ln= locmem->crs_ln, lastmode=0;
do {
- if((mode=cursor_pos(locmem, new_ln, new_top))!=DONOTHING)
+ if((mode=cursor_pos(locmem, new_ln, new_top, default_ch?0:1))!=DONOTHING)
return mode;
if(default_ch)
@@ -756,7 +759,7 @@ i_read(int cmdmode, char *direct, void (*dotitle) (), void (*doentry) (), onekey
recbase = -1;
}
}
- if (recbase != locmem->top_ln) {
+ if (recbase != locmem->top_ln) { //headers reload
recbase = locmem->top_ln;
if (recbase > last_line) {
recbase = last_line - p_lines + 1;
@@ -785,7 +788,21 @@ i_read(int cmdmode, char *direct, void (*dotitle) (), void (*doentry) (), onekey
break;
case TITLE_REDRAW:
(*dotitle) ();
- break;
+ break;
+
+ case HEADERS_RELOAD:
+ if (recbase != locmem->top_ln) {
+ recbase = locmem->top_ln;
+ if (recbase > last_line) {
+ recbase = last_line - p_lines + 1;
+ if (recbase < 1)
+ recbase = 1;
+ locmem->top_ln = recbase;
+ }
+ entries=get_records_and_bottom(currdirect,
+ headers, recbase, p_lines, last_line, bottom_line);
+ }
+ break;
} //end switch
mode = i_read_key(rcmdlist, locmem, currbid, bottom_line);
} while (mode != DOQUIT);