#zip #options #macro #single #option-t #instance #arguments

macro zips

Macros for wrapping up a bunch of Option<T>'s/Result<T, E>'s into a single Option<(T [, T...])>

8 releases

0.1.7 Sep 4, 2024
0.1.6 Sep 1, 2024
0.1.5 Aug 29, 2024
0.1.2 Jul 19, 2024

#959 in Procedural macros

Download history 412/week @ 2024-08-26 248/week @ 2024-09-02 80/week @ 2024-09-16 215/week @ 2024-09-23 394/week @ 2024-09-30 293/week @ 2024-10-07 255/week @ 2024-10-14 218/week @ 2024-10-21 208/week @ 2024-10-28 173/week @ 2024-11-04 198/week @ 2024-11-11 242/week @ 2024-11-18 431/week @ 2024-11-25 224/week @ 2024-12-02 308/week @ 2024-12-09

1,233 downloads per month
Used in 2 crates

MIT license

6KB
58 lines

zips GitHub Actions Workflow Status Crates.io Total Downloads

Just because I was annoyed that I couldn't use Option<T>::zip with more than 2 arguments...

Zips provides 2 proc-macros that accept any number of either Option<T>s or Result<T, E>s as arguments and produces an Option<(T [, T...])>.

Installation

$> cargo add zips

Usage

With Option<T>:

use zips::zip;

fn main() -> () {
  let i: Option<i32> = Some(0);
  let j: Option<usize> = Some(1usize);
  let k: Option<()> = None;
 
  //  zipped_some: Option<(i32, usize)>
  let zipped_some = zip!(i, j);
  assert_eq!(zipped_some, Some((0, 1usize)));
 
  //  zipped_none: Option<((i32, usize), ())>
  let zipped_none = zip!(zipped_some, k);
  assert_eq!(zipped_none, None);
}

With Result<T, E>:

use zips::zip_result;

fn main() -> () {
  let m: Result<i32, ()> = Ok(1);
  let n: Result<usize, ()> = Ok(0usize);
  let o: Result<(), &'static str> = Err("I'm an error!");
 
  //  zipped_ok: Option<(i32, usize)>
  let zipped_ok = zip_result!(m, n);
  assert_eq!(zipped_some, Some((1i32, 0usize)));
 
  //  zipped_err: Option<((i32, usize), ())>
  let zipped_err = zip_result!(zipped_ok, o);
  assert_eq!(zipped_err, None);
}

Dependencies

~220–660KB
~16K SLoC