HEX
Server: Apache
System: Linux server2.voipitup.com.au 4.18.0-553.109.1.lve.el8.x86_64 #1 SMP Thu Mar 5 20:23:46 UTC 2026 x86_64
User: posscale (1027)
PHP: 8.2.30
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //opt/saltstack/salt/lib/python3.10/site-packages/dateutil/tz/__pycache__/win.cpython-310.pyc
o

�N�g�2�@s�dZddlZddlZddlmZddlmZzddlZddlmZWne	y-e
d��wddlmZgd	�Z
e�d
�ZdZdZd
Zdd�Ze�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�Zdd�Zdd�ZdS)z�
This module provides an interface to the native time zone data on Windows,
including :py:class:`datetime.tzinfo` implementations.

Attempting to import this module on a non-Windows platform will raise an
:py:obj:`ImportError`.
�N)�winreg)�	text_type)�wintypesz#Running tzwin on non-Windows system�)�tzrangebase)�tzwin�
tzwinlocal�tzres�z7SOFTWARE\Microsoft\Windows NT\CurrentVersion\Time Zonesz4SOFTWARE\Microsoft\Windows\CurrentVersion\Time Zonesz4SYSTEM\CurrentControlSet\Control\TimeZoneInformationcCsJt�dtj�}zt�|t���t}Wntyt}Ynw|��|S�N)r�ConnectRegistry�HKEY_LOCAL_MACHINE�OpenKey�TZKEYNAMENT�CloseZWindowsError�TZKEYNAME9X)�handle�	TZKEYNAME�r�C/opt/saltstack/salt/lib/python3.10/site-packages/dateutil/tz/win.py�
_settzkeyname"s�rc@s6eZdZdZe�ej�Zd
dd�Z	dd�Z
dd�Zd	S)r	z}
    Class for accessing ``tzres.dll``, which contains timezone name related
    resources.

    .. versionadded:: 2.5.0
    �	tzres.dllcCs@t�d�}tjtjtjtjf|j_|j|_t�|�|_	||_
dS)N�user32)�ctypesZWinDLLrZ	HINSTANCEZUINT�LPWSTR�c_int�LoadStringW�argtypes�_tzres�	tzres_loc)�selfrrrrr�__init__9s
�
ztzres.__init__cCs<|��}t�t�|�tj�}|�|jj||d�}|d|�S)a�
        Load a timezone name from a DLL offset (integer).

        >>> from dateutil.tzwin import tzres
        >>> tzr = tzres()
        >>> print(tzr.load_name(112))
        'Eastern Standard Time'

        :param offset:
            A positive integer value referring to a string from the tzres dll.

        .. note::

            Offsets found in the registry are generally of the form
            ``@tzres.dll,-114``. The offset in this case is 114, not -114.

        rN)	�p_wcharr�cast�byrefrrrr�_handle)r �offsetZresourceZlpBufferZncharrrr�	load_nameGsztzres.load_namecCsB|�d�s|S|�d�}zt|d�}Wntd��|�|�S)a�
        Parse strings as returned from the Windows registry into the time zone
        name as defined in the registry.

        >>> from dateutil.tzwin import tzres
        >>> tzr = tzres()
        >>> print(tzr.name_from_string('@tzres.dll,-251'))
        'Dateline Daylight Time'
        >>> print(tzr.name_from_string('Eastern Standard Time'))
        'Eastern Standard Time'

        :param tzname_str:
            A timezone name string as returned from a Windows registry key.

        :return:
            Returns the localized timezone string from tzres.dll if the string
            is of the form `@tzres.dll,-offset`, else returns the input string.
        �@z,-rzMalformed timezone string.)�
startswith�split�int�
ValueErrorr')r Z
tzname_strZ	name_spltr&rrr�name_from_string^s


ztzres.name_from_stringN)r)�__name__�
__module__�__qualname__�__doc__r�POINTERrZWCHARr"r!r'r-rrrrr	0s
r	c@sPeZdZdZdd�Zdd�Zedd��Zdd	�Zd
d�Z	dd
�Z
edd��ZdS)�	tzwinbasezBtzinfo class based on win32's timezones available in the registry.cCstd��)Nz#tzwinbase is an abstract base class)�NotImplementedError�r rrrr!sztzwinbase.__init__cCs�t|t�stS|j|jkoN|j|jkoN|j|jkoN|j|jkoN|j|jkoN|j|jkoN|j	|j	koN|j
|j
koN|j|jkoN|j|jkoN|j
|j
koN|j|jkSr)�
isinstancer3�NotImplemented�_std_offset�_dst_offset�
_stddayofweek�
_dstdayofweek�_stdweeknumber�_dstweeknumber�_stdhour�_dsthour�
_stdminute�
_dstminute�	_std_abbr�	_dst_abbr)r �otherrrr�__eq__�s2

�
�
�
�
�
�
�
�
	�

�
�ztzwinbase.__eq__c	s�t�dtj��7}t�|t����fdd�tt���d�D�}Wd�n1s)wYWd�|SWd�|S1sAwY|S)z4Return a list of all time zones known to the system.Ncsg|]}t��|��qSr)rZEnumKey)�.0�i��tzkeyrr�
<listcomp>�s�z"tzwinbase.list.<locals>.<listcomp>r)rrr
rr�range�QueryInfoKey)r�resultrrHr�list�s
��
��
��ztzwinbase.listcC�|jS)z;
        Return the display name of the time zone.
        )�_displayr5rrr�display�sztzwinbase.displaycCsT|jsdSt||j|j|j|j|j�}t||j|j|j	|j
|j�}||j8}||fS)a�
        For a given year, get the DST on and off transition times, expressed
        always on the standard time side. For zones with no transitions, this
        function returns ``None``.

        :param year:
            The year whose transitions you would like to query.

        :return:
            Returns a :class:`tuple` of :class:`datetime.datetime` objects,
            ``(dston, dstoff)`` for zones with an annual DST transition, or
            ``None`` for fixed offset zones.
        N)
�hasdst�picknthweekday�	_dstmonthr;r?rAr=�	_stdmonthr:r>r@r<�_dst_base_offset)r �yearZdstonZdstoffrrr�transitions�s��
ztzwinbase.transitionscCs
|jdkS)Nr)rTr5rrr�_get_hasdst��
ztzwinbase._get_hasdstcCrOr)�_dst_base_offset_r5rrrrV�sztzwinbase._dst_base_offsetN)
r.r/r0r1r!rE�staticmethodrNrQrXrY�propertyrVrrrrr3}s
r3c@s(eZdZdZdd�Zdd�Zdd�ZdS)	ra�
    Time zone object created from the zone info in the Windows registry

    These are similar to :py:class:`dateutil.tz.tzrange` objects in that
    the time zone data is provided in the format of a single offset rule
    for either 0 or 2 time zone transitions per year.

    :param: name
        The name of a Windows time zone key, e.g. "Eastern Standard Time".
        The full list of keys can be retrieved with :func:`tzwin.list`.
    c		Cs>||_t�dtj��+}td�jt|d�}t�||��}t|�}Wd�n1s)wYWd�n1s8wY|d|_	|d|_
|d|_t�
d|d�}|d|d	}||d
}tj|d�|_tj|d�|_|dd
�\|_|_|_|_|_|dd�\|_|_|_|_|_|j|j|_|��|_dS)Nz{kn}\{name})�kn�nameZStdZDlt�Displayz=3l16hZTZIrr���minutes��	��)�_namerrr
r�formatrr�valuestodictrBrCrP�struct�unpack�datetime�	timedeltar8r9rUr:r<r>r@rTr;r=r?rAr[rYrR)	r r_r�	tzkeynamerI�keydict�tup�	stdoffset�	dstoffsetrrrr!�s<
���



�
�ztzwin.__init__cC�dt|j�S)Nz	tzwin(%s))�reprrhr5rrr�__repr__��ztzwin.__repr__cCs|j|jffSr)�	__class__rhr5rrr�
__reduce__�rwztzwin.__reduce__N)r.r/r0r1r!rvryrrrrr�s
%rc@s0eZdZdZdd�Zdd�Zdd�Zdd	�Zd
S)ra,
    Class representing the local time zone information in the Windows registry

    While :class:`dateutil.tz.tzlocal` makes system calls (via the :mod:`time`
    module) to retrieve time zone information, ``tzwinlocal`` retrieves the
    rules directly from the Windows registry and creates an object like
    :class:`dateutil.tz.tzwin`.

    Because Windows does not have an equivalent of :func:`time.tzset`, on
    Windows, :class:`dateutil.tz.tzlocal` instances will always reflect the
    time zone settings *at the time that the process was started*, meaning
    changes to the machine's time zone settings during the run of a program
    on Windows will **not** be reflected by :class:`dateutil.tz.tzlocal`.
    Because ``tzwinlocal`` reads the registry directly, it is unaffected by
    this issue.
    c
	Cs�t�dtj��d}t�|t��}t|�}Wd�n1swY|d|_|d|_z+td�j	t
|jd�}t�||��}t|�}|d|_Wd�n1sQwYWntycd|_YnwWd�n1snwY|d|d}||d}t
j|d	�|_t
j|d	�|_t�d
|d�}	|	dd
�\|_|_|_|_|	d|_t�d
|d�}	|	dd
�\|_|_|_|_|	d|_|j|j|_|��|_dS)NZStandardNameZDaylightNamez	{kn}\{sn})r^Zsnr`ZBiasZStandardBiasZDaylightBiasrbz=8hZ
StandardStartr�r
Z
DaylightStart) rrr
r�TZLOCALKEYNAMErjrBrCrrirrP�OSErrorrmrnr8r9rkrlrUr<r>r@r:rTr=r?rAr;r[rYrR)
r rZ
tzlocalkeyrprorIZ_keydictrrrsrqrrrr!sP
�


���
���
�

�
ztzwinlocal.__init__cCsdS)Nztzwinlocal()rr5rrrrvBsztzwinlocal.__repr__cCrt)Nztzwinlocal(%s))rurBr5rrr�__str__Esztzwinlocal.__str__cCs
|jdfS)Nr)rxr5rrrryIrZztzwinlocal.__reduce__N)r.r/r0r1r!rvr}ryrrrrrs.rc	CsTt�||d||�}|j||��ddd�}||dt}|j|kr(|t8}|S)z> dayofweek == 0 means Sunday, whichweek 5 means last instance rr
)�day)rm�replace�
isoweekday�ONEWEEK�month)	rWr�Z	dayofweek�hour�minuteZ	whichweek�firstZ
weekdayone�wdrrrrSMs
rScCs�i}t�|�d}d}t|�D];}t�||�\}}}|tjks$|tjkr-|d@r,|d}n|tjkrF|�d�rA|p;t�}|�	|�}|�
d�}|||<q|S)z0Convert a registry key's values to a dictionary.rNllz@tzres�)rrLrKZ	EnumValueZ	REG_DWORDZREG_DWORD_LITTLE_ENDIANZREG_SZr)r	r-�rstrip)�keyZdout�sizeZtz_resrGZkey_name�valueZdtyperrrrj[s �





rj)r1rmrkZ	six.movesrZsixrrrr,�ImportErrorZ_commonr�__all__rnr�rrr{rr�objectr	r3rrrSrjrrrr�<module>s2�
MM9J