[Zope-Checkins] CVS: Zope/lib/python/DateTime - DateTime.py:1.91
Tres Seaver
cvs-admin at zope.org
Tue Nov 18 08:17:31 EST 2003
Update of /cvs-repository/Zope/lib/python/DateTime
In directory cvs.zope.org:/tmp/cvs-serv30559/lib/python/DateTime
Modified Files:
DateTime.py
Log Message:
- Merge tseaver-strexp_delenda-branch to the head.
=== Zope/lib/python/DateTime/DateTime.py 1.90 => 1.91 ===
--- Zope/lib/python/DateTime/DateTime.py:1.90 Tue Nov 4 17:03:28 2003
+++ Zope/lib/python/DateTime/DateTime.py Tue Nov 18 08:16:59 2003
@@ -18,10 +18,24 @@
import os, re, math, DateTimeZone
from time import time, gmtime, localtime, asctime
from time import daylight, timezone, altzone, strftime
-from types import InstanceType,IntType,FloatType,StringType,UnicodeType
-try: from time import tzname
-except: tzname=('UNKNOWN','UNKNOWN')
+from types import InstanceType, IntType, FloatType, StringType, UnicodeType
+try:
+ from time import tzname
+except:
+ tzname=('UNKNOWN','UNKNOWN')
+
+class DateTimeError( Exception ):
+ pass
+
+class SyntaxError( DateTimeError ):
+ pass
+
+class DateError( DateTimeError ):
+ pass
+
+class TimeError( DateTimeError ):
+ pass
_default_datefmt = os.environ.get('DATETIME_FORMAT', "us").lower()
if not _default_datefmt in ('us', 'international'):
@@ -241,7 +255,7 @@
try: n=self._zmap[k.lower()]
except KeyError:
if numericTimeZoneMatch(k) == None:
- raise 'DateTimeError','Unrecognized timezone: %s' % k
+ raise DateTimeError,'Unrecognized timezone: %s' % k
return k
try: return self._d[n]
except KeyError:
@@ -397,7 +411,7 @@
raise OverflowError # Python 2.3 fix: int can return a long!
return gmtime(t_int)
except (IOError, OverflowError):
- raise 'TimeError', 'The time %f is beyond the range ' \
+ raise TimeError, 'The time %f is beyond the range ' \
'of this Python implementation.' % float(t)
def safelocaltime(t):
@@ -407,7 +421,7 @@
if isinstance(t_int, long):
raise OverflowError # Python 2.3 fix: int can return a long!
except OverflowError:
- raise 'TimeError', 'The time %f is beyond the range ' \
+ raise TimeError, 'The time %f is beyond the range ' \
'of this Python implementation.' % float(t)
rval = localtime(t_int)
return rval
@@ -657,7 +671,7 @@
arg=args[0]
if arg=='':
- raise self.SyntaxError, arg
+ raise SyntaxError, arg
if type(arg) in [StringType,UnicodeType] and arg.lower() in self._tzinfo._zidx:
# Current time, to be displayed in specified timezone
@@ -678,9 +692,9 @@
if not self._validDate(yr,mo,dy):
- raise self.DateTimeError, 'Invalid date: %s' % arg
+ raise DateError, 'Invalid date: %s' % arg
if not self._validTime(hr,mn,int(sc)):
- raise self.DateTimeError, 'Invalid time: %s' % arg
+ raise TimeError, 'Invalid time: %s' % arg
ms = sc - math.floor(sc)
x = _calcDependentSecond2(yr,mo,dy,hr,mn,sc)
@@ -688,7 +702,7 @@
try: tz=self._tzinfo._zmap[tz.lower()]
except KeyError:
if numericTimeZoneMatch(tz) is None:
- raise self.DateTimeError, \
+ raise DateTimeError, \
'Unknown time zone in date: %s' % arg
else:
tz = self._calcTimezoneName(x, ms)
@@ -734,7 +748,7 @@
hr,mn,sc,tz=0,0,0,0
yr = _correctYear(yr)
if not self._validDate(yr,mo,dy):
- raise self.DateTimeError, 'Invalid date: %s' % (args,)
+ raise DateError, 'Invalid date: %s' % (args,)
args=args[3:]
if args:
hr,args=args[0],args[1:]
@@ -745,9 +759,9 @@
if args:
tz,args=args[0],args[1:]
if args:
- raise self.DateTimeError,'Too many arguments'
+ raise DateTimeError,'Too many arguments'
if not self._validTime(hr,mn,sc):
- raise self.DateTimeError, 'Invalid time: %s' % `args`
+ raise TimeError, 'Invalid time: %s' % `args`
leap = (yr % 4 == 0) and (yr % 100 != 0 or yr % 400 == 0)
x = _calcDependentSecond2(yr,mo,dy,hr,mn,sc)
@@ -756,7 +770,7 @@
try: tz=self._tzinfo._zmap[tz.lower()]
except KeyError:
if numericTimeZoneMatch(tz) is None:
- raise self.DateTimeError, \
+ raise DateTimeError, \
'Unknown time zone: %s' % tz
else:
# Get local time zone name
@@ -793,9 +807,6 @@
# self._millis is the time since the epoch
# in long integer milliseconds.
- DateTimeError='DateTimeError'
- SyntaxError ='Invalid Date-Time String'
- DateError ='Invalid Date Components'
int_pattern =re.compile(r'([0-9]+)') #AJ
flt_pattern =re.compile(r':([0-9]+\.[0-9]+)') #AJ
name_pattern =re.compile(r'([a-zA-Z]+)', re.I) #AJ
@@ -949,18 +960,18 @@
if MonthNumbers.has_key(s):
v=MonthNumbers[s]
if month is None: month=v
- else: raise self.SyntaxError, st
+ else: raise SyntaxError, st
continue
# Check for time modifier:
if s in TimeModifiers:
if tm is None: tm=s
- else: raise self.SyntaxError, st
+ else: raise SyntaxError, st
continue
# Check for and skip day of week:
if DayOfWeekNames.has_key(s):
continue
- raise self.SyntaxError, st
+ raise SyntaxError, st
day=None
if ints[-1] > 60 and d not in ['.',':','/'] and len(ints) > 2:
@@ -1023,34 +1034,34 @@
year,month,day = localtime(time())[:3]
year = _correctYear(year)
- if year < 1000: raise self.SyntaxError, st
+ if year < 1000: raise SyntaxError, st
leap = year%4==0 and (year%100!=0 or year%400==0)
try:
if not day or day > self._month_len[leap][month]:
- raise self.DateError, st
+ raise DateError, st
except IndexError:
- raise self.DateError, st
+ raise DateError, st
tod=0
if ints:
i=ints[0]
# Modify hour to reflect am/pm
if tm and (tm=='pm') and i<12: i=i+12
if tm and (tm=='am') and i==12: i=0
- if i > 24: raise self.DateTimeError, st
+ if i > 24: raise TimeError, st
tod = tod + int(i) * 3600
del ints[0]
if ints:
i=ints[0]
- if i > 60: raise self.DateTimeError, st
+ if i > 60: raise TimeError, st
tod = tod + int(i) * 60
del ints[0]
if ints:
i=ints[0]
- if i > 60: raise self.DateTimeError, st
+ if i > 60: raise TimeError, st
tod = tod + i
del ints[0]
- if ints: raise self.SyntaxError,st
+ if ints: raise SyntaxError,st
tod_int = int(math.floor(tod))
@@ -1549,7 +1560,7 @@
"""A DateTime may be added to a number and a number may be
added to a DateTime; two DateTimes cannot be added."""
if hasattr(other,'_t'):
- raise self.DateTimeError,'Cannot add two DateTimes'
+ raise DateTimeError,'Cannot add two DateTimes'
o=float(other)
tz = self._tz
t = (self._t + (o*86400.0))
@@ -1636,7 +1647,7 @@
try:
return self.__parse_iso8601(s)
except IndexError:
- raise self.DateError,'Not an ISO 8601 compliant date string: "%s"' % s
+ raise DateError,'Not an ISO 8601 compliant date string: "%s"' % s
def __parse_iso8601(self,s):
More information about the Zope-Checkins
mailing list