mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 22:24:14 +00:00
Merge #10373
10373: fix: `into_iterator` not completed on `Vec<{unknown}>` r=iDawer a=iDawer Fixes #10297 Co-authored-by: Dawer <7803845+iDawer@users.noreply.github.com>
This commit is contained in:
commit
629db286d1
2 changed files with 25 additions and 7 deletions
|
@ -2504,9 +2504,8 @@ impl Type {
|
||||||
|
|
||||||
pub fn autoderef<'a>(&'a self, db: &'a dyn HirDatabase) -> impl Iterator<Item = Type> + 'a {
|
pub fn autoderef<'a>(&'a self, db: &'a dyn HirDatabase) -> impl Iterator<Item = Type> + 'a {
|
||||||
// There should be no inference vars in types passed here
|
// There should be no inference vars in types passed here
|
||||||
// FIXME check that?
|
let ty = hir_ty::replace_errors_with_variables(&self.ty).value;
|
||||||
let canonical =
|
let canonical = Canonical { value: ty, binders: CanonicalVarKinds::empty(&Interner) };
|
||||||
Canonical { value: self.ty.clone(), binders: CanonicalVarKinds::empty(&Interner) };
|
|
||||||
let environment = self.env.env.clone();
|
let environment = self.env.env.clone();
|
||||||
let ty = InEnvironment { goal: canonical, environment };
|
let ty = InEnvironment { goal: canonical, environment };
|
||||||
autoderef(db, Some(self.krate), ty)
|
autoderef(db, Some(self.krate), ty)
|
||||||
|
@ -2600,10 +2599,7 @@ impl Type {
|
||||||
callback: &mut dyn FnMut(&Ty, AssocItemId) -> ControlFlow<()>,
|
callback: &mut dyn FnMut(&Ty, AssocItemId) -> ControlFlow<()>,
|
||||||
) {
|
) {
|
||||||
// There should be no inference vars in types passed here
|
// There should be no inference vars in types passed here
|
||||||
// FIXME check that?
|
let canonical = hir_ty::replace_errors_with_variables(&self.ty);
|
||||||
// FIXME replace Unknown by bound vars here
|
|
||||||
let canonical =
|
|
||||||
Canonical { value: self.ty.clone(), binders: CanonicalVarKinds::empty(&Interner) };
|
|
||||||
|
|
||||||
let env = self.env.clone();
|
let env = self.env.clone();
|
||||||
let krate = krate.id;
|
let krate = krate.id;
|
||||||
|
|
|
@ -697,4 +697,26 @@ fn f() {
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn completes_method_call_when_receiver_type_has_errors_issue_10297() {
|
||||||
|
check(
|
||||||
|
r#"
|
||||||
|
//- minicore: iterator, sized
|
||||||
|
struct Vec<T>;
|
||||||
|
impl<T> IntoIterator for Vec<T> {
|
||||||
|
type Item = ();
|
||||||
|
type IntoIter = ();
|
||||||
|
fn into_iter(self);
|
||||||
|
}
|
||||||
|
fn main() {
|
||||||
|
let x: Vec<_>;
|
||||||
|
x.$0;
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
expect![[r#"
|
||||||
|
me into_iter() (as IntoIterator) fn(self) -> <Self as IntoIterator>::IntoIter
|
||||||
|
"#]],
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue