diff options
| author | Junio C Hamano <gitster@pobox.com> | 2014-09-11 10:33:30 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2014-09-11 10:33:31 -0700 | 
| commit | 01d678a2263c0c71e42475335b5b0b578936a7d1 (patch) | |
| tree | ee12372c4c7069f782902713187139ad5004575c /builtin/commit.c | |
| parent | 5e1dc4885840e45d6290feb209e0f6df1ad5fde6 (diff) | |
| parent | 88499b296b5f62338d7fa4019c7b5f9012b4ab88 (diff) | |
| download | git-01d678a2263c0c71e42475335b5b0b578936a7d1.tar.gz | |
Merge branch 'rs/ref-transaction-1'
The second batch of the transactional ref update series.
* rs/ref-transaction-1: (22 commits)
  update-ref --stdin: pass transaction around explicitly
  update-ref --stdin: narrow scope of err strbuf
  refs.c: make delete_ref use a transaction
  refs.c: make prune_ref use a transaction to delete the ref
  refs.c: remove lock_ref_sha1
  refs.c: remove the update_ref_write function
  refs.c: remove the update_ref_lock function
  refs.c: make lock_ref_sha1 static
  walker.c: use ref transaction for ref updates
  fast-import.c: use a ref transaction when dumping tags
  receive-pack.c: use a reference transaction for updating the refs
  refs.c: change update_ref to use a transaction
  branch.c: use ref transaction for all ref updates
  fast-import.c: change update_branch to use ref transactions
  sequencer.c: use ref transactions for all ref updates
  commit.c: use ref transactions for updates
  replace.c: use the ref transaction functions for updates
  tag.c: use ref transactions when doing updates
  refs.c: add transaction.status and track OPEN/CLOSED
  refs.c: make ref_transaction_begin take an err argument
  ...
Diffstat (limited to 'builtin/commit.c')
| -rw-r--r-- | builtin/commit.c | 25 | 
1 files changed, 12 insertions, 13 deletions
| diff --git a/builtin/commit.c b/builtin/commit.c index ec0048e8b0..5911447486 100644 --- a/builtin/commit.c +++ b/builtin/commit.c @@ -1651,11 +1651,12 @@ int cmd_commit(int argc, const char **argv, const char *prefix)  	const char *index_file, *reflog_msg;  	char *nl;  	unsigned char sha1[20]; -	struct ref_lock *ref_lock;  	struct commit_list *parents = NULL, **pptr = &parents;  	struct stat statbuf;  	struct commit *current_head = NULL;  	struct commit_extra_header *extra = NULL; +	struct ref_transaction *transaction; +	struct strbuf err = STRBUF_INIT;  	if (argc == 2 && !strcmp(argv[1], "-h"))  		usage_with_options(builtin_commit_usage, builtin_commit_options); @@ -1777,16 +1778,6 @@ int cmd_commit(int argc, const char **argv, const char *prefix)  	strbuf_release(&author_ident);  	free_commit_extra_headers(extra); -	ref_lock = lock_any_ref_for_update("HEAD", -					   !current_head -					   ? NULL -					   : current_head->object.sha1, -					   0, NULL); -	if (!ref_lock) { -		rollback_index_files(); -		die(_("cannot lock HEAD ref")); -	} -  	nl = strchr(sb.buf, '\n');  	if (nl)  		strbuf_setlen(&sb, nl + 1 - sb.buf); @@ -1795,10 +1786,17 @@ int cmd_commit(int argc, const char **argv, const char *prefix)  	strbuf_insert(&sb, 0, reflog_msg, strlen(reflog_msg));  	strbuf_insert(&sb, strlen(reflog_msg), ": ", 2); -	if (write_ref_sha1(ref_lock, sha1, sb.buf) < 0) { +	transaction = ref_transaction_begin(&err); +	if (!transaction || +	    ref_transaction_update(transaction, "HEAD", sha1, +				   current_head +				   ? current_head->object.sha1 : NULL, +				   0, !!current_head, &err) || +	    ref_transaction_commit(transaction, sb.buf, &err)) {  		rollback_index_files(); -		die(_("cannot update HEAD ref")); +		die("%s", err.buf);  	} +	ref_transaction_free(transaction);  	unlink(git_path("CHERRY_PICK_HEAD"));  	unlink(git_path("REVERT_HEAD")); @@ -1827,5 +1825,6 @@ int cmd_commit(int argc, const char **argv, const char *prefix)  	if (!quiet)  		print_summary(prefix, sha1, !current_head); +	strbuf_release(&err);  	return 0;  } | 
