| Crates.io | typed_tuple |
| lib.rs | typed_tuple |
| version | 0.1.0 |
| created_at | 2025-06-01 05:07:13.599229+00 |
| updated_at | 2025-06-01 05:07:13.599229+00 |
| description | Type based operations on primitive tuple elements. |
| homepage | |
| repository | https://github.com/cedtwo/typed_tuple.git |
| max_upload_size | |
| id | 1696893 |
| size | 8,905 |
Type based operations on primitive tuple elements.
typed_tuple allows for type safe operations on primitive tuple elements
without specifying an index. The main purpose of this crate is to simplfy
small arbitrary operations on heterogenous sequences. In the example below,
elements of a tuple are assigned and retrieved irrespective of indices:
let mut tuple: (usize, Option<Type0>, Option<Type1>, Option<Type2>) = Default::default();
// Mutate the `usize` element.
tuple.map(|el: usize| el + 10);;
// Assign the `Type` prefixed elements.
*tuple.get_mut() = Some(Type0);
*tuple.get_mut() = Some(Type2);
// Pass elements to their respective consumers.
if let Some(element) = tuple.get() { std::hint::black_box::<Type0>(*element); }
if let Some(element) = tuple.get() { std::hint::black_box::<Type1>(*element); }
if let Some(element) = tuple.get() { std::hint::black_box::<Type2>(*element); }
assert_eq!(tuple, (10, Some(Type0), None, Some(Type2)));
TypedTuple::<1, _>::get(&tuple) where 1 is the element index,
however this offers no advantage over simply calling tuple.1.typed_tuple can impact readability. Types should be explicit if not immediately
obvious. Prefer let a: usize = tuple.get() over let a = tuple.get().TypedTuple is implemented on tuples of up to 12 elements in length. This was chosen
as it is the limit of many tuple trait implementations (PartialEq, Eq, etc.),
however can be extended to support a higher number of elements if needed.License: MIT OR Apache-2.0