Chromium Code Reviews| Index: Source/bindings/scripts/idl_definitions.py |
| diff --git a/Source/bindings/scripts/idl_definitions.py b/Source/bindings/scripts/idl_definitions.py |
| index 50664ba12ef7addd5cb3cbc69484e0629231ba3d..b84e725d97f0a70c80f69b8d996c8db3f882fa8b 100644 |
| --- a/Source/bindings/scripts/idl_definitions.py |
| +++ b/Source/bindings/scripts/idl_definitions.py |
| @@ -48,8 +48,10 @@ IdlDefinitions |
| IdlInterface |
| IdlAttribute < TypedObject |
| IdlConstant < TypedObject |
| + IdlLiteral |
| IdlOperation < TypedObject |
| IdlArgument < TypedObject |
| + IdlStringifier |
| IdlException < IdlInterface |
| (same contents as IdlInterface) |
| @@ -261,6 +263,7 @@ class IdlInterface(object): |
| self.extended_attributes = {} |
| self.operations = [] |
| self.parent = None |
| + self.stringifier = None |
| if not node: # Early exit for IdlException.__init__ |
| return |
| @@ -287,6 +290,9 @@ class IdlInterface(object): |
| self.operations.append(IdlOperation(child)) |
| elif child_class == 'Inherit': |
| self.parent = child.GetName() |
| + elif child_class == 'Stringifier': |
| + self.stringifier = IdlStringifier(child) |
| + self.process_stringifier() |
| else: |
| raise ValueError('Unrecognized node class: %s' % child_class) |
| @@ -302,6 +308,14 @@ class IdlInterface(object): |
| for operation in self.operations: |
| operation.resolve_typedefs(typedefs) |
| + def process_stringifier(self): |
| + """Add the stringifier's attribute or named operation child, if it has |
| + one, as a regular attribute/operation of this interface.""" |
| + if self.stringifier.attribute: |
| + self.attributes.append(self.stringifier.attribute) |
| + elif self.stringifier.operation and self.stringifier.operation.name: |
|
haraken
2014/06/24 08:28:36
Do we need the 'and self.stringifier.operation.nam
Jens Widell
2014/06/24 08:38:43
Need that check somewhere because there will be an
|
| + self.operations.append(self.stringifier.operation) |
| + |
| def merge(self, other): |
| """Merge in another interface's members (e.g., partial interface)""" |
| self.attributes.extend(other.attributes) |
| @@ -562,6 +576,34 @@ def arguments_node_to_arguments(node): |
| ################################################################################ |
| +# Stringifiers |
| +################################################################################ |
| + |
| +class IdlStringifier(object): |
| + def __init__(self, node): |
| + self.attribute = None |
| + self.operation = None |
| + self.extended_attributes = {} |
| + |
| + for child in node.GetChildren(): |
| + child_class = child.GetClass() |
| + if child_class == 'Attribute': |
| + self.attribute = IdlAttribute(child) |
| + elif child_class == 'Operation': |
| + self.operation = IdlOperation(child) |
| + elif child_class == 'ExtAttributes': |
| + self.extended_attributes = ext_attributes_node_to_extended_attributes(child) |
| + else: |
| + raise ValueError('Unrecognized node class: %s' % child_class) |
| + |
| + # Copy the stringifier's extended attributes (such as [Unforgable]) onto |
| + # the underlying attribute or operation, if there is one. |
| + if self.attribute or self.operation: |
| + (self.attribute or self.operation).extended_attributes.update( |
| + self.extended_attributes) |
| + |
| + |
| +################################################################################ |
| # Extended attributes |
| ################################################################################ |