| Index: sdk/lib/collection_dev/to_string.dart
|
| diff --git a/sdk/lib/collection_dev/to_string.dart b/sdk/lib/collection_dev/to_string.dart
|
| deleted file mode 100644
|
| index c55ccac639b9051e12037f210cc896c1755a27b2..0000000000000000000000000000000000000000
|
| --- a/sdk/lib/collection_dev/to_string.dart
|
| +++ /dev/null
|
| @@ -1,161 +0,0 @@
|
| -// Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
|
| -// 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.
|
| -
|
| -part of dart.collection.dev;
|
| -
|
| -/**
|
| - * Temporary move `toString` methods into this class.
|
| - */
|
| -class ToString {
|
| - // TODO(jjb): visiting list should be an identityHashSet when it exists
|
| -
|
| - /**
|
| - * Returns a string representing the specified collection. If the
|
| - * collection is a [List], the returned string looks like this:
|
| - * [:'[element0, element1, ... elementN]':]. The value returned by its
|
| - * [toString] method is used to represent each element. If the specified
|
| - * collection is not a list, the returned string looks like this:
|
| - * [:{element0, element1, ... elementN}:]. In other words, the strings
|
| - * returned for lists are surrounded by square brackets, while the strings
|
| - * returned for other collections are surrounded by curly braces.
|
| - *
|
| - * If the specified collection contains a reference to itself, either
|
| - * directly or indirectly through other collections or maps, the contained
|
| - * reference is rendered as [:'[...]':] if it is a list, or [:'{...}':] if
|
| - * it is not. This prevents the infinite regress that would otherwise occur.
|
| - * So, for example, calling this method on a list whose sole element is a
|
| - * reference to itself would return [:'[[...]]':].
|
| - *
|
| - * A typical implementation of a collection's [toString] method will
|
| - * simply return the results of this method applied to the collection.
|
| - */
|
| - static String collectionToString(Collection c) {
|
| - var result = new StringBuffer();
|
| - _emitCollection(c, result, new List());
|
| - return result.toString();
|
| - }
|
| -
|
| - /**
|
| - * Appends a string representing the specified collection to the specified
|
| - * string buffer. The string is formatted as per [collectionToString].
|
| - * The [:visiting:] list contains references to all of the enclosing
|
| - * collections and maps (which are currently in the process of being
|
| - * emitted into [:result:]). The [:visiting:] parameter allows this method to
|
| - * generate a [:'[...]':] or [:'{...}':] where required. In other words,
|
| - * it allows this method and [_emitMap] to identify recursive collections
|
| - * and maps.
|
| - */
|
| - static void _emitCollection(Collection c,
|
| - StringBuffer result,
|
| - List visiting) {
|
| - visiting.add(c);
|
| - bool isList = c is List;
|
| - result.add(isList ? '[' : '{');
|
| -
|
| - bool first = true;
|
| - for (var e in c) {
|
| - if (!first) {
|
| - result.add(', ');
|
| - }
|
| - first = false;
|
| - _emitObject(e, result, visiting);
|
| - }
|
| -
|
| - result.add(isList ? ']' : '}');
|
| - visiting.removeLast();
|
| - }
|
| -
|
| - /**
|
| - * Appends a string representing the specified object to the specified
|
| - * string buffer. If the object is a [Collection] or [Map], it is formatted
|
| - * as per [collectionToString] or [mapToString]; otherwise, it is formatted
|
| - * by invoking its own [toString] method.
|
| - *
|
| - * The [:visiting:] list contains references to all of the enclosing
|
| - * collections and maps (which are currently in the process of being
|
| - * emitted into [:result:]). The [:visiting:] parameter allows this method
|
| - * to generate a [:'[...]':] or [:'{...}':] where required. In other words,
|
| - * it allows this method and [_emitCollection] to identify recursive maps
|
| - * and collections.
|
| - */
|
| - static void _emitObject(Object o, StringBuffer result, List visiting) {
|
| - if (o is Collection) {
|
| - if (_containsRef(visiting, o)) {
|
| - result.add(o is List ? '[...]' : '{...}');
|
| - } else {
|
| - _emitCollection(o, result, visiting);
|
| - }
|
| - } else if (o is Map) {
|
| - if (_containsRef(visiting, o)) {
|
| - result.add('{...}');
|
| - } else {
|
| - _emitMap(o, result, visiting);
|
| - }
|
| - } else { // o is neither a collection nor a map
|
| - result.add(o);
|
| - }
|
| - }
|
| -
|
| - /**
|
| - * Returns true if the specified collection contains the specified object
|
| - * reference.
|
| - */
|
| - static _containsRef(Collection c, Object ref) {
|
| - for (var e in c) {
|
| - if (identical(e, ref)) return true;
|
| - }
|
| - return false;
|
| - }
|
| -
|
| - /**
|
| - * Returns a string representing the specified map. The returned string
|
| - * looks like this: [:'{key0: value0, key1: value1, ... keyN: valueN}':].
|
| - * The value returned by its [toString] method is used to represent each
|
| - * key or value.
|
| - *
|
| - * If the map collection contains a reference to itself, either
|
| - * directly as a key or value, or indirectly through other collections
|
| - * or maps, the contained reference is rendered as [:'{...}':]. This
|
| - * prevents the infinite regress that would otherwise occur. So, for example,
|
| - * calling this method on a map whose sole entry maps the string key 'me'
|
| - * to a reference to the map would return [:'{me: {...}}':].
|
| - *
|
| - * A typical implementation of a map's [toString] method will
|
| - * simply return the results of this method applied to the collection.
|
| - */
|
| - static String mapToString(Map m) {
|
| - var result = new StringBuffer();
|
| - _emitMap(m, result, new List());
|
| - return result.toString();
|
| - }
|
| -
|
| - /**
|
| - * Appends a string representing the specified map to the specified
|
| - * string buffer. The string is formatted as per [mapToString].
|
| - * The [:visiting:] list contains references to all of the enclosing
|
| - * collections and maps (which are currently in the process of being
|
| - * emitted into [:result:]). The [:visiting:] parameter allows this method
|
| - * to generate a [:'[...]':] or [:'{...}':] where required. In other words,
|
| - * it allows this method and [_emitCollection] to identify recursive maps
|
| - * and collections.
|
| - */
|
| - static void _emitMap(Map m, StringBuffer result, List visiting) {
|
| - visiting.add(m);
|
| - result.add('{');
|
| -
|
| - bool first = true;
|
| - m.forEach((k, v) {
|
| - if (!first) {
|
| - result.add(', ');
|
| - }
|
| - first = false;
|
| - _emitObject(k, result, visiting);
|
| - result.add(': ');
|
| - _emitObject(v, result, visiting);
|
| - });
|
| -
|
| - result.add('}');
|
| - visiting.removeLast();
|
| - }
|
| -}
|
|
|