|  | --- | 
|  | builtin-mailinfo.c |   37 ++++++++++++++++++++++++++++++++++++- | 
|  | 1 files changed, 36 insertions(+), 1 deletions(-) | 
|  |  | 
|  | diff --git a/builtin-mailinfo.c b/builtin-mailinfo.c | 
|  | index b0b5d8f..461c47e 100644 | 
|  | --- a/builtin-mailinfo.c | 
|  | +++ b/builtin-mailinfo.c | 
|  | @@ -712,6 +712,34 @@ static inline int patchbreak(const struct strbuf *line) | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | +static int scissors(const struct strbuf *line) | 
|  | +{ | 
|  | +	size_t i, len = line->len; | 
|  | +	int scissors_dashes_seen = 0; | 
|  | +	const char *buf = line->buf; | 
|  | + | 
|  | +	for (i = 0; i < len; i++) { | 
|  | +		if (isspace(buf[i])) | 
|  | +			continue; | 
|  | +		if (buf[i] == '-') { | 
|  | +			scissors_dashes_seen |= 02; | 
|  | +			continue; | 
|  | +		} | 
|  | +		if (i + 1 < len && !memcmp(buf + i, ">8", 2)) { | 
|  | +			scissors_dashes_seen |= 01; | 
|  | +			i++; | 
|  | +			continue; | 
|  | +		} | 
|  | +		if (i + 7 < len && !memcmp(buf + i, "cut here", 8)) { | 
|  | +			i += 7; | 
|  | +			continue; | 
|  | +		} | 
|  | +		/* everything else --- not scissors */ | 
|  | +		break; | 
|  | +	} | 
|  | +	return scissors_dashes_seen == 03; | 
|  | +} | 
|  | + | 
|  | static int handle_commit_msg(struct strbuf *line) | 
|  | { | 
|  | static int still_looking = 1; | 
|  | @@ -723,10 +751,17 @@ static int handle_commit_msg(struct strbuf *line) | 
|  | strbuf_ltrim(line); | 
|  | if (!line->len) | 
|  | return 0; | 
|  | -		if ((still_looking = check_header(line, s_hdr_data, 0)) != 0) | 
|  | +		still_looking = check_header(line, s_hdr_data, 0); | 
|  | +		if (still_looking) | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | +	if (scissors(line)) { | 
|  | +		fseek(cmitmsg, 0L, SEEK_SET); | 
|  | +		still_looking = 1; | 
|  | +		return 0; | 
|  | +	} | 
|  | + | 
|  | /* normalize the log message to UTF-8. */ | 
|  | if (metainfo_charset) | 
|  | convert_to_utf8(line, charset.buf); | 
|  | -- | 
|  | 1.6.4.1 |