* src/gramps_main.py: remove local media concept

* src/RelLib.py: remove local media concept
* src/SelectObject.py: remove local media concept
* src/MediaView.py: remove local media concept
* src/EditSource.py: remove local media concept
* src/GrampsParser.py: remove local media concept
* src/AddMedia.py: remove local media concept
* src/GrampsZODB.py: delete


svn: r2942
This commit is contained in:
Don Allingham 2004-03-01 04:38:39 +00:00
parent 5aae97b744
commit a50092ff33
5 changed files with 14 additions and 282 deletions

View File

@ -121,14 +121,11 @@ class AddMediaObject:
mobj = RelLib.MediaObject()
mobj.set_description(description)
mobj.set_mime_type(type)
if type[0:5] == "image":
mobj.set_thumbnail(RelImage.build_thumbnail(filename,const.thumbScale))
self.db.add_object(mobj)
if external.get_active() == 0:
path = self.db.get_save_path()
name = RelImage.import_media_object(filename,path,mobj.get_id())
mobj.set_local(1)
else:
name = filename
name = filename
mobj.set_path(name)
if self.update:

View File

@ -226,13 +226,15 @@ class EditSource:
family = self.db.find_family_from_id(family_id)
f_id = family.get_father_id()
m_id = family.get_mother_id()
f = self.db.find_person_from_id(f_id)
m = self.db.find_person_from_id(m_id)
if f and m:
if f_id:
f = self.db.find_person_from_id(f_id)
if m_id:
m = self.db.find_person_from_id(m_id)
if f_id and m_id:
name = _("%(father)s and %(mother)s") % {
"father" : GrampsCfg.nameof(f),
"mother" : GrampsCfg.nameof(m)}
elif f:
elif f_id:
name = GrampsCfg.nameof(f)
else:
name = GrampsCfg.nameof(m)

View File

@ -489,10 +489,8 @@ class GrampsParser:
if src:
if src[0] != '/':
self.object.set_path("%s/%s" % (self.base,src))
self.object.set_local(1)
else:
self.object.set_path(src)
self.object.set_local(0)
def stop_people(self,tag):
pass
@ -518,10 +516,8 @@ class GrampsParser:
src = attrs["src"]
if src[0] != '/':
self.photo.set_path("%s/%s" % (self.base,src))
self.photo.set_local(1)
else:
self.photo.set_path(src)
self.photo.set_local(0)
else:
a = RelLib.Attribute()
a.set_type(key)
@ -1038,10 +1034,8 @@ class GrampsImportParser(GrampsParser):
if src:
if src[0] != '/':
self.object.set_path("%s/%s" % (self.db.get_save_path(),src))
self.object.set_local(1)
else:
self.object.set_path(src)
self.object.set_local(0)
def append_value(orig,val):
if orig:

View File

@ -1,259 +0,0 @@
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2002 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
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
from ZODB import Persistent
from ZODB.PersistentList import PersistentList
from ZODB.dbmStorage import gdbmStorage
from ZODB.DB import DB
from BTrees.OOBTree import OOBTree
from UserDict import UserDict
import RelLib
import const
class PersistentReference(Persistent):
def __init__(self, ob):
self.ob = ob
def getOb(self):
return self.ob
class PersonWrapper:
_real = None
def __init__(self, real, map):
self._real = real
self._map_ref = PersistentReference(map)
self.id = real.get_id()
self.PrimaryName = real.get_primary_name()
self.gender = real.get_gender()
self.birth = real.get_birth()
self.death = real.get_death()
def _notifyChange(self):
# Trigger a change to the PersonMap.
self._map_ref.getOb()[self.id] = self
def get_id(self):
return self.id
def set_id(self, id):
self._real.set_id(id)
self.id = self._real.get_id()
self._notifyChange()
def get_primary_name(self):
return self.PrimaryName
def set_primary_name(self, name):
self._real.set_primary_name(name)
self.PrimaryName = self._real.get_primary_name()
self._notifyChange()
def get_gender(self):
return self.gender
def set_gender(self, gender):
self._real.set_gender(gender)
self.gender = self._real.get_gender()
self._notifyChange()
def get_birth(self):
return self.birth
def set_birth(self, birth):
self._real.set_birth(birth)
self.birth = self._real.get_birth()
self._notifyChange()
def get_death(self):
return self.death
def set_death(self, death):
self._real.set_death(death)
self.death = self._real.get_death()
self._notifyChange()
for key, value in RelLib.Person.__dict__.items():
if not key.startswith('_'):
code = ("def %s(self, *args, **kw): "
"return apply(self._real.%s, args, kw)") % (key, key)
d = {}
exec code in d
PersonWrapper.__dict__[key] = d[key]
class PersonMap(Persistent, UserDict):
def __init__(self):
self.data = OOBTree()
def __setitem__(self, key, value):
if not isinstance(value, PersonWrapper):
# Create the PersonWrapper.
assert isinstance(value, RelLib.Person)
value = PersonWrapper(value, self)
self.data[key] = value
def update(self):
# This probably shouldn't be called anyway.
raise NotImplementedError
def copy(self):
# This probably shouldn't be called anyway.
raise NotImplementedError
class GrampsZODB(RelLib.GrampsDB):
def __init__(self):
self.conn = None
RelLib.GrampsDB.__init__(self)
def get_type(self):
return 'GrampsZODB'
def close(self):
self.db.close()
def get_base(self):
return const.zodbFile
def need_autosave(self):
return 0
def new(self):
RelLib.GrampsDB.new(self)
self.familyMap = OOBTree()
self.personMap = PersonMap()
self.sourceMap = OOBTree()
self.placeMap = OOBTree()
self.personTable = OOBTree()
self.placeTable = OOBTree()
self.sourceTable = OOBTree()
self.need_commit = 0
if self.conn:
self.db.close()
self.conn.close()
self.conn = None
def save(self,name,callback):
get_transaction().commit()
if self.conn == None:
self.load(name,callback)
def get_object(self,tag):
if self.root.has_key(tag):
item = self.root[tag]
else:
item = OOBTree()
self.root[tag] = item
self.need_commit = 1
return item
def get_display_table(self,src,tag):
if self.root.has_key(tag):
table = self.root[tag]
else:
table = OOBTree()
for key in src.keys():
obj = src[key]
table[key] = obj.get_display_info()
self.root[tag] = table
self.need_commit = 1
return table
def load(self,name,callback):
self.db = DB(gdbmStorage(name,'w'))
self.conn = self.db.open()
self.root = self.conn.root()
self.need_commit = 0
self.familyMap = self.get_object('familyMap')
if self.root.has_key('personMap'):
self.personMap = self.root['personMap']
else:
self.personMap = PersonMap()
self.root['personMap'] = self.personMap
self.need_commit = 1
self.personTable = self.get_display_table(self.personMap,'personTable')
if self.root.has_key('surnames'):
self.surnames = self.root['surnames']
else:
self.surnames = PersistentList()
for key in self.personMap.keys():
person = self.personMap[key]
self.add_surname(person.get_primary_name().get_surname())
self.root['surnames'] = self.surnames
self.need_commit = 1
self.sourceMap = self.get_object('sourceMap')
self.sourceTable = self.get_display_table(self.sourceMap,'sourceTable')
self.placeMap = self.get_object('placeMap')
self.placeTable = self.get_display_table(self.placeMap,'placeTable')
if self.root.has_key('default'):
self.default = self.root['default']
else:
self.default = None
self.root['default'] = self.default
self.need_commit = 1
if self.root.has_key('bookmarks'):
self.bookmarks = self.root['bookmarks']
else:
self.bookmarks = []
self.root['bookmarks'] = self.bookmarks
self.need_commit = 1
if self.need_commit:
get_transaction().commit()
return 1
def set_default_person(self,person):
"""sets the default Person to the passed instance"""
RelLib.GrampsDB.set_default_person(self,person)
self.root['default'] = person

View File

@ -205,9 +205,6 @@ class MediaView:
if object.get_mime_type()[0:5] == "image":
Utils.add_menuitem(menu,_("Edit with the GIMP"),
None,self.popup_edit_photo)
if object.get_local() == 0:
Utils.add_menuitem(menu,_("Convert to local copy"),None,
self.popup_convert_to_private)
item = gtk.MenuItem()
item.show()
menu.append(item)
@ -259,10 +256,7 @@ class MediaView:
title = src.get_description()
id = src.get_id()
type = Utils.get_mime_description(src.get_mime_type())
if src.get_local():
path = _("<local copy>")
else:
path = src.get_path()
path = src.get_path()
stitle = string.upper(title)
iter = self.model.append()
@ -359,6 +353,8 @@ class MediaView:
photo = RelLib.MediaObject()
photo.set_path(name)
photo.set_mime_type(mime)
if mime[0:5] == "image":
photo.set_thumbnail(RelImage.build_thumbnail(name))
description = os.path.basename(name)
photo.set_description(description)
self.db.add_object(photo)
@ -384,6 +380,8 @@ class MediaView:
mime = Utils.get_mime_type(tfile)
photo = RelLib.MediaObject()
photo.set_mime_type(mime)
if mime[0:5] == "image":
photo.set_thumbnail(RelImage.build_thumbnail(name))
photo.set_description(d)
photo.setLocal(1)
photo.set_path(tfile)