diff options
author | Ting-Wei Lan <lantw44@gmail.com> | 2013-09-10 23:19:10 +0800 |
---|---|---|
committer | LAN-TW <lantw44@gmail.com> | 2013-09-10 23:19:10 +0800 |
commit | 83a349654cc6bf1984e4d757094d63ab815d3e87 (patch) | |
tree | b60063f48f51d61b794cc73fc2c3449013a4cf64 /e-util/e-attachment-store.c | |
parent | 6ae3cd7747313301ad1484b1d7f5ccd7f9129c99 (diff) | |
download | gsoc2013-evolution-83a349654cc6bf1984e4d757094d63ab815d3e87.tar gsoc2013-evolution-83a349654cc6bf1984e4d757094d63ab815d3e87.tar.gz gsoc2013-evolution-83a349654cc6bf1984e4d757094d63ab815d3e87.tar.bz2 gsoc2013-evolution-83a349654cc6bf1984e4d757094d63ab815d3e87.tar.lz gsoc2013-evolution-83a349654cc6bf1984e4d757094d63ab815d3e87.tar.xz gsoc2013-evolution-83a349654cc6bf1984e4d757094d63ab815d3e87.tar.zst gsoc2013-evolution-83a349654cc6bf1984e4d757094d63ab815d3e87.zip |
Make gnome-autoar be an optional dependencyarchive-integration-review
Diffstat (limited to 'e-util/e-attachment-store.c')
-rw-r--r-- | e-util/e-attachment-store.c | 56 |
1 files changed, 51 insertions, 5 deletions
diff --git a/e-util/e-attachment-store.c b/e-util/e-attachment-store.c index ac52083de6..c261c92e63 100644 --- a/e-util/e-attachment-store.c +++ b/e-util/e-attachment-store.c @@ -28,7 +28,10 @@ #include <errno.h> #include <glib/gi18n.h> + +#ifdef HAVE_AUTOAR #include <gnome-autoar/autoar.h> +#endif #include "e-mktemp.h" @@ -444,7 +447,9 @@ update_preview_cb (GtkFileChooser *file_chooser, g_object_unref (pixbuf); } +#ifdef HAVE_AUTOAR #define LOAD_RESPONSE_ATTACH 1 +#endif void e_attachment_store_run_load_dialog (EAttachmentStore *store, @@ -457,10 +462,12 @@ e_attachment_store_run_load_dialog (EAttachmentStore *store, GtkWidget *extra_box_widget; GtkWidget *option_display; +#ifdef HAVE_AUTOAR GtkBox *option_format_box; GtkWidget *option_format_box_widget; GtkWidget *option_format_label; GtkWidget *option_format_combo; +#endif GtkImage *preview; @@ -469,9 +476,11 @@ e_attachment_store_run_load_dialog (EAttachmentStore *store, gboolean active; gint response; +#ifdef HAVE_AUTOAR GSettings *settings; AutoarPref *arpref; int format, filter; +#endif g_return_if_fail (E_IS_ATTACHMENT_STORE (store)); g_return_if_fail (GTK_IS_WINDOW (parent)); @@ -479,14 +488,25 @@ e_attachment_store_run_load_dialog (EAttachmentStore *store, dialog = gtk_file_chooser_dialog_new ( _("Add Attachment"), parent, GTK_FILE_CHOOSER_ACTION_OPEN, +#ifdef HAVE_AUTOAR _("_Open"), GTK_RESPONSE_OK, +#endif _("_Cancel"), GTK_RESPONSE_CANCEL, - _("A_ttach"), LOAD_RESPONSE_ATTACH, NULL); +#ifdef HAVE_AUTOAR + _("A_ttach"), LOAD_RESPONSE_ATTACH, +#else + _("A_ttach"), GTK_RESPONSE_OK, +#endif + NULL); file_chooser = GTK_FILE_CHOOSER (dialog); gtk_file_chooser_set_local_only (file_chooser, FALSE); gtk_file_chooser_set_select_multiple (file_chooser, TRUE); +#ifdef HAVE_AUTOAR gtk_dialog_set_default_response (GTK_DIALOG (dialog), LOAD_RESPONSE_ATTACH); +#else + gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_OK); +#endif gtk_window_set_icon_name (GTK_WINDOW (dialog), "mail-attachment"); preview = GTK_IMAGE (gtk_image_new ()); @@ -504,6 +524,7 @@ e_attachment_store_run_load_dialog (EAttachmentStore *store, _("_Suggest automatic display of attachment")); gtk_box_pack_start (extra_box, option_display, FALSE, FALSE, 0); +#ifdef HAVE_AUTOAR option_format_box_widget = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); option_format_box = GTK_BOX (option_format_box_widget); gtk_box_pack_start (extra_box, option_format_box_widget, FALSE, FALSE, 0); @@ -518,22 +539,29 @@ e_attachment_store_run_load_dialog (EAttachmentStore *store, autoar_pref_get_default_filter (arpref)); gtk_box_pack_start (option_format_box, option_format_label, FALSE, FALSE, 0); gtk_box_pack_start (option_format_box, option_format_combo, FALSE, FALSE, 0); +#endif gtk_file_chooser_set_extra_widget (file_chooser, extra_box_widget); gtk_widget_show_all (extra_box_widget); response = gtk_dialog_run (GTK_DIALOG (dialog)); +#ifdef HAVE_AUTOAR if (response != GTK_RESPONSE_OK && response != LOAD_RESPONSE_ATTACH) +#else + if (response != GTK_RESPONSE_OK) +#endif goto exit; files = gtk_file_chooser_get_files (file_chooser); active = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (option_display)); disposition = active ? "inline" : "attachment"; +#ifdef HAVE_AUTOAR autoar_gtk_format_filter_simple_get (option_format_combo, &format, &filter); autoar_pref_set_default_format (arpref, format); autoar_pref_set_default_filter (arpref, filter); +#endif for (iter = files; iter != NULL; iter = g_slist_next (iter)) { EAttachment *attachment; @@ -544,8 +572,10 @@ e_attachment_store_run_load_dialog (EAttachmentStore *store, e_attachment_set_disposition (attachment, disposition); e_attachment_store_add_attachment (store, attachment); +#ifdef HAVE_AUTOAR g_object_set_data_full (G_OBJECT (attachment), "autoar-pref", g_object_ref (arpref), g_object_unref); +#endif e_attachment_load_async ( attachment, (GAsyncReadyCallback) @@ -558,9 +588,10 @@ e_attachment_store_run_load_dialog (EAttachmentStore *store, exit: gtk_widget_destroy (dialog); +#ifdef HAVE_AUTOAR g_object_unref (settings); g_object_unref (arpref); - +#endif } GFile * @@ -572,6 +603,7 @@ e_attachment_store_run_save_dialog (EAttachmentStore *store, GtkFileChooserAction action; GtkWidget *dialog; +#ifdef HAVE_AUTOAR GtkBox *extra_box; GtkWidget *extra_box_widget; @@ -584,6 +616,7 @@ e_attachment_store_run_save_dialog (EAttachmentStore *store, GtkWidget *extract_yes; GtkToggleButton *extract_yes_toggle; +#endif GFile *destination; const gchar *title; @@ -615,6 +648,7 @@ e_attachment_store_run_save_dialog (EAttachmentStore *store, gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_OK); gtk_window_set_icon_name (GTK_WINDOW (dialog), "mail-attachment"); +#ifdef HAVE_AUTOAR extra_box_widget = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); extra_box = GTK_BOX (extra_box_widget); @@ -643,14 +677,18 @@ e_attachment_store_run_save_dialog (EAttachmentStore *store, gtk_widget_show_all (extra_box_widget); gtk_file_chooser_set_extra_widget (file_chooser, extra_box_widget); +#endif if (action == GTK_FILE_CHOOSER_ACTION_SAVE) { EAttachment *attachment; - AutoarPref *arpref; - GSettings *settings; GFileInfo *file_info; const gchar *name = NULL; + +#ifdef HAVE_AUTOAR + AutoarPref *arpref; + GSettings *settings; gchar *mime_type; +#endif attachment = attachment_list->data; file_info = e_attachment_ref_file_info (attachment); @@ -664,6 +702,7 @@ e_attachment_store_run_save_dialog (EAttachmentStore *store, gtk_file_chooser_set_current_name (file_chooser, name); +#ifdef HAVE_AUTOAR mime_type = e_attachment_dup_mime_type (attachment); settings = g_settings_new (AUTOAR_PREF_DEFAULT_GSCHEMA_ID); arpref = autoar_pref_new_with_gsettings (settings); @@ -672,18 +711,24 @@ e_attachment_store_run_save_dialog (EAttachmentStore *store, gtk_toggle_button_set_active (extract_yes_toggle, FALSE); } - g_clear_object (&file_info); g_clear_object (&settings); g_clear_object (&arpref); g_free (mime_type); +#endif + + g_clear_object (&file_info); } response = gtk_dialog_run (GTK_DIALOG (dialog)); if (response == GTK_RESPONSE_OK) { +#ifdef HAVE_AUTOAR gboolean save_self, save_extracted; +#endif destination = gtk_file_chooser_get_file (file_chooser); + +#ifdef HAVE_AUTOAR save_self = !gtk_toggle_button_get_active (extract_yes_toggle) || !gtk_toggle_button_get_active (extract_only_toggle); save_extracted = gtk_toggle_button_get_active (extract_yes_toggle); @@ -727,6 +772,7 @@ e_attachment_store_run_save_dialog (EAttachmentStore *store, g_object_unref (settings); g_object_unref (arpref); } +#endif } else { destination = NULL; } |