Index: Source/build/scripts/make_css_property_names.py |
diff --git a/Source/build/scripts/make_css_property_names.py b/Source/build/scripts/make_css_property_names.py |
index 3211fc88a7df63178f1ad3d864d665c4102f647e..30e86677b4376293cf04e47e4e710a8a5a61c5b9 100755 |
--- a/Source/build/scripts/make_css_property_names.py |
+++ b/Source/build/scripts/make_css_property_names.py |
@@ -1,9 +1,11 @@ |
#!/usr/bin/env python |
+import os.path |
+import re |
import subprocess |
import sys |
-import css_properties |
+from in_file import InFile |
import in_generator |
import license |
@@ -176,47 +178,71 @@ bool isInternalProperty(CSSPropertyID id) |
""" |
-class CSSPropertyNamesWriter(css_properties.CSSProperties): |
+class CSSPropertiesWriter(in_generator.Writer): |
class_name = "CSSPropertyNames" |
+ defaults = { |
+ 'alias_for': None, |
+ 'is_internal': False, |
+ } |
- def __init__(self, in_file_path): |
- super(CSSPropertyNamesWriter, self).__init__(in_file_path) |
+ def __init__(self, file_paths): |
+ in_generator.Writer.__init__(self, file_paths) |
self._outputs = {(self.class_name + ".h"): self.generate_header, |
(self.class_name + ".cpp"): self.generate_implementation, |
} |
+ self._aliases = filter(lambda property: property['alias_for'], self.in_file.name_dictionaries) |
+ for offset, property in enumerate(self._aliases): |
+ # Aliases use the enum_name that they are an alias for. |
+ property['enum_name'] = self._enum_name_from_property_name(property['alias_for']) |
+ # Aliases do not get an enum_value. |
+ |
+ self._properties = filter(lambda property: not property['alias_for'], self.in_file.name_dictionaries) |
+ if len(self._properties) > 1024: |
+ print "ERROR : There is more than 1024 CSS Properties, you need to update CSSProperty.h/StylePropertyMetadata m_propertyID accordingly." |
+ exit(1) |
+ self._first_property_id = 1 # We start after CSSPropertyInvalid. |
+ property_id = self._first_property_id |
+ for offset, property in enumerate(self._properties): |
+ property['enum_name'] = self._enum_name_from_property_name(property['name']) |
+ property['enum_value'] = self._first_property_id + offset |
+ if property['name'].startswith('-internal-'): |
+ property['is_internal'] = True |
+ |
+ def _enum_name_from_property_name(self, property_name): |
+ return "CSSProperty" + re.sub(r'(^[^-])|-(.)', lambda match: (match.group(1) or match.group(2)).upper(), property_name) |
+ |
def _enum_declaration(self, property): |
- return " %(property_id)s = %(enum_value)s," % property |
+ return " %(enum_name)s = %(enum_value)s," % property |
def generate_header(self): |
return HEADER_TEMPLATE % { |
'license': license.license_for_generated_cpp(), |
'class_name': self.class_name, |
- 'property_enums': "\n".join(map(self._enum_declaration, self._properties_list)), |
- 'first_property_id': self._first_enum_value, |
+ 'property_enums': "\n".join(map(self._enum_declaration, self._properties)), |
+ 'first_property_id': self._first_property_id, |
'properties_count': len(self._properties), |
- 'last_property_id': self._first_enum_value + len(self._properties) - 1, |
- 'max_name_length': max(map(len, self._properties)), |
+ 'last_property_id': self._first_property_id + len(self._properties) - 1, |
+ 'max_name_length': reduce(max, map(len, map(lambda property: property['name'], self._properties))), |
} |
+ def _case_properties(self, property): |
+ return "case %(enum_name)s:" % property |
+ |
def generate_implementation(self): |
property_offsets = [] |
current_offset = 0 |
- for property in self._properties_list: |
+ for property in self._properties: |
property_offsets.append(current_offset) |
current_offset += len(property["name"]) + 1 |
- css_name_and_enum_pairs = [(property['name'], property_id) for property_id, property in self._properties.items()] |
- for name, aliased_name in self._aliases.items(): |
- css_name_and_enum_pairs.append((name, css_properties.css_name_to_enum(aliased_name))) |
- |
gperf_input = GPERF_TEMPLATE % { |
'license': license.license_for_generated_cpp(), |
'class_name': self.class_name, |
- 'property_name_strings': '\n'.join(map(lambda property: ' "%(name)s\\0"' % property, self._properties_list)), |
+ 'property_name_strings': '\n'.join(map(lambda property: ' "%(name)s\\0"' % property, self._properties)), |
'property_name_offsets': '\n'.join(map(lambda offset: ' %d,' % offset, property_offsets)), |
- 'property_to_enum_map': '\n'.join(map(lambda property: '%s, %s' % property, css_name_and_enum_pairs)), |
- 'internal_properties': '\n'.join("case %s:" % property_id for property_id, property in self._properties.items() if property['is_internal']), |
+ 'property_to_enum_map': '\n'.join(map(lambda property: '%(name)s, %(enum_name)s' % property, self._properties + self._aliases)), |
+ 'internal_properties': '\n'.join(map(self._case_properties, filter(lambda property: property['is_internal'], self._properties))), |
} |
# FIXME: If we could depend on Python 2.7, we would use subprocess.check_output |
gperf_args = [self.gperf_path, '--key-positions=*', '-P', '-n'] |
@@ -227,4 +253,4 @@ class CSSPropertyNamesWriter(css_properties.CSSProperties): |
if __name__ == "__main__": |
- in_generator.Maker(CSSPropertyNamesWriter).main(sys.argv) |
+ in_generator.Maker(CSSPropertiesWriter).main(sys.argv) |