diff options
author | noelallen@google.com <noelallen@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-07-19 16:32:59 +0000 |
---|---|---|
committer | noelallen@google.com <noelallen@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-07-19 16:32:59 +0000 |
commit | 74f4b46ab44016f9e7ad56cde5916ffbc45723d3 (patch) | |
tree | 65dedb42b7d889885c62841a656a44681a81ceea /ppapi/generators/idl_visitor.py | |
parent | 075fb93ffe8574b1370de27b4c29c2a054facfb9 (diff) | |
download | chromium_src-74f4b46ab44016f9e7ad56cde5916ffbc45723d3.zip chromium_src-74f4b46ab44016f9e7ad56cde5916ffbc45723d3.tar.gz chromium_src-74f4b46ab44016f9e7ad56cde5916ffbc45723d3.tar.bz2 |
Add missing IDL Visistor class
This class provides a simple mechanism for recursively traversing the AST
for both simple and version aware traversal.
TBR= sehr@google.com
BUG= http://code.google.com/p/chromium/issues/detail?id=87684
TEST= python idl_c_header.py
Review URL: http://codereview.chromium.org/7448001
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@93036 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi/generators/idl_visitor.py')
-rw-r--r-- | ppapi/generators/idl_visitor.py | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/ppapi/generators/idl_visitor.py b/ppapi/generators/idl_visitor.py new file mode 100644 index 0000000..40a8579 --- /dev/null +++ b/ppapi/generators/idl_visitor.py @@ -0,0 +1,81 @@ +#!/usr/bin/python +# +# Copyright (c) 2011 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +""" Visitor Object for traversing AST """ + +# +# IDLVisitor +# +# The IDLVisitor class will traverse an AST truncating portions of the tree +# that fail due to class or version filters. For each node, after the filter +# passes, the visitor will call the 'Arive' member passing in the node and +# and data passing in from the parent call. It will then Visit the children. +# When done processing children, the visitor will call the 'Depart' member +# before returning +# + +class IDLVisitor(object): + def __init__(self): + self.depth = 0 + + # Return TRUE if the node should be visited + def VisitFilter(self, node, data): + return True + + # Return TRUE if data should be added to the childdata list + def AgrigateFilter(self, data): + return data is not None + + def Visit(self, node, data): + self.depth += 1 + if not self.VisitFilter(node, data): return None + + childdata = [] + newdata = self.Arrive(node, data) + for child in node.GetChildren(): + ret = self.Visit(child, newdata) + if self.AgrigateFilter(ret): + childdata.append(ret) + out = self.Depart(node, newdata, childdata) + + self.depth -= 1 + return out + + def Arrive(self, node, data): + return data + + def Depart(self, node, data, childdata): + return data + + +# +# IDLVersionVisitor +# +# The IDLVersionVisitor will only visit nodes with intervals that include the +# version. It will also optionally filter based on a class list +# +class IDLVersionVisitor(object): + def __init__(self, version, classList): + self.version = version + self.classes = classes + + def Filter(self, node, data): + if self.classList and node.cls not in self.classList: return False + if not node.IsVersion(self.version): return False + return True + +class IDLRangeVisitor(object): + def __init__(self, vmin, vmax, classList): + self.vmin = vmin + self.vmax = vmax + self.classList = classList + + def Filter(self, node, data): + if self.classList and node.cls not in self.classList: return False + if not node.IsVersion(self.version): return False + return True + + |