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
transitiveClosurefunction. - Make
stronglyConnectedComponentsandtopologicalSortiterative rather than recursive to avoid stack overflows on very large graphs. - Require Dart 2.18
2.2.0 #
- Add a
secondarySortparameter 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:
crawlAsyncwill no longer ignore a node from the graph if thereadNodecallback 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,shortestPathsandstronglyConnectedComponentsnow have one generic parameter and have replaced thekeyparameter with optional params:{bool equals(T key1, T key2), int hashCode(T key)}. This follows the pattern used indart:collectionclassesHashMapandLinkedHashMap. 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
keyinshortestPathandshortestPaths.
0.1.3 #
- Added
shortestPathandshortestPathsfunctions. - Use
HashMapandHashSetfromdart:collectionforstronglyConnectedComponents. Improves runtime performance.
0.1.2+1 #
- Allow using non-dev Dart 2 SDK.
0.1.2 #
crawlAsyncsurfaces exceptions while crawling through the result stream rather than as uncaught asynchronous errors.
0.1.1 #
crawlAsyncwill now ignore nodes that are resolved tonull.
0.1.0 #
- Initial release with an implementation of
stronglyConnectedComponentsandcrawlAsync.