1
1

* view.c (view_move_forward2): Simplified the code.

* view.c (get_byte_growing_buffer): Added bounds checking.
Этот коммит содержится в:
Roland Illig 2005-04-13 22:18:04 +00:00
родитель ca1fc0467d
Коммит 0b2f50aad4
2 изменённых файлов: 10 добавлений и 7 удалений

Просмотреть файл

@ -33,6 +33,8 @@
* view.c (view_close_datasource): For the growing buffer cases, * view.c (view_close_datasource): For the growing buffer cases,
check if the datasource has already been closed before. check if the datasource has already been closed before.
* view.c (view_handle_editkey): Simplified the code. * view.c (view_handle_editkey): Simplified the code.
* view.c (view_move_forward2): Simplified the code.
* view.c (get_byte_growing_buffer): Added bounds checking.
2005-04-07 Roland Illig <roland.illig@gmx.de> 2005-04-07 Roland Illig <roland.illig@gmx.de>

Просмотреть файл

@ -63,7 +63,7 @@
#include "selcodepage.h" #include "selcodepage.h"
/* Block size for reading files in parts */ /* Block size for reading files in parts */
#define VIEW_PAGE_SIZE 8192 #define VIEW_PAGE_SIZE ((size_t) 8192)
#define vwidth (view->widget.cols - (view->have_frame ? 2 : 0)) #define vwidth (view->widget.cols - (view->have_frame ? 2 : 0))
#define vheight (view->widget.lines - (view->have_frame ? 2 : 0)) #define vheight (view->widget.lines - (view->have_frame ? 2 : 0))
@ -98,7 +98,6 @@ struct WView {
char *filename; /* Name of the file */ char *filename; /* Name of the file */
char *command; /* Command used to pipe data in */ char *command; /* Command used to pipe data in */
int view_active; int view_active;
int have_frame;
enum view_ds datasource; /* Where the displayed data comes from */ enum view_ds datasource; /* Where the displayed data comes from */
@ -121,6 +120,7 @@ struct WView {
size_t ds_string_len; /* The length of the string */ size_t ds_string_len; /* The length of the string */
/* Display information */ /* Display information */
int have_frame;
offset_type last; /* Last byte shown */ offset_type last; /* Last byte shown */
offset_type first; /* First byte in file */ offset_type first; /* First byte in file */
offset_type bottom_first; /* First byte shown when very last page is displayed */ offset_type bottom_first; /* First byte shown when very last page is displayed */
@ -1169,9 +1169,7 @@ view_move_forward2 (WView *view, offset_type current, int lines, offset_type upt
if (c == '\r') if (c == '\r')
continue; /* This characters is never displayed */ continue; /* This characters is never displayed */
else if (c == '\t') else if (c == '\t')
col = col = ((col - frame_shift) / 8) * 8 + 8 + frame_shift;
((col - view->have_frame) / 8) * 8 + 8 +
view->have_frame;
else else
col++; col++;
if (view->viewer_nroff_flag && c == '\b') { if (view->viewer_nroff_flag && c == '\b') {
@ -2875,12 +2873,15 @@ get_byte_none (WView *view, offset_type byte_index)
static int static int
get_byte_growing_buffer (WView *view, offset_type byte_index) get_byte_growing_buffer (WView *view, offset_type byte_index)
{ {
size_t pageno = byte_index / VIEW_PAGE_SIZE; offset_type pageno = byte_index / VIEW_PAGE_SIZE;
size_t pageindex = byte_index % VIEW_PAGE_SIZE; offset_type pageindex = byte_index % VIEW_PAGE_SIZE;
assert (view->growing_buffer); assert (view->growing_buffer);
assert (view->datasource == DS_STDIO_PIPE || view->datasource == DS_VFS_PIPE); assert (view->datasource == DS_STDIO_PIPE || view->datasource == DS_VFS_PIPE);
if ((size_t) pageno != pageno)
return -1;
view_growbuf_read_until (view, byte_index + 1); view_growbuf_read_until (view, byte_index + 1);
if (view->blocks == 0) if (view->blocks == 0)
return -1; return -1;