+
    i,                        ^ RI Ht ^ RIt^ RIHt  ! R R4      t ! R R4      tRtR	t]	R
8X  d   ]P                  P                  ]P                  P                  ]4      4      t]P                  P                  ]R4      t]P                  P                  ]R4      t]! ]4      t]! ]R4      ;_uu_ 4       t]P+                  ]4       RRR4       R# R#   + '       g   i     R# ; i)    )TemplateN)IOc                   B   a  ] tR t^t o RR ltV 3R lR ltR tRtV tR# )ASTCodeGeneratorc                    Wn         V P                  V4       UUu. uF  w  r#\        W#4      NK  	  uppV n        R# u uppi )z9Initialize the code generator from a configuration
file.
N)cfg_filenameparse_cfgfileNodeCfgnode_cfg)selfr   namecontentss   &&  Y/home/wkmabra/.openclaw/workspace/venv/lib/python3.14/site-packages/pycparser/_ast_gen.py__init__ASTCodeGenerator.__init__   sC     ) %)$6$6|$D
$D  D#$D
 
s   <c                4   < V ^8  d   QhRS[ S[,          RR/# )   filereturnN)r   str)format__classdict__s   "r   __annotate__ASTCodeGenerator.__annotate__    s      RW      c                    \        \        4      P                  V P                  R7      pV\        ,          pV P
                   F   pW#P                  4       R,           ,          pK"  	  VP                  V4       R# )z2Generates the code into file, an open file buffer.)r   z

N)r   _PROLOGUE_COMMENT
substituter   _PROLOGUE_CODEr   generate_sourcewrite)r   r   srcr   s   &&  r   generateASTCodeGenerator.generate    s\    ()44$BSBS4T~H++-66C & 	

3r   c           
   #  8  "   \        VR4      ;_uu_ 4       pV F  pVP                  4       pV'       d   VP                  R4      '       d   K4  VP                  R4      pVP                  R4      pVP                  R4      pV^8  g   WT8:  g   We8:  d   \	        RV RV R24      hVR	V pW5^,           V pV'       d/   VP                  R
4       U	u. uF  qP                  4       NK  	  up	M. p
Wz3x  K  	  R	R	R	4       R	# u up	i   + '       g   i     R	# ; i5i)zPParse the configuration file and yield pairs of
(name, contents) for each node.
r#:[]zInvalid line in :

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&)9(3tfB'OPPHW~>J7ADciin=n779n="m#  !  > !  s5   D4DBDD
)D7
DDD		D)r   r   N)
_c_ast.cfg)	__name__
__module____qualname____firstlineno__r   r#   r	   __static_attributes____classdictcell__r   s   @r   r   r      s     
 $ $r   r   c                   H   a  ] tR t^?t o RtR tR tR tR tR t	R t
RtV tR	# )
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                   Wn         . V n        . V n        . V n        . V n        V F  pVP                  R 4      pV P                  P                  V4       VP                  R4      '       d   V P                  P                  V4       Kc  VP                  R 4      '       d   V P                  P                  V4       K  V P                  P                  V4       K  	  R# )*z**N)r   all_entriesattrchild	seq_childrstripappendendswith)r   r   r   entryclean_entrys   &&&  r   r   NodeCfg.__init__G   s    		
E,,s+K##K0~~d##%%k2$$

!!+.		  ' r   c                    V P                  4       pVR V P                  4       ,           ,          pVR V P                  4       ,           ,          pVR V P                  4       ,           ,          pV# )r,   )	_gen_init_gen_children	_gen_iter_gen_attr_namesr   r"   s   & r   r    NodeCfg.generate_sourceY   sY    nntd((***tdnn&&&td**,,,
r   c                v   R V P                    R2pV P                  '       dN   RP                  V P                  4      pRP                  R V P                   4       4      pVR,          pRV R2pMRpRpVR	V R
2,          pVRV R2,          pV P                  R.,            F  pVRV RV R2,          pK  	  V# )zclass z(Node):
, c              3   .   "   T F  pR V R 2x  K  	  R# 5i)'N ).0es   & r   	<genexpr>$NodeCfg._gen_init.<locals>.<genexpr>e   s     A0@1!Ah0@s   z, 'coord', '__weakref__'z(self, z, coord=None)z'coord', '__weakref__'z(self, coord=None)z    __slots__ = (z)
z    def __init__r+   coordz        self.z = r,   )r   rI   join)r   r"   argsslotsarglistr   s   &     r   rT   NodeCfg._gen_init`   s    tyyk+99T--.DIIA0@0@AAE//Ev]3G,E*G"5'--!'#..$$y00D]4&D644C 1 
r   c                "   R pV P                   '       dr   VR,          pV P                   F   pVRV R2,          pVRV RV R2,          pK"  	  V P                   F  pVRV R2,          pVR	V R
2,          pK  	  VR,          pV# VR,          pV# )z    def children(self):
z        nodelist = []
        if self. is not None:
z            nodelist.append(("z", self.z))
z'        for i, child in enumerate(self.	 or []):
z            nodelist.append((f"z[{i}]", child))
z        return tuple(nodelist)
z        return ()
rI   rK   rL   r   r"   rK   rL   s   &   r   rU   NodeCfg._gen_childrent   s    ),,C)%@@7whugTRR $ "^^	@:VV8CVWW , 55C 
 ((C
r   c                J   R pV P                   '       d   V P                   F  pVRV R2,          pVRV R2,          pK  	  V P                   F  pVRV R2,          pVR,          pK  	  V P                  '       g   V P                  '       g
   VR,          pV# VR,          pV# )	z    def __iter__(self):
rj   rk   z            yield self.r,   z        for child in (self.rl   z            yield child
z        return
        yield
rm   rn   s   &   r   rV   NodeCfg._gen_iter   s    ))%@@0r:: $ "^^	4YKzJJ22 , JJJ$...==
 
 99C
r   c                f    R RP                  R V P                   4       4      ,           R,           pV# )z    attr_names = ( c              3   ,   "   T F
  q: R 2x  K  	  R# 5i)r[   Nr^   )r_   nms   & r   ra   *NodeCfg._gen_attr_names.<locals>.<genexpr>   s     ,M9RvR[9s   ))rd   rJ   rX   s   & r   rW   NodeCfg._gen_attr_names   s*    "RWW,M499,M%MMPSS
r   )rI   rJ   rK   r   rL   N)r?   r@   rA   rB   __doc__r   r    rT   rU   rV   rW   rC   rD   rE   s   @r   r
   r
   ?   s-     ($((* r   r
   a  #-----------------------------------------------------------------
# ** ATTENTION **
# This code was automatically generated from _c_ast.cfg
#
# 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
#-----------------------------------------------------------------

ae  
import sys
from typing import Any, ClassVar, IO, Optional

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:
    __slots__ = ()
    """ Abstract base class for AST nodes.
    """
    attr_names: ClassVar[tuple[str, ...]] = ()
    coord: Optional[Any]
    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: IO[str] = sys.stdout,
        offset: int = 0,
        attrnames: bool = False,
        showemptyattrs: bool = True,
        nodenames: bool = False,
        showcoord: bool = False,
        _my_node_name: Optional[str] = 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.

            showemptyattrs:
                False if you want to suppress printing empty attributes.

            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:
            def is_empty(v):
                v is None or (hasattr(v, '__len__') and len(v) == 0)
            nvlist = [(n, getattr(self,n)) for n in self.attr_names \
                        if showemptyattrs or not is_empty(getattr(self,n))]
            if attrnames:
                attrstr = ', '.join(f'{name}={value}' for name, value in nvlist)
            else:
                attrstr = ', '.join(f'{value}' for _, value in nvlist)
            buf.write(attrstr)

        if showcoord:
            buf.write(f' (at {self.coord})')
        buf.write('\n')

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


class NodeVisitor:
    """ 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: 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: Node):
        """ Called if no explicit visitor function exists for a
            node. Implements preorder visiting of the node.
        """
        for _, c in node.children():
            self.visit(c)

__main__r>   zc_ast.pyw)stringr   ostypingr   r   r
   r   r   r?   pathdirnameabspath__file__base_dirrd   cfg_pathout_pathast_genr.   outr#   r^   r   r   <module>r      s      	 '$ '$T` `F "gT zwwrwwx89Hww||Hl3Hww||Hj1Hx(G	h		 
	 
 
		s   5CC$	