aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWill Thompson <will@willthompson.co.uk>2012-01-18 23:41:07 +0800
committerWill Thompson <will@willthompson.co.uk>2012-01-19 01:47:21 +0800
commitaded85c91fb409bafb06492ddb85aa1224178d4c (patch)
tree374c7de2868580c498358ed49e7ec50ce6e5e51a
parent449c56b28d41ddbb13e8d206b9d1fbabca7e2ec6 (diff)
downloadgsoc2013-empathy-aded85c91fb409bafb06492ddb85aa1224178d4c.tar
gsoc2013-empathy-aded85c91fb409bafb06492ddb85aa1224178d4c.tar.gz
gsoc2013-empathy-aded85c91fb409bafb06492ddb85aa1224178d4c.tar.bz2
gsoc2013-empathy-aded85c91fb409bafb06492ddb85aa1224178d4c.tar.lz
gsoc2013-empathy-aded85c91fb409bafb06492ddb85aa1224178d4c.tar.xz
gsoc2013-empathy-aded85c91fb409bafb06492ddb85aa1224178d4c.tar.zst
gsoc2013-empathy-aded85c91fb409bafb06492ddb85aa1224178d4c.zip
Use /\b<nickname>\b/ to decide whether to highlight
The current highlighting code finds the first occurrence of the nickname, then checks whether the characters before or after are a space, a comma, a colon or a full stop (or the start or end of the string). This means that someone saying “no! That's wjt’s coffee!” didn’t highlight me, because the apostrophe isn't in the whitelist. It also means that saying “borrow some Sudafed from daf” would not highlight daf, since the first match is in the middle of a word. We’re trying to check whether the nickname occurs as a complete word within the message. The regex metacharacter \b matches word boundaries, so /\b<nickname>\b/ is what we actually want. It gets the above cases right, including Unicode punctuation. https://bugzilla.gnome.org/show_bug.cgi?id=591667
-rw-r--r--libempathy/empathy-message.c67
1 files changed, 34 insertions, 33 deletions
diff --git a/libempathy/empathy-message.c b/libempathy/empathy-message.c
index 995f49ab7..9841cbb61 100644
--- a/libempathy/empathy-message.c
+++ b/libempathy/empathy-message.c
@@ -39,6 +39,9 @@
# include <telepathy-logger/call-event.h>
#endif
+#define DEBUG_FLAG EMPATHY_DEBUG_CHAT
+#include "empathy-debug.h"
+
#include "empathy-client-factory.h"
#include "empathy-message.h"
#include "empathy-utils.h"
@@ -633,21 +636,42 @@ empathy_message_is_backlog (EmpathyMessage *message)
return priv->is_backlog;
}
-#define IS_SEPARATOR(ch) (ch == ' ' || ch == ',' || ch == '.' || ch == ':')
+static GRegex *
+get_highlight_regex_for (const gchar *name)
+{
+ GRegex *regex;
+ gchar *name_esc, *pattern;
+ GError *error = NULL;
+
+ name_esc = g_regex_escape_string (name, -1);
+ pattern = g_strdup_printf ("\\b%s\\b", name_esc);
+ regex = g_regex_new (pattern, G_REGEX_CASELESS | G_REGEX_OPTIMIZE, 0,
+ &error);
+
+ if (regex == NULL) {
+ DEBUG ("couldn't compile regex /%s/: %s", pattern,
+ error->message);
+
+ g_error_free (error);
+ }
+
+ g_free (pattern);
+ g_free (name_esc);
+
+ return regex;
+}
+
gboolean
empathy_message_should_highlight (EmpathyMessage *message)
{
EmpathyContact *contact;
const gchar *msg, *to;
- gchar *cf_msg, *cf_to;
- gchar *ch;
- gboolean ret_val;
+ gboolean ret_val = FALSE;
TpChannelTextMessageFlags flags;
+ GRegex *regex;
g_return_val_if_fail (EMPATHY_IS_MESSAGE (message), FALSE);
- ret_val = FALSE;
-
msg = empathy_message_get_body (message);
if (!msg) {
return FALSE;
@@ -670,34 +694,11 @@ empathy_message_should_highlight (EmpathyMessage *message)
return FALSE;
}
- cf_msg = g_utf8_casefold (msg, -1);
- cf_to = g_utf8_casefold (to, -1);
-
- ch = strstr (cf_msg, cf_to);
- if (ch == NULL) {
- goto finished;
+ regex = get_highlight_regex_for (to);
+ if (regex != NULL) {
+ ret_val = g_regex_match (regex, msg, 0, NULL);
+ g_regex_unref (regex);
}
- if (ch != cf_msg) {
- /* Not first in the message */
- if (!IS_SEPARATOR (*(ch - 1))) {
- goto finished;
- }
- }
-
- ch = ch + strlen (cf_to);
- if (ch >= cf_msg + strlen (cf_msg)) {
- ret_val = TRUE;
- goto finished;
- }
-
- if (IS_SEPARATOR (*ch)) {
- ret_val = TRUE;
- goto finished;
- }
-
-finished:
- g_free (cf_msg);
- g_free (cf_to);
return ret_val;
}