# HG changeset patch # User Eric Warmenhoven # Date 961195145 0 # Node ID a266fd221c3cddc481534df799b450709c0aeaa7 # Parent f9dc748758337eac7ca9105d8c3b1f49b2e31b08 [gaim-migrate @ 425] /me works better in chat committer: Tailor Script diff -r f9dc74875833 -r a266fd221c3c src/buddy_chat.c --- a/src/buddy_chat.c Fri Jun 16 10:01:10 2000 +0000 +++ b/src/buddy_chat.c Fri Jun 16 22:39:05 2000 +0000 @@ -228,10 +228,33 @@ gtk_widget_show(invite); } +static gboolean meify(char *message) { + /* read /me-ify : if the message (post-HTML) starts with /me, remove + * the "/me " part of it (including that space) and return TRUE */ + char *c = message; + int inside_HTML = 0; /* i really don't like descriptive names */ + if (!c) return FALSE; /* um... this would be very bad if this happens */ + while (*c) { + if (inside_HTML) { + if (*c == '>') inside_HTML = 0; + } else { + if (*c == '<') inside_HTML = 1; + else break; + } + c++; /* i really don't like c++ either */ + } + /* k, so now we've gotten past all the HTML crap. */ + if (!*c) return FALSE; + if (!strncmp(c, "/me ", 4)) { + sprintf(c, "%s", c+4); + return TRUE; + } else + return FALSE; +} + void chat_write(struct buddy_chat *b, char *who, int flag, char *message) { char *buf; - char *buf2; GList *ignore = b->ignored; char *str; char colour[10]; @@ -247,21 +270,17 @@ buf = g_malloc(BUF_LONG); if (flag & WFLAG_WHISPER) { - buf2 = g_strdup(message); - if (!strncmp(buf2, "/me ", 4)) { + if (meify(message)) { str = g_malloc(64); g_snprintf(str, 62, "***%s", who); strcpy(colour, "#6C2585\0"); - sprintf(message, "%s", buf2 + 4); } else { str = g_malloc(64); g_snprintf(str, 62, "*%s*:", who); strcpy(colour, "#00ff00\0"); } - g_free(buf2); } else { - buf2 = g_strdup(message); - if (!strncmp(buf2, "/me ", 4)) { + if (meify(message)) { str = g_strdup(normalize(who)); if (!strcasecmp(str, normalize(current_user->username))) { if (b->makesound && (sound_options & OPT_SOUND_CHAT_SAY)) @@ -274,7 +293,6 @@ str = g_malloc(64); g_snprintf(str, 62, "***%s", who); strcpy(colour, "#6C2585\0"); - sprintf(message, "%s", buf2 + 4); } else { str = g_strdup(normalize(who)); if (!strcasecmp(str, normalize(current_user->username))) { @@ -290,7 +308,6 @@ str = g_malloc(64); g_snprintf(str, 62, "%s:", who); } - g_free(buf2); }