non-non-full

Crates.ionon-non-full
lib.rsnon-non-full
version0.0.3
created_at2025-05-25 21:38:41.138296+00
updated_at2025-06-08 18:27:46.300475+00
descriptionVec and String wrappers that assert the containers are always non-empty (or, ahem, non-non-full)
homepage
repositoryhttps://github.com/SergeyKasmy/fetcher/crates/non-non-full
max_upload_size
id1688711
size19,163
Ciren (SergeyKasmy)

documentation

README

non-non-full

Container types that guarantee non-emptiness.

This crate provides wrapper types around Vec and String that ensure they can never be empty. The name "non-non-full" is a playful way of saying "not empty" (i.e., full).

Features

  • NonEmptyVec<T>: A vector that always contains at least one element
  • NonEmptyString: A string that always contains at least one character
  • Optional serde support via the "serde" feature

Example

use non_non_full::{NonEmptyVec, NonEmptyString};

// Creating non-empty containers
let vec = NonEmptyVec::new_one(42);
let string = NonEmptyString::new("Hello".to_string()).unwrap();

// Operations that would make the container empty are prevented
let mut vec = NonEmptyVec::new(vec![1, 2]).unwrap();
assert_eq!(vec.pop(), Some(2)); // Allowed - vec still contains [1]
assert_eq!(vec.pop(), None);    // Prevented - would make vec empty

License: MPL-2.0

Commit count: 927

cargo fmt