| OLD | NEW |
| 1 #!/usr/bin/python | 1 #!/usr/bin/python |
| 2 # Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 2 # Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 3 # for details. All rights reserved. Use of this source code is governed by a | 3 # for details. All rights reserved. Use of this source code is governed by a |
| 4 # BSD-style license that can be found in the LICENSE file. | 4 # BSD-style license that can be found in the LICENSE file. |
| 5 import logging | 5 import logging |
| 6 import monitored | 6 import monitored |
| 7 import re | 7 import re |
| 8 | 8 |
| 9 html_interface_renames = monitored.Dict('htmlrenamer.html_interface_renames', { | 9 html_interface_renames = monitored.Dict('htmlrenamer.html_interface_renames', { |
| 10 'CDATASection': 'CDataSection', | 10 'CDATASection': 'CDataSection', |
| 11 'Clipboard': 'DataTransfer', | 11 'Clipboard': 'DataTransfer', |
| 12 'Database': 'SqlDatabase', # Avoid conflict with Index DB's Database. | 12 'Database': 'SqlDatabase', # Avoid conflict with Index DB's Database. |
| 13 'DatabaseSync': 'SqlDatabaseSync', | 13 'DatabaseSync': 'SqlDatabaseSync', |
| 14 'DOMApplicationCache': 'ApplicationCache', | 14 'DOMApplicationCache': 'ApplicationCache', |
| 15 'DOMCoreException': 'DomException', | 15 'DOMCoreException': 'DomException', |
| 16 'DOMFileSystem': 'FileSystem', | 16 'DOMFileSystem': 'FileSystem', |
| 17 'DOMFileSystemSync': 'FileSystemSync', | 17 'DOMFileSystemSync': 'FileSystemSync', |
| 18 'DOMFormData': 'FormData', | 18 'DOMFormData': 'FormData', |
| 19 'DOMURL': 'Url', | 19 'DOMURL': 'Url', |
| 20 'DOMWindow': 'Window', | 20 'DOMWindow': 'Window', |
| 21 'EntryCallback': '_EntryCallback', |
| 22 'EntriesCallback': '_EntriesCallback', |
| 23 'ErrorCallback': '_ErrorCallback', |
| 24 'FileCallback': '_FileCallback', |
| 25 'FileSystemCallback': '_FileSystemCallback', |
| 26 'FileWriterCallback': '_FileWriterCallback', |
| 21 'HTMLDocument' : 'HtmlDocument', | 27 'HTMLDocument' : 'HtmlDocument', |
| 22 'IDBFactory': 'IdbFactory', # Manual to avoid name conflicts. | 28 'IDBFactory': 'IdbFactory', # Manual to avoid name conflicts. |
| 23 'NamedNodeMap': '_NamedNodeMap', | 29 'NamedNodeMap': '_NamedNodeMap', |
| 24 'NavigatorUserMediaErrorCallback': '_NavigatorUserMediaErrorCallback', | 30 'NavigatorUserMediaErrorCallback': '_NavigatorUserMediaErrorCallback', |
| 25 'NavigatorUserMediaSuccessCallback': '_NavigatorUserMediaSuccessCallback', | 31 'NavigatorUserMediaSuccessCallback': '_NavigatorUserMediaSuccessCallback', |
| 32 'NotificationPermissionCallback': '_NotificationPermissionCallback', |
| 26 'PositionCallback': '_PositionCallback', | 33 'PositionCallback': '_PositionCallback', |
| 27 'PositionErrorCallback': '_PositionErrorCallback', | 34 'PositionErrorCallback': '_PositionErrorCallback', |
| 28 'Rect': 'CssRect', | 35 'Rect': 'CssRect', |
| 29 'RGBColor': 'CssRgbColor', | 36 'RGBColor': 'CssRgbColor', |
| 37 'RTCErrorCallback': '_RtcErrorCallback', |
| 38 'RTCSessionDescriptionCallback': '_RtcSessionDescriptionCallback', |
| 39 'StorageInfoErrorCallback': '_StorageInfoErrorCallback', |
| 40 'StorageInfoUsageCallback': '_StorageInfoUsageCallback', |
| 41 'StringCallback': '_StringCallback', |
| 30 'SVGDocument': 'SvgDocument', # Manual to avoid name conflicts. | 42 'SVGDocument': 'SvgDocument', # Manual to avoid name conflicts. |
| 31 'SVGElement': 'SvgElement', # Manual to avoid name conflicts. | 43 'SVGElement': 'SvgElement', # Manual to avoid name conflicts. |
| 32 'SVGException': 'SvgException', # Manual of avoid conflict with Exception. | 44 'SVGException': 'SvgException', # Manual of avoid conflict with Exception. |
| 33 'SVGSVGElement': 'SvgSvgElement', # Manual to avoid name conflicts. | 45 'SVGSVGElement': 'SvgSvgElement', # Manual to avoid name conflicts. |
| 34 'WebGLVertexArrayObjectOES': 'WebGLVertexArrayObject', | 46 'WebGLVertexArrayObjectOES': 'WebGLVertexArrayObject', |
| 35 'WebKitAnimationEvent': 'AnimationEvent', | 47 'WebKitAnimationEvent': 'AnimationEvent', |
| 36 'WebKitCSSKeyframeRule': 'CssKeyframeRule', | 48 'WebKitCSSKeyframeRule': 'CssKeyframeRule', |
| 37 'WebKitCSSKeyframesRule': 'CssKeyframesRule', | 49 'WebKitCSSKeyframesRule': 'CssKeyframesRule', |
| 38 'WebKitCSSMatrix': 'CssMatrix', | 50 'WebKitCSSMatrix': 'CssMatrix', |
| 39 'WebKitCSSTransformValue': 'CssTransformValue', | 51 'WebKitCSSTransformValue': 'CssTransformValue', |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 74 'SVGHKernElement', | 86 'SVGHKernElement', |
| 75 'SVGMissingGlyphElement', | 87 'SVGMissingGlyphElement', |
| 76 'SVGMPathElement', | 88 'SVGMPathElement', |
| 77 'SVGTRefElement', | 89 'SVGTRefElement', |
| 78 'SVGVKernElement', | 90 'SVGVKernElement', |
| 79 ] | 91 ] |
| 80 | 92 |
| 81 for interface in _removed_html_interfaces: | 93 for interface in _removed_html_interfaces: |
| 82 html_interface_renames[interface] = '_' + interface | 94 html_interface_renames[interface] = '_' + interface |
| 83 | 95 |
| 96 convert_to_future_members = monitored.Set( |
| 97 'htmlrenamer.converted_to_future_members', [ |
| 98 'DataTransferItem.getAsString', |
| 99 'DirectoryEntry.getDirectory', |
| 100 'DirectoryEntry.getFile', |
| 101 'DirectoryEntry.removeRecursively', |
| 102 'DirectoryReader.readEntries', |
| 103 'DOMWindow.webkitRequestFileSystem', |
| 104 'DOMWindow.webkitResolveLocalFileSystemURL', |
| 105 'Entry.copyTo', |
| 106 'Entry.getMetadata', |
| 107 'Entry.getParent', |
| 108 'Entry.moveTo', |
| 109 'Entry.remove', |
| 110 'FileEntry.createWriter', |
| 111 'FileEntry.file', |
| 112 'Notification.requestPermission', |
| 113 'NotificationCenter.requestPermission', |
| 114 'RTCPeerConnection.createAnswer', |
| 115 'RTCPeerConnection.createOffer', |
| 116 'RTCPeerConnection.setLocalDescription', |
| 117 'RTCPeerConnection.setRemoteDescription', |
| 118 'StorageInfo.queryUsageAndQuota', |
| 119 'StorageInfo.requestQuota', |
| 120 'WorkerContext.webkitResolveLocalFileSystemURL', |
| 121 ]) |
| 122 |
| 84 # Members from the standard dom that should not be exposed publicly in dart:html | 123 # Members from the standard dom that should not be exposed publicly in dart:html |
| 85 # but need to be exposed internally to implement dart:html on top of a standard | 124 # but need to be exposed internally to implement dart:html on top of a standard |
| 86 # browser. | 125 # browser. |
| 87 _private_html_members = monitored.Set('htmlrenamer._private_html_members', [ | 126 _private_html_members = monitored.Set('htmlrenamer._private_html_members', [ |
| 88 'CompositionEvent.initCompositionEvent', | 127 'CompositionEvent.initCompositionEvent', |
| 89 'CustomEvent.initCustomEvent', | 128 'CustomEvent.initCustomEvent', |
| 90 'DeviceOrientationEvent.initDeviceOrientationEvent', | 129 'DeviceOrientationEvent.initDeviceOrientationEvent', |
| 91 'Document.createElement', | 130 'Document.createElement', |
| 92 'Document.createElementNS', | 131 'Document.createElementNS', |
| 93 'Document.createEvent', | 132 'Document.createEvent', |
| (...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 230 'DOMURL.revokeObjectURL': 'revokeObjectUrl', | 269 'DOMURL.revokeObjectURL': 'revokeObjectUrl', |
| 231 'DOMWindow.clearTimeout': '_clearTimeout', | 270 'DOMWindow.clearTimeout': '_clearTimeout', |
| 232 'DOMWindow.clearInterval': '_clearInterval', | 271 'DOMWindow.clearInterval': '_clearInterval', |
| 233 'DOMWindow.setTimeout': '_setTimeout', | 272 'DOMWindow.setTimeout': '_setTimeout', |
| 234 'DOMWindow.setInterval': '_setInterval', | 273 'DOMWindow.setInterval': '_setInterval', |
| 235 'DOMWindow.webkitConvertPointFromNodeToPage': 'convertPointFromNodeToPage', | 274 'DOMWindow.webkitConvertPointFromNodeToPage': 'convertPointFromNodeToPage', |
| 236 'DOMWindow.webkitConvertPointFromPageToNode': 'convertPointFromPageToNode', | 275 'DOMWindow.webkitConvertPointFromPageToNode': 'convertPointFromPageToNode', |
| 237 'DOMWindow.webkitNotifications': 'notifications', | 276 'DOMWindow.webkitNotifications': 'notifications', |
| 238 'DOMWindow.webkitRequestFileSystem': 'requestFileSystem', | 277 'DOMWindow.webkitRequestFileSystem': 'requestFileSystem', |
| 239 'DOMWindow.webkitResolveLocalFileSystemURL': 'resolveLocalFileSystemUrl', | 278 'DOMWindow.webkitResolveLocalFileSystemURL': 'resolveLocalFileSystemUrl', |
| 240 'DOMWindow.webkitRequestFileSystem': 'requestFileSystem', | |
| 241 'DOMWindow.webkitResolveLocalFileSystemURL': 'resolveLocalFileSystemUrl', | |
| 242 'Element.webkitCreateShadowRoot': 'createShadowRoot', | 279 'Element.webkitCreateShadowRoot': 'createShadowRoot', |
| 243 'Element.webkitMatchesSelector' : 'matches', | 280 'Element.webkitMatchesSelector' : 'matches', |
| 244 'Navigator.webkitGetUserMedia': '_getUserMedia', | 281 'Navigator.webkitGetUserMedia': '_getUserMedia', |
| 245 'Node.cloneNode': 'clone', | 282 'Node.cloneNode': 'clone', |
| 246 'Node.nextSibling': 'nextNode', | 283 'Node.nextSibling': 'nextNode', |
| 247 'Node.ownerDocument': 'document', | 284 'Node.ownerDocument': 'document', |
| 248 'Node.parentElement': 'parent', | 285 'Node.parentElement': 'parent', |
| 249 'Node.previousSibling': 'previousNode', | 286 'Node.previousSibling': 'previousNode', |
| 250 'Node.textContent': 'text', | 287 'Node.textContent': 'text', |
| 251 'SVGElement.className': '$dom_svgClassName', | 288 'SVGElement.className': '$dom_svgClassName', |
| 252 'WorkerContext.webkitRequestFileSystem': 'requestFileSystem', | 289 'WorkerContext.webkitRequestFileSystem': 'requestFileSystem', |
| 253 'WorkerContext.webkitRequestFileSystemSync': 'requestFileSystemSync', | 290 'WorkerContext.webkitRequestFileSystemSync': 'requestFileSystemSync', |
| 254 'WorkerContext.webkitResolveLocalFileSystemSyncURL': | 291 'WorkerContext.webkitResolveLocalFileSystemSyncURL': |
| 255 'resolveLocalFileSystemSyncUrl', | 292 'resolveLocalFileSystemSyncUrl', |
| 256 'WorkerContext.webkitResolveLocalFileSystemURL': | 293 'WorkerContext.webkitResolveLocalFileSystemURL': |
| 257 'resolveLocalFileSystemUrl', | 294 'resolveLocalFileSystemUrl', |
| 258 }) | 295 }) |
| 259 | 296 |
| 297 for member in convert_to_future_members: |
| 298 if member in renamed_html_members: |
| 299 renamed_html_members[member] = '_' + renamed_html_members[member] |
| 300 else: |
| 301 renamed_html_members[member] = '_' + member[member.find('.') + 1 :] |
| 302 |
| 260 # Members and classes from the dom that should be removed completely from | 303 # Members and classes from the dom that should be removed completely from |
| 261 # dart:html. These could be expressed in the IDL instead but expressing this | 304 # dart:html. These could be expressed in the IDL instead but expressing this |
| 262 # as a simple table instead is more concise. | 305 # as a simple table instead is more concise. |
| 263 # Syntax is: ClassName.(get\:|set\:|call\:|on\:)?MemberName | 306 # Syntax is: ClassName.(get\:|set\:|call\:|on\:)?MemberName |
| 264 # Using get: and set: is optional and should only be used when a getter needs | 307 # Using get: and set: is optional and should only be used when a getter needs |
| 265 # to be suppressed but not the setter, etc. | 308 # to be suppressed but not the setter, etc. |
| 266 # TODO(jacobr): cleanup and augment this list. | 309 # TODO(jacobr): cleanup and augment this list. |
| 267 _removed_html_members = monitored.Set('htmlrenamer._removed_html_members', [ | 310 _removed_html_members = monitored.Set('htmlrenamer._removed_html_members', [ |
| 268 'Attr.*', | 311 'Attr.*', |
| 269 'CanvasRenderingContext2D.clearShadow', | 312 'CanvasRenderingContext2D.clearShadow', |
| (...skipping 364 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 634 | 677 |
| 635 # We're looking for a sequence of letters which start with capital letter | 678 # We're looking for a sequence of letters which start with capital letter |
| 636 # then a series of caps and finishes with either the end of the string or | 679 # then a series of caps and finishes with either the end of the string or |
| 637 # a capital letter. | 680 # a capital letter. |
| 638 # The [0-9] check is for names such as 2D or 3D | 681 # The [0-9] check is for names such as 2D or 3D |
| 639 # The following test cases should match as: | 682 # The following test cases should match as: |
| 640 # WebKitCSSFilterValue: WebKit(C)(SS)(F)ilterValue | 683 # WebKitCSSFilterValue: WebKit(C)(SS)(F)ilterValue |
| 641 # XPathNSResolver: (X)()(P)ath(N)(S)(R)esolver (no change) | 684 # XPathNSResolver: (X)()(P)ath(N)(S)(R)esolver (no change) |
| 642 # IFrameElement: (I)()(F)rameElement (no change) | 685 # IFrameElement: (I)()(F)rameElement (no change) |
| 643 return re.sub(r'([A-Z])([A-Z]{2,})([A-Z]|$)', toLower, name) | 686 return re.sub(r'([A-Z])([A-Z]{2,})([A-Z]|$)', toLower, name) |
| OLD | NEW |