1
0
mirror of https://github.com/arsenetar/dupeguru.git synced 2025-09-11 17:58:17 +00:00

[#22 state:fixed] Error-proofed the path2iphoto query and added more progress feedback to the iphoto deletion process.

--HG--
extra : convert_revision : svn%3Ac306627e-7827-47d3-bdf0-9a457c9553a1/trunk%407
This commit is contained in:
hsoft 2009-06-06 13:49:45 +00:00
parent c08fc8b911
commit 7f9895e806

View File

@ -145,19 +145,24 @@ class DupeGuruPE(app_cocoa.DupeGuru):
marked = [dupe for dupe in self.results.dupes if self.results.is_marked(dupe)] marked = [dupe for dupe in self.results.dupes if self.results.is_marked(dupe)]
self.path2iphoto = {} self.path2iphoto = {}
if any(isinstance(dupe, IPhoto) for dupe in marked): if any(isinstance(dupe, IPhoto) for dupe in marked):
j = j.start_subjob([6, 4], "Probing iPhoto. Don\'t touch it during the operation!")
a = app('iPhoto') a = app('iPhoto')
a.select(a.photo_library_album()) a.select(a.photo_library_album())
photos = as_fetch(a.photo_library_album().photos, k.item) photos = as_fetch(a.photo_library_album().photos, k.item)
for photo in photos: for photo in j.iter_with_progress(photos):
self.path2iphoto[photo.image_path()] = photo self.path2iphoto[unicode(photo.image_path())] = photo
j.start_job(self.results.mark_count, "Sending dupes to the Trash")
self.last_op_error_count = self.results.perform_on_marked(op, True) self.last_op_error_count = self.results.perform_on_marked(op, True)
del self.path2iphoto del self.path2iphoto
def _do_delete_dupe(self, dupe): def _do_delete_dupe(self, dupe):
if isinstance(dupe, IPhoto): if isinstance(dupe, IPhoto):
photo = self.path2iphoto[unicode(dupe.path)] if unicode(dupe.path) in self.path2iphoto:
app('iPhoto').remove(photo) photo = self.path2iphoto[unicode(dupe.path)]
return True app('iPhoto').remove(photo)
return True
else:
logging.warning("Could not find photo {0} in iPhoto Library", unicode(dupe.path))
else: else:
return app_cocoa.DupeGuru._do_delete_dupe(self, dupe) return app_cocoa.DupeGuru._do_delete_dupe(self, dupe)