diff options
| author | dequis <dx@dxzone.com.ar> | 2015-08-11 01:53:08 -0300 | 
|---|---|---|
| committer | dequis <dx@dxzone.com.ar> | 2015-08-11 03:48:15 -0300 | 
| commit | 654112d4a84babd994c5f61543ca3ebe6de6f1f3 (patch) | |
| tree | d74c1f700ab0d17c0e54a071426575d5fc779863 | |
| parent | 666722e67f6802cea4ef231834ea9e3ad321fdae (diff) | |
otr: color multiline messages
Fixes trac ticket 710.
Incoming messages can have newlines in them, which become several
PRIVMSG on the irc layer. Prepending color codes at the beginning of the
message resulted in showing the rest of those PRIVMSG as white.
This splits the message by newlines and rebuilds it in a GString,
re-adding the color codes right after each newline.
| -rw-r--r-- | otr.c | 75 | 
1 files changed, 51 insertions, 24 deletions
| @@ -218,6 +218,9 @@ void otr_disconnect_all(irc_t *irc);  /* functions to be called for certain events */  static const struct irc_plugin otr_plugin; +#define OTR_COLOR_TRUSTED "03"     /* green */ +#define OTR_COLOR_UNTRUSTED "05"   /* red */ +  /*** routines declared in otr.h: ***/  #ifdef OTR_BI @@ -741,6 +744,46 @@ void op_create_instag(void *opdata, const char *account, const char *protocol)  	}  } +/* returns newly allocated string */ +static char *otr_color_encrypted(char *msg, char *color, gboolean is_query) { +	char **lines; +	GString *out; +	int i; + +	lines = g_strsplit(msg, "\n", -1); + +	/* up to 4 extra chars per line (e.g., '\x03' + ("03"|"05") + ' ') */ +	out = g_string_sized_new(strlen(msg) + g_strv_length(lines) * 4); +	 +	for (i = 0; lines[i]; i++) { +		char *line = lines[i]; + +		if (i != 0) { +			g_string_append_c(out, '\n'); + +		} else if (is_query && g_strncasecmp(line, "/me ", 4) == 0) { +			/* in a query window, keep "/me " uncolored at the beginning */ +			line += 4; +			g_string_append(out, "/me "); +		} + +		g_string_append_c(out, '\x03'); +		g_string_append(out, color); + +		/* comma in first place could mess with the color code */ +		if (line[0] == ',') { +			/* insert a space between color spec and message */ +			g_string_append_c(out, ' '); +		} + +		g_string_append(out, line); +	} + +	g_strfreev(lines); + +	return g_string_free(out, FALSE); +} +  void op_convert_msg(void *opdata, ConnContext *ctx, OtrlConvertType typ,                      char **dst, const char *src)  { @@ -751,44 +794,28 @@ void op_convert_msg(void *opdata, ConnContext *ctx, OtrlConvertType typ,  	if (typ == OTRL_CONVERT_RECEIVING) {  		char *msg = g_strdup(src); -		char *buf = msg;  		/* HTML decoding */  		if (set_getbool(&ic->bee->set, "otr_does_html") &&  		    !(ic->flags & OPT_DOES_HTML) &&  		    set_getbool(&ic->bee->set, "strip_html")) {  			strip_html(msg); + +			/* msg is borrowed by *dst (unless the next if decides to color it) */  			*dst = msg;  		}  		/* coloring */  		if (set_getbool(&ic->bee->set, "otr_color_encrypted")) { -			int color;                /* color according to f'print trust */ -			char *pre = "", *sep = "";    /* optional parts */  			const char *trust = ctx->active_fingerprint->trust; +			char *color = (trust && *trust) ? OTR_COLOR_TRUSTED : OTR_COLOR_UNTRUSTED; +			gboolean is_query = (irc_user_msgdest(iu) == irc->user->nick); -			if (trust && trust[0] != '\0') { -				color = 3;   /* green */ -			} else { -				color = 5;   /* red */ - -			} -			/* in a query window, keep "/me " uncolored at the beginning */ -			if (g_strncasecmp(msg, "/me ", 4) == 0 -			    && irc_user_msgdest(iu) == irc->user->nick) { -				msg += 4;  /* skip */ -				pre = "/me "; -			} +			/* the return value of otr_color_encrypted() is borrowed by *dst */ +			*dst = otr_color_encrypted(msg, color, is_query); -			/* comma in first place could mess with the color code */ -			if (msg[0] == ',') { -				/* insert a space between color spec and message */ -				sep = " "; -			} - -			*dst = g_strdup_printf("%s\x03%.2d%s%s\x0F", pre, -			                       color, sep, msg); -			g_free(buf); +			/* this branch doesn't need msg */ +			g_free(msg);  		}  	} else {  		/* HTML encoding */ | 
