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 IterableBase<E> implements Set<E> { | 8 abstract class _HashSetBase<E> extends IterableBase<E> implements Set<E> { |
9 | 9 |
10 // Set. | 10 // Set. |
11 bool containsAll(Iterable<Object> other) { | 11 bool containsAll(Iterable<Object> other) { |
12 for (Object object in other) { | 12 for (Object object in other) { |
13 if (!this.contains(object)) return false; | 13 if (!this.contains(object)) return false; |
14 } | 14 } |
15 return true; | 15 return true; |
16 } | 16 } |
17 | 17 |
18 /** Create a new Set of the same type as this. */ | 18 /** Create a new Set of the same type as this. */ |
19 Set _newSet(); | 19 HashSet<E> _newSet(); |
20 | 20 |
21 Set<E> intersection(Set<Object> other) { | 21 Set<E> intersection(Set<Object> other) { |
22 Set<E> result = _newSet(); | 22 Set<E> result = _newSet(); |
23 if (other.length < this.length) { | 23 if (other.length < this.length) { |
24 for (var element in other) { | 24 for (var element in other) { |
25 if (this.contains(element)) result.add(element); | 25 if (this.contains(element)) result.add(element); |
26 } | 26 } |
27 } else { | 27 } else { |
28 for (E element in this) { | 28 for (E element in this) { |
29 if (other.contains(element)) result.add(element); | 29 if (other.contains(element)) result.add(element); |
(...skipping 17 matching lines...) Expand all Loading... |
47 void retainAll(Iterable objectsToRetain) { | 47 void retainAll(Iterable objectsToRetain) { |
48 Set retainSet; | 48 Set retainSet; |
49 if (objectsToRetain is Set) { | 49 if (objectsToRetain is Set) { |
50 retainSet = objectsToRetain; | 50 retainSet = objectsToRetain; |
51 } else { | 51 } else { |
52 retainSet = objectsToRetain.toSet(); | 52 retainSet = objectsToRetain.toSet(); |
53 } | 53 } |
54 retainWhere(retainSet.contains); | 54 retainWhere(retainSet.contains); |
55 } | 55 } |
56 | 56 |
| 57 List<E> toList({bool growable: true}) { |
| 58 List<E> result = new List<E>()..length = this.length; |
| 59 int i = 0; |
| 60 for (E element in this) result[i++] = element; |
| 61 return result; |
| 62 } |
| 63 |
| 64 Set<E> toSet() => _newSet()..addAll(this); |
| 65 |
57 // TODO(zarah) Remove this, and let it be inherited by IterableBase | 66 // TODO(zarah) Remove this, and let it be inherited by IterableBase |
58 String toString() => IterableMixinWorkaround.toStringIterable(this, '{', '}'); | 67 String toString() => IterableMixinWorkaround.toStringIterable(this, '{', '}'); |
59 } | 68 } |
60 | 69 |
61 /** | 70 /** |
62 * A [HashSet] is a hash-table based [Set] implementation. | 71 * A [HashSet] is a hash-table based [Set] implementation. |
63 * | 72 * |
64 * The elements of a `HashSet` must have consistent [Object.operator==] | 73 * The elements of a `HashSet` must have consistent equality |
65 * and [Object.hashCode] implementations. This means that the `==` operator | 74 * and hashCode implementations. This means that the equals operation |
66 * must define a stable equivalence relation on the elements (reflexive, | 75 * must define a stable equivalence relation on the elements (reflexive, |
67 * anti-symmetric, transitive, and consistent over time), and that `hashCode` | 76 * anti-symmetric, transitive, and consistent over time), and that the hashCode |
68 * must be the same for objects that are considered equal by `==`. | 77 * must consistent with equality, so that the same for objects that are |
| 78 * considered equal. |
69 * | 79 * |
70 * The set allows `null` as an element. | 80 * The set allows `null` as an element. |
71 * | 81 * |
72 * Most simple operations on `HashSet` are done in constant time: [add], | 82 * Most simple operations on `HashSet` are done in constant time: [add], |
73 * [contains], [remove], and [length]. | 83 * [contains], [remove], and [length]. |
74 */ | 84 */ |
75 class HashSet<E> extends _HashSetBase<E> { | 85 class HashSet<E> implements Set<E> { |
76 external HashSet(); | 86 /** |
| 87 * Create a hash set using the provided [equals] as equality. |
| 88 * |
| 89 * The provided [equals] must define a stable equivalence relation, and |
| 90 * [hashCode] must be consistent with [equals]. If the [equals] or [hashCode] |
| 91 * methods won't work on all objects, but only to instances of E, the |
| 92 * [isValidKey] predicate can be used to restrict the keys that they are |
| 93 * applied to. Any key for which [isValidKey] returns false is automatically |
| 94 * assumed to not be in the set. |
| 95 * |
| 96 * If [equals], [hashCode] and [isValidKey] are omitted, the set uses |
| 97 * the objects' intrinsic [Object.operator==] and [Object.hashCode]. |
| 98 * |
| 99 * If [isValidKey] is omitted, it defaults to testing if the object is an |
| 100 * [E] instance. |
| 101 * |
| 102 * If [equals] is [identical], this creates an identity set. Any hashCode |
| 103 * is compatible with [identical], and it applies to all objects, so |
| 104 * [hashCode] and [isValidKey] can safely be omitted. |
| 105 */ |
| 106 external factory HashSet({ bool equals(E e1, E e2), |
| 107 int hashCode(E e), |
| 108 bool isValidKey(potentialKey) }); |
77 | 109 |
| 110 /** |
| 111 * Create a hash set containing the elements of [iterable]. |
| 112 * |
| 113 * Creates a hash set as by `new HashSet<E>()` and adds each element of |
| 114 * `iterable` to this set in the order they are iterated. |
| 115 */ |
78 factory HashSet.from(Iterable<E> iterable) { | 116 factory HashSet.from(Iterable<E> iterable) { |
79 return new HashSet<E>()..addAll(iterable); | 117 return new HashSet<E>()..addAll(iterable); |
80 } | 118 } |
81 | |
82 // Iterable. | |
83 external Iterator<E> get iterator; | |
84 | |
85 external int get length; | |
86 | |
87 external bool get isEmpty; | |
88 | |
89 external bool get isNotEmpty; | |
90 | |
91 external bool contains(Object object); | |
92 | |
93 // Set. | |
94 external void add(E element); | |
95 | |
96 external void addAll(Iterable<E> objects); | |
97 | |
98 external bool remove(Object object); | |
99 | |
100 external void removeAll(Iterable<Object> objectsToRemove); | |
101 | |
102 external void removeWhere(bool test(E element)); | |
103 | |
104 external void retainWhere(bool test(E element)); | |
105 | |
106 external void clear(); | |
107 | |
108 Set<E> _newSet() => new HashSet<E>(); | |
109 } | 119 } |
OLD | NEW |