2007-08-12 Don Allingham <don@gramps-project.org>

* src/GrampsDbUtils/_WriteGedcom.py: remove unused options,
	handle source TEXT



svn: r8814
This commit is contained in:
Don Allingham 2007-08-13 00:00:16 +00:00
parent 1efee294a7
commit 9bd87e4e97
2 changed files with 48 additions and 119 deletions

View File

@ -1,3 +1,7 @@
2007-08-12 Don Allingham <don@gramps-project.org>
* src/GrampsDbUtils/_WriteGedcom.py: remove unused options,
handle source TEXT
2007-08-12 Zsolt Foldvari <zfoldvar@users.sourceforge.net> 2007-08-12 Zsolt Foldvari <zfoldvar@users.sourceforge.net>
* src/docgen/GtkPrint.py: More work in progress. * src/docgen/GtkPrint.py: More work in progress.

View File

@ -54,9 +54,8 @@ import const
import _GedcomInfo as GedcomInfo import _GedcomInfo as GedcomInfo
import Errors import Errors
import Utils import Utils
from BasicUtils import name_displayer from QuestionDialog import ErrorDialog, WarningDialog
from QuestionDialog import * from BasicUtils import UpdateCallback, name_displayer
from BasicUtils import UpdateCallback
try: try:
import Config import Config
@ -170,15 +169,7 @@ def addr_append(text, data):
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def sort_by_gramps_id(first, second): def sort_by_gramps_id(first, second):
fid = first.get_gramps_id() return cmp(first.gramps_id, second.gramps_id)
sid = second.get_gramps_id()
if fid == sid:
return 0
elif fid < sid:
return -1
else:
return 1
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -265,7 +256,6 @@ class GedcomWriterOptionBox:
def get_option_box(self): def get_option_box(self):
self.restrict = True self.restrict = True
self.private = True
self.adopt = GedcomInfo.ADOPT_EVENT self.adopt = GedcomInfo.ADOPT_EVENT
glade_file = "%s/gedcomexport.glade" % os.path.dirname(__file__) glade_file = "%s/gedcomexport.glade" % os.path.dirname(__file__)
@ -347,7 +337,6 @@ class GedcomWriterOptionBox:
self.topDialog.get_widget("notes").get_active()) self.topDialog.get_widget("notes").get_active())
self.exclsrcs = (self.restrict and self.exclsrcs = (self.restrict and
self.topDialog.get_widget("sources").get_active()) self.topDialog.get_widget("sources").get_active())
self.private = self.topDialog.get_widget("private").get_active()
self.cfilter = self.filter_menu.get_active().get_data("filter") self.cfilter = self.filter_menu.get_active().get_data("filter")
act_tgt = self.target_menu.get_active() act_tgt = self.target_menu.get_active()
@ -360,15 +349,7 @@ class GedcomWriterOptionBox:
else: else:
self.images_path = "" self.images_path = ""
self.dest = self.target_ged.get_dest()
self.adopt = self.target_ged.get_adopt() self.adopt = self.target_ged.get_adopt()
self.altname = self.target_ged.get_alt_name()
self.cal = self.target_ged.get_alt_calendar()
self.obje = self.target_ged.get_obje()
self.resi = self.target_ged.get_resi()
self.prefix = self.target_ged.get_prefix()
self.nl = self.target_ged.get_endl()
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -431,18 +412,10 @@ class GedcomWriter(UpdateCallback):
self.living = self.option_box.living self.living = self.option_box.living
self.exclnotes = self.option_box.exclnotes self.exclnotes = self.option_box.exclnotes
self.exclsrcs = self.option_box.exclsrcs self.exclsrcs = self.option_box.exclsrcs
self.private = self.option_box.private
self.images = self.option_box.images self.images = self.option_box.images
self.images_path = self.option_box.images_path self.images_path = self.option_box.images_path
self.target_ged = self.option_box.target_ged self.target_ged = self.option_box.target_ged
self.dest = self.option_box.dest
self.adopt = self.option_box.adopt self.adopt = self.option_box.adopt
self.altname = self.option_box.altname
self.cal = self.option_box.cal
self.obje = self.option_box.obje
self.resi = self.option_box.resi
self.prefix = self.option_box.prefix
self.nl = self.option_box.nl
if self.option_box.cfilter == None: if self.option_box.cfilter == None:
self.plist = set(self.db.get_person_handles(sort_handles=False)) self.plist = set(self.db.get_person_handles(sort_handles=False))
@ -459,7 +432,6 @@ class GedcomWriter(UpdateCallback):
def cli_setup(self): def cli_setup(self):
# use default settings # use default settings
self.restrict = 0 self.restrict = 0
self.private = 0
self.images = 0 self.images = 0
self.plist = set(self.db.get_person_handles(sort_handles=False)) self.plist = set(self.db.get_person_handles(sort_handles=False))
@ -467,21 +439,10 @@ class GedcomWriter(UpdateCallback):
gedmap = GedcomInfo.GedcomInfoDB() gedmap = GedcomInfo.GedcomInfoDB()
self.target_ged = gedmap.standard self.target_ged = gedmap.standard
self.dest = self.target_ged.get_dest()
self.adopt = self.target_ged.get_adopt() self.adopt = self.target_ged.get_adopt()
self.altname = self.target_ged.get_alt_name()
self.cal = self.target_ged.get_alt_calendar()
self.obje = self.target_ged.get_obje()
self.resi = self.target_ged.get_resi()
self.prefix = self.target_ged.get_prefix()
self.nl = self.target_ged.get_endl()
return True return True
def writeln(self, text):
self.g.write('%s%s' % (text, self.nl))
def export_data(self, filename): def export_data(self, filename):
self.dirname = os.path.dirname (filename) self.dirname = os.path.dirname (filename)
@ -638,16 +599,16 @@ class GedcomWriter(UpdateCallback):
self.__write_gender(person) self.__write_gender(person)
self.__write_person_event_ref('BIRT', person.get_birth_ref()) self.__write_person_event_ref('BIRT', person.get_birth_ref())
self.__write_person_event_ref('DEAT', person.get_death_ref()) self.__write_person_event_ref('DEAT', person.get_death_ref())
self.__write_lds_ords(person)
self.__write_remaining_events(person) self.__write_remaining_events(person)
self.__write_attributes(person) self.__write_attributes(person)
self.__write_addresses(person) self.__write_lds_ords(person)
self.__write_photos(person.get_media_list())
self.__write_child_families(person) self.__write_child_families(person)
self.__write_parent_families(person) self.__write_parent_families(person)
# add ASSOC
self.__write_person_sources(person) self.__write_person_sources(person)
self.__write_addresses(person)
self.__write_photos(person.get_media_list())
self.__write_person_objects(person) self.__write_person_objects(person)
self.__write_note_references(person.get_note_list(), 1) self.__write_note_references(person.get_note_list(), 1)
self.write_change(1, person.get_change_time()) self.write_change(1, person.get_change_time())
@ -791,8 +752,7 @@ class GedcomWriter(UpdateCallback):
def __write_addresses(self, person): def __write_addresses(self, person):
for addr in person.get_address_list(): for addr in person.get_address_list():
self.__writeln(1, 'RESI') self.__writeln(1, 'RESI')
self.print_date("2 DATE", addr.get_date_object()) self.print_date(2, addr.get_date_object())
if self.resi == 0:
self.__writeln(2, "ADDR", addr.get_street()) self.__writeln(2, "ADDR", addr.get_street())
if addr.get_city(): if addr.get_city():
self.__writeln(3, 'CITY', addr.get_city()) self.__writeln(3, 'CITY', addr.get_city())
@ -804,15 +764,6 @@ class GedcomWriter(UpdateCallback):
self.__writeln(3, 'CTRY', addr.get_country()) self.__writeln(3, 'CTRY', addr.get_country())
if addr.get_phone(): if addr.get_phone():
self.__writeln(2, 'PHON', addr.get_phone()) self.__writeln(2, 'PHON', addr.get_phone())
else:
text = addr.get_street()
text = addr_append(text, addr.get_city())
text = addr_append(text, addr.get_state())
text = addr_append(text, addr.get_postal_code())
text = addr_append(text, addr.get_country())
text = addr_append(text, addr.get_phone())
if text:
self.__writeln(2, 'PLAC', text.replace('\r', ' '))
self.__write_note_references(addr.get_note_list(), 2) self.__write_note_references(addr.get_note_list(), 2)
for srcref in addr.get_source_references(): for srcref in addr.get_source_references():
@ -851,7 +802,6 @@ class GedcomWriter(UpdateCallback):
self.write_source_ref(1, srcref) self.write_source_ref(1, srcref)
def __write_person_objects(self, person): def __write_person_objects(self, person):
if self.obje:
for url in person.get_url_list(): for url in person.get_url_list():
self.__writeln(1, 'OBJE') self.__writeln(1, 'OBJE')
self.__writeln(2, 'FORM', 'URL') self.__writeln(2, 'FORM', 'URL')
@ -964,8 +914,9 @@ class GedcomWriter(UpdateCallback):
self.write_change(1, family.get_change_time()) self.write_change(1, family.get_change_time())
self.update() self.update()
def write_note(self, level, handle): def write_note(self, level, handle, skip=[]):
note = self.db.get_note_from_handle(handle) note = self.db.get_note_from_handle(handle)
if note.get_type() not in skip:
self.__writeln(level, "NOTE", note.get()) self.__writeln(level, "NOTE", note.get())
def __write_sources(self): def __write_sources(self):
@ -1099,7 +1050,7 @@ class GedcomWriter(UpdateCallback):
def dump_event_stats(self, event, event_ref): def dump_event_stats(self, event, event_ref):
dateobj = event.get_date_object() dateobj = event.get_date_object()
self.print_date("2 DATE", dateobj) self.print_date(2, dateobj)
place = None place = None
if event.get_place_handle(): if event.get_place_handle():
@ -1139,7 +1090,7 @@ class GedcomWriter(UpdateCallback):
def write_ord(self, ord, index): def write_ord(self, ord, index):
self.__writeln(index, lds_ord_name[ord.get_type()]) self.__writeln(index, lds_ord_name[ord.get_type()])
self.print_date("%d DATE" % (index + 1), ord.get_date_object()) self.print_date(index + 1, ord.get_date_object())
if ord.get_family_handle(): if ord.get_family_handle():
family_handle = ord.get_family_handle() family_handle = ord.get_family_handle()
family = self.db.get_family_from_handle(family_handle) family = self.db.get_family_from_handle(family_handle)
@ -1158,7 +1109,7 @@ class GedcomWriter(UpdateCallback):
for srcref in ord.get_source_references(): for srcref in ord.get_source_references():
self.write_source_ref(index+1, srcref) self.write_source_ref(index+1, srcref)
def print_date(self, prefix, date): def print_date(self, level, date):
start = date.get_start_date() start = date.get_start_date()
if start != RelLib.Date.EMPTY: if start != RelLib.Date.EMPTY:
cal = date.get_calendar() cal = date.get_calendar()
@ -1173,9 +1124,9 @@ class GedcomWriter(UpdateCallback):
make_date(date.get_stop_date(), cal, mod)) make_date(date.get_stop_date(), cal, mod))
else: else:
val = make_date(start, cal, mod) val = make_date(start, cal, mod)
self.writeln("%s %s" % (prefix, val)) self.__writeln(level, 'DATE', val)
elif date.get_text(): elif date.get_text():
self.writeln("%s %s" % (prefix, date.get_text())) self.__writeln(level, 'DATE', date.get_text())
def __write_person_name(self, name, nick): def __write_person_name(self, name, nick):
""" """
@ -1212,16 +1163,10 @@ class GedcomWriter(UpdateCallback):
if firstname: if firstname:
self.__writeln(2, 'GIVN', firstname) self.__writeln(2, 'GIVN', firstname)
if self.prefix:
if surprefix: if surprefix:
self.__writeln(2, 'SPFX', surprefix) self.__writeln(2, 'SPFX', surprefix)
if surname: if surname:
self.__writeln(2, 'SURN', surname) self.__writeln(2, 'SURN', surname)
else:
if surprefix:
self.__writeln(2, 'SURN', '%s %s' % (surprefix, surname))
elif surname:
self.__writeln(2, 'SURN', surname)
if name.get_suffix(): if name.get_suffix():
self.__writeln(2, 'NSFX', suffix) self.__writeln(2, 'NSFX', suffix)
@ -1272,7 +1217,6 @@ class GedcomWriter(UpdateCallback):
if note_list: if note_list:
ref_text = note_list[0].get() ref_text = note_list[0].get()
already_printed = note_list[0].get_handle()
else: else:
ref_text = "" ref_text = ""
@ -1280,31 +1224,12 @@ class GedcomWriter(UpdateCallback):
self.__writeln(level+1, 'DATA') self.__writeln(level+1, 'DATA')
if ref_text != "": if ref_text != "":
self.__writeln(level+1, "TEXT", ref_text) self.__writeln(level+1, "TEXT", ref_text)
pfx = "%d DATE" % (level+2) self.print_date(level+2, ref.get_date_object())
self.print_date(pfx, ref.get_date_object())
else: note_list = [ self.db.get_note_from_handle(h) for h in ref.get_note_list() ]
# Inline source note_list = [ n.handle for n in note_list
if n.get_type() != RelLib.NoteType.SOURCE_TEXT]
# We put title, page, and date on the SOUR line. self.__write_note_references(note_list, level+1)
# Not using CONC and CONT because GeneWeb does not support these.
# TEXT and NOTE will be ignored by GeneWeb, but we can't
# output paragaphs in SOUR without CONT.
txt = ""
if src.get_title():
txt = src.get_title() + ". "
if ref.get_page():
txt = txt + ref.get_page() + ". "
self.__writeln(level, "SOUR", txt)
if not ref.get_date_object().is_empty():
self.print_date("", ref.get_date_object())
#ref_text = ref.get_text()
#if ref_text:
# self.write_long_text("TEXT", level+1, self.cnvtxt(ref_text))
for notehandle in ref.get_note_list():
if notehandle != already_printed:
self.write_note(level+1, notehandle)
def write_photo(self, photo, level): def write_photo(self, photo, level):
photo_obj_id = photo.get_reference_handle() photo_obj_id = photo.get_reference_handle()