Rollup merge of #105627 - compiler-errors:dyn-auto-suggestable, r=davidtwco
Auto traits in `dyn Trait + Auto` are suggestable Not sure why I had made the `IsSuggestableVisitor` have that rule to not consider `dyn Trait + Auto` to be suggestable. It's possible that this was done because of the fact that we don't print the right parentheses for `&(dyn Trait + Auto)`, but that's a problem with printing these types in general that we probably have tracked somewhere else...
This commit is contained in:
commit
a2c9f2a5e0
3 changed files with 29 additions and 13 deletions
|
@ -3,8 +3,8 @@
|
|||
use std::ops::ControlFlow;
|
||||
|
||||
use crate::ty::{
|
||||
visit::TypeVisitable, AliasTy, Const, ConstKind, DefIdTree, ExistentialPredicate, InferConst,
|
||||
InferTy, Opaque, PolyTraitPredicate, Ty, TyCtxt, TypeSuperVisitable, TypeVisitor,
|
||||
visit::TypeVisitable, AliasTy, Const, ConstKind, DefIdTree, InferConst, InferTy, Opaque,
|
||||
PolyTraitPredicate, Ty, TyCtxt, TypeSuperVisitable, TypeVisitor,
|
||||
};
|
||||
|
||||
use rustc_data_structures::fx::FxHashMap;
|
||||
|
@ -469,17 +469,6 @@ impl<'tcx> TypeVisitor<'tcx> for IsSuggestableVisitor<'tcx> {
|
|||
}
|
||||
}
|
||||
|
||||
Dynamic(dty, _, _) => {
|
||||
for pred in *dty {
|
||||
match pred.skip_binder() {
|
||||
ExistentialPredicate::Trait(_) | ExistentialPredicate::Projection(_) => {
|
||||
// Okay
|
||||
}
|
||||
_ => return ControlFlow::Break(()),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Param(param) => {
|
||||
// FIXME: It would be nice to make this not use string manipulation,
|
||||
// but it's pretty hard to do this, since `ty::ParamTy` is missing
|
||||
|
|
|
@ -0,0 +1,8 @@
|
|||
use std::fmt::Display;
|
||||
|
||||
fn foo(x: &(dyn Display + Send)) {}
|
||||
|
||||
fn main() {
|
||||
foo();
|
||||
//~^ ERROR this function takes 1 argument but 0 arguments were supplied
|
||||
}
|
|
@ -0,0 +1,19 @@
|
|||
error[E0061]: this function takes 1 argument but 0 arguments were supplied
|
||||
--> $DIR/display-is-suggestable.rs:6:5
|
||||
|
|
||||
LL | foo();
|
||||
| ^^^-- an argument of type `&dyn std::fmt::Display + Send` is missing
|
||||
|
|
||||
note: function defined here
|
||||
--> $DIR/display-is-suggestable.rs:3:4
|
||||
|
|
||||
LL | fn foo(x: &(dyn Display + Send)) {}
|
||||
| ^^^ ------------------------
|
||||
help: provide the argument
|
||||
|
|
||||
LL | foo(/* &dyn std::fmt::Display + Send */);
|
||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
For more information about this error, try `rustc --explain E0061`.
|
Loading…
Add table
Add a link
Reference in a new issue