mirror of
https://github.com/jrnl-org/jrnl.git
synced 2025-05-17 11:38:32 +02:00
Fix dealing with plain years
`-from` and `-to` flags also work
This commit is contained in:
parent
da28dc9249
commit
aede53a9f4
1 changed files with 37 additions and 27 deletions
|
@ -244,39 +244,49 @@ class Journal(object):
|
||||||
elif isinstance(date_str, datetime):
|
elif isinstance(date_str, datetime):
|
||||||
return date_str
|
return date_str
|
||||||
|
|
||||||
try:
|
if re.match(r'^\d{4}$', date_str):
|
||||||
date = dateutil.parser.parse(date_str)
|
# i.e. if we're just given a year
|
||||||
flag = 1 if date.hour == 0 and date.minute == 0 else 2
|
|
||||||
date = date.timetuple()
|
|
||||||
except:
|
|
||||||
date, flag = self.dateparse.parse(date_str)
|
|
||||||
|
|
||||||
if not flag: # Oops, unparsable.
|
|
||||||
try: # Try and parse this as a single year
|
|
||||||
year = int(date_str)
|
|
||||||
return datetime(year, 1, 1)
|
|
||||||
except ValueError:
|
|
||||||
return None
|
|
||||||
except TypeError:
|
|
||||||
return None
|
|
||||||
|
|
||||||
if flag is 1: # Date found, but no time.
|
|
||||||
if end_flag == "from":
|
if end_flag == "from":
|
||||||
date = datetime(*date[:3], hour=0, minute=0)
|
date = datetime(year=int(date_str), month=1, day=1, hour=0, minute=0)
|
||||||
elif end_flag == "to":
|
elif end_flag == "to":
|
||||||
date = datetime(*date[:3], hour=23, minute=59, second=59)
|
date = datetime(year=int(date_str), month=12, day=31, hour=23, minute=59, second=59)
|
||||||
else:
|
else:
|
||||||
# Use the default time.
|
# Use the default time.
|
||||||
date = datetime(*date[:3], hour=self.config['default_hour'], minute=self.config['default_minute'])
|
date = datetime(year=int(date_str), month=1, day=1, hour=self.config['default_hour'], minute=self.config['default_minute'])
|
||||||
else:
|
else:
|
||||||
date = datetime(*date[:6])
|
try:
|
||||||
|
date = dateutil.parser.parse(date_str)
|
||||||
|
flag = 1 if date.hour == 0 and date.minute == 0 else 2
|
||||||
|
date = date.timetuple()
|
||||||
|
except:
|
||||||
|
date, flag = self.dateparse.parse(date_str)
|
||||||
|
|
||||||
# Ugly heuristic: if the date is more than 4 weeks in the future, we got the year wrong.
|
if not flag: # Oops, unparsable.
|
||||||
# Rather then this, we would like to see parsedatetime patched so we can tell it to prefer
|
try: # Try and parse this as a single year
|
||||||
# past dates
|
year = int(date_str)
|
||||||
dt = datetime.now() - date
|
return datetime(year, 1, 1)
|
||||||
if dt.days < -28:
|
except ValueError:
|
||||||
date = date.replace(date.year - 1)
|
return None
|
||||||
|
except TypeError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
if flag is 1: # Date found, but no time.
|
||||||
|
if end_flag == "from":
|
||||||
|
date = datetime(*date[:3], hour=0, minute=0)
|
||||||
|
elif end_flag == "to":
|
||||||
|
date = datetime(*date[:3], hour=23, minute=59, second=59)
|
||||||
|
else:
|
||||||
|
# Use the default time.
|
||||||
|
date = datetime(*date[:3], hour=self.config['default_hour'], minute=self.config['default_minute'])
|
||||||
|
else:
|
||||||
|
date = datetime(*date[:6])
|
||||||
|
|
||||||
|
# Ugly heuristic: if the date is more than 4 weeks in the future, we got the year wrong.
|
||||||
|
# Rather then this, we would like to see parsedatetime patched so we can tell it to prefer
|
||||||
|
# past dates
|
||||||
|
dt = datetime.now() - date
|
||||||
|
if dt.days < -28:
|
||||||
|
date = date.replace(date.year - 1)
|
||||||
|
|
||||||
return date
|
return date
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue