From c30665523afb7df3d10015e804844e19553ea50f Mon Sep 17 00:00:00 2001 From: Alex Roitman Date: Wed, 14 May 2003 19:21:18 +0000 Subject: [PATCH] More missing media handling svn: r1529 --- src/plugins/WriteCD.py | 126 ++++++++++++++++++++++++++++++++++++++-- src/plugins/WritePkg.py | 124 ++++++++++++++++++++++++++------------- 2 files changed, 203 insertions(+), 47 deletions(-) diff --git a/src/plugins/WriteCD.py b/src/plugins/WriteCD.py index e7c1e1272..efb5cae42 100644 --- a/src/plugins/WriteCD.py +++ b/src/plugins/WriteCD.py @@ -1,7 +1,7 @@ # # Gramps - a GTK+/GNOME based genealogy program # -# Copyright (C) 2000 Donald N. Allingham +# Copyright (C) 2000-2003 Donald N. Allingham # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -18,7 +18,7 @@ # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # -"Export to GRAMPS package" +"Export to CD (nautilus)" #------------------------------------------------------------------------- # @@ -44,8 +44,10 @@ import gnome.vfs # #------------------------------------------------------------------------- import WriteXML -import TarFile import Utils +import const +from QuestionDialog import MissingMediaDialog +import RelImage from intl import gettext as _ @@ -89,18 +91,130 @@ class PackageWriter: self.top.signal_autoconnect(dic) self.top.get_widget("packageExport").show() + def vfs_copy(self,dir_name,filename,newfilename=""): + # Everything has to be ascii for the CD + dir_name = dir_name.encode('ascii') + filename = filename.encode('ascii') + newfilename = newfilename.encode('ascii') + + orig_file = open(filename,"r") + if not newfilename: + newfilename = filename + new_vfsname = 'burn:///%s/%s' % (dir_name,newfilename) + new_file = gnome.vfs.create(new_vfsname,gnome.vfs.OPEN_WRITE) + buf = orig_file.read() + new_file.write(buf) + orig_file.close() + new_file.close() + def on_ok_clicked(self,obj): Utils.destroy_passed_object(obj) base = os.path.basename(self.db.getSavePath()) - + thumb_base = os.path.join(base,'.thumb') + gnome.vfs.make_directory('burn:///%s' % base,gnome.vfs.OPEN_WRITE) + gnome.vfs.make_directory('burn:///%s' % thumb_base,gnome.vfs.OPEN_WRITE) + + #-------------------------------------------------------- + def remove_clicked(): + # File is lost => remove all references and the object itself + mobj = ObjectMap[ObjectId] + for p in self.db.getFamilyMap().values(): + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + for key in self.db.getPersonKeys(): + p = self.db.getPerson(key) + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + for key in self.db.getSourceKeys(): + p = self.db.getSource(key) + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + for key in self.db.getPlaceKeys(): + p = self.db.getPlace(key) + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + self.db.removeObject(ObjectId) + Utils.modified() + + def leave_clicked(): + # File is lost => do nothing, leave as is + pass + + def select_clicked(): + # File is lost => select a file to replace the lost one + def fs_close_window(obj): + fs_top.destroy() + + def fs_ok_clicked(obj): + newfile = fs_top.get_filename() + fs_top.destroy() + if os.path.isfile(newfile): + nbase = os.path.basename(newfile) + self.vfs_copy(base,newfile,obase) + ntype = Utils.get_mime_type(newfile) + if ntype[0:5] == "image": + (oname,oext) = os.path.splitext(obase) + thumb_name = "%s.jpg" % oname + thumb_dest = "%s/.thumb/%s" % (opath,thumb_name) + RelImage.check_thumb(newfile,thumb_dest,const.thumbScale) + self.vfs_copy(thumb_base,thumb_dest,thumb_name) + + fs_top = gtk.FileSelection("%s - GRAMPS" % _("Select file")) + fs_top.hide_fileop_buttons() + fs_top.ok_button.connect('clicked',fs_ok_clicked) + fs_top.cancel_button.connect('clicked',fs_close_window) + fs_top.show() + fs_top.run() + + #---------------------------------------------------------- + + # Write media files first, since the database may be modified + # during the process (i.e. when removing object) + ObjectMap = self.db.getObjectMap() + for ObjectId in ObjectMap.keys(): + oldfile = ObjectMap[ObjectId].getPath() + opath = os.path.dirname(oldfile) + obase = os.path.basename(oldfile) + if os.path.isfile(oldfile): + self.vfs_copy(base,oldfile,obase) + otype = Utils.get_mime_type(oldfile) + if otype[0:5] == "image": + (oname,oext) = os.path.splitext(obase) + thumb_name = "%s.jpg" % oname + thumb_dest = "%s/.thumb/%s" % (opath,thumb_name) + RelImage.check_thumb(oldfile,thumb_dest,const.thumbScale) + self.vfs_copy(thumb_base,thumb_dest,thumb_name) + else: + # File is lost => ask what to do + MissingMediaDialog(_("Media object could not be found"), + _("%(file_name)s is referenced in the database, but no longer exists. " + "The file may have been deleted or moved to a different location. " + "You may choose to either remove the reference from the database, " + "keep the reference to the missing file, or select a new file." + ) % { 'file_name' : oldfile }, + remove_clicked, leave_clicked, select_clicked) + + + # Write XML now g = gnome.vfs.create('burn:///%s/data.gramps' % base,gnome.vfs.OPEN_WRITE ) - gfile = WriteXML.XmlWriter(self.db,None,1) gfile.write_handle(g) - mtime = time.time() g.close() + #------------------------------------------------------------------------- # diff --git a/src/plugins/WritePkg.py b/src/plugins/WritePkg.py index 3b8b327e0..1273559af 100644 --- a/src/plugins/WritePkg.py +++ b/src/plugins/WritePkg.py @@ -45,6 +45,7 @@ import gtk.glade import WriteXML import TarFile import Utils +from QuestionDialog import MissingMediaDialog from intl import gettext as _ @@ -94,56 +95,97 @@ class PackageWriter: self.export(name) def export(self, filename): + #-------------------------------------------------------------- + def remove_clicked(): + # File is lost => remove all references and the object itself + mobj = ObjectMap[ObjectId] + for p in self.db.getFamilyMap().values(): + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + for key in self.db.getPersonKeys(): + p = self.db.getPerson(key) + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + for key in self.db.getSourceKeys(): + p = self.db.getSource(key) + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + for key in self.db.getPlaceKeys(): + p = self.db.getPlace(key) + nl = p.getPhotoList() + for o in nl: + if o.getReference() == mobj: + nl.remove(o) + p.setPhotoList(nl) + self.db.removeObject(ObjectId) + Utils.modified() + + def leave_clicked(): + # File is lost => do nothing, leave as is + pass + + + def select_clicked(): + # File is lost => select a file to replace the lost one + def fs_close_window(obj): + fs_top.destroy() + + def fs_ok_clicked(obj): + name = fs_top.get_filename() + fs_top.destroy() + if os.path.isfile(name): + g = open(name,"rb") + t.add_file(base,mtime,g) + g.close() + + fs_top = gtk.FileSelection("%s - GRAMPS" % _("Select file")) + fs_top.hide_fileop_buttons() + fs_top.ok_button.connect('clicked',fs_ok_clicked) + fs_top.cancel_button.connect('clicked',fs_close_window) + fs_top.show() + fs_top.run() + #--------------------------------------------------------------- t = TarFile.TarFile(filename) - g = StringIO() + mtime = time.time() + # Write media files first, since the database may be modified + # during the process (i.e. when removing object) + ObjectMap = self.db.getObjectMap() + for ObjectId in ObjectMap.keys(): + oldfile = ObjectMap[ObjectId].getPath() + base = os.path.basename(oldfile) + if os.path.isfile(oldfile): + g = open(oldfile,"rb") + t.add_file(base,mtime,g) + g.close() + else: + # File is lost => ask what to do + MissingMediaDialog(_("Media object could not be found"), + _("%(file_name)s is referenced in the database, but no longer exists. " + "The file may have been deleted or moved to a different location. " + "You may choose to either remove the reference from the database, " + "keep the reference to the missing file, or select a new file." + ) % { 'file_name' : oldfile }, + remove_clicked, leave_clicked, select_clicked) + + # Write XML now + g = StringIO() gfile = WriteXML.XmlWriter(self.db,None,1) gfile.write_handle(g) mtime = time.time() t.add_file("data.gramps",mtime,g) g.close() - for f in self.db.getPersonMap().values(): - for p in f.getPhotoList(): - object = p.getReference() - base = os.path.basename(object.getPath()) - try: - g = open(object.getPath(),"rb") - t.add_file(base,mtime,g) - g.close() - except: - pass - for f in self.db.getFamilyMap().values(): - for p in f.getPhotoList(): - object = p.getReference() - base = os.path.basename(object.getPath()) - try: - g = open(object.getPath(),"rb") - t.add_file(base,mtime,g) - g.close() - except: - pass - for f in self.db.getSourceMap().values(): - for p in f.getPhotoList(): - object = p.getReference() - base = os.path.basename(object.getPath()) - try: - g = open(object.getPath(),"rb") - t.add_file(base,mtime,g) - g.close() - except: - pass - for f in self.db.getPlaceMap().values(): - for p in f.getPhotoList(): - object = p.getReference() - base = os.path.basename(object.getPath()) - try: - g = open(object.getPath(),"rb") - t.add_file(base,mtime,g) - g.close() - except: - pass t.close() #-------------------------------------------------------------------------