diff options
author | Junio C Hamano <gitster@pobox.com> | 2021-10-19 00:47:57 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2021-10-19 00:47:57 +0200 |
commit | 853ec9aa9be1b467986dd86ffc36c1c8580a6789 (patch) | |
tree | 1c24566cefb68c6becf674e5955698be29bfeb9a /editor.c | |
parent | Merge branch 'ab/designated-initializers-more' (diff) | |
parent | editor: save and reset terminal after calling EDITOR (diff) | |
download | git-853ec9aa9be1b467986dd86ffc36c1c8580a6789.tar.xz git-853ec9aa9be1b467986dd86ffc36c1c8580a6789.zip |
Merge branch 'cm/save-restore-terminal'
An editor session launched during a Git operation (e.g. during 'git
commit') can leave the terminal in a funny state. The code path
has updated to save the terminal state before, and restore it
after, it spawns an editor.
* cm/save-restore-terminal:
editor: save and reset terminal after calling EDITOR
terminal: teach git how to save/restore its terminal settings
Diffstat (limited to 'editor.c')
-rw-r--r-- | editor.c | 8 |
1 files changed, 8 insertions, 0 deletions
@@ -3,6 +3,7 @@ #include "strbuf.h" #include "run-command.h" #include "sigchain.h" +#include "compat/terminal.h" #ifndef DEFAULT_EDITOR #define DEFAULT_EDITOR "vi" @@ -50,6 +51,8 @@ const char *git_sequence_editor(void) static int launch_specified_editor(const char *editor, const char *path, struct strbuf *buffer, const char *const *env) { + int term_fail; + if (!editor) return error("Terminal is dumb, but EDITOR unset"); @@ -83,7 +86,10 @@ static int launch_specified_editor(const char *editor, const char *path, p.env = env; p.use_shell = 1; p.trace2_child_class = "editor"; + term_fail = save_term(1); if (start_command(&p) < 0) { + if (!term_fail) + restore_term(); strbuf_release(&realpath); return error("unable to start editor '%s'", editor); } @@ -91,6 +97,8 @@ static int launch_specified_editor(const char *editor, const char *path, sigchain_push(SIGINT, SIG_IGN); sigchain_push(SIGQUIT, SIG_IGN); ret = finish_command(&p); + if (!term_fail) + restore_term(); strbuf_release(&realpath); sig = ret - 128; sigchain_pop(SIGINT); |