7 releases
0.2.1 | Jul 27, 2021 |
---|---|
0.2.0 | Jul 27, 2021 |
0.1.4 | Apr 23, 2020 |
0.1.3 | Jun 3, 2019 |
0.1.0 | Apr 28, 2019 |
#2058 in Data structures
20KB
317 lines
fplist
A persistent, immutable, and singly-linked list in Rust.
Persistency is a property of data structures when modifying them. Persistency stipulates that old versions of the structures are always preserved when adding or removing elements. This crate provides such a structure in the form of a linked list.
To be efficient as possible when maintaining persistency, the linked list uses
reference counting. This permits sharing memory between lists whose
elements are the same. By default, the list uses the Rc
type for this
purpose. However, one major downside of Rc
is that lists cannot be sent
across threads. For this, you might want to enable the multithreaded
feature,
which will signal the list to use the multithreaded sibling Arc
.
One innate requirement of persistency is that structures must be immutable. That
is, they cannot permit mutation of their elements. The list type only provides
an API for immutable and owned access to its elements. You may circumvent this
with the RefCell
or Mutex
types, which grant interior mutability.
The list type is inspired by cons lists from Lisp languages, which is also how the list type is constructed with and represented.
Serde
The list is able to be serialized or deserialized by the serde framework.
Support, however, is disabled by default (to avoid needless dependencies). Enable
support with the serde_impls
feature.
Example
use fplist::{PersistentList, cons};
let list = cons(1, cons(2, cons(3, PersistentList::new())));
assert_eq!(list.first(), Some(&1));
let list = list.rest();
assert_eq!(list.first(), Some(&2));
let list = list.rest();
assert_eq!(list.first(), Some(&3));
let list = list.rest();
assert_eq!(list.first(), None);
License
This project is under the jurisdiction of the MIT License.
Dependencies
~160KB