Chromium Code Reviews| Index: sdk/lib/html/scripts/systemhtml.py |
| diff --git a/sdk/lib/html/scripts/systemhtml.py b/sdk/lib/html/scripts/systemhtml.py |
| index 438fde8c239a51d1f07f04ac9008a6c736cf229d..ead8bd024e75be29333ecd0503602411683ba34b 100644 |
| --- a/sdk/lib/html/scripts/systemhtml.py |
| +++ b/sdk/lib/html/scripts/systemhtml.py |
| @@ -802,21 +802,12 @@ class Dart2JSBackend(HtmlDartGenerator): |
| PARAMS=', '.join(target_parameters)) |
| def GenerateChecksAndCall(operation, argument_count): |
| - checks = [] |
| - for i in range(0, argument_count): |
| - argument = operation.arguments[i] |
| - parameter_name = parameter_names[i] |
| - test_type = self._DartType(argument.type.id) |
| - if test_type in ['dynamic', 'Object']: |
| - checks.append('?%s' % parameter_name) |
| - elif test_type != parameter_types[i]: |
| - checks.append('(?%s && (%s is %s || %s == null))' % ( |
| - parameter_name, parameter_name, test_type, parameter_name)) |
| - |
| - checks.extend(['!?%s' % name for name in parameter_names[argument_count:]]) |
| - # There can be multiple presence checks. We need them all since a later |
| - # optional argument could have been passed by name, leaving 'holes'. |
| - GenerateCall(operation, argument_count, checks) |
| + GenerateCall(operation, argument_count, |
| + self._OverloadChecks( |
|
podivilov
2012/12/28 16:17:16
maybe introduce a local?
Anton Muhin
2012/12/29 12:02:12
Let's see how the things will unfold.
|
| + operation, |
| + parameter_names, |
| + argument_count, |
| + can_omit_type_check=lambda type, pos: type == parameter_types[pos])) |
| # TODO: Optimize the dispatch to avoid repeated checks. |
| if len(operations) > 1: |