##// END OF EJS Templates
Clean up date and timezone handling....
Bryan O'Sullivan -
r1321:b47f96a1 default
parent child Browse files
Show More
@@ -5,8 +5,9 b''
5 5 # This software may be used and distributed according to the terms
6 6 # of the GNU General Public License, incorporated herein by reference.
7 7
8 import os, time
9 8 from revlog import *
9 from demandload import demandload
10 demandload(globals(), "os time util")
10 11
11 12 class changelog(revlog):
12 13 def __init__(self, opener):
@@ -20,11 +21,15 b' class changelog(revlog):'
20 21 l = text[:last].splitlines()
21 22 manifest = bin(l[0])
22 23 user = l[1]
23 date = l[2]
24 if " " not in date:
25 date += " 0" # some tools used -d without a timezone
24 date = l[2].split(' ')
25 time = int(date.pop(0))
26 try:
27 # various tools did silly things with the time zone field.
28 timezone = int(date[0])
29 except:
30 timezone = 0
26 31 files = l[3:]
27 return (manifest, user, date, files, desc)
32 return (manifest, user, (time, timezone), files, desc)
28 33
29 34 def read(self, node):
30 35 return self.extract(self.revision(node))
@@ -44,9 +49,7 b' class changelog(revlog):'
44 49 if abs(offset) >= 43200:
45 50 raise ValueError('impossible time zone offset: %d' % offset)
46 51 else:
47 if time.daylight: offset = time.altzone
48 else: offset = time.timezone
49 date = "%d %d" % (time.time(), offset)
52 date = "%d %d" % util.makedate()
50 53 list.sort()
51 54 l = [hex(manifest), user, date] + list + ["", desc]
52 55 text = "\n".join(l)
@@ -264,7 +264,7 b' def dodiff(fp, ui, repo, node1, node2, f'
264 264 if node2:
265 265 change = repo.changelog.read(node2)
266 266 mmap2 = repo.manifest.read(change[0])
267 date2 = util.datestr(change)
267 date2 = util.datestr(change[2])
268 268 def read(f):
269 269 return repo.file(f).read(mmap2[f])
270 270 else:
@@ -282,7 +282,7 b' def dodiff(fp, ui, repo, node1, node2, f'
282 282
283 283 change = repo.changelog.read(node1)
284 284 mmap = repo.manifest.read(change[0])
285 date1 = util.datestr(change)
285 date1 = util.datestr(change[2])
286 286
287 287 for f in c:
288 288 to = None
@@ -319,7 +319,7 b' def show_changeset(ui, repo, rev=0, chan'
319 319 return
320 320
321 321 changes = log.read(changenode)
322 date = util.datestr(changes)
322 date = util.datestr(changes[2])
323 323
324 324 parents = [(log.rev(p), ui.verbose and hex(p) or short(p))
325 325 for p in log.parents(changenode)
@@ -27,7 +27,7 b' def age(x):'
27 27 return "%d %s" % (c, plural(t, c))
28 28
29 29 now = time.time()
30 then = int(x[2].split(' ')[0])
30 then = x[2][0]
31 31 delta = max(1, int(now - then))
32 32
33 33 scales = [["second", 1],
@@ -155,13 +155,13 b' class templater:'
155 155 common_filters = {
156 156 "escape": cgi.escape,
157 157 "age": age,
158 "date": util.datestr,
158 "date": lambda x: util.datestr(x[2]),
159 159 "addbreaks": nl2br,
160 160 "obfuscate": obfuscate,
161 161 "short": (lambda x: x[:12]),
162 162 "firstline": (lambda x: x.splitlines(1)[0]),
163 163 "permissions": (lambda x: x and "-rwxr-xr-x" or "-rw-r--r--"),
164 "rfc822date": lambda x: util.datestr(x, "%a, %d %b %Y %H:%M:%S"),
164 "rfc822date": lambda x: util.datestr(x[2], "%a, %d %b %Y %H:%M:%S"),
165 165 }
166 166
167 167 class hgweb:
@@ -185,7 +185,7 b' class hgweb:'
185 185 self.allowpull = self.repo.ui.configbool("web", "allowpull", True)
186 186
187 187 def date(self, cs):
188 return util.datestr(cs)
188 return util.datestr(cs[2])
189 189
190 190 def listfiles(self, files, mf):
191 191 for f in files[:self.maxfiles]:
@@ -544,21 +544,17 b' def filechunkiter(f, size = 65536):'
544 544 yield s
545 545 s = f.read(size)
546 546
547 def datestr(change=None, format='%c'):
548 """represent a change date as a localized time.
549 a change date is a 'unixtime offset' string, where unixtime is
550 seconds since the epoch, and offset is seconds away from UTC."""
551 if change is None:
552 t = time.time()
553 if time.daylight: tz = time.altzone
554 else: tz = time.timezone
555 else:
556 t, tz = change[2].split(' ')
557 try:
558 # a conversion tool was sticking non-integer offsets into repos
559 tz = int(tz)
560 except ValueError:
561 tz = 0
547 def makedate():
548 t = time.time()
549 if time.daylight: tz = time.altzone
550 else: tz = time.timezone
551 return t, tz
552
553 def datestr(date=None, format='%c'):
554 """represent a (unixtime, offset) tuple as a localized time.
555 unixtime is seconds since the epoch, and offset is the time zone's
556 number of seconds away from UTC."""
557 t, tz = date or makedate()
562 558 return ("%s %+03d%02d" %
563 559 (time.strftime(format, time.gmtime(float(t) - tz)),
564 560 -tz / 3600,
General Comments 0
You need to be logged in to leave comments. Login now