diff options
| -rw-r--r-- | man/vis.1 | 6 | ||||
| -rw-r--r-- | sam.c | 4 | ||||
| -rw-r--r-- | vis-cmds.c | 6 |
3 files changed, 8 insertions, 8 deletions
@@ -1206,11 +1206,11 @@ split window horizontally .It Ic :vsplit Op Ar file name split window vertically . -.It Ic :q Ns Op Cm "!" +.It Ic :q Ns Oo Cm "!" Oc Op Ar exit code close currently focused window . -.It Ic :qall Ns Op Cm "!" -close all windows, exit editor +.It Ic :qall Ns Oo Cm "!" Oc Op Ar exit code +close all windows, terminate editor with exit code (defaults to 0) .El .Pp Commands taking a file name will invoke the @@ -209,7 +209,7 @@ static const CommandDef cmds[] = { CMD_ARGV|CMD_FORCE|CMD_ONCE|CMD_ADDRESS_NONE|CMD_DESTRUCTIVE, NULL, cmd_edit }, { "q", VIS_HELP("Quit the current window") - CMD_FORCE|CMD_ONCE|CMD_ADDRESS_NONE|CMD_DESTRUCTIVE, NULL, cmd_quit + CMD_ARGV|CMD_FORCE|CMD_ONCE|CMD_ADDRESS_NONE|CMD_DESTRUCTIVE, NULL, cmd_quit }, { "cd", VIS_HELP("Change directory") CMD_ARGV|CMD_ONCE|CMD_ADDRESS_NONE, NULL, cmd_cd @@ -241,7 +241,7 @@ static const CommandDef cmds[] = { CMD_ARGV|CMD_ONCE|CMD_ADDRESS_NONE, NULL, cmd_open }, { "qall", VIS_HELP("Exit vis") - CMD_FORCE|CMD_ONCE|CMD_ADDRESS_NONE|CMD_DESTRUCTIVE, NULL, cmd_qall + CMD_ARGV|CMD_FORCE|CMD_ONCE|CMD_ADDRESS_NONE|CMD_DESTRUCTIVE, NULL, cmd_qall }, { "set", VIS_HELP("Set option") CMD_ARGV|CMD_ONCE|CMD_ADDRESS_NONE, NULL, cmd_set @@ -506,7 +506,7 @@ static bool cmd_quit(Vis *vis, Win *win, Command *cmd, const char *argv[], Selec } vis_window_close(win); if (!has_windows(vis)) - vis_exit(vis, EXIT_SUCCESS); + vis_exit(vis, argv[1] ? atoi(argv[1]) : EXIT_SUCCESS); return true; } @@ -517,7 +517,7 @@ static bool cmd_qall(Vis *vis, Win *win, Command *cmd, const char *argv[], Selec vis_window_close(win); } if (!has_windows(vis)) { - vis_exit(vis, EXIT_SUCCESS); + vis_exit(vis, argv[1] ? atoi(argv[1]) : EXIT_SUCCESS); return true; } else { info_unsaved_changes(vis); @@ -567,7 +567,7 @@ static bool cmd_wq(Vis *vis, Win *win, Command *cmd, const char *argv[], Selecti File *file = win->file; bool unmodified = file->fd == -1 && !file->name && !text_modified(file->text); if (unmodified || cmd_write(vis, win, cmd, argv, sel, range)) - return cmd_quit(vis, win, cmd, argv, sel, range); + return cmd_quit(vis, win, cmd, (const char*[]){argv[0], NULL}, sel, range); return false; } |
