3 L(Y[@sddlZddlZddlmZddlmZddlmZddlm Z ddl m Z ddd d gZ d Z d ZejZeed sxddZGddde Z ddZGdddeZeZdddZddZdd ZdS)N)TarFile)get_data)BytesIO)closing)tzfileget_zonefile_instancegettzgettz_db_metadataZrebuildzdateutil-zoneinfo.tar.gzMETADATA__exit__cOsttj||S)N)rropen)argskwargsrM/private/tmp/pip-build-nl73fm5q/python-dateutil/dateutil/zoneinfo/__init__.pytar_opensrc@seZdZddZdS)rcCs t|jffS)N)r _filename)selfrrr __reduce__sztzfile.__reduce__N)__name__ __module__ __qualname__rrrrrrsrcCsJyttttStk rD}ztjdj|j|j dSd}~XnXdS)NzI/O error({0}): {1}) rrr ZONEFILENAMEIOErrorwarningswarnformaterrnostrerror)errrgetzoneinfofile_streams r c@s eZdZdddZdddZdS) ZoneInfoFileNcs|dk rt|ddtfddjD_tfddjD}jj|y.jjt}|jj d}t j |_ Wnt k rd_ YnXWdQRXnt_d_ dS)Nr)fileobjmodec3s:|]2}|jr|jtkr|jtj||jdfVqdS))filenameN)isfilename METADATA_FNr extractfile).0zf)tfrr /sz(ZoneInfoFile.__init__..c3s0|](}|js|jr|jj|jfVqdS)N)islnkissymr'zoneslinkname)r*Zzl)rrrr-7szUTF-8)rdict getmembersr0updater) getmemberr(readdecodejsonloadsmetadataKeyError)rZzonefile_streamlinksZ metadata_jsonZ metadata_strr)rr,r__init__'s   zZoneInfoFile.__init__cCs|jj||S)ak Wrapper for :func:`ZoneInfoFile.zones.get`. This is a convenience method for retrieving zones from the zone dictionary. :param name: The name of the zone to retrieve. (Generally IANA zone names) :param default: The value to return in the event of a missing key. .. versionadded:: 2.6.0 )r0get)rr'defaultrrrr>FszZoneInfoFile.get)N)N)rrrr=r>rrrrr!&s r!FcCs2|r d}n ttdd}|dkr.tt}|t_|S)a% This is a convenience function which provides a :class:`ZoneInfoFile` instance using the data provided by the ``dateutil`` package. By default, it caches a single instance of the ZoneInfoFile object and returns that. :param new_instance: If ``True``, a new instance of :class:`ZoneInfoFile` is instantiated and used as the cached instance for the next call. Otherwise, new instances are created only as necessary. :return: Returns a :class:`ZoneInfoFile` object. .. versionadded:: 2.6 N_cached_instance)getattrrr!r r@)Z new_instanceZzifrrrr`s  cCs8tjdtttdkr(tjtttdjj |S)a+ This retrieves a time zone from the local zoneinfo tarball that is packaged with dateutil. :param name: An IANA-style time zone name, as found in the zoneinfo file. :return: Returns a :class:`dateutil.tz.tzfile` time zone object. .. warning:: It is generally inadvisable to use this function, and it is only provided for API compatibility with earlier versions. This is *not* equivalent to ``dateutil.tz.gettz()``, which selects an appropriate time zone based on the inputs, favoring system zoneinfo. This is ONLY for accessing the dateutil-specific zoneinfo (which may be out of date compared to the system zoneinfo). .. deprecated:: 2.6 If you need to use a specific zoneinfofile over the system zoneinfo, instantiate a :class:`dateutil.zoneinfo.ZoneInfoFile` object and call :func:`dateutil.zoneinfo.ZoneInfoFile.get(name)` instead. Use :func:`get_zonefile_instance` to retrieve an instance of the dateutil-provided zoneinfo. zzoneinfo.gettz() will be removed in future versions, to use the dateutil-provided zoneinfo files, instantiate a ZoneInfoFile object and use ZoneInfoFile.zones.get() instead. See the documentation for details.r) rrDeprecationWarninglen_CLASS_ZONE_INSTANCEappendr!r r0r>)r'rrrr}s  cCs2tjdtttdkr(tjtttdjS)a! Get the zonefile metadata See `zonefile_metadata`_ :returns: A dictionary with the database metadata .. deprecated:: 2.6 See deprecation warning in :func:`zoneinfo.gettz`. To get metadata, query the attribute ``zoneinfo.ZoneInfoFile.metadata``. zzoneinfo.gettz_db_metadata() will be removed in future versions, to use the dateutil-provided zoneinfo files, ZoneInfoFile object and query the 'metadata' attribute instead. See the documentation for details.r) rrrBrCrDrEr!r r:rrrrr s  )F)rr8tarfilerpkgutilrior contextlibrZ dateutil.tzr__all__rr(r rhasattrr objectr!listrDrrr rrrrs&       7 &