U
    ڲg,'                  	   @  sL  d dl mZ d dlZd dlZd dlZd dlZd dlZd dlmZ d dl	m
Z
 ddlmZ g Zd3ddd	d
dZd4dddddddZG dd dZG dd deZejdkree G dd deZejdkree G dd deZG dd deZG dd  d eZG d!d" d"eZG d#d$ d$eZG d%d& d&eZejd'kred(rVee ed)rjee ed*r~ee ed+ree ed,ree G d-d. d.eZzd d/lmZ W n ek
r   Y n
X ee e d0krHe!ej"d1k re#d2 e$  e%ej"d "Z&e#ee&fej"d1d   W 5 Q R X dS )5    )annotationsNquote)Any   )ImageintNone)orderreturnc                 C  sN   zt | tr|  } W n tk
r(   Y nX |dkr>t|  ntd|  dS )a$  
    The :py:func:`register` function is used to register additional viewers::

        from PIL import ImageShow
        ImageShow.register(MyViewer())  # MyViewer will be used as a last resort
        ImageShow.register(MySecondViewer(), 0)  # MySecondViewer will be prioritised
        ImageShow.register(ImageShow.XVViewer(), 0)  # XVViewer will be prioritised

    :param viewer: The viewer to be registered.
    :param order:
        Zero or a negative integer to prepend this viewer to the list,
        a positive integer to append it.
    r   N)
issubclassViewer	TypeError_viewersappendinsert)viewerr
    r   1/tmp/pip-unpacked-wheel-xela2va7/PIL/ImageShow.pyregister   s    

r   Image.Image
str | Noner   bool)imagetitleoptionsr   c                 K  s*   t D ] }|j| fd|i|r dS qdS )a  
    Display a given image.

    :param image: An image object.
    :param title: Optional title. Not all viewers can display the title.
    :param \**options: Additional viewer options.
    :returns: ``True`` if a suitable viewer was found, ``False`` otherwise.
    r   TF)r   show)r   r   r   r   r   r   r   r   6   s    	r   c                   @  s   e Zd ZU dZddddddZdZd	ed
< i Zded< dd	dddZddddddZ	dddddZ
ddddddZddddddZdS )r   zBase class for viewers.r   r   r   r   r   r   c                 K  sL   |j dks>| jdkr|j dks>t|j }|j |kr>||}| j|f|S )z
        The main function for displaying an image.
        Converts the given image to the target format and displays it.
        )1ZRGBAPNG)zI;16ZLA)modeformatr   Zgetmodebaseconvert
show_image)selfr   r   baser   r   r   r   J   s    

zViewer.showNr   r!   zdict[str, Any]r   )r   r   c                 C  s   | j S )z3Return format name, or ``None`` to save as PGM/PPM.)r!   r$   r   r   r   r   
get_formata   s    zViewer.get_formatstrfiler   r   c                 K  s   d}t |dS )zj
        Returns the command used to display the file.
        Not implemented in the base class.
        zunavailable in base viewerN)NotImplementedError)r$   r*   r   msgr   r   r   get_commande   s    zViewer.get_commandc                 C  s   |j f d| |i| jS )z+Save to temporary file and return filename.r!   )_dumpr'   r   r&   r   r   r   
save_imagem   s    zViewer.save_imagec                 K  s   | j | |f|S )zDisplay the given image.)	show_filer/   r$   r   r   r   r   r   r#   q   s    zViewer.show_imagepathr   r   c                 K  s(   t j|stt | j|f| dS )%
        Display given file.
        r   )osr3   existsFileNotFoundErrorsystemr-   r$   r3   r   r   r   r   r0   u   s    zViewer.show_file)__name__
__module____qualname____doc__r   r!   __annotations__r   r'   r-   r/   r#   r0   r   r   r   r   r   E   s   
r   c                   @  sB   e Zd ZdZdZdddZddddd	d
ZddddddZdS )WindowsViewerzNThe default viewer on Windows is the default system application for PNG files.r   r   TZcompress_levelZsave_allr(   r   r)   c                 K  s   d| d| dS )Nzstart "Pillow" /WAIT "z)" && ping -n 4 127.0.0.1 >NUL && del /f ""r   r$   r*   r   r   r   r   r-      s    zWindowsViewer.get_commandr   r2   c                 K  s4   t j|sttj| j|f|dttdd dS )r4   TZCREATE_NO_WINDOW)shellcreationflagsr   )r5   r3   r6   r7   
subprocessPopenr-   getattrr9   r   r   r   r0      s    zWindowsViewer.show_fileNr:   r;   r<   r=   r!   r   r-   r0   r   r   r   r   r?      s
   
r?   win32c                   @  sB   e Zd ZdZdZdddZddddd	d
ZddddddZdS )	MacViewerz2The default viewer on macOS using ``Preview.app``.r   r   Tr@   r(   r   r)   c                 K  s(   d}d| dt | dt | d}|S )Nzopen -a Preview.app( z; sleep 20; rm -f z)&r   r$   r*   r   commandr   r   r   r-      s     zMacViewer.get_commandr   r2   c                 K  sL   t j|sttddd|g tjp0t	d}|rHt
|dd|g dS )r4   openz-azPreview.apppython3z-cz<import os, sys, time; time.sleep(20); os.remove(sys.argv[1])r   )r5   r3   r6   r7   rE   callsys
executableshutilwhichrF   )r$   r3   r   rS   r   r   r   r0      s    zMacViewer.show_fileNrH   r   r   r   r   rJ      s
   
rJ   darwinc                   @  sD   e Zd ZdZdddZejddddd	d
ZddddddZdS )
UnixViewerr   r   Tr@   r(   r   tuple[str, str]r)   c                 K  s   d S )Nr   rB   r   r   r   get_command_ex   s    zUnixViewer.get_command_exc                 K  s$   | j |f|d }| dt| S )Nr   rL   )rY   r   rM   r   r   r   r-      s    zUnixViewer.get_commandN)	r:   r;   r<   r!   r   abcabstractmethodrY   r-   r   r   r   r   rW      s
   
rW   c                   @  s4   e Zd ZdZddddddZdddd	d
dZdS )	XDGViewerz3
    The freedesktop.org ``xdg-open`` command.
    r(   r   rX   r)   c                 K  s   d }}||fS )Nxdg-openr   )r$   r*   r   rN   rS   r   r   r   rY      s    zXDGViewer.get_command_exr   r2   c                 K  s"   t j|sttd|g dS )r4   r]   r   r5   r3   r6   r7   rE   rF   r9   r   r   r   r0      s    zXDGViewer.show_fileNr:   r;   r<   r=   rY   r0   r   r   r   r   r\      s   r\   c                   @  s8   e Zd ZdZdddddddd	Zddd
dddZdS )DisplayViewerz`
    The ImageMagick ``display`` command.
    This viewer supports the ``title`` parameter.
    Nr(   r   r   rX   r*   r   r   r   c                 K  s&   d }}|r|dt | 7 }||fS )Ndisplayz -title r   r$   r*   r   r   rN   rS   r   r   r   rY      s    zDisplayViewer.get_command_exr   r2   c                 K  sH   t j|stdg}|d}|r0|d|g7 }|| t| dS )r4   rb   r   z-titler   r5   r3   r6   r7   getr   rE   rF   r$   r3   r   argsr   r   r   r   r0      s    


zDisplayViewer.show_file)Nr_   r   r   r   r   r`      s    r`   c                   @  s4   e Zd ZdZddddddZdddd	d
dZdS )GmDisplayViewerz*The GraphicsMagick ``gm display`` command.r(   r   rX   r)   c                 K  s   d}d}||fS )Ngmz
gm displayr   r$   r*   r   rS   rN   r   r   r   rY     s    zGmDisplayViewer.get_command_exr   r2   c                 K  s$   t j|sttdd|g dS )r4   ri   rb   r   r^   r9   r   r   r   r0     s    zGmDisplayViewer.show_fileNr_   r   r   r   r   rh     s   rh   c                   @  s4   e Zd ZdZddddddZdddd	d
dZdS )	EogViewerz'The GNOME Image Viewer ``eog`` command.r(   r   rX   r)   c                 K  s   d}d}||fS )Neogzeog -nr   rj   r   r   r   rY     s    zEogViewer.get_command_exr   r2   c                 K  s$   t j|sttdd|g dS )r4   rl   z-nr   r^   r9   r   r   r   r0     s    zEogViewer.show_fileNr_   r   r   r   r   rk     s   rk   c                   @  s8   e Zd ZdZdddddddd	Zddd
dddZdS )XVViewerzX
    The X Viewer ``xv`` command.
    This viewer supports the ``title`` parameter.
    Nr(   r   r   rX   ra   c                 K  s&   d }}|r|dt | 7 }||fS )Nxvz -name r   rc   r   r   r   rY   .  s    zXVViewer.get_command_exr   r2   c                 K  sH   t j|stdg}|d}|r0|d|g7 }|| t| dS )r4   rn   r   z-namer   rd   rf   r   r   r   r0   8  s    


zXVViewer.show_file)Nr_   r   r   r   r   rm   (  s    
rm   )rI   rV   r]   rb   ri   rl   rn   c                   @  s"   e Zd ZdZddddddZdS )	IPythonViewerz!The viewer for IPython frontends.r   r   r   r   c                 K  s   t | dS )Nr   )ipython_displayr1   r   r   r   r#   X  s    zIPythonViewer.show_imageN)r:   r;   r<   r=   r#   r   r   r   r   ro   U  s   ro   )rb   __main__   z.Syntax: python3 ImageShow.py imagefile [title])r   )N)'
__future__r   rZ   r5   rT   rE   rR   shlexr   typingr    r   r   r   r   r   r?   platformrJ   rW   r\   r`   rh   rk   rm   rU   ro   ZIPython.displayrb   rp   ImportErrorr:   lenargvprintexitrO   Zimr   r   r   r   <module>   s^   =
!
 
