rerere: drop want_sp parameter from is_cmarker()

As the nature of the conflict marker line determines if there should
be a SP and label after it, the caller shouldn't have to pass the
parameter redundantly.

Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Junio C Hamano 2015-06-29 15:05:24 -07:00
parent a14c7ab8f5
commit 67711cdc39

View File

@ -148,8 +148,25 @@ static int rerere_file_getline(struct strbuf *sb, struct rerere_io *io_)
return strbuf_getwholeline(sb, io->input, '\n'); return strbuf_getwholeline(sb, io->input, '\n');
} }
static int is_cmarker(char *buf, int marker_char, int marker_size, int want_sp) /*
* Require the exact number of conflict marker letters, no more, no
* less, followed by SP or any whitespace
* (including LF).
*/
static int is_cmarker(char *buf, int marker_char, int marker_size)
{ {
int want_sp;
/*
* The beginning of our version and the end of their version
* always are labeled like "<<<<< ours" or ">>>>> theirs",
* hence we set want_sp for them. Note that the version from
* the common ancestor in diff3-style output is not always
* labelled (e.g. "||||| common" is often seen but "|||||"
* alone is also valid), so we do not set want_sp.
*/
want_sp = (marker_char == '<') || (marker_char == '>');
while (marker_size--) while (marker_size--)
if (*buf++ != marker_char) if (*buf++ != marker_char)
return 0; return 0;
@ -172,19 +189,19 @@ static int handle_path(unsigned char *sha1, struct rerere_io *io, int marker_siz
git_SHA1_Init(&ctx); git_SHA1_Init(&ctx);
while (!io->getline(&buf, io)) { while (!io->getline(&buf, io)) {
if (is_cmarker(buf.buf, '<', marker_size, 1)) { if (is_cmarker(buf.buf, '<', marker_size)) {
if (hunk != RR_CONTEXT) if (hunk != RR_CONTEXT)
goto bad; goto bad;
hunk = RR_SIDE_1; hunk = RR_SIDE_1;
} else if (is_cmarker(buf.buf, '|', marker_size, 0)) { } else if (is_cmarker(buf.buf, '|', marker_size)) {
if (hunk != RR_SIDE_1) if (hunk != RR_SIDE_1)
goto bad; goto bad;
hunk = RR_ORIGINAL; hunk = RR_ORIGINAL;
} else if (is_cmarker(buf.buf, '=', marker_size, 0)) { } else if (is_cmarker(buf.buf, '=', marker_size)) {
if (hunk != RR_SIDE_1 && hunk != RR_ORIGINAL) if (hunk != RR_SIDE_1 && hunk != RR_ORIGINAL)
goto bad; goto bad;
hunk = RR_SIDE_2; hunk = RR_SIDE_2;
} else if (is_cmarker(buf.buf, '>', marker_size, 1)) { } else if (is_cmarker(buf.buf, '>', marker_size)) {
if (hunk != RR_SIDE_2) if (hunk != RR_SIDE_2)
goto bad; goto bad;
if (strbuf_cmp(&one, &two) > 0) if (strbuf_cmp(&one, &two) > 0)