diff options
| author | Přemysl Janouch <p.janouch@gmail.com> | 2015-05-10 02:12:39 +0200 | 
|---|---|---|
| committer | Přemysl Janouch <p.janouch@gmail.com> | 2015-05-10 02:12:39 +0200 | 
| commit | 0a990ad6f725dba816e067f6273d59c860c306ba (patch) | |
| tree | 2edfab74c40c962fa2ab45df506c69232cbcd0f4 | |
| parent | 00b91976b07f4ad7d5f2b78642ddc8975b96c1d8 (diff) | |
| download | xK-0a990ad6f725dba816e067f6273d59c860c306ba.tar.gz xK-0a990ad6f725dba816e067f6273d59c860c306ba.tar.xz xK-0a990ad6f725dba816e067f6273d59c860c306ba.zip | |
degesch: add a way to output mIRC formatting
| -rw-r--r-- | degesch.c | 39 | 
1 files changed, 38 insertions, 1 deletions
| @@ -3967,6 +3967,39 @@ irc_process_message (const struct irc_message *msg,  		irc_process_numeric (s, msg, numeric);  } +// --- mIRC formatting --------------------------------------------------------- + +// Out user interface doesn't give us much of a choice with entering it. + +static char * +add_mirc_formatting (const char *text) +{ +	struct str output; +	str_init (&output); + +	for (; *text; text++) +	{ +		char c = *text; +		if (c != '\\') +		{ +			str_append_c (&output, c); +			continue; +		} + +		switch (text[1]) +		{ +		case 'b': c = '\x02'; text++; break; +		case 'c': c = '\x03'; text++; break; +		case 'i': c = '\x1d'; text++; break; +		case '_': c = '\x1f'; text++; break; +		case 'v': c = '\x16'; text++; break; +		case 'o': c = '\x0f'; text++; break; +		} +		str_append_c (&output, c); +	} +	return str_steal (&output); +} +  // --- Message autosplitting magic ---------------------------------------------  // This is the most basic acceptable algorithm; something like ICU with proper @@ -4102,10 +4135,13 @@ send_autosplit_message (struct server *s, struct send_autosplit_args a)  	int fixed_part = strlen (a.command) + 1 + strlen (a.target) + 1 + 1  		+ strlen (a.prefix) + strlen (a.suffix); +	// XXX: this may screw up the formatting if we do split the message +	char *formatted = add_mirc_formatting (a.message); +  	struct str_vector lines;  	str_vector_init (&lines);  	struct error *e = NULL; -	if (!irc_autosplit_message (s, a.message, fixed_part, &lines, &e)) +	if (!irc_autosplit_message (s, formatted, fixed_part, &lines, &e))  	{  		buffer_send_error (s->ctx,  			buffer ? buffer : s->buffer, "%s", e->message); @@ -4120,6 +4156,7 @@ send_autosplit_message (struct server *s, struct send_autosplit_args a)  		a.logger (s, &a, buffer, lines.vector[i]);  	}  end: +	free (formatted);  	str_vector_free (&lines);  } | 
