From cdc6b08430bdea14edd1addd580fde274a9e61f1 Mon Sep 17 00:00:00 2001 From: Don Allingham Date: Fri, 3 Jan 2003 03:19:50 +0000 Subject: [PATCH] GEDCOM improvements for GENEWEB from Alexandre Duret-Lutz svn: r1238 --- gramps2/example/gramps/data.gramps | Bin 3745 -> 3767 bytes gramps2/src/GedcomInfo.py | 12 ++++++++ gramps2/src/data/gedcom.xml | 10 ++++++ gramps2/src/plugins/WebPage.py | 4 ++- gramps2/src/plugins/WriteGedcom.py | 47 ++++++++++++++++++++++++----- 5 files changed, 64 insertions(+), 9 deletions(-) diff --git a/gramps2/example/gramps/data.gramps b/gramps2/example/gramps/data.gramps index 773b7b992e45481b6a81bbbb768873e140c2c584..5bd977f4aa061c7f3d28212d53bf084eac4f6659 100644 GIT binary patch delta 3730 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 delta 3707 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 ZVWM3(YE(QPZvM%H{{i>eH@$yh007l|E1duU diff --git a/gramps2/src/GedcomInfo.py b/gramps2/src/GedcomInfo.py index 9b9a3cb4c..d4ac9e68a 100644 --- a/gramps2/src/GedcomInfo.py +++ b/gramps2/src/GedcomInfo.py @@ -42,6 +42,8 @@ PREFIX_NO = 0 PREFIX_YES = 1 RESIDENCE_ADDR = 0 RESIDENCE_PLAC = 1 +SOURCE_REFS_NO = 0 +SOURCE_REFS_YES = 1 #------------------------------------------------------------------------- # @@ -60,6 +62,7 @@ class GedcomDescription: self.cal = CALENDAR_YES self.obje = OBJE_YES self.resi = RESIDENCE_ADDR + self.source_refs = SOURCE_REFS_YES self.gramps2tag_map = {} self.tag2gramps_map = {} self.prefix = PREFIX_YES @@ -112,6 +115,12 @@ class GedcomDescription: def get_resi(self): return self.resi + def set_source_refs(self,val): + self.source_refs = val + + def get_source_refs(self): + return self.source_refs + def add_tag_value(self,tag,value): self.gramps2tag_map[value] = tag self.tag2gramps_map[tag] = value @@ -227,3 +236,6 @@ class GedInfoParser: elif tag == "residence": if attrs['val'] == 'place': self.current.set_resi(RESIDENCE_PLAC) + elif tag == "source_refs": + if u2l(attrs['val']) == 'no': + self.current.set_source_refs(SOURCE_REFS_NO) diff --git a/gramps2/src/data/gedcom.xml b/gramps2/src/data/gedcom.xml index 1f55efb03..2fc1d15a9 100644 --- a/gramps2/src/data/gedcom.xml +++ b/gramps2/src/data/gedcom.xml @@ -11,6 +11,7 @@ + @@ -23,6 +24,7 @@ + @@ -38,6 +40,7 @@ + @@ -51,6 +54,7 @@ + @@ -63,6 +67,7 @@ + @@ -75,6 +80,7 @@ + @@ -87,6 +93,7 @@ + @@ -99,6 +106,7 @@ + @@ -111,6 +119,7 @@ + @@ -123,6 +132,7 @@ + diff --git a/gramps2/src/plugins/WebPage.py b/gramps2/src/plugins/WebPage.py index 853cba352..d85d2d9b3 100644 --- a/gramps2/src/plugins/WebPage.py +++ b/gramps2/src/plugins/WebPage.py @@ -259,8 +259,10 @@ class IndividualPage: if self.person.getGender() == Person.male: self.write_normal_row("%s:" % _("Gender"), _("Male"),None) - else: + elif self.person.getGender() == Person.female: self.write_normal_row("%s:" % _("Gender"), _("Female"),None) + else: + self.write_normal_row("%s:" % _("Gender"), _("Unknown"),None) family = self.person.getMainParents() if family: diff --git a/gramps2/src/plugins/WriteGedcom.py b/gramps2/src/plugins/WriteGedcom.py index 05403e775..91d06c803 100644 --- a/gramps2/src/plugins/WriteGedcom.py +++ b/gramps2/src/plugins/WriteGedcom.py @@ -412,6 +412,7 @@ class GedcomWriter: self.obje = self.target_ged.get_obje() self.resi = self.target_ged.get_resi() self.prefix = self.target_ged.get_prefix() + self.source_refs = self.target_ged.get_source_refs() if self.topDialog.get_widget("ansel").get_active(): self.cnvtxt = latin_to_ansel @@ -533,7 +534,10 @@ class GedcomWriter: self.pbar.set_fraction(1.0) self.write_families() - self.write_sources() + if self.source_refs: + self.write_sources() + else: + self.sbar.set_value(100.0) self.g.write("0 TRLR\n") self.g.close() @@ -945,17 +949,44 @@ class GedcomWriter: def write_source_ref(self,level,ref): if ref.getBase() == None: return + self.g.write("%d SOUR @%s@\n" % (level,self.sid(ref.getBase().getId()))) if ref.getPage(): self.g.write("%d PAGE %s\n" % (level+1,ref.getPage())) - ref_text = ref.getText() - if ref_text or not ref.getDate().isEmpty(): - self.g.write('%d DATA\n' % (level+1)) - if ref_text: - self.write_long_text("TEXT",level+2,ref_text) - pfx = "%d DATE" % (level+2) - self.print_date(pfx,ref.getDate()) + if self.source_refs: + self.g.write("%d SOUR @%s@\n" % + (level,self.sid(ref.getBase().getId()))) + if ref.getPage() != "": + self.g.write("%d PAGE %s\n" % (level+1,ref.getPage())) + + ref_text = ref.getText() + if ref_text != "" or not ref.getDate().isEmpty(): + self.g.write('%d DATA\n' % (level+1)) + if ref_text != "": + self.write_long_text("TEXT",level+2,ref_text) + pfx = "%d DATE" % (level+2) + self.print_date(pfx,ref.getDate()) + else: + # We put title, page, and date on the SOUR line. + # Not using CONC because GeneWeb does not support this. + # TEXT and NOTE will be ignored by GeneWeb, but we can't + # output paragaphs in SOUR if we don't use CONC. + sbase = ref.getBase() + if sbase and sbase.getTitle(): + txt = sbase.getTitle() + ". " + else: + txt = "" + if ref.getPage(): + txt = txt + ref.getPage() + ". " + self.g.write("%d SOUR %s" % (level,self.cnvtxt(txt))) + if not ref.getDate().isEmpty(): + self.print_date("", ref.getDate()) + else: + self.g.write("\n") + if ref.getText(): + self.write_long_text("TEXT",level+1,ref_text) + if ref.getComments(): self.write_long_text("NOTE",level+1,ref.getComments())