diff options
| author | Philip Kelley <phkelley@hotmail.com> | 2013-03-19 15:35:26 -0400 | 
|---|---|---|
| committer | Philip Kelley <phkelley@hotmail.com> | 2013-03-19 15:35:26 -0400 | 
| commit | bef2a12cc0859a65a6bc6e72465395a4a48bd3e7 (patch) | |
| tree | e647ea452fb6bddf0bf9c8a6312092baeb8817dc /src/push.c | |
| parent | 799f9a04e38579a6340145440bb927d3dd83c642 (diff) | |
| download | libgit2-bef2a12cc0859a65a6bc6e72465395a4a48bd3e7.tar.gz | |
Convert enqueue_object to a function
Diffstat (limited to 'src/push.c')
| -rw-r--r-- | src/push.c | 40 | 
1 files changed, 19 insertions, 21 deletions
| diff --git a/src/push.c b/src/push.c index ee21bd9d1..00745fbcc 100644 --- a/src/push.c +++ b/src/push.c @@ -347,6 +347,20 @@ on_error:  	return error == GIT_ITEROVER ? 0 : error;  } +static int enqueue_object( +	const git_tree_entry *entry, +	git_packbuilder *pb) +{ +	switch (git_tree_entry_type(entry)) { +		case GIT_OBJ_COMMIT: +			return 0; +		case GIT_OBJ_TREE: +			return git_packbuilder_insert_tree(pb, &entry->oid); +		default: +			return git_packbuilder_insert(pb, &entry->oid, entry->filename); +	} +} +  static int queue_differences(  	git_tree *base,  	git_tree *delta, @@ -358,22 +372,6 @@ static int queue_differences(  	size_t i = 0, j = 0;  	int error; -#define _enqueue_object(ENTRY) do { \ -	switch (git_tree_entry_type((ENTRY))) { \ -		case GIT_OBJ_COMMIT: \ -			break; \ -		case GIT_OBJ_TREE: \ -			if ((error = git_packbuilder_insert_tree(pb, &(ENTRY)->oid)) < 0) \ -				goto on_error; \ -			break; \ -		default: \ -			if ((error = git_packbuilder_insert(pb, &(ENTRY)->oid, \ -				(ENTRY)->filename)) < 0) \ -				goto on_error; \ -			break; \ -	} \ -} while (0) -  	while (i < b_length && j < d_length) {  		const git_tree_entry *b_entry = git_tree_entry_byindex(base, i);  		const git_tree_entry *d_entry = git_tree_entry_byindex(delta, j); @@ -409,8 +407,9 @@ static int queue_differences(  		}  		/* If the object is new or different in the right-hand tree,  		 * then enumerate it */ -		else if (cmp >= 0) -			_enqueue_object(d_entry); +		else if (cmp >= 0 && +			(error = enqueue_object(d_entry, pb)) < 0) +			goto on_error;  	loop:  		if (cmp <= 0) i++; @@ -419,9 +418,8 @@ static int queue_differences(  	/* Drain the right-hand tree of entries */  	for (; j < d_length; j++) -		_enqueue_object(git_tree_entry_byindex(delta, j)); - -#undef _enqueue_object +		if ((error = enqueue_object(git_tree_entry_byindex(delta, j), pb)) < 0) +			goto on_error;  	error = 0; | 
