[evolution] Bug #687998 - Attachment dialog shown when storing assigned task
- From: Milan Crha <mcrha src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution] Bug #687998 - Attachment dialog shown when storing assigned task
- Date: Mon, 12 Nov 2012 10:39:57 +0000 (UTC)
commit a92d93fdf2df62908e25b61ef88d222e6b6ec690
Author: Milan Crha <mcrha redhat com>
Date: Mon Nov 12 11:39:29 2012 +0100
Bug #687998 - Attachment dialog shown when storing assigned task
composer/e-msg-composer.c | 4 +--
widgets/misc/e-attachment.c | 72 +++++++++++++++++++++++++++++++++++++++++++
widgets/misc/e-attachment.h | 9 +++++
3 files changed, 82 insertions(+), 3 deletions(-)
---
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index 8354afa..76cafab 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -4422,9 +4422,7 @@ e_msg_composer_attach (EMsgComposer *composer,
attachment = e_attachment_new ();
e_attachment_set_mime_part (attachment, mime_part);
e_attachment_store_add_attachment (store, attachment);
- e_attachment_load_async (
- attachment, (GAsyncReadyCallback)
- e_attachment_load_handle_error, composer);
+ e_attachment_load (attachment, NULL);
g_object_unref (attachment);
}
diff --git a/widgets/misc/e-attachment.c b/widgets/misc/e-attachment.c
index 113312a..cd9385a 100644
--- a/widgets/misc/e-attachment.c
+++ b/widgets/misc/e-attachment.c
@@ -2019,6 +2019,29 @@ e_attachment_load_handle_error (EAttachment *attachment,
g_error_free (error);
}
+gboolean
+e_attachment_load (EAttachment *attachment,
+ GError **error)
+{
+ EAsyncClosure *closure;
+ GAsyncResult *result;
+ gboolean success;
+
+ g_return_val_if_fail (E_IS_ATTACHMENT (attachment), FALSE);
+
+ closure = e_async_closure_new ();
+
+ e_attachment_load_async (attachment, e_async_closure_callback, closure);
+
+ result = e_async_closure_wait (closure);
+
+ success = e_attachment_load_finish (attachment, result, error);
+
+ e_async_closure_free (closure);
+
+ return success;
+}
+
/************************* e_attachment_open_async() *************************/
typedef struct _OpenContext OpenContext;
@@ -2295,6 +2318,30 @@ e_attachment_open_handle_error (EAttachment *attachment,
g_error_free (error);
}
+gboolean
+e_attachment_open (EAttachment *attachment,
+ GAppInfo *app_info,
+ GError **error)
+{
+ EAsyncClosure *closure;
+ GAsyncResult *result;
+ gboolean success;
+
+ g_return_val_if_fail (E_IS_ATTACHMENT (attachment), FALSE);
+
+ closure = e_async_closure_new ();
+
+ e_attachment_open_async (attachment, app_info, e_async_closure_callback, closure);
+
+ result = e_async_closure_wait (closure);
+
+ success = e_attachment_open_finish (attachment, result, error);
+
+ e_async_closure_free (closure);
+
+ return success;
+}
+
/************************* e_attachment_save_async() *************************/
typedef struct _SaveContext SaveContext;
@@ -2807,3 +2854,28 @@ e_attachment_save_handle_error (EAttachment *attachment,
gtk_widget_destroy (dialog);
g_error_free (error);
}
+
+gboolean
+e_attachment_save (EAttachment *attachment,
+ GFile *in_destination,
+ GFile **out_destination,
+ GError **error)
+{
+ EAsyncClosure *closure;
+ GAsyncResult *result;
+
+ g_return_val_if_fail (E_IS_ATTACHMENT (attachment), FALSE);
+ g_return_val_if_fail (out_destination != NULL, FALSE);
+
+ closure = e_async_closure_new ();
+
+ e_attachment_save_async (attachment, in_destination, e_async_closure_callback, closure);
+
+ result = e_async_closure_wait (closure);
+
+ *out_destination = e_attachment_save_finish (attachment, result, error);
+
+ e_async_closure_free (closure);
+
+ return *out_destination != NULL;
+}
diff --git a/widgets/misc/e-attachment.h b/widgets/misc/e-attachment.h
index 26eceeb..890c132 100644
--- a/widgets/misc/e-attachment.h
+++ b/widgets/misc/e-attachment.h
@@ -115,6 +115,8 @@ void e_attachment_load_async (EAttachment *attachment,
gboolean e_attachment_load_finish (EAttachment *attachment,
GAsyncResult *result,
GError **error);
+gboolean e_attachment_load (EAttachment *attachment,
+ GError **error);
void e_attachment_open_async (EAttachment *attachment,
GAppInfo *app_info,
GAsyncReadyCallback callback,
@@ -122,6 +124,9 @@ void e_attachment_open_async (EAttachment *attachment,
gboolean e_attachment_open_finish (EAttachment *attachment,
GAsyncResult *result,
GError **error);
+gboolean e_attachment_open (EAttachment *attachment,
+ GAppInfo *app_info,
+ GError **error);
void e_attachment_save_async (EAttachment *attachment,
GFile *destination,
GAsyncReadyCallback callback,
@@ -129,6 +134,10 @@ void e_attachment_save_async (EAttachment *attachment,
GFile * e_attachment_save_finish (EAttachment *attachment,
GAsyncResult *result,
GError **error);
+gboolean e_attachment_save (EAttachment *attachment,
+ GFile *in_destination,
+ GFile **out_destination,
+ GError **error);
/* Handy GAsyncReadyCallback Functions */
void e_attachment_load_handle_error (EAttachment *attachment,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]