Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Delta Between Two Patch Sets: filters/parse_interface.py

Issue 5636796054503424: Issue 1170 - [adblockplus.org Anwiki to CMS migration] Migrate content (Closed)
Left Patch Set: Created Sept. 17, 2014, 8:33 a.m.
Right Patch Set: Remove includes/common.tmpl which is no longer required. Created March 7, 2015, 7:01 p.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
Left: Side by side diff | Download
Right: Side by side diff | Download
« no previous file with change/comment | « filters/get_subscriptions.py ('k') | filters/subscription_sort.py » ('j') | no next file with change/comment »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
LEFTRIGHT
1 import re 1 # This file is part of the Adblock Plus website,
2 # Copyright (C) 2006-2015 Eyeo GmbH
3 #
4 # Adblock Plus is free software: you can redistribute it and/or modify
5 # it under the terms of the GNU General Public License version 3 as
6 # published by the Free Software Foundation.
7 #
8 # Adblock Plus is distributed in the hope that it will be useful,
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # GNU General Public License for more details.
12 #
13 # You should have received a copy of the GNU General Public License
14 # along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
2 15
3 def parse_interface(interfaces): 16 import re, warnings
Wladimir Palant 2014/09/18 20:33:04 Nit: I think what it gets as parameter isn't inter
kzar 2014/09/19 11:28:06 Done.
17
18 TYPE_REGEXP = r"(?:arrayof\s+)?\w+"
19
20 def parse_interface(interface_items):
4 parsed = [] 21 parsed = []
5 for property_key, property in interfaces.iteritems(): 22 for key, value in interface_items.iteritems():
Wladimir Palant 2014/09/18 20:33:04 Nit: I think that simple key, value as names would
kzar 2014/09/19 11:28:06 Done.
6 if property_key.find("(") > -1: 23 if "(" in key:
Wladimir Palant 2014/09/18 20:33:04 Nit: this can be written as simply |"(" in propert
kzar 2014/09/19 11:28:06 Done.
7 match = re.match("^(arrayof\W+\w+|\w+)\W+(\w+)[\W\(]+([^\)]*)[\W\)]+$", pr operty_key) 24 # Item is a method
Wladimir Palant 2014/09/18 20:33:04 You generally want to use r"foo" rather than "foo"
kzar 2014/09/19 11:28:06 Done.
25 match = re.match(r"^\s*(%s)\s+(\S+)\s*\(\s*([^\)]*)\s*\)\s*$" % TYPE_REGEX P, key)
8 if not match: 26 if not match:
27 warnings.warn("Skipped malformed method: '%s'" % key)
9 continue 28 continue
Wladimir Palant 2014/09/18 20:33:04 Just dropping the line without any message is a gr
kzar 2014/09/19 11:28:06 Done.
10 return_type, property_name, argument_string = match.groups() 29 return_type, property_name, argument_string = match.groups()
11 arguments = [] 30 arguments = []
12 if "version" in property:
13 property_version = property["version"]
14 else:
15 property_version = ""
Wladimir Palant 2014/09/18 20:33:04 Nit: Use None instead of empty string here?
kzar 2014/09/19 11:28:06 I think empty strings are more useful for template
16 if argument_string: 31 if argument_string:
17 for i, argument in enumerate(argument_string.split(",")): 32 for argument in argument_string.split(","):
Wladimir Palant 2014/09/18 20:33:04 Nit: Why use enumerate() here? Doesn't seem to be
kzar 2014/09/19 11:28:06 Done.
18 parts = argument.split(" ") 33 if argument.strip():
Wladimir Palant 2014/09/18 20:33:04 How about: match = re.match(r"^\s*(%s)\s+(\w+)\
kzar 2014/09/19 11:28:06 Done.
19 argument_name = parts[-1] 34 match = re.match(r"^\s*(%s)\s+(\S+)\s*$" % TYPE_REGEXP, argument)
20 argument_type = " ".join(parts[:-1]) 35 if not match:
21 arguments.append({ 36 warnings.warn("Skipped malformed argument: '%s'" % argument)
22 "name": argument_name, 37 continue
23 "type": argument_type 38 argument_type, argument_name = match.groups()
24 }) 39 arguments.append({
25 parsed.append({ 40 "name": argument_name,
41 "type": argument_type
42 })
43 value.update({
26 "type": "method", 44 "type": "method",
27 "name": property_name, 45 "name": property_name,
28 "version": property_version,
29 "return_type": return_type, 46 "return_type": return_type,
30 "arguments": arguments, 47 "arguments": arguments
31 }) 48 })
49 parsed.append(value)
32 else: 50 else:
33 parts = property_key.split() 51 # Item is a property
Wladimir Palant 2014/09/18 20:33:04 I'd prefer: match = re.match(r"^\s*(readonly\s+
kzar 2014/09/19 11:28:06 Done.
34 property = { } 52 match = re.match(r"^\s*(readonly\s+)?(%s)\s+(\S+)\s*$" % TYPE_REGEXP, key)
Wladimir Palant 2014/09/18 20:33:04 Nit: no space between the brackets.
kzar 2014/09/19 11:28:06 Done.
35 property["type"], property["name"] = parts[-2:] 53 if not match:
36 if len(parts) == 3: 54 warnings.warn("Skipped malformed property: '%s'" % key)
37 property["modifier"] = parts[0] 55 continue
Wladimir Palant 2014/09/18 20:33:04 I think using temporary variables like you've done
kzar 2014/09/19 11:28:06 Done.
38 parsed.append(property) 56 property_modifier, property_type, property_name = match.groups()
39 parsed = sorted(parsed, key=lambda x: x["name"]) 57 value.update({
Wladimir Palant 2014/09/18 20:33:04 Please use parse.sort() that will sort the list in
kzar 2014/09/19 11:28:06 Done.
58 "type": property_type,
59 "name": property_name,
60 "modifier": property_modifier or ""
61 })
62 parsed.append(value)
63 parsed.sort(key=lambda x: x["name"])
40 return parsed 64 return parsed
LEFTRIGHT

Powered by Google App Engine
This is Rietveld