diff options
| author | Eric Holk <ericholk@microsoft.com> | 2025-03-12 15:59:28 -0700 |
|---|---|---|
| committer | Eric Holk <ericholk@microsoft.com> | 2025-03-14 12:21:58 -0700 |
| commit | edf65e735cd871d01149131f5d050293a9f1037c (patch) | |
| tree | fe1a0949b5b8cd23d3448634d224c00c710ffdc4 /tests/ui/coroutine/postfix-yield.rs | |
| parent | cb50d4d8566b1ee97e9a5ef95a37a40936a62c30 (diff) | |
| download | rust-edf65e735cd871d01149131f5d050293a9f1037c.tar.gz rust-edf65e735cd871d01149131f5d050293a9f1037c.zip | |
Add support for postfix yield expressions
We had a discussion[1] today about whether postfix yield would make sense. It's easy enough to support both in the parser, so we might as well have both and see how people use it while the feature is experimental. [1]: https://rust-lang.zulipchat.com/#narrow/channel/481571-t-lang.2Fgen/topic/postfix-yield/with/505231568
Diffstat (limited to 'tests/ui/coroutine/postfix-yield.rs')
| -rw-r--r-- | tests/ui/coroutine/postfix-yield.rs | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/tests/ui/coroutine/postfix-yield.rs b/tests/ui/coroutine/postfix-yield.rs new file mode 100644 index 00000000000..77b1c2a19d0 --- /dev/null +++ b/tests/ui/coroutine/postfix-yield.rs @@ -0,0 +1,34 @@ +// This demonstrates a proposed alternate or additional option of having yield in postfix position. + +//@ run-pass +//@ edition: 2024 + +#![feature(gen_blocks, coroutines, coroutine_trait, yield_expr)] + +use std::ops::{Coroutine, CoroutineState}; +use std::pin::pin; + +fn main() { + // generators (i.e. yield doesn't return anything useful) + let mut gn = gen { + yield 1; + 2.yield; + }; + + assert_eq!(gn.next(), Some(1)); + assert_eq!(gn.next(), Some(2)); + assert_eq!(gn.next(), None); + + //coroutines (i.e. yield returns something useful) + let mut coro = pin!( + #[coroutine] + |_: i32| { + let x = yield 1; + yield x + 2; + } + ); + + assert_eq!(coro.as_mut().resume(0), CoroutineState::Yielded(1)); + assert_eq!(coro.as_mut().resume(2), CoroutineState::Yielded(4)); + assert_eq!(coro.as_mut().resume(3), CoroutineState::Complete(())); +} |
