Auto merge of #114197 - matthiaskrgr:rollup-iluf7u4, r=matthiaskrgr
Rollup of 7 pull requests Successful merges: - #113773 (Don't attempt to compute layout of type referencing error) - #114107 (Prevent people from assigning me as a PR reviewer) - #114124 (tests/ui/proc-macro/*: Migrate FIXMEs to check-pass) - #114171 (Fix switch-stdout test for none unix/windows platforms) - #114172 (Fix issue_15149 test for the SGX target) - #114173 (btree/map.rs: remove "Basic usage" text) - #114174 (doc: replace wrong punctuation mark) r? `@ghost` `@rustbot` modify labels: rollup
This commit is contained in:
commit
5ed61a4378
@ -138,7 +138,10 @@ pub(super) fn report<'tcx, C, F, E>(
|
|||||||
err_inval!(Layout(LayoutError::Unknown(_))) | err_inval!(TooGeneric) => {
|
err_inval!(Layout(LayoutError::Unknown(_))) | err_inval!(TooGeneric) => {
|
||||||
ErrorHandled::TooGeneric
|
ErrorHandled::TooGeneric
|
||||||
}
|
}
|
||||||
err_inval!(AlreadyReported(error_reported)) => ErrorHandled::Reported(error_reported),
|
err_inval!(AlreadyReported(guar)) => ErrorHandled::Reported(guar),
|
||||||
|
err_inval!(Layout(LayoutError::ReferencesError(guar))) => {
|
||||||
|
ErrorHandled::Reported(guar.into())
|
||||||
|
}
|
||||||
err_inval!(Layout(layout_error @ LayoutError::SizeOverflow(_))) => {
|
err_inval!(Layout(layout_error @ LayoutError::SizeOverflow(_))) => {
|
||||||
// We must *always* hard error on these, even if the caller wants just a lint.
|
// We must *always* hard error on these, even if the caller wants just a lint.
|
||||||
// The `message` makes little sense here, this is a more serious error than the
|
// The `message` makes little sense here, this is a more serious error than the
|
||||||
|
@ -122,14 +122,9 @@ pub fn check_transmute(&self, from: Ty<'tcx>, to: Ty<'tcx>, hir_id: HirId) {
|
|||||||
} else {
|
} else {
|
||||||
err.note(format!("source type: `{}` ({})", from, skeleton_string(from, sk_from)))
|
err.note(format!("source type: `{}` ({})", from, skeleton_string(from, sk_from)))
|
||||||
.note(format!("target type: `{}` ({})", to, skeleton_string(to, sk_to)));
|
.note(format!("target type: `{}` ({})", to, skeleton_string(to, sk_to)));
|
||||||
let mut should_delay_as_bug = false;
|
if let Err(LayoutError::ReferencesError(_)) = sk_from {
|
||||||
if let Err(LayoutError::Unknown(bad_from)) = sk_from && bad_from.references_error() {
|
err.delay_as_bug();
|
||||||
should_delay_as_bug = true;
|
} else if let Err(LayoutError::ReferencesError(_)) = sk_to {
|
||||||
}
|
|
||||||
if let Err(LayoutError::Unknown(bad_to)) = sk_to && bad_to.references_error() {
|
|
||||||
should_delay_as_bug = true;
|
|
||||||
}
|
|
||||||
if should_delay_as_bug {
|
|
||||||
err.delay_as_bug();
|
err.delay_as_bug();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -52,6 +52,9 @@ middle_drop_check_overflow =
|
|||||||
overflow while adding drop-check rules for {$ty}
|
overflow while adding drop-check rules for {$ty}
|
||||||
.note = overflowed on {$overflow_ty}
|
.note = overflowed on {$overflow_ty}
|
||||||
|
|
||||||
|
middle_layout_references_error =
|
||||||
|
the type has an unknown layout
|
||||||
|
|
||||||
middle_limit_invalid =
|
middle_limit_invalid =
|
||||||
`limit` must be a non-negative integer
|
`limit` must be a non-negative integer
|
||||||
.label = {$error_str}
|
.label = {$error_str}
|
||||||
|
@ -132,6 +132,9 @@ pub enum LayoutError<'tcx> {
|
|||||||
|
|
||||||
#[diag(middle_cycle)]
|
#[diag(middle_cycle)]
|
||||||
Cycle,
|
Cycle,
|
||||||
|
|
||||||
|
#[diag(middle_layout_references_error)]
|
||||||
|
ReferencesError,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Diagnostic)]
|
#[derive(Diagnostic)]
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
use rustc_index::IndexVec;
|
use rustc_index::IndexVec;
|
||||||
use rustc_session::config::OptLevel;
|
use rustc_session::config::OptLevel;
|
||||||
use rustc_span::symbol::{sym, Symbol};
|
use rustc_span::symbol::{sym, Symbol};
|
||||||
use rustc_span::{Span, DUMMY_SP};
|
use rustc_span::{ErrorGuaranteed, Span, DUMMY_SP};
|
||||||
use rustc_target::abi::call::FnAbi;
|
use rustc_target::abi::call::FnAbi;
|
||||||
use rustc_target::abi::*;
|
use rustc_target::abi::*;
|
||||||
use rustc_target::spec::{abi::Abi as SpecAbi, HasTargetSpec, PanicStrategy, Target};
|
use rustc_target::spec::{abi::Abi as SpecAbi, HasTargetSpec, PanicStrategy, Target};
|
||||||
@ -212,6 +212,7 @@ pub enum LayoutError<'tcx> {
|
|||||||
Unknown(Ty<'tcx>),
|
Unknown(Ty<'tcx>),
|
||||||
SizeOverflow(Ty<'tcx>),
|
SizeOverflow(Ty<'tcx>),
|
||||||
NormalizationFailure(Ty<'tcx>, NormalizationError<'tcx>),
|
NormalizationFailure(Ty<'tcx>, NormalizationError<'tcx>),
|
||||||
|
ReferencesError(ErrorGuaranteed),
|
||||||
Cycle,
|
Cycle,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -224,6 +225,7 @@ pub fn diagnostic_message(&self) -> DiagnosticMessage {
|
|||||||
SizeOverflow(_) => middle_values_too_big,
|
SizeOverflow(_) => middle_values_too_big,
|
||||||
NormalizationFailure(_, _) => middle_cannot_be_normalized,
|
NormalizationFailure(_, _) => middle_cannot_be_normalized,
|
||||||
Cycle => middle_cycle,
|
Cycle => middle_cycle,
|
||||||
|
ReferencesError(_) => middle_layout_references_error,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -237,6 +239,7 @@ pub fn into_diagnostic(self) -> crate::error::LayoutError<'tcx> {
|
|||||||
E::NormalizationFailure { ty, failure_ty: e.get_type_for_failure() }
|
E::NormalizationFailure { ty, failure_ty: e.get_type_for_failure() }
|
||||||
}
|
}
|
||||||
Cycle => E::Cycle,
|
Cycle => E::Cycle,
|
||||||
|
ReferencesError(_) => E::ReferencesError,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -257,6 +260,7 @@ fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|||||||
e.get_type_for_failure()
|
e.get_type_for_failure()
|
||||||
),
|
),
|
||||||
LayoutError::Cycle => write!(f, "a cycle occurred during layout computation"),
|
LayoutError::Cycle => write!(f, "a cycle occurred during layout computation"),
|
||||||
|
LayoutError::ReferencesError(_) => write!(f, "the type has an unknown layout"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -323,7 +327,8 @@ pub fn compute(
|
|||||||
Err(
|
Err(
|
||||||
e @ LayoutError::Cycle
|
e @ LayoutError::Cycle
|
||||||
| e @ LayoutError::SizeOverflow(_)
|
| e @ LayoutError::SizeOverflow(_)
|
||||||
| e @ LayoutError::NormalizationFailure(..),
|
| e @ LayoutError::NormalizationFailure(..)
|
||||||
|
| e @ LayoutError::ReferencesError(_),
|
||||||
) => return Err(e),
|
) => return Err(e),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -195,7 +195,7 @@ pub(crate) enum Err {
|
|||||||
impl<'tcx> From<&LayoutError<'tcx>> for Err {
|
impl<'tcx> From<&LayoutError<'tcx>> for Err {
|
||||||
fn from(err: &LayoutError<'tcx>) -> Self {
|
fn from(err: &LayoutError<'tcx>) -> Self {
|
||||||
match err {
|
match err {
|
||||||
LayoutError::Unknown(..) => Self::UnknownLayout,
|
LayoutError::Unknown(..) | LayoutError::ReferencesError(..) => Self::UnknownLayout,
|
||||||
err => unimplemented!("{:?}", err),
|
err => unimplemented!("{:?}", err),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -96,6 +96,13 @@ fn layout_of_uncached<'tcx>(
|
|||||||
cx: &LayoutCx<'tcx, TyCtxt<'tcx>>,
|
cx: &LayoutCx<'tcx, TyCtxt<'tcx>>,
|
||||||
ty: Ty<'tcx>,
|
ty: Ty<'tcx>,
|
||||||
) -> Result<Layout<'tcx>, &'tcx LayoutError<'tcx>> {
|
) -> Result<Layout<'tcx>, &'tcx LayoutError<'tcx>> {
|
||||||
|
// Types that reference `ty::Error` pessimistically don't have a meaningful layout.
|
||||||
|
// The only side-effect of this is possibly worse diagnostics in case the layout
|
||||||
|
// was actually computable (like if the `ty::Error` showed up only in a `PhantomData`).
|
||||||
|
if let Err(guar) = ty.error_reported() {
|
||||||
|
return Err(error(cx, LayoutError::ReferencesError(guar)));
|
||||||
|
}
|
||||||
|
|
||||||
let tcx = cx.tcx;
|
let tcx = cx.tcx;
|
||||||
let param_env = cx.param_env;
|
let param_env = cx.param_env;
|
||||||
let dl = cx.data_layout();
|
let dl = cx.data_layout();
|
||||||
@ -564,11 +571,15 @@ fn layout_of_uncached<'tcx>(
|
|||||||
return Err(error(cx, LayoutError::Unknown(ty)));
|
return Err(error(cx, LayoutError::Unknown(ty)));
|
||||||
}
|
}
|
||||||
|
|
||||||
ty::Bound(..) | ty::GeneratorWitness(..) | ty::GeneratorWitnessMIR(..) | ty::Infer(_) => {
|
ty::Bound(..)
|
||||||
|
| ty::GeneratorWitness(..)
|
||||||
|
| ty::GeneratorWitnessMIR(..)
|
||||||
|
| ty::Infer(_)
|
||||||
|
| ty::Error(_) => {
|
||||||
bug!("Layout::compute: unexpected type `{}`", ty)
|
bug!("Layout::compute: unexpected type `{}`", ty)
|
||||||
}
|
}
|
||||||
|
|
||||||
ty::Placeholder(..) | ty::Param(_) | ty::Error(_) => {
|
ty::Placeholder(..) | ty::Param(_) => {
|
||||||
return Err(error(cx, LayoutError::Unknown(ty)));
|
return Err(error(cx, LayoutError::Unknown(ty)));
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -613,8 +613,6 @@ impl<K, V> BTreeMap<K, V> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -636,8 +634,6 @@ impl<K, V, A: Allocator + Clone> BTreeMap<K, V, A> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -661,8 +657,6 @@ pub fn clear(&mut self) {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// # #![feature(allocator_api)]
|
/// # #![feature(allocator_api)]
|
||||||
/// # #![feature(btreemap_alloc)]
|
/// # #![feature(btreemap_alloc)]
|
||||||
@ -688,8 +682,6 @@ impl<K, V, A: Allocator + Clone> BTreeMap<K, V, A> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -744,8 +736,6 @@ pub fn get_key_value<Q: ?Sized>(&self, k: &Q) -> Option<(&K, &V)>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -830,8 +820,6 @@ pub fn pop_first(&mut self) -> Option<(K, V)>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -917,8 +905,6 @@ pub fn pop_last(&mut self) -> Option<(K, V)>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -943,8 +929,6 @@ pub fn contains_key<Q: ?Sized>(&self, key: &Q) -> bool
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -982,8 +966,6 @@ pub fn get_mut<Q: ?Sized>(&mut self, key: &Q) -> Option<&mut V>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -1017,8 +999,6 @@ pub fn insert(&mut self, key: K, value: V) -> Option<V>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(map_try_insert)]
|
/// #![feature(map_try_insert)]
|
||||||
///
|
///
|
||||||
@ -1051,8 +1031,6 @@ pub fn try_insert(&mut self, key: K, value: V) -> Result<&mut V, OccupiedError<'
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -1078,8 +1056,6 @@ pub fn remove<Q: ?Sized>(&mut self, key: &Q) -> Option<V>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -1208,8 +1184,6 @@ pub fn append(&mut self, other: &mut Self)
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
/// use std::ops::Bound::Included;
|
/// use std::ops::Bound::Included;
|
||||||
@ -1251,8 +1225,6 @@ pub fn range<T: ?Sized, R>(&self, range: R) -> Range<'_, K, V>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -1283,8 +1255,6 @@ pub fn range_mut<T: ?Sized, R>(&mut self, range: R) -> RangeMut<'_, K, V>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -1336,8 +1306,6 @@ pub fn entry(&mut self, key: K) -> Entry<'_, K, V, A>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2388,8 +2356,6 @@ impl<K, V, A: Allocator + Clone> BTreeMap<K, V, A> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2420,8 +2386,6 @@ pub fn iter(&self) -> Iter<'_, K, V> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2453,8 +2417,6 @@ pub fn iter_mut(&mut self) -> IterMut<'_, K, V> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2474,8 +2436,6 @@ pub fn keys(&self) -> Keys<'_, K, V> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2495,8 +2455,6 @@ pub fn values(&self) -> Values<'_, K, V> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2521,8 +2479,6 @@ pub fn values_mut(&mut self) -> ValuesMut<'_, K, V> {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2546,8 +2502,6 @@ pub const fn len(&self) -> usize {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// use std::collections::BTreeMap;
|
/// use std::collections::BTreeMap;
|
||||||
///
|
///
|
||||||
@ -2578,8 +2532,6 @@ pub const fn is_empty(&self) -> bool {
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(btree_cursors)]
|
/// #![feature(btree_cursors)]
|
||||||
///
|
///
|
||||||
@ -2619,8 +2571,6 @@ pub fn lower_bound<Q>(&self, bound: Bound<&Q>) -> Cursor<'_, K, V>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(btree_cursors)]
|
/// #![feature(btree_cursors)]
|
||||||
///
|
///
|
||||||
@ -2673,8 +2623,6 @@ pub fn lower_bound_mut<Q>(&mut self, bound: Bound<&Q>) -> CursorMut<'_, K, V, A>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(btree_cursors)]
|
/// #![feature(btree_cursors)]
|
||||||
///
|
///
|
||||||
@ -2714,8 +2662,6 @@ pub fn upper_bound<Q>(&self, bound: Bound<&Q>) -> Cursor<'_, K, V>
|
|||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// Basic usage:
|
|
||||||
///
|
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(btree_cursors)]
|
/// #![feature(btree_cursors)]
|
||||||
///
|
///
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
/// Types express that they can be borrowed as some type `T` by implementing
|
/// Types express that they can be borrowed as some type `T` by implementing
|
||||||
/// `Borrow<T>`, providing a reference to a `T` in the trait’s
|
/// `Borrow<T>`, providing a reference to a `T` in the trait’s
|
||||||
/// [`borrow`] method. A type is free to borrow as several different types.
|
/// [`borrow`] method. A type is free to borrow as several different types.
|
||||||
/// If it wishes to mutably borrow as the type – allowing the underlying data
|
/// If it wishes to mutably borrow as the type, allowing the underlying data
|
||||||
/// to be modified, it can additionally implement [`BorrowMut<T>`].
|
/// to be modified, it can additionally implement [`BorrowMut<T>`].
|
||||||
///
|
///
|
||||||
/// Further, when providing implementations for additional traits, it needs
|
/// Further, when providing implementations for additional traits, it needs
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
#![cfg(not(target_env="sgx"))]
|
||||||
|
|
||||||
use std::env;
|
use std::env;
|
||||||
use std::fs;
|
use std::fs;
|
||||||
use std::process;
|
use std::process;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#[cfg(any(target_family = "unix", target_family = "windows"))]
|
#![cfg(any(target_family = "unix", target_family = "windows"))]
|
||||||
|
|
||||||
use std::fs::File;
|
use std::fs::File;
|
||||||
use std::io::{Read, Write};
|
use std::io::{Read, Write};
|
||||||
|
@ -44,6 +44,11 @@
|
|||||||
<strong>Note:</strong> Encountered an error during type layout; {#+ #}
|
<strong>Note:</strong> Encountered an error during type layout; {#+ #}
|
||||||
the type was too big. {# #}
|
the type was too big. {# #}
|
||||||
</p> {# #}
|
</p> {# #}
|
||||||
|
{% when Err(LayoutError::ReferencesError(_)) %}
|
||||||
|
<p> {# #}
|
||||||
|
<strong>Note:</strong> Encountered an error during type layout; {#+ #}
|
||||||
|
the type references errors. {# #}
|
||||||
|
</p> {# #}
|
||||||
{% when Err(LayoutError::NormalizationFailure(_, _)) %}
|
{% when Err(LayoutError::NormalizationFailure(_, _)) %}
|
||||||
<p> {# #}
|
<p> {# #}
|
||||||
<strong>Note:</strong> Encountered an error during type layout; {#+ #}
|
<strong>Note:</strong> Encountered an error during type layout; {#+ #}
|
||||||
|
8
tests/ui/layout/malformed-unsized-type-in-union.rs
Normal file
8
tests/ui/layout/malformed-unsized-type-in-union.rs
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
// issue: 113760
|
||||||
|
|
||||||
|
union W { s: dyn Iterator<Item = Missing> }
|
||||||
|
//~^ ERROR cannot find type `Missing` in this scope
|
||||||
|
|
||||||
|
static ONCE: W = todo!();
|
||||||
|
|
||||||
|
fn main() {}
|
9
tests/ui/layout/malformed-unsized-type-in-union.stderr
Normal file
9
tests/ui/layout/malformed-unsized-type-in-union.stderr
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
error[E0412]: cannot find type `Missing` in this scope
|
||||||
|
--> $DIR/malformed-unsized-type-in-union.rs:3:34
|
||||||
|
|
|
||||||
|
LL | union W { s: dyn Iterator<Item = Missing> }
|
||||||
|
| ^^^^^^^ not found in this scope
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0412`.
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// aux-build:test-macros.rs
|
// aux-build:test-macros.rs
|
||||||
// aux-build:derive-helper-shadowed-2.rs
|
// aux-build:derive-helper-shadowed-2.rs
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// aux-build:test-macros.rs
|
// aux-build:test-macros.rs
|
||||||
|
|
||||||
extern crate test_macros;
|
extern crate test_macros;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// edition:2018
|
// edition:2018
|
||||||
// aux-build:edition-imports-2015.rs
|
// aux-build:edition-imports-2015.rs
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// edition:2018
|
// edition:2018
|
||||||
|
|
||||||
extern crate proc_macro;
|
extern crate proc_macro;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// aux-build:test-macros.rs
|
// aux-build:test-macros.rs
|
||||||
|
|
||||||
#[macro_use(Empty)]
|
#[macro_use(Empty)]
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// aux-build:test-macros.rs
|
// aux-build:test-macros.rs
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// aux-build:test-macros.rs
|
// aux-build:test-macros.rs
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// build-pass (FIXME(62277): could be check-pass?)
|
// check-pass
|
||||||
// aux-build:test-macros.rs
|
// aux-build:test-macros.rs
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
|
@ -490,6 +490,7 @@ cc = ["@nnethercote"]
|
|||||||
[assign]
|
[assign]
|
||||||
warn_non_default_branch = true
|
warn_non_default_branch = true
|
||||||
contributing_url = "https://rustc-dev-guide.rust-lang.org/getting-started.html"
|
contributing_url = "https://rustc-dev-guide.rust-lang.org/getting-started.html"
|
||||||
|
users_on_vacation = ["jyn514"]
|
||||||
|
|
||||||
[assign.adhoc_groups]
|
[assign.adhoc_groups]
|
||||||
compiler-team = [
|
compiler-team = [
|
||||||
|
Loading…
Reference in New Issue
Block a user