U
    jgz                    @   s  d Z ddlZddlmZ ddlmZ ddlmZ ddlZddl	m
Z
mZ ddlmZ ddlm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mZmZ ddlmZ ddlmZ ddl m!Z! ddl"m#Z#m$Z$m%Z%m&Z&m'Z' ddl(m)Z*m+Z,m-Z.m/Z0 ddl1m2Z2m3Z3 ddl4Z4ddl5Z5ddl6Z6ddl7Z7ddlm8Z8 ddl9m:Z:m;Z;m<Z<m=Z=m>Z> e:rbddl?m@Z@ e4AeBZCG dd de8ZDedddddgZEeEeDjFdddeEeDjGdddeEeDjHdddeEeDjId ddeEeDjJd ddeEeDjKdd!deEeDjLdddeEeDjMdddeEeDjNdddd"	ZOd#d$ d%d$ d&d$ d'd$ d(ZPd)d$ d*d$ d+d$ d,d$ d(ZQd-d. ZRd/d0 ZSG d1d2 d2ZTG d3d4 d4ZUG d5d6 d6eVZWG d7d8 d8eVZXG d9d: d:eVZYG d;d< d<eYZZG d=d> d>eYZ[G d?d@ d@eVZ\G dAdB dBeYZ]G dCdD dDeYZ^G dEdF dFe#Z_G dGdH dHe_Z`G dIdJ dJe_ZaG dKdL dLe_ZbG dMdN dNe$ZcdOZdG dPdQ dQe'dRZeG dSdT dTe#ZfG dUdV dVe#ZgG dWdX dXe$ZhG dYdZ dZe$ZiG d[d\ d\e$ZjG d]d^ d^e$ZkG d_d` d`e$ZlG dadb dbe#ZmG dcdd dde#ZnG dedf dfe#ZoG dgdh dhe#ZpG didj djeZqG dkdl dle'dRZrG dmdn dne'dRZsG dodp dpeZtG dqdr dreZuG dsdt dteZvG dudv dve'dRZwdwdxdydzd{d|d}d~ddddddddZxdd Zydd Zzdd Z{dd Z|dd Z}dd Z~eze{e|de}e~ddZdd Zdd Ze  dd ZdS )zfontTools.ttLib.tables.otTables -- A collection of classes representing the various
OpenType subtables.

Most are constructed upon import from data in otData.py, all are populated with
converter objects from otConverters.py.
    N)IntEnum)reduce)radians)defaultdict
namedtuple)TupleVariation)dfs_base_table)quantizeRect)otRound)	TransformIdentityDecomposedTransform)	bytesjoinpadsafeEval)Vector)ControlBoundsPen)TransformPen   )	BaseTableFormatSwitchingBaseTableValueRecordCountReference getFormatSwitchingBaseTableClass)fixedToFloatfloatToFixedfloatToFixedToStrstrToFixedToFloat)LookupDebugInfoLOOKUP_DEBUG_INFO_KEY)IntFlag)TYPE_CHECKINGIteratorListOptionalSet)_TTGlyphSetc                   @   sL   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdS )VarComponentFlagsr                   @         i                 @  l      N)__name__
__module____qualname__RESET_UNSPECIFIED_AXES	HAVE_AXESAXIS_VALUES_HAVE_VARIATIONTRANSFORM_HAS_VARIATIONHAVE_TRANSLATE_XHAVE_TRANSLATE_YHAVE_ROTATIONHAVE_CONDITIONHAVE_SCALE_XHAVE_SCALE_YHAVE_TCENTER_XHAVE_TCENTER_YGID_IS_24BITHAVE_SKEW_XHAVE_SKEW_YRESERVED_MASK rH   rH   C/tmp/pip-unpacked-wheel-6y5_ig6x/fontTools/ttLib/tables/otTables.pyr'   3   s    r'   VarTransformMappingValuesflagfractionalBitsscaledefaultValue      
   iL)	Z
translateXZ
translateYZrotationscaleXscaleYZskewXZskewYZtCenterXZtCenterYc                 C   s   t d| S )N>BstructpackvrH   rH   rI   <lambda>e       rZ   c                 C   s   t d| S )N>HrU   rX   rH   rH   rI   rZ   f   r[   c                 C   s   t d| dd  S )N>Lr   rU   rX   rH   rH   rI   rZ   g   r[   c                 C   s   t d| S )Nr]   rU   rX   rH   rH   rI   rZ   h   r[   )r   r(      r)   c                 C   s   t d| d S )NrT   r   rV   unpackrX   rH   rH   rI   rZ   k   r[   c                 C   s   t d| d S )Nr\   r   r_   rX   rH   rH   rI   rZ   l   r[   c                 C   s   t dd|  d S )Nr]       r   r_   rX   rH   rH   rI   rZ   m   r[   c                 C   s   t d| d S )Nr]   r   r_   rX   rH   rH   rI   rZ   n   r[   c                 C   s  | | }|dk r||d fS |dk rD|d d> | |d  B |d fS |dk r||d d> | |d  d> B | |d  B |d fS |d	k r|d d
> | |d  d> B | |d  d> B | |d  B |d fS |d	 d> | |d  d
> B | |d  d> B | |d  d> B | |d  B |d fS dS )zlRead a variable-length number from data starting at index i.

    Return the number and the next index.
    r.   r      r*   r(      r+   r^         r)   r,      NrH   )dataiZb0rH   rH   rI   _read_uint32varr   s,     0,,
ri   c                 C   s   | dk rt d| S | dk r,t d| dB S | dk rLt d| dB d	d
 S | dk rdt d| dB S t ddt d|  S d
S )z:Write a variable-length number.

    Return the data.
    r.   rT   r4   r\      i    r]   i   r   Ni   l      @ rd   rU   rX   rH   rH   rI   _write_uint32var   s    rk   c                   @   sV   e Zd Zdd ZdddZdd Zdd	 Zd
d Zdd Zdd Z	dd Z
dd ZdS )VarComponentc                 C   s   |    d S N)populateDefaultsselfrH   rH   rI   __init__   s    zVarComponent.__init__Nc                 C   s6   d| _ d | _d | _d | _d| _t| _t| _t | _	d S )Nr   rH   )
flags	glyphNameconditionIndexaxisIndicesIndex
axisValuesNO_VARIATION_INDEXaxisValuesVarIndextransformVarIndexr   	transformrp   Z
propagatorrH   rH   rI   rn      s    zVarComponent.populateDefaultsc                    s  dt  \| _| jtj@ r(dnd}t|  |  }|7 |j| | _tj@ rrt  \| _tj	@ rt  \| _
nd | _
| j
d krd}n|d j| j
 }t|}tj	@ rt| \}tdd |D | _nd| _t| j|ksttj@ r&t  \| _nt| _tj@ rJt  \| _nt| _t | _ fdd	}	t D ] \}
}|	|}t| j|
| qptj@ s| jj| j_tj@ }|rt  \}||d
 M }q d  S )Nr   r^   r(   ZAxisIndicesListc                 s   s   | ]}t |d V  qdS    N)fi2fl.0rY   rH   rH   rI   	<genexpr>   s     z)VarComponent.decompile.<locals>.<genexpr>rH   c                    sJ   | j @ r@ttd d  d | j| j }d7 |S | jS d S )N>hr(   r   )rK   r~   rV   r`   rL   rM   rN   valuesrY   rg   rr   rh   rH   rI   read_transform_component   s    
 z8VarComponent.decompile.<locals>.read_transform_componentr   ) ri   rr   r'   rD   	_unpacker
glyphOrderrs   r?   rt   r9   ru   ZItemlenr   ZdecompileDeltas_tuplerv   AssertionErrorr:   rx   rw   r;   ry   r   rz   VAR_TRANSFORM_MAPPINGitemssetattrrA   rR   rS   rG   )rp   rg   font
localStateZgidSizeglyphIDnumAxesZaxisIndicesrv   r   	attr_namemapping_valuesvaluen_rH   r   rI   	decompile   sN    




zVarComponent.decompilec           	         s  g }| j  || j}|dkr< tjO  |td | n tj M  |td | | jd k	r~ tjO  |t	| j t
| j}|rĈ tjO  |t	| j |tdd | jD  n tj M  | jtkr tjO  |t	| j n tj M  | jtkr* tjO  |t	| j n tj M   fdd}t D ]&\}}t| j|}|||| qJt	 t| S )N  r^   r(   c                 S   s   g | ]}t |d qS r}   )fl2fir   rH   rH   rI   
<listcomp>  s     z(VarComponent.compile.<locals>.<listcomp>c                    s,    |j @ r$tdt| |j |jS dS d S )Nr   r[   )rK   rV   rW   r   rM   rL   )r   r   rr   rH   rI   write_transform_component  s    
 z7VarComponent.compile.<locals>.write_transform_component)rr   
getGlyphIDrs   r'   rD   append_packerrt   r?   rk   r   rv   r9   ru   r   ZcompileDeltaValues_rx   rw   r:   ry   r;   r   r   getattrrz   r   )	rp   r   rg   r   r   r   r   r   r   rH   r   rI   compile   sD    







zVarComponent.compilec                    s    d|    d fdd	}|d| j | jd k	rD|d| j | jd k	rZ|d| j | jd k	sp| jtj@ r| jtj@ rd}nd}|d	d
d | jD | | j	t
kr|d| j	 | jt
kr|d| j t D ]4\}}| j|j@ sqt| j|}||t||j q҈ d    d S )Nrl   rH   c                    s*   |d k	r&  | d|ff|     d S )Nr   )	simpletagnewline)namer   attrswriterrH   rI   write)  s    z!VarComponent.toXML.<locals>.writers   rt   ru   ))resetUnspecifiedAxesr   rv   c                 S   s   g | ]}t t|d qS r   )floatfl2strr   rH   rH   rI   r   <  s     z&VarComponent.toXML.<locals>.<listcomp>rx   ry   )rH   )begintagr   rs   rt   ru   rr   r'   r8   rv   rx   rw   ry   r   r   rK   r   rz   r   rL   endtag)rp   r   ttFontr   r   r   mappingrY   rH   r   rI   toXML%  s6    





zVarComponent.toXMLc                 C   s  dd |D }|    |D ]\}}}|r,t|d }|dkrD|| _q|dkrXt|| _q|dkrlt|| _q|dkrtdd	 t|D | _t|d
dr|  j	t
jO  _	q|dkrt|| _q|dkrt|| _q|tkrt| j|t| |  j	t| jO  _	qdst|qd S )Nc                 S   s   g | ]}t |tr|qS rH   
isinstancer   r   crH   rH   rI   r   O  s     
 z(VarComponent.fromXML.<locals>.<listcomp>r   rs   rt   ru   rv   c                 s   s   | ]}t |d V  qdS r|   )str2flr   rH   rH   rI   r   ^  s     z'VarComponent.fromXML.<locals>.<genexpr>r   0rx   ry   F)rn   r   rs   r   rt   ru   r   rv   getrr   r'   r8   rx   ry   r   r   rz   rK   )rp   r   r   contentr   rY   rH   rH   rI   fromXMLN  s6    
zVarComponent.fromXMLc                    s   d fdd}t  D ]*\}}||}tj|tj||  qjtj@ s`jjj_	t
 ks|tt
 fd S )Nr   c                    s6   j | j@ r.t  | j| j }d7 |S dS d S )Nr   r   )rr   rK   r~   rL   rM   r   deltasrh   rp   rH   rI   read_transform_component_deltar  s
    zIVarComponent.applyTransformDeltas.<locals>.read_transform_component_delta)r   r   r   rz   r   rr   r'   rA   rR   rS   r   r   )rp   r   r   r   r   r   rH   r   rI   applyTransformDeltaso  s    	  z!VarComponent.applyTransformDeltasc                 C   s    t | t |krtS | j|jkS rm   )typeNotImplemented__dict__)rp   otherrH   rH   rI   __eq__  s    zVarComponent.__eq__c                 C   s   |  |}|tkr|S | S rm   )r   r   )rp   r   resultrH   rH   rI   __ne__  s    
zVarComponent.__ne__)N)r5   r6   r7   rq   rn   r   r   r   r   r   r   r   rH   rH   rH   rI   rl      s   

F7)!rl   c                   @   s6   e Zd ZdddZdd Zdd Zdd	 Zd
d ZdS )VarCompositeGlyphNc                 C   s   |d k	r|ng | _ d S rm   
components)rp   r   rH   rH   rI   rq     s    zVarCompositeGlyph.__init__c                 C   s0   g | _ |r,t }||||}| j | qd S rm   )r   rl   r   r   )rp   rg   r   r   	componentrH   rH   rI   r     s
    zVarCompositeGlyph.decompilec                 C   s(   g }| j D ]}||| q
t|S rm   )r   r   r   r   )rp   r   rg   r   rH   rH   rI   r     s    
zVarCompositeGlyph.compilec                 C   sR   | d| |  t| jD ]\}}|||d|fg q|d |  d S )Nr   index)r   r   	enumerater   r   r   )rp   	xmlWriterr   r   r   rh   r   rH   rH   rI   r     s    
zVarCompositeGlyph.toXMLc                 C   sP   dd |D }|D ]8\}}}|dks(t t }||||| | j| qd S )Nc                 S   s   g | ]}t |tr|qS rH   r   r   rH   rH   rI   r     s     
 z-VarCompositeGlyph.fromXML.<locals>.<listcomp>rl   )r   rl   r   r   r   )rp   r   r   r   r   r   rH   rH   rI   r     s    zVarCompositeGlyph.fromXML)N)r5   r6   r7   rq   r   r   r   r   rH   rH   rH   rI   r     s
   
r   c                   @   s   e Zd Zdd ZdS )AATStateTablec                 C   s   i | _ g | _g | _d S rm   )ZGlyphClassesZStatesZPerGlyphLookupsro   rH   rH   rI   rq     s    zAATStateTable.__init__Nr5   r6   r7   rq   rH   rH   rH   rI   r     s   r   c                   @   s   e Zd Zdd ZdS )AATStatec                 C   s
   i | _ d S rm   )Transitionsro   rH   rH   rI   rq     s    zAATState.__init__Nr   rH   rH   rH   rI   r     s   r   c                   @   s,   e Zd ZdZedd Zdd Zdd ZdS )	AATActionNc                 C   s   dS )N)NNrH   )r   statesrH   rH   rI   compileActions  s    zAATAction.compileActionsc                    s^    fdd j D }|r4|jdd|d |   jdkrZ|jdd j d |  d S )	Nc                    s   g | ]} j | r|qS rH   )r   r   fro   rH   rI   r     s     
 z.AATAction._writeFlagsToXML.<locals>.<listcomp>Flags,r   r   ReservedFlagsz0x%04X)_FLAGSr   joinr   r   )rp   r   rr   rH   ro   rI   _writeFlagsToXML  s    
zAATAction._writeFlagsToXMLc                 C   s$   || j kstd| d| j|< d S )Nzunsupported flag %sT)r   r   r   rp   rK   rH   rH   rI   _setFlag  s    zAATAction._setFlag)r5   r6   r7   r   staticmethodr   r   r   rH   rH   rH   rI   r     s
   
	r   c                   @   sl   e Zd ZdZdZdddgZdddd	d
ddddddddddddZdd Zdd Zdd Z	dd Z
dd  Zd!S )"RearrangementMorphActionr)   r   	MarkFirstDontAdvanceMarkLastz	no changeu	   Ax ⇒ xAu	   xD ⇒ Dxu   AxD ⇒ DxAu   ABx ⇒ xABu   ABx ⇒ xBAu   xCD ⇒ CDxu   xCD ⇒ DCxu   AxCD ⇒ CDxAu   AxCD ⇒ DCxAu   ABxD ⇒ DxABu   ABxD ⇒ DxBAu   ABxCD ⇒ CDxABu   ABxCD ⇒ CDxBAu   ABxCD ⇒ DCxABu   ABxCD ⇒ DCxBA)r   r   r(   r^   r)   rf         r*   	   rQ      rO      r}      c                 C   s(   d| _ d| _d| _d| _d| _d| _d S Nr   F)NewStateVerbr   r   r   r   ro   rH   rH   rI   rq     s    z!RearrangementMorphAction.__init__c                 C   sz   |d kst || j | jdkr,| jdks6t | j| j| jB }| jrP|dO }| jr^|dO }| jrl|dO }|| d S )Nr   r   rj   r4   r3   )r   writeUShortr   r   r   r   r   r   rp   r   r   actionIndexrr   rH   rH   rI   r     s    z RearrangementMorphAction.compilec                 C   s`   |d kst | | _| }|d@ | _t|d@ | _t|d@ | _t|d@ | _|d@ | _d S )Nr   rj   r4   r3   i  )	r   
readUShortr   r   boolr   r   r   r   rp   readerr   actionReaderrr   rH   rH   rI   r      s    

z"RearrangementMorphAction.decompilec                 C   s   |j |f| |  |jd| jd |  | | |jd| jd | j| j}|d k	rh|| |  |	| |  d S )Nr   r   r   )
r   r   r   r   r   r   _VERBSr   commentr   )rp   r   r   r   r   ZverbCommentrH   rH   rI   r   
  s    


zRearrangementMorphAction.toXMLc           	      C   s   d | _  | _| _d | _ | _| _dd |D }|D ]|\}}}|dkrXt|d | _ q6|dkrpt|d | _q6|dkrt|d | _q6|d	kr6|d d
D ]}| |	  qq6d S )Nr   Fc                 S   s   g | ]}t |tr|qS rH   r   r   trH   rH   rI   r     s     
 z4RearrangementMorphAction.fromXML.<locals>.<listcomp>r   r   r   r   r   r   )
r   r   r   r   r   r   r   splitr   strip	rp   r   r   r   r   eltNameeltAttrs
eltContentrK   rH   rH   rI   r     s    z RearrangementMorphAction.fromXMLN)r5   r6   r7   
staticSizeactionHeaderSizer   r   rq   r   r   r   r   rH   rH   rH   rI   r     s2   

r   c                   @   sD   e Zd ZdZdZddgZdd Zdd Zd	d
 Zdd Z	dd Z
dS )ContextualMorphActionr*   r   SetMarkr   c                 C   s(   d| _ d\| _| _d| _d\| _| _d S )Nr   FFr   r   )r   r  r   r   	MarkIndexCurrentIndexro   rH   rH   rI   rq   -  s    zContextualMorphAction.__init__c                 C   s`   |d kst || j | j}| jr,|dO }| jr:|dO }|| || j || j d S )Nrj   r4   )r   r   r   r   r  r   r  r  r   rH   rH   rI   r   3  s    
zContextualMorphAction.compilec                 C   s\   |d kst | | _| }t|d@ | _t|d@ | _|d@ | _| | _| | _d S )Nrj   r4   i?  )	r   r   r   r   r  r   r   r  r  r   rH   rH   rI   r   ?  s    


zContextualMorphAction.decompilec                 C   s~   |j |f| |  |jd| jd |  | | |jd| jd |  |jd| jd |  || |  d S )Nr   r   r  r  )r   r   r   r   r   r  r  r   rp   r   r   r   r   rH   rH   rI   r   I  s    

zContextualMorphAction.toXMLc           	      C   s   d | _ | _d | _| _d\| _| _dd |D }|D ]\}}}|dkrXt|d | _ q6|dkr|d d	D ]}| |	  qnq6|d
krt|d | _q6|dkrt|d | _q6|dkr6t|d | _q6d S )Nr   Fr  c                 S   s   g | ]}t |tr|qS rH   r   r   rH   rH   rI   r   Z  s     
 z1ContextualMorphAction.fromXML.<locals>.<listcomp>r   r   r   r   r   r  r  )
r   r   r  r   r  r  r   r   r   r   r   rH   rH   rI   r   V  s     zContextualMorphAction.fromXMLN)r5   r6   r7   r   r  r   rq   r   r   r   r   rH   rH   rH   rI   r  (  s   
r  c                   @   s   e Zd Zdd ZdS )	LigActionc                 C   s   d| _ d| _d S )NFr   )StoreGlyphIndexDeltaro   rH   rH   rI   rq   j  s    
zLigAction.__init__Nr   rH   rH   rH   rI   r	  i  s   r	  c                   @   s`   e Zd ZdZdZddgZdd Zdd Zd	d
 Ze	dd Z
dd Zdd Zdd Zdd ZdS )LigatureMorphActionr   rO   SetComponentr   c                 C   s"   d| _ d\| _| _d| _g | _d S )Nr   r  )r   r  r   r   Actionsro   rH   rH   rI   rq     s    zLigatureMorphAction.__init__c                 C   s   |d k	st || j | j}| jr,|dO }| jr:|dO }t| jdkrP|dO }|| t| jdkr|  }|||  n
|d d S )Nrj   r4   r   r3   )	r   r   r   r   r  r   r   r  compileLigActions)rp   r   r   r   rr   actionsrH   rH   rI   r     s    
zLigatureMorphAction.compilec                 C   sv   |d k	st | | _| }t|d@ | _t|d@ | _t|d@ }|d@ | _| }|rl| ||| _ng | _d S )Nrj   r4   r3   i  )	r   r   r   r   r  r   r   _decompileLigActionsr  )rp   r   r   r   rr   ZperformActionr   rH   rH   rI   r     s    

zLigatureMorphAction.decompilec                 C   s   dt  i   }}}|D ]&}|j D ]\}}||  q$qt|dd dD ]R}||krNtdt|dD ],}	||	d  }
t||	 d }||
| qj||7 }qNt	|d}||fS )Nr[   c                 S   s   t |  | fS rm   r   xrH   rH   rI   rZ     r[   z4LigatureMorphAction.compileActions.<locals>.<lambda>keyr   r)   )
setr   r   addr  sortedranger   
setdefaultr   )r   r   r   r  r   state_glyphClasstransarh   suffixZsuffixIndexrH   rH   rI   r     s    

z"LigatureMorphAction.compileActionsc                 C   sp   g }t | jD ]X\}}|t| jd k}|jd@ }||r<dndO }||jrNdndO }|td| qt|S )Nr   ?        r      @r]   )	r   r  r   r  r
  r   rV   rW   r   )rp   r   rh   actionlastr   rH   rH   rI   r    s    
z%LigatureMorphAction.compileLigActionsc           	      C   sv   g }d}| |j|d  }|sr| }t|d@ }t }|| t|d@ |_|d@ }|dkrjd| }||_q|S )NFr)   r"  r#  r!  i    i   )getSubReaderposZ	readULongr   r	  r   r
  r  )	rp   r   r   r  r%  r   r   r$  deltarH   rH   rI   r    s    
z(LigatureMorphAction._decompileLigActionsc                 C   s   d | _ | _d | _| _d| _g | _dd |D }|D ]\}}}|dkrXt|d | _ q6|dkr|d dD ]}| |  qnq6|d	krt|d | _q6|d
kr6t	 }	|
ddd}
dd |
D }
d|
k|	_t|d |	_| j|	 q6d S )Nr   Fc                 S   s   g | ]}t |tr|qS rH   r   r   rH   rH   rI   r     s     
 z/LigatureMorphAction.fromXML.<locals>.<listcomp>r   r   r   r   r   Action c                 S   s   g | ]}|  qS rH   r   r   rH   rH   rI   r     s     r
  r  )r   r   r  r   r  r   r   r   r   r	  r   r
  r  r   )rp   r   r   r   r   r   r   r   rK   r$  rr   rH   rH   rI   r     s(    
zLigatureMorphAction.fromXMLc                 C   s   |j |f| |  |jd| jd |  | | | jD ]4}d|jfg}|jr^|d |d| |  q>|	| |  d S )Nr   r   r  )r   r
  r)  )
r   r   r   r   r   r  r  r
  r   r   )rp   r   r   r   r   r$  ZattribsrH   rH   rI   r     s    




zLigatureMorphAction.toXMLN)r5   r6   r7   r   r  r   rq   r   r   r   r   r  r  r   r   rH   rH   rH   rI   r  x  s   

r  c                   @   s`   e Zd ZdZdZddddddgZd	d
 Zdd Zdd Zdd Z	dd Z
dd Zedd ZdS )InsertionMorphActionr*   r)   r  r   CurrentIsKashidaLikeMarkedIsKashidaLikeCurrentInsertBeforeMarkedInsertBeforec                 C   s6   d| _ | jD ]}t| |d qd| _g g  | _| _d S r   )r   r   r   r   CurrentInsertionActionMarkedInsertionActionr   rH   rH   rI   rq     s
    
zInsertionMorphAction.__init__c                 C   s   |d k	st || j | j}| jr,|dO }| jr:|dO }| jrH|dO }| jrV|dO }| jrd|dO }| j	rr|dO }|t
| jd> O }|t
| jO }|| t
| jdkr|t| j }nd	}|| t
| jdkr|t| j }nd	}|| d S )
Nrj   r4   r3   r2   r1   r0   rf   r   r   )r   r   r   r   r  r   r-  r.  r/  r0  r   r1  r2  r   )rp   r   r   r   rr   ZcurrentIndexZmarkedIndexrH   rH   rI   r     s4    

zInsertionMorphAction.compilec                 C   s   |d k	st | | _| }t|d@ | _t|d@ | _t|d@ | _t|d@ | _t|d@ | _t|d@ | _	| j
||| |d@ d? d	| _| j
||| |d
@ d	| _d S )Nrj   r4   r3   r2   r1   r0   i  rf   )r   count   )r   r   r   r   r  r   r-  r.  r/  r0  _decompileInsertionActionr1  r2  r   rH   rH   rI   r   6  s*    
   
   zInsertionMorphAction.decompilec                 C   s8   |dks|dkrg S | |j|d  }|||S )Nr   r   r(   )r&  r'  getGlyphNameManyZreadUShortArray)rp   r   r   r   r3  r   rH   rH   rI   r5  G  s    z.InsertionMorphAction._decompileInsertionActionc                 C   s   |j |f| |  |jd| jd |  | | | jD ]}|jd|d |  q>| jD ]}|jd|d |  q`|| |  d S )Nr   r   r1  glyphr2  )r   r   r   r   r   r1  r2  r   )rp   r   r   r   r   grH   rH   rI   r   M  s    





zInsertionMorphAction.toXMLc           	      C   s   |    dd |D }|D ]\}}}|dkr<t|d | _q|dkrh|d dD ]}| |  qRq|dkr| j|d  q|d	kr| j|d  qd
st	|qd S )Nc                 S   s   g | ]}t |tr|qS rH   r   r   rH   rH   rI   r   ^  s     
 z0InsertionMorphAction.fromXML.<locals>.<listcomp>r   r   r   r   r1  r8  r2  F)
rq   r   r   r   r   r   r1  r   r2  r   r   rH   rH   rI   r   \  s    zInsertionMorphAction.fromXMLc                 C   s  t  i d  }}}|D ]L}|j D ]<\}}|jd k	rF|t|j |jd k	r$|t|j q$qt|dd dD ]}||krqttdt	|D ]D}	t	|d |	 }
t|	t	|D ] }||	|d  }|
||
 qq|D ]}| |}|td|7 }qqt||fS )	Nr[   c                 S   s   t |  | fS rm   r  r  rH   rH   rI   rZ   x  r[   z5InsertionMorphAction.compileActions.<locals>.<lambda>r  r   r(   r   r\   )r  r   r   r1  r  r   r2  r  r  r   r  r   rV   rW   )r   r   r  r   r   r  r  r  r$  startZ
startIndexlimitglyphsr8  r   rH   rH   rI   r   l  s&    


z#InsertionMorphAction.compileActionsN)r5   r6   r7   r   r  r   rq   r   r   r5  r   r   r   r   rH   rH   rH   rI   r,    s"   	r,  c                   @   s   e Zd Zdd ZdddZdS )FeatureParamsc                 C   s>   t |d | jks,td|d | jjf t| || d S )NZ
FeatureTagz-Wrong FeatureParams type for feature '%s': %s)featureParamTypesr   	__class__r   r5   r   r   )rp   r   r   rH   rH   rI   r     s    zFeatureParams.compileNc                 C   s   t j| |||| jjd d S )N)r   )r   r   r?  r5   r  rH   rH   rI   r     s    zFeatureParams.toXML)NN)r5   r6   r7   r   r   rH   rH   rH   rI   r=    s   	r=  c                   @   s   e Zd ZdS )FeatureParamsSizeNr5   r6   r7   rH   rH   rH   rI   r@    s   r@  c                   @   s   e Zd ZdS )FeatureParamsStylisticSetNrA  rH   rH   rH   rI   rB    s   rB  c                   @   s   e Zd ZdS )FeatureParamsCharacterVariantsNrA  rH   rH   rH   rI   rC    s   rC  c                   @   s6   e Zd ZdddZdd Zdd Zdd	 Zd
d ZdS )CoverageNc                 C   s   t | dsg | _d S )Nr<  )hasattrr<  r{   rH   rH   rI   rn     s    
zCoverage.populateDefaultsc                 C   s   | j dkr|d | _n| j dkrg  }| _|d }t|dd d}||krXtd |}~|D ]>}|j}|j}||}	||d }
||	t
|	|
 q^ng | _td	| j  | ` d S )
Nr   
GlyphArrayr(   RangeRecordc                 S   s   | j S rm   )StartCoverageIndexr  rH   rH   rI   rZ     r[   z#Coverage.postRead.<locals>.<lambda>r  .GSUB/GPOS Coverage is not sorted by glyph ids.zUnknown Coverage format: %s)Formatr<  r  logwarningStartEndr   extendr6  r  )rp   rawTabler   r<  rangesZsorted_rangesrr:  endstartIDendIDrH   rH   rI   postRead  s&    




zCoverage.postReadc                 C   sd  t | dd }|d krg  }| _d}d|i}|rZ||}t||k}|d }|gg}|dd  D ].}	|	|d kr|d | ||	g |	}qb|d | |st|d t|k rZd}
tt|D ]R}|| \}}t }||_|	||_
|	||_|
|_|||< |
| | d }
q|r>td |jdd	 d
 |D ]
}|`qBd}d|i}|| _|S )Nr<  r   rF  r   r^   rJ  c                 S   s   | j S rm   )StartIDrI  rH   rH   rI   rZ     r[   z#Coverage.preWrite.<locals>.<lambda>r  r(   rG  )r   r<  getGlyphIDManyr  r   r   r  rG  rY  ZgetGlyphNamerN  rO  rH  rL  rM  sortrK  )rp   r   r<  formatrQ  glyphIDsZbrokenOrderr%  rR  r   r   rh   r:  rT  rS  rH   rH   rI   preWrite  sH    


zCoverage.preWritec                 C   s,   t | dg D ]}|jd|d |  qd S )Nr<  Glyphr   )r   r   r   )rp   r   r   rs   rH   rH   rI   toXML2  s    zCoverage.toXML2c                 C   s0   t | dd }|d krg }|| _||d  d S )Nr<  r   )r   r<  r   )rp   r   r   r   r   r<  rH   rH   rI   r     s
    zCoverage.fromXML)Nr5   r6   r7   rn   rW  r^  r`  r   rH   rH   rH   rI   rD    s
   
,rD  l    c                   @   sJ   e Zd ZdddZdd Zedd Zdd	 Zd
d Zdd Z	dd Z
dS )DeltaSetIndexMapNc                 C   s   t | dsg | _d S Nr   rE  r   r{   rH   rH   rI   rn     s    
z!DeltaSetIndexMap.populateDefaultsc                 C   s"   |d d@ dkst |d | _d S )NEntryFormat  r   r   )r   r   )rp   rQ  r   rH   rH   rI   rW  	  s    zDeltaSetIndexMap.postReadc                 C   s   d}| D ]}||O }q|d@ }d}|r8|d7 }|dL }q"t |d}|dksNt|d| ? |d|> d @ B }|dkrxd}n |dkrd}n|dkrd}nd	}|d d	> |d B S )
Nr   r   r   r+      r(   i r^   r)   )maxr   )r   ZoredidxinnerZ	innerBitsZ	entrySizerH   rH   rI   getEntryFormat  s&    


zDeltaSetIndexMap.getEntryFormatc                 C   s\   t | dd }|d krg  }| _t|dkr.dnd| _| j }t||d< | ||d< |S )Nr   r   r   r   MappingCountre  )r   r   r   rK  r   copyrk  )rp   r   r   rQ  rH   rH   rI   r^  '  s    

zDeltaSetIndexMap.preWritec                 C   st   | d |  tt| dg D ]L\}}d|fg}|tkrZ|d|d? fd|d@ fg |d| |  q"d S )	Nz7Omitted values default to 0xFFFF/0xFFFF (no variations)r   r   outerr+   rj  r   Map)r   r   r   r   rw   rP  r   )rp   r   r   rh   r   r   rH   rH   rI   r`  1  s    



zDeltaSetIndexMap.toXML2c           	      C   sn   t | dd }|d krg  | _}t|d }t|dd}t|dd}|dksVt|||d> |B  d S )Nr   r   rn  Z0xFFFFrj  r   r+   )r   r   r   r   r   insert)	rp   r   r   r   r   r   r   rn  rj  rH   rH   rI   r   B  s    
zDeltaSetIndexMap.fromXMLc                 C   s   |t | jk r| j| S tS rm   )r   r   rw   )rp   rh   rH   rH   rI   __getitem__L  s    zDeltaSetIndexMap.__getitem__)N)r5   r6   r7   rn   rW  r   rk  r^  r`  r   rq  rH   rH   rH   rI   rb    s   



rb  Zuint8c                   @   s>   e Zd ZdddZdd Zdd Zdd	 Zd
d Zdd ZdS )	VarIdxMapNc                 C   s   t | dsi | _d S rc  rd  r{   rH   rH   rI   rn   Q  s    
zVarIdxMap.populateDefaultsc                 C   sX   |d d@ dkst | }|d }||d gt|t|   tt||| _d S )Nre  rf  r   r   rX  )r   getGlyphOrderrP  r   dictzipr   )rp   rQ  r   r   ZmapListrH   rH   rI   rW  U  s
     zVarIdxMap.postReadc                    s   t | dd   d kri   | _| } fdd|D  t dkr\ d  d kr\ d= q8d i}t |d< t |d< |S )	Nr   c                    s   g | ]} | qS rH   rH   r   r9  r   rH   rI   r   b  s     z&VarIdxMap.preWrite.<locals>.<listcomp>r   rX  rl  re  )r   r   rs  r   rb  rk  )rp   r   r   rQ  rH   rw  rI   r^  \  s    
zVarIdxMap.preWritec                 C   sT   t t| di  D ]:\}}d|fd|d? fd|d@ ff}|d| |  qd S )Nr   r8  rn  r+   rj  r   ro  )r  r   r   r   r   )rp   r   r   r8  r   r   rH   rH   rI   r`  k  s    

zVarIdxMap.toXML2c           	      C   s   t | dd }|d kri }|| _z|d }W n   | |d  }Y nX t|d }t|d }|dkslt|d> |B ||< d S )Nr   r8  r   rn  rj  r   r+   )r   r   rs  r   r   )	rp   r   r   r   r   r   r8  rn  rj  rH   rH   rI   r   u  s    zVarIdxMap.fromXMLc                 C   s   | j |tS rm   )r   r   rw   )rp   rs   rH   rH   rI   rq    s    zVarIdxMap.__getitem__)N)	r5   r6   r7   rn   rW  r^  r`  r   rq  rH   rH   rH   rI   rr  P  s   

rr  c                   @   s   e Zd Zdd ZdS )VarRegionListc                 C   s0   | d}|rt|j| _| jdt| jdiS )NZfvarRegionAxisCount)r   r   Zaxesrz  r   r   )rp   r   Z	fvarTablerH   rH   rI   r^    s    
 
zVarRegionList.preWriteNr5   r6   r7   r^  rH   rH   rH   rI   ry    s   ry  c                   @   s6   e Zd ZdddZdd Zdd Zdd	 Zd
d ZdS )SingleSubstNc                 C   s   t | dsi | _d S rc  rd  r{   rH   rH   rI   rn     s    
zSingleSubst.populateDefaultsc                    s   i }t |d }| jdkrf|d  ||} fdd|D }||}t||D ]\}}	|	||< qRnZ| jdkrt||d kstd|d	 }
t||
D ]\}}|||< qnd
std| j || _| `d S )NrD  r   DeltaGlyphIDc                    s   g | ]}|  d  qS )   rH   )r   r   r(  rH   rI   r     s     z(SingleSubst.postRead.<locals>.<listcomp>r(   Z
GlyphCountz invalid SingleSubstFormat2 table
Substituter   unknown format: %s)_getGlyphsFromCoverageTablerK  rZ  r6  ru  r   r   r   )rp   rQ  r   r   inputZ	inputGIDSZoutGIDSZoutNamesinpoutsubstsubrH   r  rI   rW    s(    



zSingleSubst.postReadc                    s  t | dd }|d kri  }| _t| }|j  fdd|D }tt||}d}d }|D ]0\}}	|d krx|	| d }|| d |	kr\ qq\|d krd}nd}i }
|| _t }dd |D }dd |D }||_	||
d	< |dkr|d k	st
||
d
< n||
d< |
S )Nr   c                    s    g | ]\}} | |fqS rH   rH   )r   r  br   rH   rI   r     s     z(SingleSubst.preWrite.<locals>.<listcomp>r(   r~  r   c                 S   s   g | ]}|d  d qS )r   r   rH   r   itemrH   rH   rI   r     s     c                 S   s   g | ]}|d  d  qS r   rH   r  rH   rH   rI   r     s     rD  r}  r  )r   r   listr   r   r  ru  rK  rD  r<  r   )rp   r   r   r   ZgidItemsZsortableItemsr\  r(  ZinIDZoutIDrQ  covr  r  rH   r  rI   r^    s:    

zSingleSubst.preWritec                 C   s@   t | j }|D ](\}}|dd|fd|fg |  qd S )NSubstitutioninr  )r  r   r   r   r   )rp   r   r   r   inGlyphZoutGlyphrH   rH   rI   r`    s    zSingleSubst.toXML2c                 C   s2   t | dd }|d kri }|| _|d ||d < d S )Nr   r  r  )r   r   )rp   r   r   r   r   r   rH   rH   rI   r     s
    zSingleSubst.fromXML)Nra  rH   rH   rH   rI   r|    s
   
'r|  c                   @   sB   e Zd ZdddZdd Zdd Zdd	 Zd
d Zedd Z	dS )MultipleSubstNc                 C   s   t | dsi | _d S rc  rd  r{   rH   rH   rI   rn     s    
zMultipleSubst.populateDefaultsc                 C   s\   i }| j dkr<t|d }dd |d D }tt||}ndsNtd| j  || _| ` d S )Nr   rD  c                 S   s   g | ]
}|j qS rH   )r  )r   srH   rH   rI   r     s     z*MultipleSubst.postRead.<locals>.<listcomp>Sequencer   r  )rK  r  rt  ru  r   r   )rp   rQ  r   r   r<  r  rH   rH   rI   rW    s    
zMultipleSubst.postReadc                    sb   t dd   d kri   _t }tt  |jd|_d_| fdd|jD d}|S )Nr   r  r   c                    s   g | ]}  | qS rH   )makeSequence_)r   r8  r   rp   rH   rI   r     s     z*MultipleSubst.preWrite.<locals>.<listcomp>)rD  r  )	r   r   rD  r  r  keysr   r<  rK  )rp   r   r  rQ  rH   r  rI   r^    s    
zMultipleSubst.preWritec                 C   sJ   t | j }|D ]2\}}d|}|dd|fd|fg |  qd S )Nr   r  r  r  )r  r   r   r   r   r   )rp   r   r   r   r  	outGlyphsr  rH   rH   rI   r`    s
    
zMultipleSubst.toXML2c                 C   s  t | dd }|d kri }|| _|dkrhg | _|D ]2}t|ts@q0|\}}}	|dkr0| j|d  q0d S |dkrt|dt|}
| j|
 }g  }||< |D ]0}t|tsq|\}}}	|dkr||d  qd S |d r|d 	d	ng }d
d |D ||d < d S )Nr   rD  r_  r   r  r   r  r  r   c                 S   s   g | ]}|  qS rH   r+  rv  rH   rH   rI   r   +  s     z)MultipleSubst.fromXML.<locals>.<listcomp>r  )
r   r   Zold_coverage_r   r   r   intr   r   r   )rp   r   r   r   r   r   elementZelement_nameZelement_attrsr   r   r8  Zglyph_mappingr  rH   rH   rI   r     s4    




zMultipleSubst.fromXMLc                 C   s   t  }| |_|S rm   )r  r  )r9  seqrH   rH   rI   r  -  s    zMultipleSubst.makeSequence_)N)
r5   r6   r7   rn   rW  r^  r`  r   r   r  rH   rH   rH   rI   r    s   
 r  c                   @   s>   e Zd ZdddZdd Zdd Zdd	 Zd
d Zdd ZdS )ClassDefNc                 C   s   t | dsi | _d S )N	classDefs)rE  r  r{   rH   rH   rI   rn   5  s    
zClassDef.populateDefaultsc                 C   s   i }| j dkrf|d }|d }||}|t| }|t||}t||D ]\}	}
|
rN|
||	< qNn~| j dkr|d }|D ]V}|j}
|
sq||j}|j}||}||d }|t||}|D ]}	|
||	< qq|nt	
d| j  || _| ` d S )Nr   
StartGlyphClassValueArrayr(   ClassRangeRecordzUnknown ClassDef format: %s)rK  r   r   r6  r  ru  ClassrN  rO  rL  rM  r  )rp   rQ  r   r  r:  Z	classListrU  rV  Z
glyphNamesrs   clsrecordsrecrT  rH   rH   rI   rW  9  s4    



zClassDef.postReadc                 C   s   t | dd }|d kri | _d S |j}g }| D ]"\}}|s>q0|||||f q0|r|  |d \}}}	|	||gg}
|dd  D ]L\}}}||d ks||	kr|
d ||g |
|||g |}|}|}	q|
d ||g |
S d S )Nr  r   r   rX  )r   r  r   r   r   r[  rP  )rp   r   r  r   r   rs   r  r%  ZlastNameZlastClsrR  r   rH   rH   rI   _getClassRangesX  s.    zClassDef._getClassRangesc                 C   s  d}dg i}|  |}|r|d d }|d d }|| d }t|d |d k rtt|D ]6}|| \}	}
}}}t }||_||_|	|_|||< q`d}d|i}n\|d d }dg| }|D ]2\}	}
}}}t|
| || d D ]}|	||< qqd}||d}|| _|S )Nr(   r  r   r   rX  r^   )r  r  )r  r   r  r  rN  rO  r  rK  )rp   r   r\  rQ  rR  Z
startGlyphZendGlyphZ
glyphCountrh   r  r:  	startNamerT  endNamer  ZstartGlyphNameclassesr9  rH   rH   rI   r^  q  s4    




zClassDef.preWritec                 C   s@   t | j }|D ](\}}|dd|fd|fg |  qd S )Nr  r8  class)r  r  r   r   r   )rp   r   r   r   rs   r  rH   rH   rI   r`    s    zClassDef.toXML2c                 C   s6   t | dd }|d kri }|| _t|d ||d < d S )Nr  r  r8  )r   r  r  )rp   r   r   r   r   r  rH   rH   rI   r     s
    zClassDef.fromXML)N)	r5   r6   r7   rn   rW  r  r^  r`  r   rH   rH   rH   rI   r  4  s   
r  c                   @   s6   e Zd ZdddZdd Zdd Zdd	 Zd
d ZdS )AlternateSubstNc                 C   s   t | dsi | _d S )N
alternates)rE  r  r{   rH   rH   rI   rn     s    
zAlternateSubst.populateDefaultsc                 C   sv   i }| j dkrVt|d }|d }t|t|ks6tt||D ]\}}|j||< q@ndshtd| j  || _| ` d S )Nr   rD  AlternateSetr   r  )rK  r  r   r   ru  	Alternater  )rp   rQ  r   r  r  altsr  altrH   rH   rI   rW    s    
zAlternateSubst.postReadc           
      C   s   d| _ t| dd }|d kr$i  }| _t| }tt|D ]$}|| \}}||||f||< q<|  t	 }dd |D |_
g }dd |D }|D ]}t }	||	_||	 qd| _||dS )Nr   r  c                 S   s   g | ]}|d  qS r  rH   r  rH   rH   rI   r     s     z+AlternateSubst.preWrite.<locals>.<listcomp>c                 S   s   g | ]}|d  qS rX  rH   r  rH   rH   rI   r     s     )rD  r  )rK  r   r  r  r   r  r   r   r[  rD  r<  r  r  r   sortCoverageLast)
rp   r   r  r   rh   rs   r  r  setListr  rH   rH   rI   r^    s&    
zAlternateSubst.preWritec                 C   sh   t | j }|D ]P\}}|jd|d |  |D ]}|jd|d |  q4|d |  qd S )Nr  r7  r  )r  r  r   r   r   r   r   )rp   r   r   r   rs   r  r  rH   rH   rI   r`    s    

zAlternateSubst.toXML2c           	      C   sd   t | dd }|d kri }|| _|d }g }|||< |D ](}t|tsFq6|\}}}||d  q6d S )Nr  r8  )r   r  r   r   r   )	rp   r   r   r   r   r  rs   r  r  rH   rH   rI   r     s    

zAlternateSubst.fromXML)Nra  rH   rH   rH   rI   r    s
   
r  c                   @   sB   e Zd ZdddZdd Zedd Zdd	 Zd
d Zdd Z	dS )LigatureSubstNc                 C   s   t | dsi | _d S )N	ligatures)rE  r  r{   rH   rH   rI   rn     s    
zLigatureSubst.populateDefaultsc                 C   s|   i }| j dkr\t|d }|d }t|t|ks6ttt|D ]}|| j||| < qBndsntd| j  || _| ` d S )Nr   rD  LigatureSetr   r  )rK  r  r   r   r  Ligaturer  )rp   rQ  r   r  r  ligSetsrh   rH   rH   rI   rW    s    
zLigatureSubst.postReadc                 C   s
   t |  S rm   r  r   rH   rH   rI   _getLigatureSortKey  s    z!LigatureSubst._getLigatureSortKeyc                 C   sT  d| _ t| dd }|d kr$i  }| _|rttt|trt }t|	 | j
dD ]B}t }|dd  |_t||_|| |_||d g | qR|}t| }tt|D ]$}|| \}}	||||	f||< q|  t }
dd |D |
_g }dd |D }|D ]6}	t }g  }|_|	D ]}|| q$|| qd| _|
|dS )	Nr   r  r  r   c                 S   s   g | ]}|d  qS r  rH   r  rH   rH   rI   r   -  s     z*LigatureSubst.preWrite.<locals>.<listcomp>c                 S   s   g | ]}|d  qS r  rH   r  rH   rH   rI   r   0  s     )rD  r  )rK  r   r  r   nextiterr   rt  r  r  r  r  	Componentr   	CompCountLigGlyphr  r   r  r   r  r   r[  rD  r<  r  r  )rp   r   r  ZnewLigaturescompsZligaturer   rh   rs   r  r  r  r  ZligSetligsligrH   rH   rI   r^    s<    



zLigatureSubst.preWritec                 C   st   t | j }|D ]\\}}|jd|d |  |D ]&}|jd|jd|jd |  q4|	d |  qd S )Nr  r7  r  r   )r8  r   )
r  r  r   r   r   r   r  r   r  r   )rp   r   r   r   rs   r  r  rH   rH   rI   r`  =  s      


zLigatureSubst.toXML2c                 C   s   t | dd }|d kri }|| _|d }g }|||< |D ]\}t|tsFq6|\}}}t }	|d |	_|d }
|
rv|
dng |	_t|	j|	_	|
|	 q6d S )Nr  r8  r   r   )r   r  r   r   r  r  r   r  r   r  r   )rp   r   r   r   r   r  rs   r  r  r  r   rH   rH   rI   r   J  s"    


zLigatureSubst.fromXML)N)
r5   r6   r7   rn   rW  r   r  r^  r`  r   rH   rH   rH   rI   r    s   

*r  c                   @   s.   e Zd Zdd Zdd Zddeddd	Zd
S )COLRc                 C   sb   |j dd}|  D ]6}|jdkr0||j q|j||i d||j<  qTqtdt| ||S )Nr   )offsetLayerRecordCount)Z	tableDictz$LayerRecordCount converter not found)	r&  getConvertersr   Zadvancer   readr   r   r   )rp   r   r   Z	subReaderconvrH   rH   rI   r   _  s    
zCOLR.decompilec                 C   s   d | _ | jdt| jdiS )Nr  )r  r   r   rp   r   rH   rH   rI   r^  p  s
     
zCOLR.preWriter   r&   )glyphSetquantizationc           	      C   s   | j dkrd S i }| jjD ]l}z|j| ||}W n@ tk
rr } z"ddlm} |d|j|W 5 d }~X Y nX |d k	r|||j< qt	| do| j
d k	}|s|rd | _
n|st
 | _
d| j
_|| j
_d S )Nr   )
TTLibErrorz#Failed to compute COLR ClipBox for ClipListr   )VersionBaseGlyphListBaseGlyphPaintRecordPaintcomputeClipBox	ExceptionZfontTools.ttLibr  	BaseGlyphrE  r  rK  clips)	rp   r  r  r  r  clipBoxer  ZhasClipListrH   rH   rI   computeClipBoxesz  s.    

zCOLR.computeClipBoxesN)r   )r5   r6   r7   r   r^  r  r  rH   rH   rH   rI   r  ^  s   
r  c                       s(   e Zd Zedd Z fddZ  ZS )
LookupListc                 C   sP   | j D ]@}|jD ]4}t|jdr,  dS t|jdr  dS qqtd S )NZSubstGSUBZPosGPOS)LookupSubTabler   r5   endswith
ValueError)rp   lstrH   rH   rI   table  s    

zLookupList.tablec              
      sL  |rd|kst |d jkr(t ||S |d jt  | j }|  D ] }|jrt| |jg }t	|D ]\}}t
||krt|t
|  }|j}	|jr|j d|	 }	|jr|j\}
}}|	 d| d|
 d| d}	||	 |  |||||jd|fg qhqD|jr$t|jd t| s$qDt| |jd }|||||jg  qDd S )NZDebgz: z in z (/)r   )r   rg   superr`  r  r  repeatr   r   r   strr   locationfeaturer   r   ZxmlWriteZauxevalvars)rp   r   r   Z	debugDatar  r   lookupIndexr  infotagscriptlanguager  r?  rH   rI   r`    sJ    
      zLookupList.toXML2)r5   r6   r7   propertyr  r`  __classcell__rH   rH   r  rI   r    s   
	r  c                   @   s   e Zd Zdd ZdS )BaseGlyphRecordArrayc                    s"   t | j fddd| _| j S )Nc                    s     | jS rm   r   r  r  r   rH   rI   rZ     r[   z/BaseGlyphRecordArray.preWrite.<locals>.<lambda>r  )r  ZBaseGlyphRecordr   rm  r  rH   r  rI   r^    s
     
zBaseGlyphRecordArray.preWriteNr{  rH   rH   rH   rI   r    s   r  c                   @   s   e Zd Zdd ZdS )r  c                    s"   t | j fddd| _| j S )Nc                    s     | jS rm   r  r  r  rH   rI   rZ     r[   z(BaseGlyphList.preWrite.<locals>.<lambda>r  )r  r  r   rm  r  rH   r  rI   r^    s
     
zBaseGlyphList.preWriteNr{  rH   rH   rH   rI   r    s   r  c                   @   s$   e Zd ZdZdZdd Zdd ZdS )ClipBoxFormatr   r(   c                 C   s
   | | j kS rm   Variablero   rH   rH   rI   is_variable  s    zClipBoxFormat.is_variablec                 C   s   | j S rm   r  ro   rH   rH   rI   as_variable  s    zClipBoxFormat.as_variableN)r5   r6   r7   Staticr  r  r  rH   rH   rH   rI   r    s   r  c                   @   s    e Zd ZeZdd Zdd ZdS )ClipBoxc                    s   t  fdd  D S )Nc                 3   s   | ]}t  |jV  qd S rm   )r   r   )r   r  ro   rH   rI   r     s     z#ClipBox.as_tuple.<locals>.<genexpr>)r   r  ro   rH   ro   rI   as_tuple  s    zClipBox.as_tuplec                 C   s   | j j |   S rm   )r?  r5   r  ro   rH   rH   rI   __repr__  s    zClipBox.__repr__N)r5   r6   r7   r  
formatEnumr  r  rH   rH   rH   rI   r    s   r  c                   @   s@   e Zd ZdddZdd Zdd Zdd	 Zdd
dZdd ZdS )r  Nc                 C   s   t | dsi | _d S )Nr  )rE  r  r{   rH   rH   rI   rn     s    
zClipList.populateDefaultsc              
   C   s   i }|  }t|d D ]\}}|j|jkrBtd||j|j qg }g }t|j|jd D ]X}	z||	 }
W n" tk
r   ||	 Y q\Y nX |
|krt		|j
||
< q\||	 q\|rtd|t|t| |rtd|t|t| q|| _d S )N
ClipRecordzCinvalid ClipRecord[%i].StartGlyphID (%i) > EndGlyphID (%i); skippedr   zqClipRecord[%i] overlaps previous records; ignoring redefined clip boxes for the following glyph ID range: [%i-%i]z:ClipRecord[%i] range references missing glyph IDs: [%i-%i])rs  r   StartGlyphID
EndGlyphIDrL  rM  r  
IndexErrorr   rm  r  minrh  r  )rp   rQ  r   r  r   rh   r  ZredefinedGlyphsZmissingGlyphsr   r8  rH   rH   rI   rW    sJ    

zClipList.postReadc                    s\   t t}i  | j D ].\}}| }|| | | kr| |< q fdd| D S )Nc                    s   i | ]\}}t | | qS rH   )	frozenset)r   r  r<  ZuniqueClipsrH   rI   
<dictcomp>"  s     z#ClipList.groups.<locals>.<dictcomp>)r   r  r  r   r  r   )rp   ZglyphsByCliprs   r  r  rH   r  rI   groups  s    

zClipList.groupsc                    s$  t | dsi | _i }|  |   D ]\}}t fdd|D }|sLq(|d }|gg}|dd  D ].}||d kr|d | ||g |}qh|d | |D ]$\}	}
|	|
f|kst|||	|
f< qq(g }t| D ].\\}	}
}t }|	|_	|
|_
||_|| qt||d}|S )Nr  c                 3   s   | ]}| kr | V  qd S rm   rH   )r   rs   ZglyphMaprH   rI   r   ,  s     z$ClipList.preWrite.<locals>.<genexpr>r   r   rX  )Z	ClipCountr   )rE  r  ZgetReverseGlyphMapr  r   r  r   r   r   r  r  r  r   )rp   r   ZclipBoxRangesr<  r  r]  r%  rR  r   r:  rT  ZclipRecordsrecordrQ  rH   r	  rI   r^  &  s@    
zClipList.preWritec           	      C   s  |r|n| j j}|d krg }t| dr6|d| jf ||| |  t|  	 dd dD ]\}}|d |  t|D ]}|j
d|d |  q|dd|jfg |  ||| |d |  |d |  qb|| |  d S )	NrK  c                 S   s   t | d S )Nr   )r  )r  rH   rH   rI   rZ   T  r[   z ClipList.toXML.<locals>.<lambda>r  Clipr_  r   r  )r?  r5   rE  r   rK  r   r   r  r  r   r   r`  r   )	rp   r   r   r   r   	tableNamer<  r  rs   rH   rH   rI   r   J  s2    

 





zClipList.toXMLc           
      C   s   t | dd }|d kri  | _}|dks*tg }d }|D ]~}t|tsFq6|\}}}|dkrh||d  q6|dkr6t }t|d |_|D ]*}t|tsq|\}}}|	|||| qq6|r|D ]}	|||	< qd S )Nr  r  r_  r   r  rK  )
r   r  r   r   r   r   r  r   rK  r   )
rp   r   r   r   r   r  r<  r  elemrs   rH   rH   rI   r   e  s.    




zClipList.fromXML)N)NN)	r5   r6   r7   rn   rW  r  r^  r   r   rH   rH   rH   rI   r    s   
+$
r  c                   @   s   e Zd ZdZdZdZdS )
ExtendModer   r   r(   N)r5   r6   r7   ZPADREPEATZREFLECTrH   rH   rH   rI   r    s   r  c                   @   s|   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdS )CompositeModer   r   r(   r^   r)   rf   r   r   r*   r   rQ   r   rO   r   r}   r   r+                        re            N)r5   r6   r7   ZCLEARZSRCZDESTZSRC_OVERZ	DEST_OVERZSRC_INZDEST_INZSRC_OUTZDEST_OUTZSRC_ATOPZ	DEST_ATOPZXORPLUSZSCREENZOVERLAYZDARKENZLIGHTENZCOLOR_DODGEZ
COLOR_BURNZ
HARD_LIGHTZ
SOFT_LIGHTZ
DIFFERENCEZ	EXCLUSIONZMULTIPLYZHSL_HUEZHSL_SATURATIONZ	HSL_COLORZHSL_LUMINOSITYrH   rH   rH   rI   r    s8   r  c                   @   s   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZ dZ!d Z"d!d" Z#d#d$ Z$d%S )&PaintFormatr   r(   r^   r)   rf   r   r   r*   r   rQ   r   rO   r   r}   r   r+   r  r  r  r  r  r  r  re   r  r  r           r4  r,   c                 C   s   | j dS )NPaintVar)r   
startswithro   rH   rH   rI   r    s    zPaintFormat.is_variablec                 C   sD   |   r| S ztjd| jdd    W S  tk
r>   Y d S X d S )Nr   rf   )r  r  __members__r   KeyErrorro   rH   rH   rI   r    s    zPaintFormat.as_variableN)%r5   r6   r7   PaintColrLayersZ
PaintSolidZPaintVarSolidZPaintLinearGradientZPaintVarLinearGradientZPaintRadialGradientZPaintVarRadialGradientZPaintSweepGradientZPaintVarSweepGradient
PaintGlyphPaintColrGlyphPaintTransformZPaintVarTransformPaintTranslateZPaintVarTranslate
PaintScaleZPaintVarScalePaintScaleAroundCenterZPaintVarScaleAroundCenterPaintScaleUniformZPaintVarScaleUniformPaintScaleUniformAroundCenterZ PaintVarScaleUniformAroundCenterPaintRotateZPaintVarRotatePaintRotateAroundCenterZPaintVarRotateAroundCenter	PaintSkewZPaintVarSkewPaintSkewAroundCenterZPaintVarSkewAroundCenterZPaintCompositer  r  rH   rH   rH   rI   r    sD   r  c                   @   s   e Zd ZeZdd ZdddZeee	j
 dddZed  d	d
dZedddZed	ddZdedeee dddZdS )r  c                 C   s:   z|  | jjW S  tk
r4   td| j Y nX d S )NzUnknown Paint format: )r  rK  r   r  NotImplementedErrorro   rH   rH   rI   getFormatName  s    zPaint.getFormatNameNc                 C   sp   |r|n| j j}|d krg }|d| jf ||| ||   |  | || |	| |  d S )NrK  )
r?  r5   r   rK  r   r   r2  r   r`  r   )rp   r   r   r   r   r  rH   rH   rI   r     s    
zPaint.toXML)colrreturnc                 c   s   | j tjkrPg }|jd k	r"|jj}dd t|| j| j| j  D E d H  d S | j tjkr|j	j
D ](}|j| jkrdtjd|jdV   d S qdt| jd|  D ]<}|jd k	rt|jt| rt| |j}tj|j|dV  qd S )Nc                 s   s"   | ]\}}t jd ||dV  qdS )ZLayers)r   r   r   N)r   SubTableEntry)r   rh   rY   rH   rH   rI   r     s   z+Paint.iterPaintSubTables.<locals>.<genexpr>r  )r   r   z not in colr.BaseGlyphList)rK  r  r$  Z	LayerListr  r   ZFirstLayerIndexZ	NumLayersr&  r  r  r  r_  r   r5  r#  r  Z
tableClass
issubclassr   r   r   )rp   r3  Zlayersr
  r  r   rH   rH   rI   iterPaintSubTables  s(    
zPaint.iterPaintSubTables)r4  c                 C   s   dd |  |D S )Nc                 S   s   g | ]
}|j qS rH   r   )r   prH   rH   rI   r     s     z%Paint.getChildren.<locals>.<listcomp>r7  )rp   r3  rH   rH   rI   getChildren  s    zPaint.getChildrenr3  c                    s@   t |stdt|  fdddD ]}|d j}|| q$dS )zEDepth-first traversal of graph rooted at self, callback on each node.zcallback must be callablec                    s
   |   S rm   r9  paintr;  rH   rI   rZ     r[   z Paint.traverse.<locals>.<lambda>Ziter_subtables_fnrX  N)callable	TypeErrorr   r   )rp   r3  callbackpathr=  rH   r;  rI   traverse  s     


zPaint.traversec                 C   s  | j tjkr0| j}t|j|j|j|j|j|j	S | j tj
krLt| j| j	S | j tjkrht| j| jS | j tjkrt| j| j| j| j| j | j S | j tjkrt| jS | j tjk rt| j| j| j| j | j S | j tjkrtt| jS | j tjkrFt| j| jt| j| j | j S | j tjkrntt| j t| jS | j tjkrt| j| jt| j t| j| j | j S t| j   rt!d| j  tS )NzVariable Paints not supported: )"rK  r  r'  r   ZxxZyxZxyyyZdxZdyr(  r   	translater)  rM   rR   rS   r*  ZcenterXZcenterYr+  r,  r-  rotater   Zangler.  r/  ZskewZ
xSkewAngleZ
ySkewAngler0  r  r1  )rp   r   rH   rH   rI   getTransform  sd        
  zPaint.getTransformr   r&   )r3  r  r  r4  c           	         s   t |}t|  fdddD ]H}|d j}|jtjkrttjdd |D t	}||j
 t|| q|jd krtd S t }ttj|_t|j|\|_|_|_|_|S )Nc                    s
   |   S rm   r9  r<  r;  rH   rI   rZ   C  r[   z&Paint.computeClipBox.<locals>.<lambda>r>  rX  c                 s   s   | ]}|j  V  qd S rm   )r   rG  )r   r  rH   rH   rI   r   I  s     z'Paint.computeClipBox.<locals>.<genexpr>)r   r   r   rK  r  r%  r   r   rz   r   r_  Zdrawr   Zboundsr  r  r  r  r	   ZxMinZyMinZxMaxZyMax)	rp   r3  r  r  ZpenrB  r=  ZtransformationcbrH   r;  rI   r  >  s&     



zPaint.computeClipBox)NN)r   )r5   r6   r7   r  r  r2  r   r  r"   r   r5  r7  r#   r:  rC  r   rG  r  r$   r  r  rH   rH   rH   rI   r    s   
,   r  )Z
Mark1Array)ZDefaultLangSys)MarkCoverageBaseCoverageZLigatureCoverageZMark1CoverageZMark2CoverageZBacktrackCoverageZInputCoverageZLookAheadCoverageZVertGlyphCoverageZHorizGlyphCoverageZTopAccentCoverageZExtendedShapeCoverageZMathKernCoverage)	ClassDef1	ClassDef2ZBacktrackClassDefZInputClassDefZLookAheadClassDefZGlyphClassDefZMarkAttachClassDef)ZEntryAnchorZ
ExitAnchor
BaseAnchorZLigatureAnchorZMark2AnchorZ
MarkAnchor)Z
XPlaDeviceZ
YPlaDeviceZ
XAdvDeviceZ
YAdvDeviceZXDeviceTableZYDeviceTableZDeviceTable)Z	HorizAxisZVertAxis)ZDefaultMinMax)ZMinCoordZMaxCoord)ZDefJstfLangSys)ZShrinkageEnableGSUBZShrinkageDisableGSUBZExtensionEnableGSUBZExtensionDisableGSUB)ZShrinkageEnableGPOSZShrinkageDisableGPOSZExtensionEnableGPOSZExtensionDisableGPOS)ZShrinkageJstfMaxZExtensionJstfMax)ZTopRightMathKernZTopLeftMathKernZBottomRightMathKernZBottomLeftMathKern)ZVertGlyphConstructionZHorizGlyphConstruction)	MarkArrayZLangSysrD  r  ZAnchorZDeviceZAxisZMinMaxZ	BaseCoordZJstfLangSysZJstfGSUBModListZJstfGPOSModListZJstfMaxZMathKernZMathGlyphConstructionc                 C   s
  d}|j }|jdkr|d }|dk r(|S |jdkr8d}n|jdkrFd}| |j jjj}|| }|jd jj|kr|d }|dk r|S || }q^t	|t
|D ]d}|| }|j|kr||_t	t
|jD ]8}|j| }t|j | }	|	 }
d|
_||
_|
|j|< qqd}|S )a   Either the offset from the LookupList to a lookup overflowed, or
    an offset from a lookup to a subtable overflowed.
    The table layout is:
    GPSO/GUSB
            Script List
            Feature List
            LookUpList
                    Lookup[0] and contents
                            SubTable offset list
                                    SubTable[0] and contents
                                    ...
                                    SubTable[n] and contents
                    ...
                    Lookup[n] and contents
                            SubTable offset list
                                    SubTable[0] and contents
                                    ...
                                    SubTable[n] and contents
    If the offset to a lookup overflowed (SubTableIndex is None)
            we must promote the *previous*	lookup to an Extension type.
    If the offset from a lookup to subtable overflowed, then we must promote it
            to an Extension Lookup type.
    r   Nr   r  r   r  r   )LookupListIndexSubTableIndex	tableTyper  r  r  r  r?  
LookupTyper  r   lookupTypesrK  ExtSubTable)ttfoverflowRecordokr  ZextTypeZlookupslookupsiZsubTableZextSubTableClassextSubTablerH   rH   rI   fixLookupOverFlows  s<    





r[  c           
      C   s   d}t | j }t|}|jdkr.|d }n|jdkrB|jd }i |_t||D ]*}|| }|d }	|d |j|	< | j|	= qR|S )Nr   rD  rG  r(   r  r   )r  r   r   r   itemName	itemIndexr  )
oldSubTablenewSubTablerV  rW  Z
oldMappingoldLennewLenrh   r  r  rH   rH   rI   splitMultipleSubst  s    




rc  c           
      C   s   d}t | dr| j|_t| j }t|}|jdkr@|d }n|jdkrT|jd }i |_t||D ]*}|| }|d }	|d |j|	< | j|	= qd|S )Nr   r  r\  r(   r  r   )	rE  r  r  r  r   r   r]  r^  r  )
r_  r`  rV  rW  ZoldAltsra  rb  rh   r  r  rH   rH   rI   splitAlternateSubst	  s     





rd  c           
      C   s   d}t | j }t|}|jdkr.|d }n|jdkrB|jd }i |_t||D ]*}|| }|d }	|d |j|	< | j|	= qR|S )Nr   r\  r(   r  r   )r  r  r   r   r]  r^  r  )
r_  r`  rV  rW  ZoldLigsra  rb  rh   r  r  rH   rH   rI   splitLigatureSubst$	  s    




re  c           	         s  | }d}| j |_ | j dkrt| jdkrdD ]}t||t| | q,| j |_| jj}| j}t| jd |d  | j_|d  | _|d  |j_|d  |_t| j| _t|j|_d}nL| j dkrt| j	dkrt
| dst| j	d j| _dD ]}t||t| | qd| _| j |_| j |_| jj}| jj}| j	}t| j	d tfd	d
| D   fdd|D | j_fdd| D | j_|d  | _	 fdd|D |j_fdd| D |j_|d  |_	t| j	| _t|j	|_d}|S )NFr   )ValueFormat1ValueFormat2r(   TClass2Countr   )rh  rL  rf  rg  c                 3   s   | ]\}}| kr|V  qd S rm   rH   r   krY   oldCountrH   rI   r   o	  s      zsplitPairPos.<locals>.<genexpr>c                    s   g | ]}| kr|qS rH   rH   rv  	newGlyphsrH   rI   r   q	  s      z splitPairPos.<locals>.<listcomp>c                    s   i | ]\}}| k r||qS rH   rH   ri  rk  rH   rI   r  r	  s      z splitPairPos.<locals>.<dictcomp>c                    s   g | ]}| kr|qS rH   rH   rv  rm  rH   rI   r   w	  s      c                    s"   i | ]\}}| kr||  qS rH   rH   ri  rk  rH   rI   r  x	  s      )rK  r   ZPairSetr   r   rD  r?  r<  ZPairSetCountZClass1RecordrE  ZClass2Recordrh  	DontSharerK  r  r  r   ZClass1Count)	r_  r`  rV  r  rW  r   coverager  r  rH   )rn  rl  rI   splitPairPos>	  sX    



rq  c                 C   s  | j }|dk rdS |d }|| }g g  }}g g  }}	t| jj| jjD ]J\}
}|j|k rp||
 || qH| j|8  _||
 |	| qHg g  }}| jj	D ]J}|
 |
  }}|jd | |_|j|d  |_|| || q| j|_|| j_| j
 |_||j_| j|_|| _ ||_ || j_| j
 |_|	|j_t|| j_t|	|j_|| j_	| j
 |_||j_	t|| j_t||j_dS )Nr(   FT)Z
ClassCountru  rI  r<  rN  Z
MarkRecordr  r   Z	BaseArrayZ
BaseRecordr?  rM  rK  rJ  r   Z	MarkCountZ	BaseCount)r_  r`  rV  Z
classCountZoldClassCountZnewClassCountZoldMarkCoverageZoldMarkRecordsZnewMarkCoverageZnewMarkRecordsrs   Z
markRecordZoldBaseRecordsZnewBaseRecordsr  ZoldBaseRecordZnewBaseRecordrH   rH   rI   splitMarkBasePos	  sT    

 




rr  )r(   r^   r)   )r(   r)   r  r  c                 C   s6  | |j  j}|jj|j }|j}|j| }t|ds>d|_dS t|dr|j	j
j}|}|j	}t|j  |j
j }| }	|j|	_|	}
t|j  | }| }||	_	n |j
j}t|j  | }| }|}
t|dr|jd |_zt|j  | }W n( tk
r   td|j | Y dS X ||||}|r2|j|d |
 |S )zj
    An offset has overflowed within a sub-table. We need to divide this subtable into smaller parts.
    ro  TrT  SubTableCountr   z)Don't know how to split %s lookup type %sF)rQ  r  r  r  rO  rP  r  rE  ro  rT  r?  rR  rS  rK  rt  
splitTabler#  rL  errorrp  )rU  rV  r  rX  ZsubIndexZsubtableZsubTableTyperZ  ZnewExtSubTableClassZnewExtSubTableZtoInsertZnewSubTableClassr`  Z	splitFuncrW  rH   rH   rI   fixSubTableOverFlows	  sN    




rw  c                  C   s|  dd l } ddlm} | d}t }|D ]d\}}t}||}|r`|d}|d d }t|}||kr(t||fi }	|dkrd|	_	|	||< q(|D ]R\}}
|
drt|dkr|dd  |kr|| }||dd   }||_||_qt D ]$\}}|| }|D ]}|||< qqttttttttd	ttttttttt d
	dt!it"t#t$t!t%dda&t&d t&d< t&' D ] }| D ]\}}	||	_(qxqldt)ia*t+ddD ]}t,t*d| < qt+ddD ]}t-t*d| < qddl.m/} |D ]\}}||}|rZ|0 \}}t1|}|| }	t2|	ds.i |	_3i |	_4||dd  |\}}||	j3|< ||	j4|< n|| }	|||\|	_3|	_4qd S )Nr   r   )otDataz([A-Za-z0-9]+)Format(\d+)$rs  TZVarr^   )r   r(   r^   r)   rf   r   r   r*   )	r   r(   r^   r)   rf   r   r   r*   r   r)   )r   r   r(   r)   rf   )r  r  ZmortZmorxr  ZJSTFsizer  zss%02dd   zcv%02d)buildConverters
converters)5rerx  r   globalsr   matchgroupr   r   ro  r!  r   Z	NoVarTypeZVarType_equivalentsr   r|  r  r  r  ZContextSubstZChainContextSubstZExtensionSubstZReverseChainSingleSubstZ	SinglePosZPairPosZ
CursivePosZMarkBasePosZ
MarkLigPosZMarkMarkPosZ
ContextPosZChainContextPosZExtensionPosZNoncontextualMorphZRearrangementMorphZContextualMorphZLigatureMorphZInsertionMorphrS  r   rR  r@  r>  r  rB  rC  ZotConvertersr{  r  r  rE  r|  convertersByName)r}  rx  Z	formatPat	namespacer   r  Z	baseClassmZ
formatTyper  r   ZvarTypeZ	noVarTypebaser  r  Z
lookupEnumenumrh   r{  r\  r|  r  rH   rH   rI   _buildClasses
  s    



& " 

r  c                 C   s   | d krg S | j S d S rm   )r<  )rp  rH   rH   rI   r  
  s    r  )__doc__rm  r  r   	functoolsr   mathr   	itertoolscollectionsr   r   Z%fontTools.ttLib.tables.TupleVariationr   Z!fontTools.ttLib.tables.otTraverser   ZfontTools.misc.arrayToolsr	   ZfontTools.misc.roundToolsr
   ZfontTools.misc.transformr   r   r   ZfontTools.misc.textToolsr   r   r   ZfontTools.misc.vectorr   ZfontTools.pens.boundsPenr   ZfontTools.pens.transformPenr   ZotBaser   r   r   r   r   ZfontTools.misc.fixedToolsr   r~   r   r   r   r   r   r   Z fontTools.feaLib.lookupDebugInfor   r   loggingrV   arraysysr    typingr!   r"   r#   r$   r%   ZfontTools.ttLib.ttGlyphSetr&   	getLoggerr5   rL  r'   rJ   r<   r=   r>   r@   rA   rE   rF   rB   rC   r   r   r   ri   rk   rl   r   objectr   r   r   r   r  r	  r  r,  r=  r@  rB  rC  rD  rw   rb  rr  ry  r|  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r[  rc  rd  re  rq  rr  ru  rw  r  r  rH   rH   rH   rI   <module>   s  

       w"UA  [L7PKjFz9.
 . 		U;G?;o