diff options
| author | Marc André Tanner <mat@brain-dump.org> | 2014-09-30 16:26:55 +0200 |
|---|---|---|
| committer | Marc André Tanner <mat@brain-dump.org> | 2014-09-30 16:26:55 +0200 |
| commit | a9c2a093fceec3a09eaffe29db157802af47dc59 (patch) | |
| tree | 6854a4a70a0d09e37eb55e3c73fc869ffc56261b | |
| parent | fb80e02464b06e81c2c7e68cd3323fa56c4b9a6d (diff) | |
| download | vis-a9c2a093fceec3a09eaffe29db157802af47dc59.tar.gz vis-a9c2a093fceec3a09eaffe29db157802af47dc59.tar.xz | |
Allow to supend the editor via CTRL-Z
| -rw-r--r-- | config.def.h | 1 | ||||
| -rw-r--r-- | vis.c | 8 |
2 files changed, 9 insertions, 0 deletions
diff --git a/config.def.h b/config.def.h index ab44ddd..cc2a076 100644 --- a/config.def.h +++ b/config.def.h @@ -93,6 +93,7 @@ static bool vis_keypress(Key *key) { } static KeyBinding basic_movement[] = { + { { CONTROL('Z') }, suspend, { NULL } }, { { KEY(LEFT) }, movement, { .i = MOVE_CHAR_PREV } }, { { KEY(SLEFT) }, movement, { .i = MOVE_LONGWORD_START_PREV } }, { { KEY(RIGHT) }, movement, { .i = MOVE_CHAR_NEXT } }, @@ -372,6 +372,8 @@ static TextObject *moves_linewise[] = { }; /** functions to be called from keybindings */ +/* temporarily suspend the editor and return to the shell, type 'fg' to get back */ +static void suspend(const Arg *arg); /* switch to mode indicated by arg->i */ static void switchmode(const Arg *arg); /* set mark indicated by arg->i to current cursor position */ @@ -768,6 +770,11 @@ static size_t window_lines_bottom(const Arg *arg) { /** key bindings functions of type: void (*func)(const Arg*) */ +static void suspend(const Arg *arg) { + endwin(); + raise(SIGSTOP); +} + static void repeat(const Arg *arg) { action = action_prev; action_do(&action); @@ -1512,6 +1519,7 @@ static void setup() { sigemptyset(&sa.sa_mask); sa.sa_handler = sigwinch_handler; sigaction(SIGWINCH, &sa, NULL); + sigaction(SIGCONT, &sa, NULL); } static bool keymatch(Key *key0, Key *key1) { |
