diff options
Diffstat (limited to 'pretty.c')
| -rw-r--r-- | pretty.c | 24 | 
1 files changed, 11 insertions, 13 deletions
| @@ -659,7 +659,7 @@ static void pp_title_line(enum cmit_fmt fmt,  			  const char *subject,  			  const char *after_subject,  			  const char *encoding, -			  int plain_non_ascii) +			  int need_8bit_cte)  {  	struct strbuf title; @@ -692,7 +692,7 @@ static void pp_title_line(enum cmit_fmt fmt,  	}  	strbuf_addch(sb, '\n'); -	if (plain_non_ascii) { +	if (need_8bit_cte > 0) {  		const char *header_fmt =  			"MIME-Version: 1.0\n"  			"Content-Type: text/plain; charset=%s\n" @@ -741,9 +741,9 @@ static void pp_remainder(enum cmit_fmt fmt,  }  void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit, -				  struct strbuf *sb, int abbrev, -				  const char *subject, const char *after_subject, -				  enum date_mode dmode, int plain_non_ascii) +			 struct strbuf *sb, int abbrev, +			 const char *subject, const char *after_subject, +			 enum date_mode dmode, int need_8bit_cte)  {  	unsigned long beginning_of_body;  	int indent = 4; @@ -769,13 +769,11 @@ void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit,  	if (fmt == CMIT_FMT_ONELINE || fmt == CMIT_FMT_EMAIL)  		indent = 0; -	/* After-subject is used to pass in Content-Type: multipart -	 * MIME header; in that case we do not have to do the -	 * plaintext content type even if the commit message has -	 * non 7-bit ASCII character.  Otherwise, check if we need -	 * to say this is not a 7-bit ASCII. +	/* +	 * We need to check and emit Content-type: to mark it +	 * as 8-bit if we haven't done so.  	 */ -	if (fmt == CMIT_FMT_EMAIL && !after_subject) { +	if (fmt == CMIT_FMT_EMAIL && need_8bit_cte == 0) {  		int i, ch, in_body;  		for (in_body = i = 0; (ch = msg[i]); i++) { @@ -788,7 +786,7 @@ void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit,  					in_body = 1;  			}  			else if (non_ascii(ch)) { -				plain_non_ascii = 1; +				need_8bit_cte = 1;  				break;  			}  		} @@ -813,7 +811,7 @@ void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit,  	/* These formats treat the title line specially. */  	if (fmt == CMIT_FMT_ONELINE || fmt == CMIT_FMT_EMAIL)  		pp_title_line(fmt, &msg, sb, subject, -			      after_subject, encoding, plain_non_ascii); +			      after_subject, encoding, need_8bit_cte);  	beginning_of_body = sb->len;  	if (fmt != CMIT_FMT_ONELINE) | 
