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: |