-
Notifications
You must be signed in to change notification settings - Fork 28
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Using of proper TZ environment #106
Comments
@mowgli Do you think you'd be able to pull together a PR that improves the timezone handling for the timezones of this format? 🙂 |
If it would have been perl, I would have answered that question with a clear yes. But I have no real clues of python. I could help with algorithmic ideas but not coding in python. |
Got it. Well, what would really help is if you could outline in more detail what were the parts of the codebase you needed to patch out in order to get your code working with the |
Well, in tzlocal is a assertion that went mad. So I just patched them out. It is not really a fix but it keep most of it from breaking and throwing stack traces: Version 2.x: --- a/tzlocal/unix.py
+++ b/tzlocal/unix.py
@@ -84,10 +84,6 @@ def _get_localzone(_root='/'):
if not etctz:
continue
tz = pytz.timezone(etctz.replace(' ', '_'))
- if _root == '/':
- # We are using a file in etc to name the timezone.
- # Verify that the timezone specified there is actually used:
- utils.assert_tz_offset(tz)
return tz
except IOError:
@@ -122,10 +118,6 @@ def _get_localzone(_root='/'):
# We found a timezone
tz = pytz.timezone(etctz.replace(' ', '_'))
- if _root == '/':
- # We are using a file in etc to name the timezone.
- # Verify that the timezone specified there is actually used:
- utils.assert_tz_offset(tz)
return tz
except IOError: Version 3.x: --- a/tzlocal/unix.py
+++ b/tzlocal/unix.py
@@ -90,10 +90,6 @@ def _get_localzone(_root='/'):
if not etctz:
continue
tz = ZoneInfo(etctz.replace(' ', '_'))
- if _root == '/':
- # We are using a file in etc to name the timezone.
- # Verify that the timezone specified there is actually used:
- utils.assert_tz_offset(tz)
return tz
except (IOError, UnicodeDecodeError):
@@ -128,10 +124,6 @@ def _get_localzone(_root='/'):
# We found a timezone
tz = ZoneInfo(etctz.replace(' ', '_'))
- if _root == '/':
- # We are using a file in etc to name the timezone.
- # Verify that the timezone specified there is actually used:
- utils.assert_tz_offset(tz)
return tz
except (IOError, UnicodeDecodeError) as e: Version 1.5.1 was a last working version of tzlocal. Afterwards it gets more and more bad. However, I do still not understand, why this is implemented that broken way and not using the python standard methods from time import which seems to do it the right way. |
Ah yes, even the 1.5.1 version was a bit wrong: --- unix.py.orig 2020-03-05 15:31:48.600637137 +0100
+++ unix.py 2020-03-05 15:32:03.720637570 +0100
@@ -105,7 +105,7 @@
if os.path.exists(tzpath) and os.path.islink(tzpath):
tzpath = os.path.realpath(tzpath)
start = tzpath.find("/")+1
- while start is not 0:
+ while start != 0:
tzpath = tzpath[start:]
try:
return pytz.timezone(tzpath) |
There is another information, It seems that tzlocal changed its API between 2 and 3. And the later one is incompatible at all with tasklib. |
Is this true for the newest tasklib release? I was under the impression we are now compatible with tzlocal 3.x. |
I don't know. I use tasklib 2.3.4-r1 in gentoo. Devuan uses 2.4.3 but I have tzlocal on hold on that system with version 1.5.1 as this version had have only little trouble with python3 (see above). |
Long time now, I have troubles with tools using tasklib due to a custom setting of TZ environment variable ("CET-1", without summertime)
While python is able to work correct with that
The Approach of tzlocal using ZoneInfo is completely broken and gives exceptions and wrong results. Some of the major troubles can be patched out of tzlocal by dropping the stupid asserts but the main problem remains that ZoneInfo is not able to parse proper TZ environment.
So please use the python base structures to use timezone instead of the broken tzlocal/ZoneInfo way.
The text was updated successfully, but these errors were encountered: