graphs 2.3.2 graphs: ^2.3.2 copied to clipboard
Graph algorithms that operate on graphs in any representation.
2.3.2 #
- Require Dart 3.4
- Update to the latest version of
package:dart_flutter_team_lints
.
2.3.1 #
- Update package repository after move.
2.3.0 #
- Add a
transitiveClosure
function. - Make
stronglyConnectedComponents
andtopologicalSort
iterative rather than recursive to avoid stack overflows on very large graphs. - Require Dart 2.18
2.2.0 #
- Add a
secondarySort
parameter to thetopologicalSort()
function which applies an additional lexical sort where that doesn't break the topological sort.
2.1.0 #
- Add a
topologicalSort()
function.
2.0.0 #
- Breaking:
crawlAsync
will no longer ignore a node from the graph if thereadNode
callback returns null.
1.0.0 #
- Migrate to null safety.
- Breaking: Paths from
shortestPath[s]
are now returned as iterables to reduce memory consumption of the algorithm to O(n).
0.2.0 #
- BREAKING
shortestPath
,shortestPaths
andstronglyConnectedComponents
now have one generic parameter and have replaced thekey
parameter with optional params:{bool equals(T key1, T key2), int hashCode(T key)}
. This follows the pattern used indart:collection
classesHashMap
andLinkedHashMap
. It improves the usability and performance of the case where the source values are directly usable in a hash data structure.
0.1.3+1 #
- Fixed a bug with non-identity
key
inshortestPath
andshortestPaths
.
0.1.3 #
- Added
shortestPath
andshortestPaths
functions. - Use
HashMap
andHashSet
fromdart:collection
forstronglyConnectedComponents
. Improves runtime performance.
0.1.2+1 #
- Allow using non-dev Dart 2 SDK.
0.1.2 #
crawlAsync
surfaces exceptions while crawling through the result stream rather than as uncaught asynchronous errors.
0.1.1 #
crawlAsync
will now ignore nodes that are resolved tonull
.
0.1.0 #
- Initial release with an implementation of
stronglyConnectedComponents
andcrawlAsync
.