Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Amanieu/intrusive-rs
Intrusive collections for Rust
https://github.com/Amanieu/intrusive-rs
Last synced: 4 days ago
JSON representation
Intrusive collections for Rust
- Host: GitHub
- URL: https://github.com/Amanieu/intrusive-rs
- Owner: Amanieu
- License: apache-2.0
- Created: 2016-02-22T02:40:38.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-07-30T23:32:14.000Z (over 1 year ago)
- Last Synced: 2024-05-08T18:48:42.846Z (6 months ago)
- Language: Rust
- Size: 1.43 MB
- Stars: 388
- Watchers: 12
- Forks: 46
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
intrusive-collections
=====================[![Build Status](https://travis-ci.org/Amanieu/intrusive-rs.svg?branch=master)](https://travis-ci.org/Amanieu/intrusive-rs) [![Coverage Status](https://coveralls.io/repos/github/Amanieu/intrusive-rs/badge.svg?branch=master)](https://coveralls.io/github/Amanieu/intrusive-rs?branch=master) [![Crates.io](https://img.shields.io/crates/v/intrusive-collections.svg)](https://crates.io/crates/intrusive-collections)
A Rust library for creating intrusive collections. Currently supports singly-linked and doubly-linked lists, as well as red-black trees.
## Features
- Compatible with `#[no_std]`.
- Intrusive collections don't require any dynamic memory allocation since they simply keep track of existing objects rather than allocating new ones.
- You can safely manipulate intrusive collections without any unsafe code.
- A single object can be a member of multiple intrusive collections simultaneously.
- Intrusive collections provide a `Cursor`-based interface, which allows safe mutation while iterating.For examples and more information, see the documentation ([crates.io](https://docs.rs/intrusive-collections), [master](https://amanieu.github.io/intrusive-rs/intrusive_collections/index.html)).
## Usage
Add this to your `Cargo.toml`:
```toml
[dependencies]
intrusive-collections = "0.9"
```This crate has two Cargo features:
- `nightly`: Enables nightly-only features: `const fn` constructors for collections (`Link` constructors are always `const fn`)
- `alloc` (enabled by default): Implements `IntrusivePointer` for `Box`, `Rc` and `Arc`.## License
Licensed under either of
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any
additional terms or conditions.