Unnamed repository; edit this file 'description' to name the repository.
Merge pull request #22110 from lnicola/sync-from-rust
minor: Sync from downstream
Laurențiu Nicola 4 weeks ago
parent 0b696c0 · parent d18966a · commit 8d9244a
-rw-r--r--crates/hir-ty/src/infer/closure.rs17
-rw-r--r--crates/hir-ty/src/next_solver/interner.rs16
-rw-r--r--rust-version2
3 files changed, 20 insertions, 15 deletions
diff --git a/crates/hir-ty/src/infer/closure.rs b/crates/hir-ty/src/infer/closure.rs
index bebf39b694..10d514ee12 100644
--- a/crates/hir-ty/src/infer/closure.rs
+++ b/crates/hir-ty/src/infer/closure.rs
@@ -588,13 +588,8 @@ impl<'db> InferenceContext<'_, 'db> {
let ret_param_ty = projection.skip_binder().term.expect_type();
debug!(?ret_param_ty);
- let sig = projection.rebind(self.interner().mk_fn_sig(
- input_tys,
- ret_param_ty,
- false,
- Safety::Safe,
- FnAbi::Rust,
- ));
+ let sig =
+ projection.rebind(self.interner().mk_fn_sig_safe_rust_abi(input_tys, ret_param_ty));
Some(sig)
}
@@ -676,13 +671,7 @@ impl<'db> InferenceContext<'_, 'db> {
// that does not misuse a `FnSig` type, but that can be done separately.
let return_ty = return_ty.unwrap_or_else(|| self.table.next_ty_var());
- let sig = projection.rebind(self.interner().mk_fn_sig(
- input_tys,
- return_ty,
- false,
- Safety::Safe,
- FnAbi::Rust,
- ));
+ let sig = projection.rebind(self.interner().mk_fn_sig_safe_rust_abi(input_tys, return_ty));
Some(sig)
}
diff --git a/crates/hir-ty/src/next_solver/interner.rs b/crates/hir-ty/src/next_solver/interner.rs
index 9ad1b3b712..229e520972 100644
--- a/crates/hir-ty/src/next_solver/interner.rs
+++ b/crates/hir-ty/src/next_solver/interner.rs
@@ -2360,6 +2360,22 @@ impl<'db> DbInterner<'db> {
abi,
}
}
+
+ /// `mk_fn_sig`, but with a safe Rust ABI, and no C-variadic argument.
+ pub fn mk_fn_sig_safe_rust_abi<I>(self, inputs: I, output: Ty<'db>) -> FnSig<'db>
+ where
+ I: IntoIterator<Item = Ty<'db>>,
+ {
+ FnSig {
+ inputs_and_output: Tys::new_from_iter(
+ self,
+ inputs.into_iter().chain(std::iter::once(output)),
+ ),
+ c_variadic: false,
+ safety: Safety::Safe,
+ abi: FnAbi::Rust,
+ }
+ }
}
fn predicates_of(db: &dyn HirDatabase, def_id: SolverDefId) -> &GenericPredicates {
diff --git a/rust-version b/rust-version
index 8d1ee32630..e9fc6c4cd0 100644
--- a/rust-version
+++ b/rust-version
@@ -1 +1 @@
-e8e4541ff19649d95afab52fdde2c2eaa6829965
+e22c616e4e87914135c1db261a03e0437255335e