Your IP : 18.222.108.185


Current Path : /opt/cloudlinux/venv/lib64/python3.11/site-packages/lxml/html/__pycache__/
Upload File :
Current File : //opt/cloudlinux/venv/lib64/python3.11/site-packages/lxml/html/__pycache__/clean.cpython-311.pyc

�

��bg�n���dZddlmZddlZddlZddlZ	ddlmZddlm	Z	n#e
$rddlmZm	Z	YnwxYwddlm
Z
ddlmZdd	lmZmZdd
lmZmZ	en
#e$reZYnwxYw	en
#e$reZYnwxYw	en#e$reefZYnwxYwgd�Zejdejejz��jZ ejd
ej��jZ!ejdgej"ddkrej#fnd�R�j$Z%ejdej��j&Z'ejdej��j&Z(ejdej��j$Z)d�Z*ejd��jZ+ejdejejz��Z,e
j-d��Z.e
j-ddei���Z/Gd�de0��Z1e1��Z2e2j3Z3ejdej��ejdej��gZ4gd�Z5ejd ej��ejd!ej��ejd"��gZ6d#gZ7e4e5e6e7fd$�Z8d%�Z9d&�Z:e8je:_gd'�Z;d(gZ<d)e;e<ed*��fd+�Z=d,�Z>d-�Z?ejd.ej��Z@d/�ZAdS)0zcA cleanup tool for HTML.

Removes unwanted tags and content.  See the `Cleaner` class for
details.
�)�absolute_importN)�urlsplit)�unquote_plus)rr)�etree)�defs)�
fromstring�XHTML_NAMESPACE)�
xhtml_to_html�_transform_result)�
clean_html�clean�Cleaner�autolink�
autolink_html�
word_break�word_break_htmlzexpression\s*\(.*?\)z
@\s*importz</?[a-zA-Z]+|\son[a-zA-Z]+\s*=��z:(javascript|jscript|livescript|vbscript|data|about|mocha):z	(xml|svg)c��d}t|��D]}t|��rdS|dz
}�tt|����|kS)NrT�)�_find_image_dataurls�_is_unsafe_image_type�len�_possibly_malicious_schemes)�s�safe_image_urls�
image_types   �b/builddir/build/BUILD/cloudlinux-venv-1.0.7/venv/lib64/python3.11/site-packages/lxml/html/clean.py�_has_javascript_schemerVs]���O�*�1�-�-���
� ��,�,�	��4�4��1�����*�1�-�-�.�.��@�@�z[\s\x00-\x08\x0B\x0C\x0E-\x19]+z\[if[\s\n\r]+.*?][\s\n\r]*>zdescendant-or-self::*[@style]z�descendant-or-self::a  [normalize-space(@href) and substring(normalize-space(@href),1,1) != '#'] |descendant-or-self::x:a[normalize-space(@href) and substring(normalize-space(@href),1,1) != '#']�x)�
namespacesc	��eZdZdZdZdZdZdZdZdZ	dZ
dZdZdZ
dZdZdZdZdZdZdZdZejZdZdZddhZd�Zed	d
ddgd	d	d	d
�
��Zd�Zd�Zd�Z d�Z!d�Z"dd�Z#d�Z$e%j&de%j'��j(Z)d�Z*d�Z+dS)ra
    Instances cleans the document of each of the possible offending
    elements.  The cleaning is controlled by attributes; you can
    override attributes in a subclass, or set them in the constructor.

    ``scripts``:
        Removes any ``<script>`` tags.

    ``javascript``:
        Removes any Javascript, like an ``onclick`` attribute. Also removes stylesheets
        as they could contain Javascript.

    ``comments``:
        Removes any comments.

    ``style``:
        Removes any style tags.

    ``inline_style``
        Removes any style attributes.  Defaults to the value of the ``style`` option.

    ``links``:
        Removes any ``<link>`` tags

    ``meta``:
        Removes any ``<meta>`` tags

    ``page_structure``:
        Structural parts of a page: ``<head>``, ``<html>``, ``<title>``.

    ``processing_instructions``:
        Removes any processing instructions.

    ``embedded``:
        Removes any embedded objects (flash, iframes)

    ``frames``:
        Removes any frame-related tags

    ``forms``:
        Removes any form tags

    ``annoying_tags``:
        Tags that aren't *wrong*, but are annoying.  ``<blink>`` and ``<marquee>``

    ``remove_tags``:
        A list of tags to remove.  Only the tags will be removed,
        their content will get pulled up into the parent tag.

    ``kill_tags``:
        A list of tags to kill.  Killing also removes the tag's content,
        i.e. the whole subtree, not just the tag itself.

    ``allow_tags``:
        A list of tags to include (default include all).

    ``remove_unknown_tags``:
        Remove any tags that aren't standard parts of HTML.

    ``safe_attrs_only``:
        If true, only include 'safe' attributes (specifically the list
        from the feedparser HTML sanitisation web site).

    ``safe_attrs``:
        A set of attribute names to override the default list of attributes
        considered 'safe' (when safe_attrs_only=True).

    ``add_nofollow``:
        If true, then any <a> tags will have ``rel="nofollow"`` added to them.

    ``host_whitelist``:
        A list or set of hosts that you can use for embedded content
        (for content like ``<object>``, ``<link rel="stylesheet">``, etc).
        You can also implement/override the method
        ``allow_embedded_url(el, url)`` or ``allow_element(el)`` to
        implement more complex rules for what can be embedded.
        Anything that passes this test will be shown, regardless of
        the value of (for instance) ``embedded``.

        Note that this parameter might not work as intended if you do not
        make the links absolute before doing the cleaning.

        Note that you may also need to set ``whitelist_tags``.

    ``whitelist_tags``:
        A set of tags that can be included with ``host_whitelist``.
        The default is ``iframe`` and ``embed``; you may wish to
        include other tags like ``script``, or you may want to
        implement ``allow_embedded_url`` for more control.  Set to None to
        include all tags.

    This modifies the document *in place*.
    TFNr�iframe�embedc���t��}|���D]n\}}t|||��}|�E|durA|dur=t|tt
ttf��std|�d|�����t|||���o|j
�d|vr|j|_
|�d��r-|�d��rtd���d|_dSdS)	NTFzUnknown parameter: �=�inline_style�
allow_tags�remove_unknown_tags�IIt does not make sense to pass in both allow_tags and remove_unknown_tags)�object�items�getattr�
isinstance�	frozenset�set�tuple�list�	TypeError�setattrr(�style�get�
ValueErrorr*)�self�kw�not_an_attribute�name�value�defaults      r�__init__zCleaner.__init__�s$��!�8�8���8�8�:�:�	'�	'�K�D�%��d�D�*:�;�;�G��#��t�(;�(;��u�@T�@T�&�w��C���0M�N�N�AU��i�26�$�$���>�@�@�@��D�$��&�&�&�&���$��r�)A�)A� $�
�D��
�6�6�,���	-��v�v�+�,�,�
G� �"F�G�G�G�',�D�$�$�$�		-�	-r �src�href�coder,)�script�link�appletr$r%�layer�ac���	|j}|��}n#t$rYnwxYwt|��|�d��D]	}d|_�
|js|�|��t|jpd��}t|j	pd��}t|j
pd��}|jr|�d��|j
r[t|j��}|�tj��D]'}|j}|���D]	}	|	|vr||	=�
�(|j�r�|j
r|jt(jksX|�tj��D]8}|j}|���D]}	|	�d��r||	=��9|�|jd���|js�t3|��D]q}|�d��}
t7d	|
��}t9d	|��}|�|��r	|jd=�U||
kr|�d|���r|js�t?|�d����D]�}|�d
d	��� ���!��dkr|�"���U|j#pd	}
t7d	|
��}t9d	|��}|�|��rd|_#��||
kr||_#��|jr|�tj$��|j%r|�tj&��|jr|�d��|jrtj'|d��|j(r|�d
��n�|js|jrxt?|�d
����D]U}d|�dd	��� ��vr)|�)|��s|�"���V|j*r|�d��|j+r|�,d��|j-r�t?|�d����D]V}|�.��}|�(|jdvr|�.��}|�	|jdv�|�|�"���W|�,d��|�,d��|j/r|�,t(j0��|j1r*|�d��|�,d��|j2r|�,d��g}
g}|���D]k}|j|vr,|�)|��r�!|�3|���7|j|vr+|�)|��r�V|
�3|���l|
rB|
d|kr6|
�4d��}d|_|j�5��nI|rG|d|kr;|�4d��}|jdkrd|_|�5��|�6��|D]}|�"���|
D]}|�7���|j8r*|rtsd���tt(j:��}|r�|js|�tj$��|j%s|�tj&��g}|���D] }|j|vr|�3|���!|rX|d|ur5|�4d��}d|_|j�5��|D]}|�7���|j;rhty|��D]Z}|�=|��sA|�d��}|rd|vrdd |zvr�:d!|z}nd}|�d|���YdSdS)"z&
        Cleans the document.
        �image�imgrrC�onF)�resolve_base_hrefr6��typeztext/javascriptz
/* deleted */rD�
stylesheet�rel�meta)�head�html�title�paramN)rEr,)rE)r$r%rFr,rU�form)�button�input�select�textarea)�blink�marqueer�divrSr+�nofollowz
 nofollow z %s z%s nofollow)>�getroot�AttributeErrorr
�iter�tag�comments�kill_conditional_commentsr1�	kill_tags�remove_tagsr)�scripts�add�safe_attrs_only�
safe_attrsr�Element�attrib�keys�
javascriptr�
startswith�
rewrite_links�_remove_javascript_linkr(�_find_styled_elementsr7�_replace_css_javascript�_replace_css_import�_has_sneaky_javascriptr6r3�lower�strip�	drop_tree�text�Comment�processing_instructions�ProcessingInstruction�strip_attributes�links�
allow_elementrQ�page_structure�update�embedded�	getparent�frames�
frame_tags�forms�
annoying_tags�append�pop�clear�reverse�drop_tagr*r8�tags�add_nofollow�_find_external_links�allow_follow)r9�docr_�elrerfr)rjrl�aname�old�new�parent�_remove�_kill�badrPs                 r�__call__zCleaner.__call__s���	��k�G��'�)�)�C�C���	�	�	��D�	����
	�c�����(�(�7�#�#�	�	�B��B�F�F��}�	0�
�*�*�3�/�/�/����,�"�-�-�	��$�*�0�b�1�1�����.�B�/�/�
��<�	$��M�M�(�#�#�#���	*��T�_�-�-�J��h�h�u�}�-�-�
*�
*�����#�[�[�]�]�*�*�E��J�.�.�"�5�M��*��?�$	&��(�
.��O�t��6�6��(�(�5�=�1�1�.�.�B��Y�F�!'�����.�.�� �+�+�D�1�1�.� &�u�
��.�
���d�:�05�
�
7�
7�
7��$�	
-�/��4�4�-�-�B��&�&��/�/�C�1�"�c�:�:�C�-�b�#�6�6�C��2�2�3�7�7�-��I�g�.�.��������w��,�,�,���:�

&��s�x�x��0�0�1�1�&�&�B��v�v�f�b�)�)�/�/�1�1�7�7�9�9�=N�N�N������� ��'�-�R�C�1�"�c�:�:�C�-�b�#�6�6�C��2�2�3�7�7�&�"1��������"%�����=�	)��M�M�%�-�(�(�(��'�	7��M�M�%�5�6�6�6��:�	#��M�M�'�"�"�"���	1��"�3��0�0�0��:�		'��M�M�&�!�!�!�!�
�Z�	'�4�?�	'��3�8�8�F�+�+�,�,�
'�
'���2�6�6�%��#4�#4�#:�#:�#<�#<�<�<��-�-�b�1�1�'���������9�	"��M�M�&�!�!�!���	:����8�9�9�9��=�	P��3�8�8�G�,�,�-�-�
#�
#���������(�V�Z�?S�-S�-S�#�-�-�/�/�F��(�V�Z�?S�-S�-S��>��L�L�N�N�N�����[�)�)�)����N�O�O�O��;�	.�
���T�_�-�-�-��:�	H��O�O�F�#�#�#����F�G�G�G���	5����3�4�4�4������(�(�*�*�	#�	#�B��v��"�"��%�%�b�)�)������R� � � � ���;�&�&��%�%�b�)�)������r�"�"�"���	�w�q�z�S�(�(����Q���B��B�F��I�O�O�����
�	�u�Q�x�3������1���B��v��������H�H�J�J�J�
�
�
�����	�	�B��L�L�N�N�N�N��	�	�B��K�K�M�M�M�M��#�	(��
a� �_�a�a�a��T�Y���J��	"��=�
.����u�}�-�-�-��/�
<����u�:�;�;�;��C��h�h�j�j�
#�
#���6��+�+��J�J�r�N�N�N���
"��q�6�S�=�=�������B�"�B�F��I�O�O�%�%�%��"�"�B��K�K�M�M�M�M���	'�*�3�/�/�

'�

'���(�(��,�,�	'��&�&��-�-�C��)�&�#�-�-�$0�V�c�\�$B�$B�$�+�c�1���(���F�F�5�#�&�&�&��	'�	'�

'�

's��
!�!c��dS)zF
        Override to suppress rel="nofollow" on some anchors.
        Fr)r9�anchors  rr�zCleaner.allow_follow�s	���ur c�P�|j|jvrdS|j|j}t|ttf��r:|D]5}|�|��}|sdS|�||��sdS�6dS|�|��}|sdS|�||��S)z�
        Decide whether an element is configured to be accepted or rejected.

        :param el: an element.
        :return: true to accept the element or false to reject/discard it.
        FT)rb�_tag_link_attrsr/r3r2r7�allow_embedded_url)r9r��attr�one_attr�urls     rrzCleaner.allow_element�s����6��-�-�-��5��#�B�F�+���d�T�5�M�*�*�	4� �
!�
!���f�f�X�&�&���!� �5�5��.�.�r�3�7�7�!� �5�5�!��4��&�&��,�,�C��
��u��*�*�2�s�3�3�3r c���|j�|j|jvrdSt|��\}}}}}|����dd��d}|dvrdS||jvrdSdS)a
        Decide whether a URL that was found in an element's attributes or text
        if configured to be accepted or rejected.

        :param el: an element.
        :param url: a URL found on the element.
        :return: true to accept the URL and false to reject it.
        NF�:rr)�http�httpsT)�whitelist_tagsrbrrv�split�host_whitelist)r9r�r��scheme�netloc�path�query�fragments        rr�zCleaner.allow_embedded_url�s�����*�r�v�T�=P�/P�/P��5�08��
�
�-����e�X������%�%�c�1�-�-�a�0���*�*�*��5��T�(�(�(��4��ur c�h��tj�|�|�fd�tj��dS)z�
        IE conditional comments basically embed HTML that the parser
        doesn't normally see.  We can't allow anything like that, so
        we'll kill any comments that could be conditional.
        c�$���|j��S�N)ry)r��has_conditional_comments �r�<lambda>z3Cleaner.kill_conditional_comments.<locals>.<lambda>�s���3�3�B�G�<�<�r N)�_conditional_comment_re�search�_kill_elementsrrz)r9r�r�s  @rrdz!Cleaner.kill_conditional_comments�sD���#:�"@������<�<�<�<��M�	�	�	�	�	r c��g}|�|��D]"}||��r|�|���#|D]}|����dSr�)rar�rx)r9r��	condition�iterater�r�s      rr�zCleaner._kill_elementssj�����(�(�7�#�#�	�	�B��y��}�}�
��
�
�2������	�	�B��L�L�N�N�N�N�	�	r c�b�tdt|����}t|��rdS|S)NrM)�_substitute_whitespacerr)r9rDr�s   rrqzCleaner._remove_javascript_links3��$�R��d�);�);�<�<��!�#�&�&�	��2��r z	/\*.*?\*/c��|�d|��}|�dd��}td|��}|���}t	|��rdSd|vrdSd|vrdSd|vrdSt|��rdSdS)a�
        Depending on the browser, stuff like ``e x p r e s s i o n(...)``
        can get interpreted, or ``expre/* stuff */ssion(...)``.  This
        checks for attempt to do stuff like this.

        Typically the response will be to kill the entire style; if you
        have just a bit of Javascript in the style another rule will catch
        that and remove only the Javascript from the style; this catches
        more sneaky attempts.
        rM�\Tzexpression(z@importz
</noscriptF)�_substitute_comments�replacer�rvr�_looks_like_tag_content)r9r6s  rruzCleaner._has_sneaky_javascripts����)�)�"�e�4�4���
�
�d�B�'�'��&�r�5�1�1�����
�
��!�%�(�(�	��4��E�!�!��4������4��5� � ��4�"�5�)�)�	��4��ur c���t|��}t|t��rt|��}nt	j|��}||��t
||��Sr�)rNr/�
basestringr�copy�deepcopyr)r9rS�result_typer�s    rrzCleaner.clean_html/sZ���4�j�j���d�J�'�'�	&��T�"�"�C�C��-��%�%�C���S�	�	�	� ��c�2�2�2r r�),�__name__�
__module__�__qualname__�__doc__rgrnrcr6r(r~rQr�r{r�r�r�r�rfr)rer*rirrjr�r�r�r?�dictr�r�r�rr�rdr�rq�re�compile�S�subr�rurrr rrrms�������\�\�|�G��J��H��E��L��E��D��N�"���H�
�F��E��M��K��J��I����O���J��L��N���(�N�-�-�-�(�d��
���!�����#
�
�
�O�(w'�w'�w'�r���4�4�4�0���&	�	�	��������&�2�:�l�B�D�9�9�=�����:3�3�3�3�3r rzb(?P<body>https?://(?P<host>[a-z0-9._-]+)(?:/[/\-_.,a-z0-9%&?;=~]*)?(?:\([/\-_.,a-z0-9%&?;=~]*\))?)z9mailto:(?P<body>[a-z0-9._-]+@(?P<host>[a-z0-9_.-]+[a-z])))rZ�prerBrRrYrGz
^localhostz\bexample\.(?:com|org|net)$z^127\.0\.0\.1$�nolinkc���|j|vrdS|�d��}|r |���}|D]	}||vrdS�
t|��D]h}t	|||||���|jrKt
|j|||j���\}}	|	r)||_|�|��}
|	||
dz|
dz�<�i|j	r2t
|j	|||j���\}}|r||_	||dd�<dSdSdS)a
    Turn any URLs into links.

    It will search for links identified by the given regular
    expressions (by default mailto and http(s) links).

    It won't link text in an element in avoid_elements, or an element
    with a class in avoid_classes.  It won't link to anything with a
    host that matches one of the regular expressions in avoid_hosts
    (default localhost and 127.0.0.1).

    If you pass in an element, the element's tail will not be
    substituted, only the contents of the element.
    N�class)�link_regexes�avoid_elements�avoid_hosts�
avoid_classes)�factoryrr)
rbr7r�r3r�tail�
_link_text�makeelement�indexry)r�r�r�r�r��
class_name�match_class�childry�
tail_childrenr��pre_childrens            rrrOsn��$
�v������������J����%�%�'�'�
�(�	�	�K��j�(�(����)��b���4�4����\� .�(�,�	.�	.�	.�	.��:�	4�",��
�L�+�r�~�#O�#O�#O��D�-��
4�!��
��������&3��5��7�5��7�?�#��	�w�"�'��G�\�;���H�H�H���l��	"��B�G�!�B�r��r�F�F�F�"�"�	"�	"r c��d}g}d}	d\}}|D]�}	|}
	|	�||
���}|�nG|�d��}|D]-}
|
�|��r|���}
n�.n�a|��i|�|���|kr|}|���}��|�'|r|djrJ�||d_n|rJ�|}�n9|�d��}|���}|�d��s|�d	��r|dz}|dd�}|d|����}|r|djrJ�||d_n|rJ�|}|d
��}|�d|��|�d��}|s|}|�d��s|�d	��r
|dd�}||_|�|��||d�}��||fS)
NrMrr)NN)�pos�host����.�,rGrA�body)	r��group�end�startr��endswithr1ryr�)ryr�r�r��leading_textr~�last_pos�
best_match�best_pos�regex�	regex_pos�matchr��
host_regexrDr��	prev_textr�r�s                   rr�r�|s����L��E��H�3�)��
�H�!�	)�	)�E� �I�

����T�y��9�9���=���{�{�6�*�*��"-���J�!�(�(��.�.��$)�I�I�K�K�	�����

��}����5�;�;�=�=�8�#;�#;�"�
� �;�;�=�=������
$� ��9�>�)�)�)�!%��b�	���'�'�'�'�#�������"�"���n�n�����=�=����	����s�!3�!3�	��1�H�C�����9�D��,�*�*�*�,�,�,�-�	��	%��R�y�~�%�%�%�&�E�"�I�N�N�#�#�#�#�$�L��������
�
�6�4� � � �����'�'���	��D��=�=����	����s�!3�!3�	�����9�D����
���V�����C�D�D�z��g3�h���r c���t|��}t|t��rt|��}nt	j|��}t
|g|�Ri|��t||��Sr�)rNr/r�rr�r�rr�rS�argsr:r�r�s     rrr�sk���t�*�*�K��$�
�#�#�"��������m�D�!�!���S��4����2�����[�#�.�.�.r )r�rZrB�nobreak�(i c�\�|jtvrdS|�d��}|r'd}|���}|D]
}||vrd}n�|rdS|jrt|j||��|_|D]8}t
|||||���|jrt|j||��|_�9dS)a�
    Breaks any long words found in the body of the text (not attributes).

    Doesn't effect any of the tags in avoid_elements, by default
    ``<textarea>`` and ``<pre>``

    Breaks words by inserting &#8203;, which is a unicode character
    for Zero Width Space character.  This generally takes up no space
    in rendering, but does copy as a space, and in monospace contexts
    usually takes up space.

    See http://www.cs.tut.fi/~jkorpela/html/nobr.html for a discussion
    Nr�FT)�	max_widthr�r��break_character)rb�_avoid_word_break_elementsr7r�ry�_break_textrr�)	r�r�r�r�r�r��
dont_break�avoidr�s	         rrr�s��&
�v�+�+�+���������J����
��%�%�'�'�
�"�	�	�E��
�"�"�!�
���#��	��F�	�w�C��b�g�y�/�B�B����M�M���5�I�"0�!.�#2�	4�	4�	4�	4��:�	M�$�U�Z��O�L�L�E�J��
M�Mr c�~�t|��}t|��}t|g|�Ri|��t||��Sr�)rNrrrr�s     rrr�sH���t�*�*�K�
�T�
�
�C��s� �T� � � �R� � � ��[�#�.�.�.r c��|���}|D]<}t|��|kr't|||��}|�||��}�=|Sr�)r�r�
_insert_breakr�)ryr�r��words�word�replacements      rr�r��sY���J�J�L�L�E��3�3���t�9�9�y� � �'��i��I�I�K��<�<��k�2�2�D���Kr z[^a-z]c��|}d}t|��|kr�|d|�}tt�|����}|r?|d}|���|dz
kr|d|����}|||zz
}|t|��d�}t|��|k��||z
}|S)NrMr��
)rr3�_break_prefer_re�finditerr�)r�widthr��	orig_word�resultr��breaks�
last_breaks        rrrs����I�
�F�

�d�)�)�e�
�
��V�e�V����&�/�/��6�6�7�7���	0����J��~�~���%��(�*�*��.�j�n�n�.�.�.�/���%�/�)�)���C��J�J�K�K� ���d�)�)�e�
�
��d�N�F��Mr )Br��
__future__rr�r��sys�urlparser�urllibr�ImportError�urllib.parse�lxmlr�	lxml.htmlrrr	r
r�unichr�	NameError�chr�unicode�strr��bytes�__all__r�r��Ir�rsrt�version_info�ASCIIr�r��findallrrrrr�r��XPathrrr�r,rr
r�
_link_regexes�_avoid_elements�_avoid_hosts�_avoid_classesrr�rr��_avoid_word_break_classesrrr�r	rrr r�<module>r)s�����'�&�&�&�&�&�����	�	�	�	�
�
�
�
�4�!�!�!�!�!�!�#�#�#�#�#�#�#���4�4�4�3�3�3�3�3�3�3�3�3�3�4����������������1�1�1�1�1�1�1�1�6�6�6�6�6�6�6�6��
�F�F������
�F�F�F�������G�G�������G�G�G�������J�J�������u��J�J�J�����,�,�,��0%�"�*��R�T�"�$�Y�(�(�(+��!�b�j��2�4�����%�"�*�%�8��%�a�(�A�-�-�r�x�k�k�2�8�8�8�8>��"�r�z����&�&�&-��(�b�j�A��D�
�
�
��#��
�<���6�6�=��A�A�A�$���$F�G�G�K��%�"�*�"�B�D���I�/�/��$���#�%�%��#�u�{�h��O�$�&�&�&��I3�I3�I3�I3�I3�f�I3�I3�I3�V	��	�	��
�
�
��B�J�t�vx�vz�{�{��B�J�K�R�T�R�R��
�E�D�D���B�J�}�b�d�#�#��B�J�-�r�t�4�4��B�J� �!�!������+�+�%�)�+"�+"�+"�+"�Z8�8�8�t/�/�/�!�(�
��9�8�8��&�K���8�6�%�v�f�~�~�'M�'M�'M�'M�R/�/�/�����2�:�i���.�.������sB�#�
3�3�A�A �A �$A'�'A1�0A1�5A8�8	B�B

?>