blob: e59303d1f788f86dc10ff3095d2f2d4199676b9f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
// run-pass
// A test for something that NLL enables. It sometimes happens that
// the `while let` pattern makes some borrows from a variable (in this
// case, `x`) that you need in order to compute the next value for
// `x`. The lexical checker makes this very painful. The NLL checker
// does not.
use std::rc::Rc;
#[derive(Debug, PartialEq, Eq)]
enum Foo {
Base(usize),
Next(Rc<Foo>),
}
fn find_base(mut x: Rc<Foo>) -> Rc<Foo> {
while let Foo::Next(n) = &*x {
x = n.clone();
}
x
}
fn main() {
let chain = Rc::new(Foo::Next(Rc::new(Foo::Base(44))));
let base = find_base(chain);
assert_eq!(&*base, &Foo::Base(44));
}
|