
    #	h;)                     D    S SK Jr   " S S\5      r " S S\5      rSrSrg)	    )Templatec                   .    \ rS rSrSS jrSS jrS rSrg)	ASTCodeGenerator   c                     Xl         U R                  U5       VVs/ s H  u  p#[        X#5      PM     snnU l        gs  snnf )z9Initialize the code generator from a configuration
file.
N)cfg_filenameparse_cfgfileNodeCfgnode_cfg)selfr   namecontentss       D/var/www/html/env/lib/python3.13/site-packages/pycparser/_ast_gen.py__init__ASTCodeGenerator.__init__   sD     )$($6$6|$DF$D  !0$DF Fs   <Nc                     [        [        5      R                  U R                  S9nU[        -  nU R
                   H  nX#R                  5       S-   -  nM     UR                  U5        g)z;Generates the code into file, an open file buffer.
        )r   z

N)r   _PROLOGUE_COMMENT
substituter   _PROLOGUE_CODEr   generate_sourcewrite)r   filesrcr   s       r   generateASTCodeGenerator.generate   se     ()44** 5 , 	~H++-66C & 	

3    c           	   #     #    [        US5       nU H  nUR                  5       nU(       a  UR                  S5      (       a  M2  UR                  S5      nUR                  S5      nUR                  S5      nUS:  d
  XT::  d  Xe::  a  [	        SU< SU< S	35      eUS
U nX5S-   U nU(       a/  UR                  S5       V	s/ s H  oR                  5       PM     sn	O/ n
Xz4v   M     S
S
S
5        g
s  sn	f ! , (       d  f       g
= f7f)zPParse the configuration file and yield pairs of
(name, contents) for each node.
r#:[]   zInvalid line in z:

N,)openstrip
startswithfindRuntimeErrorsplit)r   filenameflinecolon_i
lbracket_i
rbracket_ir   valvvallists              r   r	   ASTCodeGenerator.parse_cfgfile%   s      (C Azz|ts33))C.!YYs^
!YYs^
Q;*"7:;S&hPT'UVVHW~>*5ADciin=n779n="m#  !  > ! s/   DB2C6C1C6(	D1C66
D D)r   r   )z
_c_ast.cfg)N)__name__
__module____qualname____firstlineno__r   r   r	   __static_attributes__ r   r   r   r      s    F
$r   r   c                   <    \ rS rSrSrS rS rS rS rS r	S r
S	rg
)r
   :   zNode configuration.

name: node name
contents: a list of contents - attributes and child nodes
See comment at the top of the configuration file for details.
c                    Xl         / U l        / U l        / U l        / U l        U H  nUR                  S5      nU R                  R                  U5        UR                  S5      (       a  U R                  R                  U5        Mb  UR                  S5      (       a  U R                  R                  U5        M  U R                  R                  U5        M     g )N*z**)r   all_entriesattrchild	seq_childrstripappendendswith)r   r   r   entryclean_entrys        r   r   NodeCfg.__init__B   s    		
E,,s+K##K0~~d##%%k2$$

!!+.		  ' r   c                     U R                  5       nUSU R                  5       -   -  nUSU R                  5       -   -  nUSU R                  5       -   -  nU$ )Nr$   )	_gen_init_gen_children	_gen_iter_gen_attr_namesr   r   s     r   r   NodeCfg.generate_sourceT   sY    nntd((***tdnn&&&td**,,,
r   c                 H   SU R                   -  nU R                  (       aH  SR                  U R                  5      nSR                  S U R                   5       5      nUS-  nSU-  nOSnSnUSU-  -  nUS	U-  -  nU R                  S
/-    H  nUSU< SU< S3-  nM     U$ )Nzclass %s(Node):
z, c              3   D   #    U  H  nS R                  U5      v   M     g7f)z'{0}'N)format).0es     r   	<genexpr>$NodeCfg._gen_init.<locals>.<genexpr>`   s     J9IAgnnQ//9Is    z, 'coord', '__weakref__'z(self, %s, coord=None)z'coord', '__weakref__'z(self, coord=None)z    __slots__ = (%s)
z    def __init__%s:
coordz        self.z = r$   )r   r@   join)r   r   argsslotsarglistr   s         r   rK   NodeCfg._gen_init[   s    !DII-99T--.DIIJ9I9IJJE//E.5G,E*G'%//&00$$y0DtT::C 1 
r   c                     SnU R                   (       aP  US-  nU R                   H  nUS[        US9-  -  nM     U R                   H  nUS[        US9-  -  nM     US-  nU$ US-  nU$ )Nz    def children(self):
z        nodelist = []
zV        if self.%(child)s is not None: nodelist.append(("%(child)s", self.%(child)s))
rB   zu        for i, child in enumerate(self.%(child)s or []):
            nodelist.append(("%(child)s[%%d]" %% i, child))
z        return tuple(nodelist)
z        return ()
r@   rB   dictrC   r   r   rB   rC   s       r   rL   NodeCfg._gen_childreno   s    ),,CH5)+ + $ "^^	T9-/ / , 55C 
 ((C
r   c                    SnU R                   (       am  U R                   H  nUS[        US9-  -  nM     U R                   H  nUS[        US9-  -  nM     U R                  (       d  U R                  (       d  US-  nU$ US-  nU$ )Nz    def __iter__(self):
zH        if self.%(child)s is not None:
            yield self.%(child)s
r_   zE        for child in (self.%(child)s or []):
            yield child
z        return
        yield
r`   rb   s       r   rM   NodeCfg._gen_iter   s    )9=A=NP P $
 "^^	048y4IK K ,
 JJ$..&' 
	 "#C 
r   c                 V    SSR                  S U R                   5       5      -   S-   nU$ )Nz    attr_names = ( c              3   ,   #    U  H
  nS U-  v   M     g7f)z%r, Nr;   )rT   nms     r   rV   *NodeCfg._gen_attr_names.<locals>.<genexpr>   s     ,M9RVb[9s   ))rY   rA   rO   s     r   rN   NodeCfg._gen_attr_names   s*    "RWW,M499,M%MMPSS
r   )r@   rA   rB   r   rC   N)r6   r7   r8   r9   __doc__r   r   rK   rL   rM   rN   r:   r;   r   r   r
   r
   :   s%    ($(06r   r
   a  #-----------------------------------------------------------------
# ** ATTENTION **
# This code was automatically generated from the file:
# $cfg_filename
#
# Do not modify it directly. Modify the configuration file and
# run the generator again.
# ** ** *** ** **
#
# pycparser: c_ast.py
#
# AST Node classes.
#
# Eli Bendersky [https://eli.thegreenplace.net/]
# License: BSD
#-----------------------------------------------------------------

a3  
import sys

def _repr(obj):
    """
    Get the representation of an object, with dedicated pprint-like format for lists.
    """
    if isinstance(obj, list):
        return '[' + (',\n '.join((_repr(e).replace('\n', '\n ') for e in obj))) + '\n]'
    else:
        return repr(obj)

class Node(object):
    __slots__ = ()
    """ Abstract base class for AST nodes.
    """
    def __repr__(self):
        """ Generates a python representation of the current node
        """
        result = self.__class__.__name__ + '('

        indent = ''
        separator = ''
        for name in self.__slots__[:-2]:
            result += separator
            result += indent
            result += name + '=' + (_repr(getattr(self, name)).replace('\n', '\n  ' + (' ' * (len(name) + len(self.__class__.__name__)))))

            separator = ','
            indent = '\n ' + (' ' * len(self.__class__.__name__))

        result += indent + ')'

        return result

    def children(self):
        """ A sequence of all children that are Nodes
        """
        pass

    def show(self, buf=sys.stdout, offset=0, attrnames=False, nodenames=False, showcoord=False, _my_node_name=None):
        """ Pretty print the Node and all its attributes and
            children (recursively) to a buffer.

            buf:
                Open IO buffer into which the Node is printed.

            offset:
                Initial offset (amount of leading spaces)

            attrnames:
                True if you want to see the attribute names in
                name=value pairs. False to only see the values.

            nodenames:
                True if you want to see the actual node names
                within their parents.

            showcoord:
                Do you want the coordinates of each Node to be
                displayed.
        """
        lead = ' ' * offset
        if nodenames and _my_node_name is not None:
            buf.write(lead + self.__class__.__name__+ ' <' + _my_node_name + '>: ')
        else:
            buf.write(lead + self.__class__.__name__+ ': ')

        if self.attr_names:
            if attrnames:
                nvlist = [(n, getattr(self,n)) for n in self.attr_names]
                attrstr = ', '.join('%s=%s' % nv for nv in nvlist)
            else:
                vlist = [getattr(self, n) for n in self.attr_names]
                attrstr = ', '.join('%s' % v for v in vlist)
            buf.write(attrstr)

        if showcoord:
            buf.write(' (at %s)' % self.coord)
        buf.write('\n')

        for (child_name, child) in self.children():
            child.show(
                buf,
                offset=offset + 2,
                attrnames=attrnames,
                nodenames=nodenames,
                showcoord=showcoord,
                _my_node_name=child_name)


class NodeVisitor(object):
    """ A base NodeVisitor class for visiting c_ast nodes.
        Subclass it and define your own visit_XXX methods, where
        XXX is the class name you want to visit with these
        methods.

        For example:

        class ConstantVisitor(NodeVisitor):
            def __init__(self):
                self.values = []

            def visit_Constant(self, node):
                self.values.append(node.value)

        Creates a list of values of all the constant nodes
        encountered below the given node. To use it:

        cv = ConstantVisitor()
        cv.visit(node)

        Notes:

        *   generic_visit() will be called for AST nodes for which
            no visit_XXX method was defined.
        *   The children of nodes for which a visit_XXX was
            defined will not be visited - if you need this, call
            generic_visit() on the node.
            You can use:
                NodeVisitor.generic_visit(self, node)
        *   Modeled after Python's own AST visiting facilities
            (the ast module of Python 3.0)
    """

    _method_cache = None

    def visit(self, node):
        """ Visit a node.
        """

        if self._method_cache is None:
            self._method_cache = {}

        visitor = self._method_cache.get(node.__class__.__name__, None)
        if visitor is None:
            method = 'visit_' + node.__class__.__name__
            visitor = getattr(self, method, self.generic_visit)
            self._method_cache[node.__class__.__name__] = visitor

        return visitor(node)

    def generic_visit(self, node):
        """ Called if no explicit visitor function exists for a
            node. Implements preorder visiting of the node.
        """
        for c in node:
            self.visit(c)

N)stringr   objectr   r
   r   r   r;   r   r   <module>rp      s8    '$v '$Tjf j\ (Ur   