U
    §òccW  ã                   @   sZ   d Z ddlmZmZmZ ddlmZ ddlmZ ddgZ	i Z
dd	d„Zd
d„ Zdd„ ZdS )a…  A collection of modules for iterating through different kinds of
tree, generating tokens identical to those produced by the tokenizer
module.

To create a tree walker for a new type of tree, you need to
implement a tree walker object (called TreeWalker by convention) that
implements a 'serialize' method which takes a tree as sole argument and
returns an iterator which generates tokens.
é    )Úabsolute_importÚdivisionÚunicode_literalsé   )Ú	constants)Údefault_etreeÚgetTreeWalkerÚpprintNc                 K   sª   |   ¡ } | tkr | dkr0ddlm} |jt| < np| dkrPddlm} |jt| < nP| dkrpddlm} |jt| < n0| dkr dd	lm} |d
krt}|j	|f|ŽjS t 
| ¡S )a;  Get a TreeWalker class for various types of tree with built-in support

    :arg str treeType: the name of the tree type required (case-insensitive).
        Supported values are:

        * "dom": The xml.dom.minidom DOM implementation
        * "etree": A generic walker for tree implementations exposing an
          elementtree-like interface (known to work with ElementTree,
          cElementTree and lxml.etree).
        * "lxml": Optimized walker for lxml.etree
        * "genshi": a Genshi stream

    :arg implementation: A module implementing the tree type e.g.
        xml.etree.ElementTree or cElementTree (Currently applies to the "etree"
        tree type only).

    :arg kwargs: keyword arguments passed to the etree walker--for other
        walkers, this has no effect

    :returns: a TreeWalker class

    Údomé   )r
   Úgenshi)r   Zlxml)Ú
etree_lxmlÚetree)r   N)ÚlowerÚtreeWalkerCacheÚ r
   Z
TreeWalkerr   r   r   r   ZgetETreeModuleÚget)ZtreeTypeÚimplementationÚkwargsr
   r   r   r   © r   úW/var/www/html/project/venv/lib/python3.8/site-packages/html5lib/treewalkers/__init__.pyr      s"    c                 c   sh   g }| D ]D}|d }|dkr,|  |d ¡ q|rFdd |¡dœV  g }|V  q|rddd |¡dœV  d S )NÚtype)Ú
CharactersÚSpaceCharactersÚdatar   r   )r   r   )ÚappendÚjoin)ÚtokensZpendingCharactersÚtokenr   r   r   r   ÚconcatenateCharacterTokensA   s    r   c              	   C   sb  g }d}t | ƒD ]D}|d }|dkr|d rz|d tjd krz|d tjkr`tj|d  }n|d }d||d f }n|d }| dd	| |f ¡ |d
7 }|d }t| ¡ ƒD ]T\\}}	}
|rì|tjkrÚtj| }n|}d||	f }n|	}| dd	| ||
f ¡ q´|dkrV|d
8 }q|dkr2|d
8 }q|dkrX| dd	| |d f ¡ q|dkr
|d rô|d r¬| dd	| |d |d |d r |d ndf ¡ nF|d rØ| dd	| |d |d f ¡ n| dd	| |d f ¡ n| dd	| f ¡ q|dkr0| dd	| |d f ¡ q|dkrJdsVtdƒ‚qtd| ƒ‚qd 	|¡S ) z Pretty printer for tree walkers

    Takes a TreeWalker instance and pretty prints the output of walking the tree.

    :arg walker: a TreeWalker instance

    r   r   )ZStartTagÚEmptyTagÚ	namespaceÚhtmlz%s %sÚnamez%s<%s>ú r   r   z	%s%s="%s"r    ZEndTagÚCommentz%s<!-- %s -->ZDoctypeZpublicIdz%s<!DOCTYPE %s "%s" "%s">ZsystemIdr   z%s<!DOCTYPE %s "" "%s">z%s<!DOCTYPE %s>z%s<!DOCTYPE >r   z%s"%s"r   FzBconcatenateCharacterTokens should have got rid of all Space tokenszUnknown token type, %sÚ
)
r   r   Ú
namespacesÚprefixesr   ÚsortedÚitemsÚAssertionErrorÚ
ValueErrorr   )ZwalkerÚoutputÚindentr   r   Únsr#   Úattrsr!   Ú	localnameÚvaluer   r   r   r	   P   sn    









ýÿ
þÿÿ


)N)Ú__doc__Ú
__future__r   r   r   r   r   Ú_utilsr   Ú__all__r   r   r   r	   r   r   r   r   Ú<module>   s   

,