diff options
| author | Russell Belfer <rb@github.com> | 2013-06-19 15:54:19 -0700 | 
|---|---|---|
| committer | Russell Belfer <rb@github.com> | 2013-06-19 15:54:19 -0700 | 
| commit | 7863523a1be51981bafee9d13b3344fb4ff47347 (patch) | |
| tree | ff0f851b89ad1e0a72a980f402d0cac0c4d028a6 /src/index.c | |
| parent | f30fff45a752cb0781067ad48c283e49345a5813 (diff) | |
| download | libgit2-7863523a1be51981bafee9d13b3344fb4ff47347.tar.gz | |
Add tests and fix use of freed memory
This adds some tests for updating the index and having it remove
items to make sure that the iteration over the index still works
even as earlier items are removed.
In testing with valgrind, this found a path that would use the
path string from the index entry after it had been freed.  The
bug fix is simply to copy the path of the index entry before
doing any actual index manipulation.
Diffstat (limited to 'src/index.c')
| -rw-r--r-- | src/index.c | 12 | 
1 files changed, 9 insertions, 3 deletions
| diff --git a/src/index.c b/src/index.c index e65dc052c..d5568528b 100644 --- a/src/index.c +++ b/src/index.c @@ -2176,6 +2176,7 @@ static int index_apply_to_all(  	size_t i;  	git_pathspec_context ps;  	const char *match; +	git_buf path = GIT_BUF_INIT;  	assert(index); @@ -2205,23 +2206,27 @@ static int index_apply_to_all(  			}  		} +		/* index manipulation may alter entry, so don't depend on it */ +		if ((error = git_buf_sets(&path, entry->path)) < 0) +			break; +  		switch (action) {  		case INDEX_ACTION_NONE:  			break;  		case INDEX_ACTION_UPDATE: -			error = git_index_add_bypath(index, entry->path); +			error = git_index_add_bypath(index, path.ptr);  			if (error == GIT_ENOTFOUND) {  				giterr_clear(); -				error = git_index_remove_bypath(index, entry->path); +				error = git_index_remove_bypath(index, path.ptr);  				if (!error) /* back up foreach if we removed this */  					i--;  			}  			break;  		case INDEX_ACTION_REMOVE: -			if (!(error = git_index_remove_bypath(index, entry->path))) +			if (!(error = git_index_remove_bypath(index, path.ptr)))  				i--; /* back up foreach if we removed this */  			break;  		default: @@ -2231,6 +2236,7 @@ static int index_apply_to_all(  		}  	} +	git_buf_free(&path);  	git_pathspec_context_free(&ps);  	return error; | 
