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

Side by Side Diff: bindings/scripts/utilities.py

Issue 581453002: Dartium Roll 38 roll (Closed) Base URL: https://dart.googlecode.com/svn/third_party/WebCore
Patch Set: Sync'd w/ r 182210 Created 6 years, 3 months 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 | « bindings/scripts/interface_dependency_resolver.py ('k') | bindings/scripts/v8_attributes.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 # Copyright 2014 The Chromium Authors. All rights reserved. 1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 """Utility functions (file reading, simple IDL parsing by regexes) for IDL build . 5 """Utility functions (file reading, simple IDL parsing by regexes) for IDL build .
6 6
7 Design doc: http://www.chromium.org/developers/design-documents/idl-build 7 Design doc: http://www.chromium.org/developers/design-documents/idl-build
8 """ 8 """
9 9
10 import os 10 import os
(...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after
112 return ( 112 return (
113 [left for left, right in implements_pairs if right == interface_name], 113 [left for left, right in implements_pairs if right == interface_name],
114 [right for left, right in implements_pairs if left == interface_name]) 114 [right for left, right in implements_pairs if left == interface_name])
115 115
116 116
117 def is_callback_interface_from_idl(file_contents): 117 def is_callback_interface_from_idl(file_contents):
118 match = re.search(r'callback\s+interface\s+\w+\s*{', file_contents) 118 match = re.search(r'callback\s+interface\s+\w+\s*{', file_contents)
119 return bool(match) 119 return bool(match)
120 120
121 121
122 def is_dictionary_from_idl(file_contents):
123 match = re.search(r'dictionary\s+\w+\s*{', file_contents)
124 return bool(match)
125
126
122 def get_parent_interface(file_contents): 127 def get_parent_interface(file_contents):
123 match = re.search(r'interface\s+' 128 match = re.search(r'interface\s+'
124 r'\w+\s*' 129 r'\w+\s*'
125 r':\s*(\w+)\s*' 130 r':\s*(\w+)\s*'
126 r'{', 131 r'{',
127 file_contents) 132 file_contents)
128 return match and match.group(1) 133 return match and match.group(1)
129 134
130 135
131 def get_interface_extended_attributes_from_idl(file_contents): 136 def get_interface_extended_attributes_from_idl(file_contents):
132 # Strip comments 137 # Strip comments
133 # re.compile needed b/c Python 2.6 doesn't support flags in re.sub 138 # re.compile needed b/c Python 2.6 doesn't support flags in re.sub
134 single_line_comment_re = re.compile(r'//.*$', flags=re.MULTILINE) 139 single_line_comment_re = re.compile(r'//.*$', flags=re.MULTILINE)
135 block_comment_re = re.compile(r'/\*.*?\*/', flags=re.MULTILINE | re.DOTALL) 140 block_comment_re = re.compile(r'/\*.*?\*/', flags=re.MULTILINE | re.DOTALL)
136 file_contents = re.sub(single_line_comment_re, '', file_contents) 141 file_contents = re.sub(single_line_comment_re, '', file_contents)
137 file_contents = re.sub(block_comment_re, '', file_contents) 142 file_contents = re.sub(block_comment_re, '', file_contents)
138 143
139 match = re.search(r'\[(.*)\]\s*' 144 match = re.search(r'\[(.*)\]\s*'
140 r'((callback|partial)\s+)?' 145 r'((callback|partial)\s+)?'
141 r'(interface|exception)\s+' 146 r'(interface|exception)\s+'
142 r'\w+\s*' 147 r'\w+\s*'
143 r'(:\s*\w+\s*)?' 148 r'(:\s*\w+\s*)?'
144 r'{', 149 r'{',
145 file_contents, flags=re.DOTALL) 150 file_contents, flags=re.DOTALL)
146 if not match: 151 if not match:
147 return {} 152 return {}
148 153
149 extended_attributes_string = match.group(1) 154 extended_attributes_string = match.group(1)
150 extended_attributes = {} 155 extended_attributes = {}
151 # FIXME: this splitting is WRONG: it fails on ExtendedAttributeArgList like 156 # FIXME: this splitting is WRONG: it fails on extended attributes where list s of
152 # 'NamedConstructor=Foo(a, b)' 157 # multiple values are used, which are seperated by a comma and a space.
153 parts = [extended_attribute.strip() 158 parts = [extended_attribute.strip()
154 for extended_attribute in extended_attributes_string.split(',') 159 for extended_attribute in re.split(',\s+', extended_attributes_stri ng)
155 # Discard empty parts, which may exist due to trailing comma 160 # Discard empty parts, which may exist due to trailing comma
156 if extended_attribute.strip()] 161 if extended_attribute.strip()]
157 for part in parts: 162 for part in parts:
158 name, _, value = map(string.strip, part.partition('=')) 163 name, _, value = map(string.strip, part.partition('='))
159 extended_attributes[name] = value 164 extended_attributes[name] = value
160 return extended_attributes 165 return extended_attributes
161 166
162 167
163 def get_put_forward_interfaces_from_idl(file_contents): 168 def get_put_forward_interfaces_from_idl(file_contents):
164 put_forwards_pattern = (r'\[[^\]]*PutForwards=[^\]]*\]\s+' 169 put_forwards_pattern = (r'\[[^\]]*PutForwards=[^\]]*\]\s+'
165 r'readonly\s+' 170 r'readonly\s+'
166 r'attribute\s+' 171 r'attribute\s+'
167 r'(\w+)') 172 r'(\w+)')
168 return sorted(set(match.group(1) 173 return sorted(set(match.group(1)
169 for match in re.finditer(put_forwards_pattern, 174 for match in re.finditer(put_forwards_pattern,
170 file_contents, 175 file_contents,
171 flags=re.DOTALL))) 176 flags=re.DOTALL)))
OLDNEW
« no previous file with comments | « bindings/scripts/interface_dependency_resolver.py ('k') | bindings/scripts/v8_attributes.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698