1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
"""
babel.localtime
~~~~~~~~~~~~~~~
Babel specific fork of tzlocal to determine the local timezone
of the system.
:copyright: (c) 2013-2022 by the Babel Team.
:license: BSD, see LICENSE for more details.
"""
import sys
import time
from datetime import datetime, timedelta, tzinfo
from threading import RLock
if sys.platform == 'win32':
from babel.localtime._win32 import _get_localzone
else:
from babel.localtime._unix import _get_localzone
_cached_tz = None
_cache_lock = RLock()
STDOFFSET = timedelta(seconds=-time.timezone)
if time.daylight:
DSTOFFSET = timedelta(seconds=-time.altzone)
else:
DSTOFFSET = STDOFFSET
DSTDIFF = DSTOFFSET - STDOFFSET
ZERO = timedelta(0)
class _FallbackLocalTimezone(tzinfo):
def utcoffset(self, dt: datetime) -> timedelta:
if self._isdst(dt):
return DSTOFFSET
else:
return STDOFFSET
def dst(self, dt: datetime) -> timedelta:
if self._isdst(dt):
return DSTDIFF
else:
return ZERO
def tzname(self, dt: datetime) -> str:
return time.tzname[self._isdst(dt)]
def _isdst(self, dt: datetime) -> bool:
tt = (dt.year, dt.month, dt.day,
dt.hour, dt.minute, dt.second,
dt.weekday(), 0, -1)
stamp = time.mktime(tt)
tt = time.localtime(stamp)
return tt.tm_isdst > 0
def get_localzone() -> tzinfo:
"""Returns the current underlying local timezone object.
Generally this function does not need to be used, it's a
better idea to use the :data:`LOCALTZ` singleton instead.
"""
return _get_localzone()
try:
LOCALTZ = get_localzone()
except LookupError:
LOCALTZ = _FallbackLocalTimezone()
|