diff -r a6647dc5baee -r 694a8ad60edd src/protocols/msn/utils.c --- a/src/protocols/msn/utils.c Sun Mar 28 19:53:43 2004 +0000 +++ b/src/protocols/msn/utils.c Sun Mar 28 21:38:22 2004 +0000 @@ -34,10 +34,12 @@ cur = strstr(mime, "FN="); - if (cur && (*(cur = cur + 3) != ';')) { + if (cur && (*(cur = cur + 3) != ';')) + { pre = g_string_append(pre, " 0) { + if (i > 0) + { char tag[64]; - if (i == 1) { - colors[2] = colors[0]; + if (i == 1) + { colors[1] = 0; - colors[0] = 0; + colors[2] = 0; } - else if (i == 2) { - colors[2] = colors[1]; - colors[1] = colors[0]; - colors[0] = 0; + else if (i == 2) + { + unsigned int temp = colors[0]; + + colors[0] = colors[1]; + colors[1] = temp; + colors[2] = 0; + } + else if (i == 3) + { + unsigned int temp = colors[2]; + + colors[2] = colors[0]; + colors[0] = temp; } g_snprintf(tag, sizeof(tag), "", - colors[2], colors[1], colors[0]); + colors[0], colors[1], colors[2]); + + gaim_debug_misc("msn", "Got: %s\n", tag); pre = g_string_append(pre, tag); post = g_string_prepend(post, ""); @@ -103,3 +121,158 @@ else g_free(cur); } + +/* + * We need this because we're only supposed to encode spaces in the font + * names. gaim_url_encode() isn't acceptable. + */ +const char * +encode_spaces(const char *str) +{ + static char buf[BUF_LEN]; + const char *c; + char *d; + + g_return_val_if_fail(str != NULL, NULL); + + for (c = str, d = buf; *c != '\0'; c++) + { + if (*c == ' ') + { + *d++ = '%'; + *d++ = '2'; + *d++ = '0'; + } + else + *d++ = *c; + } + + return buf; +} + +/* + * Taken from the zephyr plugin. + * This parses HTML formatting (put out by one of the gtkimhtml widgets + * and converts it to msn formatting. It doesn't deal with the tag closing, + * but gtkimhtml widgets give valid html. + * It currently deals properly with , , , , + * . + * It ignores and + */ +void +msn_import_html(const char *html, char **attributes, char **message) +{ + int len, retcount = 0; + const char *c; + char *msg; + char *fontface = NULL; + char fonteffect[4]; + char fontcolor[7]; + + g_return_if_fail(html != NULL); + g_return_if_fail(attributes != NULL); + g_return_if_fail(message != NULL); + + len = strlen(html); + msg = g_malloc0(len + 1); + + memset(fontcolor, 0, sizeof(fontcolor)); + memset(fonteffect, 0, sizeof(fontcolor)); + + for (c = html; *c != '\0';) + { + if (*c == '<') + { + if (!g_ascii_strncasecmp(c + 1, "i>", 2)) + { + strcat(fonteffect, "I"); + c += 3; + } + else if (!g_ascii_strncasecmp(c + 1, "b>", 2)) + { + strcat(fonteffect, "B"); + c += 3; + } + else if (!g_ascii_strncasecmp(c + 1, "u>", 2)) + { + strcat(fonteffect, "U"); + c += 3; + } + else if (!g_ascii_strncasecmp(c + 1, "a href=\"", 8)) + { + c += 9; + + while (g_ascii_strncasecmp(c, "\">", 2)) + msg[retcount++] = *c++; + + c += 2; + + /* ignore descriptive string */ + while (g_ascii_strncasecmp(c, "", 4)) + c++; + + c += 4; + } + else if (!g_ascii_strncasecmp(c + 1, "font", 4)) + { + c += 5; + + while (!g_ascii_strncasecmp(c, " ", 1)) + c++; + + if (!g_ascii_strncasecmp(c, "color=\"#", 7)) + { + c += 8; + + fontcolor[0] = *(c + 4); + fontcolor[1] = *(c + 5); + fontcolor[2] = *(c + 2); + fontcolor[3] = *(c + 3); + fontcolor[4] = *c; + fontcolor[5] = *(c + 1); + + c += 8; + } + else if (!g_ascii_strncasecmp(c, "face=\"", 6)) + { + const char *end = NULL; + unsigned int namelen = 0; + + c += 6; + end = strchr(c, '\"'); + namelen = (unsigned int)(end - c); + fontface = g_strndup(c, namelen); + c = end + 2; + } + else + { + /* Drop all unrecognized/misparsed font tags */ + while (g_ascii_strncasecmp(c, "\">", 2)) + c++; + + c += 2; + } + } + else + { + while (g_ascii_strncasecmp(c, ">", 1)) + c++; + + c++; + } + } + else + msg[retcount++] = *c++; + } + + if (fontface == NULL) + fontface = g_strdup("MS Sans Serif"); + + *attributes = g_strdup_printf("FN=%s; EF=%s; CO=%s; PF=0", + encode_spaces(fontface), + fonteffect, fontcolor); + *message = g_strdup(msg); + + g_free(fontface); + g_free(msg); +}