提交 b66ae795 编写于 作者: J Junio C Hamano

Merge branch 'sb/committer'

* sb/committer:
  commit: Show committer if automatic
  commit: Show author if different from committer
  Preparation to call determine_author_info from prepare_to_commit
...@@ -47,6 +47,7 @@ static enum { ...@@ -47,6 +47,7 @@ static enum {
static char *logfile, *force_author, *template_file; static char *logfile, *force_author, *template_file;
static char *edit_message, *use_message; static char *edit_message, *use_message;
static char *author_name, *author_email, *author_date;
static int all, edit_flag, also, interactive, only, amend, signoff; static int all, edit_flag, also, interactive, only, amend, signoff;
static int quiet, verbose, untracked_files, no_verify, allow_empty; static int quiet, verbose, untracked_files, no_verify, allow_empty;
/* /*
...@@ -397,6 +398,47 @@ static int is_a_merge(const unsigned char *sha1) ...@@ -397,6 +398,47 @@ static int is_a_merge(const unsigned char *sha1)
static const char sign_off_header[] = "Signed-off-by: "; static const char sign_off_header[] = "Signed-off-by: ";
static void determine_author_info(void)
{
char *name, *email, *date;
name = getenv("GIT_AUTHOR_NAME");
email = getenv("GIT_AUTHOR_EMAIL");
date = getenv("GIT_AUTHOR_DATE");
if (use_message) {
const char *a, *lb, *rb, *eol;
a = strstr(use_message_buffer, "\nauthor ");
if (!a)
die("invalid commit: %s", use_message);
lb = strstr(a + 8, " <");
rb = strstr(a + 8, "> ");
eol = strchr(a + 8, '\n');
if (!lb || !rb || !eol)
die("invalid commit: %s", use_message);
name = xstrndup(a + 8, lb - (a + 8));
email = xstrndup(lb + 2, rb - (lb + 2));
date = xstrndup(rb + 2, eol - (rb + 2));
}
if (force_author) {
const char *lb = strstr(force_author, " <");
const char *rb = strchr(force_author, '>');
if (!lb || !rb)
die("malformed --author parameter");
name = xstrndup(force_author, lb - force_author);
email = xstrndup(lb + 2, rb - (lb + 2));
}
author_name = name;
author_email = email;
author_date = date;
}
static int prepare_to_commit(const char *index_file, const char *prefix) static int prepare_to_commit(const char *index_file, const char *prefix)
{ {
struct stat statbuf; struct stat statbuf;
...@@ -406,6 +448,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix) ...@@ -406,6 +448,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix)
FILE *fp; FILE *fp;
const char *hook_arg1 = NULL; const char *hook_arg1 = NULL;
const char *hook_arg2 = NULL; const char *hook_arg2 = NULL;
int ident_shown = 0;
if (!no_verify && run_hook(index_file, "pre-commit", NULL)) if (!no_verify && run_hook(index_file, "pre-commit", NULL))
return 0; return 0;
...@@ -485,7 +528,14 @@ static int prepare_to_commit(const char *index_file, const char *prefix) ...@@ -485,7 +528,14 @@ static int prepare_to_commit(const char *index_file, const char *prefix)
strbuf_release(&sb); strbuf_release(&sb);
determine_author_info();
/* This checks if committer ident is explicitly given */
git_committer_info(0);
if (use_editor) { if (use_editor) {
char *author_ident;
const char *committer_ident;
if (in_merge) if (in_merge)
fprintf(fp, fprintf(fp,
"#\n" "#\n"
...@@ -508,6 +558,27 @@ static int prepare_to_commit(const char *index_file, const char *prefix) ...@@ -508,6 +558,27 @@ static int prepare_to_commit(const char *index_file, const char *prefix)
if (only_include_assumed) if (only_include_assumed)
fprintf(fp, "# %s\n", only_include_assumed); fprintf(fp, "# %s\n", only_include_assumed);
author_ident = xstrdup(fmt_name(author_name, author_email));
committer_ident = fmt_name(getenv("GIT_COMMITTER_NAME"),
getenv("GIT_COMMITTER_EMAIL"));
if (strcmp(author_ident, committer_ident))
fprintf(fp,
"%s"
"# Author: %s\n",
ident_shown++ ? "" : "#\n",
author_ident);
free(author_ident);
if (!user_ident_explicitly_given)
fprintf(fp,
"%s"
"# Committer: %s\n",
ident_shown++ ? "" : "#\n",
committer_ident);
if (ident_shown)
fprintf(fp, "#\n");
saved_color_setting = wt_status_use_color; saved_color_setting = wt_status_use_color;
wt_status_use_color = 0; wt_status_use_color = 0;
commitable = run_status(fp, index_file, prefix, 1); commitable = run_status(fp, index_file, prefix, 1);
...@@ -624,45 +695,6 @@ static int message_is_empty(struct strbuf *sb, int start) ...@@ -624,45 +695,6 @@ static int message_is_empty(struct strbuf *sb, int start)
return 1; return 1;
} }
static void determine_author_info(struct strbuf *sb)
{
char *name, *email, *date;
name = getenv("GIT_AUTHOR_NAME");
email = getenv("GIT_AUTHOR_EMAIL");
date = getenv("GIT_AUTHOR_DATE");
if (use_message) {
const char *a, *lb, *rb, *eol;
a = strstr(use_message_buffer, "\nauthor ");
if (!a)
die("invalid commit: %s", use_message);
lb = strstr(a + 8, " <");
rb = strstr(a + 8, "> ");
eol = strchr(a + 8, '\n');
if (!lb || !rb || !eol)
die("invalid commit: %s", use_message);
name = xstrndup(a + 8, lb - (a + 8));
email = xstrndup(lb + 2, rb - (lb + 2));
date = xstrndup(rb + 2, eol - (rb + 2));
}
if (force_author) {
const char *lb = strstr(force_author, " <");
const char *rb = strchr(force_author, '>');
if (!lb || !rb)
die("malformed --author parameter");
name = xstrndup(force_author, lb - force_author);
email = xstrndup(lb + 2, rb - (lb + 2));
}
strbuf_addf(sb, "author %s\n", fmt_ident(name, email, date, IDENT_ERROR_ON_NO_NAME));
}
static int parse_and_validate_options(int argc, const char *argv[], static int parse_and_validate_options(int argc, const char *argv[],
const char * const usage[]) const char * const usage[])
{ {
...@@ -922,7 +954,8 @@ int cmd_commit(int argc, const char **argv, const char *prefix) ...@@ -922,7 +954,8 @@ int cmd_commit(int argc, const char **argv, const char *prefix)
strbuf_addf(&sb, "parent %s\n", sha1_to_hex(head_sha1)); strbuf_addf(&sb, "parent %s\n", sha1_to_hex(head_sha1));
} }
determine_author_info(&sb); strbuf_addf(&sb, "author %s\n",
fmt_ident(author_name, author_email, author_date, IDENT_ERROR_ON_NO_NAME));
strbuf_addf(&sb, "committer %s\n", git_committer_info(IDENT_ERROR_ON_NO_NAME)); strbuf_addf(&sb, "committer %s\n", git_committer_info(IDENT_ERROR_ON_NO_NAME));
if (!is_encoding_utf8(git_commit_encoding)) if (!is_encoding_utf8(git_commit_encoding))
strbuf_addf(&sb, "encoding %s\n", git_commit_encoding); strbuf_addf(&sb, "encoding %s\n", git_commit_encoding);
......
...@@ -735,6 +735,7 @@ extern int config_error_nonbool(const char *); ...@@ -735,6 +735,7 @@ extern int config_error_nonbool(const char *);
#define MAX_GITNAME (1000) #define MAX_GITNAME (1000)
extern char git_default_email[MAX_GITNAME]; extern char git_default_email[MAX_GITNAME];
extern char git_default_name[MAX_GITNAME]; extern char git_default_name[MAX_GITNAME];
extern int user_ident_explicitly_given;
extern const char *git_commit_encoding; extern const char *git_commit_encoding;
extern const char *git_log_output_encoding; extern const char *git_log_output_encoding;
......
...@@ -448,6 +448,8 @@ int git_default_config(const char *var, const char *value) ...@@ -448,6 +448,8 @@ int git_default_config(const char *var, const char *value)
if (!value) if (!value)
return config_error_nonbool(var); return config_error_nonbool(var);
strlcpy(git_default_name, value, sizeof(git_default_name)); strlcpy(git_default_name, value, sizeof(git_default_name));
if (git_default_email[0])
user_ident_explicitly_given = 1;
return 0; return 0;
} }
...@@ -455,6 +457,8 @@ int git_default_config(const char *var, const char *value) ...@@ -455,6 +457,8 @@ int git_default_config(const char *var, const char *value)
if (!value) if (!value)
return config_error_nonbool(var); return config_error_nonbool(var);
strlcpy(git_default_email, value, sizeof(git_default_email)); strlcpy(git_default_email, value, sizeof(git_default_email));
if (git_default_name[0])
user_ident_explicitly_given = 1;
return 0; return 0;
} }
......
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
char git_default_email[MAX_GITNAME]; char git_default_email[MAX_GITNAME];
char git_default_name[MAX_GITNAME]; char git_default_name[MAX_GITNAME];
int user_ident_explicitly_given;
int trust_executable_bit = 1; int trust_executable_bit = 1;
int quote_path_fully = 1; int quote_path_fully = 1;
int has_symlinks = 1; int has_symlinks = 1;
......
...@@ -250,6 +250,9 @@ const char *git_author_info(int flag) ...@@ -250,6 +250,9 @@ const char *git_author_info(int flag)
const char *git_committer_info(int flag) const char *git_committer_info(int flag)
{ {
if (getenv("GIT_COMMITTER_NAME") &&
getenv("GIT_COMMITTER_EMAIL"))
user_ident_explicitly_given = 1;
return fmt_ident(getenv("GIT_COMMITTER_NAME"), return fmt_ident(getenv("GIT_COMMITTER_NAME"),
getenv("GIT_COMMITTER_EMAIL"), getenv("GIT_COMMITTER_EMAIL"),
getenv("GIT_COMMITTER_DATE"), getenv("GIT_COMMITTER_DATE"),
......
...@@ -154,6 +154,33 @@ test_expect_success 'cleanup commit messages (strip,-F,-e)' ' ...@@ -154,6 +154,33 @@ test_expect_success 'cleanup commit messages (strip,-F,-e)' '
' '
echo "#
# Author: $GIT_AUTHOR_NAME <$GIT_AUTHOR_EMAIL>
#" >> expect
test_expect_success 'author different from committer' '
echo >>negative &&
git commit -e -m "sample"
head -n 7 .git/COMMIT_EDITMSG >actual &&
test_cmp expect actual
'
sed -i '$d' expect
echo "# Committer:
#" >> expect
unset GIT_COMMITTER_EMAIL
unset GIT_COMMITTER_NAME
test_expect_success 'committer is automatic' '
echo >>negative &&
git commit -e -m "sample"
head -n 8 .git/COMMIT_EDITMSG | \
sed "s/^# Committer: .*/# Committer:/" >actual &&
test_cmp expect actual
'
pwd=`pwd` pwd=`pwd`
cat >> .git/FAKE_EDITOR << EOF cat >> .git/FAKE_EDITOR << EOF
#! /bin/sh #! /bin/sh
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册