On 19/10/2020 18.37, Maxim Levitsky wrote: > The g_list_remove_link doesn't free the link element, > opposed to what I thought. > Switch to g_list_delete_link that does free it. > > Also refactor the code a bit. > Thanks for Max Reitz for helping me with this. > > Signed-off-by: Maxim Levitsky <mlevi...@redhat.com> > --- > tests/qtest/libqtest.c | 11 ++++------- > 1 file changed, 4 insertions(+), 7 deletions(-) > > diff --git a/tests/qtest/libqtest.c b/tests/qtest/libqtest.c > index bd96cb6fdd..9ae052d566 100644 > --- a/tests/qtest/libqtest.c > +++ b/tests/qtest/libqtest.c > @@ -795,15 +795,12 @@ void qtest_qmp_send_raw(QTestState *s, const char *fmt, > ...) > > QDict *qtest_qmp_event_ref(QTestState *s, const char *event) > { > - GList *next = NULL; > - QDict *response; > - > - for (GList *it = s->pending_events; it != NULL; it = next) { > + while (s->pending_events) { > > - next = it->next; > - response = (QDict *)it->data; > + GList *first = s->pending_events; > + QDict *response = (QDict *)first->data; > > - s->pending_events = g_list_remove_link(s->pending_events, it); > + s->pending_events = g_list_delete_link(s->pending_events, first); > > if (!strcmp(qdict_get_str(response, "event"), event)) { > return response; >
Thanks, queued (together with patch 2) to qtest-next: https://gitlab.com/huth/qemu/-/commits/qtest-next/ Thomas