<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"
        integrity="sha384-GLhlTQ8iRABdZLl6O3oVMWSktQOp6b7In1Zl3/Jr59b6EGGoI1aFkw7cmDA6j6gD" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css"
        integrity="sha512-SzlrxWUlpfuzQ+pcUCosxcglQRNAq/DZjVsC0lE40xsADsfeQoEypE+enwcOiGjk/bSuGGKHEyjSoQ1zVisanQ=="
        crossorigin="anonymous" referrerpolicy="no-referrer" />
</head>
</html>

Rec           @` sv   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  Z d	   Z d
   Z d S(   u  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.
i    (   t   absolute_importt   divisiont   unicode_literalsi   (   t	   constants(   t   default_etreeu   getTreeWalkeru   pprintc         K` s   |  j    }  |  t k r |  d k rD d d l m } | j t |  <q |  d k rp d d l m } | j t |  <q |  d k r d d l m } | j t |  <q |  d k r d d	 l m } | d
 k r t	 } n  | j
 | |  j Sn  t j |   S(   u;  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

    u   domi   (   t   domu   genshi(   t   genshiu   lxml(   t
   etree_lxmlu   etree(   t   etreeN(   t   lowert   treeWalkerCachet    R   t
   TreeWalkerR   R   R   t   NoneR   t   getETreeModulet   get(   t   treeTypet   implementationt   kwargsR   R   R   R   (    (    s   /builddir/build/BUILDROOT/alt-python27-pip-20.2.4-5.el8.x86_64/opt/alt/python27/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.pyt   getTreeWalker   s"    	c         c` s   g  } xh |  D]` } | d } | d k r= | j  | d  q | rh i d d 6d j |  d 6Vg  } n  | Vq W| r i d d 6d j |  d 6Vn  d  S(   Nu   typeu
   Charactersu   SpaceCharactersu   datau    (   u
   Charactersu   SpaceCharacters(   t   appendt   join(   t   tokenst   pendingCharacterst   tokent   type(    (    s   /builddir/build/BUILDROOT/alt-python27-pip-20.2.4-5.el8.x86_64/opt/alt/python27/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.pyt   concatenateCharacterTokensA   s    
		c         C` s  g  } d } xt  |   D]} | d } | d k r~| d r | d t j d k r | d t j k r} t j | d } n
 | d } d | | d f } n
 | d } | j d	 d
 | | f  | d 7} | d } x t | j    D]t \ \ } }	 }
 | r:| t j k r!t j | } n | } d | |	 f } n |	 } | j d d
 | | |
 f  q W| d k r| d 8} qq | d k r| d 8} q | d k r| j d d
 | | d f  q | d k r| d rz| d r%| j d d
 | | d | d | d r| d n d f  q| d rX| j d d
 | | d | d f  q| j d d
 | | d f  q| j d d
 | f  q | d k r| j d d
 | | d f  q | d k rt st d   q t	 d |   q Wd j
 |  S(    u   Pretty printer for tree walkers

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

    :arg walker: a TreeWalker instance

    i    u   typeu   StartTagu   EmptyTagu	   namespaceu   htmlu   %s %su   nameu   %s<%s>u    i   u   datau	   %s%s="%s"u   EndTagu   Commentu   %s<!-- %s -->u   Doctypeu   publicIdu   %s<!DOCTYPE %s "%s" "%s">u   systemIdu    u   %s<!DOCTYPE %s "" "%s">u   %s<!DOCTYPE %s>u   %s<!DOCTYPE >u
   Charactersu   %s"%s"u   SpaceCharactersuB   concatenateCharacterTokens should have got rid of all Space tokensu   Unknown token type, %su   
(   u   StartTagu   EmptyTag(   R   R   t
   namespacest   prefixesR   t   sortedt   itemst   Falset   AssertionErrort
   ValueErrorR   (   t   walkert   outputt   indentR   R   t   nst   namet   attrst	   namespacet	   localnamet   value(    (    s   /builddir/build/BUILDROOT/alt-python27-pip-20.2.4-5.el8.x86_64/opt/alt/python27/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.pyt   pprintP   sd    
!



%""

	"
	"N(   t   __doc__t
   __future__R    R   R   R   R   t   _utilsR   t   __all__R
   R   R   R   R+   (    (    (    s   /builddir/build/BUILDROOT/alt-python27-pip-20.2.4-5.el8.x86_64/opt/alt/python27/lib/python2.7/site-packages/pip/_vendor/html5lib/treewalkers/__init__.pyt   <module>	   s   ,	