Blame SOURCES/xsane-0.999-no-file-selected.patch

8ceb32
From 2f7abcaa7ad39f118b2f49fdcba9c90b37b3d972 Mon Sep 17 00:00:00 2001
8ceb32
From: Nils Philippsen <nils@redhat.com>
8ceb32
Date: Fri, 5 Jul 2013 16:15:55 +0200
8ceb32
Subject: [PATCH] patch: no-file-selected
8ceb32
8ceb32
Squashed commit of the following:
8ceb32
8ceb32
commit f887550276e324151947960292a7266c71aeb573
8ceb32
Author: Pavel Polischouk <pavel.polischouk@gmail.com>
8ceb32
Date:   Fri Nov 25 23:55:49 2011 -0500
8ceb32
8ceb32
    fix changing working directory (#621778)
8ceb32
8ceb32
    The patch checks the value returned by xsane_back_gtk_get_filename. In
8ceb32
    most places it will check the result properly (taking 0 for success),
8ceb32
    except one case where it takes 0 for an error, and this happens in
8ceb32
    xsane_browse_filename_callback (xsane-front-gtk.c). The new code would
8ceb32
    abort copying the filename into preferences structure if 0 was returned,
8ceb32
    and that's the OK case. I'm very curious how wonderfully it would blow
8ceb32
    up if an actual error was returned, but that's a different story.
8ceb32
8ceb32
commit 2c02ddd8282fa231107d8860aee4d92bdb5cb8e8
8ceb32
Author: Nils Philippsen <nils@redhat.com>
8ceb32
Date:   Fri Nov 19 12:25:54 2010 +0100
8ceb32
8ceb32
    don't crash if no files are selected (#608047)
8ceb32
---
8ceb32
 src/xsane-back-gtk.c  | 20 ++++++++++++++++----
8ceb32
 src/xsane-front-gtk.c |  6 +++++-
8ceb32
 2 files changed, 21 insertions(+), 5 deletions(-)
8ceb32
8ceb32
diff --git a/src/xsane-back-gtk.c b/src/xsane-back-gtk.c
8ceb32
index bca9eb2..6ef1506 100644
8ceb32
--- a/src/xsane-back-gtk.c
8ceb32
+++ b/src/xsane-back-gtk.c
8ceb32
@@ -1111,6 +1111,11 @@ static void xsane_back_gtk_filetype2_callback(GtkWidget *widget, gpointer data)
8ceb32
 
8ceb32
   chooser_filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(filechooser));
8ceb32
 
8ceb32
+  if (!chooser_filename)
8ceb32
+  {
8ceb32
+    return;
8ceb32
+  }
8ceb32
+
8ceb32
   if ((new_filetype) && (*new_filetype))
8ceb32
   {
8ceb32
     extension = strrchr(chooser_filename, '.');
8ceb32
@@ -1505,12 +1510,19 @@ int xsane_back_gtk_get_filename(const char *label, const char *default_name, siz
8ceb32
 #endif
8ceb32
 
8ceb32
     chooser_filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(filechooser));
8ceb32
-    strncpy(filename, chooser_filename, max_len - 1);
8ceb32
-    g_free(chooser_filename);
8ceb32
+    if (chooser_filename)
8ceb32
+    {
8ceb32
+      strncpy(filename, chooser_filename, max_len - 1);
8ceb32
+      g_free(chooser_filename);
8ceb32
 
8ceb32
-    filename[max_len - 1] = '\0';
8ceb32
+      filename[max_len - 1] = '\0';
8ceb32
 
8ceb32
-    ok = TRUE;
8ceb32
+      ok = TRUE;
8ceb32
+    }
8ceb32
+    else
8ceb32
+    {
8ceb32
+      ok = FALSE;
8ceb32
+    }
8ceb32
   }
8ceb32
 
8ceb32
   gtk_widget_destroy(filechooser);
8ceb32
diff --git a/src/xsane-front-gtk.c b/src/xsane-front-gtk.c
8ceb32
index 4c973fb..7bb49b0 100644
8ceb32
--- a/src/xsane-front-gtk.c
8ceb32
+++ b/src/xsane-front-gtk.c
8ceb32
@@ -1333,7 +1333,11 @@ static void xsane_browse_filename_callback(GtkWidget *widget, gpointer data)
8ceb32
   snprintf(windowname, sizeof(windowname), "%s %s %s", xsane.prog_name, WINDOW_OUTPUT_FILENAME, xsane.device_text);
8ceb32
 
8ceb32
   umask((mode_t) preferences.directory_umask); /* define new file permissions */    
8ceb32
-  xsane_back_gtk_get_filename(windowname, filename, sizeof(filename), filename, &preferences.filetype, &preferences.cms_function, XSANE_FILE_CHOOSER_ACTION_SELECT_SAVE, show_extra_widgets, XSANE_FILE_FILTER_ALL | XSANE_FILE_FILTER_IMAGES, XSANE_FILE_FILTER_IMAGES);
8ceb32
+  if (xsane_back_gtk_get_filename(windowname, filename, sizeof(filename), filename, &preferences.filetype, &preferences.cms_function, XSANE_FILE_CHOOSER_ACTION_SELECT_SAVE, show_extra_widgets, XSANE_FILE_FILTER_ALL | XSANE_FILE_FILTER_IMAGES, XSANE_FILE_FILTER_IMAGES) < 0)
8ceb32
+  {
8ceb32
+    xsane_set_sensitivity(TRUE);
8ceb32
+    return;
8ceb32
+  }
8ceb32
   umask(XSANE_DEFAULT_UMASK); /* define new file permissions */    
8ceb32
 
8ceb32
   if (preferences.filename)
8ceb32
-- 
8ceb32
1.8.3.1
8ceb32