diff options
Diffstat (limited to 'builtin/commit.c')
| -rw-r--r-- | builtin/commit.c | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/builtin/commit.c b/builtin/commit.c index dca09e2c3b..89bf6ad38a 100644 --- a/builtin/commit.c +++ b/builtin/commit.c @@ -32,6 +32,7 @@  #include "sequencer.h"  #include "notes-utils.h"  #include "mailmap.h" +#include "sigchain.h"  static const char * const builtin_commit_usage[] = {  	N_("git commit [<options>] [--] <pathspec>..."), @@ -299,7 +300,7 @@ static void create_base_index(const struct commit *current_head)  	opts.dst_index = &the_index;  	opts.fn = oneway_merge; -	tree = parse_tree_indirect(current_head->object.sha1); +	tree = parse_tree_indirect(current_head->object.oid.hash);  	if (!tree)  		die(_("failed to unpack HEAD tree object"));  	parse_tree(tree); @@ -760,7 +761,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix,  		hook_arg2 = "";  	} -	s->fp = fopen(git_path(commit_editmsg), "w"); +	s->fp = fopen_for_writing(git_path(commit_editmsg));  	if (s->fp == NULL)  		die_errno(_("could not open '%s'"), git_path(commit_editmsg)); @@ -1537,8 +1538,10 @@ static int run_rewrite_hook(const unsigned char *oldsha1,  		return code;  	n = snprintf(buf, sizeof(buf), "%s %s\n",  		     sha1_to_hex(oldsha1), sha1_to_hex(newsha1)); +	sigchain_push(SIGPIPE, SIG_IGN);  	write_in_full(proc.in, buf, n);  	close(proc.in); +	sigchain_pop(SIGPIPE);  	return finish_command(&proc);  } @@ -1766,7 +1769,7 @@ int cmd_commit(int argc, const char **argv, const char *prefix)  	if (!transaction ||  	    ref_transaction_update(transaction, "HEAD", sha1,  				   current_head -				   ? current_head->object.sha1 : null_sha1, +				   ? current_head->object.oid.hash : null_sha1,  				   0, sb.buf, &err) ||  	    ref_transaction_commit(transaction, &err)) {  		rollback_index_files(); @@ -1793,10 +1796,10 @@ int cmd_commit(int argc, const char **argv, const char *prefix)  		cfg = init_copy_notes_for_rewrite("amend");  		if (cfg) {  			/* we are amending, so current_head is not NULL */ -			copy_note_for_rewrite(cfg, current_head->object.sha1, sha1); +			copy_note_for_rewrite(cfg, current_head->object.oid.hash, sha1);  			finish_copy_notes_for_rewrite(cfg, "Notes added by 'git commit --amend'");  		} -		run_rewrite_hook(current_head->object.sha1, sha1); +		run_rewrite_hook(current_head->object.oid.hash, sha1);  	}  	if (!quiet)  		print_summary(prefix, sha1, !current_head); | 
