diff options
| author | Pierre Habouzit <madcoder@debian.org> | 2007-09-06 13:20:10 +0200 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2007-09-06 23:57:44 -0700 | 
| commit | 19b358e8daafdfe5a5d25ff7972e041493b05156 (patch) | |
| tree | 194dfee3bdd900e1d0e10cb18e256dbc2eb7b90a | |
| parent | af6eb82262e35687aa8f00d688e327cb845973fa (diff) | |
| download | git-19b358e8daafdfe5a5d25ff7972e041493b05156.tar.gz | |
Use strbuf API in buitin-rerere.c
Signed-off-by: Pierre Habouzit <madcoder@debian.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | builtin-rerere.c | 56 | 
1 files changed, 18 insertions, 38 deletions
| diff --git a/builtin-rerere.c b/builtin-rerere.c index 29d057c98c..98d7702168 100644 --- a/builtin-rerere.c +++ b/builtin-rerere.c @@ -1,6 +1,7 @@  #include "builtin.h"  #include "cache.h"  #include "path-list.h" +#include "strbuf.h"  #include "xdiff/xdiff.h"  #include "xdiff-interface.h" @@ -66,41 +67,20 @@ static int write_rr(struct path_list *rr, int out_fd)  	return commit_lock_file(&write_lock);  } -struct buffer { -	char *ptr; -	int nr, alloc; -}; - -static void append_line(struct buffer *buffer, const char *line) -{ -	int len = strlen(line); - -	if (buffer->nr + len > buffer->alloc) { -		buffer->alloc = alloc_nr(buffer->nr + len); -		buffer->ptr = xrealloc(buffer->ptr, buffer->alloc); -	} -	memcpy(buffer->ptr + buffer->nr, line, len); -	buffer->nr += len; -} - -static void clear_buffer(struct buffer *buffer) -{ -	free(buffer->ptr); -	buffer->ptr = NULL; -	buffer->nr = buffer->alloc = 0; -} -  static int handle_file(const char *path,  	 unsigned char *sha1, const char *output)  {  	SHA_CTX ctx;  	char buf[1024];  	int hunk = 0, hunk_no = 0; -	struct buffer minus = { NULL, 0, 0 }, plus = { NULL, 0, 0 }; -	struct buffer *one = &minus, *two = + +	struct strbuf minus, plus; +	struct strbuf *one = &minus, *two = +  	FILE *f = fopen(path, "r");  	FILE *out; +	strbuf_init(&minus); +	strbuf_init(&plus); +  	if (!f)  		return error("Could not open %s", path); @@ -122,36 +102,36 @@ static int handle_file(const char *path,  		else if (!prefixcmp(buf, "======="))  			hunk = 2;  		else if (!prefixcmp(buf, ">>>>>>> ")) { -			int one_is_longer = (one->nr > two->nr); -			int common_len = one_is_longer ? two->nr : one->nr; -			int cmp = memcmp(one->ptr, two->ptr, common_len); +			int one_is_longer = (one->len > two->len); +			int common_len = one_is_longer ? two->len : one->len; +			int cmp = memcmp(one->buf, two->buf, common_len);  			hunk_no++;  			hunk = 0;  			if ((cmp > 0) || ((cmp == 0) && one_is_longer)) { -				struct buffer *swap = one; +				struct strbuf *swap = one;  				one = two;  				two = swap;  			}  			if (out) {  				fputs("<<<<<<<\n", out); -				fwrite(one->ptr, one->nr, 1, out); +				fwrite(one->buf, one->len, 1, out);  				fputs("=======\n", out); -				fwrite(two->ptr, two->nr, 1, out); +				fwrite(two->buf, two->len, 1, out);  				fputs(">>>>>>>\n", out);  			}  			if (sha1) { -				SHA1_Update(&ctx, one->ptr, one->nr); +				SHA1_Update(&ctx, one->buf, one->len);  				SHA1_Update(&ctx, "\0", 1); -				SHA1_Update(&ctx, two->ptr, two->nr); +				SHA1_Update(&ctx, two->buf, two->len);  				SHA1_Update(&ctx, "\0", 1);  			} -			clear_buffer(one); -			clear_buffer(two); +			strbuf_release(one); +			strbuf_release(two);  		} else if (hunk == 1) -			append_line(one, buf); +			strbuf_addstr(one, buf);  		else if (hunk == 2) -			append_line(two, buf); +			strbuf_addstr(two, buf);  		else if (out)  			fputs(buf, out);  	} | 
