diff options
| author | Russell Belfer <rb@github.com> | 2013-05-31 12:18:43 -0700 | 
|---|---|---|
| committer | Russell Belfer <rb@github.com> | 2013-05-31 12:18:43 -0700 | 
| commit | cee695ae6b9a9f586d32d0b9460a358bfdc4fe1b (patch) | |
| tree | 33fa5cceec1bbb24ab919ccb21732cd1487d4fec /src/submodule.c | |
| parent | 1ed356dcfef449313bac3ce795f26d19423c744c (diff) | |
| download | libgit2-cee695ae6b9a9f586d32d0b9460a358bfdc4fe1b.tar.gz | |
Make iterators use GIT_ITEROVER & smart advance
1. internal iterators now return GIT_ITEROVER when you go past the
   last item in the iteration.
2. git_iterator_advance will "advance" to the first item in the
   iteration if it is called immediately after creating the
   iterator, which allows a simpler idiom for basic iteration.
3. if git_iterator_advance encounters an error reading data (e.g.
   a missing tree or an unreadable file), it returns the error
   but also attempts to advance past the invalid data to prevent
   an infinite loop.
Updated all tests and internal usage of iterators to account for
these new behaviors.
Diffstat (limited to 'src/submodule.c')
| -rw-r--r-- | src/submodule.c | 18 | 
1 files changed, 8 insertions, 10 deletions
| diff --git a/src/submodule.c b/src/submodule.c index f4fbcd35a..16114d8ac 100644 --- a/src/submodule.c +++ b/src/submodule.c @@ -1143,9 +1143,7 @@ static int load_submodule_config_from_index(  		(error = git_iterator_for_index(&i, index, 0, NULL, NULL)) < 0)  		return error; -	error = git_iterator_current(&entry, i); - -	while (!error && entry != NULL) { +	while (!(error = git_iterator_advance(&entry, i))) {  		if (S_ISGITLINK(entry->mode)) {  			error = submodule_load_from_index(repo, entry); @@ -1158,10 +1156,11 @@ static int load_submodule_config_from_index(  			if (strcmp(entry->path, GIT_MODULES_FILE) == 0)  				git_oid_cpy(gitmodules_oid, &entry->oid);  		} - -		error = git_iterator_advance(&entry, i);  	} +	if (error == GIT_ITEROVER) +		error = 0; +  	git_iterator_free(i);  	return error; @@ -1183,9 +1182,7 @@ static int load_submodule_config_from_head(  		return error;  	} -	error = git_iterator_current(&entry, i); - -	while (!error && entry != NULL) { +	while (!(error = git_iterator_advance(&entry, i))) {  		if (S_ISGITLINK(entry->mode)) {  			error = submodule_load_from_head(repo, entry->path, &entry->oid); @@ -1199,10 +1196,11 @@ static int load_submodule_config_from_head(  				git_oid_iszero(gitmodules_oid))  				git_oid_cpy(gitmodules_oid, &entry->oid);  		} - -		error = git_iterator_advance(&entry, i);  	} +	if (error == GIT_ITEROVER) +		error = 0; +  	git_iterator_free(i);  	git_tree_free(head); | 
