https://github.com/python/cpython/commit/134adb32e86c5c4f1335c5884483adf9c56120b0
commit: 134adb32e86c5c4f1335c5884483adf9c56120b0
branch: main
author: Stan Ulbrych <[email protected]>
committer: encukou <[email protected]>
date: 2025-10-30T12:12:45+01:00
summary:

gh-139188: Remove `Tools/tz/zdump.py` script (GH-139189)

files:
A Misc/NEWS.d/next/Tools-Demos/2025-09-20-20-31-54.gh-issue-139188.zfcxkW.rst
D Tools/tz/zdump.py
M Tools/README

diff --git 
a/Misc/NEWS.d/next/Tools-Demos/2025-09-20-20-31-54.gh-issue-139188.zfcxkW.rst 
b/Misc/NEWS.d/next/Tools-Demos/2025-09-20-20-31-54.gh-issue-139188.zfcxkW.rst
new file mode 100644
index 00000000000000..9f52d0163ab038
--- /dev/null
+++ 
b/Misc/NEWS.d/next/Tools-Demos/2025-09-20-20-31-54.gh-issue-139188.zfcxkW.rst
@@ -0,0 +1 @@
+Remove ``Tools/tz/zdump.py`` script.
diff --git a/Tools/README b/Tools/README
index c8a34d82206672..22d76dfdbcf4a4 100644
--- a/Tools/README
+++ b/Tools/README
@@ -51,8 +51,6 @@ ssl             Scripts to generate ssl_data.h from OpenSSL 
sources, and run
 
 tsan            Utilities for building CPython with thread-sanitizer.
 
-tz              A script to dump timezone from /usr/share/zoneinfo.
-
 unicode         Tools for generating unicodedata and codecs from unicode.org
                 and other mapping files (by Fredrik Lundh, Marc-Andre Lemburg
                 and Martin von Loewis).
diff --git a/Tools/tz/zdump.py b/Tools/tz/zdump.py
deleted file mode 100644
index 39de0a416d0251..00000000000000
--- a/Tools/tz/zdump.py
+++ /dev/null
@@ -1,81 +0,0 @@
-import sys
-import os
-import struct
-from array import array
-from collections import namedtuple
-from datetime import datetime
-
-ttinfo = namedtuple('ttinfo', ['tt_gmtoff', 'tt_isdst', 'tt_abbrind'])
-
-class TZInfo:
-    def __init__(self, transitions, type_indices, ttis, abbrs):
-        self.transitions = transitions
-        self.type_indices = type_indices
-        self.ttis = ttis
-        self.abbrs = abbrs
-
-    @classmethod
-    def fromfile(cls, fileobj):
-        if fileobj.read(4).decode() != "TZif":
-            raise ValueError("not a zoneinfo file")
-        fileobj.seek(20)
-        header = fileobj.read(24)
-        tzh = (tzh_ttisgmtcnt, tzh_ttisstdcnt, tzh_leapcnt,
-               tzh_timecnt, tzh_typecnt, tzh_charcnt) = struct.unpack(">6l", 
header)
-        transitions = array('i')
-        transitions.fromfile(fileobj, tzh_timecnt)
-        if sys.byteorder != 'big':
-            transitions.byteswap()
-
-        type_indices = array('B')
-        type_indices.fromfile(fileobj, tzh_timecnt)
-
-        ttis = []
-        for i in range(tzh_typecnt):
-            ttis.append(ttinfo._make(struct.unpack(">lbb", fileobj.read(6))))
-
-        abbrs = fileobj.read(tzh_charcnt)
-
-        self = cls(transitions, type_indices, ttis, abbrs)
-        self.tzh = tzh
-
-        return self
-
-    def dump(self, stream, start=None, end=None):
-        for j, (trans, i) in enumerate(zip(self.transitions, 
self.type_indices)):
-            utc = datetime.utcfromtimestamp(trans)
-            tti = self.ttis[i]
-            lmt = datetime.utcfromtimestamp(trans + tti.tt_gmtoff)
-            abbrind = tti.tt_abbrind
-            abbr = self.abbrs[abbrind:self.abbrs.find(0, abbrind)].decode()
-            if j > 0:
-                prev_tti = self.ttis[self.type_indices[j - 1]]
-                shift = " %+g" % ((tti.tt_gmtoff - prev_tti.tt_gmtoff) / 3600)
-            else:
-                shift = ''
-            print("%s UTC = %s %-5s isdst=%d" % (utc, lmt, abbr, tti[1]) + 
shift, file=stream)
-
-    @classmethod
-    def zonelist(cls, zonedir='/usr/share/zoneinfo'):
-        zones = []
-        for root, _, files in os.walk(zonedir):
-            for f in files:
-                p = os.path.join(root, f)
-                with open(p, 'rb') as o:
-                    magic =  o.read(4)
-                if magic == b'TZif':
-                    zones.append(p[len(zonedir) + 1:])
-        return zones
-
-if __name__ == '__main__':
-    if len(sys.argv) < 2:
-        zones = TZInfo.zonelist()
-        for z in zones:
-            print(z)
-        sys.exit()
-    filepath = sys.argv[1]
-    if not filepath.startswith('/'):
-        filepath = os.path.join('/usr/share/zoneinfo', filepath)
-    with open(filepath, 'rb') as fileobj:
-        tzi = TZInfo.fromfile(fileobj)
-    tzi.dump(sys.stdout)

_______________________________________________
Python-checkins mailing list -- [email protected]
To unsubscribe send an email to [email protected]
https://mail.python.org/mailman3//lists/python-checkins.python.org
Member address: [email protected]

Reply via email to