diff options
author | Junio C Hamano <gitster@pobox.com> | 2009-01-28 23:56:13 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-01-28 23:56:13 -0800 |
commit | a9ed6ce0e7057b94809d3c51094ba96fe96fded8 (patch) | |
tree | 71e9dce5864dd1a885b8853903b6d9ae2219f91a /builtin-log.c | |
parent | 9530eb1db874a6eb1278aa904406d379c601856e (diff) | |
parent | 9800a754f931d05c2d26da9c1b188ae2c2b80eb4 (diff) | |
download | git-a9ed6ce0e7057b94809d3c51094ba96fe96fded8.tar.gz git-a9ed6ce0e7057b94809d3c51094ba96fe96fded8.tar.xz |
Merge branch 'jc/maint-format-patch-o-relative' into maint
* jc/maint-format-patch-o-relative:
Teach format-patch to handle output directory relative to cwd
Conflicts:
t/t4014-format-patch.sh
Diffstat (limited to 'builtin-log.c')
-rw-r--r-- | builtin-log.c | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/builtin-log.c b/builtin-log.c index 4420b4fd4..60f8dd860 100644 --- a/builtin-log.c +++ b/builtin-log.c @@ -553,6 +553,7 @@ static const char *get_oneline_for_filename(struct commit *commit, static FILE *realstdout = NULL; static const char *output_directory = NULL; +static int outdir_offset; static int reopen_stdout(const char *oneline, int nr, int total) { @@ -579,7 +580,7 @@ static int reopen_stdout(const char *oneline, int nr, int total) strcpy(filename + len, fmt_patch_suffix); } - fprintf(realstdout, "%s\n", filename); + fprintf(realstdout, "%s\n", filename + outdir_offset); if (freopen(filename, "w", stdout) == NULL) return error("Cannot open patch file %s",filename); @@ -740,6 +741,27 @@ static const char *clean_message_id(const char *msg_id) return xmemdupz(a, z - a); } +static const char *set_outdir(const char *prefix, const char *output_directory) +{ + if (output_directory && is_absolute_path(output_directory)) + return output_directory; + + if (!prefix || !*prefix) { + if (output_directory) + return output_directory; + /* The user did not explicitly ask for "./" */ + outdir_offset = 2; + return "./"; + } + + outdir_offset = strlen(prefix); + if (!output_directory) + return prefix; + + return xstrdup(prefix_filename(prefix, outdir_offset, + output_directory)); +} + int cmd_format_patch(int argc, const char **argv, const char *prefix) { struct commit *commit; @@ -917,8 +939,8 @@ int cmd_format_patch(int argc, const char **argv, const char *prefix) if (!DIFF_OPT_TST(&rev.diffopt, TEXT) && !no_binary_diff) DIFF_OPT_SET(&rev.diffopt, BINARY); - if (!output_directory && !use_stdout) - output_directory = prefix; + if (!use_stdout) + output_directory = set_outdir(prefix, output_directory); if (output_directory) { if (use_stdout) |