blob: 4dbfb6f53037181b29f8d5e3c618d93ad9d9e0c1 [file] [log] [blame]
#!/usr/bin/python
# Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
# for details. All rights reserved. Use of this source code is governed by a
# BSD-style license that can be found in the LICENSE file.
"""This module provides shared functionality for systems to generate
Dart APIs from the IDL database."""
import re
import pdb
_pure_interfaces = set([
'DOMStringMap',
'ElementTimeControl',
'ElementTraversal',
'MediaQueryListListener',
'NodeSelector',
'SVGExternalResourcesRequired',
'SVGFilterPrimitiveStandardAttributes',
'SVGFitToViewBox',
'SVGLangSpace',
'SVGLocatable',
'SVGStylable',
'SVGTests',
'SVGTransformable',
'SVGURIReference',
'SVGViewSpec',
'SVGZoomAndPan',
'TimeoutHandler'])
def IsPureInterface(interface_name):
return interface_name in _pure_interfaces
#
# Renames for attributes that have names that are not legal Dart names.
#
_dart_attribute_renames = {
'default': 'defaultValue',
'final': 'finalValue',
}
#
# Interface version of the DOM needs to delegate typed array constructors to a
# factory provider.
#
interface_factories = {
'Float32Array': '_TypedArrayFactoryProvider',
'Float64Array': '_TypedArrayFactoryProvider',
'Int8Array': '_TypedArrayFactoryProvider',
'Int16Array': '_TypedArrayFactoryProvider',
'Int32Array': '_TypedArrayFactoryProvider',
'Uint8Array': '_TypedArrayFactoryProvider',
'Uint16Array': '_TypedArrayFactoryProvider',
'Uint32Array': '_TypedArrayFactoryProvider',
'Uint8ClampedArray': '_TypedArrayFactoryProvider',
}
#
# Custom native specs for the Frog dom.
#
_frog_dom_custom_native_specs = {
# Decorate the singleton Console object, if present (workers do not have a
# console).
'Console': "=(typeof console == 'undefined' ? {} : console)",
# DOMWindow aliased with global scope.
'DOMWindow': '@*DOMWindow',
}
#
# Custom native bodies for frog implementations of dom operations that appear in
# dart:dom and dart:html. This is used to work-around the lack of a 'rename'
# feature in the 'native' string - the correct name is available on the DartName
# extended attribute. See Issue 1814
#
dom_frog_native_bodies = {
# Some JavaScript processors, especially tools like yuicompress and
# JSCompiler, choke on 'this.continue'
'IDBCursor.continueFunction':
"""
if (key == null) return this['continue']();
return this['continue'](key);
""",
}
def IsPrimitiveType(type_name):
return isinstance(GetIDLTypeInfo(type_name), PrimitiveIDLTypeInfo)
def MaybeListElementTypeName(type_name):
"""Returns the List element type T from string of form "List<T>", or None."""
match = re.match(r'sequence<(\w*)>$', type_name)
if match:
return match.group(1)
return None
def MaybeListElementType(interface):
"""Returns the List element type T, or None in interface does not implement
List<T>.
"""
for parent in interface.parents:
element_type = MaybeListElementTypeName(parent.type.id)
if element_type:
return element_type
return None
def MaybeTypedArrayElementType(interface):
"""Returns the typed array element type, or None in interface is not a
TypedArray.
"""
# Typed arrays implement ArrayBufferView and List<T>.
for parent in interface.parents:
if parent.type.id == 'ArrayBufferView':
return MaybeListElementType(interface)
return None
def MakeNativeSpec(javascript_binding_name):
if javascript_binding_name in _frog_dom_custom_native_specs:
return _frog_dom_custom_native_specs[javascript_binding_name]
else:
# Make the class 'hidden' so it is dynamically patched at runtime. This
# is useful not only for browser compat, but to allow code that links
# against dart:dom to load in a worker isolate.
return '*' + javascript_binding_name
def MatchSourceFilter(filter, thing):
if not filter:
return True
else:
return any(token in thing.annotations for token in filter)
def DartType(idl_type_name):
return GetIDLTypeInfo(idl_type_name).dart_type()
def JsType(idl_type_name):
return GetIDLTypeInfo(idl_type_name).js_type()
class ParamInfo(object):
"""Holder for various information about a parameter of a Dart operation.
Attributes:
name: Name of parameter.
type_id: Original type id. None for merged types.
dart_type: DartType of parameter.
default_value: String holding the expression. None for mandatory parameter.
"""
def __init__(self, name, type_id, dart_type, default_value, interface):
self.name = name
self.type_id = type_id
self.dart_type = dart_type
self.default_value = default_value
self.interface = interface
# Given a list of overloaded arguments, render a dart argument.
def _DartArg(args, interface):
# Given a list of overloaded arguments, choose a suitable name.
def OverloadedName(args):
return '_OR_'.join(sorted(set(arg.id for arg in args)))
# Given a list of overloaded arguments, choose a suitable type.
def OverloadedType(args):
type_ids = sorted(set(arg.type.id for arg in args))
dart_types = sorted(set(DartType(arg.type.id) for arg in args))
if len(dart_types) == 1:
if len(type_ids) == 1:
return (type_ids[0], dart_types[0])
else:
return (None, dart_types[0])
else:
return (None, TypeName(type_ids, interface))
filtered = filter(None, args)
optional = any(not arg or arg.is_optional for arg in args)
(type_id, dart_type) = OverloadedType(filtered)
name = OverloadedName(filtered)
if optional:
return ParamInfo(name, type_id, dart_type, None, interface)
else:
return ParamInfo(name, type_id, dart_type, None, interface)
def AnalyzeOperation(interface, operations):
"""Makes operation calling convention decision for a set of overloads.
Returns: An OperationInfo object.
"""
# Zip together arguments from each overload by position, then convert
# to a dart argument.
args = map(lambda *args: _DartArg(args, interface),
*(op.arguments for op in operations))
info = OperationInfo()
info.interface = interface
info.overloads = operations
info.declared_name = operations[0].id
info.name = operations[0].ext_attrs.get('DartName', info.declared_name)
info.js_name = info.declared_name
info.type_name = DartType(operations[0].type.id) # TODO: widen.
info.param_infos = args
info.arguments = operations[0].arguments
return info
def AnalyzeConstructor(interface):
"""Returns an OperationInfo object for the constructor.
Returns None if the interface has no Constructor.
"""
def GetArgs(func_value):
return map(lambda arg: _DartArg([arg], interface), func_value.arguments)
if 'Constructor' in interface.ext_attrs:
name = None
func_value = interface.ext_attrs.get('Constructor')
if func_value:
# [Constructor(param,...)]
args = GetArgs(func_value)
idl_args = func_value.arguments
else: # [Constructor]
args = []
idl_args = []
else:
func_value = interface.ext_attrs.get('NamedConstructor')
if func_value:
name = func_value.id
args = GetArgs(func_value)
idl_args = func_value.arguments
else:
return None
info = OperationInfo()
info.overloads = None
info.idl_args = idl_args
info.declared_name = name
info.name = name
info.js_name = name
info.type_name = interface.id
info.param_infos = args
return info
def RecognizeCallback(interface):
"""Returns the info for the callback method if the interface smells like a
callback.
"""
if 'Callback' not in interface.ext_attrs: return None
handlers = [op for op in interface.operations if op.id == 'handleEvent']
if not handlers: return None
if not (handlers == interface.operations): return None
return AnalyzeOperation(interface, handlers)
def IsDartListType(type):
return type == 'List' or type.startswith('sequence<')
def IsDartCollectionType(type):
return IsDartListType(type)
def FindMatchingAttribute(interface, attr1):
matches = [attr2 for attr2 in interface.attributes
if attr1.id == attr2.id
and attr1.is_fc_getter == attr2.is_fc_getter
and attr1.is_fc_setter == attr2.is_fc_setter]
if matches:
assert len(matches) == 1
return matches[0]
return None
def DartDomNameOfAttribute(attr):
"""Returns the Dart name for an IDLAttribute.
attr.id is the 'native' or JavaScript name.
To ensure uniformity, work with the true IDL name until as late a possible,
e.g. translate to the Dart name when generating Dart code.
"""
name = attr.id
name = _dart_attribute_renames.get(name, name)
name = attr.ext_attrs.get('DartName', None) or name
return name
def TypeOrNothing(dart_type, info):
"""Returns string for declaring something with |dart_type| in a context
where a type may be omitted.
The string is empty or has a trailing space.
"""
# hack until over-loaded callback issue is fixed
if dart_type == 'Dynamic' or info is not None and info.interface == 'DatabaseCallback':
return 'Object '
else:
return dart_type + ' '
def NameOrEntry(param, database):
"""Returns either the name of the param, or a $entry wrapper"""
if param.type_id.endswith('Callback') or param.type_id.endswith('Handler'):
argtype = database.GetInterface(param.type_id)
op = argtype.operations[0]
jsniArgs = []
for arg in op.arguments:
if database.HasInterface(arg.type.id):
argface = database.GetInterface(arg.type.id)
# HACK: this interface is overloaded, we should fix the IDL or detect overloaded callbacks automatically
if param.type_id == 'DatabaseCallback' and (argface.id == 'Database' or argface.id == 'DatabaseSync'):
jsniArgs.append("Ljava/lang/Object;")
else:
jsniArgs.append("Lelemental/%s/%s;" % (getModule(argface.annotations), DartType(arg.type.id)))
else:
jsniArgs.append(primitives[DartType(arg.type.id)])
return "$entry(%s.@elemental.%s.%s::on%s(%s)).bind(%s)" % (param.name, getModule(argtype.annotations), argtype.id, argtype.id, ''.join(jsniArgs), param.name)
else:
return param.name
def TypeOrVar(dart_type, comment=None):
return dart_type
def JsoTypeOrVar(dart_type, mixins):
if dart_type.endswith("Handler") or dart_type.endswith("Callback") or dart_type in mixins:
return dart_type
if dart_type[0].isupper() and not dart_type.startswith("Js") and not dart_type in java_lang:
return "Js" + dart_type
return dart_type
class OperationInfo(object):
"""Holder for various derived information from a set of overloaded operations.
Attributes:
overloads: A list of IDL operation overloads with the same name.
name: A string, the simple name of the operation.
type_name: A string, the name of the return type of the operation.
param_infos: A list of ParamInfo.
"""
def ParametersInterfaceDeclaration(self):
"""Returns a formatted string declaring the parameters for the interface."""
return self._FormatParams(
self.param_infos, True,
lambda param: TypeOrNothing(param.dart_type, param))
def ParametersImplementationDeclaration(self, rename_type=None):
"""Returns a formatted string declaring the parameters for the
implementation.
Args:
rename_type: A function that allows the types to be renamed.
The function is applied to the parameter's dart_type.
"""
if rename_type:
def renamer(param_info):
return TypeOrNothing(rename_type(param_info.dart_type), param_info)
return self._FormatParams(self.param_infos, False, renamer)
else:
def type_fn(param_info):
if param_info.dart_type == 'Dynamic':
if param_info.type_id:
# It is more informative to use a comment IDL type.
return 'Object'
else:
return 'Object'
else:
return param_info.dart_type
return self._FormatParams(
self.param_infos, False,
lambda param: TypeOrNothing(param.dart_type, param))
def ParametersAsArgumentList(self, database):
"""Returns a string of the parameter names suitable for passing the
parameters as arguments.
"""
return ', '.join(map(lambda param_info: NameOrEntry(param_info, database), self.param_infos))
def _FormatParams(self, params, is_interface, type_fn):
def FormatParam(param):
"""Returns a parameter declaration fragment for an ParamInfo."""
type = type_fn(param)
if is_interface or param.default_value is None:
return '%s%s' % (type, param.name)
else:
return '%s%s = %s' % (type, param.name, param.default_value)
required = []
optional = []
for param_info in params:
if param_info.default_value:
optional.append(param_info)
else:
if optional:
raise Exception('Optional parameters cannot precede required ones: '
+ str(args))
required.append(param_info)
argtexts = map(FormatParam, required)
if optional:
argtexts.append(', '.join(map(FormatParam, optional)))
return ', '.join(argtexts)
def IsStatic(self):
is_static = self.overloads[0].is_static
assert any([is_static == o.is_static for o in self.overloads])
return is_static
def AttributeOutputOrder(a, b):
"""Canonical output ordering for attributes."""
# Getters before setters:
if a.id < b.id: return -1
if a.id > b.id: return 1
if a.is_fc_setter < b.is_fc_setter: return -1
if a.is_fc_setter > b.is_fc_setter: return 1
return 0
def ConstantOutputOrder(a, b):
"""Canonical output ordering for constants."""
if a.id < b.id: return -1
if a.id > b.id: return 1
return 0
def _FormatNameList(names):
"""Returns JavaScript array literal expression with one name per line."""
#names = sorted(names)
if len(names) <= 1:
expression_string = str(names) # e.g. ['length']
else:
expression_string = ',\n '.join(str(names).split(','))
expression_string = expression_string.replace('[', '[\n ')
return expression_string
def IndentText(text, indent):
"""Format lines of text with indent."""
def FormatLine(line):
if line.strip():
return '%s%s\n' % (indent, line)
else:
return '\n'
return ''.join(FormatLine(line) for line in text.split('\n'))
# Given a sorted sequence of type identifiers, return an appropriate type
# name
def TypeName(type_ids, interface):
# Dynamically type this field for now.
return 'Dynamic'
# ------------------------------------------------------------------------------
class IDLTypeInfo(object):
def __init__(self, idl_type, dart_type=None,
native_type=None,
custom_to_native=False,
custom_to_dart=False, conversion_includes=[],
js_type = None):
self._idl_type = idl_type
self._dart_type = dart_type
self._native_type = native_type
self._custom_to_native = custom_to_native
self._custom_to_dart = custom_to_dart
self._conversion_includes = conversion_includes + [idl_type]
self._js_type = js_type
def idl_type(self):
return self._idl_type
def dart_type(self):
return self._dart_type or self._idl_type
def js_type(self):
return self._js_type or self._idl_type
def native_type(self):
return self._native_type or self._idl_type
def emit_to_native(self, emitter, idl_node, name, handle, interface_name):
if 'Callback' in idl_node.ext_attrs:
if 'RequiredCppParameter' in idl_node.ext_attrs:
flag = 'DartUtilities::ConvertNullToDefaultValue'
else:
flag = 'DartUtilities::ConvertNone'
emitter.Emit(
'\n'
' RefPtr<$TYPE> $NAME = Dart$IDL_TYPE::create($HANDLE, $FLAG, exception);\n'
' if (exception)\n'
' goto fail;\n',
TYPE=self.native_type(),
NAME=name,
IDL_TYPE=self.idl_type(),
HANDLE=handle,
FLAG=flag)
return name
argument = name
if self.custom_to_native():
type = 'RefPtr<%s>' % self.native_type()
argument = '%s.get()' % name
else:
type = '%s*' % self.native_type()
if isinstance(self, SVGTearOffIDLTypeInfo) and not interface_name.endswith('List'):
argument = '%s->propertyReference()' % name
emitter.Emit(
'\n'
' $TYPE $NAME = Dart$IDL_TYPE::toNative($HANDLE, exception);\n'
' if (exception)\n'
' goto fail;\n',
TYPE=type,
NAME=name,
IDL_TYPE=self.idl_type(),
HANDLE=handle)
return argument
def custom_to_native(self):
return self._custom_to_native
def parameter_type(self):
return '%s*' % self.native_type()
def webcore_includes(self):
WTF_INCLUDES = [
'ArrayBuffer',
'ArrayBufferView',
'Float32Array',
'Float64Array',
'Int8Array',
'Int16Array',
'Int32Array',
'Uint8Array',
'Uint16Array',
'Uint32Array',
'Uint8ClampedArray',
]
if self._idl_type in WTF_INCLUDES:
return ['<wtf/%s.h>' % self.native_type()]
if not self._idl_type.startswith('SVG'):
return ['"%s.h"' % self.native_type()]
if self._idl_type in ['SVGNumber', 'SVGPoint']:
return ['"SVGPropertyTearOff.h"']
if self._idl_type.startswith('SVGPathSeg'):
include = self._idl_type.replace('Abs', '').replace('Rel', '')
else:
include = self._idl_type
return ['"%s.h"' % include] + _svg_supplemental_includes
def receiver(self):
return 'receiver->'
def conversion_includes(self):
return ['"Dart%s.h"' % include for include in self._conversion_includes]
def to_dart_conversion(self, value, interface_name=None, attributes=None):
return 'Dart%s::toDart(%s)' % (self._idl_type, value)
def custom_to_dart(self):
return self._custom_to_dart
class SequenceIDLTypeInfo(IDLTypeInfo):
def __init__(self, idl_type, item_info):
super(SequenceIDLTypeInfo, self).__init__(idl_type)
self._item_info = item_info
def dart_type(self):
etype = self._item_info.dart_type()
if etype == 'int':
return "IndexableInt"
elif etype == 'float' or etype == 'double':
return "IndexableNumber"
return "Indexable"
# TODO(cromwellian) fix when generic SingleJsoImpl JSOs are fixed
# return 'Indexable<%s>' % self._item_info.dart_type()
def to_dart_conversion(self, value, interface_name=None, attributes=None):
return 'DartDOMWrapper::vectorToDart<Dart%s>(%s)' % (self._item_info.native_type(), value)
def conversion_includes(self):
return self._item_info.conversion_includes()
class PrimitiveIDLTypeInfo(IDLTypeInfo):
def __init__(self, idl_type, dart_type, native_type=None,
webcore_getter_name='getAttribute',
webcore_setter_name='setAttribute'):
super(PrimitiveIDLTypeInfo, self).__init__(idl_type, dart_type=dart_type,
native_type=native_type)
self._webcore_getter_name = webcore_getter_name
self._webcore_setter_name = webcore_setter_name
def emit_to_native(self, emitter, idl_node, name, handle, interface_name):
arguments = [handle]
if idl_node.ext_attrs.get('Optional') == 'DefaultIsNullString' or 'RequiredCppParameter' in idl_node.ext_attrs:
arguments.append('DartUtilities::ConvertNullToDefaultValue')
emitter.Emit(
'\n'
' const ParameterAdapter<$TYPE> $NAME($ARGUMENTS);\n'
' if (!$NAME.conversionSuccessful()) {\n'
' exception = $NAME.exception();\n'
' goto fail;\n'
' }\n',
TYPE=self.native_type(),
NAME=name,
ARGUMENTS=', '.join(arguments))
return name
def parameter_type(self):
if self.native_type() == 'String':
return 'const String&'
return self.native_type()
def conversion_includes(self):
return []
def to_dart_conversion(self, value, interface_name=None, attributes=None):
conversion_arguments = [value]
if attributes and 'TreatReturnedNullStringAs' in attributes:
conversion_arguments.append('DartUtilities::ConvertNullToDefaultValue')
function_name = re.sub(r' [a-z]', lambda x: x.group(0)[1:].upper(), self.native_type())
function_name = function_name[0].lower() + function_name[1:]
function_name = 'DartUtilities::%sToDart' % function_name
return '%s(%s)' % (function_name, ', '.join(conversion_arguments))
def webcore_getter_name(self):
return self._webcore_getter_name
def webcore_setter_name(self):
return self._webcore_setter_name
class SVGTearOffIDLTypeInfo(IDLTypeInfo):
def __init__(self, idl_type, native_type=''):
super(SVGTearOffIDLTypeInfo, self).__init__(idl_type,
native_type=native_type)
def native_type(self):
if self._native_type:
return self._native_type
tear_off_type = 'SVGPropertyTearOff'
if self._idl_type.endswith('List'):
tear_off_type = 'SVGListPropertyTearOff'
return '%s<%s>' % (tear_off_type, self._idl_type)
def receiver(self):
if self._idl_type.endswith('List'):
return 'receiver->'
return 'receiver->propertyReference().'
def to_dart_conversion(self, value, interface_name, attributes):
svg_primitive_types = ['SVGAngle', 'SVGLength', 'SVGMatrix',
'SVGNumber', 'SVGPoint', 'SVGRect', 'SVGTransform']
conversion_cast = '%s::create(%s)'
if interface_name.startswith('SVGAnimated'):
conversion_cast = 'static_cast<%s*>(%s)'
elif self.idl_type() == 'SVGStringList':
conversion_cast = '%s::create(receiver, %s)'
elif interface_name.endswith('List'):
conversion_cast = 'static_cast<%s*>(%s.get())'
elif self.idl_type() in svg_primitive_types:
conversion_cast = '%s::create(%s)'
else:
conversion_cast = 'static_cast<%s*>(%s)'
conversion_cast = conversion_cast % (self.native_type(), value)
return 'Dart%s::toDart(%s)' % (self._idl_type, conversion_cast)
_idl_type_registry = {
'boolean': PrimitiveIDLTypeInfo('boolean', dart_type='boolean', native_type='bool',
webcore_getter_name='hasAttribute',
webcore_setter_name='setBooleanAttribute'),
'short': PrimitiveIDLTypeInfo('short', dart_type='short', native_type='short'),
'unsigned short': PrimitiveIDLTypeInfo('unsigned short', dart_type='int',
native_type='int'),
'int': PrimitiveIDLTypeInfo('int', dart_type='int'),
'unsigned int': PrimitiveIDLTypeInfo('unsigned int', dart_type='int',
native_type='unsigned'),
'long': PrimitiveIDLTypeInfo('long', dart_type='int', native_type='int',
webcore_getter_name='getIntegralAttribute',
webcore_setter_name='setIntegralAttribute'),
'unsigned long': PrimitiveIDLTypeInfo('unsigned long', dart_type='int',
native_type='unsigned',
webcore_getter_name='getUnsignedIntegralAttribute',
webcore_setter_name='setUnsignedIntegralAttribute'),
'long long': PrimitiveIDLTypeInfo('long long', dart_type='double'),
'unsigned long long': PrimitiveIDLTypeInfo('unsigned long long', dart_type='double'),
'float': PrimitiveIDLTypeInfo('float', dart_type='float', native_type='double'),
'double': PrimitiveIDLTypeInfo('double', dart_type='double'),
'any': PrimitiveIDLTypeInfo('any', dart_type='Object'),
'any[]': PrimitiveIDLTypeInfo('any[]', dart_type='Indexable'),
'Array': PrimitiveIDLTypeInfo('Array', dart_type='Indexable'),
'custom': PrimitiveIDLTypeInfo('custom', dart_type='Object'),
'Date': PrimitiveIDLTypeInfo('Date', dart_type='Date', native_type='double'),
'DOMObject': PrimitiveIDLTypeInfo('DOMObject', dart_type='Object', native_type='ScriptValue'),
'DOMString': PrimitiveIDLTypeInfo('DOMString', dart_type='String', native_type='String'),
# TODO(vsm): This won't actually work until we convert the Map to
# a native JS Map for JS DOM.
'Dictionary': PrimitiveIDLTypeInfo('Dictionary', dart_type='Mappable'),
# TODO(sra): Flags is really a dictionary: {create:bool, exclusive:bool}
# http://dev.w3.org/2009/dap/file-system/file-dir-sys.html#the-flags-interface
'Flags': PrimitiveIDLTypeInfo('Flags', dart_type='Object'),
'DOMTimeStamp': PrimitiveIDLTypeInfo('DOMTimeStamp', dart_type='double', native_type='unsigned long long'),
'object': PrimitiveIDLTypeInfo('object', dart_type='Object', native_type='ScriptValue'),
# TODO(sra): Come up with some meaningful name so that where this appears in
# the documentation, the user is made aware that only a limited subset of
# serializable types are actually permitted.
'SerializedScriptValue': PrimitiveIDLTypeInfo('SerializedScriptValue', dart_type='Object'),
# TODO(sra): Flags is really a dictionary: {create:bool, exclusive:bool}
# http://dev.w3.org/2009/dap/file-system/file-dir-sys.html#the-flags-interface
'WebKitFlags': PrimitiveIDLTypeInfo('WebKitFlags', dart_type='Object'),
'sequence': PrimitiveIDLTypeInfo('sequence', dart_type='Indexable'),
'void': PrimitiveIDLTypeInfo('void', dart_type='void'),
'CSSRule': IDLTypeInfo('CSSRule', conversion_includes=['CSSImportRule']),
'DOMException': IDLTypeInfo('DOMException', native_type='DOMCoreException'),
# 'DOMStringList': IDLTypeInfo('DOMStringList', dart_type='Indexable<String>', custom_to_native=True),
'DOMStringList': IDLTypeInfo('DOMStringList', dart_type='Indexable', custom_to_native=True),
# 'DOMStringMap': IDLTypeInfo('DOMStringMap', dart_type='Mappable<String>'),
'DOMStringMap': IDLTypeInfo('DOMStringMap', dart_type='Mappable'),
'DOMWindow': IDLTypeInfo('DOMWindow', custom_to_dart=True),
'Element': IDLTypeInfo('Element', custom_to_dart=True),
'EventListener': IDLTypeInfo('EventListener', custom_to_native=True),
'EventTarget': IDLTypeInfo('EventTarget', custom_to_native=True),
'HTMLElement': IDLTypeInfo('HTMLElement', custom_to_dart=True),
'IDBAny': IDLTypeInfo('IDBAny', dart_type='Object', custom_to_native=True),
'IDBKey': IDLTypeInfo('IDBKey', dart_type='Object', custom_to_native=True),
'StyleSheet': IDLTypeInfo('StyleSheet', conversion_includes=['CSSStyleSheet']),
'SVGElement': IDLTypeInfo('SVGElement', custom_to_dart=True),
'SVGAngle': SVGTearOffIDLTypeInfo('SVGAngle'),
'SVGLength': SVGTearOffIDLTypeInfo('SVGLength'),
'SVGLengthList': SVGTearOffIDLTypeInfo('SVGLengthList'),
'SVGMatrix': SVGTearOffIDLTypeInfo('SVGMatrix'),
'SVGNumber': SVGTearOffIDLTypeInfo('SVGNumber', native_type='SVGPropertyTearOff<float>'),
'SVGNumberList': SVGTearOffIDLTypeInfo('SVGNumberList'),
'SVGPathSegList': SVGTearOffIDLTypeInfo('SVGPathSegList', native_type='SVGPathSegListPropertyTearOff'),
'SVGPoint': SVGTearOffIDLTypeInfo('SVGPoint', native_type='SVGPropertyTearOff<FloatPoint>'),
'SVGPointList': SVGTearOffIDLTypeInfo('SVGPointList'),
'SVGPreserveAspectRatio': SVGTearOffIDLTypeInfo('SVGPreserveAspectRatio'),
'SVGRect': SVGTearOffIDLTypeInfo('SVGRect', native_type='SVGPropertyTearOff<FloatRect>'),
'SVGStringList': SVGTearOffIDLTypeInfo('SVGStringList', native_type='SVGStaticListPropertyTearOff<SVGStringList>'),
'SVGTransform': SVGTearOffIDLTypeInfo('SVGTransform'),
'SVGTransformList': SVGTearOffIDLTypeInfo('SVGTransformList', native_type='SVGTransformListPropertyTearOff'),
'PeerConnection00': IDLTypeInfo('PeerConnection00', js_type='webkitPeerConnection00'),
'AudioContext': IDLTypeInfo('AudioContext', js_type='webkitAudioContext'),
'AudioPannerNode': IDLTypeInfo('AudioPannerNode', js_type='webkitAudioPannerNode'),
'IDBCursor': IDLTypeInfo('IDBCursor', js_type='webkitIDBCursor'),
'IDBDatabase': IDLTypeInfo('IDBDatabase', js_type='webkitIDBDatabase'),
'IDBDatabaseFactory': IDLTypeInfo('IDBDatabaseRactory', js_type='webkitIDBDatabaseFactory'),
'IDBFactory': IDLTypeInfo('IDBFactory', js_type='webkitIDBFactory'),
'IDBIndex': IDLTypeInfo('IDBIndex', js_type='webkitIDBIndex'),
'IDBKeyRange': IDLTypeInfo('IDBKeyRange', js_type='webkitIDBKeyRange'),
'IDBObjectStore': IDLTypeInfo('IDBObjectStore', js_type='webkitIDBObjectStore'),
'IDBRequest': IDLTypeInfo('IDBRequest', js_type='webkitIDBRequest'),
'IDBTransaction': IDLTypeInfo('IDBTransaction', js_type='webkitIDBTransaction'),
'IndexedDB': IDLTypeInfo('IndexedDB', js_type='webkitIndexedDB'),
'Intent': IDLTypeInfo('Intent', js_type='webkitIntent'),
'MediaStream': IDLTypeInfo('MediaStream', js_type='webkitMediaStream'),
'URL': IDLTypeInfo('URL', js_type='webkitURL'),
'ShadowRoot': IDLTypeInfo('ShadowRoot', js_type='WebKitShadowRoot'),
'BlobBuilder': IDLTypeInfo('BlobBuilder', js_type='WebKitBlobBuilder'),
}
_svg_supplemental_includes = [
'"SVGAnimatedPropertyTearOff.h"',
'"SVGAnimatedListPropertyTearOff.h"',
'"SVGStaticListPropertyTearOff.h"',
'"SVGAnimatedListPropertyTearOff.h"',
'"SVGTransformListPropertyTearOff.h"',
'"SVGPathSegListPropertyTearOff.h"',
]
def GetIDLTypeInfo(idl_type_name):
match = re.match(r'sequence<(\w+)>$', idl_type_name)
if match:
return SequenceIDLTypeInfo(idl_type_name, GetIDLTypeInfo(match.group(1)))
return _idl_type_registry.get(idl_type_name, IDLTypeInfo(idl_type_name))
def getModule(annotations):
htmlaliases = ['audio', 'webaudio', 'inspector', 'offline', 'p2p', 'window', 'websockets', 'threads', 'view', 'storage', 'fileapi']
module = "dom"
if 'WebKit' in annotations and 'module' in annotations['WebKit']:
module = annotations['WebKit']['module']
if module in htmlaliases:
return "html"
if module == 'core':
return 'dom'
return module
java_lang = ['Object', 'String', 'Exception', 'DOMTimeStamp', 'DOMString', 'Date']
primitives = {
'int' : 'I',
'short' : 'S',
'float' : 'F',
'double' : 'D',
'byte' : 'B',
'char' : 'C',
'long' : 'L',
'boolean' : 'Z',
'String' : 'Ljava/lang/String;',
'Object' : 'Ljava/lang/Object;'
}