a
    ¨º”h˜  ã                   @  sJ   d dl mZ d dlmZ ddlmZ G dd„ dƒZddd	d
dœdd„ZdS )é    )Úannotations)ÚCallableé   )ÚImagec                   @  sL   e Zd ZdZdddœdd„Zdddœd	d
„Zd dœdd„Zddœdd„ZdS )ÚIteratora-  
    This class implements an iterator object that can be used to loop
    over an image sequence.

    You can use the ``[]`` operator to access elements by index. This operator
    will raise an :py:exc:`IndexError` if you try to access a nonexistent
    frame.

    :param im: An image object.
    zImage.ImageÚNone)ÚimÚreturnc                 C  s0   t |dƒsd}t|ƒ‚|| _t| jddƒ| _d S )NÚseekzim must have seek methodZ
_min_framer   )ÚhasattrÚAttributeErrorr   ÚgetattrÚposition)Úselfr   Úmsg© r   ú?/var/www/auris/lib/python3.9/site-packages/PIL/ImageSequence.pyÚ__init__$   s
    
zIterator.__init__Úint)Úixr	   c              
   C  sL   z| j  |¡ | j W S  tyF } zd}t|ƒ|‚W Y d }~n
d }~0 0 d S )Núend of sequence)r   r
   ÚEOFErrorÚ
IndexError)r   r   Úer   r   r   r   Ú__getitem__+   s    zIterator.__getitem__)r	   c                 C  s   | S )Nr   )r   r   r   r   Ú__iter__3   s    zIterator.__iter__c              
   C  s\   z$| j  | j¡ |  jd7  _| j W S  tyV } zd}t|ƒ|‚W Y d }~n
d }~0 0 d S )Nr   r   )r   r
   r   r   ÚStopIteration)r   r   r   r   r   r   Ú__next__6   s    zIterator.__next__N)Ú__name__Ú
__module__Ú__qualname__Ú__doc__r   r   r   r   r   r   r   r   r      s
   r   NzImage.Image | list[Image.Image]z+Callable[[Image.Image], Image.Image] | Nonezlist[Image.Image])r   Úfuncr	   c                   s`   t | tƒs| g} g }| D ],}| ¡ }|dd„ t|ƒD ƒ7 }| |¡ qˆ r\‡ fdd„|D ƒS |S )a  
    Applies a given function to all frames in an image or a list of images.
    The frames are returned as a list of separate images.

    :param im: An image, or a list of images.
    :param func: The function to apply to all of the image frames.
    :returns: A list of images.
    c                 S  s   g | ]}|  ¡ ‘qS r   )Úcopy)Ú.0Zim_framer   r   r   Ú
<listcomp>S   ó    zall_frames.<locals>.<listcomp>c                   s   g | ]}ˆ |ƒ‘qS r   r   )r$   r   ©r"   r   r   r%   V   r&   )Ú
isinstanceÚlistÚtellr   r
   )r   r"   ZimsZ
imSequenceÚcurrentr   r'   r   Ú
all_frames@   s    
r,   )N)Ú
__future__r   Útypingr   Ú r   r   r,   r   r   r   r   Ú<module>   s
   * þ