summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2017-03-12 20:52:20 +0100
committerSébastien Helleu <flashcode@flashtux.org>2017-03-25 14:19:48 +0100
commita8bf5eb7bab3941fb71d0b6f9bb847d695e9a218 (patch)
treef4768a2933cb4b6cbe3a10d937ca1ddf12568a1c /src/gui
parent4ef8e61ca59e2db11aeb8d521cbe6f188ef60829 (diff)
downloadweechat-a8bf5eb7bab3941fb71d0b6f9bb847d695e9a218.zip
core: add hotlist pointer in buffer structure
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/gui-buffer.c3
-rw-r--r--src/gui/gui-buffer.h3
-rw-r--r--src/gui/gui-hotlist.c3
3 files changed, 8 insertions, 1 deletions
diff --git a/src/gui/gui-buffer.c b/src/gui/gui-buffer.c
index d7fb5f828..54a52a2cf 100644
--- a/src/gui/gui-buffer.c
+++ b/src/gui/gui-buffer.c
@@ -709,6 +709,7 @@ gui_buffer_new (struct t_weechat_plugin *plugin,
new_buffer->highlight_tags_array = NULL;
/* hotlist */
+ new_buffer->hotlist = NULL;
new_buffer->hotlist_max_level_nicks = hashtable_new (
32,
WEECHAT_HASHTABLE_STRING,
@@ -4156,6 +4157,7 @@ gui_buffer_hdata_buffer_cb (const void *pointer, void *data,
HDATA_VAR(struct t_gui_buffer, highlight_tags, STRING, 0, NULL, NULL);
HDATA_VAR(struct t_gui_buffer, highlight_tags_count, INTEGER, 0, NULL, NULL);
HDATA_VAR(struct t_gui_buffer, highlight_tags_array, POINTER, 0, "highlight_tags_count", NULL);
+ HDATA_VAR(struct t_gui_buffer, hotlist, POINTER, 0, NULL, "hotlist");
HDATA_VAR(struct t_gui_buffer, hotlist_max_level_nicks, HASHTABLE, 0, NULL, NULL);
HDATA_VAR(struct t_gui_buffer, keys, POINTER, 0, NULL, "key");
HDATA_VAR(struct t_gui_buffer, last_key, POINTER, 0, NULL, "key");
@@ -4571,6 +4573,7 @@ gui_buffer_print_log ()
log_printf (" highlight_tags. . . . . : '%s'", ptr_buffer->highlight_tags);
log_printf (" highlight_tags_count. . : %d", ptr_buffer->highlight_tags_count);
log_printf (" highlight_tags_array. . : 0x%lx", ptr_buffer->highlight_tags_array);
+ log_printf (" hotlist . . . . . . . . : 0x%lx", ptr_buffer->hotlist);
log_printf (" keys. . . . . . . . . . : 0x%lx", ptr_buffer->keys);
log_printf (" last_key. . . . . . . . : 0x%lx", ptr_buffer->last_key);
log_printf (" keys_count. . . . . . . : %d", ptr_buffer->keys_count);
diff --git a/src/gui/gui-buffer.h b/src/gui/gui-buffer.h
index 7bbd27982..1f009a88a 100644
--- a/src/gui/gui-buffer.h
+++ b/src/gui/gui-buffer.h
@@ -197,7 +197,8 @@ struct t_gui_buffer
int highlight_tags_count; /* number of highlight tags */
char ***highlight_tags_array; /* array with highlight tags */
- /* hotlist settings for buffer */
+ /* hotlist */
+ struct t_gui_hotlist *hotlist; /* hotlist entry for buffer */
struct t_hashtable *hotlist_max_level_nicks; /* max hotlist level for */
/* some nicks */
diff --git a/src/gui/gui-hotlist.c b/src/gui/gui-hotlist.c
index 9bbcf65e0..86f118d35 100644
--- a/src/gui/gui-hotlist.c
+++ b/src/gui/gui-hotlist.c
@@ -99,6 +99,8 @@ gui_hotlist_free (struct t_gui_hotlist **hotlist,
if (!ptr_hotlist)
return;
+ ptr_hotlist->buffer->hotlist = NULL;
+
/* remove hotlist from queue */
if (*last_hotlist == ptr_hotlist)
*last_hotlist = ptr_hotlist->prev_hotlist;
@@ -405,6 +407,7 @@ gui_hotlist_add (struct t_gui_buffer *buffer,
else
gettimeofday (&(new_hotlist->creation_time), NULL);
new_hotlist->buffer = buffer;
+ buffer->hotlist = new_hotlist;
memcpy (new_hotlist->count, count, sizeof (new_hotlist->count));
new_hotlist->count[priority]++;
new_hotlist->next_hotlist = NULL;