o
    h
                     @  sv   d Z ddlmZ ddlmZ ddlmZmZmZ ddl	m
Z ddl	mZ ddlmZ G d	d
 d
ejZddddZdS )a  
.. note::
    This format cannot be automatically recognized, so the
    class is not registered for use with :py:func:`PIL.Image.open()`.  To open a
    gd file, use the :py:func:`PIL.GdImageFile.open()` function instead.

.. warning::
    THE GD FORMAT IS NOT DESIGNED FOR DATA INTERCHANGE.  This
    implementation is provided for convenience and demonstrational
    purposes only.
    )annotations)IO   )	ImageFileImagePaletteUnidentifiedImageError)i16be)i32be)StrOrBytesPathc                   @  s"   e Zd ZdZdZdZd	ddZdS )
GdImageFilea%  
    Image plugin for the GD uncompressed format.  Note that this format
    is not supported by the standard :py:func:`PIL.Image.open()` function.  To use
    this plugin, you have to import the :py:mod:`PIL.GdImageFile` module and
    use the :py:func:`PIL.GdImageFile.open()` function.
    GDzGD uncompressed imagesreturnNonec                 C  s   | j d usJ | j d}t|dvrd}t|d| _t|dt|df| _|d }|r/dnd}t|d	| }|d
k rA|| jd< t	d|d	| d d	| d d  | _
tdd| j d	| d d dg| _d S )Ni  )i  i  zNot a valid GD 2.x .gd fileP         r         transparencyRGBXi   raw)r   r   L)fpreadi16SyntaxError_mode_sizei32infor   r   paletter   _Tilesizetile)selfsmsg
true_colortrue_color_offsettindex r+   Q/var/www/html/optinet_system/venv/lib/python3.10/site-packages/PIL/GdImageFile.py_open1   s,   
 
zGdImageFile._openN)r   r   )__name__
__module____qualname____doc__formatformat_descriptionr-   r+   r+   r+   r,   r   &   s
    r   rr   StrOrBytesPath | IO[bytes]modestrr   c              
   C  sF   |dkr
d}t |zt| W S  ty" } zd}t||d}~ww )a#  
    Load texture from a GD image file.

    :param fp: GD file name, or an opened file handle.
    :param mode: Optional mode.  In this version, if the mode argument
        is given, it must be "r".
    :returns: An image instance.
    :raises OSError: If the image could not be read.
    r4   zbad modezcannot identify this image fileN)
ValueErrorr   r   r   )r   r6   r'   er+   r+   r,   openT   s   


r:   N)r4   )r   r5   r6   r7   r   r   )r1   
__future__r   typingr    r   r   r   _binaryr   r   r	   r   _typingr
   r   r:   r+   r+   r+   r,   <module>   s   .