You can't forcibly extend a value's lifetime; you just have to return the full Vec
. If I may ask, why do you want to return the slice itself? It is almost always unnecessary, since a Vec
can be cheaply (both in the sense of easy syntax and low-overhead at runtime) coerced to a slice.
Alternatively, you could return the iterator:
use std::iter;
pub fn find<'a>(&'a self, name: &str) -> Box<Iterator<Item = &'a Element> + 'a> {
Box::new(self.iter_elements()
.filter(move |&elem| elem.name.borrow().local_name == name))
}
For now, you will have to use an iterator trait object, since closure have types that are unnameable.
NB. I had to change the filter
closure to capture-by-move (the move
keyword) to ensure that it can be returned, or else the name
variable would just passed into the closure pointer into find
's stack frame, and hence would be restricted from leaving find
.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…