0008355: Gramps can't [GEDCOM] import estim. date period exported by

itself

Changed output format to DATE EST FROM TO and DATE CALC FROM TO. Also
changed in Narrative Web (which uses the same functions).
This commit is contained in:
kulath 2015-03-31 10:48:16 +01:00
parent 5c278cfc36
commit 8be01ff00e
2 changed files with 25 additions and 13 deletions

View File

@ -1164,16 +1164,22 @@ class GedcomWriter(UpdateCallback):
cal = date.get_calendar() cal = date.get_calendar()
mod = date.get_modifier() mod = date.get_modifier()
quality = date.get_quality() quality = date.get_quality()
if quality in libgedcom.DATE_QUALITY:
qual_text = libgedcom.DATE_QUALITY[quality] + " "
else:
qual_text = ""
if mod == gen.lib.Date.MOD_SPAN: if mod == gen.lib.Date.MOD_SPAN:
val = "FROM %s TO %s" % ( val = "%sFROM %s TO %s" % (
libgedcom.make_gedcom_date(start, cal, mod, quality), qual_text,
libgedcom.make_gedcom_date(start, cal, mod, None),
libgedcom.make_gedcom_date(date.get_stop_date(), libgedcom.make_gedcom_date(date.get_stop_date(),
cal, mod, quality)) cal, mod, None))
elif mod == gen.lib.Date.MOD_RANGE: elif mod == gen.lib.Date.MOD_RANGE:
val = "BET %s AND %s" % ( val = "%sBET %s AND %s" % (
libgedcom.make_gedcom_date(start, cal, mod, quality), qual_text,
libgedcom.make_gedcom_date(start, cal, mod, None),
libgedcom.make_gedcom_date(date.get_stop_date(), libgedcom.make_gedcom_date(date.get_stop_date(),
cal, mod, quality)) cal, mod, None))
else: else:
val = libgedcom.make_gedcom_date(start, cal, mod, quality) val = libgedcom.make_gedcom_date(start, cal, mod, quality)
self.__writeln(level, 'DATE', val) self.__writeln(level, 'DATE', val)

View File

@ -140,7 +140,7 @@ from libhtml import Html
# import styled notes from src/plugins/lib/libhtmlbackend.py # import styled notes from src/plugins/lib/libhtmlbackend.py
from libhtmlbackend import HtmlBackend, process_spaces from libhtmlbackend import HtmlBackend, process_spaces
from libgedcom import make_gedcom_date from libgedcom import make_gedcom_date, DATE_QUALITY
from PlaceUtils import conv_lat_lon from PlaceUtils import conv_lat_lon
from gui.pluginmanager import GuiPluginManager from gui.pluginmanager import GuiPluginManager
@ -519,14 +519,20 @@ def format_date(date):
cal = date.get_calendar() cal = date.get_calendar()
mod = date.get_modifier() mod = date.get_modifier()
quality = date.get_quality() quality = date.get_quality()
if quality in libgedcom.DATE_QUALITY:
qual_text = libgedcom.DATE_QUALITY[quality] + " "
else:
qual_text = ""
if mod == Date.MOD_SPAN: if mod == Date.MOD_SPAN:
val = "FROM %s TO %s" % ( val = "%sFROM %s TO %s" % (
make_gedcom_date(start, cal, mod, quality), qual_text,
make_gedcom_date(date.get_stop_date(), cal, mod, quality)) make_gedcom_date(start, cal, mod, None),
make_gedcom_date(date.get_stop_date(), cal, mod, None))
elif mod == Date.MOD_RANGE: elif mod == Date.MOD_RANGE:
val = "BET %s AND %s" % ( val = "%sBET %s AND %s" % (
make_gedcom_date(start, cal, mod, quality), qual_text,
make_gedcom_date(date.get_stop_date(), cal, mod, quality)) make_gedcom_date(start, cal, mod, None),
make_gedcom_date(date.get_stop_date(), cal, mod, None))
else: else:
val = make_gedcom_date(start, cal, mod, quality) val = make_gedcom_date(start, cal, mod, quality)
return val return val