del self.context['dow']
self.context['delta_unit'] = dow
- # For the nth Fooday in Month, start at the 1st of the
- # month and count ahead N Foodays. For the last Fooday in
- # Month, start at the last of the month and count back one
- # Fooday.
+ # For the nth Fooday in Month, start at the last day of
+ # the previous month count ahead N Foodays. For the last
+ # Fooday in Month, start at the last of the month and
+ # count back one Fooday.
if n == -1:
month += 1
if month == 13:
tmp_date = datetime.date(year=year, month=month, day=1)
tmp_date = tmp_date - datetime.timedelta(days=1)
- self.context['year'] = tmp_date.year
- self.context['month'] = tmp_date.month
- self.context['day'] = tmp_date.day
-
# The delta adjustment code can handle the case where
# the last day of the month is the day we're looking
# for already.
else:
- self.context['year'] = year
- self.context['month'] = month
- self.context['day'] = 1
+ tmp_date = datetime.date(year=year, month=month, day=1)
+ tmp_date = tmp_date - datetime.timedelta(days=1)
+
+ self.context['year'] = tmp_date.year
+ self.context['month'] = tmp_date.month
+ self.context['day'] = tmp_date.day
self.main_type = DateParser.PARSE_TYPE_BASE_AND_OFFSET_EXPR
except Exception as e:
raise ParseException(f'Invalid nthWeekday expression: {ctx.getText()}') from e
('2 sun in jun', datetime.datetime(2021, 6, 13)),
('easter -40 days', datetime.datetime(2021, 2, 23)),
('easter +39 days', datetime.datetime(2021, 5, 13)),
+ ('2nd Sunday in May, 2022', datetime.datetime(2022, 5, 8)),
('1st tuesday in nov, 2024', datetime.datetime(2024, 11, 5)),
(
'2 days before last xmas at 3:14:15.92a',