“Sound unchecked indexing” in Rust using “generativity” (branding by unique lifetime parameter).
Extremely experimental, but somewhat promising & exciting.
Main focus is on index ranges, not just single indices.
|buildstatus| |crates|_
.. |buildstatus| image:: https://travis-ci.org/bluss/indexing.svg?branch=master .. _buildstatus: https://travis-ci.org/bluss/indexing
.. |crates| image:: http://meritbadge.herokuapp.com/indexing .. _crates: https://crates.io/crates/indexing
Crate Features:
use_std
Enabled by default, disable to be no_std
-compatible.sound unchecked indexing
__._ https://www.reddit.com/r/rust/comments/3oo0oe/sounduncheckedindexingwithlifetimebasedvalue/
Also now described in: You can't spell trust without Rust <https://raw.githubusercontent.com/Gankro/thesis/master/thesis.pdf>
_. Chapter 6.3 hacking generativity onto rust. Gankro's master's thesis.
0.2.0
PIndex, PRange, PSlice
which are the pointer-based equivalents
of safe trusted indices and ranges. Some algos are better when using
a raw pointer representation (for example: lower bound). Since we don't
have HKT, traitifying all of this is not so pleasant and is not yet complete.0.1.2
binary_search_by
and lower_bound
to algorithms. Algorithms
don't require T: Debug
anymore.0.1.1
0.1.0
0.1.0-alpha3
0.1.0-alpha2
0.1.0-alpha1
Dual-licensed to be compatible with the Rust project.
Licensed under the Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0 or the MIT license http://opensource.org/licenses/MIT, at your option. This file may not be copied, modified, or distributed except according to those terms.