collection 1.14.5

Contains utility functions and classes in the style of dart:collection to make working with collections easier.

Algorithms #

The package contains functions that operate on lists.

It contains ways to shuffle a List, do binary search on a sorted List, and various sorting algorithms.

Equality #

The package provides a way to specify the equality of elements and collections.

Collections in Dart have no inherent equality. Two sets are not equal, even if they contain exactly the same objects as elements.

The Equality interface provides a way to say define such an equality. In this case, for example, const SetEquality(const IdentityEquality()) is an equality that considers two sets equal exactly if they contain identical elements.

Equalities are provided for Iterables, Lists, Sets, and Maps, as well as combinations of these, such as:

const MapEquality(const IdentityEquality(), const ListEquality());

This equality considers maps equal if they have identical keys, and the corresponding values are lists with equal (operator==) values.

Iterable Zip #

Utilities for "zipping" a list of iterables into an iterable of lists.

Priority Queue #

An interface and implementation of a priority queue.

Wrappers #

The package contains classes that "wrap" a collection.

A wrapper class contains an object of the same type, and it forwards all methods to the wrapped object.

Wrapper classes can be used in various ways, for example to restrict the type of an object to that of a supertype, or to change the behavior of selected functions on an existing object.

Features and bugs #

Please file feature requests and bugs at the issue tracker.

1.14.5 #

  • Fix issue with EmptyUnmodifiableSet's stubs that were introduced in 1.14.4.

1.14.4 #

  • Add implementation stubs of upcoming Dart 2.0 core library methods, namely new methods for classes that implement Iterable, List, Map, Queue, and Set.

1.14.3 #

  • Fix MapKeySet.lookup to be a valid override in strong mode.

1.14.2 #

  • Add type arguments to SyntheticInvocation.

1.14.1 #

  • Make Equality implementations accept null as argument to hash.

1.14.0 #

  • Add CombinedListView, a view of several lists concatenated together.
  • Add CombinedIterableView, a view of several iterables concatenated together.
  • Add CombinedMapView, a view of several maps concatenated together.

1.13.0 #

  • Add EqualityBy

1.12.0 #

  • Add CaseInsensitiveEquality.

  • Fix bug in equalsIgnoreAsciiCase.

1.11.0 #

  • Add EqualityMap and EqualitySet classes which use Equality objects for key and element equality, respectively.

1.10.1 #

  • Set.difference now takes a Set<Object> as argument.

1.9.1 #

  • Fix some documentation bugs.

1.9.0 #

  • Add a top-level stronglyConnectedComponents() function that returns the strongly connected components in a directed graph.

1.8.0 #

  • Add a top-level mapMap() function that works like on a Map.

  • Add a top-level mergeMaps() function that creates a new map with the combined contents of two existing maps.

  • Add a top-level groupBy() function that converts an Iterable to a Map by grouping its elements using a function.

  • Add top-level minBy() and maxBy() functions that return the minimum and maximum values in an Iterable, respectively, ordered by a derived value.

  • Add a top-level transitiveClosure() function that returns the transitive closure of a directed graph.

1.7.0 #

  • Add a const UnmodifiableSetView.empty() constructor.

1.6.0 #

  • Add a UnionSet class that provides a view of the union of a set of sets.

  • Add a UnionSetController class that provides a convenient way to manage the contents of a UnionSet.

  • Fix another incorrectly-declared generic type.

1.5.1 #

  • Fix an incorrectly-declared generic type.

1.5.0 #

  • Add DelegatingIterable.typed(), DelegatingList.typed(), DelegatingSet.typed(), DelegatingMap.typed(), and DelegatingQueue.typed() static methods. These wrap untyped instances of these classes with the correct type parameter, and assert the types of values as they're accessed.

  • Fix the types for binarySearch() and lowerBound() so they no longer require all arguments to be comparable.

  • Add generic annotations to insertionSort() and mergeSort().

1.4.1 #

  • Fix all strong mode warnings.

1.4.0 #

  • Add a new PriorityQueue() constructor that forwards to new HeapPriorityQueue().

  • Deprecate top-level libraries other than package:collection/collection.dart, which exports these libraries' interfaces.

1.3.0 #

  • Add lowerBound to binary search for values that might not be present.

  • Verify that the is valid for CanonicalMap.[].

1.2.0 #

  • Add string comparators that ignore ASCII case and sort numbers numerically.

1.1.3 #

  • Fix type inconsistencies with Map and Set.

1.1.2 #

  • Export UnmodifiableMapView from the Dart core libraries.

1.1.1 #

  • Bug-fix for signatures of isValidKey arguments of CanonicalizedMap.

1.1.0 #

  • Add a QueueList class that implements both Queue and List.

0.9.4 #

  • Add a CanonicalizedMap class that canonicalizes its keys to provide a custom equality relation.

0.9.3+1 #

  • Fix all analyzer hints.

0.9.3 #

  • Add a MapKeySet class that exposes an unmodifiable Set view of a Map's keys.

  • Add a MapValueSet class that takes a function from values to keys and uses it to expose a Set view of a Map's values.

Use this package as a library

1. Depend on it

Add this to your package's pubspec.yaml file:

  collection: ^1.14.5

2. Install it

You can install packages from the command line:

with pub:

$ pub get

Alternatively, your editor might support pub get. Check the docs for your editor to learn more.

3. Import it

Now in your Dart code, you can use:

import 'package:collection/collection.dart';
Describes how popular the package is relative to other packages. [more]
Code health derived from static analysis. [more]
Reflects how tidy and up-to-date the package is. [more]
Weighted score of the above. [more]
Learn more about scoring.

The package version is not analyzed, because it does not support Dart 2. Until this is resolved, the package will receive a health and maintenance score of 0.

Analysis issues and suggestions

Support Dart 2 in pubspec.yaml.

The SDK constraint in pubspec.yaml doesn't allow the Dart 2.0.0 release. For information about upgrading it to be Dart 2 compatible, please see

Maintenance issues and suggestions

Make sure dartdoc successfully runs on your package's source files. (-10 points)

Dependencies were not resolved.


Package Constraint Resolved Available
Direct dependencies
Dart SDK >=1.21.0 <2.0.0