123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125 |
- #-----------------------------------------------------------------
- # ** ATTENTION **
- # This code was automatically generated from the file:
- # _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
- #-----------------------------------------------------------------
- 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)
- class ArrayDecl(Node):
- __slots__ = ('type', 'dim', 'dim_quals', 'coord', '__weakref__')
- def __init__(self, type, dim, dim_quals, coord=None):
- self.type = type
- self.dim = dim
- self.dim_quals = dim_quals
- self.coord = coord
- def children(self):
- nodelist = []
- if self.type is not None: nodelist.append(("type", self.type))
- if self.dim is not None: nodelist.append(("dim", self.dim))
- return tuple(nodelist)
- def __iter__(self):
- if self.type is not None:
- yield self.type
- if self.dim is not None:
- yield self.dim
- attr_names = ('dim_quals', )
- class ArrayRef(Node):
- __slots__ = ('name', 'subscript', 'coord', '__weakref__')
- def __init__(self, name, subscript, coord=None):
- self.name = name
- self.subscript = subscript
- self.coord = coord
- def children(self):
- nodelist = []
- if self.name is not None: nodelist.append(("name", self.name))
- if self.subscript is not None: nodelist.append(("subscript", self.subscript))
- return tuple(nodelist)
- def __iter__(self):
- if self.name is not None:
- yield self.name
- if self.subscript is not None:
- yield self.subscript
- attr_names = ()
- class Assignment(Node):
- __slots__ = ('op', 'lvalue', 'rvalue', 'coord', '__weakref__')
- def __init__(self, op, lvalue, rvalue, coord=None):
- self.op = op
- self.lvalue = lvalue
- self.rvalue = rvalue
- self.coord = coord
- def children(self):
- nodelist = []
- if self.lvalue is not None: nodelist.append(("lvalue", self.lvalue))
- if self.rvalue is not None: nodelist.append(("rvalue", self.rvalue))
- return tuple(nodelist)
- def __iter__(self):
- if self.lvalue is not None:
- yield self.lvalue
- if self.rvalue is not None:
- yield self.rvalue
- attr_names = ('op', )
- class Alignas(Node):
- __slots__ = ('alignment', 'coord', '__weakref__')
- def __init__(self, alignment, coord=None):
- self.alignment = alignment
- self.coord = coord
- def children(self):
- nodelist = []
- if self.alignment is not None: nodelist.append(("alignment", self.alignment))
- return tuple(nodelist)
- def __iter__(self):
- if self.alignment is not None:
- yield self.alignment
- attr_names = ()
- class BinaryOp(Node):
- __slots__ = ('op', 'left', 'right', 'coord', '__weakref__')
- def __init__(self, op, left, right, coord=None):
- self.op = op
- self.left = left
- self.right = right
- self.coord = coord
- def children(self):
- nodelist = []
- if self.left is not None: nodelist.append(("left", self.left))
- if self.right is not None: nodelist.append(("right", self.right))
- return tuple(nodelist)
- def __iter__(self):
- if self.left is not None:
- yield self.left
- if self.right is not None:
- yield self.right
- attr_names = ('op', )
- class Break(Node):
- __slots__ = ('coord', '__weakref__')
- def __init__(self, coord=None):
- self.coord = coord
- def children(self):
- return ()
- def __iter__(self):
- return
- yield
- attr_names = ()
- class Case(Node):
- __slots__ = ('expr', 'stmts', 'coord', '__weakref__')
- def __init__(self, expr, stmts, coord=None):
- self.expr = expr
- self.stmts = stmts
- self.coord = coord
- def children(self):
- nodelist = []
- if self.expr is not None: nodelist.append(("expr", self.expr))
- for i, child in enumerate(self.stmts or []):
- nodelist.append(("stmts[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- if self.expr is not None:
- yield self.expr
- for child in (self.stmts or []):
- yield child
- attr_names = ()
- class Cast(Node):
- __slots__ = ('to_type', 'expr', 'coord', '__weakref__')
- def __init__(self, to_type, expr, coord=None):
- self.to_type = to_type
- self.expr = expr
- self.coord = coord
- def children(self):
- nodelist = []
- if self.to_type is not None: nodelist.append(("to_type", self.to_type))
- if self.expr is not None: nodelist.append(("expr", self.expr))
- return tuple(nodelist)
- def __iter__(self):
- if self.to_type is not None:
- yield self.to_type
- if self.expr is not None:
- yield self.expr
- attr_names = ()
- class Compound(Node):
- __slots__ = ('block_items', 'coord', '__weakref__')
- def __init__(self, block_items, coord=None):
- self.block_items = block_items
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.block_items or []):
- nodelist.append(("block_items[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.block_items or []):
- yield child
- attr_names = ()
- class CompoundLiteral(Node):
- __slots__ = ('type', 'init', 'coord', '__weakref__')
- def __init__(self, type, init, coord=None):
- self.type = type
- self.init = init
- self.coord = coord
- def children(self):
- nodelist = []
- if self.type is not None: nodelist.append(("type", self.type))
- if self.init is not None: nodelist.append(("init", self.init))
- return tuple(nodelist)
- def __iter__(self):
- if self.type is not None:
- yield self.type
- if self.init is not None:
- yield self.init
- attr_names = ()
- class Constant(Node):
- __slots__ = ('type', 'value', 'coord', '__weakref__')
- def __init__(self, type, value, coord=None):
- self.type = type
- self.value = value
- self.coord = coord
- def children(self):
- nodelist = []
- return tuple(nodelist)
- def __iter__(self):
- return
- yield
- attr_names = ('type', 'value', )
- class Continue(Node):
- __slots__ = ('coord', '__weakref__')
- def __init__(self, coord=None):
- self.coord = coord
- def children(self):
- return ()
- def __iter__(self):
- return
- yield
- attr_names = ()
- class Decl(Node):
- __slots__ = ('name', 'quals', 'align', 'storage', 'funcspec', 'type', 'init', 'bitsize', 'coord', '__weakref__')
- def __init__(self, name, quals, align, storage, funcspec, type, init, bitsize, coord=None):
- self.name = name
- self.quals = quals
- self.align = align
- self.storage = storage
- self.funcspec = funcspec
- self.type = type
- self.init = init
- self.bitsize = bitsize
- self.coord = coord
- def children(self):
- nodelist = []
- if self.type is not None: nodelist.append(("type", self.type))
- if self.init is not None: nodelist.append(("init", self.init))
- if self.bitsize is not None: nodelist.append(("bitsize", self.bitsize))
- return tuple(nodelist)
- def __iter__(self):
- if self.type is not None:
- yield self.type
- if self.init is not None:
- yield self.init
- if self.bitsize is not None:
- yield self.bitsize
- attr_names = ('name', 'quals', 'align', 'storage', 'funcspec', )
- class DeclList(Node):
- __slots__ = ('decls', 'coord', '__weakref__')
- def __init__(self, decls, coord=None):
- self.decls = decls
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.decls or []):
- nodelist.append(("decls[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.decls or []):
- yield child
- attr_names = ()
- class Default(Node):
- __slots__ = ('stmts', 'coord', '__weakref__')
- def __init__(self, stmts, coord=None):
- self.stmts = stmts
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.stmts or []):
- nodelist.append(("stmts[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.stmts or []):
- yield child
- attr_names = ()
- class DoWhile(Node):
- __slots__ = ('cond', 'stmt', 'coord', '__weakref__')
- def __init__(self, cond, stmt, coord=None):
- self.cond = cond
- self.stmt = stmt
- self.coord = coord
- def children(self):
- nodelist = []
- if self.cond is not None: nodelist.append(("cond", self.cond))
- if self.stmt is not None: nodelist.append(("stmt", self.stmt))
- return tuple(nodelist)
- def __iter__(self):
- if self.cond is not None:
- yield self.cond
- if self.stmt is not None:
- yield self.stmt
- attr_names = ()
- class EllipsisParam(Node):
- __slots__ = ('coord', '__weakref__')
- def __init__(self, coord=None):
- self.coord = coord
- def children(self):
- return ()
- def __iter__(self):
- return
- yield
- attr_names = ()
- class EmptyStatement(Node):
- __slots__ = ('coord', '__weakref__')
- def __init__(self, coord=None):
- self.coord = coord
- def children(self):
- return ()
- def __iter__(self):
- return
- yield
- attr_names = ()
- class Enum(Node):
- __slots__ = ('name', 'values', 'coord', '__weakref__')
- def __init__(self, name, values, coord=None):
- self.name = name
- self.values = values
- self.coord = coord
- def children(self):
- nodelist = []
- if self.values is not None: nodelist.append(("values", self.values))
- return tuple(nodelist)
- def __iter__(self):
- if self.values is not None:
- yield self.values
- attr_names = ('name', )
- class Enumerator(Node):
- __slots__ = ('name', 'value', 'coord', '__weakref__')
- def __init__(self, name, value, coord=None):
- self.name = name
- self.value = value
- self.coord = coord
- def children(self):
- nodelist = []
- if self.value is not None: nodelist.append(("value", self.value))
- return tuple(nodelist)
- def __iter__(self):
- if self.value is not None:
- yield self.value
- attr_names = ('name', )
- class EnumeratorList(Node):
- __slots__ = ('enumerators', 'coord', '__weakref__')
- def __init__(self, enumerators, coord=None):
- self.enumerators = enumerators
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.enumerators or []):
- nodelist.append(("enumerators[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.enumerators or []):
- yield child
- attr_names = ()
- class ExprList(Node):
- __slots__ = ('exprs', 'coord', '__weakref__')
- def __init__(self, exprs, coord=None):
- self.exprs = exprs
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.exprs or []):
- nodelist.append(("exprs[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.exprs or []):
- yield child
- attr_names = ()
- class FileAST(Node):
- __slots__ = ('ext', 'coord', '__weakref__')
- def __init__(self, ext, coord=None):
- self.ext = ext
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.ext or []):
- nodelist.append(("ext[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.ext or []):
- yield child
- attr_names = ()
- class For(Node):
- __slots__ = ('init', 'cond', 'next', 'stmt', 'coord', '__weakref__')
- def __init__(self, init, cond, next, stmt, coord=None):
- self.init = init
- self.cond = cond
- self.next = next
- self.stmt = stmt
- self.coord = coord
- def children(self):
- nodelist = []
- if self.init is not None: nodelist.append(("init", self.init))
- if self.cond is not None: nodelist.append(("cond", self.cond))
- if self.next is not None: nodelist.append(("next", self.next))
- if self.stmt is not None: nodelist.append(("stmt", self.stmt))
- return tuple(nodelist)
- def __iter__(self):
- if self.init is not None:
- yield self.init
- if self.cond is not None:
- yield self.cond
- if self.next is not None:
- yield self.next
- if self.stmt is not None:
- yield self.stmt
- attr_names = ()
- class FuncCall(Node):
- __slots__ = ('name', 'args', 'coord', '__weakref__')
- def __init__(self, name, args, coord=None):
- self.name = name
- self.args = args
- self.coord = coord
- def children(self):
- nodelist = []
- if self.name is not None: nodelist.append(("name", self.name))
- if self.args is not None: nodelist.append(("args", self.args))
- return tuple(nodelist)
- def __iter__(self):
- if self.name is not None:
- yield self.name
- if self.args is not None:
- yield self.args
- attr_names = ()
- class FuncDecl(Node):
- __slots__ = ('args', 'type', 'coord', '__weakref__')
- def __init__(self, args, type, coord=None):
- self.args = args
- self.type = type
- self.coord = coord
- def children(self):
- nodelist = []
- if self.args is not None: nodelist.append(("args", self.args))
- if self.type is not None: nodelist.append(("type", self.type))
- return tuple(nodelist)
- def __iter__(self):
- if self.args is not None:
- yield self.args
- if self.type is not None:
- yield self.type
- attr_names = ()
- class FuncDef(Node):
- __slots__ = ('decl', 'param_decls', 'body', 'coord', '__weakref__')
- def __init__(self, decl, param_decls, body, coord=None):
- self.decl = decl
- self.param_decls = param_decls
- self.body = body
- self.coord = coord
- def children(self):
- nodelist = []
- if self.decl is not None: nodelist.append(("decl", self.decl))
- if self.body is not None: nodelist.append(("body", self.body))
- for i, child in enumerate(self.param_decls or []):
- nodelist.append(("param_decls[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- if self.decl is not None:
- yield self.decl
- if self.body is not None:
- yield self.body
- for child in (self.param_decls or []):
- yield child
- attr_names = ()
- class Goto(Node):
- __slots__ = ('name', 'coord', '__weakref__')
- def __init__(self, name, coord=None):
- self.name = name
- self.coord = coord
- def children(self):
- nodelist = []
- return tuple(nodelist)
- def __iter__(self):
- return
- yield
- attr_names = ('name', )
- class ID(Node):
- __slots__ = ('name', 'coord', '__weakref__')
- def __init__(self, name, coord=None):
- self.name = name
- self.coord = coord
- def children(self):
- nodelist = []
- return tuple(nodelist)
- def __iter__(self):
- return
- yield
- attr_names = ('name', )
- class IdentifierType(Node):
- __slots__ = ('names', 'coord', '__weakref__')
- def __init__(self, names, coord=None):
- self.names = names
- self.coord = coord
- def children(self):
- nodelist = []
- return tuple(nodelist)
- def __iter__(self):
- return
- yield
- attr_names = ('names', )
- class If(Node):
- __slots__ = ('cond', 'iftrue', 'iffalse', 'coord', '__weakref__')
- def __init__(self, cond, iftrue, iffalse, coord=None):
- self.cond = cond
- self.iftrue = iftrue
- self.iffalse = iffalse
- self.coord = coord
- def children(self):
- nodelist = []
- if self.cond is not None: nodelist.append(("cond", self.cond))
- if self.iftrue is not None: nodelist.append(("iftrue", self.iftrue))
- if self.iffalse is not None: nodelist.append(("iffalse", self.iffalse))
- return tuple(nodelist)
- def __iter__(self):
- if self.cond is not None:
- yield self.cond
- if self.iftrue is not None:
- yield self.iftrue
- if self.iffalse is not None:
- yield self.iffalse
- attr_names = ()
- class InitList(Node):
- __slots__ = ('exprs', 'coord', '__weakref__')
- def __init__(self, exprs, coord=None):
- self.exprs = exprs
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.exprs or []):
- nodelist.append(("exprs[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.exprs or []):
- yield child
- attr_names = ()
- class Label(Node):
- __slots__ = ('name', 'stmt', 'coord', '__weakref__')
- def __init__(self, name, stmt, coord=None):
- self.name = name
- self.stmt = stmt
- self.coord = coord
- def children(self):
- nodelist = []
- if self.stmt is not None: nodelist.append(("stmt", self.stmt))
- return tuple(nodelist)
- def __iter__(self):
- if self.stmt is not None:
- yield self.stmt
- attr_names = ('name', )
- class NamedInitializer(Node):
- __slots__ = ('name', 'expr', 'coord', '__weakref__')
- def __init__(self, name, expr, coord=None):
- self.name = name
- self.expr = expr
- self.coord = coord
- def children(self):
- nodelist = []
- if self.expr is not None: nodelist.append(("expr", self.expr))
- for i, child in enumerate(self.name or []):
- nodelist.append(("name[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- if self.expr is not None:
- yield self.expr
- for child in (self.name or []):
- yield child
- attr_names = ()
- class ParamList(Node):
- __slots__ = ('params', 'coord', '__weakref__')
- def __init__(self, params, coord=None):
- self.params = params
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.params or []):
- nodelist.append(("params[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.params or []):
- yield child
- attr_names = ()
- class PtrDecl(Node):
- __slots__ = ('quals', 'type', 'coord', '__weakref__')
- def __init__(self, quals, type, coord=None):
- self.quals = quals
- self.type = type
- self.coord = coord
- def children(self):
- nodelist = []
- if self.type is not None: nodelist.append(("type", self.type))
- return tuple(nodelist)
- def __iter__(self):
- if self.type is not None:
- yield self.type
- attr_names = ('quals', )
- class Return(Node):
- __slots__ = ('expr', 'coord', '__weakref__')
- def __init__(self, expr, coord=None):
- self.expr = expr
- self.coord = coord
- def children(self):
- nodelist = []
- if self.expr is not None: nodelist.append(("expr", self.expr))
- return tuple(nodelist)
- def __iter__(self):
- if self.expr is not None:
- yield self.expr
- attr_names = ()
- class StaticAssert(Node):
- __slots__ = ('cond', 'message', 'coord', '__weakref__')
- def __init__(self, cond, message, coord=None):
- self.cond = cond
- self.message = message
- self.coord = coord
- def children(self):
- nodelist = []
- if self.cond is not None: nodelist.append(("cond", self.cond))
- if self.message is not None: nodelist.append(("message", self.message))
- return tuple(nodelist)
- def __iter__(self):
- if self.cond is not None:
- yield self.cond
- if self.message is not None:
- yield self.message
- attr_names = ()
- class Struct(Node):
- __slots__ = ('name', 'decls', 'coord', '__weakref__')
- def __init__(self, name, decls, coord=None):
- self.name = name
- self.decls = decls
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.decls or []):
- nodelist.append(("decls[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.decls or []):
- yield child
- attr_names = ('name', )
- class StructRef(Node):
- __slots__ = ('name', 'type', 'field', 'coord', '__weakref__')
- def __init__(self, name, type, field, coord=None):
- self.name = name
- self.type = type
- self.field = field
- self.coord = coord
- def children(self):
- nodelist = []
- if self.name is not None: nodelist.append(("name", self.name))
- if self.field is not None: nodelist.append(("field", self.field))
- return tuple(nodelist)
- def __iter__(self):
- if self.name is not None:
- yield self.name
- if self.field is not None:
- yield self.field
- attr_names = ('type', )
- class Switch(Node):
- __slots__ = ('cond', 'stmt', 'coord', '__weakref__')
- def __init__(self, cond, stmt, coord=None):
- self.cond = cond
- self.stmt = stmt
- self.coord = coord
- def children(self):
- nodelist = []
- if self.cond is not None: nodelist.append(("cond", self.cond))
- if self.stmt is not None: nodelist.append(("stmt", self.stmt))
- return tuple(nodelist)
- def __iter__(self):
- if self.cond is not None:
- yield self.cond
- if self.stmt is not None:
- yield self.stmt
- attr_names = ()
- class TernaryOp(Node):
- __slots__ = ('cond', 'iftrue', 'iffalse', 'coord', '__weakref__')
- def __init__(self, cond, iftrue, iffalse, coord=None):
- self.cond = cond
- self.iftrue = iftrue
- self.iffalse = iffalse
- self.coord = coord
- def children(self):
- nodelist = []
- if self.cond is not None: nodelist.append(("cond", self.cond))
- if self.iftrue is not None: nodelist.append(("iftrue", self.iftrue))
- if self.iffalse is not None: nodelist.append(("iffalse", self.iffalse))
- return tuple(nodelist)
- def __iter__(self):
- if self.cond is not None:
- yield self.cond
- if self.iftrue is not None:
- yield self.iftrue
- if self.iffalse is not None:
- yield self.iffalse
- attr_names = ()
- class TypeDecl(Node):
- __slots__ = ('declname', 'quals', 'align', 'type', 'coord', '__weakref__')
- def __init__(self, declname, quals, align, type, coord=None):
- self.declname = declname
- self.quals = quals
- self.align = align
- self.type = type
- self.coord = coord
- def children(self):
- nodelist = []
- if self.type is not None: nodelist.append(("type", self.type))
- return tuple(nodelist)
- def __iter__(self):
- if self.type is not None:
- yield self.type
- attr_names = ('declname', 'quals', 'align', )
- class Typedef(Node):
- __slots__ = ('name', 'quals', 'storage', 'type', 'coord', '__weakref__')
- def __init__(self, name, quals, storage, type, coord=None):
- self.name = name
- self.quals = quals
- self.storage = storage
- self.type = type
- self.coord = coord
- def children(self):
- nodelist = []
- if self.type is not None: nodelist.append(("type", self.type))
- return tuple(nodelist)
- def __iter__(self):
- if self.type is not None:
- yield self.type
- attr_names = ('name', 'quals', 'storage', )
- class Typename(Node):
- __slots__ = ('name', 'quals', 'align', 'type', 'coord', '__weakref__')
- def __init__(self, name, quals, align, type, coord=None):
- self.name = name
- self.quals = quals
- self.align = align
- self.type = type
- self.coord = coord
- def children(self):
- nodelist = []
- if self.type is not None: nodelist.append(("type", self.type))
- return tuple(nodelist)
- def __iter__(self):
- if self.type is not None:
- yield self.type
- attr_names = ('name', 'quals', 'align', )
- class UnaryOp(Node):
- __slots__ = ('op', 'expr', 'coord', '__weakref__')
- def __init__(self, op, expr, coord=None):
- self.op = op
- self.expr = expr
- self.coord = coord
- def children(self):
- nodelist = []
- if self.expr is not None: nodelist.append(("expr", self.expr))
- return tuple(nodelist)
- def __iter__(self):
- if self.expr is not None:
- yield self.expr
- attr_names = ('op', )
- class Union(Node):
- __slots__ = ('name', 'decls', 'coord', '__weakref__')
- def __init__(self, name, decls, coord=None):
- self.name = name
- self.decls = decls
- self.coord = coord
- def children(self):
- nodelist = []
- for i, child in enumerate(self.decls or []):
- nodelist.append(("decls[%d]" % i, child))
- return tuple(nodelist)
- def __iter__(self):
- for child in (self.decls or []):
- yield child
- attr_names = ('name', )
- class While(Node):
- __slots__ = ('cond', 'stmt', 'coord', '__weakref__')
- def __init__(self, cond, stmt, coord=None):
- self.cond = cond
- self.stmt = stmt
- self.coord = coord
- def children(self):
- nodelist = []
- if self.cond is not None: nodelist.append(("cond", self.cond))
- if self.stmt is not None: nodelist.append(("stmt", self.stmt))
- return tuple(nodelist)
- def __iter__(self):
- if self.cond is not None:
- yield self.cond
- if self.stmt is not None:
- yield self.stmt
- attr_names = ()
- class Pragma(Node):
- __slots__ = ('string', 'coord', '__weakref__')
- def __init__(self, string, coord=None):
- self.string = string
- self.coord = coord
- def children(self):
- nodelist = []
- return tuple(nodelist)
- def __iter__(self):
- return
- yield
- attr_names = ('string', )
|