Rollup merge of #123997 - compiler-errors:self-res, r=fmease

Delay span bug when `Self` kw resolves to `DefKind::{Mod,Trait}`

Catch the case where `kw::Self` is recovered in the parser and causes us to subsequently resolve `&self`'s implicit type to something that's not a type.

This check could be made more accurate, though I'm not sure how hard we have to try here.

Fixes #123988
This commit is contained in:
Matthias Krüger 2024-04-17 05:44:53 +02:00 committed by GitHub
commit 90af17ddcb
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 58 additions and 0 deletions

View File

@ -1866,6 +1866,17 @@ pub fn lower_path(
self.set_tainted_by_errors(e); self.set_tainted_by_errors(e);
Ty::new_error(self.tcx(), e) Ty::new_error(self.tcx(), e)
} }
Res::Def(..) => {
assert_eq!(
path.segments.get(0).map(|seg| seg.ident.name),
Some(kw::SelfUpper),
"only expected incorrect resolution for `Self`"
);
Ty::new_error(
self.tcx(),
self.tcx().dcx().span_delayed_bug(span, "incorrect resolution for `Self`"),
)
}
_ => span_bug!(span, "unexpected resolution: {:?}", path.res), _ => span_bug!(span, "unexpected resolution: {:?}", path.res),
} }
} }

View File

@ -0,0 +1,17 @@
fn module() {
fn test(&mut self) {
//~^ ERROR `self` parameter is only allowed in associated functions
}
mod Self {}
//~^ ERROR expected identifier, found keyword `Self`
}
fn trait_() {
fn test(&mut self) {
//~^ ERROR `self` parameter is only allowed in associated functions
}
trait Self {}
//~^ ERROR expected identifier, found keyword `Self`
}
fn main() {}

View File

@ -0,0 +1,30 @@
error: expected identifier, found keyword `Self`
--> $DIR/incorrect-self-res.rs:5:9
|
LL | mod Self {}
| ^^^^ expected identifier, found keyword
error: expected identifier, found keyword `Self`
--> $DIR/incorrect-self-res.rs:13:11
|
LL | trait Self {}
| ^^^^ expected identifier, found keyword
error: `self` parameter is only allowed in associated functions
--> $DIR/incorrect-self-res.rs:2:13
|
LL | fn test(&mut self) {
| ^^^^^^^^^ not semantically valid as function parameter
|
= note: associated functions are those in `impl` or `trait` definitions
error: `self` parameter is only allowed in associated functions
--> $DIR/incorrect-self-res.rs:10:13
|
LL | fn test(&mut self) {
| ^^^^^^^^^ not semantically valid as function parameter
|
= note: associated functions are those in `impl` or `trait` definitions
error: aborting due to 4 previous errors