summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog1
-rw-r--r--src/gui/gui-line.c35
-rw-r--r--src/gui/gui-window.c45
-rw-r--r--src/gui/gui-window.h5
4 files changed, 76 insertions, 10 deletions
diff --git a/ChangeLog b/ChangeLog
index e4ce71299..6248b1422 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -14,6 +14,7 @@ http://weechat.org/files/releasenotes/ReleaseNotes-devel.html[release notes]
Version 0.4.2 (under dev!)
--------------------------
+* core: fix random crash on mouse actions (bug #39094)
* core: set options weechat.look.color_inactive_{buffer|window} to "on" by
default
* core: add infolist "layout" and hdata "layout", "layout_buffer" and
diff --git a/src/gui/gui-line.c b/src/gui/gui-line.c
index c4c4cbef2..33bc86d55 100644
--- a/src/gui/gui-line.c
+++ b/src/gui/gui-line.c
@@ -792,7 +792,7 @@ gui_line_remove_from_list (struct t_gui_buffer *buffer,
{
struct t_gui_window *ptr_win;
struct t_gui_window_scroll *ptr_scroll;
- int i, update_prefix_max_length, prefix_length, prefix_is_nick;
+ int update_prefix_max_length, prefix_length, prefix_is_nick;
for (ptr_win = gui_windows; ptr_win; ptr_win = ptr_win->next_window)
{
@@ -808,14 +808,7 @@ gui_line_remove_from_list (struct t_gui_buffer *buffer,
}
}
/* remove line from coords */
- if (ptr_win->coords)
- {
- for (i = 0; i < ptr_win->coords_size; i++)
- {
- if (ptr_win->coords[i].line == line)
- gui_window_coords_init_line (ptr_win, i);
- }
- }
+ gui_window_coords_remove_line (ptr_win, line);
}
gui_line_get_prefix_for_display (line, NULL, &prefix_length, NULL,
@@ -1184,6 +1177,7 @@ gui_line_add_y (struct t_gui_buffer *buffer, int y, const char *message)
{
struct t_gui_line *ptr_line, *new_line;
struct t_gui_line_data *new_line_data;
+ struct t_gui_window *ptr_win;
/* search if line exists for "y" */
for (ptr_line = buffer->own_lines->first_line; ptr_line;
@@ -1256,7 +1250,16 @@ gui_line_add_y (struct t_gui_buffer *buffer, int y, const char *message)
/* set message for line */
if (ptr_line->data->message)
+ {
+ /* remove line from coords if the content is changing */
+ for (ptr_win = gui_windows; ptr_win; ptr_win = ptr_win->next_window)
+ {
+ gui_window_coords_remove_line (ptr_win, ptr_line);
+ }
+
+ /* free message in line */
free (ptr_line->data->message);
+ }
ptr_line->data->message = (message) ? strdup (message) : strdup ("");
/* check if line is filtered or not */
@@ -1444,7 +1447,8 @@ gui_line_hdata_line_data_update_cb (void *data,
{
const char *value;
struct t_gui_line_data *line_data;
- int rc;
+ struct t_gui_window *ptr_win;
+ int rc, update_coords;
/* make C compiler happy */
(void) data;
@@ -1452,6 +1456,7 @@ gui_line_hdata_line_data_update_cb (void *data,
line_data = (struct t_gui_line_data *)pointer;
rc = 0;
+ update_coords = 0;
if (hashtable_has_key (hashtable, "date"))
{
@@ -1463,6 +1468,7 @@ gui_line_hdata_line_data_update_cb (void *data,
free (line_data->str_time);
line_data->str_time = gui_chat_get_time_string (line_data->date);
rc++;
+ update_coords = 1;
}
}
@@ -1502,6 +1508,7 @@ gui_line_hdata_line_data_update_cb (void *data,
gui_chat_strlen_screen (line_data->prefix) : 0;
gui_line_compute_prefix_max_length (line_data->buffer->lines);
rc++;
+ update_coords = 1;
}
if (hashtable_has_key (hashtable, "message"))
@@ -1509,10 +1516,18 @@ gui_line_hdata_line_data_update_cb (void *data,
value = hashtable_get (hashtable, "message");
hdata_set (hdata, pointer, "message", value);
rc++;
+ update_coords = 1;
}
if (rc > 0)
{
+ if (update_coords)
+ {
+ for (ptr_win = gui_windows; ptr_win; ptr_win = ptr_win->next_window)
+ {
+ gui_window_coords_remove_line_data (ptr_win, line_data);
+ }
+ }
gui_filter_buffer (line_data->buffer, line_data);
gui_buffer_ask_chat_refresh (line_data->buffer, 1);
}
diff --git a/src/gui/gui-window.c b/src/gui/gui-window.c
index 9c99c6623..f4045796c 100644
--- a/src/gui/gui-window.c
+++ b/src/gui/gui-window.c
@@ -862,6 +862,51 @@ gui_window_coords_init_line (struct t_gui_window *window, int line)
}
/*
+ * Removes a line from coordinates: each time the line is found in the array
+ * "coords", it is reinitialized.
+ */
+
+void
+gui_window_coords_remove_line (struct t_gui_window *window,
+ struct t_gui_line *line)
+{
+ int i;
+
+ if (!window->coords)
+ return;
+
+ for (i = 0; i < window->coords_size; i++)
+ {
+ if (window->coords[i].line == line)
+ gui_window_coords_init_line (window, i);
+ }
+}
+
+/*
+ * Removes a line from coordinates: each time a line with data == line_data is
+ * found in the array "coords", it is reinitialized.
+ */
+
+void
+gui_window_coords_remove_line_data (struct t_gui_window *window,
+ struct t_gui_line_data *line_data)
+{
+ int i;
+
+ if (!window->coords)
+ return;
+
+ for (i = 0; i < window->coords_size; i++)
+ {
+ if (window->coords[i].line
+ && (window->coords[i].line->data == line_data))
+ {
+ gui_window_coords_init_line (window, i);
+ }
+ }
+}
+
+/*
* Allocates and initializes coordinates for window.
*/
diff --git a/src/gui/gui-window.h b/src/gui/gui-window.h
index fad84229f..1dacf722c 100644
--- a/src/gui/gui-window.h
+++ b/src/gui/gui-window.h
@@ -22,6 +22,7 @@
struct t_infolist;
struct t_gui_bar_window;
+struct t_gui_line_data;
/* window structures */
@@ -164,6 +165,10 @@ extern void gui_window_set_layout_plugin_name (struct t_gui_window *window,
extern void gui_window_set_layout_buffer_name (struct t_gui_window *window,
const char *buffer_name);
extern void gui_window_coords_init_line (struct t_gui_window *window, int line);
+extern void gui_window_coords_remove_line (struct t_gui_window *window,
+ struct t_gui_line *line);
+extern void gui_window_coords_remove_line_data (struct t_gui_window *window,
+ struct t_gui_line_data *line_data);
extern void gui_window_coords_alloc (struct t_gui_window *window);
extern void gui_window_free (struct t_gui_window *window);
extern void gui_window_switch_previous (struct t_gui_window *window);