diff options
author | Ivan Komarov <Ivan.Komarov@dfyz.info> | 2022-02-10 16:46:48 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:46:48 +0300 |
commit | 4de97ab2fe437cbe83e4c63234e809ddd5ac34f2 (patch) | |
tree | ff8fb38b661955e6c99d1d000d6c72f739199590 /contrib/libs/cctz/tzdata/update_tzdata.py | |
parent | 9abfb1a53b7f7b791444d1378e645d8fad9b06ed (diff) | |
download | ydb-4de97ab2fe437cbe83e4c63234e809ddd5ac34f2.tar.gz |
Restoring authorship annotation for Ivan Komarov <Ivan.Komarov@dfyz.info>. Commit 1 of 2.
Diffstat (limited to 'contrib/libs/cctz/tzdata/update_tzdata.py')
-rwxr-xr-x | contrib/libs/cctz/tzdata/update_tzdata.py | 198 |
1 files changed, 99 insertions, 99 deletions
diff --git a/contrib/libs/cctz/tzdata/update_tzdata.py b/contrib/libs/cctz/tzdata/update_tzdata.py index 9c3cd07352..74cd84ef17 100755 --- a/contrib/libs/cctz/tzdata/update_tzdata.py +++ b/contrib/libs/cctz/tzdata/update_tzdata.py @@ -1,112 +1,112 @@ -#!/usr/bin/env python - -import glob -import hashlib -import os -import re -import shutil -import string -import subprocess -import sys -import tarfile -import tempfile -import urllib2 - -def create_cmakelists(zoneinfo_dir): - tz_to_hash = {} - hash_to_content = {} - total_size = 0 - for dirpath, _, filenames in os.walk(zoneinfo_dir): - for fn in filenames: - tz_file_name = os.path.join(dirpath, fn) - with open(tz_file_name) as f: - tz_content = f.read() - if not tz_content.startswith('TZif'): - continue - tz_hash = hashlib.md5(tz_content).hexdigest() - tz_name = tz_file_name.replace(zoneinfo_dir, '').lstrip('/') - tz_to_hash[tz_name] = tz_hash - hash_to_content[tz_hash] = tz_content - total_size += len(tz_content) - print 'Total data size in bytes:', total_size - - generated_dir = 'generated' - if not os.path.isdir(generated_dir): - os.mkdir(generated_dir) - for tz_hash, tz_content in hash_to_content.iteritems(): - with open(os.path.join(generated_dir, tz_hash), 'w') as f: - f.write(tz_content) - +#!/usr/bin/env python + +import glob +import hashlib +import os +import re +import shutil +import string +import subprocess +import sys +import tarfile +import tempfile +import urllib2 + +def create_cmakelists(zoneinfo_dir): + tz_to_hash = {} + hash_to_content = {} + total_size = 0 + for dirpath, _, filenames in os.walk(zoneinfo_dir): + for fn in filenames: + tz_file_name = os.path.join(dirpath, fn) + with open(tz_file_name) as f: + tz_content = f.read() + if not tz_content.startswith('TZif'): + continue + tz_hash = hashlib.md5(tz_content).hexdigest() + tz_name = tz_file_name.replace(zoneinfo_dir, '').lstrip('/') + tz_to_hash[tz_name] = tz_hash + hash_to_content[tz_hash] = tz_content + total_size += len(tz_content) + print 'Total data size in bytes:', total_size + + generated_dir = 'generated' + if not os.path.isdir(generated_dir): + os.mkdir(generated_dir) + for tz_hash, tz_content in hash_to_content.iteritems(): + with open(os.path.join(generated_dir, tz_hash), 'w') as f: + f.write(tz_content) + yamake_template = ( 'RESOURCE(\n' '{}\n' ')' ) - resources = '\n'.join(' generated/{} /cctz/tzdata/{}'.format(tz_hash, tz_name) for tz_name, tz_hash in sorted(tz_to_hash.iteritems())) - - all_hashes = set(tz_to_hash.values()) - hash_pattern = os.path.join('generated', '[{}]'.format(string.hexdigits) * 32) - for fn in glob.glob(hash_pattern): - cmd = 'add' if os.path.basename(fn) in all_hashes else 'remove' - subprocess.check_call(['svn', cmd, '--force', fn]) - + resources = '\n'.join(' generated/{} /cctz/tzdata/{}'.format(tz_hash, tz_name) for tz_name, tz_hash in sorted(tz_to_hash.iteritems())) + + all_hashes = set(tz_to_hash.values()) + hash_pattern = os.path.join('generated', '[{}]'.format(string.hexdigits) * 32) + for fn in glob.glob(hash_pattern): + cmd = 'add' if os.path.basename(fn) in all_hashes else 'remove' + subprocess.check_call(['svn', cmd, '--force', fn]) + with open('ya.make.resources', 'w') as f: print >>f, yamake_template.format(resources) - -def get_latest_iana_version(): - index_html = urllib2.urlopen('http://www.iana.org/time-zones').read() - version_match = re.search('<a href="[^"]*">tzdata(.*).tar.gz</a>', index_html) - if not version_match: - raise Exception('Failed to determine the latest tzdata version') - return version_match.group(1) - -def get_current_version(): + +def get_latest_iana_version(): + index_html = urllib2.urlopen('http://www.iana.org/time-zones').read() + version_match = re.search('<a href="[^"]*">tzdata(.*).tar.gz</a>', index_html) + if not version_match: + raise Exception('Failed to determine the latest tzdata version') + return version_match.group(1) + +def get_current_version(): try: with open('VERSION') as f: return f.read() except: return 0 - -def prepare_tzdata(version): - temp_dir = tempfile.mkdtemp() - try: - for file_type in ('data', 'code'): - file_name = 'tz{}{}.tar.gz'.format(file_type, version) - full_url = 'http://www.iana.org/time-zones/repository/releases/{}'.format(file_name) - print 'Downloading {}'.format(full_url) - - local_file_name = os.path.join(temp_dir, file_name) - with open(local_file_name, 'w') as f: - f.write(urllib2.urlopen(full_url).read()) - - print 'Extracting {}'.format(local_file_name) - with tarfile.open(local_file_name) as f: - f.extractall(path=temp_dir) - - print 'Converting tzdata to binary format' - subprocess.check_call(['make', '-s', '-C', temp_dir, 'TOPDIR={}'.format(temp_dir), 'install']) - + +def prepare_tzdata(version): + temp_dir = tempfile.mkdtemp() + try: + for file_type in ('data', 'code'): + file_name = 'tz{}{}.tar.gz'.format(file_type, version) + full_url = 'http://www.iana.org/time-zones/repository/releases/{}'.format(file_name) + print 'Downloading {}'.format(full_url) + + local_file_name = os.path.join(temp_dir, file_name) + with open(local_file_name, 'w') as f: + f.write(urllib2.urlopen(full_url).read()) + + print 'Extracting {}'.format(local_file_name) + with tarfile.open(local_file_name) as f: + f.extractall(path=temp_dir) + + print 'Converting tzdata to binary format' + subprocess.check_call(['make', '-s', '-C', temp_dir, 'TOPDIR={}'.format(temp_dir), 'install']) + print 'Preparing ya.make.resources' - zoneinfo_dir = os.path.join(temp_dir, 'usr', 'share', 'zoneinfo') - create_cmakelists(zoneinfo_dir) - finally: - shutil.rmtree(temp_dir) - -def main(): - current_version, latest_version = get_current_version(), get_latest_iana_version() - print 'The current version of tzdata is {}'.format(current_version) - print 'The latest version of tzdata on the IANA site is {}'.format(latest_version) - if current_version == latest_version: - print 'You already have the latest version' - return - print 'Updating from {} to {}'.format(current_version, latest_version) - prepare_tzdata(latest_version) - - with open('VERSION', 'w') as f: - f.write(latest_version) - - print 'All good! Now make sure the tests pass, and run this:' - print 'svn ci -m "Updated tzdata to {}"'.format(latest_version) - -if __name__ == '__main__': - main() + zoneinfo_dir = os.path.join(temp_dir, 'usr', 'share', 'zoneinfo') + create_cmakelists(zoneinfo_dir) + finally: + shutil.rmtree(temp_dir) + +def main(): + current_version, latest_version = get_current_version(), get_latest_iana_version() + print 'The current version of tzdata is {}'.format(current_version) + print 'The latest version of tzdata on the IANA site is {}'.format(latest_version) + if current_version == latest_version: + print 'You already have the latest version' + return + print 'Updating from {} to {}'.format(current_version, latest_version) + prepare_tzdata(latest_version) + + with open('VERSION', 'w') as f: + f.write(latest_version) + + print 'All good! Now make sure the tests pass, and run this:' + print 'svn ci -m "Updated tzdata to {}"'.format(latest_version) + +if __name__ == '__main__': + main() |