Commit Graph

83 Commits

Author SHA1 Message Date
4abef5b294 Add missing MutNode.retain_reachable and bump docs. 2025-01-10 09:29:39 -05:00
651ce5fd84 Tighten up mark-and-compact GC.
Now it is in-place and should take less space for at least some workloads. See
TODOs left behind for thoughts on future directions it may make sense to go in
for performance tuning.

This still needs better test coverage, but these code improvements should make
it clear that there are no obvious fundamental flaws to this approach.
2025-01-10 09:29:39 -05:00
d94fd76d94 Use MaybeUninit instead of writing directly into uninitialized Vec.
This addresses a precondition error which is caught in newer stdlib.
2025-01-10 09:29:39 -05:00
1fcff8f4eb Hit it with the cargo fmt bat. 2025-01-10 09:29:39 -05:00
d627b8b964 Accommodate clippy suggestions. 2025-01-10 09:29:39 -05:00
063fedd709 Small readability improvements to satisfy lints. 2025-01-10 09:29:39 -05:00
147e6828d7 Small improvements to doc comments. 2025-01-10 09:29:39 -05:00
f54651ec4d Clean up some compilation warnings. 2025-01-10 09:29:39 -05:00
59e02dd89f Use a type that can actually be named for parent and child iteration in View. 2019-07-30 17:01:32 -04:00
6df253c3cc Fix formatting to be Markdown-friendly. 2019-07-25 22:02:03 -04:00
a35534da10 Bump README and change from org-mode to Markdown. 2019-07-25 22:01:36 -04:00
8af9689fc1 Version bump. 2019-07-25 21:53:40 -04:00
508d31f5b4 Further documentation bump. 2019-07-25 21:53:22 -04:00
112b6865de Move mark & compact GC to top-level module. 2019-07-23 17:56:56 -04:00
650b240dc5 Big documentation bump. More to come. 2019-07-23 17:55:35 -04:00
889c4a6d00 Correct lifetime oversights that lead to unsafety in view.
Some cleanup, too.
2019-07-23 12:53:53 -04:00
e8faceb964 Syntactic cleanup to reduce linebreaks added by rustfmt. 2019-07-23 12:53:17 -04:00
983ca4ca45 Delete empty file. 2019-07-23 12:52:46 -04:00
74d972de59 PartialEq and Eq for EdgeRef/NodeRef. 2019-07-23 01:59:30 -04:00
ff9cdcb0b9 Debug impl for EdgeRef and NodeRef. 2019-07-23 01:45:35 -04:00
4252119879 Version bump for new APIs. 2019-07-23 01:12:29 -04:00
01497be3e8 Ditch AppendOnlyGraph, which was broken and unfixable. 2019-07-23 01:11:59 -04:00
154e49c9f0 Added the view module and a few basic tests. 2019-07-23 01:09:56 -04:00
50bdbb41a7 Improved error message 2019-07-22 12:02:50 -04:00
2bc8e47843 Flesh out AppendOnlyGraph with new append_edge method. 2019-07-17 20:26:25 -04:00
f54bd3ace0 AppendOnlyGraph.add_edge doesn't need &mut self. 2019-07-17 20:07:30 -04:00
8b2011d104 Impl Clone and Copy for nav traits. 2019-07-17 19:32:22 -04:00
2f63b80e36 Add AppendOnlyGraph, to allow safe appends without invalidating pointers. 2019-07-17 19:21:27 -04:00
bbb9be1ae6 Actually add rustfmt.toml. 2019-07-13 23:07:38 -04:00
072a28fa76 Set indentation correctly and run rustfmt on everything. 2019-07-13 23:07:09 -04:00
d6de8fb161 Update to Rust 2018 and use pub(crate) for hidden APIs. 2019-07-13 22:38:17 -04:00
c1a24ff1a6 Use recently published version of symbol_table (now called symbol_map). 2016-09-08 22:02:58 -04:00
b937e22f50 Remove unused import. 2016-09-05 23:47:18 -04:00
e0d34f1f68 Use crossbeam's scoped threads instead of unsafe cast in test. 2016-05-04 14:42:00 -04:00
962768dfb4 Dead simple tests to ensure that Graph can be Send and Sync. 2016-05-01 20:41:14 -04:00
4935b8b646 Remove dead code. 2016-05-01 17:51:55 -04:00
7f8a4b3c0b Switch to using symbol-table package instead of built-in StateNamespace. 2016-05-01 17:51:10 -04:00
8550af7562 Remove unused, obsoleted enum. 2016-05-01 16:11:45 -04:00
0e9c6a64ec Recover vertex labels from node handles. 2016-04-17 17:19:18 -04:00
fc77c8824b Method for temporarily borrowing a Node from a MutNode. 2016-04-17 15:59:34 -04:00
4b348c9bc6 New methods for adding parent edges to graph. 2016-04-17 14:17:12 -04:00
6ce69e5d12 New methods for adding child edges to graph. 2016-04-17 14:12:37 -04:00
f57667f410 Get rid of notion of unexpanded edge.
Make one to throw away.

Upon reflection, it is not necessary for the graph data structure itself
to support unexpanded edges. It is sufficient to mark on vertex or edge
data when expansion is needed.
2016-04-17 13:59:41 -04:00
1a5c88e687 Rename Arc->RawEdge. Add Ord & co. to RawEdge. 2016-04-13 23:05:46 -04:00
649203baad Rename Vertex->RawVertex. Add Ord and PartialOrd to RawVertex. 2016-04-13 23:01:54 -04:00
9d3c123bdb Rename StateId->VertexId, ArcId->EdgeId. 2016-04-13 22:58:26 -04:00
ba77a28cd4 Use references to game state in retain_reachable_from. 2016-04-12 10:45:19 -04:00
137168a35a Clean up module structure and documentation. 2016-04-12 10:36:25 -04:00
173ffea759 Wrap up basic test suite for mark & compact. 2016-04-12 08:52:07 -04:00
df11119ec6 Strengthen mark-and-compact to suit tests.
Tests still incomplete.
2016-04-12 00:54:47 -04:00