| Index: sdk/lib/_internal/compiler/implementation/js_backend/runtime_types.dart
|
| diff --git a/sdk/lib/_internal/compiler/implementation/js_backend/runtime_types.dart b/sdk/lib/_internal/compiler/implementation/js_backend/runtime_types.dart
|
| index e4b8122b9ccb05e3f61488b4786b28afcbd855d4..7feb4013b844d73ef177bc24fd779dee4a7eaea3 100644
|
| --- a/sdk/lib/_internal/compiler/implementation/js_backend/runtime_types.dart
|
| +++ b/sdk/lib/_internal/compiler/implementation/js_backend/runtime_types.dart
|
| @@ -2,68 +2,50 @@
|
| // for details. All rights reserved. Use of this source code is governed by a
|
| // BSD-style license that can be found in the LICENSE file.
|
|
|
| -library runtime_types;
|
| -
|
| -import '../dart2jslib.dart';
|
| -import '../elements/elements.dart';
|
| -import '../tree/tree.dart';
|
| -import '../universe/universe.dart';
|
| -import '../util/util.dart';
|
| +part of js_backend;
|
|
|
| class RuntimeTypeInformation {
|
| - /**
|
| - * Names used for elements in runtime type information. This map is kept to
|
| - * detect elements with the same name and use a different name instead.
|
| - */
|
| - final Map<String, Element> usedNames = new Map<String, Element>();
|
| -
|
| final Compiler compiler;
|
|
|
| - RuntimeTypeInformation(this.compiler) {
|
| - // Reserve the name 'dynamic' for the dynamic type.
|
| - usedNames['dynamic'] = compiler.dynamicClass;
|
| - }
|
| -
|
| - /** Get a unique name for the element. */
|
| - String getName(Element element) {
|
| - if (element == compiler.dynamicClass) return 'dynamic';
|
| - String guess = element.name.slowToString();
|
| - String name = guess;
|
| - int id = 0;
|
| - while (usedNames.containsKey(name) && usedNames[name] != element) {
|
| - name = '$guess@$id';
|
| - id++;
|
| - }
|
| - usedNames[name] = element;
|
| - return name;
|
| - }
|
| + RuntimeTypeInformation(this.compiler);
|
|
|
| // TODO(karlklose): remove when using type representations.
|
| - String buildStringRepresentation(DartType type) {
|
| + String getStringRepresentation(DartType type, {bool expandRawType: false}) {
|
| StringBuffer builder = new StringBuffer();
|
| void build(DartType t) {
|
| - builder.add(getName(t.element));
|
| + if (t is TypeVariableType) {
|
| + builder.add(t.name.slowToString());
|
| + return;
|
| + }
|
| + JavaScriptBackend backend = compiler.backend;
|
| + builder.add(backend.namer.getName(t.element));
|
| if (t is InterfaceType) {
|
| InterfaceType interface = t;
|
| - if (interface.arguments.isEmpty) return;
|
| - bool firstArgument = true;
|
| + ClassElement element = t.element;
|
| + if (element.typeVariables.isEmpty) return;
|
| + bool isRaw = interface.arguments.isEmpty;
|
| + if (isRaw && !expandRawType) return;
|
| builder.add('<');
|
| - for (DartType argument in interface.arguments) {
|
| - if (firstArgument) {
|
| - firstArgument = false;
|
| + Iterable items = isRaw ? element.typeVariables : interface.arguments;
|
| + var stringify = isRaw ? (_) => 'dynamic' : (type) => type.toString();
|
| + bool first = true;
|
| + for (var item in items) {
|
| + if (first) {
|
| + first = false;
|
| } else {
|
| builder.add(', ');
|
| }
|
| - build(argument);
|
| + builder.add(stringify(item));
|
| }
|
| builder.add('>');
|
| }
|
| }
|
| +
|
| build(type);
|
| return builder.toString();
|
| }
|
|
|
| - bool hasTypeArguments(DartType type) {
|
| + static bool hasTypeArguments(DartType type) {
|
| if (type is InterfaceType) {
|
| InterfaceType interfaceType = type;
|
| return !interfaceType.arguments.isEmpty;
|
| @@ -71,57 +53,12 @@ class RuntimeTypeInformation {
|
| return false;
|
| }
|
|
|
| - /**
|
| - * Map type variables to strings calling [:stringify:] and joins the results
|
| - * to a single string separated by commas.
|
| - * The argument [:hasValue:] is used to treat variables that will not receive
|
| - * a value at the use site of the code that is generated with this function.
|
| - */
|
| - static String stringifyTypeVariables(Link collection,
|
| - int numberOfInputs,
|
| - stringify(TypeVariableType variable,
|
| - bool hasValue)) {
|
| - int currentVariable = 0;
|
| - bool isFirst = true;
|
| - StringBuffer buffer = new StringBuffer();
|
| - collection.forEach((TypeVariableType variable) {
|
| - if (!isFirst) buffer.add(", ");
|
| - bool hasValue = currentVariable < numberOfInputs;
|
| - buffer.add(stringify(variable, hasValue));
|
| - isFirst = false;
|
| - currentVariable++;
|
| - });
|
| - return buffer.toString();
|
| - }
|
| -
|
| - /**
|
| - * Generate a string representation template for this element, using '#' to
|
| - * denote the place for the type argument input. If there are more type
|
| - * variables than [numberOfInputs], 'dynamic' is used as the value for these
|
| - * arguments.
|
| - */
|
| - String generateRuntimeTypeString(ClassElement element, int numberOfInputs) {
|
| - String elementName = getName(element);
|
| - if (element.typeVariables.isEmpty) return "$elementName";
|
| - String stringify(_, bool hasValue) => hasValue ? "' + # + '" : "dynamic";
|
| - String arguments = stringifyTypeVariables(element.typeVariables,
|
| - numberOfInputs,
|
| - stringify);
|
| - return "$elementName<$arguments>";
|
| - }
|
| -
|
| - /**
|
| - * Generate a string template for the runtime type fields that contain the
|
| - * type descriptions of the reified type arguments, using '#' to denote the
|
| - * place for the type argument value, or [:null:] if there are more than
|
| - * [numberOfInputs] type variables.
|
| - */
|
| - static String generateTypeVariableString(ClassElement element,
|
| - int numberOfInputs) {
|
| - String stringify(TypeVariableType variable, bool hasValue) {
|
| - return "'${variable.name.slowToString()}': #";
|
| + static int getTypeVariableIndex(TypeVariableType variable) {
|
| + ClassElement classElement = variable.element.getEnclosingClass();
|
| + Link<DartType> variables = classElement.typeVariables;
|
| + for (int index = 0; !variables.isEmpty;
|
| + index++, variables = variables.tail) {
|
| + if (variables.head == variable) return index;
|
| }
|
| - return stringifyTypeVariables(element.typeVariables, numberOfInputs,
|
| - stringify);
|
| }
|
| }
|
|
|