x11: Iterate over selections in a safer manner for event handling
It might be the case that handling an event induces the stream to trigger completion, hence removing itself from the list. In that case we would operate on the no longer valid list element to fetch the next one. Keep a pointer to the next element beforehand, so we can tiptoe over streams that did remove themselves. https://gitlab.gnome.org/GNOME/mutter/merge_requests/869
This commit is contained in:
parent
e1fa0734a9
commit
45a8806e65
1 changed files with 14 additions and 4 deletions
|
@ -1734,11 +1734,21 @@ process_selection_event (MetaX11Display *x11_display,
|
||||||
|
|
||||||
handled |= meta_x11_selection_handle_event (x11_display, event);
|
handled |= meta_x11_selection_handle_event (x11_display, event);
|
||||||
|
|
||||||
for (l = x11_display->selection.input_streams; l && !handled; l = l->next)
|
for (l = x11_display->selection.input_streams; l && !handled;)
|
||||||
handled |= meta_x11_selection_input_stream_xevent (l->data, event);
|
{
|
||||||
|
GList *next = l->next;
|
||||||
|
|
||||||
for (l = x11_display->selection.output_streams; l && !handled; l = l->next)
|
handled |= meta_x11_selection_input_stream_xevent (l->data, event);
|
||||||
handled |= meta_x11_selection_output_stream_xevent (l->data, event);
|
l = next;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (l = x11_display->selection.output_streams; l && !handled;)
|
||||||
|
{
|
||||||
|
GList *next = l->next;
|
||||||
|
|
||||||
|
handled |= meta_x11_selection_output_stream_xevent (l->data, event);
|
||||||
|
l = next;
|
||||||
|
}
|
||||||
|
|
||||||
return handled;
|
return handled;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue