o
    hI                     @   sV  d dl m 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
Z
d dlZd dl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 d dlmZ d d	lmZ d dlmZ  d d
l!m"Z"m#Z# d dl$m%Z% d dl&m'Z'm(Z(m)Z) e	e
j*Z+e#dgdd Z,e#dgdd Z-e#dgdddd Z.e#dgdddd Z/dd Z0e#dgdd Z1d d! Z2ej34d"e5e6d#fe5d d gd$fe7d%d&fe7d'd(fe7d)d*fe7d+d,ffd-d. Z8e#d/gd0d1 Z9e#d2gddd3d4 Z:e#d5gd6d7 Z;d8d9 Z<d:d; Z=ej3j4d<d=d>gd?d@gdAdBdC Z>dDdE Z?dFdG Z@dHdI ZAdJdK ZBdLdM ZCdNdO ZDej34dPg dQej34dRg dSdTdU ZEe#dVgdWdX ZFe#dYgdZd[ ZGe#d\gd]d^ ZHd_d` ZIe#dagdbdc ZJddde ZKe#dfgdgdh ZLej34dig djdkdl ZMdmdn ZNdodp ZOdqdr ZPe%dsdt ZQe%dudv ZRej34dwg dxdydz ZSe#d{gd|d} ZTe#d~gdd ZUdd ZVdd ZWe"dgddd ZXe#dgdddd ZYej34dg ddd ZZdd Z[dd Z\dd Z]dd Z^e"dgddd Z_dd Z`dd Zadd Zbej34dddggdd Zcdd Zde#dgdddd Zedd Zfej3jge+jhdkdddd Ziej3jge+jhdkdddd Zje#dgdddd Zke#dgdddd Zle%dd Zmdd Zndd Zodd Zpe"dgddd Zqe" ddĄ Zre" ddƄ ZsddȄ Ztddʄ Zudd̄ Zvdd΄ Zwe#dgdgdЍdd҄ Zxe#dgdgdЍddՄ ZydS )    )datetimeN)assert_almost_equal)parse)
MouseEvent)RendererAgg)Figure)FontProperties)GridSpec)check_figures_equalimage_comparison)needs_usetex)Text
Annotation
OffsetFromfont_stylesc            	         s^   fdd} ddl m m tjddtdd t \}}| d	d
d
dd}|jddd|d}|	 dks7J |
 d
ks?J | d
ksGJ | d
ksOJ | d
ksWJ | dd
d
dddd}|jddd|d | ddd
dddd}|jddd|d | d	d
d
dddd}|jddd|d | d	d
d
dd dd}|jd!d"d|d |g  |g  d S )#Nc                     s(    di | }|t  d} |dS )N)	directory)fname )mplget_data_path)kwproppathr   findfontr   n/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/matplotlib/tests/test_text.pyfind_matplotlib_font   s   
z.test_font_styles.<locals>.find_matplotlib_fontr   r   ignorez>findfont: Font family \[u?'Foo'\] not found. Falling back to .zmatplotlib.font_manager)modulez
sans-serifnormal   )familystylevariantsizezNormal Font)皙?r%   axes fraction)xycoordsfontpropertieszDejaVu SansFooboldi  )r!   r"   r#   weightstretchr$   z	Bold Font)r%   皙?
sans serifitalici  zBold Italic Font)r%   333333?   z
Light Font)r%   皙?d   zCondensed Font)r%         ?)matplotlib.font_managerr   r   warningsfilterwarningsUserWarningpltsubplotsannotateget_fontnameget_fontstyleget_fontvariant
get_weightget_stretch
set_xticks
set_yticks)	r   figaxnormal_fonta	bold_fontbold_italic_font
light_fontcondensed_fontr   r   r   test_font_styles   s   
rK   	multilinec                  C   s   t   t ddd} | d t jddddddd	 t jddd
dddd	 t jddddddd	 t dd t dd | g  | g  d S )N   zmultiline
text alignmentr-   r4   zTpTpTp
$M$
TpTpTp   centertop)r$   havazTpTpTp
$M^{M^{M^{M}}}$
TpTpTpg?zTpTpTp
$M_{q_{q_{q}}}$
TpTpTpr   )	r9   figuresubplot	set_titletextxlimylimrA   rB   rD   r   r   r   test_multilinet   s$   

rZ   
multiline2mpl20)r"   c               	      s  dt jd< t  \} }|ddg |ddg |jdddd	 g d
}| j   fdd}d}t|D ]\}}|j	d| d d||dd}||| q6|j	ddddd |jdddd	 t|D ]\}}|j	d| d d||dd}||| qc|j	ddddd |jdddd	 t|D ]\}}|j	d| d d||dd}||| q|j	ddddd |jdddd	 t|D ]\}}|j	d| d d||ddd}||| q|j	ddddd d S )N   text.kerning_factorr   gffffff?   r4   C2r0   )color	linewidth)Linez2 Lineg
 2 Lgz$\sum_i x $zhi $\sum_i x $
testztest
 $\sum_i x $z$\sum_i x $
 $\sum_i x $c                    sB   t jdddd| jd}|| | j j | | d S )Nr   r   rM   F)clip_on	transform)	mpatches	Rectangle	transAxes
set_boundsget_window_extenttransformedinvertedbounds	add_patch)rD   ttrrendererr   r   draw_box   s   z!test_multiline2.<locals>.draw_boxleftr-   r%   bottom)horizontalalignmentverticalalignmentg333333?zBottom alignra   g?rP   z	Top aligng?baselinezBaseline alignrN   )rw   rx   rotationzBot align, rot20)
r9   rcParamsr:   set_xlimset_ylimaxhlinecanvasget_renderer	enumeraterV   )rC   rD   stsrt   horalnnstrp   r   rr   r   test_multiline2   sH   

	r   zantialiased.pngc                  C   s   dt jd< tjdd} | jdddddd	d
 | jdddddd	d
 d	t jd< | jddddddd
 | jddddddd
 dt jd< d S )NFtext.antialiased)g      @      ?figsizer0   r   antialiasedrO   T)rw   rx   r         ?z
$\sqrt{x}$ffffff?znot antialiased)r   r|   r9   rS   rV   rC   r   r   r   test_antialiasing   s    

r   c                  C   s\   t jjddd} t| d}t j|}W d    n1 sw   Y  |ddks,J d S )N	Helveticaafm)fontextrbVAVAVAVAVAVA)g     @i  )r   font_managerr   open_afmAFMstring_width_height)fnfhr   r   r   r   test_afm_kerning   s
   r   ztext_contains.pngc                  C   s   t  } t  }td| jdddd }tddd}tddd}t||\}}t jdddd	ddd
}| j	  t
|j|jD ]3\}}t  j||g\|_|_||\}}	|r\dnd}
|j }|j||d|
d |j| q?d S )Nbutton_press_eventr4   rM   r   r      r2   zhello worldrO   )rQ   fontsizer{   yellowredory   )r9   rS   axesr   r   nplinspacemeshgridrV   drawzipflatgcari   rf   xycontainsviewLimfrozenplotset)rC   rD   meventxsystxtr   r   r   _ra   vlr   r   r   test_contains   s$   

r   c                  C   sb   t  \} }|jdddddid}| j  td| jg|jdR  }||d	i fks/J d S )
Nhello)r2   r2   )333333?r   
arrowstylez->)xyxytext
arrowpropsr   )r4   r   F)	r9   r:   r;   r   r   r   	transDatarf   r   )rC   rD   anneventr   r   r   test_annotation_contains   s   

r   zerr, xycoords, matchz<xycoords callable must return a BboxBase or Transform, not az,'xycoords' must be an instance of str, tuplefooz'foo' is not a valid coordinatezfoo barz#'foo bar' is not a valid coordinatez
offset fooz'xycoords cannot be an offset coordinatezaxes fooz'foo' is not a recognized unitc                 C   s\   t  \}}tj| |d |jddd|d |j  W d    d S 1 s'w   Y  d S )Nmatchr   rd   r4   r4   )r   r'   )r9   r:   pytestraisesr;   r   r   )errr'   r   rC   rD   r   r   r   test_annotate_errors  s
   	"r   titlesc                  C   sJ   t   t ddd} | jddd | jddd | g  | g  d S )NrM   z
left titleru   loczright titleright)r9   rS   rT   rU   rA   rB   rY   r   r   r   test_titles  s   
r   text_alignmentc                  C   s   t   t ddd} d}dD ]'}dD ]"}| j|d|d ||tdddd	d
 | j|dd||d |d7 }qq| ddgddg | ddgddg | dd | dd | g  | 	g  d S )NrM   r%   )r   r   )rP   rv   rz   rO   r4   z Tjroundwheat)boxstyle	facecoloralpha)rR   r{   bboxg      ?z$\sum_{i=0}^{j}$)rR   r{   r   g      ?)
r9   rS   rT   rV   dictr   r}   r~   rA   rB   )rD   r   r{   	alignmentr   r   r   test_alignment  s(   


r   zaxes_titles.pngc                  C   sP   t   t ddd} | jddddd | jddddd | jd	d	ddd d S )
NrM   rO   rN   i  )r   r   
fontweightru      i  r   )r9   rS   rT   rU   rY   r   r   r   test_axes_titles7  s
   r   c                  C   s  t  \} }|jddddd}| j  || jj}d}|||f | j  || jj}t|j	|j	D ]\}}|| |ksCJ q7|jddddd}| j  || jj}d}||f|_
| j  || jj}t|j	|j	D ]\}}|| |ksJ qsd S )Ntestrd   figure pixels)r   
textcoords   )r9   r:   r;   r   r   rk   rs   set_positionr   minxyann)rC   rD   r   init_pos	shift_valpost_posrF   br   r   r   test_set_positionA  s0   




r   c                  C   sJ  t  } | ddd}|d | }|j|j }|d | }|j|j }|d | }|j}||| dks@J ||dksIJ ||d|  dksVJ ||d	|  d
kscJ |||d  dkspJ |||d  |d  dksJ |||d  |d  dksJ |||d  |d  dksJ d S )Nr%   ? imiiiimmmmr   gV-?gx&1?rM               
   )r9   rS   rV   set_textrk   x1x0_char_index_at)rC   rV   r   size_isize_moriginr   r   r   test_char_index_ata  s&   


""&r   rV   r   Oemptyz	non-empty)idsc                 C   sx   t  \}}|jdd| ddd}|j  |j}| }|j|d d}tjj	|
 |
 d dd |j|ks:J d S )	Nr4   ru   rv   )rQ   rR   r   dpi皙?rtol)r9   r:   rV   r   r   r   rk   r   testingassert_allclose
get_points)rV   rC   rD   t1r   bbox1bbox2r   r   r   test_non_default_dpi{  s   
r
  c                   C   s0   t dd dksJ t dd dksJ d S )N
horizontalr{           verticalg     V@r   get_rotationr   r   r   r   test_get_rotation_string  s   r  c                  C   s$   dD ]} t | d | ksJ qd S )N)g      .@g333330@gYS@r  r  r   r   r   r   test_get_rotation_float  s   r  c                  C   s(   dD ]} t | d t| ksJ qd S )N)C      )   r  )r   r  floatr  r   r   r   test_get_rotation_int  s   r  c                   C   s:   t t tdd W d    d S 1 sw   Y  d S )N
hozirontalr  r   r   
ValueErrorr   r   r   r   r   test_get_rotation_raises  s   "r  c                   C   s   t d d dksJ d S )Nr  r  r  r   r   r   r   test_get_rotation_none  s   r  c                  C   s4   t g dg dD ]\} }tt| d | q	d S )N)g     v@g     w@g	@)r  g      1@gfffff&f@r  )r   r   r   r  )r   jr   r   r   test_get_rotation_mod360  s   r  rQ   )rO   r   ru   rR   )rO   rP   rv   rz   center_baselinec                 C   sv   t  \}}td|| d}|jdddi|}|jdddi|}|j  t||jj	 ||jj	  d S )Nr   )r{   rR   rQ   )r4   r4   r   rotation_modeanchordefault)
r9   r:   r   rV   r   r   r   rk   rs   r  )rQ   rR   rC   rD   r   t0r  r   r   r   %test_null_rotation_with_rotation_mode  s   
r%  text_bboxclipc                  C   s8   t jdddddd t jddddd	} | d
di d S )Nr   r-   zIs bbox clipped?rq   T)backgroundcolorre   r4   zIs fancy bbox clipped?re   r   zround, pad=0.1)r9   rV   set_bbox)tr   r   r   test_bbox_clipping  s   r+  z!annotation_negative_ax_coords.pngc               	   C   s   t  \} }|jdddgdddgddd |jdddgdddgddd	d
 |jdddgdddgddd |jdddgdddgddd	d
 |jdddgdddgddd |jdddgdddgddd	d
 d S )N+ ptsr   rN   zaxes points    r   r   r   r'   r   - ptsirP   r   r   r   r'   r   rR   + fracr   r  r&   - frac皙+ pixels      zaxes pixels- pixelsir9   r:   r;   rC   rD   r   r   r   "test_annotation_negative_ax_coords  8   






r:  z"annotation_negative_fig_coords.pngc               	   C   s   t  \} }|jdddgdddgddd |jddd	gddd	gddd
d |jdddgdddgddd |jdddgdddgddd
d |jdddgdddgddd |jdddgdddgddd
d d S )Nr,  r   x   zfigure pointsr-  r.  r/     rP   r0  r1  r  g?zfigure fractionr2  r3  r4   r4  2   r   r7  ir3   r8  r9  r   r   r   #test_annotation_negative_fig_coords  r;  r@  c                  C   s   t dd\} \}}t   |jrJ |jrJ | jrJ |ddd}|js)J |js.J | js3J |jdddgd}|jsAJ |jsFJ | jsKJ t   |jrTJ |jrYJ | jr^J d S )NrM   r_   r4   aardvarkr   )r9   r:   draw_allstalerV   r;   )rC   ax1ax2txt1ann1r   r   r   test_text_stale  s"   










rI  zagg_text_clip.pngc                  C   sZ   t jd td\} \}}t jddD ]\}}|j||ddd |||d qd S )NrM   r_   r   r   Tr(  )r   randomseedr9   r:   randrV   )rC   rE  rF  r   r   r   r   r   test_agg_text_clip  s   rM  c                  C   s>   dt jd< t jjdd} |  }dt jd< ||  ksJ d S )Nr   z	font.sizelarger$   r3   )r   r|   r   r   get_size_in_points)fpsz1r   r   r   test_text_size_binding  s
   

rS  zfont_scaling.pdfc                  C   s   dt jd< tjdd\} }|jt  |jt  |dd t	t
ddd	D ]\}}|jd
|d | d|d q+d S )N*   pdf.fonttype)g@g(@r   r=  iX  r   +   r_   r%   r   z pt font size)r   )r   r|   r9   r:   xaxisset_major_locatorNullLocatoryaxisr~   r   rangerV   )rC   rD   r   fsr   r   r   test_font_scaling  s   
r]  zspacing1, spacing2))r2   r_   )r_   r2   )r_   r_   c           	      C   s   d}t  }|j }|jdd|| d}|jdd||d}|j  |j|d}|j|d}|j|jks6J | |krD|j|jksBJ d S |j|jksLJ d S )Nzline1
line2r   r4   linespacingrr   )	r9   rS   r   r   rV   r   rk   widthheight)	spacing1spacing2text_stringrC   rs   text1text2box1box2r   r   r   test_two_2line_texts)  s   

ri  c                   C   sB   t t tjddddd W d    d S 1 sw   Y  d S )Nr   r4   r   abcr^  )r   r   	TypeErrorr9   rV   r   r   r   r   test_validate_linespacing>     "rl  c                  C   s:   t  \} }|dtjd |tjdd | j  d S )Nr   naninf)r9   r:   rV   r   rn  ro  r   r   r9  r   r   r   test_nonfinite_posC  s   rp  c                  C   sj   dt jd< t  } | ddd}| jt dd | j}| jt dd t	j
j| j|dd	 d S )
NrM   ztext.hinting_factorr4   z	some textsvgformatpngr%   r  )r9   r|   rS   rV   savefigioBytesIOrk   	intervalxr   r  r  )rC   r*  expectedr   r   r   test_hinting_factor_backendsJ  s   


rz  c                  C   sx   t  } dt jd< | d}dt jd< | d}| j  |df|dffD ]\}}|jjD ]}|j	 |ks8J q-q%d S )NFtext.usetexy   Tz   )
r9   rS   r|   add_subplotr   r   rW  
majorTickslabel1
get_usetex)rC   rE  rF  rD   usetexr*  r   r   r   test_usetex_is_copiedX  s   




r  c                  C   s(   t  } | jddddd | j  d S )Nr4   z	$\frac12$Tr  )r9   rS   rV   r   r   r   r   r   r   test_single_artist_usetexg  s   r  fmt)rt  pdfrq  c                 C   s:   dt jd< t  }|jddddd |jt | d d S )NTr{  r4   2_2_2Fr  rr  )r9   r|   rS   rV   ru  rv  rw  )r  rC   r   r   r   test_single_artist_usenotexq  s   
r  ztext_as_path_opacity.svgc                   C   sP   t   t    t jddddd t jddddd t jddd	dd
d d S )Nr   cr   r   r   r4   ry   r4   rF   r   r   r   r   r   r   rM   r   ra   )r9   rS   r   set_axis_offrV   r   r   r   r   test_text_as_path_opacity}  s
   r  ztext_as_text_opacity.svgc                   C   sZ   dt jd< t  t   tjddddd tjddddd	 tjdd
dddd d S )Nnonezsvg.fonttyper   z50% using `color`r  ry   r4   z50% using `alpha`r  r   z"50% using `alpha` and 100% `color`r  r  )r   r|   r9   rS   r   r  rV   r   r   r   r   test_text_as_text_opacity  s   

r  c                   C   s,   t ddgddg tt dgdd d S )NABrM   r_   r4   Boo)r9   r   reprrV   r   r   r   r   test_text_repr  s   r  c                  C   sf   t dd\} }|jddd}|| j }|   || j }tj|	 |	 ddr1J d S )NrM   
annotationr   rB  gư>r  )
r9   r:   r;   rk   r   r   tight_layoutr   allcloser  )rC   rD   anextent1extent2r   r   r   test_annotation_update  s   r  rt  )
extensionsc                 C   sl   |   }|t dd |jdt dfdddd |  }|t dd |jdt dfdd	 d S )
NrM   r   r   r4   )datar&   rd   offset points)r'   r   r   )r'   )r~  r   r   nowr;   fig_testfig_refrD   r   r   r   test_annotation_units  s   r  zlarge_subscript_title.pngc                  C   s   dt jd< d t jd< t jddddd\} }|d	 }|d
 |jddd |g  |d }|jd
dd |jddd |g  d S )Nr]   r^   zaxes.titleyrM   r_   )	   g      @T)r   constrained_layoutr   z$\sum_{i} x_i$zNew wayru   r   g)\(?)r   zOld Way)r9   r|   r:   rU   set_xticklabels)rC   axsrD   r   r   r   test_large_subscript_title  s   



r  zx, rotation, halign))r   r   ru   )r4   _   ru   )r0   r   r   )r0      ru   c                 C   s`   t jdd}tdd|d}||d }d}|j| d|d||d	}|j  | d
ks.J d S )N)   r  r   r   )nrowsncolsrS   rM   rM   z?This is a very long text that should be wrapped multiple times.r   T)wrapr{   rQ   z?This is a very long
text that should be
wrapped multiple
times.)r9   rS   r	   add_subfigurerV   r   r   _get_wrapped_text)r   r{   halignrC   gssubfigsrV   r   r   r   	test_wrap  s   
r  c                  C   sB   t jdd} d}| jdd|ddd}| j  | d	ksJ d S )
Nr]   r   r   z;This is a very $\overline{\mathrm{long}}$ line of Mathtext.r   r4   (   T)r$   r  z;This is a very $\overline{\mathrm{long}}$
line of Mathtext.r9   rS   rV   r   r   r  )rC   r  rV   r   r   r   test_mathwrap  s
   
r  c                  C   sh   t jdd} | jddd | j }t jdd}|d |j }|j|jks*J |j|jks2J d S )N)r   r   r   z.suptitle that is clearly too long in this caseTr  z.suptitle that is clearly
too long in this case)r9   rS   suptitle	_suptitlerk   y0y1)fig1window_extent_testfig2window_extent_refr   r   r   test_get_window_extent_wrapped  s   


r  c                  C   s<   t jdd} | jddddd}| j  | dksJ d S )Nr  r   g      #@r   AlonglineoftexttowrapTr  r  rC   rV   r   r   r   test_long_word_wrap     
r  c                  C   s<   t jdd} | jddddd}| j  | dksJ d S )Nr  r   r   znon wrapped textTr  r  r  r   r   r   test_wrap_no_wrap  r  r  c                 C   s`   |   }|ddg |ddg |jjd jd |  }|ddg |ddg d S )Nr   rM   u   €rF   wr   )r~  rB   set_yticklabelsrZ  r  r  	set_colorr  r   r   r   test_buffer_size  s   r  c                  C   sL   t   t jdddd} t jdddd}|  dksJ | dks$J dS )z>Test that kwargs take precedence over fontproperties defaults.valuezTimes New Romang      D@)r(   r$   counts)r$   r(   N)r9   rS   xlabelylabelget_size)re  rf  r   r   r   $test_fontproperties_kwarg_precedence
  s
   r  c                  C   s@   t  } t d}| jddd|dd}| }t|d d S )Nr   r   r   T)rf   transform_rotates_text)r9   r   mtransformsAffine2D
rotate_degrV   r  r   )rD   rf   rV   resultr   r   r   test_transform_rotates_text  s   r  c                  C   sV   t tddd d} t | }t }||  | d |d ksJ | d |d ks)J d S )Nr*   )r+   )r(   r   r(   r   )r   r   r   update)inpcacher*  r   r   r   test_update_mutate_input  s   

r  r{   zinvalid stringZ   c                 C   sD   t jtdd tddd| d W d    d S 1 sw   Y  d S )Nz5rotation must be 'vertical', 'horizontal' or a numberr   r   r   r  r  r  r   r   r   test_invalid_rotation_values&  s   "r  c                   C   sB   t t tjddddd W d    d S 1 sw   Y  d S )Nr4   r   foobar)r  )r   r   r  r9   figtextr   r   r   r   test_invalid_color.  rm  r  ztext_pdf_kerning.pdfc                   C   s   t   t jddddd d S )Nr%   r4   ATATATATATATATATATAr   rO  )r9   rS   r  r   r   r   r   test_pdf_kerning3  s   r  c                 C   sd   t  }|ddd}|j  tdd | D sJ dd | D d|  d fd	gks0J d S )
Nr4   u   ০c                 s   s    | ]	}t |jtV  qd S N)
isinstancemessager8   .0warnr   r   r   	<genexpr>=  s    z*test_unsupported_script.<locals>.<genexpr>c                 S   s   g | ]}|j jqS r   )r  argsr  r   r   r   
<listcomp>?  s    z+test_unsupported_script.<locals>.<listcomp>z9Glyph 2534 (\N{BENGALI DIGIT ZERO}) missing from font(s) .)z7Matplotlib currently does not support Bengali natively.)r9   rS   rV   r   r   allr<   )recwarnrC   r*  r   r   r   test_unsupported_script9  s   
r  )r   rM   r   z1Error messages are incorrect with pyparsing 3.1.0)reasonc                  C   sx   t  \} }|jddddd | j  |jddddd tjtdd | j  W d    d S 1 s5w   Y  d S )Nr   $ \wrong{math} $F)
parse_mathTUnknown symbolr   )r9   r:   rV   r   r   r   r   r  r9  r   r   r   test_parse_mathF  s   
"r  c                  C   s   t  \} }|ddd tjtdd | j  W d    n1 s$w   Y  t	ddi t  \} }|ddd | j  W d    d S 1 sNw   Y  d S )Nr   r  r  r   ztext.parse_mathF)
r9   r:   rV   r   r   r  r   r   r   
rc_contextr9  r   r   r   test_parse_math_rcparamsS  s   "r  ztext_pdf_font42_kerning.pdfc                   C   s(   dt jd< t   t jddddd d S )NrT  rU  r%   r4   ATAVATAVATAVATAVATAr   rO  r9   r|   rS   r  r   r   r   r   test_pdf_font42_kerningc  s   
r  ztext_pdf_chars_beyond_bmp.pdfc                   C   s2   dt jd< dt jd< t   t jddddd	 d S )
NrT  rU  stixsanszmathtext.fontsetr%   r4   u   Mass $m$ 𐌈r   rO  r  r   r   r   r   test_pdf_chars_beyond_bmpj  s   

r   c                     s   t jj  t } | ddd | jddddd | jddddd | j  |  }i   fdd}||_	| j  g  dd	gksFJ t
 d t
 d	   krYd
ks\J  J t jj }|j|jksjJ d S )Nr0   r4   foo
barTr  c                     s&   | ^}}}}}  |t | d S r  )
setdefaultr   add)r  kwargsrs   r   r   r  r   r   r   r   call~  s   z test_metrics_cache.<locals>.callr   barrM   )r   rV   !_get_text_metrics_with_cache_implcache_clearr9   rS   r   r   _get_rendererdraw_texlen
cache_infohitsmisses)rC   rs   r  infor   r  r   test_metrics_cacher  s   

,r  c                     sj   t  \}  ddgddg fddtdD }dd	 |D \}}| j  t|t|ks3J d S )
Nr  zoffset fontsize)r   r   r  c              
      s*   g | ]} j d d| dd| dqS )r   r   10r  )r   r   r   r'   r   )r;   )r  r   rD   text_coordsxy_textr   r   r    s    
z1test_annotate_offset_fontsize.<locals>.<listcomp>r_   c                 s   s    | ]}|  V  qd S r  )rk   )r  r   r   r   r   r    s    z0test_annotate_offset_fontsize.<locals>.<genexpr>)r9   r:   r[  r   r   str)rC   annspoints_coordsfontsize_coordsr   r  r   test_annotate_offset_fontsize  s   
r  c                  C   s   t ddd} | jtjd ksJ |  tjd ksJ | d | jdu s'J |  | jks0J | d | jdu s<J |  | jksEJ d S )Nr4   r  r   TF)r   _antialiasedr   r|   get_antialiasedset_antialiased)r   r   r   r   test_get_set_antialiased  s   

r  c                  C   s   t dddd} | jdu sJ |  | jksJ t dddd}|jdu s%J | |jks.J t dddd}|d | du sBJ |jdu sIJ t dd}|jtjd ksXJ d S )Nr  r   Tr   Fr   )r   r  r  r  r   r|   )annotannot2annot3annot4r   r   r   test_annotation_antialiased  s   

r$  c                 C   s   |   }|ddgddg\}tddg}|jdt||ddd d|d d < |  }|ddgddg\}tddg}|jd||dd	d
 d|d d < d S )Nr   r_   r4   r   )r   r   rd   )r   r   r   rM   r  )r   r'   r   r   )r~  r   r   arrayr;   r   )r  r  rD   lof_xyan_xyr   r   r   'test_annotate_and_offsetfrom_copy_input  s   r)  c                 C   .   | j ddddd dtjd< | ddd d S )Nr4   6 inches x 2 inchesFr  r   rV   r   r|   r  r  r   r   r   +test_text_antialiased_off_default_vs_manual  s
   

r.  c                 C   r*  )Nr4   r+  Tr  r   r,  r-  r   r   r   *test_text_antialiased_on_default_vs_manual  s   
r/  c                  C   s  t dd} tddd}tdddd}||  tdddd	}||  |j|d
}|j|d
}|j|jks7J |j|jks?J |jd|j	dd\}}}|jd|j	dd\}}}t
||}	| }
|
d dkshJ |
d |jksqJ |
d |	 kszJ |
d |j|	 ksJ d S )Nr3   r   r1   r   rd   r   )r   r'   r   )rV   r   r   rr   rV   F)ismathlpr  rM   r   r   rM   r  )r   r   r   
set_figurer   rk   r`  ra  get_text_width_height_descent_fontpropertiesmaxr  )rS   rs   r  rV   r   	text_bboxr   dlp_d
below_linepointsr   r   r   &test_text_annotation_get_window_extent  s,   



r=  c               
   C   s   d} t jdd\}}|jdddd}|jdddd	d
d| ddd}t   |jj}|j|d}|j|d}|j|}t	|}	|j
|j
d ksJJ |	j|jksRJ |	j
|j
ksZJ tj|	|g}
t|j|
j d S )N   r3   r   r   r   )r  r   r   r        I@r@  r@  r   blackr_   r  r   r`  	headwidthshrinkr   r   r'   r   rr   r@  )r9   r:   rV   r;   r   r   rs   rk   arrow_patchr   r`  ra  r  Bboxunionr   )rD  rC   rD   r   r   rs   r8  r   
arrow_bboxann_txt_bboxexpected_bboxr   r   r   1test_text_with_arrow_annotation_get_window_extent  s,   
rM  c               
   C   s   d} | d }t | d}|d |d tddd}tdddd	d
ddddd}|| || | }| }|j	dksBJ t
|jd|  |d dksRJ |d dd|  ks^J d S )Nr3   H   r          @r1   r   r?  rA  r   rB  r   r   r  rC  rF  r@  g      $@rd   r3     )r   set_figwidthset_figheightr   r   r4  r   rk   r  r`  r   ra  )r   dots_per_pointrS   rs   r  r   r<  r   r   r   'test_arrow_annotation_get_window_extent$  s&   




rT  c                  C   s   t dd} | d | d tddd}tddddd}||  || | }| }|d	 d
ks7J |d d
ks?J |d dksGJ |d dksOJ d S )Nr3   r   rO  r1   r   r?  r   )r   r   r'   rd   r  r2  r  r@  r3  )	r   rQ  rR  r   r   r4  r   rk   r  )rS   rs   r  r   r<  r   r   r   'test_empty_annotation_get_window_extent=  s   




rU  basictext_wrap)baseline_imagesr  c               
   C   s   t  } t g d d}t jdd|dddd t jd	d
|dddd t jd
d
|dddd t jd
d|dddddd t jdd|ddddd t jdd|dddd d S )Nr   r   r   r   This is a really long string that I'd rather have wrapped so that it doesn't go outside of the figure, but if it's long enough it will go off the top or bottom!r   rM   ru   r   T)rQ   r{   r  r]   rP  r   r   r  obliquerO   rP   )r   r"   rQ   rR   r  r   serifr/   )r!   r"   rQ   r  r   r9   rS   axisrV   rC   r*  r   r   r   test_basic_wrapR  s   ra  fonttext_wrapc               
   C   s   t  } t g d d}t jdd|ddddd	d
 t jdd|dddd	d t jdd|dddd	d t jdd|ddd	d t jdd|ddddd	d d S )NrX  rY  r   r]  r  r\  ru   r   T)r   r!   rQ   r{   r  r]   rP  r.   )r!   rQ   r{   r  r   heavyrO   rP   )r+   rQ   rR   r  r   	monospacer   )r!   rQ   r  r   r    r/   rZ  )r   r"   rQ   r{   r  r^  r`  r   r   r   test_font_wrapc  s   
re  )zr   rv  r6   numpyr   numpy.testingr   packaging.versionr   parse_version	pyparsingr   
matplotlibr   matplotlib.backend_basesr   matplotlib.backends.backend_aggr   matplotlib.figurer   r5   r   matplotlib.patchespatchesrg   matplotlib.pyplotpyplotr9   matplotlib.gridspecr	   matplotlib.transforms
transformsr  matplotlib.testing.decoratorsr
   r   matplotlib.testing._markersr   matplotlib.textr   r   r   __version__pyparsing_versionrK   rZ   r   r   r   r   r   markparametrizerk  printr  r   r   r   r   r   r   r
  r  r  r  r  r  r  r%  r+  r:  r@  rI  rM  rS  r]  ri  rl  rp  rz  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  xfailreleaser  r  r  r   r  r  r  r$  r)  r.  r/  r=  rM  rT  rU  ra  re  r   r   r   r   <module>   s*   

X

3






	 





	



	







	

		











#
