summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2010-10-11 16:29:15 +0200
committerSebastien Helleu <flashcode@flashtux.org>2010-10-11 16:29:15 +0200
commitfe2a36136429f451db2546b10502df2655a2b1c8 (patch)
tree30ed8c1fc9be1c5da04470d1bebfd78087e89b64
parentf32e18c717520e3482b1a4155ff4e804da7aecbb (diff)
downloadweechat-fe2a36136429f451db2546b10502df2655a2b1c8.zip
Add property "no_highlight_nicks" in buffers to disable highlight for some nicks in buffer
This can be used with script buffer_autoset.py (see /help autosetbuffer).
-rw-r--r--ChangeLog5
-rw-r--r--doc/en/weechat_plugin_api.en.txt12
-rw-r--r--doc/fr/weechat_plugin_api.fr.txt13
-rw-r--r--doc/it/weechat_plugin_api.it.txt16
-rw-r--r--src/core/wee-upgrade.c2
-rw-r--r--src/gui/gui-buffer.c117
-rw-r--r--src/gui/gui-buffer.h3
-rw-r--r--src/gui/gui-line.c31
8 files changed, 195 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index 56ab23333..24e906b7c 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,12 +1,14 @@
WeeChat ChangeLog
=================
Sébastien Helleu <flashcode@flashtux.org>
-v0.3.4-dev, 2010-10-09
+v0.3.4-dev, 2010-10-11
Version 0.3.4 (under dev!)
--------------------------
+* core: add property "no_highlight_nicks" in buffers to disable highlight
+ for some nicks in buffer
* core: add new options weechat.look.input_share and
weechat.look.input_share_overwrite (task #9228)
* core: add new option weechat.look.prefix_align_min (task #10650)
@@ -19,6 +21,7 @@ Version 0.3.4 (under dev!)
* api: add priority for hooks (task #10550)
* api: add new functions: hashtable_get_string, hook_info_hashtable,
info_get_hashtable
+* irc: add tag "nick_xxx" in user messages
* irc: move options from network section to server section: connection_timeout,
anti_flood_prio_high, anti_flood_prio_low, away_check, away_check_max_nicks,
default_msg_part, default_msg_quit (task #10664, task #10668)
diff --git a/doc/en/weechat_plugin_api.en.txt b/doc/en/weechat_plugin_api.en.txt
index 5f35210c8..2975dbbc4 100644
--- a/doc/en/weechat_plugin_api.en.txt
+++ b/doc/en/weechat_plugin_api.en.txt
@@ -7874,6 +7874,7 @@ Arguments:
** 'text_search_input': input saved before text search
** 'highlight_words': list of words to highlight
** 'highlight_tags': list of tags to highlight
+** 'no_highlight_nicks': list of nicks to NOT highlight
** 'localvar_xxx': get content of local variable "xxx" (replace "xxx" by the
name of variable to read)
@@ -8030,6 +8031,17 @@ Arguments:
| highlight_tags | comma separated list of tags |
comma separated list of tags to highlight in this buffer
+| no_highlight_nicks | comma separated list of nicks |
+ comma separated list of nicks to NOT highlight in this buffer, for example:
+ "joe,mike,robert"
+
+| no_highlight_nicks_add | comma separated list of nicks |
+ comma separated list of nicks to NOT highlight in this buffer, these words are
+ added to existing nicks in buffer
+
+| no_highlight_nicks_del | comma separated list of nicks |
+ comma separated list of nicks to remove from non highlighted nicks on buffer
+
| key_bind_xxx | any string |
bind a new key 'xxx', specific to this buffer, value is command to execute
for this key
diff --git a/doc/fr/weechat_plugin_api.fr.txt b/doc/fr/weechat_plugin_api.fr.txt
index 05a99ffb2..2945faa36 100644
--- a/doc/fr/weechat_plugin_api.fr.txt
+++ b/doc/fr/weechat_plugin_api.fr.txt
@@ -7982,6 +7982,7 @@ Paramètres :
** 'text_search_input': texte saisi sauvegardé avant la recherche de texte
** 'highlight_words': liste des mots pour le highlight
** 'highlight_tags': liste des étiquettes pour le highlight
+** 'no_highlight_nicks': liste des pseudos à NE PAS mettre en valeur (highlight)
** 'localvar_xxx' : contenu de la variable locale "xxx" (remplacer "xxx" par le
nom de la variable locale à lire)
@@ -8145,6 +8146,18 @@ Paramètres :
| highlight_tags | liste d'étiquettes ("tags") séparées par des virgules |
liste d'étiquettes ("tags") à mettre en valeur pour ce tampon
+| no_highlight_nicks | liste de pseudos séparés par des virgules |
+ liste de pseudos à NE PAS mettre en valeur dans ce tampon, par exemple :
+ "joe,mike,robert"
+
+| no_highlight_nicks_add | liste de pseudos séparés par des virgules |
+ liste de pseudos à NE PAS mettre en valeur dans ce tampon, ces mots sont
+ ajoutés aux pseudos existants pour le tampon
+
+| no_highlight_nicks_del | liste de pseudos séparés par des virgules |
+ liste de pseudos à supprimer de la liste des pseudos à ne pas mettre en
+ valeur dans ce tampon
+
| key_bind_xxx | toute chaîne |
associe la nouvelle touche 'xxx', spécifique à ce tampon, la valeur est la
commande à exécuter pour cette touche
diff --git a/doc/it/weechat_plugin_api.it.txt b/doc/it/weechat_plugin_api.it.txt
index 3d47211f6..82f164d26 100644
--- a/doc/it/weechat_plugin_api.it.txt
+++ b/doc/it/weechat_plugin_api.it.txt
@@ -7959,6 +7959,8 @@ Argomenti:
** 'text_search_input': input salvato prima della ricerca nel testo
** 'highlight_words': elenco di parole da evidenziare
** 'highlight_tags': elenco di tag da evidenziare
+// TRANSLATION MISSING
+** 'no_highlight_nicks': list of nicks to NOT highlight
** 'localvar_xxx': ottiene il contenuto della variabile locale "xxx"
(sostituire "xxx" con il nome della variabile da leggere)
@@ -8124,6 +8126,20 @@ Argomenti:
| highlight_tags | elenco separato da virgole di tag |
elenco separato da virgole di tag da evidenziare in questo buffer
+// TRANSLATION MISSING
+| no_highlight_nicks | comma separated list of nicks |
+ comma separated list of nicks to NOT highlight in this buffer, for example:
+ "joe,mike,robert"
+
+// TRANSLATION MISSING
+| no_highlight_nicks_add | comma separated list of nicks |
+ comma separated list of nicks to NOT highlight in this buffer, these words are
+ added to existing nicks in buffer
+
+// TRANSLATION MISSING
+| no_highlight_nicks_del | comma separated list of nicks |
+ comma separated list of nicks to remove from non highlighted nicks on buffer
+
| key_bind_xxx | qualsiasi stringa |
assegna un nuovo tasto 'xxx', specifico per questo buffer, il valore è il
comando da eseguire per questo tasto
diff --git a/src/core/wee-upgrade.c b/src/core/wee-upgrade.c
index 90983b1e5..f6810d091 100644
--- a/src/core/wee-upgrade.c
+++ b/src/core/wee-upgrade.c
@@ -412,6 +412,8 @@ upgrade_weechat_read_cb (void *data,
infolist_string (infolist, "highlight_words"));
gui_buffer_set_highlight_tags (upgrade_current_buffer,
infolist_string (infolist, "highlight_tags"));
+ gui_buffer_set_no_highlight_nicks (upgrade_current_buffer,
+ infolist_string (infolist, "no_highlight_nicks"));
index = 0;
while (1)
{
diff --git a/src/gui/gui-buffer.c b/src/gui/gui-buffer.c
index 053abb559..4462458b8 100644
--- a/src/gui/gui-buffer.c
+++ b/src/gui/gui-buffer.c
@@ -84,7 +84,7 @@ char *gui_buffer_properties_get_integer[] =
};
char *gui_buffer_properties_get_string[] =
{ "plugin", "name", "short_name", "title", "input", "text_search_input",
- "highlight_words", "highlight_tags",
+ "highlight_words", "highlight_tags", "no_highlight_nicks",
NULL
};
char *gui_buffer_properties_get_pointer[] =
@@ -95,8 +95,9 @@ char *gui_buffer_properties_set[] =
{ "unread", "display", "print_hooks_enabled", "number", "name", "short_name",
"type", "notify", "title", "time_for_each_line", "nicklist",
"nicklist_case_sensitive", "nicklist_display_groups", "highlight_words",
- "highlight_words_add", "highlight_words_del", "highlight_tags", "input",
- "input_pos", "input_get_unknown_commands",
+ "highlight_words_add", "highlight_words_del", "highlight_tags",
+ "no_highlight_nicks", "no_highlight_nicks_add", "no_highlight_nicks_del",
+ "input", "input_pos", "input_get_unknown_commands",
NULL
};
@@ -459,6 +460,11 @@ gui_buffer_new (struct t_weechat_plugin *plugin,
new_buffer->highlight_tags = NULL;
new_buffer->highlight_tags_count = 0;
new_buffer->highlight_tags_array = NULL;
+ new_buffer->no_highlight_nicks = hashtable_new (8,
+ WEECHAT_HASHTABLE_STRING,
+ WEECHAT_HASHTABLE_STRING,
+ NULL,
+ NULL);
/* keys */
new_buffer->keys = NULL;
@@ -748,6 +754,8 @@ gui_buffer_get_string (struct t_gui_buffer *buffer, const char *property)
return buffer->highlight_words;
else if (string_strcasecmp (property, "highlight_tags") == 0)
return buffer->highlight_tags;
+ else if (string_strcasecmp (property, "no_highlight_nicks") == 0)
+ return hashtable_get_string (buffer->no_highlight_nicks, "keys");
else if (string_strncasecmp (property, "localvar_", 9) == 0)
{
ptr_value = (const char *)hashtable_get (buffer->local_variables,
@@ -1096,6 +1104,87 @@ gui_buffer_set_highlight_tags (struct t_gui_buffer *buffer,
}
/*
+ * gui_buffer_set_no_highlight_nicks: set no_highlight_nicks for a buffer
+ */
+
+void
+gui_buffer_set_no_highlight_nicks (struct t_gui_buffer *buffer,
+ const char *new_no_highlight_nicks)
+{
+ char **nicks;
+ int nicks_count, i;
+
+ hashtable_remove_all (buffer->no_highlight_nicks);
+
+ if (new_no_highlight_nicks && new_no_highlight_nicks[0])
+ {
+ nicks = string_split (new_no_highlight_nicks, ",", 0, 0, &nicks_count);
+ if (nicks)
+ {
+ for (i = 0; i < nicks_count; i++)
+ {
+ hashtable_set (buffer->no_highlight_nicks, nicks[i], NULL);
+ }
+ string_free_split (nicks);
+ }
+ }
+}
+
+/*
+ * gui_buffer_add_no_highlight_nicks: add nicks to no_highlight_nicks for a
+ * buffer
+ */
+
+void
+gui_buffer_add_no_highlight_nicks (struct t_gui_buffer *buffer,
+ const char *nicks_to_add)
+{
+ char **nicks;
+ int nicks_count, i;
+
+ if (!nicks_to_add)
+ return;
+
+ nicks = string_split (nicks_to_add, ",", 0, 0,
+ &nicks_count);
+ if (nicks)
+ {
+ for (i = 0; i < nicks_count; i++)
+ {
+ hashtable_set (buffer->no_highlight_nicks, nicks[i], NULL);
+ }
+ string_free_split (nicks);
+ }
+}
+
+/*
+ * gui_buffer_remove_no_highlight_nicks: remove nicks from no_highlight_nicks
+ * in a buffer
+ */
+
+void
+gui_buffer_remove_no_highlight_nicks (struct t_gui_buffer *buffer,
+ const char *nicks_to_remove)
+{
+ char **nicks;
+ int nicks_count, i;
+
+ if (!nicks_to_remove)
+ return;
+
+ nicks = string_split (nicks_to_remove, ",", 0, 0,
+ &nicks_count);
+ if (nicks)
+ {
+ for (i = 0; i < nicks_count; i++)
+ {
+ hashtable_remove (buffer->no_highlight_nicks, nicks[i]);
+ }
+ string_free_split (nicks);
+ }
+}
+
+/*
* gui_buffer_set_input_get_unknown_commands: set "input_get_unknown_commands"
* flag for a buffer
*/
@@ -1268,6 +1357,18 @@ gui_buffer_set (struct t_gui_buffer *buffer, const char *property,
{
gui_buffer_set_highlight_tags (buffer, value);
}
+ else if (string_strcasecmp (property, "no_highlight_nicks") == 0)
+ {
+ gui_buffer_set_no_highlight_nicks (buffer, value);
+ }
+ else if (string_strcasecmp (property, "no_highlight_nicks_add") == 0)
+ {
+ gui_buffer_add_no_highlight_nicks (buffer, value);
+ }
+ else if (string_strcasecmp (property, "no_highlight_nicks_del") == 0)
+ {
+ gui_buffer_remove_no_highlight_nicks (buffer, value);
+ }
else if (string_strncasecmp (property, "key_bind_", 9) == 0)
{
gui_keyboard_bind (buffer, property + 9, value);
@@ -1816,6 +1917,8 @@ gui_buffer_close (struct t_gui_buffer *buffer)
free (buffer->highlight_tags);
if (buffer->highlight_tags_array)
string_free_split (buffer->highlight_tags_array);
+ if (buffer->no_highlight_nicks)
+ hashtable_free (buffer->no_highlight_nicks);
gui_keyboard_free_all (&buffer->keys, &buffer->last_key,
&buffer->keys_count);
gui_buffer_local_var_remove_all (buffer);
@@ -2718,6 +2821,8 @@ gui_buffer_add_to_infolist (struct t_infolist *infolist,
return 0;
if (!infolist_new_var_string (ptr_item, "highlight_tags", buffer->highlight_tags))
return 0;
+ if (!infolist_new_var_string (ptr_item, "no_highlight_nicks", hashtable_get_string (buffer->no_highlight_nicks, "keys")))
+ return 0;
i = 0;
for (ptr_key = buffer->keys; ptr_key; ptr_key = ptr_key->next_key)
{
@@ -2898,6 +3003,12 @@ gui_buffer_print_log ()
log_printf (" prev_buffer. . . . . . : 0x%lx", ptr_buffer->prev_buffer);
log_printf (" next_buffer. . . . . . : 0x%lx", ptr_buffer->next_buffer);
+ if (ptr_buffer->no_highlight_nicks)
+ {
+ hashtable_print_log (ptr_buffer->no_highlight_nicks,
+ "no_highlight_nicks");
+ }
+
if (ptr_buffer->keys)
{
log_printf ("");
diff --git a/src/gui/gui-buffer.h b/src/gui/gui-buffer.h
index 17be7ed1d..fbe8c4afb 100644
--- a/src/gui/gui-buffer.h
+++ b/src/gui/gui-buffer.h
@@ -162,6 +162,7 @@ struct t_gui_buffer
int highlight_tags_count; /* number of tags to highlight */
/* (if 0, any tag is highlighted) */
char **highlight_tags_array; /* tags to highlight */
+ struct t_hashtable *no_highlight_nicks; /* nicks to NOT highlight */
/* keys associated to buffer */
struct t_gui_key *keys; /* keys specific to buffer */
@@ -231,6 +232,8 @@ extern void gui_buffer_set_highlight_words (struct t_gui_buffer *buffer,
const char *new_highlight_words);
extern void gui_buffer_set_highlight_tags (struct t_gui_buffer *buffer,
const char *new_highlight_tags);
+extern void gui_buffer_set_no_highlight_nicks (struct t_gui_buffer *buffer,
+ const char *new_no_highlight_nicks);
extern void gui_buffer_set_unread (struct t_gui_buffer *buffer);
extern void gui_buffer_set (struct t_gui_buffer *buffer, const char *property,
const char *value);
diff --git a/src/gui/gui-line.c b/src/gui/gui-line.c
index 3aa4b695c..f2cc03583 100644
--- a/src/gui/gui-line.c
+++ b/src/gui/gui-line.c
@@ -30,6 +30,7 @@
#include "../core/weechat.h"
#include "../core/wee-config.h"
+#include "../core/wee-hashtable.h"
#include "../core/wee-hook.h"
#include "../core/wee-infolist.h"
#include "../core/wee-log.h"
@@ -378,6 +379,24 @@ gui_line_match_tags (struct t_gui_line *line, int tags_count,
}
/*
+ * gui_line_get_nick_tag: get nick in tags: return "xxx" if tag "nick_xxx"
+ * is found
+ */
+
+const char *
+gui_line_get_nick_tag (struct t_gui_line *line)
+{
+ int i;
+
+ for (i = 0; i < line->data->tags_count; i++)
+ {
+ if (strncmp (line->data->tags_array[i], "nick_", 5) == 0)
+ return line->data->tags_array[i] + 5;
+ }
+ return NULL;
+}
+
+/*
* gui_line_has_highlight: return 1 if given message contains highlight (with
* a string in global highlight or buffer highlight)
*/
@@ -387,6 +406,7 @@ gui_line_has_highlight (struct t_gui_line *line)
{
int rc, i;
char *msg_no_color, *highlight_words;
+ const char *nick;
/*
* highlights are disabled on this buffer? (special value "-" means that
@@ -414,6 +434,17 @@ gui_line_has_highlight (struct t_gui_line *line)
line->data->buffer->highlight_tags_array))
return 0;
}
+
+ /*
+ * if a nick is defined in tags ("nick_xxx"), then check if highlight is
+ * disabled for this nick (using hashtable buffer->no_highlight_nicks)
+ */
+ nick = gui_line_get_nick_tag (line);
+ if (nick)
+ {
+ if (hashtable_has_key (line->data->buffer->no_highlight_nicks, nick))
+ return 0;
+ }
/* remove color codes from line message */
msg_no_color = gui_color_decode (line->data->message, NULL);