From e4ebeb247a33642cd5f0e1ef3ce639d02251b0a2 Mon Sep 17 00:00:00 2001 From: Paul Franklin Date: Wed, 18 Mar 2015 14:04:26 -0700 Subject: [PATCH] 7155: Support creating directories in various scenarios --- src/gui/plug/report/_reportdialog.py | 21 ++++++++++++++------- src/plugins/export/ExportXml.py | 6 ++++++ 2 files changed, 20 insertions(+), 7 deletions(-) diff --git a/src/gui/plug/report/_reportdialog.py b/src/gui/plug/report/_reportdialog.py index 42b4a3de7..f2da669fc 100644 --- a/src/gui/plug/report/_reportdialog.py +++ b/src/gui/plug/report/_reportdialog.py @@ -533,13 +533,20 @@ class ReportDialog(ManagedWindow.ManagedWindow): # we will need to create the file/dir # need to make sure we can create in the parent dir parent_dir = os.path.dirname(os.path.normpath(self.target_path)) - if not os.access(parent_dir, os.W_OK): - ErrorDialog(_('Permission problem'), - _("You do not have permission to create " - "%s\n\n" - "Please select another path or correct " - "the permissions.") % self.target_path - ) + if os.path.isdir(parent_dir): + if not os.access(parent_dir, os.W_OK): + ErrorDialog(_('Permission problem'), + _("You do not have permission to create " + "%s\n\n" + "Please select another path or correct " + "the permissions.") % self.target_path + ) + return None + else: + ErrorDialog(_('No directory'), + _('There is no directory %s.\n\n' + 'Please select another directory ' + 'or create it.') % parent_dir ) return None self.set_default_directory(os.path.dirname(self.target_path) + os.sep) diff --git a/src/plugins/export/ExportXml.py b/src/plugins/export/ExportXml.py index 5b2e61bba..714b86b8e 100644 --- a/src/plugins/export/ExportXml.py +++ b/src/plugins/export/ExportXml.py @@ -140,6 +140,12 @@ class GrampsXmlWriter(UpdateCallback): "Please make sure you have write access to the " "directory and try again.")) return 0 + else: + raise DbWriteFailure(_('No directory'), + _('There is no directory %s.\n\n' + 'Please select another directory ' + 'or create it.') % base ) + return 0 if os.path.exists(filename): if not os.access(filename, os.W_OK):