General polish of some date handling code; fixed a bug in date comparisons involving 'ABT' dates

svn: r10592
This commit is contained in:
Doug Blank 2008-04-19 16:48:46 +00:00
parent e00bce1ebd
commit f637730a87
5 changed files with 29 additions and 12 deletions

View File

@ -232,6 +232,10 @@ class SimpleTable:
self.row_sort_val(col, item.sortval) self.row_sort_val(col, item.sortval)
if (self.__link_col == col or link == None): if (self.__link_col == col or link == None):
link = ('Date', item) link = ('Date', item)
elif isinstance(item, gen.lib.Span):
text = str(item)
retval.append(text)
self.row_sort_val(col, float(item))
else: else:
raise AttributeError, ("unknown object type: '%s': %s" % raise AttributeError, ("unknown object type: '%s': %s" %
(item, type(item))) (item, type(item)))

View File

@ -578,7 +578,7 @@ def probably_alive(person, db, current_date=None, limit=0):
(defaults to today) (defaults to today)
limit - number of years to check beyond death_date limit - number of years to check beyond death_date
""" """
if not current_date: if current_date == None:
current_date = gen.lib.Date() current_date = gen.lib.Date()
# yr, mon, day: # yr, mon, day:
current_date.set_yr_mon_day(*time.localtime(time.time())[0:3]) current_date.set_yr_mon_day(*time.localtime(time.time())[0:3])
@ -617,15 +617,18 @@ def probably_alive(person, db, current_date=None, limit=0):
birth_ref = person.get_birth_ref() birth_ref = person.get_birth_ref()
if birth_ref and birth_ref.get_role() == gen.lib.EventRoleType.PRIMARY: if birth_ref and birth_ref.get_role() == gen.lib.EventRoleType.PRIMARY:
birth = db.get_event_from_handle(birth_ref.ref) birth = db.get_event_from_handle(birth_ref.ref)
if birth.get_date_object().get_start_date() != gen.lib.Date.EMPTY: if (birth.get_date_object().get_start_date() != gen.lib.Date.EMPTY):
if not birth_date: if not birth_date:
birth_date = birth.get_date_object() birth_date = birth.get_date_object()
# Check whether the birth event is too old because the # Check whether the birth event is too old because the
# code above did not look at birth, only at other events # code above did not look at birth, only at other events
if too_old(birth.get_date_object(), current_date.get_year()): birth_obj = birth.get_date_object()
return False if birth_obj.get_valid():
if not_too_old(birth.get_date_object(), current_date.get_year()): # only if this is a valid birth:
return True if too_old(birth_obj, current_date.get_year()):
return False
if not_too_old(birth_obj, current_date.get_year()):
return True
if not birth_date and death_date: if not birth_date and death_date:
if death_date.match(current_date.copy_offset_ymd(year=_MAX_AGE_PROB_ALIVE), ">>"): if death_date.match(current_date.copy_offset_ymd(year=_MAX_AGE_PROB_ALIVE), ">>"):

View File

@ -23,7 +23,7 @@
"""The core library of GRAMPS objects""" """The core library of GRAMPS objects"""
# Dates # Dates
from gen.lib.date import Date, DateError from gen.lib.date import Date, DateError, Span
# Secondary objects # Secondary objects
from gen.lib.secondaryobj import SecondaryObject from gen.lib.secondaryobj import SecondaryObject

View File

@ -86,9 +86,19 @@ class Span:
return retval return retval
def __int__(self): def __int__(self):
return int(self.diff_tuple[0] * 12 + self.diff_tuple[1]) # months return int(self.diff_tuple[0] * 12 +
self.diff_tuple[1]
) # number of months, for sorting
def __float__(self):
return float(self.diff_tuple[0] * 12 +
self.diff_tuple[1] +
self.diff_tuple[2]/31.0
) # number of months, for sorting
def __eq__(self, other): def __eq__(self, other):
if other == None:
return False
return self.diff_tuple == other.diff_tuple return self.diff_tuple == other.diff_tuple
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
@ -353,7 +363,7 @@ class Date:
eDate = date1 - (years, months, days) eDate = date1 - (years, months, days)
if eDate << date2: # too small, strictly less than if eDate << date2: # too small, strictly less than
diff = 0 diff = 0
while eDate < date2 and diff < 60: while eDate << date2 and diff < 60:
diff += 1 diff += 1
eDate = eDate + (0, 0, diff) eDate = eDate + (0, 0, diff)
if diff == 60: if diff == 60:
@ -361,7 +371,7 @@ class Date:
return Span(years, months, days - diff) return Span(years, months, days - diff)
elif eDate >> date2: elif eDate >> date2:
diff = 0 diff = 0
while eDate > date2 and diff > -60: while eDate >> date2 and diff > -60:
diff -= 1 diff -= 1
eDate = eDate - (0, 0, abs(diff)) eDate = eDate - (0, 0, abs(diff))
if diff == -60: if diff == -60:

View File

@ -862,8 +862,8 @@ class PythonGramplet(Gramplet):
return True return True
_retval = self.process_command(line) _retval = self.process_command(line)
if _retval != None: if _retval != None:
self.append_text("%s" % str(_retval)) self.append_text("%s\n" % str(_retval))
self.append_text("\n%s " % self.prompt) self.append_text("%s " % self.prompt)
end = buffer.get_end_iter() end = buffer.get_end_iter()
buffer.place_cursor(end) buffer.place_cursor(end)
return True return True