Chromium Code Reviews| Index: third_party/WebKit/Source/build/scripts/make_css_property_api.py |
| diff --git a/third_party/WebKit/Source/build/scripts/make_css_property_api.py b/third_party/WebKit/Source/build/scripts/make_css_property_api.py |
| new file mode 100755 |
| index 0000000000000000000000000000000000000000..91a8768eac8b74ae7faa5d6afa31a34f88fd9a11 |
| --- /dev/null |
| +++ b/third_party/WebKit/Source/build/scripts/make_css_property_api.py |
| @@ -0,0 +1,40 @@ |
| +#!/usr/bin/env python |
| +# Copyright 2016 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. |
| + |
| +import sys |
| + |
| +import in_generator |
| +import template_expander |
| +import make_style_builder |
| + |
| + |
| +class CSSPropertyAPIWriter(make_style_builder.StyleBuilderWriter): |
| + def __init__(self, in_file_path): |
| + super(CSSPropertyAPIWriter, self).__init__(in_file_path) |
| + |
| + self._outputs = {"CSSPropertyDescriptor.cpp": self.generate_property_descriptor_h} |
|
sashab
2016/12/08 23:56:35
Move this line and move newline to after it to be
aazzam
2016/12/09 00:44:39
done
|
| + self._property_groups = [] |
|
sashab
2016/12/08 23:56:35
Add comments explaining what these variables are f
aazzam
2016/12/09 00:44:39
done
|
| + self._properties_by_index = [] |
| + for property in self._properties.values(): |
| + if property['generated_api_class'] is not None: |
| + if property['generated_api_class'] is True: |
| + self._property_groups.append(property['upper_camel_name']) |
|
sashab
2016/12/08 23:56:35
It's not clear that the other branch is not False.
aazzam
2016/12/09 00:44:39
done
|
| + else: |
|
sashab
2016/12/08 23:56:35
I would change to elif property['..'] is not False
aazzam
2016/12/09 00:44:39
done :)
|
| + self._property_groups.append(property['generated_api_class']) |
| + self._properties_by_index.append(property) |
| + |
| + self._property_groups = list(set(self._property_groups)) |
|
sashab
2016/12/08 23:56:35
Add comment explaining this is to remove duplicate
aazzam
2016/12/09 00:44:39
done
|
| + for i, property in enumerate(self._properties_by_index): |
|
sashab
2016/12/08 23:56:35
Add comment explaining what this loop is for
aazzam
2016/12/09 00:44:39
done
|
| + property['api_array_index'] = i + 1 |
| + |
| + @template_expander.use_jinja('CSSPropertyDescriptor.cpp.tmpl') |
| + def generate_property_descriptor_h(self): |
| + return { |
| + 'propertyGroups': sorted(self._property_groups), |
|
sashab
2016/12/08 23:56:35
Check other files - I think they use underscore_na
aazzam
2016/12/09 00:44:39
done
|
| + 'properties': self._properties_by_index, |
| + } |
| + |
| +if __name__ == '__main__': |
| + in_generator.Maker(CSSPropertyAPIWriter).main(sys.argv) |