httpd_output: clear the client's page queue on cancel
When the httpd output is cancelled, it freed all pages, but didn't remove them from the queue. Call g_queue_clear() and remove the write source id.
This commit is contained in:
parent
50c2dde5b5
commit
58844aabac
@ -409,13 +409,24 @@ httpd_client_queue_size(const struct httpd_client *client)
|
||||
return size;
|
||||
}
|
||||
|
||||
/* g_queue_clear() was introduced in GLib 2.14 */
|
||||
#if !GLIB_CHECK_VERSION(2,14,0)
|
||||
#define g_queue_clear(q) do { g_queue_free(q); q = g_queue_new(); } while (0)
|
||||
#endif
|
||||
|
||||
void
|
||||
httpd_client_cancel(const struct httpd_client *client)
|
||||
httpd_client_cancel(struct httpd_client *client)
|
||||
{
|
||||
if (client->state != RESPONSE)
|
||||
return;
|
||||
|
||||
g_queue_foreach(client->pages, httpd_client_unref_page, NULL);
|
||||
g_queue_clear(client->pages);
|
||||
|
||||
if (client->write_source_id != 0 && client->current_page == NULL) {
|
||||
g_source_remove(client->write_source_id);
|
||||
client->write_source_id = 0;
|
||||
}
|
||||
}
|
||||
|
||||
static GIOStatus
|
||||
|
@ -54,7 +54,7 @@ httpd_client_queue_size(const struct httpd_client *client);
|
||||
* Clears the page queue.
|
||||
*/
|
||||
void
|
||||
httpd_client_cancel(const struct httpd_client *client);
|
||||
httpd_client_cancel(struct httpd_client *client);
|
||||
|
||||
/**
|
||||
* Appends a page to the client's queue.
|
||||
|
Loading…
Reference in New Issue
Block a user