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

Side by Side Diff: sdk/lib/_internal/compiler/implementation/js_backend/checked_mode_helpers.dart

Issue 304153014: Remove element from DynamicType. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Fix infinite loop. Created 6 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 part of js_backend; 5 part of js_backend;
6 6
7 class CheckedModeHelper { 7 class CheckedModeHelper {
8 final String name; 8 final String name;
9 9
10 const CheckedModeHelper(String this.name); 10 const CheckedModeHelper(String this.name);
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after
88 arguments.add(js.string(additionalArgument)); 88 arguments.add(js.string(additionalArgument));
89 } 89 }
90 } 90 }
91 91
92 class TypeVariableCheckedModeHelper extends CheckedModeHelper { 92 class TypeVariableCheckedModeHelper extends CheckedModeHelper {
93 const TypeVariableCheckedModeHelper(String name) : super(name); 93 const TypeVariableCheckedModeHelper(String name) : super(name);
94 94
95 void generateAdditionalArguments(SsaCodeGenerator codegen, 95 void generateAdditionalArguments(SsaCodeGenerator codegen,
96 HTypeConversion node, 96 HTypeConversion node,
97 List<jsAst.Expression> arguments) { 97 List<jsAst.Expression> arguments) {
98 assert(node.typeExpression.kind == TypeKind.TYPE_VARIABLE); 98 assert(node.typeExpression.isTypeVariable);
99 codegen.use(node.typeRepresentation); 99 codegen.use(node.typeRepresentation);
100 arguments.add(codegen.pop()); 100 arguments.add(codegen.pop());
101 } 101 }
102 } 102 }
103 103
104 class SubtypeCheckedModeHelper extends CheckedModeHelper { 104 class SubtypeCheckedModeHelper extends CheckedModeHelper {
105 const SubtypeCheckedModeHelper(String name) : super(name); 105 const SubtypeCheckedModeHelper(String name) : super(name);
106 106
107 void generateAdditionalArguments(SsaCodeGenerator codegen, 107 void generateAdditionalArguments(SsaCodeGenerator codegen,
108 HTypeConversion node, 108 HTypeConversion node,
109 List<jsAst.Expression> arguments) { 109 List<jsAst.Expression> arguments) {
110 DartType type = node.typeExpression; 110 DartType type = node.typeExpression;
111 Element element = type.element; 111 Element element = type.element;
112 String isField = codegen.backend.namer.operatorIs(element); 112 String isField = codegen.backend.namer.operatorIs(element);
113 arguments.add(js.string(isField)); 113 arguments.add(js.string(isField));
114 codegen.use(node.typeRepresentation); 114 codegen.use(node.typeRepresentation);
115 arguments.add(codegen.pop()); 115 arguments.add(codegen.pop());
116 String asField = codegen.backend.namer.substitutionName(element); 116 String asField = codegen.backend.namer.substitutionName(element);
117 arguments.add(js.string(asField)); 117 arguments.add(js.string(asField));
118 } 118 }
119 } 119 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698