This patch removes exit()/die() calls and builtin-specific messages from launch_editor(), so that it can be used as a general libgit.a function to launch an editor. Signed-off-by: Stephan Beyer <s-beyer@xxxxxxx> --- Hi, Johannes Schindelin wrote: > On Fri, 18 Jul 2008, Stephan Beyer wrote: > > > This patch removes exit()/die() calls and builtin-specific messages from > > launch_editor(), so that it can be used as a general libgit.a function > > to launch an editor. > > Thanks. Now we have to convince Junio that it is a good idea :-) > > > diff --git a/builtin-commit.c b/builtin-commit.c > > index ed3fe3f..64f69f3 100644 > > --- a/builtin-commit.c > > +++ b/builtin-commit.c > > @@ -647,7 +647,9 @@ static int prepare_to_commit(const char *index_file, const char *prefix) > > char index[PATH_MAX]; > > const char *env[2] = { index, NULL }; > > snprintf(index, sizeof(index), "GIT_INDEX_FILE=%s", index_file); > > - launch_editor(git_path(commit_editmsg), NULL, env); > > + if (launch_editor(git_path(commit_editmsg), NULL, env)) > > + die("running editor failed.\n" > > + "Please supply the message using either -m or -F option."); > > In the error case, run_editor() already said more than "running editor > failed.", right? Maybe you just want to skip that line and keep the > second? Well, I wanted to do it like that, but die_builtin() usually adds "fatal: ", so the message becomes like: error: There was a problem with the editor xxx. fatal: Please supply the message using either -m or -F option. ^^^^^^^^^^^^^ That looks odd. Btw, using the former patch, it is: error: There was a problem with the editor xxx. fatal: running editor failed. Please supply the message using either -m or -F option. So I wonder if I should not die() at all, but do a fprintf(stderr, "Please supply the message using either -m or -F option.\n"); exit(1); which is done in *this* version of the patch. So that the message becomes: error: There was a problem with the editor 'xxx'. Please supply the message using either -m or -F option. > > diff --git a/editor.c b/editor.c > > index 483b62d..5d7f5f9 100644 > > --- a/editor.c > > +++ b/editor.c > > @@ -17,9 +17,8 @@ void launch_editor(const char *path, struct strbuf *buffer, const char *const *e > > terminal = getenv("TERM"); > > if (!editor && (!terminal || !strcmp(terminal, "dumb"))) { > > fprintf(stderr, > > - "Terminal is dumb but no VISUAL nor EDITOR defined.\n" > > - "Please supply the message using either -m or -F option.\n"); > > - exit(1); > > + "Terminal is dumb but no VISUAL nor EDITOR defined.\n"); > > + return 1; > > Why not "return error()"? I was unsure here, too, but you're right. Regards. builtin-commit.c | 6 +++++- builtin-tag.c | 6 +++++- editor.c | 24 ++++++++++++------------ foo | 1 + strbuf.h | 2 +- 5 files changed, 24 insertions(+), 15 deletions(-) create mode 100644 foo diff --git a/builtin-commit.c b/builtin-commit.c index ed3fe3f..23ec629 100644 --- a/builtin-commit.c +++ b/builtin-commit.c @@ -647,7 +647,11 @@ static int prepare_to_commit(const char *index_file, const char *prefix) char index[PATH_MAX]; const char *env[2] = { index, NULL }; snprintf(index, sizeof(index), "GIT_INDEX_FILE=%s", index_file); - launch_editor(git_path(commit_editmsg), NULL, env); + if (launch_editor(git_path(commit_editmsg), NULL, env)) { + fprintf(stderr, + "Please supply the message using either -m or -F option.\n"); + exit(1); + } } if (!no_verify && diff --git a/builtin-tag.c b/builtin-tag.c index 219f51d..325b1b2 100644 --- a/builtin-tag.c +++ b/builtin-tag.c @@ -295,7 +295,11 @@ static void create_tag(const unsigned char *object, const char *tag, write_or_die(fd, tag_template, strlen(tag_template)); close(fd); - launch_editor(path, buf, NULL); + if (launch_editor(path, buf, NULL)) { + fprintf(stderr, + "Please supply the message using either -m or -F option.\n"); + exit(1); + } unlink(path); free(path); diff --git a/editor.c b/editor.c index 483b62d..eebc3e9 100644 --- a/editor.c +++ b/editor.c @@ -2,7 +2,7 @@ #include "strbuf.h" #include "run-command.h" -void launch_editor(const char *path, struct strbuf *buffer, const char *const *env) +int launch_editor(const char *path, struct strbuf *buffer, const char *const *env) { const char *editor, *terminal; @@ -15,12 +15,8 @@ void launch_editor(const char *path, struct strbuf *buffer, const char *const *e editor = getenv("EDITOR"); terminal = getenv("TERM"); - if (!editor && (!terminal || !strcmp(terminal, "dumb"))) { - fprintf(stderr, - "Terminal is dumb but no VISUAL nor EDITOR defined.\n" - "Please supply the message using either -m or -F option.\n"); - exit(1); - } + if (!editor && (!terminal || !strcmp(terminal, "dumb"))) + return error("Terminal is dumb but no VISUAL nor EDITOR defined."); if (!editor) editor = "vi"; @@ -28,6 +24,7 @@ void launch_editor(const char *path, struct strbuf *buffer, const char *const *e if (strcmp(editor, ":")) { size_t len = strlen(editor); int i = 0; + int failed; const char *args[6]; struct strbuf arg0; @@ -43,14 +40,17 @@ void launch_editor(const char *path, struct strbuf *buffer, const char *const *e args[i++] = path; args[i] = NULL; - if (run_command_v_opt_cd_env(args, 0, NULL, env)) - die("There was a problem with the editor %s.", editor); + failed = run_command_v_opt_cd_env(args, 0, NULL, env); strbuf_release(&arg0); + if (failed) + return error("There was a problem with the editor '%s'.", + editor); } if (!buffer) - return; + return 0; if (strbuf_read_file(buffer, path, 0) < 0) - die("could not read message file '%s': %s", - path, strerror(errno)); + return error("could not read file '%s': %s", + path, strerror(errno)); + return 0; } diff --git a/foo b/foo new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/foo @@ -0,0 +1 @@ + diff --git a/strbuf.h b/strbuf.h index 0c6ffad..eba7ba4 100644 --- a/strbuf.h +++ b/strbuf.h @@ -123,6 +123,6 @@ extern int strbuf_read_file(struct strbuf *sb, const char *path, size_t hint); extern int strbuf_getline(struct strbuf *, FILE *, int); extern void stripspace(struct strbuf *buf, int skip_comments); -extern void launch_editor(const char *path, struct strbuf *buffer, const char *const *env); +extern int launch_editor(const char *path, struct strbuf *buffer, const char *const *env); #endif /* STRBUF_H */ -- 1.5.6.3.390.g7b30 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html