diff options
author | Kartik K. Agaram <vc@akkartik.com> | 2023-05-06 09:09:48 -0700 |
---|---|---|
committer | Kartik K. Agaram <vc@akkartik.com> | 2023-05-06 09:09:48 -0700 |
commit | e39fe490e43d7950fce23db7fb17631728f11ecc (patch) | |
tree | 979f91ad74d2a007cd90db00e9f8f16f3e411b27 | |
parent | 6274df27c3773a5ea84e73ce1be3b48e95905d3c (diff) | |
parent | 6a1d8e5164a9bb21c654f4cfa7bc8ff4c43e6c95 (diff) | |
download | text.love-e39fe490e43d7950fce23db7fb17631728f11ecc.tar.gz |
Merge lines.love
-rw-r--r-- | Manual_tests.md | 3 | ||||
-rw-r--r-- | source_text.lua | 4 | ||||
-rw-r--r-- | text.lua | 4 |
3 files changed, 7 insertions, 4 deletions
diff --git a/Manual_tests.md b/Manual_tests.md index 5e702fa..236cd27 100644 --- a/Manual_tests.md +++ b/Manual_tests.md @@ -28,8 +28,7 @@ Lua is dynamically typed. Tests can't patch over lack of type-checking. * All strings are UTF-8. Bytes within them are not characters. I try to label byte offsets with the suffix `_offset`, and character positions as `_pos`. - For example, `string.sub` should never use a `_pos` to substring, only an - `_offset`. + For example, `string.sub` should never use a `_pos`, only an `_offset`. * Some ADT/interface support would be helpful in keeping per-line state in sync. Any change to line data should clear line `fragments` and diff --git a/source_text.lua b/source_text.lua index e00a3fe..30f4bd4 100644 --- a/source_text.lua +++ b/source_text.lua @@ -55,7 +55,9 @@ function Text.draw(State, line_index, y, startpos, hide_cursor) if not hide_cursor and line_index == State.cursor1.line then if pos <= State.cursor1.pos and pos + frag_len >= State.cursor1.pos then if State.search_term then - if State.lines[State.cursor1.line].data:sub(State.cursor1.pos, State.cursor1.pos+utf8.len(State.search_term)-1) == State.search_term then + local data = State.lines[State.cursor1.line].data + local cursor_offset = Text.offset(data, State.cursor1.pos) + if data:sub(cursor_offset, cursor_offset+#State.search_term-1) == State.search_term then local lo_px = Text.draw_highlight(State, line, State.left,y, pos, State.cursor1.pos, State.cursor1.pos+utf8.len(State.search_term)) App.color(Text_color) love.graphics.print(State.search_term, State.left+lo_px,y) diff --git a/text.lua b/text.lua index 9abc6fe..89a673a 100644 --- a/text.lua +++ b/text.lua @@ -33,7 +33,9 @@ function Text.draw(State, line_index, y, startpos) if line_index == State.cursor1.line then if pos <= State.cursor1.pos and pos + frag_len >= State.cursor1.pos then if State.search_term then - if State.lines[State.cursor1.line].data:sub(State.cursor1.pos, State.cursor1.pos+utf8.len(State.search_term)-1) == State.search_term then + local data = State.lines[State.cursor1.line].data + local cursor_offset = Text.offset(data, State.cursor1.pos) + if data:sub(cursor_offset, cursor_offset+#State.search_term-1) == State.search_term then local lo_px = Text.draw_highlight(State, line, State.left,y, pos, State.cursor1.pos, State.cursor1.pos+utf8.len(State.search_term)) App.color(Text_color) love.graphics.print(State.search_term, State.left+lo_px,y) |