aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc Coquand <marc@mccd.space>2024-05-30 10:04:25 -0500
committerMarc Coquand <marc@mccd.space>2024-05-30 10:04:25 -0500
commit87dcfa6edd43316068347ff5b8f23c76bdc7b472 (patch)
treec10abd3e81df14e0eaf5b9b1e35d2e76d5ce66e7
parent2c0f6e026acb2ecfc1c39d617f47d024e404bb9d (diff)
downloadstitch-87dcfa6edd43316068347ff5b8f23c76bdc7b472.tar.gz
stitch-87dcfa6edd43316068347ff5b8f23c76bdc7b472.tar.bz2
stitch-87dcfa6edd43316068347ff5b8f23c76bdc7b472.zip
Add half-screen down/up scrolling
-rw-r--r--lib/basic.ml1
-rw-r--r--lib/done.ml18
-rw-r--r--lib/headlines.ml18
-rw-r--r--lib/help_screen.ml2
-rw-r--r--lib/stitched_article.ml21
-rw-r--r--lib/todos.ml18
6 files changed, 52 insertions, 26 deletions
diff --git a/lib/basic.ml b/lib/basic.ml
index 76b6863..94838ab 100644
--- a/lib/basic.ml
+++ b/lib/basic.ml
@@ -1,3 +1,2 @@
let array_drop n arr =
if Array.length arr < n then [||] else Array.sub arr n (max (Array.length arr - n) 0)
-
diff --git a/lib/done.ml b/lib/done.ml
index 18e7b89..5b8ad2c 100644
--- a/lib/done.ml
+++ b/lib/done.ml
@@ -87,13 +87,15 @@ let rec render
in
Common.Term.image t img;
let content_end = Array.length content_pretty + (content_start - 1) in
- let scroll_up () =
- let scroll = if y - content_start - scroll = 0 then max (scroll - 1) 0 else scroll in
- render t { state with pos = x, max (y - 1) content_start; scroll; output = None }
+ let scroll_up ?(amount = 1) () =
+ let scroll =
+ if y - content_start - scroll - amount < 0 then max (scroll - amount) 0 else scroll
+ in
+ render t { state with pos = x, max (y - amount) content_start; scroll; output = None }
in
- let scroll_down () =
- let scroll = if y - scroll >= size_y - 1 then scroll + 1 else scroll in
- render t { state with pos = x, min (y + 1) content_end; scroll; output = None }
+ let scroll_down ?(amount = 1) () =
+ let scroll = if y - scroll >= size_y - amount then scroll + amount else scroll in
+ render t { state with pos = x, min (y + amount) content_end; scroll; output = None }
in
match Common.Term.event t with
| `End | `Key (`Escape, []) | `Key (`ASCII 'q', []) | `Key (`ASCII 'C', [ `Ctrl ]) -> ()
@@ -132,6 +134,10 @@ let rec render
Input_prompt.render t input_state
| `Key (`ASCII '1', []) -> goto_headlines (fun () -> render t state)
| `Key (`ASCII '2', []) -> goto_todo (fun () -> render t state)
+ | `Key (`ASCII 'D', [ `Ctrl ]) | `Key (`Page `Down, []) ->
+ scroll_down ~amount:(size_y / 2) ()
+ | `Key (`ASCII 'U', [ `Ctrl ]) | `Key (`Page `Up, []) ->
+ scroll_up ~amount:(size_y / 2) ()
| `Key (`ASCII 'h', []) ->
let hide_file_name = not hide_file_name in
let content_pretty =
diff --git a/lib/headlines.ml b/lib/headlines.ml
index b8303c0..97eab20 100644
--- a/lib/headlines.ml
+++ b/lib/headlines.ml
@@ -93,13 +93,15 @@ let rec render
in
Common.Term.image t img;
let content_end = Array.length content_pretty + (content_start - 1) in
- let scroll_up () =
- let scroll = if y - content_start - scroll = 0 then max (scroll - 1) 0 else scroll in
- render t { state with pos = x, max (y - 1) content_start; scroll; output = None }
+ let scroll_up ?(amount = 1) () =
+ let scroll =
+ if y - content_start - scroll - amount < 0 then max (scroll - amount) 0 else scroll
+ in
+ render t { state with pos = x, max (y - amount) content_start; scroll; output = None }
in
- let scroll_down () =
- let scroll = if y - scroll >= size_y - 1 then scroll + 1 else scroll in
- render t { state with pos = x, min (y + 1) content_end; scroll; output = None }
+ let scroll_down ?(amount = 1) () =
+ let scroll = if y - scroll >= size_y - amount then scroll + amount else scroll in
+ render t { state with pos = x, min (y + amount) content_end; scroll; output = None }
in
match Common.Term.event t with
| `End | `Key (`Escape, []) | `Key (`ASCII 'q', []) | `Key (`ASCII 'C', [ `Ctrl ]) -> ()
@@ -189,6 +191,10 @@ let rec render
}
in
Input_prompt.render t input_state
+ | `Key (`ASCII 'D', [ `Ctrl ]) | `Key (`Page `Down, []) ->
+ scroll_down ~amount:(size_y / 2) ()
+ | `Key (`ASCII 'U', [ `Ctrl ]) | `Key (`Page `Up, []) ->
+ scroll_up ~amount:(size_y / 2) ()
| `Key (`ASCII 'j', []) | `Key (`ASCII 'N', [ `Ctrl ]) -> scroll_down ()
| `Key (`ASCII 'k', []) | `Key (`ASCII 'P', [ `Ctrl ]) -> scroll_up ()
| `Key (`Arrow d, _) ->
diff --git a/lib/help_screen.ml b/lib/help_screen.ml
index 3c17a9e..9d10010 100644
--- a/lib/help_screen.ml
+++ b/lib/help_screen.ml
@@ -25,6 +25,8 @@ let general_help_menu =
; "Exit", "Ctrl-c, q, Esc"
; "Down", "Ctrl-n, j"
; "Up", "Ctrl-p, k"
+ ; "Half-screen down", "Ctrl-d, PgDn"
+ ; "Half-screen up", "Ctrl-u, PgUp"
; "Regexp Search", "s"
; "Notes", "1"
; "Todo", "2"
diff --git a/lib/stitched_article.ml b/lib/stitched_article.ml
index 9548e11..9df2bd6 100644
--- a/lib/stitched_article.ml
+++ b/lib/stitched_article.ml
@@ -72,14 +72,17 @@ let rec render
in
Common.Term.image t img;
let content_length = Array.length content_pretty in
- let scroll_up () =
- let scroll = if y - content_start - scroll = 0 then max (scroll - 1) 0 else scroll in
- render t @@ { state with pos = x, max (y - 1) content_start; scroll; output = None }
+ let scroll_up ?(amount = 1) () =
+ let scroll =
+ if y - content_start - scroll - amount < 0 then max (scroll - amount) 0 else scroll
+ in
+ render t { state with pos = x, max (y - amount) content_start; scroll; output = None }
in
- let scroll_down () =
- let scroll = if y - scroll >= size_y - 1 then scroll + 1 else scroll in
- render t
- @@ { state with pos = x, min (y + 1) (content_length - 1); scroll; output = None }
+ let scroll_down ?(amount = 1) () =
+ let scroll = if y - scroll >= size_y - amount then scroll + amount else scroll in
+ render
+ t
+ { state with pos = x, min (y + amount) content_length; scroll; output = None }
in
match Common.Term.event t with
| `End | `Key (`Escape, []) | `Key (`ASCII 'q', []) | `Key (`ASCII 'C', [ `Ctrl ]) -> ()
@@ -120,6 +123,10 @@ let rec render
}
in
Input_prompt.render t input_state
+ | `Key (`ASCII 'D', [ `Ctrl ]) | `Key (`Page `Down, []) ->
+ scroll_down ~amount:(size_y / 2) ()
+ | `Key (`ASCII 'U', [ `Ctrl ]) | `Key (`Page `Up, []) ->
+ scroll_up ~amount:(size_y / 2) ()
| `Key (`ASCII '!', []) ->
let file_number_offset, content_line = Array.get content_pretty (y - content_start) in
let content_line = Grep.display_type_line content_line in
diff --git a/lib/todos.ml b/lib/todos.ml
index f2e461d..4ee911d 100644
--- a/lib/todos.ml
+++ b/lib/todos.ml
@@ -94,13 +94,15 @@ let rec render
in
Common.Term.image t img;
let content_end = Array.length content_pretty + (content_start - 1) in
- let scroll_up () =
- let scroll = if y - content_start - scroll = 0 then max (scroll - 1) 0 else scroll in
- render t { state with pos = x, max (y - 1) content_start; scroll; output = None }
+ let scroll_up ?(amount = 1) () =
+ let scroll =
+ if y - content_start - scroll - amount < 0 then max (scroll - amount) 0 else scroll
+ in
+ render t { state with pos = x, max (y - amount) content_start; scroll; output = None }
in
- let scroll_down () =
- let scroll = if y - scroll >= size_y - 1 then scroll + 1 else scroll in
- render t { state with pos = x, min (y + 1) content_end; scroll; output = None }
+ let scroll_down ?(amount = 1) () =
+ let scroll = if y - scroll >= size_y - amount then scroll + amount else scroll in
+ render t { state with pos = x, min (y + amount) content_end; scroll; output = None }
in
match Common.Term.event t with
| `End | `Key (`Escape, []) | `Key (`ASCII 'q', []) | `Key (`ASCII 'C', [ `Ctrl ]) -> ()
@@ -114,6 +116,10 @@ let rec render
| `Key (`ASCII '?', []) -> Help_screen.render t { go_back = (fun () -> render t state) }
| `Key (`ASCII '1', []) -> goto_headlines (fun () -> render t state)
| `Key (`ASCII '3', []) -> goto_done (fun () -> render t state)
+ | `Key (`ASCII 'D', [ `Ctrl ]) | `Key (`Page `Down, []) ->
+ scroll_down ~amount:(size_y / 2) ()
+ | `Key (`ASCII 'U', [ `Ctrl ]) | `Key (`Page `Up, []) ->
+ scroll_up ~amount:(size_y / 2) ()
| `Key (`ASCII 'g', []) ->
let content, content_pretty = load_todos ~hide_file_name () in
let y = min (List.length content_pretty + content_start) y in