Auto merge of #119722 - matthiaskrgr:rollup-y6w3c9h, r=matthiaskrgr
Rollup of 5 pull requests Successful merges: - #116129 (Rewrite `pin` module documentation to clarify usage and invariants) - #119703 (Impl trait diagnostic tweaks) - #119705 (Support `~const` in associated functions in trait impls) - #119708 (Unions are not `PointerLike`) - #119711 (Delete unused makefile in tests/ui) r? `@ghost` `@rustbot` modify labels: rollup
This commit is contained in:
commit
76101eecbe
53 changed files with 1481 additions and 579 deletions
|
|
@ -106,7 +106,8 @@ ast_lowering_misplaced_double_dot =
|
|||
.note = only allowed in tuple, tuple struct, and slice patterns
|
||||
|
||||
ast_lowering_misplaced_impl_trait =
|
||||
`impl Trait` only allowed in function and inherent method argument and return types, not in {$position}
|
||||
`impl Trait` is not allowed in {$position}
|
||||
.note = `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
ast_lowering_misplaced_relax_trait_bound =
|
||||
`?Trait` bounds are only permitted at the point where a type parameter is declared
|
||||
|
|
|
|||
|
|
@ -90,6 +90,7 @@ pub enum AssocTyParenthesesSub {
|
|||
|
||||
#[derive(Diagnostic)]
|
||||
#[diag(ast_lowering_misplaced_impl_trait, code = "E0562")]
|
||||
#[note]
|
||||
pub struct MisplacedImplTrait<'a> {
|
||||
#[primary_span]
|
||||
pub span: Span,
|
||||
|
|
|
|||
|
|
@ -12,6 +12,7 @@ use rustc_hir::def::{DefKind, Res};
|
|||
use rustc_hir::def_id::{LocalDefId, CRATE_DEF_ID};
|
||||
use rustc_hir::PredicateOrigin;
|
||||
use rustc_index::{Idx, IndexSlice, IndexVec};
|
||||
use rustc_middle::span_bug;
|
||||
use rustc_middle::ty::{ResolverAstLowering, TyCtxt};
|
||||
use rustc_span::edit_distance::find_best_match_for_name;
|
||||
use rustc_span::symbol::{kw, sym, Ident};
|
||||
|
|
@ -182,7 +183,8 @@ impl<'hir> LoweringContext<'_, 'hir> {
|
|||
self.lower_use_tree(use_tree, &prefix, id, vis_span, ident, attrs)
|
||||
}
|
||||
ItemKind::Static(box ast::StaticItem { ty: t, mutability: m, expr: e }) => {
|
||||
let (ty, body_id) = self.lower_const_item(t, span, e.as_deref());
|
||||
let (ty, body_id) =
|
||||
self.lower_const_item(t, span, e.as_deref(), ImplTraitPosition::StaticTy);
|
||||
hir::ItemKind::Static(ty, *m, body_id)
|
||||
}
|
||||
ItemKind::Const(box ast::ConstItem { generics, ty, expr, .. }) => {
|
||||
|
|
@ -191,7 +193,9 @@ impl<'hir> LoweringContext<'_, 'hir> {
|
|||
Const::No,
|
||||
id,
|
||||
&ImplTraitContext::Disallowed(ImplTraitPosition::Generic),
|
||||
|this| this.lower_const_item(ty, span, expr.as_deref()),
|
||||
|this| {
|
||||
this.lower_const_item(ty, span, expr.as_deref(), ImplTraitPosition::ConstTy)
|
||||
},
|
||||
);
|
||||
hir::ItemKind::Const(ty, generics, body_id)
|
||||
}
|
||||
|
|
@ -448,8 +452,9 @@ impl<'hir> LoweringContext<'_, 'hir> {
|
|||
ty: &Ty,
|
||||
span: Span,
|
||||
body: Option<&Expr>,
|
||||
impl_trait_position: ImplTraitPosition,
|
||||
) -> (&'hir hir::Ty<'hir>, hir::BodyId) {
|
||||
let ty = self.lower_ty(ty, &ImplTraitContext::Disallowed(ImplTraitPosition::ConstTy));
|
||||
let ty = self.lower_ty(ty, &ImplTraitContext::Disallowed(impl_trait_position));
|
||||
(ty, self.lower_const_body(span, body))
|
||||
}
|
||||
|
||||
|
|
@ -572,23 +577,25 @@ impl<'hir> LoweringContext<'_, 'hir> {
|
|||
// This is used to track which lifetimes have already been defined,
|
||||
// and which need to be replicated when lowering an async fn.
|
||||
|
||||
match parent_hir.node().expect_item().kind {
|
||||
let generics = match parent_hir.node().expect_item().kind {
|
||||
hir::ItemKind::Impl(impl_) => {
|
||||
self.is_in_trait_impl = impl_.of_trait.is_some();
|
||||
&impl_.generics
|
||||
}
|
||||
hir::ItemKind::Trait(_, _, generics, _, _) if self.tcx.features().effects => {
|
||||
self.host_param_id = generics
|
||||
.params
|
||||
.iter()
|
||||
.find(|param| {
|
||||
matches!(
|
||||
param.kind,
|
||||
hir::GenericParamKind::Const { is_host_effect: true, .. }
|
||||
)
|
||||
})
|
||||
.map(|param| param.def_id);
|
||||
hir::ItemKind::Trait(_, _, generics, _, _) => generics,
|
||||
kind => {
|
||||
span_bug!(item.span, "assoc item has unexpected kind of parent: {}", kind.descr())
|
||||
}
|
||||
_ => {}
|
||||
};
|
||||
|
||||
if self.tcx.features().effects {
|
||||
self.host_param_id = generics
|
||||
.params
|
||||
.iter()
|
||||
.find(|param| {
|
||||
matches!(param.kind, hir::GenericParamKind::Const { is_host_effect: true, .. })
|
||||
})
|
||||
.map(|param| param.def_id);
|
||||
}
|
||||
|
||||
match ctxt {
|
||||
|
|
|
|||
|
|
@ -304,8 +304,6 @@ enum ImplTraitPosition {
|
|||
ClosureParam,
|
||||
PointerParam,
|
||||
FnTraitParam,
|
||||
TraitParam,
|
||||
ImplParam,
|
||||
ExternFnReturn,
|
||||
ClosureReturn,
|
||||
PointerReturn,
|
||||
|
|
@ -324,29 +322,27 @@ impl std::fmt::Display for ImplTraitPosition {
|
|||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||
let name = match self {
|
||||
ImplTraitPosition::Path => "paths",
|
||||
ImplTraitPosition::Variable => "variable bindings",
|
||||
ImplTraitPosition::Variable => "the type of variable bindings",
|
||||
ImplTraitPosition::Trait => "traits",
|
||||
ImplTraitPosition::AsyncBlock => "async blocks",
|
||||
ImplTraitPosition::Bound => "bounds",
|
||||
ImplTraitPosition::Generic => "generics",
|
||||
ImplTraitPosition::ExternFnParam => "`extern fn` params",
|
||||
ImplTraitPosition::ClosureParam => "closure params",
|
||||
ImplTraitPosition::PointerParam => "`fn` pointer params",
|
||||
ImplTraitPosition::FnTraitParam => "`Fn` trait params",
|
||||
ImplTraitPosition::TraitParam => "trait method params",
|
||||
ImplTraitPosition::ImplParam => "`impl` method params",
|
||||
ImplTraitPosition::ExternFnParam => "`extern fn` parameters",
|
||||
ImplTraitPosition::ClosureParam => "closure parameters",
|
||||
ImplTraitPosition::PointerParam => "`fn` pointer parameters",
|
||||
ImplTraitPosition::FnTraitParam => "the parameters of `Fn` trait bounds",
|
||||
ImplTraitPosition::ExternFnReturn => "`extern fn` return types",
|
||||
ImplTraitPosition::ClosureReturn => "closure return types",
|
||||
ImplTraitPosition::PointerReturn => "`fn` pointer return types",
|
||||
ImplTraitPosition::FnTraitReturn => "`Fn` trait return types",
|
||||
ImplTraitPosition::FnTraitReturn => "the return type of `Fn` trait bounds",
|
||||
ImplTraitPosition::GenericDefault => "generic parameter defaults",
|
||||
ImplTraitPosition::ConstTy => "const types",
|
||||
ImplTraitPosition::StaticTy => "static types",
|
||||
ImplTraitPosition::AssocTy => "associated types",
|
||||
ImplTraitPosition::FieldTy => "field types",
|
||||
ImplTraitPosition::Cast => "cast types",
|
||||
ImplTraitPosition::Cast => "cast expression types",
|
||||
ImplTraitPosition::ImplSelf => "impl headers",
|
||||
ImplTraitPosition::OffsetOf => "`offset_of!` params",
|
||||
ImplTraitPosition::OffsetOf => "`offset_of!` parameters",
|
||||
};
|
||||
|
||||
write!(f, "{name}")
|
||||
|
|
@ -364,19 +360,6 @@ enum FnDeclKind {
|
|||
Impl,
|
||||
}
|
||||
|
||||
impl FnDeclKind {
|
||||
fn param_impl_trait_allowed(&self) -> bool {
|
||||
matches!(self, FnDeclKind::Fn | FnDeclKind::Inherent | FnDeclKind::Impl | FnDeclKind::Trait)
|
||||
}
|
||||
|
||||
fn return_impl_trait_allowed(&self) -> bool {
|
||||
match self {
|
||||
FnDeclKind::Fn | FnDeclKind::Inherent | FnDeclKind::Impl | FnDeclKind::Trait => true,
|
||||
_ => false,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Copy, Clone)]
|
||||
enum AstOwner<'a> {
|
||||
NonOwner,
|
||||
|
|
@ -1842,19 +1825,19 @@ impl<'a, 'hir> LoweringContext<'a, 'hir> {
|
|||
inputs = &inputs[..inputs.len() - 1];
|
||||
}
|
||||
let inputs = self.arena.alloc_from_iter(inputs.iter().map(|param| {
|
||||
let itctx = if kind.param_impl_trait_allowed() {
|
||||
ImplTraitContext::Universal
|
||||
} else {
|
||||
ImplTraitContext::Disallowed(match kind {
|
||||
FnDeclKind::Fn | FnDeclKind::Inherent => {
|
||||
unreachable!("fn should allow APIT")
|
||||
}
|
||||
FnDeclKind::ExternFn => ImplTraitPosition::ExternFnParam,
|
||||
FnDeclKind::Closure => ImplTraitPosition::ClosureParam,
|
||||
FnDeclKind::Pointer => ImplTraitPosition::PointerParam,
|
||||
FnDeclKind::Trait => ImplTraitPosition::TraitParam,
|
||||
FnDeclKind::Impl => ImplTraitPosition::ImplParam,
|
||||
})
|
||||
let itctx = match kind {
|
||||
FnDeclKind::Fn | FnDeclKind::Inherent | FnDeclKind::Impl | FnDeclKind::Trait => {
|
||||
ImplTraitContext::Universal
|
||||
}
|
||||
FnDeclKind::ExternFn => {
|
||||
ImplTraitContext::Disallowed(ImplTraitPosition::ExternFnParam)
|
||||
}
|
||||
FnDeclKind::Closure => {
|
||||
ImplTraitContext::Disallowed(ImplTraitPosition::ClosureParam)
|
||||
}
|
||||
FnDeclKind::Pointer => {
|
||||
ImplTraitContext::Disallowed(ImplTraitPosition::PointerParam)
|
||||
}
|
||||
};
|
||||
self.lower_ty_direct(¶m.ty, &itctx)
|
||||
}));
|
||||
|
|
@ -1866,26 +1849,25 @@ impl<'a, 'hir> LoweringContext<'a, 'hir> {
|
|||
}
|
||||
None => match &decl.output {
|
||||
FnRetTy::Ty(ty) => {
|
||||
let context = if kind.return_impl_trait_allowed() {
|
||||
let fn_def_id = self.local_def_id(fn_node_id);
|
||||
ImplTraitContext::ReturnPositionOpaqueTy {
|
||||
origin: hir::OpaqueTyOrigin::FnReturn(fn_def_id),
|
||||
let itctx = match kind {
|
||||
FnDeclKind::Fn
|
||||
| FnDeclKind::Inherent
|
||||
| FnDeclKind::Trait
|
||||
| FnDeclKind::Impl => ImplTraitContext::ReturnPositionOpaqueTy {
|
||||
origin: hir::OpaqueTyOrigin::FnReturn(self.local_def_id(fn_node_id)),
|
||||
fn_kind: kind,
|
||||
},
|
||||
FnDeclKind::ExternFn => {
|
||||
ImplTraitContext::Disallowed(ImplTraitPosition::ExternFnReturn)
|
||||
}
|
||||
FnDeclKind::Closure => {
|
||||
ImplTraitContext::Disallowed(ImplTraitPosition::ClosureReturn)
|
||||
}
|
||||
FnDeclKind::Pointer => {
|
||||
ImplTraitContext::Disallowed(ImplTraitPosition::PointerReturn)
|
||||
}
|
||||
} else {
|
||||
ImplTraitContext::Disallowed(match kind {
|
||||
FnDeclKind::Fn
|
||||
| FnDeclKind::Inherent
|
||||
| FnDeclKind::Trait
|
||||
| FnDeclKind::Impl => {
|
||||
unreachable!("fn should allow return-position impl trait in traits")
|
||||
}
|
||||
FnDeclKind::ExternFn => ImplTraitPosition::ExternFnReturn,
|
||||
FnDeclKind::Closure => ImplTraitPosition::ClosureReturn,
|
||||
FnDeclKind::Pointer => ImplTraitPosition::PointerReturn,
|
||||
})
|
||||
};
|
||||
hir::FnRetTy::Return(self.lower_ty(ty, &context))
|
||||
hir::FnRetTy::Return(self.lower_ty(ty, &itctx))
|
||||
}
|
||||
FnRetTy::Default(span) => hir::FnRetTy::DefaultReturn(self.lower_span(*span)),
|
||||
},
|
||||
|
|
|
|||
|
|
@ -120,11 +120,11 @@ impl<'a> Layout<'a> {
|
|||
/// Whether the layout is from a type that implements [`std::marker::PointerLike`].
|
||||
///
|
||||
/// Currently, that means that the type is pointer-sized, pointer-aligned,
|
||||
/// and has a scalar ABI.
|
||||
/// and has a initialized (non-union), scalar ABI.
|
||||
pub fn is_pointer_like(self, data_layout: &TargetDataLayout) -> bool {
|
||||
self.size() == data_layout.pointer_size
|
||||
&& self.align().abi == data_layout.pointer_align.abi
|
||||
&& matches!(self.abi(), Abi::Scalar(..))
|
||||
&& matches!(self.abi(), Abi::Scalar(Scalar::Initialized { .. }))
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -899,25 +899,37 @@ marker_impls! {
|
|||
{T: ?Sized} &mut T,
|
||||
}
|
||||
|
||||
/// Types that can be safely moved after being pinned.
|
||||
/// Types that do not require any pinning guarantees.
|
||||
///
|
||||
/// Rust itself has no notion of immovable types, and considers moves (e.g.,
|
||||
/// through assignment or [`mem::replace`]) to always be safe.
|
||||
/// For information on what "pinning" is, see the [`pin` module] documentation.
|
||||
///
|
||||
/// The [`Pin`][Pin] type is used instead to prevent moves through the type
|
||||
/// system. Pointers `P<T>` wrapped in the [`Pin<P<T>>`][Pin] wrapper can't be
|
||||
/// moved out of. See the [`pin` module] documentation for more information on
|
||||
/// pinning.
|
||||
/// Implementing the `Unpin` trait for `T` expresses the fact that `T` is pinning-agnostic:
|
||||
/// it shall not expose nor rely on any pinning guarantees. This, in turn, means that a
|
||||
/// `Pin`-wrapped pointer to such a type can feature a *fully unrestricted* API.
|
||||
/// In other words, if `T: Unpin`, a value of type `T` will *not* be bound by the invariants
|
||||
/// which pinning otherwise offers, even when "pinned" by a [`Pin<Ptr>`] pointing at it.
|
||||
/// When a value of type `T` is pointed at by a [`Pin<Ptr>`], [`Pin`] will not restrict access
|
||||
/// to the pointee value like it normally would, thus allowing the user to do anything that they
|
||||
/// normally could with a non-[`Pin`]-wrapped `Ptr` to that value.
|
||||
///
|
||||
/// Implementing the `Unpin` trait for `T` lifts the restrictions of pinning off
|
||||
/// the type, which then allows moving `T` out of [`Pin<P<T>>`][Pin] with
|
||||
/// functions such as [`mem::replace`].
|
||||
/// The idea of this trait is to alleviate the reduced ergonomics of APIs that require the use
|
||||
/// of [`Pin`] for soundness for some types, but which also want to be used by other types that
|
||||
/// don't care about pinning. The prime example of such an API is [`Future::poll`]. There are many
|
||||
/// [`Future`] types that don't care about pinning. These futures can implement `Unpin` and
|
||||
/// therefore get around the pinning related restrictions in the API, while still allowing the
|
||||
/// subset of [`Future`]s which *do* require pinning to be implemented soundly.
|
||||
///
|
||||
/// `Unpin` has no consequence at all for non-pinned data. In particular,
|
||||
/// [`mem::replace`] happily moves `!Unpin` data (it works for any `&mut T`, not
|
||||
/// just when `T: Unpin`). However, you cannot use [`mem::replace`] on data
|
||||
/// wrapped inside a [`Pin<P<T>>`][Pin] because you cannot get the `&mut T` you
|
||||
/// need for that, and *that* is what makes this system work.
|
||||
/// For more discussion on the consequences of [`Unpin`] within the wider scope of the pinning
|
||||
/// system, see the [section about `Unpin`] in the [`pin` module].
|
||||
///
|
||||
/// `Unpin` has no consequence at all for non-pinned data. In particular, [`mem::replace`] happily
|
||||
/// moves `!Unpin` data, which would be immovable when pinned ([`mem::replace`] works for any
|
||||
/// `&mut T`, not just when `T: Unpin`).
|
||||
///
|
||||
/// *However*, you cannot use [`mem::replace`] on `!Unpin` data which is *pinned* by being wrapped
|
||||
/// inside a [`Pin<Ptr>`] pointing at it. This is because you cannot (safely) use a
|
||||
/// [`Pin<Ptr>`] to get an `&mut T` to its pointee value, which you would need to call
|
||||
/// [`mem::replace`], and *that* is what makes this system work.
|
||||
///
|
||||
/// So this, for example, can only be done on types implementing `Unpin`:
|
||||
///
|
||||
|
|
@ -935,11 +947,22 @@ marker_impls! {
|
|||
/// mem::replace(&mut *pinned_string, "other".to_string());
|
||||
/// ```
|
||||
///
|
||||
/// This trait is automatically implemented for almost every type.
|
||||
/// This trait is automatically implemented for almost every type. The compiler is free
|
||||
/// to take the conservative stance of marking types as [`Unpin`] so long as all of the types that
|
||||
/// compose its fields are also [`Unpin`]. This is because if a type implements [`Unpin`], then it
|
||||
/// is unsound for that type's implementation to rely on pinning-related guarantees for soundness,
|
||||
/// *even* when viewed through a "pinning" pointer! It is the responsibility of the implementor of
|
||||
/// a type that relies upon pinning for soundness to ensure that type is *not* marked as [`Unpin`]
|
||||
/// by adding [`PhantomPinned`] field. For more details, see the [`pin` module] docs.
|
||||
///
|
||||
/// [`mem::replace`]: crate::mem::replace
|
||||
/// [Pin]: crate::pin::Pin
|
||||
/// [`pin` module]: crate::pin
|
||||
/// [`mem::replace`]: crate::mem::replace "mem replace"
|
||||
/// [`Future`]: crate::future::Future "Future"
|
||||
/// [`Future::poll`]: crate::future::Future::poll "Future poll"
|
||||
/// [`Pin`]: crate::pin::Pin "Pin"
|
||||
/// [`Pin<Ptr>`]: crate::pin::Pin "Pin"
|
||||
/// [`pin` module]: crate::pin "pin module"
|
||||
/// [section about `Unpin`]: crate::pin#unpin "pin module docs about unpin"
|
||||
/// [`unsafe`]: ../../std/keyword.unsafe.html "keyword unsafe"
|
||||
#[stable(feature = "pin", since = "1.33.0")]
|
||||
#[diagnostic::on_unimplemented(
|
||||
note = "consider using the `pin!` macro\nconsider using `Box::pin` if you need to access the pinned value outside of the current scope",
|
||||
|
|
|
|||
File diff suppressed because it is too large
Load diff
|
|
@ -33,7 +33,6 @@ const EXTENSION_EXCEPTION_PATHS: &[&str] = &[
|
|||
"tests/ui/macros/macro-expanded-include/file.txt", // testing including data with the include macros
|
||||
"tests/ui/macros/not-utf8.bin", // testing including data with the include macros
|
||||
"tests/ui/macros/syntax-extension-source-utils-files/includeme.fragment", // more include
|
||||
"tests/ui/unused-crate-deps/test.mk", // why would you use make
|
||||
"tests/ui/proc-macro/auxiliary/included-file.txt", // more include
|
||||
"tests/ui/invalid/foo.natvis.xml", // sample debugger visualizer
|
||||
];
|
||||
|
|
|
|||
|
|
@ -33,11 +33,13 @@ LL | fn main<A: TraitWAssocConst<A=32>>() {
|
|||
= note: see issue #92827 <https://github.com/rust-lang/rust/issues/92827> for more information
|
||||
= help: add `#![feature(associated_const_equality)]` to the crate attributes to enable
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in impl headers
|
||||
error[E0562]: `impl Trait` is not allowed in impl headers
|
||||
--> $DIR/issue-105330.rs:6:27
|
||||
|
|
||||
LL | impl TraitWAssocConst for impl Demo {
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0131]: `main` function is not allowed to have generic parameters
|
||||
--> $DIR/issue-105330.rs:15:8
|
||||
|
|
|
|||
|
|
@ -13,7 +13,7 @@ note: required because it appears within the type `Sleep`
|
|||
|
|
||||
LL | struct Sleep(std::marker::PhantomPinned);
|
||||
| ^^^^^
|
||||
note: required by a bound in `Pin::<P>::new`
|
||||
note: required by a bound in `Pin::<Ptr>::new`
|
||||
--> $SRC_DIR/core/src/pin.rs:LL:COL
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
error[E0133]: call to unsafe function `Pin::<P>::new_unchecked` is unsafe and requires unsafe function or block
|
||||
error[E0133]: call to unsafe function `Pin::<Ptr>::new_unchecked` is unsafe and requires unsafe function or block
|
||||
--> $DIR/coerce-unsafe-closure-to-unsafe-fn-ptr.rs:2:31
|
||||
|
|
||||
LL | let _: unsafe fn() = || { ::std::pin::Pin::new_unchecked(&0_u8); };
|
||||
|
|
|
|||
16
tests/ui/dyn-star/union.rs
Normal file
16
tests/ui/dyn-star/union.rs
Normal file
|
|
@ -0,0 +1,16 @@
|
|||
#![feature(dyn_star)]
|
||||
//~^ WARN the feature `dyn_star` is incomplete and may not be safe to use and/or cause compiler crashes
|
||||
|
||||
union Union {
|
||||
x: usize,
|
||||
}
|
||||
|
||||
trait Trait {}
|
||||
impl Trait for Union {}
|
||||
|
||||
fn bar(_: dyn* Trait) {}
|
||||
|
||||
fn main() {
|
||||
bar(Union { x: 0usize });
|
||||
//~^ ERROR `Union` needs to have the same ABI as a pointer
|
||||
}
|
||||
20
tests/ui/dyn-star/union.stderr
Normal file
20
tests/ui/dyn-star/union.stderr
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
warning: the feature `dyn_star` is incomplete and may not be safe to use and/or cause compiler crashes
|
||||
--> $DIR/union.rs:1:12
|
||||
|
|
||||
LL | #![feature(dyn_star)]
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: see issue #102425 <https://github.com/rust-lang/rust/issues/102425> for more information
|
||||
= note: `#[warn(incomplete_features)]` on by default
|
||||
|
||||
error[E0277]: `Union` needs to have the same ABI as a pointer
|
||||
--> $DIR/union.rs:14:9
|
||||
|
|
||||
LL | bar(Union { x: 0usize });
|
||||
| ^^^^^^^^^^^^^^^^^^^ `Union` needs to be a pointer-like type
|
||||
|
|
||||
= help: the trait `PointerLike` is not implemented for `Union`
|
||||
|
||||
error: aborting due to 1 previous error; 1 warning emitted
|
||||
|
||||
For more information about this error, try `rustc --explain E0277`.
|
||||
|
|
@ -54,20 +54,20 @@ fn _rpit_dyn() -> Box<dyn Tr1<As1: Copy>> { Box::new(S1) }
|
|||
|
||||
const _cdef: impl Tr1<As1: Copy> = S1;
|
||||
//~^ ERROR associated type bounds are unstable
|
||||
//~| ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~| ERROR `impl Trait` is not allowed in const types
|
||||
// FIXME: uncomment when `impl_trait_in_bindings` feature is fixed.
|
||||
// const _cdef_dyn: &dyn Tr1<As1: Copy> = &S1;
|
||||
|
||||
static _sdef: impl Tr1<As1: Copy> = S1;
|
||||
//~^ ERROR associated type bounds are unstable
|
||||
//~| ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~| ERROR `impl Trait` is not allowed in static types
|
||||
// FIXME: uncomment when `impl_trait_in_bindings` feature is fixed.
|
||||
// static _sdef_dyn: &dyn Tr1<As1: Copy> = &S1;
|
||||
|
||||
fn main() {
|
||||
let _: impl Tr1<As1: Copy> = S1;
|
||||
//~^ ERROR associated type bounds are unstable
|
||||
//~| ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~| ERROR `impl Trait` is not allowed in the type of variable bindings
|
||||
// FIXME: uncomment when `impl_trait_in_bindings` feature is fixed.
|
||||
// let _: &dyn Tr1<As1: Copy> = &S1;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -115,23 +115,29 @@ LL | let _: impl Tr1<As1: Copy> = S1;
|
|||
= note: see issue #52662 <https://github.com/rust-lang/rust/issues/52662> for more information
|
||||
= help: add `#![feature(associated_type_bounds)]` to the crate attributes to enable
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in const types
|
||||
error[E0562]: `impl Trait` is not allowed in const types
|
||||
--> $DIR/feature-gate-associated_type_bounds.rs:55:14
|
||||
|
|
||||
LL | const _cdef: impl Tr1<As1: Copy> = S1;
|
||||
| ^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in const types
|
||||
error[E0562]: `impl Trait` is not allowed in static types
|
||||
--> $DIR/feature-gate-associated_type_bounds.rs:61:15
|
||||
|
|
||||
LL | static _sdef: impl Tr1<As1: Copy> = S1;
|
||||
| ^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/feature-gate-associated_type_bounds.rs:68:12
|
||||
|
|
||||
LL | let _: impl Tr1<As1: Copy> = S1;
|
||||
| ^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0277]: the trait bound `<<Self as _Tr3>::A as Iterator>::Item: Copy` is not satisfied
|
||||
--> $DIR/feature-gate-associated_type_bounds.rs:12:28
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
fn f() -> impl Fn() -> impl Sized { || () }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return
|
||||
//~^ ERROR `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
fn g() -> &'static dyn Fn() -> impl Sized { &|| () }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return
|
||||
//~^ ERROR `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
|
||||
fn main() {}
|
||||
|
|
|
|||
|
|
@ -1,18 +1,20 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return types
|
||||
error[E0562]: `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
--> $DIR/feature-gate-impl_trait_in_fn_trait_return.rs:1:24
|
||||
|
|
||||
LL | fn f() -> impl Fn() -> impl Sized { || () }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
= note: see issue #99697 <https://github.com/rust-lang/rust/issues/99697> for more information
|
||||
= help: add `#![feature(impl_trait_in_fn_trait_return)]` to the crate attributes to enable
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return types
|
||||
error[E0562]: `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
--> $DIR/feature-gate-impl_trait_in_fn_trait_return.rs:3:32
|
||||
|
|
||||
LL | fn g() -> &'static dyn Fn() -> impl Sized { &|| () }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
= note: see issue #99697 <https://github.com/rust-lang/rust/issues/99697> for more information
|
||||
= help: add `#![feature(impl_trait_in_fn_trait_return)]` to the crate attributes to enable
|
||||
|
||||
|
|
|
|||
|
|
@ -2,6 +2,6 @@ use std::fmt::Debug;
|
|||
|
||||
fn main() {
|
||||
let x: Option<impl Debug> = Some(44_u32);
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
println!("{:?}", x);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-54600.rs:4:19
|
||||
|
|
||||
LL | let x: Option<impl Debug> = Some(44_u32);
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -3,5 +3,5 @@ use std::ops::Add;
|
|||
fn main() {
|
||||
let i: i32 = 0;
|
||||
let j: &impl Add = &i;
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-54840.rs:5:13
|
||||
|
|
||||
LL | let j: &impl Add = &i;
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -8,5 +8,5 @@ fn mk_gen() -> impl Coroutine<Return=!, Yield=()> {
|
|||
|
||||
fn main() {
|
||||
let gens: [impl Coroutine<Return=!, Yield=()>;2] = [ mk_gen(), mk_gen() ];
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-58504.rs:10:16
|
||||
|
|
||||
LL | let gens: [impl Coroutine<Return=!, Yield=()>;2] = [ mk_gen(), mk_gen() ];
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -5,9 +5,9 @@ impl Lam for B {}
|
|||
pub struct Wrap<T>(T);
|
||||
|
||||
const _A: impl Lam = {
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in const types
|
||||
let x: Wrap<impl Lam> = Wrap(B);
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
x.0
|
||||
};
|
||||
|
||||
|
|
|
|||
|
|
@ -1,14 +1,18 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in const types
|
||||
error[E0562]: `impl Trait` is not allowed in const types
|
||||
--> $DIR/issue-58956.rs:7:11
|
||||
|
|
||||
LL | const _A: impl Lam = {
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-58956.rs:9:17
|
||||
|
|
||||
LL | let x: Wrap<impl Lam> = Wrap(B);
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
fn main() {
|
||||
let x : (impl Copy,) = (true,);
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-70971.rs:2:14
|
||||
|
|
||||
LL | let x : (impl Copy,) = (true,);
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
struct Bug {
|
||||
V1: [(); {
|
||||
let f: impl core::future::Future<Output = u8> = async { 1 };
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
//~| expected identifier
|
||||
1
|
||||
}],
|
||||
|
|
|
|||
|
|
@ -9,11 +9,13 @@ LL | let f: impl core::future::Future<Output = u8> = async { 1 };
|
|||
= help: pass `--edition 2021` to `rustc`
|
||||
= note: for more on editions, read https://doc.rust-lang.org/edition-guide
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-79099.rs:3:16
|
||||
|
|
||||
LL | let f: impl core::future::Future<Output = u8> = async { 1 };
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
|
|
|
|||
|
|
@ -1,8 +1,8 @@
|
|||
struct Foo<T = impl Copy>(T);
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
|
||||
type Result<T, E = impl std::error::Error> = std::result::Result<T, E>;
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
|
||||
// should not cause ICE
|
||||
fn x() -> Foo {
|
||||
|
|
|
|||
|
|
@ -1,14 +1,18 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/issue-83929-impl-trait-in-generic-default.rs:1:16
|
||||
|
|
||||
LL | struct Foo<T = impl Copy>(T);
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/issue-83929-impl-trait-in-generic-default.rs:4:20
|
||||
|
|
||||
LL | type Result<T, E = impl std::error::Error> = std::result::Result<T, E>;
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@ impl Trait for () {}
|
|||
|
||||
fn foo<'a: 'a>() {
|
||||
let _x: impl Trait = ();
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
}
|
||||
|
||||
fn main() {}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-84919.rs:5:13
|
||||
|
|
||||
LL | let _x: impl Trait = ();
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
static x: impl Fn(&str) -> Result<&str, ()> = move |source| {
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in static types
|
||||
let res = (move |source| Ok(source))(source);
|
||||
let res = res.or((move |source| Ok(source))(source));
|
||||
res
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in const types
|
||||
error[E0562]: `impl Trait` is not allowed in static types
|
||||
--> $DIR/issue-86642.rs:1:11
|
||||
|
|
||||
LL | static x: impl Fn(&str) -> Result<&str, ()> = move |source| {
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -14,5 +14,5 @@ impl<F> Struct<F> {
|
|||
|
||||
fn main() {
|
||||
let _do_not_waste: Struct<impl Trait<Output = i32>> = Struct::new(());
|
||||
//~^ `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ `impl Trait` is not allowed in the type of variable bindings
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-87295.rs:16:31
|
||||
|
|
||||
LL | let _do_not_waste: Struct<impl Trait<Output = i32>> = Struct::new(());
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -9,7 +9,7 @@ fn bad_in_ret_position(x: impl Into<u32>) -> impl Into<impl Debug> { x }
|
|||
|
||||
fn bad_in_fn_syntax(x: fn() -> impl Into<impl Debug>) {}
|
||||
//~^ ERROR nested `impl Trait` is not allowed
|
||||
//~| `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~| `impl Trait` is not allowed in `fn` pointer
|
||||
|
||||
fn bad_in_arg_position(_: impl Into<impl Debug>) { }
|
||||
//~^ ERROR nested `impl Trait` is not allowed
|
||||
|
|
|
|||
|
|
@ -34,11 +34,13 @@ LL | fn bad(x: impl Into<u32>) -> impl Into<impl Debug> { x }
|
|||
| | nested `impl Trait` here
|
||||
| outer `impl Trait`
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `fn` pointer return types
|
||||
error[E0562]: `impl Trait` is not allowed in `fn` pointer return types
|
||||
--> $DIR/nested_impl_trait.rs:10:32
|
||||
|
|
||||
LL | fn bad_in_fn_syntax(x: fn() -> impl Into<impl Debug>) {}
|
||||
| ^^^^^^^^^^^^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0277]: the trait bound `impl Debug: From<impl Into<u32>>` is not satisfied
|
||||
--> $DIR/nested_impl_trait.rs:6:46
|
||||
|
|
|
|||
|
|
@ -16,47 +16,47 @@ fn in_adt_in_parameters(_: Vec<impl Debug>) { panic!() }
|
|||
|
||||
// Disallowed
|
||||
fn in_fn_parameter_in_parameters(_: fn(impl Debug)) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in `fn` pointer
|
||||
|
||||
// Disallowed
|
||||
fn in_fn_return_in_parameters(_: fn() -> impl Debug) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in `fn` pointer
|
||||
|
||||
// Disallowed
|
||||
fn in_fn_parameter_in_return() -> fn(impl Debug) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in `fn` pointer
|
||||
|
||||
// Disallowed
|
||||
fn in_fn_return_in_return() -> fn() -> impl Debug { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in `fn` pointer
|
||||
|
||||
// Disallowed
|
||||
fn in_dyn_Fn_parameter_in_parameters(_: &dyn Fn(impl Debug)) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
|
||||
// Disallowed
|
||||
fn in_dyn_Fn_return_in_parameters(_: &dyn Fn() -> impl Debug) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
|
||||
// Disallowed
|
||||
fn in_dyn_Fn_parameter_in_return() -> &'static dyn Fn(impl Debug) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
|
||||
// Allowed
|
||||
fn in_dyn_Fn_return_in_return() -> &'static dyn Fn() -> impl Debug { panic!() }
|
||||
|
||||
// Disallowed
|
||||
fn in_impl_Fn_parameter_in_parameters(_: &impl Fn(impl Debug)) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
//~^^ ERROR nested `impl Trait` is not allowed
|
||||
|
||||
// Disallowed
|
||||
fn in_impl_Fn_return_in_parameters(_: &impl Fn() -> impl Debug) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
|
||||
// Disallowed
|
||||
fn in_impl_Fn_parameter_in_return() -> &'static impl Fn(impl Debug) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
//~| ERROR nested `impl Trait` is not allowed
|
||||
|
||||
// Allowed
|
||||
|
|
@ -64,11 +64,11 @@ fn in_impl_Fn_return_in_return() -> &'static impl Fn() -> impl Debug { panic!()
|
|||
|
||||
// Disallowed
|
||||
fn in_Fn_parameter_in_generics<F: Fn(impl Debug)> (_: F) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
|
||||
// Disallowed
|
||||
fn in_Fn_return_in_generics<F: Fn() -> impl Debug> (_: F) { panic!() }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
|
||||
|
||||
// Allowed
|
||||
|
|
@ -81,22 +81,22 @@ fn in_impl_Trait_in_return() -> impl IntoIterator<Item = impl IntoIterator> {
|
|||
|
||||
// Disallowed
|
||||
struct InBraceStructField { x: impl Debug }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in field types
|
||||
|
||||
// Disallowed
|
||||
struct InAdtInBraceStructField { x: Vec<impl Debug> }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in field types
|
||||
|
||||
// Disallowed
|
||||
struct InTupleStructField(impl Debug);
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in field types
|
||||
|
||||
// Disallowed
|
||||
enum InEnum {
|
||||
InBraceVariant { x: impl Debug },
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in field types
|
||||
InTupleVariant(impl Debug),
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in field types
|
||||
}
|
||||
|
||||
// Allowed
|
||||
|
|
@ -136,10 +136,10 @@ impl DummyType {
|
|||
// Disallowed
|
||||
extern "C" {
|
||||
fn in_foreign_parameters(_: impl Debug);
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in `extern fn`
|
||||
|
||||
fn in_foreign_return() -> impl Debug;
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in `extern fn`
|
||||
}
|
||||
|
||||
// Allowed
|
||||
|
|
@ -155,97 +155,97 @@ type InTypeAlias<R> = impl Debug;
|
|||
//~^ ERROR `impl Trait` in type aliases is unstable
|
||||
|
||||
type InReturnInTypeAlias<R> = fn() -> impl Debug;
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in `fn` pointer
|
||||
//~| ERROR `impl Trait` in type aliases is unstable
|
||||
|
||||
// Disallowed in impl headers
|
||||
impl PartialEq<impl Debug> for () {
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in traits
|
||||
}
|
||||
|
||||
// Disallowed in impl headers
|
||||
impl PartialEq<()> for impl Debug {
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in impl headers
|
||||
}
|
||||
|
||||
// Disallowed in inherent impls
|
||||
impl impl Debug {
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in impl headers
|
||||
}
|
||||
|
||||
// Disallowed in inherent impls
|
||||
struct InInherentImplAdt<T> { t: T }
|
||||
impl InInherentImplAdt<impl Debug> {
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in impl headers
|
||||
}
|
||||
|
||||
// Disallowed in where clauses
|
||||
fn in_fn_where_clause()
|
||||
where impl Debug: Debug
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in bounds
|
||||
{
|
||||
}
|
||||
|
||||
// Disallowed in where clauses
|
||||
fn in_adt_in_fn_where_clause()
|
||||
where Vec<impl Debug>: Debug
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in bounds
|
||||
{
|
||||
}
|
||||
|
||||
// Disallowed
|
||||
fn in_trait_parameter_in_fn_where_clause<T>()
|
||||
where T: PartialEq<impl Debug>
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in bounds
|
||||
{
|
||||
}
|
||||
|
||||
// Disallowed
|
||||
fn in_Fn_parameter_in_fn_where_clause<T>()
|
||||
where T: Fn(impl Debug)
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
{
|
||||
}
|
||||
|
||||
// Disallowed
|
||||
fn in_Fn_return_in_fn_where_clause<T>()
|
||||
where T: Fn() -> impl Debug
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
{
|
||||
}
|
||||
|
||||
// Disallowed
|
||||
struct InStructGenericParamDefault<T = impl Debug>(T);
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
|
||||
// Disallowed
|
||||
enum InEnumGenericParamDefault<T = impl Debug> { Variant(T) }
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
|
||||
// Disallowed
|
||||
trait InTraitGenericParamDefault<T = impl Debug> {}
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
|
||||
// Disallowed
|
||||
type InTypeAliasGenericParamDefault<T = impl Debug> = T;
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
|
||||
// Disallowed
|
||||
impl <T = impl Debug> T {}
|
||||
//~^ ERROR defaults for type parameters are only allowed in `struct`, `enum`, `type`, or `trait` definitions
|
||||
//~| WARNING this was previously accepted by the compiler but is being phased out
|
||||
//~| ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~| ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
//~| ERROR no nominal type found
|
||||
|
||||
// Disallowed
|
||||
fn in_method_generic_param_default<T = impl Debug>(_: T) {}
|
||||
//~^ ERROR defaults for type parameters are only allowed in `struct`, `enum`, `type`, or `trait` definitions
|
||||
//~| WARNING this was previously accepted by the compiler but is being phased out
|
||||
//~| ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~| ERROR `impl Trait` is not allowed in generic parameter defaults
|
||||
|
||||
fn main() {
|
||||
let _in_local_variable: impl Fn() = || {};
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the type of variable bindings
|
||||
let _in_return_in_local_variable = || -> impl Fn() { || {} };
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in closure return types
|
||||
}
|
||||
|
|
|
|||
|
|
@ -43,227 +43,301 @@ LL | type InReturnInTypeAlias<R> = fn() -> impl Debug;
|
|||
= note: see issue #63063 <https://github.com/rust-lang/rust/issues/63063> for more information
|
||||
= help: add `#![feature(type_alias_impl_trait)]` to the crate attributes to enable
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `fn` pointer params
|
||||
error[E0562]: `impl Trait` is not allowed in `fn` pointer parameters
|
||||
--> $DIR/where-allowed.rs:18:40
|
||||
|
|
||||
LL | fn in_fn_parameter_in_parameters(_: fn(impl Debug)) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `fn` pointer return types
|
||||
error[E0562]: `impl Trait` is not allowed in `fn` pointer return types
|
||||
--> $DIR/where-allowed.rs:22:42
|
||||
|
|
||||
LL | fn in_fn_return_in_parameters(_: fn() -> impl Debug) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `fn` pointer params
|
||||
error[E0562]: `impl Trait` is not allowed in `fn` pointer parameters
|
||||
--> $DIR/where-allowed.rs:26:38
|
||||
|
|
||||
LL | fn in_fn_parameter_in_return() -> fn(impl Debug) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `fn` pointer return types
|
||||
error[E0562]: `impl Trait` is not allowed in `fn` pointer return types
|
||||
--> $DIR/where-allowed.rs:30:40
|
||||
|
|
||||
LL | fn in_fn_return_in_return() -> fn() -> impl Debug { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait params
|
||||
error[E0562]: `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:34:49
|
||||
|
|
||||
LL | fn in_dyn_Fn_parameter_in_parameters(_: &dyn Fn(impl Debug)) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return types
|
||||
error[E0562]: `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:38:51
|
||||
|
|
||||
LL | fn in_dyn_Fn_return_in_parameters(_: &dyn Fn() -> impl Debug) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait params
|
||||
error[E0562]: `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:42:55
|
||||
|
|
||||
LL | fn in_dyn_Fn_parameter_in_return() -> &'static dyn Fn(impl Debug) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait params
|
||||
error[E0562]: `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:49:51
|
||||
|
|
||||
LL | fn in_impl_Fn_parameter_in_parameters(_: &impl Fn(impl Debug)) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return types
|
||||
error[E0562]: `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:54:53
|
||||
|
|
||||
LL | fn in_impl_Fn_return_in_parameters(_: &impl Fn() -> impl Debug) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait params
|
||||
error[E0562]: `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:58:57
|
||||
|
|
||||
LL | fn in_impl_Fn_parameter_in_return() -> &'static impl Fn(impl Debug) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait params
|
||||
error[E0562]: `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:66:38
|
||||
|
|
||||
LL | fn in_Fn_parameter_in_generics<F: Fn(impl Debug)> (_: F) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return types
|
||||
error[E0562]: `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:70:40
|
||||
|
|
||||
LL | fn in_Fn_return_in_generics<F: Fn() -> impl Debug> (_: F) { panic!() }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in field types
|
||||
error[E0562]: `impl Trait` is not allowed in field types
|
||||
--> $DIR/where-allowed.rs:83:32
|
||||
|
|
||||
LL | struct InBraceStructField { x: impl Debug }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in field types
|
||||
error[E0562]: `impl Trait` is not allowed in field types
|
||||
--> $DIR/where-allowed.rs:87:41
|
||||
|
|
||||
LL | struct InAdtInBraceStructField { x: Vec<impl Debug> }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in field types
|
||||
error[E0562]: `impl Trait` is not allowed in field types
|
||||
--> $DIR/where-allowed.rs:91:27
|
||||
|
|
||||
LL | struct InTupleStructField(impl Debug);
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in field types
|
||||
error[E0562]: `impl Trait` is not allowed in field types
|
||||
--> $DIR/where-allowed.rs:96:25
|
||||
|
|
||||
LL | InBraceVariant { x: impl Debug },
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in field types
|
||||
error[E0562]: `impl Trait` is not allowed in field types
|
||||
--> $DIR/where-allowed.rs:98:20
|
||||
|
|
||||
LL | InTupleVariant(impl Debug),
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `extern fn` params
|
||||
error[E0562]: `impl Trait` is not allowed in `extern fn` parameters
|
||||
--> $DIR/where-allowed.rs:138:33
|
||||
|
|
||||
LL | fn in_foreign_parameters(_: impl Debug);
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `extern fn` return types
|
||||
error[E0562]: `impl Trait` is not allowed in `extern fn` return types
|
||||
--> $DIR/where-allowed.rs:141:31
|
||||
|
|
||||
LL | fn in_foreign_return() -> impl Debug;
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `fn` pointer return types
|
||||
error[E0562]: `impl Trait` is not allowed in `fn` pointer return types
|
||||
--> $DIR/where-allowed.rs:157:39
|
||||
|
|
||||
LL | type InReturnInTypeAlias<R> = fn() -> impl Debug;
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in traits
|
||||
error[E0562]: `impl Trait` is not allowed in traits
|
||||
--> $DIR/where-allowed.rs:162:16
|
||||
|
|
||||
LL | impl PartialEq<impl Debug> for () {
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in impl headers
|
||||
error[E0562]: `impl Trait` is not allowed in impl headers
|
||||
--> $DIR/where-allowed.rs:167:24
|
||||
|
|
||||
LL | impl PartialEq<()> for impl Debug {
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in impl headers
|
||||
error[E0562]: `impl Trait` is not allowed in impl headers
|
||||
--> $DIR/where-allowed.rs:172:6
|
||||
|
|
||||
LL | impl impl Debug {
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in impl headers
|
||||
error[E0562]: `impl Trait` is not allowed in impl headers
|
||||
--> $DIR/where-allowed.rs:178:24
|
||||
|
|
||||
LL | impl InInherentImplAdt<impl Debug> {
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in bounds
|
||||
error[E0562]: `impl Trait` is not allowed in bounds
|
||||
--> $DIR/where-allowed.rs:184:11
|
||||
|
|
||||
LL | where impl Debug: Debug
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in bounds
|
||||
error[E0562]: `impl Trait` is not allowed in bounds
|
||||
--> $DIR/where-allowed.rs:191:15
|
||||
|
|
||||
LL | where Vec<impl Debug>: Debug
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in bounds
|
||||
error[E0562]: `impl Trait` is not allowed in bounds
|
||||
--> $DIR/where-allowed.rs:198:24
|
||||
|
|
||||
LL | where T: PartialEq<impl Debug>
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait params
|
||||
error[E0562]: `impl Trait` is not allowed in the parameters of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:205:17
|
||||
|
|
||||
LL | where T: Fn(impl Debug)
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `Fn` trait return types
|
||||
error[E0562]: `impl Trait` is not allowed in the return type of `Fn` trait bounds
|
||||
--> $DIR/where-allowed.rs:212:22
|
||||
|
|
||||
LL | where T: Fn() -> impl Debug
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/where-allowed.rs:218:40
|
||||
|
|
||||
LL | struct InStructGenericParamDefault<T = impl Debug>(T);
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/where-allowed.rs:222:36
|
||||
|
|
||||
LL | enum InEnumGenericParamDefault<T = impl Debug> { Variant(T) }
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/where-allowed.rs:226:38
|
||||
|
|
||||
LL | trait InTraitGenericParamDefault<T = impl Debug> {}
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/where-allowed.rs:230:41
|
||||
|
|
||||
LL | type InTypeAliasGenericParamDefault<T = impl Debug> = T;
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/where-allowed.rs:234:11
|
||||
|
|
||||
LL | impl <T = impl Debug> T {}
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generic parameter defaults
|
||||
error[E0562]: `impl Trait` is not allowed in generic parameter defaults
|
||||
--> $DIR/where-allowed.rs:241:40
|
||||
|
|
||||
LL | fn in_method_generic_param_default<T = impl Debug>(_: T) {}
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/where-allowed.rs:247:29
|
||||
|
|
||||
LL | let _in_local_variable: impl Fn() = || {};
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in closure return types
|
||||
error[E0562]: `impl Trait` is not allowed in closure return types
|
||||
--> $DIR/where-allowed.rs:249:46
|
||||
|
|
||||
LL | let _in_return_in_local_variable = || -> impl Fn() { || {} };
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: defaults for type parameters are only allowed in `struct`, `enum`, `type`, or `trait` definitions
|
||||
--> $DIR/where-allowed.rs:234:7
|
||||
|
|
|
|||
|
|
@ -7,22 +7,22 @@ trait Iterable {
|
|||
}
|
||||
|
||||
struct Container<T: Iterable<Item = impl Foo>> {
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generics
|
||||
field: T
|
||||
}
|
||||
|
||||
enum Enum<T: Iterable<Item = impl Foo>> {
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generics
|
||||
A(T),
|
||||
}
|
||||
|
||||
union Union<T: Iterable<Item = impl Foo> + Copy> {
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generics
|
||||
x: T,
|
||||
}
|
||||
|
||||
type Type<T: Iterable<Item = impl Foo>> = T;
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in generics
|
||||
|
||||
fn main() {
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,26 +1,34 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generics
|
||||
error[E0562]: `impl Trait` is not allowed in generics
|
||||
--> $DIR/issue-47715.rs:9:37
|
||||
|
|
||||
LL | struct Container<T: Iterable<Item = impl Foo>> {
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generics
|
||||
error[E0562]: `impl Trait` is not allowed in generics
|
||||
--> $DIR/issue-47715.rs:14:30
|
||||
|
|
||||
LL | enum Enum<T: Iterable<Item = impl Foo>> {
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generics
|
||||
error[E0562]: `impl Trait` is not allowed in generics
|
||||
--> $DIR/issue-47715.rs:19:32
|
||||
|
|
||||
LL | union Union<T: Iterable<Item = impl Foo> + Copy> {
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in generics
|
||||
error[E0562]: `impl Trait` is not allowed in generics
|
||||
--> $DIR/issue-47715.rs:24:30
|
||||
|
|
||||
LL | type Type<T: Iterable<Item = impl Foo>> = T;
|
||||
| ^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 4 previous errors
|
||||
|
||||
|
|
|
|||
|
|
@ -1,27 +1,30 @@
|
|||
error[E0277]: can't compare `impl PartialEq + Destruct + Copy` with `impl PartialEq + Destruct + Copy`
|
||||
--> $DIR/const-impl-trait.rs:28:17
|
||||
error[E0277]: can't compare `()` with `()`
|
||||
--> $DIR/const-impl-trait.rs:35:17
|
||||
|
|
||||
LL | fn huh() -> impl ~const PartialEq + ~const Destruct + Copy {
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ no implementation for `impl PartialEq + Destruct + Copy == impl PartialEq + Destruct + Copy`
|
||||
LL | assert!(cmp(&()));
|
||||
| --- ^^^ no implementation for `() == ()`
|
||||
| |
|
||||
| required by a bound introduced by this call
|
||||
|
|
||||
= help: the trait `~const PartialEq` is not implemented for `impl PartialEq + Destruct + Copy`
|
||||
note: required by a bound in `Foo::{opaque#0}`
|
||||
--> $DIR/const-impl-trait.rs:24:22
|
||||
= help: the trait `const PartialEq` is not implemented for `()`
|
||||
= help: the trait `PartialEq` is implemented for `()`
|
||||
note: required by a bound in `cmp`
|
||||
--> $DIR/const-impl-trait.rs:12:23
|
||||
|
|
||||
LL | fn huh() -> impl ~const PartialEq + ~const Destruct + Copy;
|
||||
| ^^^^^^^^^^^^^^^^ required by this bound in `Foo::{opaque#0}`
|
||||
LL | const fn cmp(a: &impl ~const PartialEq) -> bool {
|
||||
| ^^^^^^^^^^^^^^^^ required by this bound in `cmp`
|
||||
|
||||
error[E0277]: can't drop `impl PartialEq + Destruct + Copy`
|
||||
--> $DIR/const-impl-trait.rs:28:17
|
||||
error[E0277]: can't compare `&impl ~const PartialEq` with `&impl ~const PartialEq`
|
||||
--> $DIR/const-impl-trait.rs:13:7
|
||||
|
|
||||
LL | fn huh() -> impl ~const PartialEq + ~const Destruct + Copy {
|
||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `~const Destruct` is not implemented for `impl PartialEq + Destruct + Copy`
|
||||
LL | a == a
|
||||
| ^^ no implementation for `&impl ~const PartialEq == &impl ~const PartialEq`
|
||||
|
|
||||
note: required by a bound in `Foo::{opaque#0}`
|
||||
--> $DIR/const-impl-trait.rs:24:41
|
||||
= help: the trait `~const PartialEq<&impl ~const PartialEq>` is not implemented for `&impl ~const PartialEq`
|
||||
help: consider dereferencing both sides of the expression
|
||||
|
|
||||
LL | fn huh() -> impl ~const PartialEq + ~const Destruct + Copy;
|
||||
| ^^^^^^^^^^^^^^^ required by this bound in `Foo::{opaque#0}`
|
||||
LL | *a == *a
|
||||
| + +
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
|
|
|
|||
|
|
@ -0,0 +1,29 @@
|
|||
// Regression test for issue #119700.
|
||||
// check-pass
|
||||
|
||||
#![feature(const_trait_impl, effects)]
|
||||
|
||||
#[const_trait]
|
||||
trait Main {
|
||||
fn compute<T: ~const Aux>() -> u32;
|
||||
}
|
||||
|
||||
impl const Main for () {
|
||||
fn compute<T: ~const Aux>() -> u32 {
|
||||
T::generate()
|
||||
}
|
||||
}
|
||||
|
||||
#[const_trait]
|
||||
trait Aux {
|
||||
fn generate() -> u32;
|
||||
}
|
||||
|
||||
impl const Aux for () {
|
||||
fn generate() -> u32 { 1024 }
|
||||
}
|
||||
|
||||
fn main() {
|
||||
const _: u32 = <()>::compute::<()>();
|
||||
let _ = <()>::compute::<()>();
|
||||
}
|
||||
|
|
@ -6,7 +6,7 @@ LL | Pin::new(S).x();
|
|||
| |
|
||||
| required by a bound introduced by this call
|
||||
|
|
||||
note: required by a bound in `Pin::<P>::new`
|
||||
note: required by a bound in `Pin::<Ptr>::new`
|
||||
--> $SRC_DIR/core/src/pin.rs:LL:COL
|
||||
help: consider borrowing here
|
||||
|
|
||||
|
|
|
|||
|
|
@ -52,7 +52,7 @@ LL | Pin::new(x)
|
|||
|
|
||||
= note: consider using the `pin!` macro
|
||||
consider using `Box::pin` if you need to access the pinned value outside of the current scope
|
||||
note: required by a bound in `Pin::<P>::new`
|
||||
note: required by a bound in `Pin::<Ptr>::new`
|
||||
--> $SRC_DIR/core/src/pin.rs:LL:COL
|
||||
|
||||
error[E0277]: `dyn Future<Output = i32> + Send` cannot be unpinned
|
||||
|
|
@ -65,7 +65,7 @@ LL | Pin::new(Box::new(x))
|
|||
|
|
||||
= note: consider using the `pin!` macro
|
||||
consider using `Box::pin` if you need to access the pinned value outside of the current scope
|
||||
note: required by a bound in `Pin::<P>::new`
|
||||
note: required by a bound in `Pin::<Ptr>::new`
|
||||
--> $SRC_DIR/core/src/pin.rs:LL:COL
|
||||
|
||||
error[E0308]: mismatched types
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@
|
|||
// FIXME: this is ruled out for now but should work
|
||||
|
||||
type Foo = fn() -> impl Send;
|
||||
//~^ ERROR: `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR: `impl Trait` is not allowed in `fn` pointer return types
|
||||
|
||||
fn make_foo() -> Foo {
|
||||
|| 15
|
||||
|
|
|
|||
|
|
@ -1,8 +1,10 @@
|
|||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in `fn` pointer return types
|
||||
error[E0562]: `impl Trait` is not allowed in `fn` pointer return types
|
||||
--> $DIR/type-alias-impl-trait-fn-type.rs:6:20
|
||||
|
|
||||
LL | type Foo = fn() -> impl Send;
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 1 previous error
|
||||
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
struct S;
|
||||
fn f() {
|
||||
let _: S<impl Oops> = S; //~ ERROR cannot find trait `Oops` in this scope
|
||||
//~^ ERROR `impl Trait` only allowed in function and inherent method argument and return types
|
||||
//~^ ERROR `impl Trait` is not allowed in the type of variable bindings
|
||||
}
|
||||
fn main() {}
|
||||
|
|
|
|||
|
|
@ -4,11 +4,13 @@ error[E0405]: cannot find trait `Oops` in this scope
|
|||
LL | let _: S<impl Oops> = S;
|
||||
| ^^^^ not found in this scope
|
||||
|
||||
error[E0562]: `impl Trait` only allowed in function and inherent method argument and return types, not in variable bindings
|
||||
error[E0562]: `impl Trait` is not allowed in the type of variable bindings
|
||||
--> $DIR/issue-104513-ice.rs:3:14
|
||||
|
|
||||
LL | let _: S<impl Oops> = S;
|
||||
| ^^^^^^^^^
|
||||
|
|
||||
= note: `impl Trait` is only allowed in arguments and return types of functions and methods
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
|
|
|
|||
|
|
@ -1,7 +0,0 @@
|
|||
# Everyone uses make for building Rust
|
||||
|
||||
foo: bar.rlib
|
||||
$(RUSTC) --crate-type bin --extern bar=bar.rlib
|
||||
|
||||
%.rlib: %.rs
|
||||
$(RUSTC) --crate-type lib $<
|
||||
Loading…
Add table
Add a link
Reference in a new issue