Merge branch 'master' into geps/gep-032-database-backend
This commit is contained in:
commit
b1d07b8e70
@ -98,7 +98,8 @@ class DateParserFI(DateParser):
|
|||||||
|
|
||||||
def init_strings(self):
|
def init_strings(self):
|
||||||
DateParser.init_strings(self)
|
DateParser.init_strings(self)
|
||||||
# date, whitespace
|
self._text2 = re.compile('(\d+)?\.?\s+?%s\.?\s*((\d+)(/\d+)?)?\s*$'
|
||||||
|
% self._mon_str, re.IGNORECASE)
|
||||||
self._span = re.compile("(?P<start>.+)\s+(-)\s+(?P<stop>.+)",
|
self._span = re.compile("(?P<start>.+)\s+(-)\s+(?P<stop>.+)",
|
||||||
re.IGNORECASE)
|
re.IGNORECASE)
|
||||||
self._range = re.compile(
|
self._range = re.compile(
|
||||||
@ -114,90 +115,68 @@ class DateDisplayFI(DateDisplay):
|
|||||||
"""
|
"""
|
||||||
Finnish language date display class.
|
Finnish language date display class.
|
||||||
"""
|
"""
|
||||||
long_months = ("", "Tammikuu", "Helmikuu", "Maaliskuu", "Huhtikuu",
|
|
||||||
"Toukokuu", "Kesäkuu", "Heinäkuu", "Elokuu",
|
|
||||||
"Syyskuu", "Lokakuu", "Marraskuu", "Joulukuu")
|
|
||||||
|
|
||||||
short_months = ("", "Tammi", "Helmi", "Maali", "Huhti", "Touko",
|
|
||||||
"Kesäk", "Heinä", "Eloku", "Syysk", "Lokak", "Marra",
|
|
||||||
"Joulu")
|
|
||||||
|
|
||||||
calendar = ("",
|
|
||||||
"juliaaninen",
|
|
||||||
"heprealainen",
|
|
||||||
"ranskan v.",
|
|
||||||
"persialainen",
|
|
||||||
"islamilainen",
|
|
||||||
"svensk"
|
|
||||||
)
|
|
||||||
|
|
||||||
_qual_str = ("", "arviolta", "laskettuna")
|
|
||||||
|
|
||||||
_bce_str = "%s ekr."
|
_bce_str = "%s ekr."
|
||||||
|
|
||||||
formats = (
|
formats = (
|
||||||
"VVVV-KK-PP (ISO)",
|
"VVVV-KK-PP (ISO)",
|
||||||
"PP.KK.VVVV"
|
"PP.KK.VVVV",
|
||||||
|
"Päivä Kuukausi Vuosi" # Day, full month name, year
|
||||||
)
|
)
|
||||||
# normally, this would agree with DateDisplayEn's "formats"
|
# this definition must agree with its "_display_calendar" method
|
||||||
# (since no locale-specific _display_gregorian exists, here),
|
|
||||||
# but the locale-specific "display" (below) forces self.format = 1
|
|
||||||
|
|
||||||
def display(self, date):
|
display = DateDisplay.display_formatted
|
||||||
"""
|
|
||||||
Return a text string representing the date.
|
|
||||||
"""
|
|
||||||
mod = date.get_modifier()
|
|
||||||
qual = date.get_quality()
|
|
||||||
cal = date.get_calendar()
|
|
||||||
start = date.get_start_date()
|
|
||||||
newyear = date.get_new_year()
|
|
||||||
|
|
||||||
if mod == Date.MOD_TEXTONLY:
|
def _display_calendar(self, date_val, long_months, short_months = None,
|
||||||
return date.get_text()
|
inflect=""):
|
||||||
if start == Date.EMPTY:
|
# this must agree with its locale-specific "formats" definition
|
||||||
return ""
|
|
||||||
|
|
||||||
# select numerical date format
|
if short_months is None:
|
||||||
self.format = 1
|
# Let the short formats work the same as long formats
|
||||||
|
short_months = long_months
|
||||||
|
|
||||||
if mod == Date.MOD_SPAN:
|
if self.format == 0:
|
||||||
d1 = self.display_cal[cal](start)
|
return self.display_iso(date_val)
|
||||||
d2 = self.display_cal[cal](date.get_stop_date())
|
elif self.format == 1:
|
||||||
text = "%s - %s" % (d1, d2)
|
# numerical
|
||||||
elif mod == Date.MOD_RANGE:
|
value = self.dd_dformat01(date_val)
|
||||||
stop = date.get_stop_date()
|
# elif self.format == 4:
|
||||||
if start[0] == start[1] == 0 and stop[0] == 0 and stop[1] == 0:
|
|
||||||
d1 = self.display_cal[cal](start)
|
|
||||||
d2 = self.display_cal[cal](stop)
|
|
||||||
text = "vuosien %s ja %s välillä" % (d1, d2)
|
|
||||||
else:
|
else:
|
||||||
d1 = self.display_cal[cal](start)
|
# day month_name year
|
||||||
d2 = self.display_cal[cal](stop)
|
value = self.dd_dformat04(date_val, inflect, long_months)
|
||||||
text = "%s ja %s välillä" % (d1, d2)
|
if date_val[2] < 0:
|
||||||
|
# TODO fix BUG 7064: non-Gregorian calendars wrongly use BCE notation for negative dates
|
||||||
|
return self._bce_str % value
|
||||||
else:
|
else:
|
||||||
text = self.display_cal[date.get_calendar()](start)
|
return value
|
||||||
if mod == Date.MOD_AFTER:
|
|
||||||
text = text + " jälkeen"
|
|
||||||
elif mod == Date.MOD_ABOUT:
|
|
||||||
text = "noin " + text
|
|
||||||
elif mod == Date.MOD_BEFORE:
|
|
||||||
text = "ennen " + text
|
|
||||||
|
|
||||||
if qual:
|
def dd_dformat04(self, date_val, inflect, long_months):
|
||||||
# prepend quality
|
"""
|
||||||
text = "%s %s" % (self._qual_str[qual], text)
|
day month_name year -- for Finnish locale
|
||||||
|
"""
|
||||||
if cal or newyear:
|
year = self._slash_year(date_val[2], date_val[3])
|
||||||
# append calendar type
|
if date_val[0] == 0:
|
||||||
scal = self.format_extras(cal, newyear)
|
if date_val[1] == 0:
|
||||||
text = "%s %s" % (text, scal)
|
return year
|
||||||
|
else:
|
||||||
return text
|
if inflect:
|
||||||
|
return self.format_long_month_year(date_val[1], year,
|
||||||
|
inflect, long_months)
|
||||||
|
else:
|
||||||
|
return "{long_month.f[IN]} {year}".format(
|
||||||
|
long_month = long_months[date_val[1]],
|
||||||
|
year = year)
|
||||||
|
else:
|
||||||
|
if not hasattr(long_months[date_val[1]], 'f'): # not a Lexeme
|
||||||
|
return self.dd_dformat01(date_val) # maybe the month is zero
|
||||||
|
return "{day:d}. {long_month.f[P]} {year}".format(
|
||||||
|
day = date_val[0],
|
||||||
|
long_month = long_months[date_val[1]],
|
||||||
|
year = year)
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# Register classes
|
# Register classes
|
||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
register_datehandler(('fi_FI', 'fi', 'finnish', 'Finnish'), DateParserFI, DateDisplayFI)
|
register_datehandler(('fi_FI', 'fi', 'finnish', 'Finnish'),
|
||||||
|
DateParserFI, DateDisplayFI)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user