o
    eG                     @  s   d dl mZ d dlZddlmZmZ ddlmZ dddd	d
dddZ	dd Z
G dd dejZeejee
 eejd dS )    )annotationsN   )Image	ImageFile)i32le)AL)r   r   )RGBALA)RGBzYCC;P)r	   zYCCA;P)r   r   )r	   r	   ))i  )i   )i  i )i   i  i  )i  i i i )i   i  i  )i  i i i c                 C  s   | d d t jkS )N   )olefileMAGIC)prefix r   E/var/www/html/venv/lib/python3.10/site-packages/PIL/FpxImagePlugin.py_accept,   s   r   c                      sT   e Zd ZdZdZdd ZdddZdd	d
Zdd Z fddZ	 fddZ
  ZS )FpxImageFileFPXFlashPixc              
   C  sb   z	t | j| _W n ty } zd}t||d }~ww | jjjdkr*d}t|| d d S )Nz!not an FPX file; invalid OLE filez$56616700-C154-11CE-8553-00AA00A1F95Bznot an FPX file; bad root CLSIDr   )	r   	OleFileIOfpoleOSErrorSyntaxErrorrootclsid_open_index)selfemsgr   r   r   _open8   s   
zFpxImageFile._openr   c           	        s  | j d|ddg}|d |d f| _t| j}d}|dkr,|d }|d7 }|dks |d | _| jd	> }|d
|B   t d}|dkrKd}t|t fddt	|D }t
| \| _| _i | _t	dD ]}d|d	> B }||v rz|| | j|< qg| d| j d S )NData Object Store 06dzImage Contentsi  i  r   @         i     zInvalid number of bandsc                 3  s&    | ]}t  d |d  d@ V  qdS )r   r'   iN)i32).0isr   r   	<genexpr>l   s   $ z+FpxImageFile._open_index.<locals>.<genexpr>   i  )r   getproperties_sizemaxsizemaxidr(   r   tuplerangeMODES_moderawmodejpeg_open_subimage)	r   indexpropr2   r*   idbandsr    colorsr   r+   r   r   I   s4   



zFpxImageFile._open_indexr   c              
   C  sJ  d|dd|ddg}| j |}|d |d}t|dt|d	f}t|d
t|df}t|d}t|d}	|| jkrFd}
t|
|d|  |t|d|	 }d }}|\}}|\}}g | _tdt	||	D ]}t
||| }t
||| }t||d	 }|dkr| jd||||ft||d | jff nb|dkr| jd||||ft||d | j|dd
 ff nC|dkr|d }|d }| j}|r|dkrd\}}nd }n|}| jd||||ft||d ||ff |r| j| | _nd}
t|
|| }||krd|| }}||kr nqn|| _| j| _d | _d S )Nr"   r#   zResolution 04dzSubimage 0000 Header   $   r'   r   r&          zsubimage mismatch   r   rawr   fillr%         r	   )YCbCrKCMYKr9   zunknown/invalid compression)r   
openstreamreadr(   r2   r   seektiler5   lenminappendr8   r9   tile_prefixstreamr   _fp)r   r;   subimagerT   r   r,   r2   tilesizeoffsetlengthr    xyxsizeysizextileytiler*   x1y1compressioninternal_color_conversionjpeg_tablesr8   jpegmoder   r   r   r:   y   s   







	
	




zFpxImageFile._open_subimagec                 C  s0   | j s| j| jd d dg | _ tj| S )Nr%   zSubimage 0000 Data)r   r   rL   rT   r   loadr   r   r   r   rf      s   zFpxImageFile.loadc                   s   | j   t   d S N)r   closesuperrg   	__class__r   r   ri         
zFpxImageFile.closec                   s   | j   t   d S rh   )r   ri   rj   __exit__)r   argsrk   r   r   rn      rm   zFpxImageFile.__exit__)r   )r   r   )__name__
__module____qualname__formatformat_descriptionr!   r   r:   rf   ri   rn   __classcell__r   r   rk   r   r   4   s    

0qr   z.fpx)
__future__r   r    r   r   _binaryr   r(   r6   r   r   register_openrs   register_extensionr   r   r   r   <module>   s"    J