o
    P+ i*(                     @  s   d Z ddlmZ ddlmZ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 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 erlddlmZ ddlmZ ddl m!Z!m"Z" ddlm#Z# G dd deZ$G dd dZ%dS )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                      s$  e Zd ZdZdB fddZejfdCd
dZ		dDdEddZdFddZ	dGddZ
edHddZejdId!dZd"d# ZedJd%d&ZedKd(d)ZedHd*d+ZejdId,d+ZdLd.d/ZdMd3d4ZedNd6d7ZejdOd:d7ZedPd;d<ZejdGd=d<ZedQd?d@ZejdRdAd@Z  ZS )SRunaI  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.
    rr   parentt.ProvidesStoryPartc                   s"   t  | | | _ | _| _d S N)super__init___r_elementelement)selfr   r   	__class__ Y/home/app/PaddleOCR-VL-test/.venv_paddleocr/lib/python3.10/site-packages/docx/text/run.pyr   "   s   zRun.__init__
break_typer	   c                 C  s^   t jdt jdt jdt jdt jdt jdi| \}}| j }|dur$||_	|dur-||_
dS dS )a	  Add 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	   LINEZPAGEZCOLUMNZLINE_CLEAR_LEFTZLINE_CLEAR_RIGHTZLINE_CLEAR_ALLr   Zadd_brtypeclear)r   r$   type_r.   brr"   r"   r#   	add_break&   s   

zRun.add_breakNimage_path_or_streamstr | IO[bytes]widthint | Length | Noneheightreturnr   c                 C  s$   | j |||}| j| t|S )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.
        )partZnew_pic_inliner   Zadd_drawingr   )r   r2   r4   r6   inliner"   r"   r#   add_picture;   s   zRun.add_pictureNonec                 C  s   | j   dS )zcAdd a ``<w:tab/>`` element at the end of the run, which Word interprets as a
        tab character.N)r   add_tabr   r"   r"   r#   r<   S   s   zRun.add_tabtextstrc                 C  s   | j |}t|S )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   Zadd_t_Text)r   r>   tr"   r"   r#   add_textX   s   zRun.add_textbool | Nonec                 C     | j jS )a  Read/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boldr=   r"   r"   r#   rG   b      zRun.boldvaluec                 C     || j _d S r   rE   r   rI   r"   r"   r#   rG   l      c                 C  s   | j   | S )zoReturn reference to this run after removing all its content.

        All run formatting is preserved.
        )r   clear_contentr=   r"   r"   r#   r.   p   s   
z	Run.clearboolc                 C  s   t | jjS )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.
        )rN   r   ZlastRenderedPageBreaksr=   r"   r"   r#   contains_page_breakx   s   zRun.contains_page_breakr   c                 C  s
   t | jS )z{The |Font| object providing access to the character formatting properties for
        this run, such as font name and size.)r   r   r=   r"   r"   r#   rF      s   
zRun.fontc                 C  rD   )a	  Read/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.
        rF   italicr=   r"   r"   r#   rQ      rH   z
Run.italicc                 C  rJ   r   rP   rK   r"   r"   r#   rQ      rL   +Iterator[str | Drawing | RenderedPageBreak]c                 c  sT    | j jD ]"}t|tr|V  qt|trt|| V  qt|tr't|| V  qdS )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   Zinner_content_items
isinstancer?   r   r   r
   r   )r   itemr"   r"   r#   iter_inner_content   s   


zRun.iter_inner_contentlast_run
comment_idintc                 C  s   | j | |j | dS )zMark the range of runs from this run to `last_run` (inclusive) as belonging to a comment.

        `comment_id` identfies the comment that references this range.
        N)r   Z insert_comment_range_start_aboveZ,insert_comment_range_end_and_reference_below)r   rV   rW   r"   r"   r#   mark_comment_range   s   zRun.mark_comment_ranger   c                 C  s   | j j}tt| j|tjS )aa  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   r8   	get_styler   	CHARACTER)r   style_idr"   r"   r#   rZ      s   	z	Run.stylestyle_or_namestr | CharacterStyle | Nonec                 C  s   | j |tj}|| j_d S r   )r8   Zget_style_idr   r\   r   rZ   )r   r^   r]   r"   r"   r#   rZ      s   c                 C  rD   )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   r>   r=   r"   r"   r#   r>      s   zRun.textc                 C  rJ   r   r`   )r   r>   r"   r"   r#   r>      rL   bool | WD_UNDERLINE | Nonec                 C  rD   )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.
        rF   	underliner=   r"   r"   r#   rc      s   zRun.underlinec                 C  rJ   r   rb   rK   r"   r"   r#   rc      rL   )r   r   r   r   )r$   r	   r%   )r2   r3   r4   r5   r6   r5   r7   r   )r7   r;   )r>   r?   )r7   rC   )rI   rC   )r7   rN   )r7   r   )r7   rR   )rV   r   rW   rX   r7   r;   )r7   r   )r^   r_   )r7   r?   )r7   ra   )rI   ra   )__name__
__module____qualname____doc__r   r	   r,   r1   r:   r<   rB   propertyrG   setterr.   rO   rF   rQ   rU   rY   rZ   r>   rc   __classcell__r"   r"   r    r#   r      sH    


		

r   c                      s"   e Zd ZdZd fddZ  ZS )r@   z&Proxy object wrapping `<w:t>` element.t_elmr   c                   s   t t|   || _d S r   )r   r@   r   Z_t)r   rk   r    r"   r#   r      s   
z_Text.__init__)rk   r   )rd   re   rf   rg   r   rj   r"   r"   r    r#   r@      s    r@   )&rg   
__future__r   typingr   r   r   r   Zdocx.drawingr   Zdocx.enum.styler   Zdocx.enum.textr	   Zdocx.oxml.drawingr
   Zdocx.oxml.text.pagebreakr   Z
docx.shaper   Zdocx.sharedr   Zdocx.styles.styler   Zdocx.text.fontr   Zdocx.text.pagebreakr   Z
docx.typestypesrA   r   Zdocx.oxml.text.runr   r   r   r   r@   r"   r"   r"   r#   <module>   s*     d