From: Junio C Hamano <gitster@pobox.com>
To: Jeff King <peff@peff.net>
Cc: George Brown <321.george@gmail.com>, git@vger.kernel.org
Subject: Re: [PATCH] contrib/git-jump: cat output when not a terminal
Date: Mon, 11 May 2020 08:36:05 -0700 [thread overview]
Message-ID: <xmqqr1vqscuy.fsf@gitster.c.googlers.com> (raw)
In-Reply-To: <20200511143157.GA1415@coredump.intra.peff.net> (Jeff King's message of "Mon, 11 May 2020 10:31:57 -0400")
Jeff King <peff@peff.net> writes:
> - I'm pretty sure git-jump does _not_ work with emacs or emacsclient.
;-) Its output can be used in M-x find-grep, though, actually.
> However, it should work with gvim, and any isatty() check would
> potentially cause issues there. So I'd much prefer the caller say
> explicitly that they're not expecting the editor to start.
Yes, that is exactly what I was worried about.
> So I'm OK to leave the status quo and let people use the GIT_EDITOR
> solution in this instance. But I'd also be happy to take a patch for
> "--no-editor" or similar if somebody wants to work it up.
I actually would support --no-editor. One thing nobody noticed so
far is that "git-jump" is only compatible with editors that support
the "-q" option from the command line, and "cat" is not among them.
Another thing I was thinking about was a change like the attached.
Plugging it thru "git var" to allow "git var GIT_JUMP_EDITOR" may
allow vim users to set it to 'cat' while setting GIT_EDITOR to vim.
It still needs a fix to get rid of the uncondtional "-q" option from
open_editor() function, though.
cache.h | 2 +-
editor.c | 33 ++++++++++++++++++++++-----------
2 files changed, 23 insertions(+), 12 deletions(-)
diff --git a/cache.h b/cache.h
index 0f0485ecfe..b3f7a6d6c4 100644
--- a/cache.h
+++ b/cache.h
@@ -1649,7 +1649,7 @@ const char *fmt_ident(const char *name, const char *email,
const char *fmt_name(enum want_ident);
const char *ident_default_name(void);
const char *ident_default_email(void);
-const char *git_editor(void);
+const char *git_editor(const char *);
const char *git_sequence_editor(void);
const char *git_pager(int stdout_is_tty);
int is_terminal_dumb(void);
diff --git a/editor.c b/editor.c
index 91989ee8a1..3d04824e9e 100644
--- a/editor.c
+++ b/editor.c
@@ -14,11 +14,29 @@ int is_terminal_dumb(void)
return !terminal || !strcmp(terminal, "dumb");
}
-const char *git_editor(void)
+const char *git_editor(const char *program)
{
- const char *editor = getenv("GIT_EDITOR");
+ const char *editor = NULL;
int terminal_is_dumb = is_terminal_dumb();
+ if (program) {
+ char *varname;
+
+ varname = xstrfmt("GIT_%s_EDITOR", program);
+ editor = getenv(varname);
+ free(varname);
+
+ if (!editor) {
+ struct strbuf progname = STRBUF_INIT;
+ strbuf_addstr(&progname, program);
+ strbuf_tolower(&progname);
+ varname = xstrfmt("%s.editor", progname.buf);
+ git_config_get_string_const(varname, &editor);
+ free(varname);
+ strbuf_release(&progname);
+ }
+ }
+
if (!editor && editor_program)
editor = editor_program;
if (!editor && !terminal_is_dumb)
@@ -37,14 +55,7 @@ const char *git_editor(void)
const char *git_sequence_editor(void)
{
- const char *editor = getenv("GIT_SEQUENCE_EDITOR");
-
- if (!editor)
- git_config_get_string_const("sequence.editor", &editor);
- if (!editor)
- editor = git_editor();
-
- return editor;
+ return git_editor("SEQUENCE");
}
static int launch_specified_editor(const char *editor, const char *path,
@@ -118,7 +129,7 @@ static int launch_specified_editor(const char *editor, const char *path,
int launch_editor(const char *path, struct strbuf *buffer, const char *const *env)
{
- return launch_specified_editor(git_editor(), path, buffer, env);
+ return launch_specified_editor(git_editor(NULL), path, buffer, env);
}
int launch_sequence_editor(const char *path, struct strbuf *buffer,
next prev parent reply other threads:[~2020-05-11 15:36 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-05-09 19:15 [PATCH] contrib/git-jump: cat output when not a terminal George Brown
2020-05-09 21:41 ` Junio C Hamano
2020-05-09 22:04 ` George Brown
2020-05-09 23:42 ` Junio C Hamano
2020-05-10 9:03 ` George Brown
2020-05-10 16:47 ` Junio C Hamano
2020-05-10 17:33 ` George Brown
2020-05-10 18:12 ` Junio C Hamano
2020-05-10 18:34 ` George Brown
2020-05-10 19:10 ` Junio C Hamano
2020-05-10 19:25 ` George Brown
2020-05-10 19:38 ` Junio C Hamano
2020-05-10 20:20 ` George Brown
2020-05-11 14:31 ` Junio C Hamano
2020-05-11 14:31 ` Jeff King
2020-05-11 15:36 ` Junio C Hamano [this message]
2020-05-11 15:42 ` Jeff King
2020-05-11 16:46 ` Re* " Junio C Hamano
2020-05-12 19:23 ` Jeff King
2020-05-12 21:30 ` Junio C Hamano
2020-05-13 4:52 ` Jeff King
-- strict thread matches above, loose matches on Subject: below --
2020-05-10 20:26 Benjamin
2020-05-11 14:33 ` Junio C Hamano
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=xmqqr1vqscuy.fsf@gitster.c.googlers.com \
--to=gitster@pobox.com \
--cc=321.george@gmail.com \
--cc=git@vger.kernel.org \
--cc=peff@peff.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).