blob: a941cc0a793ffab314af87b59c9f47dcbe1f0b94 [file] [log] [blame]
#!/usr/bin/env python
# Copyright (C) 2013 Google Inc. All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# * Redistributions in binary form must reproduce the above
# copyright notice, this list of conditions and the following disclaimer
# in the documentation and/or other materials provided with the
# distribution.
# * Neither the name of Google Inc. nor the names of its
# contributors may be used to endorse or promote products derived from
# this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
import os.path
import sys
import json5_generator
import license
import name_utilities
import template_expander
# All events on the following whitelist are matched case-insensitively
# in createEvent.
#
# https://dom.spec.whatwg.org/#dom-document-createevent
def create_event_whitelist(name):
return (name == 'HTMLEvents'
or name == 'Event'
or name == 'Events'
or name.startswith('UIEvent')
or name.startswith('CustomEvent')
or name == 'KeyboardEvent'
or name == 'MessageEvent'
or name.startswith('MouseEvent')
or name == 'TouchEvent')
# All events on the following whitelist are matched case-insensitively
# in createEvent and are measured using UseCounter.
#
# TODO(foolip): All events on this list should either be added to the spec and
# moved to the above whitelist (causing them to be matched case-insensitively)
# or be deprecated/removed. https://crbug.com/569690
def create_event_measure_whitelist(name):
return (name == 'AnimationEvent'
or name == 'BeforeUnloadEvent'
or name == 'CloseEvent'
or name == 'CompositionEvent'
or name == 'DeviceMotionEvent'
or name == 'DeviceOrientationEvent'
or name == 'DragEvent'
or name == 'ErrorEvent'
or name == 'FocusEvent'
or name == 'HashChangeEvent'
or name == 'IDBVersionChangeEvent'
or name == 'KeyboardEvents'
or name == 'MutationEvent'
or name == 'MutationEvents'
or name == 'PageTransitionEvent'
or name == 'PopStateEvent'
or name == 'StorageEvent'
or name == 'SVGEvents'
or name == 'TextEvent'
or name == 'TrackEvent'
or name == 'TransitionEvent'
or name == 'WebGLContextEvent'
or name == 'WheelEvent')
def measure_name(name):
return 'DocumentCreateEvent' + name
class EventFactoryWriter(json5_generator.Writer):
default_parameters = {
'ImplementedAs': {},
'interfaceHeaderDir': {},
'RuntimeEnabled': {},
}
default_metadata = {
'export': '',
'namespace': '',
'suffix': '',
}
filters = {
'cpp_name': name_utilities.cpp_name,
'name': lambda entry: entry['name'].original,
'create_event_whitelist': create_event_whitelist,
'create_event_measure_whitelist': create_event_measure_whitelist,
'measure_name': measure_name,
}
def __init__(self, json5_file_path, output_dir):
super(EventFactoryWriter, self).__init__(json5_file_path, output_dir)
self.namespace = self.json5_file.metadata['namespace'].strip('"')
assert self.namespace == 'event_interface_names', 'namespace field should be "event_interface_names".'
self.suffix = self.json5_file.metadata['suffix'].strip('"')
snake_suffix = (self.suffix.lower() + '_') if self.suffix else ''
self._outputs = {
('event_%sfactory.cc' % snake_suffix): self.generate_implementation,
}
def _fatal(self, message):
print 'FATAL ERROR: ' + message
exit(1)
def _headers_header_include_path(self, entry):
path = entry['interfaceHeaderDir']
if len(path):
path += '/'
return path + self.get_file_basename(name_utilities.cpp_name(entry)) + '.h'
def _headers_header_includes(self, entries):
includes = dict()
for entry in entries:
cpp_name = name_utilities.cpp_name(entry)
# Avoid duplicate includes.
if cpp_name in includes:
continue
includes[cpp_name] = self._headers_header_include_path(entry)
return sorted(includes.values())
@template_expander.use_jinja('templates/event_factory.cc.tmpl', filters=filters)
def generate_implementation(self):
return {
'include_header_paths': self._headers_header_includes(
self.json5_file.name_dictionaries),
'input_files': self._input_files,
'suffix': self.suffix,
'events': self.json5_file.name_dictionaries,
}
if __name__ == "__main__":
json5_generator.Maker(EventFactoryWriter).main()