#vec #min #length #1

vec1

a std Vec wrapper assuring that it has at least 1 element

8 stable releases

✓ Uses Rust 2018 edition

1.5.1 Jul 1, 2020
1.5.0 May 21, 2020
1.4.0 Mar 26, 2019
1.1.0 Jul 24, 2018
1.0.1 Jun 12, 2018

#45 in Data structures

Download history 386/week @ 2020-03-16 435/week @ 2020-03-23 520/week @ 2020-03-30 437/week @ 2020-04-06 480/week @ 2020-04-13 676/week @ 2020-04-20 332/week @ 2020-04-27 466/week @ 2020-05-04 568/week @ 2020-05-11 423/week @ 2020-05-18 446/week @ 2020-05-25 493/week @ 2020-06-01 431/week @ 2020-06-08 511/week @ 2020-06-15 757/week @ 2020-06-22 553/week @ 2020-06-29

2,159 downloads per month
Used in 16 crates (10 directly)

MIT/Apache

40KB
832 lines

vec1 Crates.io vec1 License License

This crate provides a rust std::vec::Vec wrapper with type guarantees to contain at least 1 element. This is useful if you build a API which sometimes has such constraints e.g. you need at least one target server address but there can be more.

Example

#[macro_use]
extern crate vec1;

use vec1::Vec1;

fn main() {
    // vec1![] makes sure there is at least one element
    // at compiler time
    //let names = vec1! [ ];
    let names = vec1! [ "Liz" ];
    greet(names);
}

fn greet(names: Vec1<&str>) {
    // methods like first/last which return a Option on Vec do
    // directly return the value, we know it's possible
    let first = names.first();
    println!("hallo {}", first);
    for name in names.iter().skip(1) {
        println!("  who is also know as {}", name)
    }
}

Support for serde::{Serialize, Deserialize}

The Vec1 type supports both of serde's Serialize and Deserialize traits, but this feature is only enabled when the "serde" feature flag is specified in your project's Cargo.toml file:

# Cargo.toml

[dependencies]
vec1 = { version = "...", features = ["serde"] }

License

Licensed under either of

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.

Contributors: ./CONTRIBUTORS.md

Change Log

See ./CHANGELOG.md

Dependencies

~185KB