| [![crates.io](https://img.shields.io/crates/v/option-ext.svg)](https://crates.io/crates/option-ext) |
| [![API documentation](https://docs.rs/option-ext/badge.svg)](https://docs.rs/option-ext/) |
| ![actively developed](https://img.shields.io/badge/maintenance-actively--developed-brightgreen.svg) |
| ![License: MPL-2.0](https://img.shields.io/badge/license-MPL--2.0-orange.svg) |
| |
| # `option-ext` |
| |
| ## Introduction |
| |
| This crate extends `Option` with additional methods, currently: |
| |
| - `contains` |
| - `map_or2` (as a replacement for `map_or`) |
| - `map_or_else2` (as a replacement for `map_or_else`) |
| |
| Its sister crate is [`result-ext`](https://github.com/soc/result-ext), which extends `Result`. |
| |
| ## Requirements |
| |
| Rust 1.0 or newer. |
| |
| ## Usage |
| |
| #### Dependency |
| |
| Add the library as a dependency to your project by inserting |
| |
| ```toml |
| option-ext = "0.2.0" |
| ``` |
| |
| into the `[dependencies]` section of your Cargo.toml file. |
| |
| #### Example |
| |
| ```rust |
| use option_ext::OptionExt; |
| |
| fn example_contains() { |
| let x: Option<u32> = Some(2); |
| assert_eq!(x.contains(&2), true); |
| |
| let x: Option<u32> = Some(3); |
| assert_eq!(x.contains(&2), false); |
| |
| let x: Option<u32> = None; |
| assert_eq!(x.contains(&2), false); |
| } |
| |
| fn example_map_or2() { |
| let x = Some("bar"); |
| assert_eq!(x.map_or2(|v| v.len(), 42), 3); |
| |
| let x: Option<&str> = None; |
| assert_eq!(x.map_or2(|v| v.len(), 42), 42); |
| } |
| |
| fn example_map_or_else2() { |
| let k = 23; |
| |
| let x = Some("bar"); |
| assert_eq!(x.map_or_else2(|v| v.len(), || 2 * k), 3); |
| |
| let x: Option<&str> = None; |
| assert_eq!(x.map_or_else2(|v| v.len(), || 2 * k), 46); |
| } |
| ``` |