[Xfce4-commits] <midori:master> Save non-text as single file, checkbox otherwise

Christian Dywan noreply at xfce.org
Wed Jul 18 01:22:05 CEST 2012


Updating branch refs/heads/master
         to 3d14faf9bed31d108082f1fdd9d64bbde1174278 (commit)
       from 3259ab1be2a43cbdbbcbca8194edf6523072c833 (commit)

commit 3d14faf9bed31d108082f1fdd9d64bbde1174278
Author: Christian Dywan <christian at twotoasts.de>
Date:   Wed Jul 18 01:17:29 2012 +0200

    Save non-text as single file, checkbox otherwise
    
    Fixes: https://bugs.launchpad.net/midori/+bug/1025894

 midori/midori-browser.c |   29 +++++++++++++++++++++++------
 midori/midori-view.c    |    3 +--
 2 files changed, 24 insertions(+), 8 deletions(-)

diff --git a/midori/midori-browser.c b/midori/midori-browser.c
index b6c7563..7a30766 100644
--- a/midori/midori-browser.c
+++ b/midori/midori-browser.c
@@ -1104,6 +1104,8 @@ midori_browser_save_uri (MidoriBrowser* browser,
     GtkWidget* dialog;
     const gchar* title = midori_view_get_display_title (view);
     gchar* filename;
+    gboolean file_only;
+    GtkWidget* checkbox;
 
     if (!gtk_widget_get_visible (GTK_WIDGET (browser)))
         return;
@@ -1111,6 +1113,15 @@ midori_browser_save_uri (MidoriBrowser* browser,
     dialog = sokoke_file_chooser_dialog_new (_("Save file as"),
         GTK_WINDOW (browser), GTK_FILE_CHOOSER_ACTION_SAVE);
     gtk_file_chooser_set_do_overwrite_confirmation (GTK_FILE_CHOOSER (dialog), TRUE);
+    if (midori_view_can_view_source (view))
+    {
+        file_only = FALSE;
+        checkbox = gtk_check_button_new_with_mnemonic (_("Save associated _resources"));
+        gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (checkbox), TRUE);
+        gtk_file_chooser_set_extra_widget (GTK_FILE_CHOOSER (dialog), checkbox);
+    }
+    else
+        file_only = TRUE;
     if (last_dir && *last_dir)
         gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), last_dir);
     else
@@ -1122,7 +1133,7 @@ midori_browser_save_uri (MidoriBrowser* browser,
 
     if (uri == NULL)
         uri = midori_view_get_display_uri (view);
-    if (!g_str_equal (title, uri))
+    if (!file_only && !g_str_equal (title, uri))
         filename = midori_browser_fixup_filename (g_strdup (title));
     else
         filename = midori_browser_get_filename_suggestion_for_uri (view, uri);
@@ -1131,14 +1142,20 @@ midori_browser_save_uri (MidoriBrowser* browser,
 
     if (gtk_dialog_run (GTK_DIALOG (dialog)) == GTK_RESPONSE_OK)
     {
-        gchar* fullname;
         filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog));
-        fullname = g_strconcat (filename, ".html", NULL);
-        midori_view_save_source (view, uri, fullname);
+        file_only = !gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (checkbox));
+        if (!file_only && !g_str_equal (title, uri))
+        {
+            gchar* fullname = g_strconcat (filename, ".html", NULL);
+            midori_view_save_source (view, uri, fullname);
+            g_free (fullname);
+        }
+        else
+            midori_view_save_source (view, uri, filename);
+        if (!file_only)
+            midori_browser_save_resources (view, filename);
         katze_assign (last_dir,
             gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dialog)));
-        midori_browser_save_resources (view, filename);
-        g_free (fullname);
     }
     gtk_widget_destroy (dialog);
 }
diff --git a/midori/midori-view.c b/midori/midori-view.c
index b4d8412..e14a61a 100644
--- a/midori/midori-view.c
+++ b/midori/midori-view.c
@@ -5448,10 +5448,9 @@ const gchar*
 midori_view_fallback_extension (MidoriView* view,
                                 const gchar* extension)
 {
-    if (!view->mime_type)
-        extension = "";
     if (extension && *extension)
         return extension;
+    g_return_val_if_fail (view->mime_type != NULL, "");
     if (strstr (view->mime_type, "css"))
         return ".css";
     if (strstr (view->mime_type, "javascript"))


More information about the Xfce4-commits mailing list