From 34ccab684503c753fdfaf7caa56dd9f2c8415589 Mon Sep 17 00:00:00 2001 From: in2 Date: Fri, 27 Aug 2004 06:13:06 +0000 Subject: fix bug in r2169 git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@2168 63ad8ddf-47c3-0310-b6dd-a9e9d9715204 --- mbbsd/io.c | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) (limited to 'mbbsd') diff --git a/mbbsd/io.c b/mbbsd/io.c index 1840162d..75d38c96 100644 --- a/mbbsd/io.c +++ b/mbbsd/io.c @@ -290,15 +290,18 @@ igetch() if (currutmp->msgs[0].pid && WATERMODE(WATER_OFO) && wmofo == NOTREPLYING) { int y, x, my_newfd; - screenline_t *screen0 = calloc(WB_OFO_WINDOW_HEIGHT, sizeof(screenline_t)); - memcpy(screen0, &big_picture[WB_OFO_USER_TOP - 1], - WB_OFO_WINDOW_HEIGHT * sizeof(screenline_t)); + screenline_t *screen0 = calloc(WB_OFO_WINDOW_HEIGHT + 1, + sizeof(screenline_t)); + memcpy(&screen0[0], &big_picture[0], sizeof(screenline_t)); + memcpy(&screen0[1], &big_picture[WB_OFO_USER_TOP], + WB_OFO_WINDOW_HEIGHT * sizeof(screenline_t)); getyx(&y, &x); my_newfd = i_newfd; i_newfd = 0; my_write2(); - memcpy(&big_picture[WB_OFO_USER_TOP - 1], screen0, - WB_OFO_WINDOW_HEIGHT * sizeof(screenline_t)); + memcpy(&big_picture[0], &screen0[0], sizeof(screenline_t)); + memcpy(&big_picture[WB_OFO_USER_TOP], &screen0[1], + WB_OFO_WINDOW_HEIGHT * sizeof(screenline_t)); i_newfd = my_newfd; move(y, x); free(screen0); -- cgit v1.2.3