From b7c0e464d5fbe6fdd008c3c25f835e4978a5ae2d Mon Sep 17 00:00:00 2001 From: Guillaume Gomez Date: Thu, 7 Nov 2019 13:01:53 +0100 Subject: [PATCH 1/5] Add long error explanation for E0623 --- src/librustc/error_codes.rs | 44 ++++++++++++++++++++++++++++++++++++- 1 file changed, 43 insertions(+), 1 deletion(-) diff --git a/src/librustc/error_codes.rs b/src/librustc/error_codes.rs index f5ff92e69bc7a..9274608bc2f84 100644 --- a/src/librustc/error_codes.rs +++ b/src/librustc/error_codes.rs @@ -1896,6 +1896,49 @@ fn foo<'a>(x: &'a i32, y: &i32) -> &'a i32 { ``` "##, +E0623: r##" +A lifetime didn't match what was expected. + +Erroneous code example: + +```compile_fail,E0623 +struct Foo<'a> { + x: &'a isize, +} + +fn bar<'short, 'long>(c: Foo<'short>, l: &'long isize) { + let _: Foo<'long> = c; // error! +} +``` + +In this example, we tried to set a value with an incompatible lifetime to +another one (`'long` != `'short`). We can solve this issue in two different +ways: either we make `'short` lives longer than `'long`: + +``` +struct Foo<'a> { + x: &'a isize, +} + +// we set 'short to outlive 'long +fn bar<'short: 'long, 'long>(c: Foo<'short>, l: &'long isize) { + let _: Foo<'long> = c; // ok! +} +``` + +Or we use only one lifetime: + +``` +struct Foo<'a> { + x: &'a isize, +} + +fn bar<'short>(c: Foo<'short>, l: &'short isize) { + let _: Foo<'short> = c; // ok! +} +``` +"##, + E0635: r##" The `#![feature]` attribute specified an unknown feature. @@ -2329,7 +2372,6 @@ the future, [RFC 2091] prohibits their implementation without a follow-up RFC. E0488, // lifetime of variable does not enclose its declaration E0489, // type/lifetime parameter not in scope here E0490, // a value of type `..` is borrowed for too long - E0623, // lifetime mismatch where both parameters are anonymous regions E0628, // generators cannot have explicit parameters E0631, // type mismatch in closure arguments E0637, // "'_" is not a valid lifetime bound From ffc1c5a04d431679a6b6c5c92fdd7ad77b109c98 Mon Sep 17 00:00:00 2001 From: Guillaume Gomez Date: Thu, 7 Nov 2019 13:02:34 +0100 Subject: [PATCH 2/5] Update ui tests --- .../associated-type-bounds/implied-region-constraints.stderr | 1 + .../associated-types-project-from-hrtb-in-fn-body.stderr | 1 + .../ui/associated-types/associated-types-subtyping-1.stderr | 1 + .../cache/project-fn-ret-contravariant.krisskross.stderr | 1 + .../cache/project-fn-ret-invariant.krisskross.stderr | 1 + .../cache/project-fn-ret-invariant.oneuse.stderr | 1 + src/test/ui/async-await/issues/issue-63388-1.stderr | 1 + .../async-await/multiple-lifetimes/ret-impl-trait-one.stderr | 1 + .../borrowck-reborrow-from-shorter-lived-andmut.stderr | 1 + src/test/ui/continue-after-missing-main.stderr | 3 ++- .../ui/impl-trait/must_outlive_least_region_or_bound.stderr | 3 ++- src/test/ui/in-band-lifetimes/mismatched.stderr | 3 ++- src/test/ui/in-band-lifetimes/mismatched_trait_impl.stderr | 1 + src/test/ui/issues/issue-17728.stderr | 3 ++- .../ex1-return-one-existing-name-if-else-using-impl.stderr | 1 + .../ex1-return-one-existing-name-return-type-is-anon.stderr | 1 + .../ex1-return-one-existing-name-self-is-anon.stderr | 1 + .../lifetime-errors/ex2b-push-no-existing-names.stderr | 1 + .../lifetime-errors/ex2c-push-inference-variable.stderr | 1 + .../lifetime-errors/ex2d-push-inference-variable-2.stderr | 1 + .../lifetime-errors/ex2e-push-inference-variable-3.stderr | 1 + .../lifetimes/lifetime-errors/ex3-both-anon-regions-2.stderr | 1 + .../lifetimes/lifetime-errors/ex3-both-anon-regions-3.stderr | 1 + .../ex3-both-anon-regions-both-are-structs-2.stderr | 1 + .../ex3-both-anon-regions-both-are-structs-3.stderr | 1 + ...oth-anon-regions-both-are-structs-earlybound-regions.stderr | 1 + ...both-anon-regions-both-are-structs-latebound-regions.stderr | 1 + .../ex3-both-anon-regions-both-are-structs.stderr | 1 + .../ex3-both-anon-regions-latebound-regions.stderr | 1 + .../ex3-both-anon-regions-one-is-struct-2.stderr | 1 + .../ex3-both-anon-regions-one-is-struct-3.stderr | 1 + .../ex3-both-anon-regions-one-is-struct-4.stderr | 1 + .../lifetime-errors/ex3-both-anon-regions-one-is-struct.stderr | 1 + .../ex3-both-anon-regions-return-type-is-anon.stderr | 1 + .../lifetime-errors/ex3-both-anon-regions-self-is-anon.stderr | 1 + .../ex3-both-anon-regions-using-fn-items.stderr | 1 + .../ex3-both-anon-regions-using-impl-items.stderr | 1 + .../ex3-both-anon-regions-using-trait-objects.stderr | 1 + .../ui/lifetimes/lifetime-errors/ex3-both-anon-regions.stderr | 1 + .../ui/object-lifetime/object-lifetime-default-mybox.stderr | 3 ++- .../regions/region-lifetime-bounds-on-fns-where-clause.stderr | 3 ++- .../region-multiple-lifetime-bounds-on-fns-where-clause.stderr | 3 ++- .../regions-bounded-method-type-parameters-cross-crate.stderr | 1 + .../regions-bounded-method-type-parameters-trait-bound.stderr | 1 + src/test/ui/regions/regions-creating-enums3.stderr | 1 + src/test/ui/regions/regions-free-region-ordering-callee.stderr | 1 + .../regions/regions-free-region-ordering-caller.migrate.stderr | 1 + .../ui/regions/regions-infer-contravariance-due-to-decl.stderr | 1 + .../ui/regions/regions-infer-covariance-due-to-decl.stderr | 1 + src/test/ui/regions/regions-lifetime-bounds-on-fns.stderr | 3 ++- .../regions-reborrow-from-shorter-mut-ref-mut-ref.stderr | 1 + .../ui/regions/regions-reborrow-from-shorter-mut-ref.stderr | 1 + ...iance-contravariant-use-covariant-in-second-position.stderr | 1 + .../regions-variance-contravariant-use-covariant.stderr | 1 + .../regions-variance-covariant-use-contravariant.stderr | 1 + .../regions-variance-invariant-use-contravariant.stderr | 1 + .../arbitrary_self_types_pin_lifetime_mismatch-async.stderr | 1 + .../ui/self/arbitrary_self_types_pin_lifetime_mismatch.stderr | 1 + src/test/ui/self/elision/lt-ref-self-async.stderr | 1 + src/test/ui/self/elision/lt-ref-self.stderr | 1 + src/test/ui/self/elision/ref-mut-self-async.stderr | 1 + src/test/ui/self/elision/ref-mut-self.stderr | 1 + src/test/ui/self/elision/ref-mut-struct-async.stderr | 1 + src/test/ui/self/elision/ref-mut-struct.stderr | 1 + src/test/ui/self/elision/ref-self-async.stderr | 1 + src/test/ui/self/elision/ref-self.stderr | 1 + src/test/ui/self/elision/ref-struct-async.stderr | 1 + src/test/ui/self/elision/ref-struct.stderr | 1 + .../underscore-lifetime-elison-mismatch.stderr | 1 + src/test/ui/variance/variance-cell-is-invariant.stderr | 1 + 70 files changed, 78 insertions(+), 8 deletions(-) diff --git a/src/test/ui/associated-type-bounds/implied-region-constraints.stderr b/src/test/ui/associated-type-bounds/implied-region-constraints.stderr index 9968f3e8bac5e..60c6e8a80fb6a 100644 --- a/src/test/ui/associated-type-bounds/implied-region-constraints.stderr +++ b/src/test/ui/associated-type-bounds/implied-region-constraints.stderr @@ -18,3 +18,4 @@ LL | let _failure_proves_not_implied_outlives_region_b: &'b T = &x; error: aborting due to 2 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/associated-types/associated-types-project-from-hrtb-in-fn-body.stderr b/src/test/ui/associated-types/associated-types-project-from-hrtb-in-fn-body.stderr index 63d662f44658a..d5310c47fcf1e 100644 --- a/src/test/ui/associated-types/associated-types-project-from-hrtb-in-fn-body.stderr +++ b/src/test/ui/associated-types/associated-types-project-from-hrtb-in-fn-body.stderr @@ -11,3 +11,4 @@ LL | let z: I::A = if cond { x } else { y }; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/associated-types/associated-types-subtyping-1.stderr b/src/test/ui/associated-types/associated-types-subtyping-1.stderr index 660e5b3928acf..58ceec9040b9d 100644 --- a/src/test/ui/associated-types/associated-types-subtyping-1.stderr +++ b/src/test/ui/associated-types/associated-types-subtyping-1.stderr @@ -18,3 +18,4 @@ LL | let _c: >::Type = b; error: aborting due to 2 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/associated-types/cache/project-fn-ret-contravariant.krisskross.stderr b/src/test/ui/associated-types/cache/project-fn-ret-contravariant.krisskross.stderr index dc9a549586bab..fa4c6adb5fff7 100644 --- a/src/test/ui/associated-types/cache/project-fn-ret-contravariant.krisskross.stderr +++ b/src/test/ui/associated-types/cache/project-fn-ret-contravariant.krisskross.stderr @@ -22,3 +22,4 @@ LL | (a, b) error: aborting due to 2 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/associated-types/cache/project-fn-ret-invariant.krisskross.stderr b/src/test/ui/associated-types/cache/project-fn-ret-invariant.krisskross.stderr index 6accf8110ad1e..5009e0868a7d4 100644 --- a/src/test/ui/associated-types/cache/project-fn-ret-invariant.krisskross.stderr +++ b/src/test/ui/associated-types/cache/project-fn-ret-invariant.krisskross.stderr @@ -21,3 +21,4 @@ LL | let b = bar(foo, x); error: aborting due to 2 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/associated-types/cache/project-fn-ret-invariant.oneuse.stderr b/src/test/ui/associated-types/cache/project-fn-ret-invariant.oneuse.stderr index ef036bd8fbaa8..65d16440ac9b0 100644 --- a/src/test/ui/associated-types/cache/project-fn-ret-invariant.oneuse.stderr +++ b/src/test/ui/associated-types/cache/project-fn-ret-invariant.oneuse.stderr @@ -11,3 +11,4 @@ LL | let b = bar(f, y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/async-await/issues/issue-63388-1.stderr b/src/test/ui/async-await/issues/issue-63388-1.stderr index 2917fa9ccb7f2..8813183312ddf 100644 --- a/src/test/ui/async-await/issues/issue-63388-1.stderr +++ b/src/test/ui/async-await/issues/issue-63388-1.stderr @@ -11,3 +11,4 @@ LL | foo error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/async-await/multiple-lifetimes/ret-impl-trait-one.stderr b/src/test/ui/async-await/multiple-lifetimes/ret-impl-trait-one.stderr index f6d611517bc8f..7b8f290d6c2f8 100644 --- a/src/test/ui/async-await/multiple-lifetimes/ret-impl-trait-one.stderr +++ b/src/test/ui/async-await/multiple-lifetimes/ret-impl-trait-one.stderr @@ -9,3 +9,4 @@ LL | async fn async_ret_impl_trait1<'a, 'b>(a: &'a u8, b: &'b u8) -> impl Trait< error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/borrowck/borrowck-reborrow-from-shorter-lived-andmut.stderr b/src/test/ui/borrowck/borrowck-reborrow-from-shorter-lived-andmut.stderr index 4142fc488c0dd..67b6f64eaa64f 100644 --- a/src/test/ui/borrowck/borrowck-reborrow-from-shorter-lived-andmut.stderr +++ b/src/test/ui/borrowck/borrowck-reborrow-from-shorter-lived-andmut.stderr @@ -10,3 +10,4 @@ LL | S { pointer: &mut *p.pointer } error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/continue-after-missing-main.stderr b/src/test/ui/continue-after-missing-main.stderr index 64d34cb6a1947..439f9e5221f66 100644 --- a/src/test/ui/continue-after-missing-main.stderr +++ b/src/test/ui/continue-after-missing-main.stderr @@ -21,4 +21,5 @@ LL | let _: AdaptedMatrixProvider<'original_data, MP> = tableau.provider().c error: aborting due to 2 previous errors -For more information about this error, try `rustc --explain E0601`. +Some errors have detailed explanations: E0601, E0623. +For more information about an error, try `rustc --explain E0601`. diff --git a/src/test/ui/impl-trait/must_outlive_least_region_or_bound.stderr b/src/test/ui/impl-trait/must_outlive_least_region_or_bound.stderr index 2ffb94348616b..a8341f62e1d14 100644 --- a/src/test/ui/impl-trait/must_outlive_least_region_or_bound.stderr +++ b/src/test/ui/impl-trait/must_outlive_least_region_or_bound.stderr @@ -77,4 +77,5 @@ LL | fn ty_param_wont_outlive_static(x: T) -> impl Debug + 'static { error: aborting due to 5 previous errors -For more information about this error, try `rustc --explain E0310`. +Some errors have detailed explanations: E0310, E0623. +For more information about an error, try `rustc --explain E0310`. diff --git a/src/test/ui/in-band-lifetimes/mismatched.stderr b/src/test/ui/in-band-lifetimes/mismatched.stderr index ec1045d5fae37..db72c20697108 100644 --- a/src/test/ui/in-band-lifetimes/mismatched.stderr +++ b/src/test/ui/in-band-lifetimes/mismatched.stderr @@ -16,4 +16,5 @@ LL | fn foo2(x: &'a u32, y: &'b u32) -> &'a u32 { y } error: aborting due to 2 previous errors -For more information about this error, try `rustc --explain E0621`. +Some errors have detailed explanations: E0621, E0623. +For more information about an error, try `rustc --explain E0621`. diff --git a/src/test/ui/in-band-lifetimes/mismatched_trait_impl.stderr b/src/test/ui/in-band-lifetimes/mismatched_trait_impl.stderr index bc302e91c1c51..15891c9e7a62d 100644 --- a/src/test/ui/in-band-lifetimes/mismatched_trait_impl.stderr +++ b/src/test/ui/in-band-lifetimes/mismatched_trait_impl.stderr @@ -22,3 +22,4 @@ LL | x error: aborting due to 2 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/issues/issue-17728.stderr b/src/test/ui/issues/issue-17728.stderr index 56dfb89456fe5..945dfc26b206d 100644 --- a/src/test/ui/issues/issue-17728.stderr +++ b/src/test/ui/issues/issue-17728.stderr @@ -29,4 +29,5 @@ LL | | } error: aborting due to 2 previous errors -For more information about this error, try `rustc --explain E0308`. +Some errors have detailed explanations: E0308, E0623. +For more information about an error, try `rustc --explain E0308`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-if-else-using-impl.stderr b/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-if-else-using-impl.stderr index 56ca610019c4c..e9f5fc311dfc2 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-if-else-using-impl.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-if-else-using-impl.stderr @@ -11,3 +11,4 @@ LL | if x > y { x } else { y } error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-return-type-is-anon.stderr b/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-return-type-is-anon.stderr index df34d18ee83a4..0d506f2b9fcb4 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-return-type-is-anon.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-return-type-is-anon.stderr @@ -11,3 +11,4 @@ LL | x error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-self-is-anon.stderr b/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-self-is-anon.stderr index 22e14df9edc03..98a23613c3635 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-self-is-anon.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex1-return-one-existing-name-self-is-anon.stderr @@ -11,3 +11,4 @@ LL | if true { x } else { self } error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex2b-push-no-existing-names.stderr b/src/test/ui/lifetimes/lifetime-errors/ex2b-push-no-existing-names.stderr index c0c75c7453d24..e505c9c0dc262 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex2b-push-no-existing-names.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex2b-push-no-existing-names.stderr @@ -8,3 +8,4 @@ LL | x.push(y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex2c-push-inference-variable.stderr b/src/test/ui/lifetimes/lifetime-errors/ex2c-push-inference-variable.stderr index 57101cffe9b92..63b1c6db28f14 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex2c-push-inference-variable.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex2c-push-inference-variable.stderr @@ -9,3 +9,4 @@ LL | x.push(z); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex2d-push-inference-variable-2.stderr b/src/test/ui/lifetimes/lifetime-errors/ex2d-push-inference-variable-2.stderr index cab30636280a9..2f669efcf1eb4 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex2d-push-inference-variable-2.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex2d-push-inference-variable-2.stderr @@ -8,3 +8,4 @@ LL | let a: &mut Vec> = x; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex2e-push-inference-variable-3.stderr b/src/test/ui/lifetimes/lifetime-errors/ex2e-push-inference-variable-3.stderr index 384caca824892..258b6805acd5c 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex2e-push-inference-variable-3.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex2e-push-inference-variable-3.stderr @@ -8,3 +8,4 @@ LL | let a: &mut Vec> = x; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-2.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-2.stderr index 9251c5e2446f3..0aff80c6fbdd3 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-2.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-2.stderr @@ -8,3 +8,4 @@ LL | *v = x; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-3.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-3.stderr index adda66899cbf0..2e5ff6782d3b6 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-3.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-3.stderr @@ -16,3 +16,4 @@ LL | z.push((x,y)); error: aborting due to 2 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-2.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-2.stderr index 4341e8e663e19..8e41d7c54e68d 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-2.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-2.stderr @@ -8,3 +8,4 @@ LL | x.b = y.b; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-3.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-3.stderr index b49ee0cfc7033..d659c88f69ef7 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-3.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-3.stderr @@ -8,3 +8,4 @@ LL | x.a = x.b; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-earlybound-regions.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-earlybound-regions.stderr index a13c7e63cd6d9..374bbd93d0874 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-earlybound-regions.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-earlybound-regions.stderr @@ -9,3 +9,4 @@ LL | x.push(y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-latebound-regions.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-latebound-regions.stderr index 14faf6f460f52..94798d1ce2ab6 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-latebound-regions.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs-latebound-regions.stderr @@ -8,3 +8,4 @@ LL | x.push(y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs.stderr index e5696b74da9ec..9f5a79ed333dc 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-both-are-structs.stderr @@ -8,3 +8,4 @@ LL | x.push(y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-latebound-regions.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-latebound-regions.stderr index bbf5d2452bfb9..2c87f8dbd2c2b 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-latebound-regions.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-latebound-regions.stderr @@ -8,3 +8,4 @@ LL | x.push(y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-2.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-2.stderr index f1bc1ca3aab01..60b92ed2b3247 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-2.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-2.stderr @@ -10,3 +10,4 @@ LL | y = x.b; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-3.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-3.stderr index d8f6b8c49d30d..a220c8ddb2be6 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-3.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-3.stderr @@ -8,3 +8,4 @@ LL | y.b = x; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-4.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-4.stderr index 08ae2c9db52e7..73472a8d02252 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-4.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct-4.stderr @@ -8,3 +8,4 @@ LL | y.b = x; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct.stderr index ff286d722aacd..eb6e6f2e95e78 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-one-is-struct.stderr @@ -8,3 +8,4 @@ LL | x.b = y; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-return-type-is-anon.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-return-type-is-anon.stderr index 3d16c26568353..199f880b3c487 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-return-type-is-anon.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-return-type-is-anon.stderr @@ -10,3 +10,4 @@ LL | x error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-self-is-anon.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-self-is-anon.stderr index 10872d31ef206..838f43b37747f 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-self-is-anon.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-self-is-anon.stderr @@ -10,3 +10,4 @@ LL | if true { x } else { self } error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-fn-items.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-fn-items.stderr index 99e6e8bc5aa9b..d2cc3dba6a433 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-fn-items.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-fn-items.stderr @@ -8,3 +8,4 @@ LL | y.push(z); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-impl-items.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-impl-items.stderr index 8ac221e333ad7..e8b0208f092f7 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-impl-items.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-impl-items.stderr @@ -8,3 +8,4 @@ LL | x.push(y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-trait-objects.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-trait-objects.stderr index bfecb4d33931b..2acc4eaf60f55 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-trait-objects.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions-using-trait-objects.stderr @@ -8,3 +8,4 @@ LL | y.push(z); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions.stderr b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions.stderr index 053d577fa01ed..b2784827672b8 100644 --- a/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions.stderr +++ b/src/test/ui/lifetimes/lifetime-errors/ex3-both-anon-regions.stderr @@ -8,3 +8,4 @@ LL | x.push(y); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/object-lifetime/object-lifetime-default-mybox.stderr b/src/test/ui/object-lifetime/object-lifetime-default-mybox.stderr index f825475b96b03..89579fb1df3df 100644 --- a/src/test/ui/object-lifetime/object-lifetime-default-mybox.stderr +++ b/src/test/ui/object-lifetime/object-lifetime-default-mybox.stderr @@ -27,4 +27,5 @@ LL | fn load2<'a>(ss: &MyBox) -> MyBox { error: aborting due to 2 previous errors -For more information about this error, try `rustc --explain E0308`. +Some errors have detailed explanations: E0308, E0623. +For more information about an error, try `rustc --explain E0308`. diff --git a/src/test/ui/regions/region-lifetime-bounds-on-fns-where-clause.stderr b/src/test/ui/regions/region-lifetime-bounds-on-fns-where-clause.stderr index fd78f82d0f321..36c66451cfaf6 100644 --- a/src/test/ui/regions/region-lifetime-bounds-on-fns-where-clause.stderr +++ b/src/test/ui/regions/region-lifetime-bounds-on-fns-where-clause.stderr @@ -27,4 +27,5 @@ LL | let _: fn(&mut &isize, &mut &isize) = a; error: aborting due to 3 previous errors -For more information about this error, try `rustc --explain E0308`. +Some errors have detailed explanations: E0308, E0623. +For more information about an error, try `rustc --explain E0308`. diff --git a/src/test/ui/regions/region-multiple-lifetime-bounds-on-fns-where-clause.stderr b/src/test/ui/regions/region-multiple-lifetime-bounds-on-fns-where-clause.stderr index 220c5493d19b1..a366bd2e5c2d7 100644 --- a/src/test/ui/regions/region-multiple-lifetime-bounds-on-fns-where-clause.stderr +++ b/src/test/ui/regions/region-multiple-lifetime-bounds-on-fns-where-clause.stderr @@ -38,4 +38,5 @@ LL | let _: fn(&mut &isize, &mut &isize, &mut &isize) = a; error: aborting due to 4 previous errors -For more information about this error, try `rustc --explain E0308`. +Some errors have detailed explanations: E0308, E0623. +For more information about an error, try `rustc --explain E0308`. diff --git a/src/test/ui/regions/regions-bounded-method-type-parameters-cross-crate.stderr b/src/test/ui/regions/regions-bounded-method-type-parameters-cross-crate.stderr index 4e88be1c1e8a8..eb205a303dbdf 100644 --- a/src/test/ui/regions/regions-bounded-method-type-parameters-cross-crate.stderr +++ b/src/test/ui/regions/regions-bounded-method-type-parameters-cross-crate.stderr @@ -9,3 +9,4 @@ LL | a.bigger_region(b) error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-bounded-method-type-parameters-trait-bound.stderr b/src/test/ui/regions/regions-bounded-method-type-parameters-trait-bound.stderr index 6b1302b539402..de1073cd1d9da 100644 --- a/src/test/ui/regions/regions-bounded-method-type-parameters-trait-bound.stderr +++ b/src/test/ui/regions/regions-bounded-method-type-parameters-trait-bound.stderr @@ -9,3 +9,4 @@ LL | f.method(b); error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-creating-enums3.stderr b/src/test/ui/regions/regions-creating-enums3.stderr index 763b62d945df8..2fc1fc3f68128 100644 --- a/src/test/ui/regions/regions-creating-enums3.stderr +++ b/src/test/ui/regions/regions-creating-enums3.stderr @@ -10,3 +10,4 @@ LL | Ast::Add(x, y) error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-free-region-ordering-callee.stderr b/src/test/ui/regions/regions-free-region-ordering-callee.stderr index 49cf1dfc642da..4648bf046bc77 100644 --- a/src/test/ui/regions/regions-free-region-ordering-callee.stderr +++ b/src/test/ui/regions/regions-free-region-ordering-callee.stderr @@ -22,3 +22,4 @@ LL | let z: &'b usize = &*x; error: aborting due to 2 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-free-region-ordering-caller.migrate.stderr b/src/test/ui/regions/regions-free-region-ordering-caller.migrate.stderr index 9d6bae79ce5d8..a33d3583552dc 100644 --- a/src/test/ui/regions/regions-free-region-ordering-caller.migrate.stderr +++ b/src/test/ui/regions/regions-free-region-ordering-caller.migrate.stderr @@ -29,3 +29,4 @@ LL | let z: Option<&'a &'b usize> = None; error: aborting due to 3 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-infer-contravariance-due-to-decl.stderr b/src/test/ui/regions/regions-infer-contravariance-due-to-decl.stderr index 9374818960d36..f3a0358b90fb0 100644 --- a/src/test/ui/regions/regions-infer-contravariance-due-to-decl.stderr +++ b/src/test/ui/regions/regions-infer-contravariance-due-to-decl.stderr @@ -12,3 +12,4 @@ LL | let _: Contravariant<'long> = c; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-infer-covariance-due-to-decl.stderr b/src/test/ui/regions/regions-infer-covariance-due-to-decl.stderr index cd0a18a892f20..c3e2075fbc37e 100644 --- a/src/test/ui/regions/regions-infer-covariance-due-to-decl.stderr +++ b/src/test/ui/regions/regions-infer-covariance-due-to-decl.stderr @@ -11,3 +11,4 @@ LL | let _: Covariant<'short> = c; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-lifetime-bounds-on-fns.stderr b/src/test/ui/regions/regions-lifetime-bounds-on-fns.stderr index 0c3c342728c01..e260fccf8488c 100644 --- a/src/test/ui/regions/regions-lifetime-bounds-on-fns.stderr +++ b/src/test/ui/regions/regions-lifetime-bounds-on-fns.stderr @@ -27,4 +27,5 @@ LL | let _: fn(&mut &isize, &mut &isize) = a; error: aborting due to 3 previous errors -For more information about this error, try `rustc --explain E0308`. +Some errors have detailed explanations: E0308, E0623. +For more information about an error, try `rustc --explain E0308`. diff --git a/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref-mut-ref.stderr b/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref-mut-ref.stderr index ead448df930fe..aca3a1ed05728 100644 --- a/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref-mut-ref.stderr +++ b/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref-mut-ref.stderr @@ -10,3 +10,4 @@ LL | &mut ***p error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref.stderr b/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref.stderr index 064e89ee001c1..a9916dbe4f5ef 100644 --- a/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref.stderr +++ b/src/test/ui/regions/regions-reborrow-from-shorter-mut-ref.stderr @@ -10,3 +10,4 @@ LL | &mut **p error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-variance-contravariant-use-covariant-in-second-position.stderr b/src/test/ui/regions/regions-variance-contravariant-use-covariant-in-second-position.stderr index 6b3a488805f97..98f7a8136da91 100644 --- a/src/test/ui/regions/regions-variance-contravariant-use-covariant-in-second-position.stderr +++ b/src/test/ui/regions/regions-variance-contravariant-use-covariant-in-second-position.stderr @@ -9,3 +9,4 @@ LL | let _: S<'long, 'long> = c; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-variance-contravariant-use-covariant.stderr b/src/test/ui/regions/regions-variance-contravariant-use-covariant.stderr index 44199881444ad..e7c106cbbe3d1 100644 --- a/src/test/ui/regions/regions-variance-contravariant-use-covariant.stderr +++ b/src/test/ui/regions/regions-variance-contravariant-use-covariant.stderr @@ -12,3 +12,4 @@ LL | let _: Contravariant<'long> = c; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-variance-covariant-use-contravariant.stderr b/src/test/ui/regions/regions-variance-covariant-use-contravariant.stderr index 22ba8838893d6..e5e5261ba993f 100644 --- a/src/test/ui/regions/regions-variance-covariant-use-contravariant.stderr +++ b/src/test/ui/regions/regions-variance-covariant-use-contravariant.stderr @@ -11,3 +11,4 @@ LL | let _: Covariant<'short> = c; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/regions/regions-variance-invariant-use-contravariant.stderr b/src/test/ui/regions/regions-variance-invariant-use-contravariant.stderr index a779b485ea701..2a2d5d019a129 100644 --- a/src/test/ui/regions/regions-variance-invariant-use-contravariant.stderr +++ b/src/test/ui/regions/regions-variance-invariant-use-contravariant.stderr @@ -11,3 +11,4 @@ LL | let _: Invariant<'short> = c; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch-async.stderr b/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch-async.stderr index e3c261576e61e..37297032632e1 100644 --- a/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch-async.stderr +++ b/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch-async.stderr @@ -24,3 +24,4 @@ LL | async fn bar<'a>(self: Alias<&Self>, arg: &'a ()) -> &() { arg } error: aborting due to 3 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch.stderr b/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch.stderr index 3296e14f806e1..f3a7d14720171 100644 --- a/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch.stderr +++ b/src/test/ui/self/arbitrary_self_types_pin_lifetime_mismatch.stderr @@ -24,3 +24,4 @@ LL | fn bar<'a>(self: Alias<&Self>, arg: &'a ()) -> &() { arg } error: aborting due to 3 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/lt-ref-self-async.stderr b/src/test/ui/self/elision/lt-ref-self-async.stderr index 6b668d9f1f655..235b71ccab3a8 100644 --- a/src/test/ui/self/elision/lt-ref-self-async.stderr +++ b/src/test/ui/self/elision/lt-ref-self-async.stderr @@ -60,3 +60,4 @@ LL | f error: aborting due to 6 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/lt-ref-self.stderr b/src/test/ui/self/elision/lt-ref-self.stderr index f73b3eddd3821..afd07d38f2fe4 100644 --- a/src/test/ui/self/elision/lt-ref-self.stderr +++ b/src/test/ui/self/elision/lt-ref-self.stderr @@ -60,3 +60,4 @@ LL | f error: aborting due to 6 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-mut-self-async.stderr b/src/test/ui/self/elision/ref-mut-self-async.stderr index 29fbec9fa7ae0..a656808d46bc2 100644 --- a/src/test/ui/self/elision/ref-mut-self-async.stderr +++ b/src/test/ui/self/elision/ref-mut-self-async.stderr @@ -60,3 +60,4 @@ LL | f error: aborting due to 6 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-mut-self.stderr b/src/test/ui/self/elision/ref-mut-self.stderr index 37984cd72fbac..3d6ae4b3dd388 100644 --- a/src/test/ui/self/elision/ref-mut-self.stderr +++ b/src/test/ui/self/elision/ref-mut-self.stderr @@ -60,3 +60,4 @@ LL | f error: aborting due to 6 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-mut-struct-async.stderr b/src/test/ui/self/elision/ref-mut-struct-async.stderr index 46591bfc9580f..2dc8cdb7d28ec 100644 --- a/src/test/ui/self/elision/ref-mut-struct-async.stderr +++ b/src/test/ui/self/elision/ref-mut-struct-async.stderr @@ -50,3 +50,4 @@ LL | f error: aborting due to 5 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-mut-struct.stderr b/src/test/ui/self/elision/ref-mut-struct.stderr index 2a4826905b94a..3fec398bb9879 100644 --- a/src/test/ui/self/elision/ref-mut-struct.stderr +++ b/src/test/ui/self/elision/ref-mut-struct.stderr @@ -50,3 +50,4 @@ LL | f error: aborting due to 5 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-self-async.stderr b/src/test/ui/self/elision/ref-self-async.stderr index c255d18936376..bda958241b67b 100644 --- a/src/test/ui/self/elision/ref-self-async.stderr +++ b/src/test/ui/self/elision/ref-self-async.stderr @@ -70,3 +70,4 @@ LL | f error: aborting due to 7 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-self.stderr b/src/test/ui/self/elision/ref-self.stderr index 611498f18da42..8343c8d349e16 100644 --- a/src/test/ui/self/elision/ref-self.stderr +++ b/src/test/ui/self/elision/ref-self.stderr @@ -70,3 +70,4 @@ LL | f error: aborting due to 7 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-struct-async.stderr b/src/test/ui/self/elision/ref-struct-async.stderr index c70facc931ec1..49a2a00953d87 100644 --- a/src/test/ui/self/elision/ref-struct-async.stderr +++ b/src/test/ui/self/elision/ref-struct-async.stderr @@ -50,3 +50,4 @@ LL | f error: aborting due to 5 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/self/elision/ref-struct.stderr b/src/test/ui/self/elision/ref-struct.stderr index 186e651c143bf..5116488dd22bb 100644 --- a/src/test/ui/self/elision/ref-struct.stderr +++ b/src/test/ui/self/elision/ref-struct.stderr @@ -50,3 +50,4 @@ LL | f error: aborting due to 5 previous errors +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/underscore-lifetime/underscore-lifetime-elison-mismatch.stderr b/src/test/ui/underscore-lifetime/underscore-lifetime-elison-mismatch.stderr index 21fdfcaef862e..76c14ccc14b45 100644 --- a/src/test/ui/underscore-lifetime/underscore-lifetime-elison-mismatch.stderr +++ b/src/test/ui/underscore-lifetime/underscore-lifetime-elison-mismatch.stderr @@ -8,3 +8,4 @@ LL | fn foo(x: &mut Vec<&'_ u8>, y: &'_ u8) { x.push(y); } error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. diff --git a/src/test/ui/variance/variance-cell-is-invariant.stderr b/src/test/ui/variance/variance-cell-is-invariant.stderr index 91f6d7659ed4e..6fcd6460fe30a 100644 --- a/src/test/ui/variance/variance-cell-is-invariant.stderr +++ b/src/test/ui/variance/variance-cell-is-invariant.stderr @@ -12,3 +12,4 @@ LL | let _: Foo<'long> = c; error: aborting due to previous error +For more information about this error, try `rustc --explain E0623`. From 6a3a05580ee5d6f807f87013871b568eab6a55c3 Mon Sep 17 00:00:00 2001 From: Dylan DPC Date: Wed, 13 Nov 2019 01:47:25 +0100 Subject: [PATCH 3/5] Update error_codes.rs --- src/librustc/error_codes.rs | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/librustc/error_codes.rs b/src/librustc/error_codes.rs index 9274608bc2f84..dab8fd565facc 100644 --- a/src/librustc/error_codes.rs +++ b/src/librustc/error_codes.rs @@ -1912,15 +1912,17 @@ fn bar<'short, 'long>(c: Foo<'short>, l: &'long isize) { ``` In this example, we tried to set a value with an incompatible lifetime to -another one (`'long` != `'short`). We can solve this issue in two different -ways: either we make `'short` lives longer than `'long`: +another one (`'long` is unrelated to `'short`). We can solve this issue in two different +ways: + +Either we make `'short` live at least as long as `'long`: ``` struct Foo<'a> { x: &'a isize, } -// we set 'short to outlive 'long +// we set 'short to live at least as long as 'long fn bar<'short: 'long, 'long>(c: Foo<'short>, l: &'long isize) { let _: Foo<'long> = c; // ok! } From 1de094a28e1b648553e5ab3c84b8336a1d2f26ad Mon Sep 17 00:00:00 2001 From: Dylan DPC Date: Wed, 13 Nov 2019 01:50:12 +0100 Subject: [PATCH 4/5] Update error_codes.rs From fd868d4bf4d0be79b7bb0c38145faecb18f18217 Mon Sep 17 00:00:00 2001 From: Dylan DPC Date: Wed, 13 Nov 2019 02:16:01 +0100 Subject: [PATCH 5/5] tidy up! --- src/librustc/error_codes.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/librustc/error_codes.rs b/src/librustc/error_codes.rs index dab8fd565facc..a7a66fd7cd786 100644 --- a/src/librustc/error_codes.rs +++ b/src/librustc/error_codes.rs @@ -1912,8 +1912,8 @@ fn bar<'short, 'long>(c: Foo<'short>, l: &'long isize) { ``` In this example, we tried to set a value with an incompatible lifetime to -another one (`'long` is unrelated to `'short`). We can solve this issue in two different -ways: +another one (`'long` is unrelated to `'short`). We can solve this issue in +two different ways: Either we make `'short` live at least as long as `'long`: