[Patches] [ python-Patches-658405 ] use datetime for calendar.py

noreply@sourceforge.net noreply@sourceforge.net
Wed, 25 Dec 2002 08:39:08 -0800


Patches item #658405, was opened at 2002-12-25 02:29
You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=305470&aid=658405&group_id=5470

Category: Library (Lib)
Group: Python 2.3
>Status: Closed
Resolution: Accepted
Priority: 5
Submitted By: Raymond Hettinger (rhettinger)
Assigned to: Raymond Hettinger (rhettinger)
Summary: use datetime for calendar.py

Initial Comment:
Straightforward update for calendar.py to use the 
datetime module instead of the time module.

Simplifies the code, makes it more readable, and 
dramatically extends the range of usable dates.

----------------------------------------------------------------------

>Comment By: Raymond Hettinger (rhettinger)
Date: 2002-12-25 11:39

Message:
Logged In: YES 
user_id=80475

Added other changes as requested.

Committed as Lib/calendar.py 1.31 and 
Doc/lib/libcalendar.tex 1.17.

Closing patch.

----------------------------------------------------------------------

Comment By: Tim Peters (tim_one)
Date: 2002-12-25 03:18

Message:
Logged In: YES 
user_id=31435

Good idea!  Random comments:

+ The old "Revision 2" comment was useless in the code 
and belonged in a checkin comment.  The same for the 
new "Revision 3" comment.

+ leapdays() should be changed to use integer division (// 
instead of /)

+ timegm() could be similarly simplified:

EPOCH = 1970  # that's already there
_EPOCH_ORD = datetime.date(EPOCH, 1, 1).toordinal()

def timegm(tuple):
    # Replace all the code computing days by
    days = datetime.date(year, month, day).toordinal() - 
_EPOCH_ORD

The assertions can be dropped too, as the date() 
constructor does a better of job of checking them than the 
timegm() code is doing.

----------------------------------------------------------------------

You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=305470&aid=658405&group_id=5470