Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(74)

Side by Side Diff: ppapi/generators/idl_namespace.py

Issue 11235016: Change the way we generate versions (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 8 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « ppapi/generators/idl_gen_wrapper.py ('k') | ppapi/generators/idl_node.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/usr/bin/env python 1 #!/usr/bin/env python
2 # Copyright (c) 2012 The Chromium Authors. All rights reserved. 2 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be 3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file. 4 # found in the LICENSE file.
5 5
6 """ 6 """
7 IDLNamespace for PPAPI 7 IDLNamespace for PPAPI
8 8
9 This file defines the behavior of the AST namespace which allows for resolving 9 This file defines the behavior of the AST namespace which allows for resolving
10 a symbol as one or more AST nodes given a release or range of releases. 10 a symbol as one or more AST nodes given a release or range of releases.
(...skipping 10 matching lines...) Expand all
21 21
22 22
23 # 23 #
24 # IDLNamespace 24 # IDLNamespace
25 # 25 #
26 # IDLNamespace provides a mapping between a symbol name and an IDLReleaseList 26 # IDLNamespace provides a mapping between a symbol name and an IDLReleaseList
27 # which contains IDLRelease objects. It provides an interface for fetching 27 # which contains IDLRelease objects. It provides an interface for fetching
28 # one or more IDLNodes based on a release or range of releases. 28 # one or more IDLNodes based on a release or range of releases.
29 # 29 #
30 class IDLNamespace(object): 30 class IDLNamespace(object):
31 def __init__(self, parent): 31 def __init__(self, parent, name):
32 self.namespace = {} 32 self._name_to_releases = {}
33 self.parent = parent 33 self._parent = parent
34 self._name = name
34 35
35 def Dump(self): 36 def Dump(self):
36 for name in self.namespace: 37 for name in self._name_to_releases:
37 InfoOut.Log('NAME=%s' % name) 38 InfoOut.Log('NAME=%s' % name)
38 for cver in self.namespace[name].nodes: 39 for cver in self._name_to_releases[name].GetReleases():
39 InfoOut.Log(' %s' % cver) 40 InfoOut.Log(' %s' % cver)
40 InfoOut.Log('') 41 InfoOut.Log('')
41 42
42 def FindRelease(self, name, release): 43 def FindRelease(self, name, release):
43 verlist = self.namespace.get(name, None) 44 verlist = self._name_to_releases.get(name, None)
44 if verlist == None: 45 if verlist == None:
45 if self.parent: 46 if self._parent:
46 return self.parent.FindRelease(name, release) 47 return self._parent.FindRelease(name, release)
47 else: 48 else:
48 return None 49 return None
49 return verlist.FindRelease(release) 50 return verlist.FindRelease(release)
50 51
51 def FindRange(self, name, rmin, rmax): 52 def FindRange(self, name, rmin, rmax):
52 verlist = self.namespace.get(name, None) 53 verlist = self._name_to_releases.get(name, None)
53 if verlist == None: 54 if verlist == None:
54 if self.parent: 55 if self._parent:
55 return self.parent.FindRange(name, rmin, rmax) 56 return self._parent.FindRange(name, rmin, rmax)
56 else: 57 else:
57 return [] 58 return []
58 return verlist.FindRange(rmin, rmax) 59 return verlist.FindRange(rmin, rmax)
59 60
60 def FindList(self, name): 61 def FindList(self, name):
61 verlist = self.namespace.get(name, None) 62 verlist = self._name_to_releases.get(name, None)
62 if verlist == None: 63 if verlist == None:
63 if self.parent: 64 if self._parent:
64 return self.parent.FindList(name) 65 return self._parent.FindList(name)
65 return verlist 66 return verlist
66 67
67 def AddNode(self, node): 68 def AddNode(self, node):
68 name = node.GetName() 69 name = node.GetName()
69 verlist = self.namespace.setdefault(name,IDLReleaseList()) 70 verlist = self._name_to_releases.setdefault(name,IDLReleaseList())
70 if GetOption('namespace_debug'): 71 if GetOption('namespace_debug'):
71 print "Adding to namespace: %s" % node 72 print "Adding to namespace: %s" % node
72 return verlist.AddNode(node) 73 return verlist.AddNode(node)
73 74
74 75
75 76
76 # 77 #
77 # Testing Code 78 # Testing Code
78 # 79 #
79 80
(...skipping 160 matching lines...) Expand 10 before | Expand all | Expand 10 after
240 241
241 if errors: 242 if errors:
242 print 'Test failed with %d errors.' % errors 243 print 'Test failed with %d errors.' % errors
243 else: 244 else:
244 print 'Passed.' 245 print 'Passed.'
245 return errors 246 return errors
246 247
247 248
248 if __name__ == '__main__': 249 if __name__ == '__main__':
249 sys.exit(Main(sys.argv[1:])) 250 sys.exit(Main(sys.argv[1:]))
251
OLDNEW
« no previous file with comments | « ppapi/generators/idl_gen_wrapper.py ('k') | ppapi/generators/idl_node.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698