1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

Reuse existing functions to scroll. Added horizontal_scroll_extended.

This commit is contained in:
Witold Filipczyk 2018-04-15 14:32:18 +02:00
parent 7a006b6dd2
commit 798a7cc4e6
3 changed files with 20 additions and 8 deletions

View File

@ -1312,6 +1312,7 @@ move_search_do(struct session *ses, struct document_view *doc_view, int directio
return FRAME_EVENT_REFRESH; return FRAME_EVENT_REFRESH;
} }
enum frame_event_status enum frame_event_status
move_search_next(struct session *ses, struct document_view *doc_view) move_search_next(struct session *ses, struct document_view *doc_view)
{ {
@ -1340,10 +1341,8 @@ move_search_number(struct session *ses, struct document_view *doc_view, int numb
x = pt[number].x; x = pt[number].x;
y = pt[number].y; y = pt[number].y;
if (x < doc_view->vs->x || x >= doc_view->vs->x + doc_view->box.width) horizontal_scroll_extended(ses, doc_view, x - doc_view->vs->x, 0);
doc_view->vs->x = x; vertical_scroll(ses, doc_view, y - doc_view->vs->y);
doc_view->vs->y = y;
set_link(doc_view);
return FIND_ERROR_NONE; return FIND_ERROR_NONE;
} }

View File

@ -300,7 +300,7 @@ move_link_dir(struct session *ses, struct document_view *doc_view, int dir_x, in
} }
/*! @a steps > 0 -> down */ /*! @a steps > 0 -> down */
static enum frame_event_status enum frame_event_status
vertical_scroll(struct session *ses, struct document_view *doc_view, int steps) vertical_scroll(struct session *ses, struct document_view *doc_view, int steps)
{ {
int y; int y;
@ -335,8 +335,8 @@ vertical_scroll(struct session *ses, struct document_view *doc_view, int steps)
} }
/*! @a steps > 0 -> right */ /*! @a steps > 0 -> right */
static enum frame_event_status enum frame_event_status
horizontal_scroll(struct session *ses, struct document_view *doc_view, int steps) horizontal_scroll_extended(struct session *ses, struct document_view *doc_view, int steps, int extended)
{ {
int x, max; int x, max;
@ -345,7 +345,7 @@ horizontal_scroll(struct session *ses, struct document_view *doc_view, int steps
x = doc_view->vs->x + steps; x = doc_view->vs->x + steps;
if (get_opt_bool("document.browse.scrolling.horizontal_extended", ses)) { if (extended) {
max = doc_view->document->width - 1; max = doc_view->document->width - 1;
} else { } else {
max = int_max(doc_view->vs->x, max = int_max(doc_view->vs->x,
@ -365,6 +365,17 @@ horizontal_scroll(struct session *ses, struct document_view *doc_view, int steps
return FRAME_EVENT_REFRESH; return FRAME_EVENT_REFRESH;
} }
/*! @a steps > 0 -> right */
static enum frame_event_status
horizontal_scroll(struct session *ses, struct document_view *doc_view, int steps)
{
assert(ses && doc_view && doc_view->vs && doc_view->document);
if_assert_failed return FRAME_EVENT_OK;
return horizontal_scroll_extended(ses, doc_view, steps,
get_opt_bool("document.browse.scrolling.horizontal_extended", ses));
}
enum frame_event_status enum frame_event_status
scroll_up(struct session *ses, struct document_view *doc_view) scroll_up(struct session *ses, struct document_view *doc_view)
{ {

View File

@ -42,6 +42,8 @@ enum frame_event_status scroll_up(struct session *ses, struct document_view *doc
enum frame_event_status scroll_down(struct session *ses, struct document_view *doc_view); enum frame_event_status scroll_down(struct session *ses, struct document_view *doc_view);
enum frame_event_status scroll_left(struct session *ses, struct document_view *doc_view); enum frame_event_status scroll_left(struct session *ses, struct document_view *doc_view);
enum frame_event_status scroll_right(struct session *ses, struct document_view *doc_view); enum frame_event_status scroll_right(struct session *ses, struct document_view *doc_view);
enum frame_event_status horizontal_scroll_extended(struct session *ses, struct document_view *doc_view, int steps, int extended);
enum frame_event_status vertical_scroll(struct session *ses, struct document_view *doc_view, int steps);
enum frame_event_status move_document_start(struct session *ses, struct document_view *doc_view); enum frame_event_status move_document_start(struct session *ses, struct document_view *doc_view);
enum frame_event_status move_document_end(struct session *ses, struct document_view *doc_view); enum frame_event_status move_document_end(struct session *ses, struct document_view *doc_view);