{
Ok1(&'a u32),
Ok2,
}
fn my_do<'a> (s: &'a mut S) -> Result<OkKind<'a>, ()> {
let res = || -> Result<OkKind<'_>, ()> {
s.try_get()
}();
match res { // казалось бы, переместили
Ok(r) => { // заимствование, ок
Ok(r)
},
Err(e) => { // Как тут сбросить заимствование, раз 'e' живёт сам по себе?
s.revert_mut(4); // чтобы &mut self доступен стал
Err(e)
}
}
}
В нагромождённом оригинале сообщение об ошибке имеет вид 'cannot borrow *self as mutable because previous closure requires unique access', но тут похожее: 'cannot borrow *s as mutable because it is also borrowed as immutable'
Полный пример
Спасибо
Это опять классическая проблема с возвращаемыми значениями, текущий борроу-чекер имеет с ними проблемы. Красивого решения нет, можно разве что два раза try_get() вызывать: playground
вру, можно через try_get_or_mut сделать красивее: playground
Возврат восстановление доступности self путём его передачи при ошибке выглядит правда как хак. Но так нельзя делать несколько раз. А из одного вызова цепочку команд не собрать(
Обсуждают сегодня