Spade
Mini Shell
| Directory:~$ /lib/python2.7/site-packages/pycparser/ |
| [Home] [System Details] [Kill Me] |
�
g�wUc@s�ddlZddlmZdefd��YZdefd��YZdZdZed kr�ddl Z ed
�Z
e
jedd��ndS(
i����N(tTemplatetASTCodeGeneratorcBs)eZdd�Zdd�Zd�ZRS(s
_c_ast.cfgcCsA||_g|j|�D]\}}t||�^q|_dS(sN Initialize
the code generator from a configuration
file.
N(tcfg_filenamet
parse_cfgfiletNodeCfgtnode_cfg(tselfRtnametcontents((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyt__init__s cCs^tt�jd|j�}|t7}x%|jD]}||j�d7}q/W|j|�dS(s<
Generates the code into file, an open file buffer.
Rs
N(Rt_PROLOGUE_COMMENTt
substituteRt_PROLOGUE_CODERtgenerate_sourcetwrite(RtfiletsrcR((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pytgenerates
ccst|d��}x�|D]�}|j�}|s|jd�rGqn|jd�}|jd�}|jd�}|dks�||ks�||kr�td||f��n||
}||d|!}|r�g|jd�D]} | j�^q�ng}
||
fVqWWd QXd S(
se Parse the configuration file and yield pairs of
(name, contents) for each node.
trt#t:t[t]isInvalid line in %s:
%s
t,N(topentstript
startswithtfindtRuntimeErrortsplit(Rtfilenametftlinetcolon_it
lbracket_it
rbracket_iRtvaltvtvallist((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyR&s
$
4N(t__name__t
__module__R tNoneRR(((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyRsRcBs;eZdZd�Zd�Zd�Zd�Zd�ZRS(s�
Node configuration.
name: node name
contents: a list of contents - attributes and child nodes
See comment at the top of the configuration file for details.
cCs�||_g|_g|_g|_g|_x�|D]y}|jd�}|jj|�|jd�r{|jj|�q4|jd�r�|jj|�q4|jj|�q4WdS(Nt*s**(Rtall_entriestattrtchildt seq_childtrstriptappendtendswith(RRRtentrytclean_entry((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyR Bs
cCs8|j�}|d|j�7}|d|j�7}|S(Ns
(t _gen_initt
_gen_childrent_gen_attr_names(RR((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyR
TscCs�d|j}|jr[dj|j�}djd�|jD��}|d7}d|}nd}d}|d|7}|d |7}x,|jd
gD]}|d||f7}q�W|S(Nsclass %s(Node):
s,
css|]}dj|�VqdS(s'{0}'N(tformat(t.0te((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pys <genexpr>_ss,
'coord', '__weakref__'s(self, %s,
coord=None)s'coord', '__weakref__'s(self,
coord=None)s __slots__ = (%s)
s def __init__%s:
tcoords self.%s = %s
(RR+tjoin(RRtargstslotstarglistR((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyR4Zs
cCs�d}|jr�|d7}x,|jD]!}|ddtd|�7}q#Wx(|jD]}|dtd|�7}qRW|d7}n
|d7}|S( Ns def children(self):
s nodelist = []
s& if self.%(child)s is not None:s0
nodelist.append(("%(child)s", self.%(child)s))
R-su for i, child in enumerate(self.%(child)s or []):
nodelist.append(("%(child)s[%%d]" %% i, child))
s return tuple(nodelist)
s return ()
(R+R-tdictR.(RRR-R.((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyR5ns
cCs(ddjd�|jD��d}|S(Ns attr_names =
(tcss|]}d|VqdS(s%r,
N((R8tnm((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pys <genexpr>�st)(R;R,(RR((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyR6�s$(R'R(t__doc__R R
R4R5R6(((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyR;s s�#-----------------------------------------------------------------
# ** 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.
#
# Copyright (C) 2008-2015, Eli Bendersky
# License: BSD
#-----------------------------------------------------------------
s�
import sys
class Node(object):
__slots__ = ()
""" Abstract base class for AST nodes.
"""
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)
"""
def visit(self, node):
""" Visit a node.
"""
method = 'visit_' + node.__class__.__name__
visitor = getattr(self, method, self.generic_visit)
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_name, c in node.children():
self.visit(c)
t__main__s
_c_ast.cfgsc_ast.pytw(
tpprinttstringRtobjectRRR
RR'tsystast_genRR(((s6/usr/lib/python2.7/site-packages/pycparser/_ast_gen.pyt<module>
s*br