quality of life improvements

This commit is contained in:
2025-11-25 15:46:47 -08:00
parent feb6667a24
commit 78d522ba98
2 changed files with 34 additions and 8 deletions

5
ke.1
View File

@@ -22,6 +22,7 @@ grandeur. Many commands work with and without control; for example,
saving a file can be done with either C-k s or C-k C-s. Other commands work saving a file can be done with either C-k s or C-k C-s. Other commands work
with ESC or CTRL. with ESC or CTRL.
.Sh K-COMMANDS .Sh K-COMMANDS
k-command mode can be exited with ESC or C-g.
.Bl -tag -width xxxxxxxxxxxx -offset indent .Bl -tag -width xxxxxxxxxxxx -offset indent
.It C-k BACKSPACE .It C-k BACKSPACE
Delete from the cursor to the beginning of the line. Delete from the cursor to the beginning of the line.
@@ -36,7 +37,7 @@ Edit a new file. Also C-k C-e.
.It C-k f .It C-k f
Incremental find. Incremental find.
.It C-k g .It C-k g
Go to a specific line. Also C-k C-g. Go to a specific line.
.It C-k l .It C-k l
List the number of lines of code in a saved file. List the number of lines of code in a saved file.
.It C-k m .It C-k m
@@ -54,6 +55,8 @@ Dump core.
.El .El
.Sh OTHER KEYBINDINGS .Sh OTHER KEYBINDINGS
.Bl -tag -width xxxxxxxxxxxx -offset indent .Bl -tag -width xxxxxxxxxxxx -offset indent
.It C-g
In general, C-g cancels an operation.
.It C-l .It C-l
Refresh the display. Refresh the display.
.It C-s .It C-s

37
main.c
View File

@@ -161,6 +161,7 @@ void delete_region(void);
void kwrite(int fd, const char *buf, int len); void kwrite(int fd, const char *buf, int len);
void die(const char *s); void die(const char *s);
int get_winsz(int *rows, int *cols); int get_winsz(int *rows, int *cols);
void jump_to_position(int col, int row);
void goto_line(void); void goto_line(void);
int cursor_at_eol(void); int cursor_at_eol(void);
void delete_row(int at); void delete_row(int at);
@@ -857,8 +858,7 @@ delete_region(void)
swap_int(&cury, &marky); swap_int(&cury, &marky);
} }
editor.curx = markx; jump_to_position(markx, marky);
editor.cury = marky;
while (killed < count) { while (killed < count) {
move_cursor(ARROW_RIGHT); move_cursor(ARROW_RIGHT);
@@ -866,6 +866,10 @@ delete_region(void)
killed++; killed++;
} }
while (editor.curx != markx && editor.cury != marky) {
deletech(KILLRING_NO_OP);
}
editor.kill = 1; editor.kill = 1;
editor_set_status("Region killed."); editor_set_status("Region killed.");
} }
@@ -920,6 +924,15 @@ get_winsz(int *rows, int *cols)
} }
void
jump_to_position(const int x, const int y)
{
editor.curx = x;
editor.cury = y;
editor.rowoffs = editor.cury - (editor.rows / 2);
}
void void
goto_line(void) goto_line(void)
{ {
@@ -938,8 +951,7 @@ goto_line(void)
return; return;
} }
editor.cury = lineno - 1; jump_to_position(0, lineno - 1);
editor.rowoffs = editor.cury - (editor.rows / 2);
free(query); free(query);
} }
@@ -1560,7 +1572,7 @@ editor_find_callback(char *query, int16_t c)
char *match; char *match;
struct erow *row; struct erow *row;
if (c == '\r' || c == ESC_KEY) { if (c == '\r' || c == ESC_KEY || c == CTRL_KEY('g')) {
/* reset search */ /* reset search */
lmatch = -1; lmatch = -1;
dir = 1; dir = 1;
@@ -1929,7 +1941,6 @@ process_kcommand(int16_t c)
break; break;
case 'g': case 'g':
case CTRL_KEY('g'):
goto_line(); goto_line();
break; break;
case BACKSPACE: case BACKSPACE:
@@ -1975,13 +1986,20 @@ process_kcommand(int16_t c)
case 'y': case 'y':
killring_yank(); killring_yank();
break; break;
case ESC_KEY:
case CTRL_KEY('g'):
break;
default: default:
if (isprint(c)) {
editor_set_status("unknown kcommand '%c'", c);
break;
}
editor_set_status("unknown kcommand: %04x", c); editor_set_status("unknown kcommand: %04x", c);
return; return;
} }
editor.dirtyex = 1; editor.dirtyex = 1;
return;
} }
@@ -2013,6 +2031,8 @@ process_normal(int16_t c)
deletech(KILLRING_PREPEND); deletech(KILLRING_PREPEND);
} }
break; break;
case CTRL_KEY('g'):
break;
case CTRL_KEY('l'): case CTRL_KEY('l'):
display_refresh(); display_refresh();
break; break;
@@ -2084,6 +2104,9 @@ process_escape(int16_t c)
case BACKSPACE: case BACKSPACE:
delete_prev_word(); delete_prev_word();
break; break;
case ESC_KEY:
case CTRL_KEY('g'):
break; /* escape out of escape-mode */
default: default:
editor_set_status("unknown ESC key: %04x", c); editor_set_status("unknown ESC key: %04x", c);
} }