[evolution] EHTTPRequest: Rearrange free functions and set error on failure
- From: Milan Crha <mcrha src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution] EHTTPRequest: Rearrange free functions and set error on failure
- Date: Thu, 13 Oct 2022 10:56:18 +0000 (UTC)
commit 93fd2541f229590a6c13d610f8375374dd6b9933
Author: Milan Crha <mcrha redhat com>
Date: Thu Oct 13 12:53:22 2022 +0200
EHTTPRequest: Rearrange free functions and set error on failure
Two changes:
a) rearrange free functions - the input stream can access some
underlying libsoup structures, which can be freed together
with the message or the session, thus rather free the objects
in the reverse order than they had been created;
b) the function did not propagate the error on failure, thus make
sure any error is returned in such case.
src/mail/e-http-request.c | 11 +++++++----
1 file changed, 7 insertions(+), 4 deletions(-)
---
diff --git a/src/mail/e-http-request.c b/src/mail/e-http-request.c
index a30911e801..7d9853f109 100644
--- a/src/mail/e-http-request.c
+++ b/src/mail/e-http-request.c
@@ -369,16 +369,16 @@ e_http_request_process_sync (EContentRequest *request,
cancelled_id = g_cancellable_connect (cancellable, G_CALLBACK
(http_request_cancelled_cb), temp_session, NULL);
soup_message_headers_append (soup_message_get_request_headers (message), "Connection",
"close");
- input_stream = soup_session_send (temp_session, message, cancellable, NULL);
+ input_stream = soup_session_send (temp_session, message, cancellable, error);
if (cancellable && cancelled_id)
g_cancellable_disconnect (cancellable, cancelled_id);
if (!input_stream || !SOUP_STATUS_IS_SUCCESSFUL (soup_message_get_status (message))) {
g_debug ("Failed to request %s (code %d)", use_uri, soup_message_get_status
(message));
+ g_clear_object (&input_stream);
g_object_unref (message);
g_object_unref (temp_session);
- g_clear_object (&input_stream);
goto cleanup;
}
@@ -406,9 +406,9 @@ e_http_request_process_sync (EContentRequest *request,
if (!g_error_matches (local_error, G_IO_ERROR, G_IO_ERROR_CANCELLED))
g_warning ("Failed to write data to cache stream: %s",
local_error->message);
g_clear_error (&local_error);
+ g_clear_object (&input_stream);
g_object_unref (message);
g_object_unref (temp_session);
- g_clear_object (&input_stream);
goto cleanup;
}
@@ -445,9 +445,9 @@ e_http_request_process_sync (EContentRequest *request,
}
}
+ g_clear_object (&input_stream);
g_object_unref (message);
g_object_unref (temp_session);
- g_clear_object (&input_stream);
d (printf ("Received image from %s\n"
"Content-Type: %s\n"
@@ -460,6 +460,9 @@ e_http_request_process_sync (EContentRequest *request,
cleanup:
g_clear_object (&cache);
+ if (!success && error && !*error)
+ g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED, "Failed to get resource '%s'", use_uri);
+
g_free (use_uri);
g_free (uri_md5);
g_free (mail_uri);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]