diff options
author | Kartik K. Agaram <vc@akkartik.com> | 2023-04-19 22:15:58 -0700 |
---|---|---|
committer | Kartik K. Agaram <vc@akkartik.com> | 2023-04-19 22:15:58 -0700 |
commit | 488f0e4bce938736da74035fbd394319f4e20eec (patch) | |
tree | 7a9050f7c21c02c58f841b228dc7cbb08ac0a1ab | |
parent | 88caf4eb3108a5dee7325cc75d8581711568619f (diff) | |
parent | 22071c9b71ad9b2256bd8302f2eeacdbbce5c01f (diff) | |
download | text.love-488f0e4bce938736da74035fbd394319f4e20eec.tar.gz |
Merge lines.love
-rw-r--r-- | source_text.lua | 17 |
1 files changed, 4 insertions, 13 deletions
diff --git a/source_text.lua b/source_text.lua index 178e0c4..e00a3fe 100644 --- a/source_text.lua +++ b/source_text.lua @@ -429,19 +429,7 @@ end function Text.pagedown(State) --? print('pagedown') - -- If a line/paragraph gets to a page boundary, I often want to scroll - -- before I get to the bottom. - -- However, only do this if it makes forward progress. - local bot2 = Text.to2(State, State.screen_bottom1) - if bot2.screen_line > 1 then - bot2.screen_line = math.max(bot2.screen_line-10, 1) - end - local new_top1 = Text.to1(State, bot2) - if Text.lt1(State.screen_top1, new_top1) then - State.screen_top1 = new_top1 - else - State.screen_top1 = {line=State.screen_bottom1.line, pos=State.screen_bottom1.pos} - end + State.screen_top1 = {line=State.screen_bottom1.line, pos=State.screen_bottom1.pos} --? print('setting top to', State.screen_top1.line, State.screen_top1.pos) State.cursor1 = {line=State.screen_top1.line, pos=State.screen_top1.pos} Text.move_cursor_down_to_next_text_line_while_scrolling_again_if_necessary(State) @@ -688,6 +676,9 @@ function Text.move_cursor_down_to_next_text_line_while_scrolling_again_if_necess y = y + Drawing_padding_height + Drawing.pixels(State.lines[State.cursor1.line].h, State.width) State.cursor1.line = State.cursor1.line + 1 end + if State.cursor1.pos == nil then + State.cursor1.pos = 1 + end -- hack: insert a text line at bottom of file if necessary if State.cursor1.line > #State.lines then assert(State.cursor1.line == #State.lines+1) |