split_array 0.2.0

Split array references in two with compile-time size validation.
Documentation
  • Coverage
  • 93.33%
    14 out of 15 items documented1 out of 12 items with examples
  • Size
  • Source code size: 15.89 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 639.08 kB This is the summed size of all files generated by rustdoc for all configured targets
  • Links
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • melvdlin

split_array

Split array references in two with compile-time size validation.

This crate requires nightly!

Unstable features used:

Examples

The sizes of the two halves can usually be inferred:

use split_array::SplitArray;
let mut array: [usize; 5] = [0, 1, 2, 3, 4];
let (left, right) = array.split_arr_mut();
* left = [10, 11, 12];
* right = [23, 24];
assert_eq!([10, 11, 12, 23, 24], array);

They can be annotated explicitly as well:

use split_array::SplitArray;
let array: [usize; 5] = [0, 1, 2, 3, 4];
let (left, right) = array.split_arr::<2 > ();
assert_eq!([0, 1, 2], *left);
assert_eq!([3, 4], *right);

The annotated size is validated at compile-time. This won't compile:

use split_array::SplitArray;
let array: [usize; 5] = [0, 1, 2, 3, 4];
let (left, right) = array.split_arr::<6 > ();