| Crates.io | result-like |
| lib.rs | result-like |
| version | 0.5.1 |
| created_at | 2020-01-04 14:17:36.489523+00 |
| updated_at | 2025-09-02 01:01:52.701293+00 |
| description | Option/Result-like monad interface for your own enum |
| homepage | https://github.com/youknowone/result-like |
| repository | https://github.com/youknowone/result-like |
| max_upload_size | |
| id | 195138 |
| size | 15,127 |
Install: https://crates.io/crates/result-like
Define your own Option-like and Result-like enum types. Avoid reimplementing the entire APIs of option and result for your own enums.
Option example
use result_like::OptionLike;
// Simple case with single argument name to use Some and None
#[derive(OptionLike)]
enum MyOption<T> {
Some(T),
None,
}
let v = MyOption::Some(1);
// every option utilities are possible including unwrap, map, and, or etc.
assert_eq!(v.unwrap(), 1);
// convertable to option
let opt = v.into_option();
assert_eq!(opt, Some(1));
// enum with custom names instead of Some and None
#[derive(OptionLike)]
enum Number {
Value(i64),
Nan,
}
let v = Number::Value(10);
assert_ne!(v, Number::Nan);
Result example in same way
use result_like::ResultLike;
// typical
#[derive(ResultLike)]
enum MyResult<T, E> {
Ok(T),
Err(E),
}
// value-only
#[derive(ResultLike)]
enum Trial {
Success(String),
Failure(String),
}