Chromium Code Reviews| 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 | 5 |
| 6 """This module provides shared functionality for the system to generate | 6 """This module provides shared functionality for the system to generate |
| 7 dart:html APIs from the IDL database.""" | 7 dart:html APIs from the IDL database.""" |
| 8 | 8 |
| 9 import emitter | 9 import emitter |
| 10 from generator import AnalyzeOperation, ConstantOutputOrder, \ | 10 from generator import AnalyzeOperation, ConstantOutputOrder, \ |
| (...skipping 222 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 233 version[0] += 1 | 233 version[0] += 1 |
| 234 generate_call(stmts_emitter, call_emitter, | 234 generate_call(stmts_emitter, call_emitter, |
| 235 version[0], signature_index, argument_count) | 235 version[0], signature_index, argument_count) |
| 236 | 236 |
| 237 def GenerateChecksAndCall(signature_index, argument_count): | 237 def GenerateChecksAndCall(signature_index, argument_count): |
| 238 checks = [] | 238 checks = [] |
| 239 for i in range(0, argument_count): | 239 for i in range(0, argument_count): |
| 240 argument = signatures[signature_index][i] | 240 argument = signatures[signature_index][i] |
| 241 parameter_name = parameter_names[i] | 241 parameter_name = parameter_names[i] |
| 242 test_type = self._DartType(argument.type.id) | 242 test_type = self._DartType(argument.type.id) |
| 243 nullable = False or argument.type.nullable | |
|
Anton Muhin
2013/05/21 13:24:08
False or?
Andrei Mouravski
2013/05/21 18:39:14
I am not a smart person... :-)
On 2013/05/21 13:
| |
| 244 | |
| 243 if test_type in ['dynamic', 'Object']: | 245 if test_type in ['dynamic', 'Object']: |
| 244 checks.append('?%s' % parameter_name) | 246 checks.append('?%s' % parameter_name) |
| 245 elif not can_omit_type_check(test_type, i): | 247 elif not can_omit_type_check(test_type, i): |
| 248 nullable = True | |
| 246 checks.append('(%s is %s || %s == null)' % ( | 249 checks.append('(%s is %s || %s == null)' % ( |
| 247 parameter_name, test_type, parameter_name)) | 250 parameter_name, test_type, parameter_name)) |
| 251 | |
| 252 if nullable is False: | |
|
Anton Muhin
2013/05/21 13:24:08
nit: if not nullable
Andrei Mouravski
2013/05/21 18:39:14
Done.
| |
| 253 for signature in signatures: | |
| 254 if (argument not in signature or (len(signature) > i and | |
|
Anton Muhin
2013/05/21 13:24:08
why still argument not in signagture check
Andrei Mouravski
2013/05/21 18:39:14
Done.
| |
| 255 signature[i] != argument)): | |
| 256 checks.append('%s != null' % parameter_name) | |
| 257 break | |
| 258 | |
| 248 # There can be multiple presence checks. We need them all since a later | 259 # There can be multiple presence checks. We need them all since a later |
| 249 # optional argument could have been passed by name, leaving 'holes'. | 260 # optional argument could have been passed by name, leaving 'holes'. |
| 250 checks.extend(['!?%s' % name for name in parameter_names[argument_count:]] ) | 261 checks.extend(['!?%s' % name for name in parameter_names[argument_count:]] ) |
| 251 | 262 |
| 252 GenerateCall(signature_index, argument_count, checks) | 263 GenerateCall(signature_index, argument_count, checks) |
| 253 | 264 |
| 254 # TODO: Optimize the dispatch to avoid repeated checks. | 265 # TODO: Optimize the dispatch to avoid repeated checks. |
| 255 if len(signatures) > 1: | 266 if len(signatures) > 1: |
| 256 index_swaps = {} | 267 index_swaps = {} |
| 257 for signature_index, signature in enumerate(signatures): | 268 for signature_index, signature in enumerate(signatures): |
| (...skipping 322 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 580 if interface.parents: | 591 if interface.parents: |
| 581 parent = interface.parents[0] | 592 parent = interface.parents[0] |
| 582 if IsPureInterface(parent.type.id): | 593 if IsPureInterface(parent.type.id): |
| 583 walk(interface.parents) | 594 walk(interface.parents) |
| 584 else: | 595 else: |
| 585 walk(interface.parents[1:]) | 596 walk(interface.parents[1:]) |
| 586 return result | 597 return result |
| 587 | 598 |
| 588 def _DartType(self, type_name): | 599 def _DartType(self, type_name): |
| 589 return self._type_registry.DartType(type_name) | 600 return self._type_registry.DartType(type_name) |
| OLD | NEW |