#options #traits #ops #utils #no-alloc

nightly no-std option_trait

Helper traits for more generalized options

24 releases (7 stable)

1.0.6 Dec 23, 2024
1.0.5 Dec 22, 2024
0.1.16 Apr 20, 2024
0.1.5 Jan 23, 2024
0.1.1 Jun 24, 2023

#374 in Rust patterns

Download history 12/week @ 2024-09-25 5/week @ 2024-10-02 10/week @ 2024-12-04 21/week @ 2024-12-11 518/week @ 2024-12-18 147/week @ 2024-12-25 4/week @ 2025-01-08

669 downloads per month
Used in signal_processing

MIT license

175KB
4K SLoC

Build Status (nightly) Build Status (nightly, all features)

Build Status (stable) Build Status (stable, all features)

Test Status Lint Status

Latest Version License:MIT Documentation Coverage Status

option_trait

Provides the Optional trait for Options, as well as compile-time managed Option alternatives, all generalized under the trait Maybe.

Maybe<T> is implemented for:

  • Option<T>
    • Run-time managed
    • Also implements Optional and PureMaybe
  • T and ()
    • Compile-time managed
    • Also implements PureStaticMaybe, PureMaybe and StaticMaybe
  • [T; 1] and [T; 0]
    • Compile-time managed
    • Can be managed using constant expressions, but with some difficulty
    • Also implements StaticMaybe
  • OptCell<T, _> (only if feature opt_cell is enabled)
    • Compile-time managed
    • Can be more easily managed using boolean constant expressions
    • Has const methods
    • Also implements StaticMaybe

Examples

This is how i like to handle optional function arguments with maximum flexibility.

use option_trait::*;

fn f<O>(required: i32, optional: O)
where
    O: Maybe<i32>
{
    if O::IS_MAYBE_SOME
    {
        let param = optional.unwrap_or(0);

        // This part of the code will be disabled at compile-time if the maybe cannot
        // possibly contain a value.
    }

    // Do whatever
}

f(1, 2);
f(1, ());
f(1, Some(2));
f(1, None);
f(1, [2]);
f(1, [] as [i32; 0]);
f(1, OptCell::some(2));
f(1, OptCell::none());

Dependencies