
    h%                       S r SSKJr  SSKJrJrJrJr  SSKJ	r	  SSK
Jr  SSKJr  SSKJr  SSKJr  SS	KJr  SS
KJr  SSKJr  SSKJr  SSKJr  \(       a  SSKJr  SSKJr  SSK J!r!J"r"  SSKJ#r#   " S S\5      r$ " S S5      r%g)z=Run-related proxy objects for python-docx, Run in particular.    )annotations)IOTYPE_CHECKINGIteratorcast)Drawing)WD_STYLE_TYPE)WD_BREAK)
CT_Drawing)CT_LastRenderedPageBreak)InlineShape)
StoryChild)CharacterStyle)Font)RenderedPageBreakN)WD_UNDERLINE)CT_RCT_Text)Lengthc                    ^  \ rS rSrSrSU 4S jjr\R                  4SS jjr  S       SS jjr	SS jr
SS jr\SS j5       r\R                  SS	 j5       rS
 r\SS j5       r\S S j5       r\SS j5       r\R                  SS j5       rS!S jr\S"S j5       r\R                  S#S j5       r\S$S j5       r\R                  SS j5       r\S%S j5       r\R                  S&S j5       rSrU =r$ )'Run   a5  Proxy object wrapping `<w:r>` element.

Several of the properties on Run take a tri-state value, |True|, |False|, or |None|.
|True| and |False| correspond to on and off respectively. |None| indicates the
property is not specified directly on the run and its effective value is taken from
the style hierarchy.
c                N   > [         TU ]  U5        U=U l        =U l        U l        g N)super__init___r_elementelement)selfrparent	__class__s      ?/var/www/html/env/lib/python3.13/site-packages/docx/text/run.pyr   Run.__init__"   s%     1222$-$,    c                ,   [         R                  S[         R                  S[         R                  S[         R                  S[         R
                  S[         R                  S0U   u  p#U R                  R                  5       nUb  X$l	        Ub  X4l
        gg)zAdd a break element of `break_type` to this run.

`break_type` can take the values `WD_BREAK.LINE`, `WD_BREAK.PAGE`, and
`WD_BREAK.COLUMN` where `WD_BREAK` is imported from `docx.enum.text`.
`break_type` defaults to `WD_BREAK.LINE`.
NN)pageN)columnN)textWrappingleft)r+   right)r+   allN)r
   LINEPAGECOLUMNLINE_CLEAR_LEFTLINE_CLEAR_RIGHTLINE_CLEAR_ALLr   add_brtypeclear)r    
break_typetype_r7   brs        r$   	add_breakRun.add_break&   s     MM<MM>OO-$$&>%%'@##%<
  WW^^GH r&   c                    U R                   R                  XU5      nU R                  R                  U5        [	        U5      $ )a  Return |InlineShape| containing image identified by `image_path_or_stream`.

The picture is added to the end of this run.

`image_path_or_stream` can be a path (a string) or a file-like object containing
a binary image.

If neither width nor height is specified, the picture appears at
its native size. If only one is specified, it is used to compute a scaling
factor that is then applied to the unspecified dimension, preserving the aspect
ratio of the image. The native size of the picture is calculated using the dots-
per-inch (dpi) value specified in the image file, defaulting to 72 dpi if no
value is specified, as is often the case.
)partnew_pic_inliner   add_drawingr   )r    image_path_or_streamwidthheightinlines        r$   add_pictureRun.add_picture;   s8    ( ))*>vNF#6""r&   c                8    U R                   R                  5         g)z[Add a ``<w:tab/>`` element at the end of the run, which Word interprets as a
tab character.N)r   add_tabr    s    r$   rH   Run.add_tabS   s     	r&   c                N    U R                   R                  U5      n[        U5      $ )zReturns a newly appended |_Text| object (corresponding to a new ``<w:t>``
child element) to the run, containing `text`.

Compare with the possibly more friendly approach of assigning text to the
:attr:`Run.text` property.
)r   add_t_Text)r    textts      r$   add_textRun.add_textX   s     GGMM$Qxr&   c                .    U R                   R                  $ )zRead/write tri-state value.

When |True|, causes the text of the run to appear in bold face. When |False|,
the text unconditionally appears non-bold. When |None| the bold setting for this
run is inherited from the style hierarchy.
fontboldrI   s    r$   rU   Run.boldb   s     yy~~r&   c                $    XR                   l        g r   rS   r    values     r$   rU   rV   l   s    		r&   c                :    U R                   R                  5         U $ )z_Return reference to this run after removing all its content.

All run formatting is preserved.
)r   clear_contentrI   s    r$   r7   	Run.clearp   s    
 	r&   c                @    [        U R                  R                  5      $ )a  `True` when one or more rendered page-breaks occur in this run.

Note that "hard" page-breaks inserted by the author are not included. A hard
page-break gives rise to a rendered page-break in the right position so if those
were included that page-break would be "double-counted".

It would be very rare for multiple rendered page-breaks to occur in a single
run, but it is possible.
)boolr   lastRenderedPageBreaksrI   s    r$   contains_page_breakRun.contains_page_breakx   s     DGG2233r&   c                ,    [        U R                  5      $ )zsThe |Font| object providing access to the character formatting properties for
this run, such as font name and size.)r   r   rI   s    r$   rT   Run.font   s     DMM""r&   c                .    U R                   R                  $ )zRead/write tri-state value.

When |True|, causes the text of the run to appear in italics. When |False|, the
text unconditionally appears non-italic. When |None| the italic setting for this
run is inherited from the style hierarchy.
rT   italicrI   s    r$   rf   
Run.italic   s     yyr&   c                $    XR                   l        g r   re   rX   s     r$   rf   rg      s     		r&   c              #    #    U R                   R                   Hf  n[        U[        5      (       a  Uv   M  [        U[        5      (       a  [        X5      v   MB  [        U[        5      (       d  MY  [        X5      v   Mh     g7f)a  Generate the content-items in this run in the order they appear.

NOTE: only content-types currently supported by `python-docx` are generated. In
this version, that is text and rendered page-breaks. Drawing is included but
currently only provides access to its XML element (CT_Drawing) on its
`._drawing` attribute. `Drawing` attributes and methods may be expanded in
future releases.

There are a number of element-types that can appear inside a run, but most of
those (w:br, w:cr, w:noBreakHyphen, w:t, w:tab) have a clear plain-text
equivalent. Any contiguous range of such elements is generated as a single
`str`. Rendered page-break and drawing elements are generated individually. Any
other elements are ignored.
N)r   inner_content_items
isinstancestrr   r   r   r   )r    items     r$   iter_inner_contentRun.iter_inner_content   s^      GG//D$$$
D":;;'33D*--d)) 0s   A,B2Bc                    U R                   R                  n[        [        U R                  R                  U[        R                  5      5      $ )a9  Read/write.

A |CharacterStyle| object representing the character style applied to this run.
The default character style for the document (often `Default Character Font`) is
returned if the run has no directly-applied character style. Setting this
property to |None| removes any directly-applied character style.
)r   styler   r   r>   	get_styler	   	CHARACTER)r    style_ids     r$   rq   	Run.style   s5     77==NDII$7$7-BYBY$Z[[r&   c                x    U R                   R                  U[        R                  5      nX R                  l        g r   )r>   get_style_idr	   rs   r   rq   )r    style_or_namert   s      r$   rq   ru      s'    99))-9P9PQ r&   c                .    U R                   R                  $ )a  String formed by concatenating the text equivalent of each run.

Each `<w:t>` element adds the text characters it contains. A `<w:tab/>` element
adds a `\t` character. A `<w:cr/>` or `<w:br>` element each add a `\n`
character. Note that a `<w:br>` element can indicate a page break or column
break as well as a line break. Only line-break `<w:br>` elements translate to
a `\n` character. Others are ignored. All other content child elements, such as
`<w:drawing>`, are ignored.

Assigning text to this property has the reverse effect, translating each `\t`
character to a `<w:tab/>` element and each `\n` or `\r` character to a
`<w:cr/>` element. Any existing run content is replaced. Run formatting is
preserved.
r   rN   rI   s    r$   rN   Run.text   s      ww||r&   c                $    XR                   l        g r   rz   )r    rN   s     r$   rN   r{      s    r&   c                .    U R                   R                  $ )a[  The underline style for this |Run|.

Value is one of |None|, |True|, |False|, or a member of :ref:`WdUnderline`.

A value of |None| indicates the run has no directly-applied underline value and
so will inherit the underline value of its containing paragraph. Assigning
|None| to this property removes any directly-applied underline value.

A value of |False| indicates a directly-applied setting of no underline,
overriding any inherited value.

A value of |True| indicates single underline.

The values from :ref:`WdUnderline` are used to specify other outline styles such
as double, wavy, and dotted.
rT   	underlinerI   s    r$   r   Run.underline   s    $ yy"""r&   c                $    XR                   l        g r   r~   rX   s     r$   r   r      s    #		r&   )r   r   r   )r!   r   r"   zt.ProvidesStoryPart)r8   r
   r(   )rA   zstr | IO[bytes]rB   int | Length | NonerC   r   returnr   )r   None)rN   rl   )r   bool | None)rY   r   )r   r^   )r   r   )r   z+Iterator[str | Drawing | RenderedPageBreak])r   r   )rx   zstr | CharacterStyle | None)r   rl   )r   zbool | WD_UNDERLINE | None)rY   r^   )__name__
__module____qualname____firstlineno____doc__r   r
   r/   r;   rE   rH   rP   propertyrU   setterr7   r`   rT   rf   rn   rq   rN   r   __static_attributes____classcell__r#   s   @r$   r   r      sj   3 08}} 0 &*&*	#-# ## $	#
 
#0
   
[[  
4 
4 # #
     ]]! !*. 	\ 	\ \\! !  " 
[[  # #& $ $r&   r   c                  0   ^  \ rS rSrSrSU 4S jjrSrU =r$ )rM      z&Proxy object wrapping `<w:t>` element.c                6   > [         [        U ]  5         Xl        g r   )r   rM   r   _t)r    t_elmr#   s     r$   r   _Text.__init__   s    eT#%r&   )r   )r   r   )r   r   r   r   r   r   r   r   r   s   @r$   rM   rM      s    0 r&   rM   )&r   
__future__r   typingr   r   r   r   docx.drawingr   docx.enum.styler	   docx.enum.textr
   docx.oxml.drawingr   docx.oxml.text.pagebreakr   
docx.shaper   docx.sharedr   docx.styles.styler   docx.text.fontr   docx.text.pagebreakr   
docx.typestypesrO   r   docx.oxml.text.runr   r   r   r   rM    r&   r$   <module>r      sW    C " 4 4   ) # ( = " " ,  1+0"T$* T$n r&   