From: Mikel Astiz <mikel.astiz@xxxxxxxxxxxx> Previous implementation of session_terminate_transfer assumed that the transfer being terminated would always be the active one. However, it should be possible to cancel any queued transfer using the D-Bus api. --- client/session.c | 27 +++++++++++++++++++++++---- 1 files changed, 23 insertions(+), 4 deletions(-) diff --git a/client/session.c b/client/session.c index 7f387d4..3429f0a 100644 --- a/client/session.c +++ b/client/session.c @@ -764,14 +764,31 @@ static void session_process_queue(struct obc_session *session) obc_session_unref(session); } +static gint pending_transfer_cmptransfer(gconstpointer a, gconstpointer b) +{ + const struct pending_request *p = a; + const struct obc_transfer *transfer = b; + + return p->transfer < transfer ? -1 : (p->transfer > transfer ? 1 : 0); +} + static void session_terminate_transfer(struct obc_session *session, struct obc_transfer *transfer, GError *gerr) { struct pending_request *p = session->p; - if (p == NULL || p->transfer != transfer) - return; + if (p == NULL || p->transfer != transfer) { + GList *match; + + match = g_list_find_custom(session->queue->head, transfer, + pending_transfer_cmptransfer); + if (match == NULL) + return; + + p = match->data; + g_queue_delete_link(session->queue, match); + } obc_session_ref(session); @@ -779,9 +796,11 @@ static void session_terminate_transfer(struct obc_session *session, p->func(session, gerr, p->data); pending_request_free(p); - session->p = NULL; - session_process_queue(session); + if (p == session->p) { + session->p = NULL; + session_process_queue(session); + } obc_session_unref(session); } -- 1.7.6.5 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html