2019-01-27 11:03:21 +00:00
|
|
|
error: lifetime may not live long enough
|
2022-04-01 17:13:25 +00:00
|
|
|
--> $DIR/ex3-both-anon-regions-one-is-struct-3.rs:4:5
|
2019-01-27 11:03:21 +00:00
|
|
|
|
|
|
|
|
LL | fn foo(mut y: Ref, x: &u32) {
|
|
|
|
| ----- - let's call the lifetime of this reference `'1`
|
|
|
|
| |
|
|
|
|
| has type `Ref<'_, '2>`
|
|
|
|
LL | y.b = x;
|
|
|
|
| ^^^^^^^ assignment requires that `'1` must outlive `'2`
|
Suggest setting lifetime in borrowck error involving types with elided lifetimes
```
error: lifetime may not live long enough
--> $DIR/ex3-both-anon-regions-both-are-structs-2.rs:7:5
|
LL | fn foo(mut x: Ref, y: Ref) {
| ----- - has type `Ref<'_, '1>`
| |
| has type `Ref<'_, '2>`
LL | x.b = y.b;
| ^^^^^^^^^ assignment requires that `'1` must outlive `'2`
|
help: consider introducing a named lifetime parameter
|
LL | fn foo<'a>(mut x: Ref<'a, 'a>, y: Ref<'a, 'a>) {
| ++++ ++++++++ ++++++++
```
As can be seen above, it currently doesn't try to compare the `ty::Ty` lifetimes that diverged vs the `hir::Ty` to correctly suggest the following
```
help: consider introducing a named lifetime parameter
|
LL | fn foo<'a>(mut x: Ref<'_, 'a>, y: Ref<'_, 'a>) {
| ++++ ++++++++ ++++++++
```
but I believe this to still be an improvement over the status quo.
CC #40990.
2024-05-03 21:42:34 +00:00
|
|
|
|
|
|
|
|
help: consider introducing a named lifetime parameter
|
|
|
|
|
|
|
|
|
LL | fn foo<'a>(mut y: Ref<'a, 'a>, x: &'a u32) {
|
|
|
|
| ++++ ++++++++ ++
|
2019-01-27 11:03:21 +00:00
|
|
|
|
2023-11-21 15:44:16 +00:00
|
|
|
error: aborting due to 1 previous error
|
2019-01-27 11:03:21 +00:00
|
|
|
|