Skip to content

Commit

Permalink
refs: document transaction semantics
Browse files Browse the repository at this point in the history
Add some comments on ref transaction semantics to refs.h

Signed-off-by: David Turner <[email protected]>
Signed-off-by: Junio C Hamano <[email protected]>
  • Loading branch information
dturner-tw authored and gitster committed Feb 25, 2016
1 parent 7548842 commit 4938686
Showing 1 changed file with 12 additions and 0 deletions.
12 changes: 12 additions & 0 deletions refs.h
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,11 @@ extern int dwim_log(const char *str, int len, unsigned char *sha1, char **ref);
* If this succeeds, the ref updates will have taken place and
* the transaction cannot be rolled back.
*
* - Instead of `ref_transaction_commit`, use
* `initial_ref_transaction_commit()` if the ref database is known
* to be empty (e.g. during clone). This is likely to be much
* faster.
*
* - At any time call `ref_transaction_free()` to discard the
* transaction and free associated resources. In particular,
* this rolls back the transaction if it has not been
Expand All @@ -124,6 +129,13 @@ extern int dwim_log(const char *str, int len, unsigned char *sha1, char **ref);
*
* The message is appended to err without first clearing err.
* err will not be '\n' terminated.
*
* Caveats
* -------
*
* Note that no locks are taken, and no refs are read, until
* `ref_transaction_commit` is called. So `ref_transaction_verify`
* won't report a verification failure until the commit is attempted.
*/
struct ref_transaction;

Expand Down

0 comments on commit 4938686

Please sign in to comment.