diff options
| author | Russell Belfer <rb@github.com> | 2014-02-07 14:17:19 -0800 | 
|---|---|---|
| committer | Russell Belfer <rb@github.com> | 2014-04-17 14:43:45 -0700 | 
| commit | 27e54bcf82fe27bdfadbaa9c5383ee8a948ea33c (patch) | |
| tree | 9b373c91e459827dda96179ccd77c7ecccdef355 /src | |
| parent | 3dbee456564a9baf24631bfe219f81434d8fdfa6 (diff) | |
| download | libgit2-27e54bcf82fe27bdfadbaa9c5383ee8a948ea33c.tar.gz | |
Add public diff print helpers
The usefulness of these helpers came up for me while debugging
some of the iterator changes that I was making, so since they
have also been requested (albeit indirectly) I thought I'd include
them.
Diffstat (limited to 'src')
| -rw-r--r-- | src/diff_print.c | 28 | 
1 files changed, 26 insertions, 2 deletions
| diff --git a/src/diff_print.c b/src/diff_print.c index 1a09bed54..a7f7b6fe8 100644 --- a/src/diff_print.c +++ b/src/diff_print.c @@ -8,6 +8,7 @@  #include "diff.h"  #include "diff_patch.h"  #include "fileops.h" +#include "git2/sys/diff.h"  typedef struct {  	git_diff *diff; @@ -435,7 +436,7 @@ int git_patch_print(  	return error;  } -static int diff_print_to_buffer_cb( +int git_diff_print_callback__to_buf(  	const git_diff_delta *delta,  	const git_diff_hunk *hunk,  	const git_diff_line *line, @@ -444,6 +445,11 @@ static int diff_print_to_buffer_cb(  	git_buf *output = payload;  	GIT_UNUSED(delta); GIT_UNUSED(hunk); +	if (!output) { +		giterr_set(GITERR_INVALID, "Buffer pointer must be provided"); +		return -1; +	} +  	if (line->origin == GIT_DIFF_LINE_ADDITION ||  		line->origin == GIT_DIFF_LINE_DELETION ||  		line->origin == GIT_DIFF_LINE_CONTEXT) @@ -452,10 +458,28 @@ static int diff_print_to_buffer_cb(  	return git_buf_put(output, line->content, line->content_len);  } +int git_diff_print_callback__to_file_handle( +	const git_diff_delta *delta, +	const git_diff_hunk *hunk, +	const git_diff_line *line, +	void *payload) +{ +	FILE *fp = payload ? payload : stdout; + +	GIT_UNUSED(delta); GIT_UNUSED(hunk); + +	if (line->origin == GIT_DIFF_LINE_CONTEXT || +		line->origin == GIT_DIFF_LINE_ADDITION || +		line->origin == GIT_DIFF_LINE_DELETION) +		fputc(line->origin, fp); +	fwrite(line->content, 1, line->content_len, fp); +	return 0; +} +  /* print a git_patch to a git_buf */  int git_patch_to_buf(  	git_buf *out,  	git_patch *patch)  { -	return git_patch_print(patch, diff_print_to_buffer_cb, out); +	return git_patch_print(patch, git_diff_print_callback__to_buf, out);  } | 
