summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornoelallen@google.com <noelallen@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-07-19 16:32:59 +0000
committernoelallen@google.com <noelallen@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-07-19 16:32:59 +0000
commit74f4b46ab44016f9e7ad56cde5916ffbc45723d3 (patch)
tree65dedb42b7d889885c62841a656a44681a81ceea
parent075fb93ffe8574b1370de27b4c29c2a054facfb9 (diff)
downloadchromium_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
-rw-r--r--ppapi/generators/idl_visitor.py81
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
+
+