#control-flow #never-type #unbreakable

no-break

Typesafe extraction of continuation values from unbreakable control flows

2 releases

0.1.1 Dec 1, 2024
0.1.0 Dec 1, 2024

#720 in Rust patterns

Apache-2.0 OR LGPL-2.1-or-later

17KB

Typesafe Extraction of Continuation Values from Unbreakable Control Flows

This crate provides a convenience extension trait NoBreak adding a method continue_value_no_break to ControlFlow types in which the type of the value contained in the break variant is Unbreakable. The purpose is identical to that of the unwrap_infallible crate, but for control flows.

Unbreakable is a marker type similar to Infallible (it is an empty enum), but with a different name as breaks in a control flow are not thought of as errors. It should ultimately be replaced with the never type.

Using continue_value_no_break on a ControlFlow forces a typesafe, compile-time check that the control flow will never break, and extracts the value from the only possible variant. In particular, type inference should make it possible to use expressions such as ControlFlow::Continue(value) without specifying the break type.

Examples

use no_break::NoBreak;
use std::ops::ControlFlow;

fn never_breaks<B>() -> ControlFlow<B, usize> {
    // Note that we do not need to specify B
    ControlFlow::Continue(5)
}
fn main() {
    // Type inference takes care of setting B to Unbreakable
    println!("{}", never_breaks().continue_value_no_break());
}

No runtime deps