Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1849)

Unified Diff: sdk/lib/_internal/js_runtime/lib/js_helper.dart

Issue 1220793012: Revert "Fix runtimeType.toString for tear-offs." (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: sdk/lib/_internal/js_runtime/lib/js_helper.dart
diff --git a/sdk/lib/_internal/js_runtime/lib/js_helper.dart b/sdk/lib/_internal/js_runtime/lib/js_helper.dart
index c39c6dc0131b3c33d7a26124eada257f6f2fd73d..291e1784bd851e8183963890355c0cf10ec4bf73 100644
--- a/sdk/lib/_internal/js_runtime/lib/js_helper.dart
+++ b/sdk/lib/_internal/js_runtime/lib/js_helper.dart
@@ -2283,14 +2283,11 @@ abstract class Closure implements Function {
// Object.create to create the desired prototype.
//
// TODO(sra): Perhaps cache the prototype to avoid the allocation.
- TearOffClosure dummyObject = isStatic
- ? new StaticClosure()
- : new BoundClosure(null, null, null, null);
-
- var prototype = JS(
- 'TearOffClosure',
- 'Object.create(#.constructor.prototype)',
- dummyObject);
+ var prototype = isStatic
+ ? JS('StaticClosure', 'Object.create(#.constructor.prototype)',
+ new StaticClosure())
+ : JS('BoundClosure', 'Object.create(#.constructor.prototype)',
+ new BoundClosure(null, null, null, null));
JS('', '#.\$initialize = #', prototype, JS('', '#.constructor', prototype));
var constructor = isStatic
@@ -2303,23 +2300,7 @@ abstract class Closure implements Function {
// It is necessary to set the constructor property, otherwise it will be
// "Object".
- // We want the constructor.name property to have the name of the
- // StaticClosure or BoundClosure class.
- // Most browsers (except IE10) don't allow to change the name of a function
- // as such we can't just set the property. However, we can work around this
- // by creating an empty object with the name property set to the correct
- // value and then setting the prototype to the original constructor.
- // This works for all browsers except IE10 which doesn't have a way to
- // change the prototype. There we simply set the name.
- if (JS('bool', 'typeof Object.setPrototypeOf != "undefined"')) {
- String tearOffClassName = JS('String', '#.constructor.name', dummyObject);
- JS('', '#.constructor = {name: #}', prototype, tearOffClassName);
- JS('', 'Object.setPrototypeOf(#.constructor, #)', prototype, constructor);
- } else {
- // IE10.
- JS('', '#.constructor = #', prototype, constructor);
- JS('', '#.constructor.name = #', prototype, propertyName);
- }
+ JS('', '#.constructor = #', prototype, constructor);
JS('', '#.prototype = #', constructor, prototype);
« no previous file with comments | « pkg/compiler/lib/src/js_emitter/old_emitter/setup_program_builder.dart ('k') | tests/language/runtime_type2_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698