aboutsummaryrefslogtreecommitdiff
path: root/editor.c
diff options
context:
space:
mode:
authorMarc André Tanner <mat@brain-dump.org>2014-08-31 11:07:42 +0200
committerMarc André Tanner <mat@brain-dump.org>2014-08-31 11:07:42 +0200
commitc72fe77e5d3cf4ecb3b691a5fa582d0e96b5ec1e (patch)
tree6b5487c3384e8c35c5b531fffca1f2b2bacc193d /editor.c
parentfbaeffb469d2fd6833a1301255f1ac73c7226a83 (diff)
downloadvis-c72fe77e5d3cf4ecb3b691a5fa582d0e96b5ec1e.tar.gz
vis-c72fe77e5d3cf4ecb3b691a5fa582d0e96b5ec1e.tar.xz
First part of a vi like frontend
Still very incomplete
Diffstat (limited to 'editor.c')
-rw-r--r--editor.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/editor.c b/editor.c
index 78f7916..85b366f 100644
--- a/editor.c
+++ b/editor.c
@@ -972,6 +972,21 @@ size_t editor_cursor_get(Editor *ed) {
return ed->win->cursor.pos;
}
+Text *editor_text_get(Editor *ed) {
+ return ed->win->text;
+}
+
+void editor_scroll_to(Editor *ed, size_t pos) {
+ Win *win = ed->win;
+ while (pos < win->start && scroll_line_up(win, 1));
+ while (pos > win->end && scroll_line_down(win, 1));
+ cursor_move_to(win, pos);
+}
+
+void editor_cursor_to(Editor *ed, size_t pos) {
+ cursor_move_to(ed->win, pos);
+}
+
size_t editor_selection_start(Editor *ed) {
return ed->win->sel.start = editor_cursor_get(ed);
}