diff --git a/src/GrampsParser.py b/src/GrampsParser.py index dfc404383..497341485 100644 --- a/src/GrampsParser.py +++ b/src/GrampsParser.py @@ -86,6 +86,7 @@ class GrampsParser(handler.ContentHandler): self.in_scomments = 0 self.db = database self.base = base + self.photo = None self.person = None self.family = None self.address = None @@ -230,7 +231,9 @@ class GrampsParser(handler.ContentHandler): self.attribute.setType(u2l(attrs["type"])) else: self.in_old_attr = 0 - if self.person: + if self.photo: + self.photo.addAttribute(self.attribute) + elif self.person: self.person.addAttribute(self.attribute) elif self.family: self.family.addAttribute(self.attribute) @@ -440,28 +443,31 @@ class GrampsParser(handler.ContentHandler): # #--------------------------------------------------------------------- def start_photo(self,attrs): - photo = Photo() + self.photo = Photo() for key in attrs.keys(): if key == "descrip" or key == "description": - photo.setDescription(u2l(attrs[key])) + self.photo.setDescription(u2l(attrs[key])) elif key == "src": src = u2l(attrs["src"]) if src[0] != os.sep: - photo.setPath("%s%s%s" % (self.base,os.sep,src)) - photo.setPrivate(1) + self.photo.setPath("%s%s%s" % (self.base,os.sep,src)) + self.photo.setPrivate(1) else: - photo.setPath(src) - photo.setPrivate(0) + self.photo.setPath(src) + self.photo.setPrivate(0) if self.family: - self.family.addPhoto(photo) + self.family.addPhoto(self.photo) elif self.source: - self.source.addPhoto(photo) + self.source.addPhoto(self.photo) elif self.person: - self.person.addPhoto(photo) + self.person.addPhoto(self.photo) elif self.placeobj: - self.placeobj.addPhoto(photo) + self.placeobj.addPhoto(self.photo) else: - photo.addProperty(key,u2l(attrs[key])) + a = Attribute() + a.setType(key) + a.setValue(u2l(attrs[key])) + self.photo.addAttribute(a) #--------------------------------------------------------------------- # @@ -514,14 +520,12 @@ class GrampsParser(handler.ContentHandler): def stop_address(self,tag): self.address = None - #--------------------------------------------------------------------- - # - # - # - #--------------------------------------------------------------------- def stop_places(self,tag): self.placeobj = None + def stop_photo(self,tag): + self.photo = None + def stop_placeobj(self,tag): if self.placeobj.get_title() == "": loc = self.placeobj.get_main_location() @@ -951,7 +955,7 @@ class GrampsParser(handler.ContentHandler): "parentin" : (start_parentin,None), "people" : (start_people, stop_people), "person" : (start_person, None), - "img" : (start_photo, None), + "img" : (start_photo, stop_photo), "place" : (start_place, stop_place), "places" : (None, stop_places), "placeobj" : (start_placeobj,stop_placeobj), diff --git a/src/RelLib.py b/src/RelLib.py index fdc985953..b4da08d6e 100644 --- a/src/RelLib.py +++ b/src/RelLib.py @@ -342,21 +342,17 @@ class Photo: def __init__(self,source=None): """Create a new Photo object, copying from the source if provided""" + self.attrlist = [] if source: self.path = source.path self.desc = source.desc self.private = source.private - if self.proplist != None: - self.proplist = {} - for p in source.proplist.keys(): - self.proplist[p] = source.proplist[p] - else: - self.proplist = None + for attr in source.attrlist: + self.attrlist.append(Attribute(attr)) else: self.path = "" self.desc = "" self.private = 0 - self.proplist = None def setPath(self,path): """set the file path to the passed path""" @@ -382,18 +378,15 @@ class Photo: """returns the description of the image""" return self.desc - def addProperty(self,key,value): + def addAttribute(self,attr): """Adds a propery to the Photo object. This is not used by gramps, but provides a means for XML users to attach other properties to the image""" - if self.proplist == None: - self.proplist = { key: value} - else: - self.proplist[key] = value; + self.attrlist.append(attr) - def getPropertyList(self): + def getAttributeList(self): """returns the property list associated with the image""" - return self.proplist + return self.attrlist class Attribute(DataObj): """Provides a simple key/value pair for describing properties. Used diff --git a/src/WriteXML.py b/src/WriteXML.py index 3055a3713..60965b9e6 100644 --- a/src/WriteXML.py +++ b/src/WriteXML.py @@ -268,18 +268,19 @@ def dump_location(g,loc): g.write('/>\n') -def write_attribute_list(g, list): +def write_attribute_list(g, list, indent=3): + sp = ' ' * indent for attr in list: - if len(attr.getSourceRef()) > 0 or attr.getNote(): - g.write(' \n' % conf_priv(attr)) + if len(attr.getSourceRefList()) > 0 or attr.getNote(): + g.write('%s\n' % (sp,conf_priv(attr))) write_line(g,"attr_type",attr.getType(),4) write_line(g,"attr_value",attr.getValue(),4) for s in attr.getSourceRefList(): dump_source_ref(g,s,index+1) writeNote(g,"note",attr.getNote(),4) - g.write(' \n') + g.write('%s\n' % sp) else: - g.write(' ' % attr.getType()) + g.write('%s' % (sp,attr.getType())) g.write(fix(attr.getValue())) g.write('\n') @@ -296,11 +297,13 @@ def write_photo_list(g,list): path = path[l+1:] g.write(' \n") + proplist = photo.getAttributeList() + if len(proplist) == 0: + g.write("/>\n") + else: + g.write(">\n") + write_attribute_list(g,proplist,4) + g.write(' \n') def write_url_list(g, list):