Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 dart.collection; | 5 part of dart.collection; |
| 6 | 6 |
| 7 /** Common parts of [HashSet] and [LinkedHashSet] implementations. */ | 7 /** Common parts of [HashSet] and [LinkedHashSet] implementations. */ |
| 8 abstract class _HashSetBase<E> extends SetBase<E> { | 8 abstract class _HashSetBase<E> extends SetBase<E> { |
| 9 | 9 |
| 10 // The following two methods override the ones in SetBase. | 10 // The following two methods override the ones in SetBase. |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 64 * the objects' intrinsic [Object.operator==] and [Object.hashCode]. | 64 * the objects' intrinsic [Object.operator==] and [Object.hashCode]. |
| 65 * | 65 * |
| 66 * If [isValidKey] is omitted, it defaults to testing if the object is an | 66 * If [isValidKey] is omitted, it defaults to testing if the object is an |
| 67 * [E] instance. | 67 * [E] instance. |
| 68 * | 68 * |
| 69 * If you supply one of [equals] and [hashCode], | 69 * If you supply one of [equals] and [hashCode], |
| 70 * you should generally also to supply the other. | 70 * you should generally also to supply the other. |
| 71 * An example would be using [identical] and [identityHashCode], | 71 * An example would be using [identical] and [identityHashCode], |
| 72 * which is equivalent to using the shorthand [LinkedSet.identity]). | 72 * which is equivalent to using the shorthand [LinkedSet.identity]). |
| 73 */ | 73 */ |
| 74 external factory HashSet({ bool equals(E e1, E e2), | 74 external factory HashSet({bool equals(E e1, E e2), |
| 75 int hashCode(E e), | 75 int hashCode(E e), |
| 76 bool isValidKey(potentialKey) }); | 76 bool isValidKey(potentialKey)}); |
| 77 | 77 |
| 78 /** | 78 /** |
| 79 * Creates an unordered identity-based set. | 79 * Creates an unordered identity-based set. |
| 80 * | 80 * |
| 81 * Effectively a shorthand for: | 81 * Effectively a shorthand for: |
| 82 * | 82 * |
| 83 * new HashSet(equals: identical, hashCode: identityHashCodeOf) | 83 * new HashSet(equals: identical, hashCode: identityHashCodeOf) |
| 84 */ | 84 */ |
| 85 external factory HashSet.identity(); | 85 external factory HashSet.identity(); |
| 86 | 86 |
| 87 /** | 87 /** |
| 88 * Create a hash set containing the elements of [iterable]. | 88 * Create a hash set containing all of [elements]. |
|
floitsch
2015/01/05 14:45:30
all [elements]. ?
Lasse Reichstein Nielsen
2015/01/06 10:14:45
Done.
| |
| 89 * | 89 * |
| 90 * Creates a hash set as by `new HashSet<E>()` and adds each element of | 90 * Creates a hash set as by `new HashSet<E>()` and adds each element of |
| 91 * `iterable` to this set in the order they are iterated. | 91 * `elements` to this set in the order they are iterated. |
| 92 * | |
| 93 * All the [elements] should be assignable to [E]. | |
|
Søren Gjesse
2015/01/05 15:35:15
[E] -> `E`
Lasse Reichstein Nielsen
2015/01/06 10:14:45
Why? The [E] is in scope, so we might as well link
Søren Gjesse
2015/01/06 12:09:05
Good - I am not exactly clear on the dartdoc scopi
Lasse Reichstein Nielsen
2015/01/07 07:56:45
The spec tries to specify how references in DartDo
| |
| 94 * The `elements` iterable itself may have any element type, so this | |
| 95 * constructor can be used to down-cast a `Set`, for example as: | |
| 96 * | |
| 97 * Set<SuperType> superSet = ...; | |
| 98 * Set<SubType> subSet = | |
| 99 * new HashSet<SubType>.from(superSet.where((e) => e is SubType)); | |
| 92 */ | 100 */ |
| 93 factory HashSet.from(Iterable<E> iterable) { | 101 factory HashSet.from(Iterable elements) { |
| 94 return new HashSet<E>()..addAll(iterable); | 102 HashSet<E> result = new HashSet<E>(); |
| 103 for (E e in elements) result.add(e); | |
| 104 return result; | |
| 95 } | 105 } |
| 96 | 106 |
| 97 /** | 107 /** |
| 98 * Provides an iterator that iterates over the elements of this set. | 108 * Provides an iterator that iterates over the elements of this set. |
| 99 * | 109 * |
| 100 * The order of iteration is unspecified, | 110 * The order of iteration is unspecified, |
| 101 * but consistent between changes to the set. | 111 * but consistent between changes to the set. |
| 102 */ | 112 */ |
| 103 Iterator<E> get iterator; | 113 Iterator<E> get iterator; |
| 104 } | 114 } |
| OLD | NEW |