Auto merge of #104428 - matthiaskrgr:rollup-jo3078i, r=matthiaskrgr
Rollup of 13 pull requests Successful merges: - #103842 (Adding Fuchsia compiler testing script, docs) - #104354 (Remove leading newlines from `NonZero*` doc examples) - #104372 (Update compiler-builtins) - #104380 (rustdoc: remove unused CSS `code { opacity: 1 }`) - #104381 (Remove dead NoneError diagnostic handling) - #104383 (Remove unused symbols and diagnostic items) - #104391 (Deriving cleanups) - #104403 (Specify language of code comment to generate document) - #104404 (Fix missing minification for static files) - #104413 ([llvm-wrapper] adapt for LLVM API change) - #104415 (rustdoc: fix corner case in search keyboard commands) - #104422 (Fix suggest associated call syntax) - #104426 (Add test for #102154) Failed merges: r? `@ghost` `@rustbot` modify labels: rollup
This commit is contained in:
commit
ca92d90b59
38 changed files with 1444 additions and 349 deletions
|
@ -392,15 +392,7 @@ pub struct Generics {
|
||||||
impl Default for Generics {
|
impl Default for Generics {
|
||||||
/// Creates an instance of `Generics`.
|
/// Creates an instance of `Generics`.
|
||||||
fn default() -> Generics {
|
fn default() -> Generics {
|
||||||
Generics {
|
Generics { params: Vec::new(), where_clause: Default::default(), span: DUMMY_SP }
|
||||||
params: Vec::new(),
|
|
||||||
where_clause: WhereClause {
|
|
||||||
has_where_token: false,
|
|
||||||
predicates: Vec::new(),
|
|
||||||
span: DUMMY_SP,
|
|
||||||
},
|
|
||||||
span: DUMMY_SP,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -415,6 +407,12 @@ pub struct WhereClause {
|
||||||
pub span: Span,
|
pub span: Span,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Default for WhereClause {
|
||||||
|
fn default() -> WhereClause {
|
||||||
|
WhereClause { has_where_token: false, predicates: Vec::new(), span: DUMMY_SP }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// A single predicate in a where-clause.
|
/// A single predicate in a where-clause.
|
||||||
#[derive(Clone, Encodable, Decodable, Debug)]
|
#[derive(Clone, Encodable, Decodable, Debug)]
|
||||||
pub enum WherePredicate {
|
pub enum WherePredicate {
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
use crate::deriving::generic::ty::*;
|
|
||||||
use crate::deriving::generic::*;
|
use crate::deriving::generic::*;
|
||||||
use crate::deriving::path_std;
|
use crate::deriving::path_std;
|
||||||
|
|
||||||
|
@ -19,7 +18,6 @@ pub fn expand_deriving_copy(
|
||||||
path: path_std!(marker::Copy),
|
path: path_std!(marker::Copy),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: true,
|
supports_unions: true,
|
||||||
methods: Vec::new(),
|
methods: Vec::new(),
|
||||||
associated_types: Vec::new(),
|
associated_types: Vec::new(),
|
||||||
|
|
|
@ -75,7 +75,6 @@ pub fn expand_deriving_clone(
|
||||||
path: path_std!(clone::Clone),
|
path: path_std!(clone::Clone),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: bounds,
|
additional_bounds: bounds,
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: true,
|
supports_unions: true,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: sym::clone,
|
name: sym::clone,
|
||||||
|
|
|
@ -28,7 +28,6 @@ pub fn expand_deriving_eq(
|
||||||
path: path_std!(cmp::Eq),
|
path: path_std!(cmp::Eq),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: true,
|
supports_unions: true,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: sym::assert_receiver_is_total_eq,
|
name: sym::assert_receiver_is_total_eq,
|
||||||
|
|
|
@ -22,7 +22,6 @@ pub fn expand_deriving_ord(
|
||||||
path: path_std!(cmp::Ord),
|
path: path_std!(cmp::Ord),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: sym::cmp,
|
name: sym::cmp,
|
||||||
|
|
|
@ -86,7 +86,6 @@ pub fn expand_deriving_partial_eq(
|
||||||
path: path_std!(cmp::PartialEq),
|
path: path_std!(cmp::PartialEq),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods,
|
methods,
|
||||||
associated_types: Vec::new(),
|
associated_types: Vec::new(),
|
||||||
|
|
|
@ -40,7 +40,6 @@ pub fn expand_deriving_partial_ord(
|
||||||
path: path_std!(cmp::PartialOrd),
|
path: path_std!(cmp::PartialOrd),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: vec![],
|
additional_bounds: vec![],
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods: vec![partial_cmp_def],
|
methods: vec![partial_cmp_def],
|
||||||
associated_types: Vec::new(),
|
associated_types: Vec::new(),
|
||||||
|
|
|
@ -23,7 +23,6 @@ pub fn expand_deriving_debug(
|
||||||
path: path_std!(fmt::Debug),
|
path: path_std!(fmt::Debug),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: sym::fmt,
|
name: sym::fmt,
|
||||||
|
|
|
@ -26,7 +26,6 @@ pub fn expand_deriving_rustc_decodable(
|
||||||
path: Path::new_(vec![krate, sym::Decodable], vec![], PathKind::Global),
|
path: Path::new_(vec![krate, sym::Decodable], vec![], PathKind::Global),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: sym::decode,
|
name: sym::decode,
|
||||||
|
|
|
@ -27,7 +27,6 @@ pub fn expand_deriving_default(
|
||||||
path: Path::new(vec![kw::Default, sym::Default]),
|
path: Path::new(vec![kw::Default, sym::Default]),
|
||||||
skip_path_as_bound: has_a_default_variant(item),
|
skip_path_as_bound: has_a_default_variant(item),
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: kw::Default,
|
name: kw::Default,
|
||||||
|
|
|
@ -110,7 +110,6 @@ pub fn expand_deriving_rustc_encodable(
|
||||||
path: Path::new_(vec![krate, sym::Encodable], vec![], PathKind::Global),
|
path: Path::new_(vec![krate, sym::Encodable], vec![], PathKind::Global),
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: sym::encode,
|
name: sym::encode,
|
||||||
|
|
|
@ -195,9 +195,6 @@ pub struct TraitDef<'a> {
|
||||||
/// other than the current trait
|
/// other than the current trait
|
||||||
pub additional_bounds: Vec<Ty>,
|
pub additional_bounds: Vec<Ty>,
|
||||||
|
|
||||||
/// Any extra lifetimes and/or bounds, e.g., `D: serialize::Decoder`
|
|
||||||
pub generics: Bounds,
|
|
||||||
|
|
||||||
/// Can this trait be derived for unions?
|
/// Can this trait be derived for unions?
|
||||||
pub supports_unions: bool,
|
pub supports_unions: bool,
|
||||||
|
|
||||||
|
@ -583,19 +580,21 @@ impl<'a> TraitDef<'a> {
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
||||||
let Generics { mut params, mut where_clause, .. } =
|
let mut where_clause = ast::WhereClause::default();
|
||||||
self.generics.to_generics(cx, self.span, type_ident, generics);
|
|
||||||
where_clause.span = generics.where_clause.span;
|
where_clause.span = generics.where_clause.span;
|
||||||
let ctxt = self.span.ctxt();
|
let ctxt = self.span.ctxt();
|
||||||
let span = generics.span.with_ctxt(ctxt);
|
let span = generics.span.with_ctxt(ctxt);
|
||||||
|
|
||||||
// Create the generic parameters
|
// Create the generic parameters
|
||||||
params.extend(generics.params.iter().map(|param| match ¶m.kind {
|
let params: Vec<_> = generics
|
||||||
GenericParamKind::Lifetime { .. } => param.clone(),
|
.params
|
||||||
GenericParamKind::Type { .. } => {
|
.iter()
|
||||||
// I don't think this can be moved out of the loop, since
|
.map(|param| match ¶m.kind {
|
||||||
// a GenericBound requires an ast id
|
GenericParamKind::Lifetime { .. } => param.clone(),
|
||||||
let bounds: Vec<_> =
|
GenericParamKind::Type { .. } => {
|
||||||
|
// I don't think this can be moved out of the loop, since
|
||||||
|
// a GenericBound requires an ast id
|
||||||
|
let bounds: Vec<_> =
|
||||||
// extra restrictions on the generics parameters to the
|
// extra restrictions on the generics parameters to the
|
||||||
// type being derived upon
|
// type being derived upon
|
||||||
self.additional_bounds.iter().map(|p| {
|
self.additional_bounds.iter().map(|p| {
|
||||||
|
@ -608,21 +607,22 @@ impl<'a> TraitDef<'a> {
|
||||||
param.bounds.iter().cloned()
|
param.bounds.iter().cloned()
|
||||||
).collect();
|
).collect();
|
||||||
|
|
||||||
cx.typaram(param.ident.span.with_ctxt(ctxt), param.ident, bounds, None)
|
cx.typaram(param.ident.span.with_ctxt(ctxt), param.ident, bounds, None)
|
||||||
}
|
}
|
||||||
GenericParamKind::Const { ty, kw_span, .. } => {
|
GenericParamKind::Const { ty, kw_span, .. } => {
|
||||||
let const_nodefault_kind = GenericParamKind::Const {
|
let const_nodefault_kind = GenericParamKind::Const {
|
||||||
ty: ty.clone(),
|
ty: ty.clone(),
|
||||||
kw_span: kw_span.with_ctxt(ctxt),
|
kw_span: kw_span.with_ctxt(ctxt),
|
||||||
|
|
||||||
// We can't have default values inside impl block
|
// We can't have default values inside impl block
|
||||||
default: None,
|
default: None,
|
||||||
};
|
};
|
||||||
let mut param_clone = param.clone();
|
let mut param_clone = param.clone();
|
||||||
param_clone.kind = const_nodefault_kind;
|
param_clone.kind = const_nodefault_kind;
|
||||||
param_clone
|
param_clone
|
||||||
}
|
}
|
||||||
}));
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
// and similarly for where clauses
|
// and similarly for where clauses
|
||||||
where_clause.predicates.extend(generics.where_clause.predicates.iter().map(|clause| {
|
where_clause.predicates.extend(generics.where_clause.predicates.iter().map(|clause| {
|
||||||
|
@ -1062,18 +1062,15 @@ impl<'a> MethodDef<'a> {
|
||||||
trait_.create_struct_field_access_fields(cx, selflike_args, struct_def, true);
|
trait_.create_struct_field_access_fields(cx, selflike_args, struct_def, true);
|
||||||
mk_body(cx, selflike_fields)
|
mk_body(cx, selflike_fields)
|
||||||
} else {
|
} else {
|
||||||
// Neither packed nor copy. Need to use ref patterns.
|
// Packed and not copy. Need to use ref patterns.
|
||||||
let prefixes: Vec<_> =
|
let prefixes: Vec<_> =
|
||||||
(0..selflike_args.len()).map(|i| format!("__self_{}", i)).collect();
|
(0..selflike_args.len()).map(|i| format!("__self_{}", i)).collect();
|
||||||
let addr_of = always_copy;
|
let selflike_fields = trait_.create_struct_pattern_fields(cx, struct_def, &prefixes);
|
||||||
let selflike_fields =
|
|
||||||
trait_.create_struct_pattern_fields(cx, struct_def, &prefixes, addr_of);
|
|
||||||
let mut body = mk_body(cx, selflike_fields);
|
let mut body = mk_body(cx, selflike_fields);
|
||||||
|
|
||||||
let struct_path = cx.path(span, vec![Ident::new(kw::SelfUpper, type_ident.span)]);
|
let struct_path = cx.path(span, vec![Ident::new(kw::SelfUpper, type_ident.span)]);
|
||||||
let by_ref = ByRef::from(is_packed && !always_copy);
|
|
||||||
let patterns =
|
let patterns =
|
||||||
trait_.create_struct_patterns(cx, struct_path, struct_def, &prefixes, by_ref);
|
trait_.create_struct_patterns(cx, struct_path, struct_def, &prefixes, ByRef::Yes);
|
||||||
|
|
||||||
// Do the let-destructuring.
|
// Do the let-destructuring.
|
||||||
let mut stmts: Vec<_> = iter::zip(selflike_args, patterns)
|
let mut stmts: Vec<_> = iter::zip(selflike_args, patterns)
|
||||||
|
@ -1254,9 +1251,7 @@ impl<'a> MethodDef<'a> {
|
||||||
// A single arm has form (&VariantK, &VariantK, ...) => BodyK
|
// A single arm has form (&VariantK, &VariantK, ...) => BodyK
|
||||||
// (see "Final wrinkle" note below for why.)
|
// (see "Final wrinkle" note below for why.)
|
||||||
|
|
||||||
let addr_of = false; // because enums can't be repr(packed)
|
let fields = trait_.create_struct_pattern_fields(cx, &variant.data, &prefixes);
|
||||||
let fields =
|
|
||||||
trait_.create_struct_pattern_fields(cx, &variant.data, &prefixes, addr_of);
|
|
||||||
|
|
||||||
let sp = variant.span.with_ctxt(trait_.span.ctxt());
|
let sp = variant.span.with_ctxt(trait_.span.ctxt());
|
||||||
let variant_path = cx.path(sp, vec![type_ident, variant.ident]);
|
let variant_path = cx.path(sp, vec![type_ident, variant.ident]);
|
||||||
|
@ -1519,15 +1514,13 @@ impl<'a> TraitDef<'a> {
|
||||||
cx: &mut ExtCtxt<'_>,
|
cx: &mut ExtCtxt<'_>,
|
||||||
struct_def: &'a VariantData,
|
struct_def: &'a VariantData,
|
||||||
prefixes: &[String],
|
prefixes: &[String],
|
||||||
addr_of: bool,
|
|
||||||
) -> Vec<FieldInfo> {
|
) -> Vec<FieldInfo> {
|
||||||
self.create_fields(struct_def, |i, _struct_field, sp| {
|
self.create_fields(struct_def, |i, _struct_field, sp| {
|
||||||
prefixes
|
prefixes
|
||||||
.iter()
|
.iter()
|
||||||
.map(|prefix| {
|
.map(|prefix| {
|
||||||
let ident = self.mk_pattern_ident(prefix, i);
|
let ident = self.mk_pattern_ident(prefix, i);
|
||||||
let expr = cx.expr_path(cx.path_ident(sp, ident));
|
cx.expr_path(cx.path_ident(sp, ident))
|
||||||
if addr_of { cx.expr_addr_of(sp, expr) } else { expr }
|
|
||||||
})
|
})
|
||||||
.collect()
|
.collect()
|
||||||
})
|
})
|
||||||
|
|
|
@ -25,7 +25,6 @@ pub fn expand_deriving_hash(
|
||||||
path,
|
path,
|
||||||
skip_path_as_bound: false,
|
skip_path_as_bound: false,
|
||||||
additional_bounds: Vec::new(),
|
additional_bounds: Vec::new(),
|
||||||
generics: Bounds::empty(),
|
|
||||||
supports_unions: false,
|
supports_unions: false,
|
||||||
methods: vec![MethodDef {
|
methods: vec![MethodDef {
|
||||||
name: sym::hash,
|
name: sym::hash,
|
||||||
|
|
|
@ -20,11 +20,10 @@ use rustc_infer::infer::{
|
||||||
};
|
};
|
||||||
use rustc_middle::infer::unify_key::{ConstVariableOrigin, ConstVariableOriginKind};
|
use rustc_middle::infer::unify_key::{ConstVariableOrigin, ConstVariableOriginKind};
|
||||||
use rustc_middle::traits::util::supertraits;
|
use rustc_middle::traits::util::supertraits;
|
||||||
|
use rustc_middle::ty::fast_reject::DeepRejectCtxt;
|
||||||
use rustc_middle::ty::fast_reject::{simplify_type, TreatParams};
|
use rustc_middle::ty::fast_reject::{simplify_type, TreatParams};
|
||||||
use rustc_middle::ty::print::with_crate_prefix;
|
use rustc_middle::ty::print::with_crate_prefix;
|
||||||
use rustc_middle::ty::{
|
use rustc_middle::ty::{self, DefIdTree, GenericArgKind, ToPredicate, Ty, TyCtxt, TypeVisitable};
|
||||||
self, DefIdTree, GenericArg, GenericArgKind, ToPredicate, Ty, TyCtxt, TypeVisitable,
|
|
||||||
};
|
|
||||||
use rustc_middle::ty::{IsSuggestable, ToPolyTraitRef};
|
use rustc_middle::ty::{IsSuggestable, ToPolyTraitRef};
|
||||||
use rustc_span::symbol::{kw, sym, Ident};
|
use rustc_span::symbol::{kw, sym, Ident};
|
||||||
use rustc_span::Symbol;
|
use rustc_span::Symbol;
|
||||||
|
@ -263,15 +262,15 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
}) => {
|
}) => {
|
||||||
let tcx = self.tcx;
|
let tcx = self.tcx;
|
||||||
|
|
||||||
let actual = self.resolve_vars_if_possible(rcvr_ty);
|
let rcvr_ty = self.resolve_vars_if_possible(rcvr_ty);
|
||||||
let ty_str = self.ty_to_string(actual);
|
let ty_str = self.ty_to_string(rcvr_ty);
|
||||||
let is_method = mode == Mode::MethodCall;
|
let is_method = mode == Mode::MethodCall;
|
||||||
let item_kind = if is_method {
|
let item_kind = if is_method {
|
||||||
"method"
|
"method"
|
||||||
} else if actual.is_enum() {
|
} else if rcvr_ty.is_enum() {
|
||||||
"variant or associated item"
|
"variant or associated item"
|
||||||
} else {
|
} else {
|
||||||
match (item_name.as_str().chars().next(), actual.is_fresh_ty()) {
|
match (item_name.as_str().chars().next(), rcvr_ty.is_fresh_ty()) {
|
||||||
(Some(name), false) if name.is_lowercase() => "function or associated item",
|
(Some(name), false) if name.is_lowercase() => "function or associated item",
|
||||||
(Some(_), false) => "associated item",
|
(Some(_), false) => "associated item",
|
||||||
(Some(_), true) | (None, false) => "variant or associated item",
|
(Some(_), true) | (None, false) => "variant or associated item",
|
||||||
|
@ -280,9 +279,9 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
};
|
};
|
||||||
|
|
||||||
if self.suggest_wrapping_range_with_parens(
|
if self.suggest_wrapping_range_with_parens(
|
||||||
tcx, actual, source, span, item_name, &ty_str,
|
tcx, rcvr_ty, source, span, item_name, &ty_str,
|
||||||
) || self.suggest_constraining_numerical_ty(
|
) || self.suggest_constraining_numerical_ty(
|
||||||
tcx, actual, source, span, item_kind, item_name, &ty_str,
|
tcx, rcvr_ty, source, span, item_kind, item_name, &ty_str,
|
||||||
) {
|
) {
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
|
@ -290,9 +289,9 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
|
|
||||||
// Don't show generic arguments when the method can't be found in any implementation (#81576).
|
// Don't show generic arguments when the method can't be found in any implementation (#81576).
|
||||||
let mut ty_str_reported = ty_str.clone();
|
let mut ty_str_reported = ty_str.clone();
|
||||||
if let ty::Adt(_, generics) = actual.kind() {
|
if let ty::Adt(_, generics) = rcvr_ty.kind() {
|
||||||
if generics.len() > 0 {
|
if generics.len() > 0 {
|
||||||
let mut autoderef = self.autoderef(span, actual);
|
let mut autoderef = self.autoderef(span, rcvr_ty);
|
||||||
let candidate_found = autoderef.any(|(ty, _)| {
|
let candidate_found = autoderef.any(|(ty, _)| {
|
||||||
if let ty::Adt(adt_def, _) = ty.kind() {
|
if let ty::Adt(adt_def, _) = ty.kind() {
|
||||||
self.tcx
|
self.tcx
|
||||||
|
@ -321,16 +320,16 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
"no {} named `{}` found for {} `{}` in the current scope",
|
"no {} named `{}` found for {} `{}` in the current scope",
|
||||||
item_kind,
|
item_kind,
|
||||||
item_name,
|
item_name,
|
||||||
actual.prefix_string(self.tcx),
|
rcvr_ty.prefix_string(self.tcx),
|
||||||
ty_str_reported,
|
ty_str_reported,
|
||||||
);
|
);
|
||||||
if actual.references_error() {
|
if rcvr_ty.references_error() {
|
||||||
err.downgrade_to_delayed_bug();
|
err.downgrade_to_delayed_bug();
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Mode::MethodCall = mode && let SelfSource::MethodCall(cal) = source {
|
if let Mode::MethodCall = mode && let SelfSource::MethodCall(cal) = source {
|
||||||
self.suggest_await_before_method(
|
self.suggest_await_before_method(
|
||||||
&mut err, item_name, actual, cal, span,
|
&mut err, item_name, rcvr_ty, cal, span,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if let Some(span) = tcx.resolutions(()).confused_type_with_std_module.get(&span) {
|
if let Some(span) = tcx.resolutions(()).confused_type_with_std_module.get(&span) {
|
||||||
|
@ -341,7 +340,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
Applicability::MachineApplicable,
|
Applicability::MachineApplicable,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if let ty::RawPtr(_) = &actual.kind() {
|
if let ty::RawPtr(_) = &rcvr_ty.kind() {
|
||||||
err.note(
|
err.note(
|
||||||
"try using `<*const T>::as_ref()` to get a reference to the \
|
"try using `<*const T>::as_ref()` to get a reference to the \
|
||||||
type behind the pointer: https://doc.rust-lang.org/std/\
|
type behind the pointer: https://doc.rust-lang.org/std/\
|
||||||
|
@ -353,7 +352,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
let ty_span = match actual.kind() {
|
let ty_span = match rcvr_ty.kind() {
|
||||||
ty::Param(param_type) => Some(
|
ty::Param(param_type) => Some(
|
||||||
param_type.span_from_generics(self.tcx, self.body_id.owner.to_def_id()),
|
param_type.span_from_generics(self.tcx, self.body_id.owner.to_def_id()),
|
||||||
),
|
),
|
||||||
|
@ -365,7 +364,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
span,
|
span,
|
||||||
format!(
|
format!(
|
||||||
"{item_kind} `{item_name}` not found for this {}",
|
"{item_kind} `{item_name}` not found for this {}",
|
||||||
actual.prefix_string(self.tcx)
|
rcvr_ty.prefix_string(self.tcx)
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -398,122 +397,15 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
custom_span_label = true;
|
custom_span_label = true;
|
||||||
}
|
}
|
||||||
if static_candidates.len() == 1 {
|
if static_candidates.len() == 1 {
|
||||||
let mut has_unsuggestable_args = false;
|
self.suggest_associated_call_syntax(
|
||||||
let ty_str = if let Some(CandidateSource::Impl(impl_did)) =
|
&mut err,
|
||||||
static_candidates.get(0)
|
&static_candidates,
|
||||||
{
|
rcvr_ty,
|
||||||
// When the "method" is resolved through dereferencing, we really want the
|
source,
|
||||||
// original type that has the associated function for accurate suggestions.
|
item_name,
|
||||||
// (#61411)
|
args,
|
||||||
let ty = tcx.at(span).type_of(*impl_did);
|
sugg_span,
|
||||||
match (&ty.peel_refs().kind(), &actual.peel_refs().kind()) {
|
);
|
||||||
(ty::Adt(def, _), ty::Adt(def_actual, substs)) if def == def_actual => {
|
|
||||||
// If there are any inferred arguments, (`{integer}`), we should replace
|
|
||||||
// them with underscores to allow the compiler to infer them
|
|
||||||
let infer_substs: Vec<GenericArg<'_>> = substs
|
|
||||||
.into_iter()
|
|
||||||
.map(|arg| {
|
|
||||||
if !arg.is_suggestable(tcx, true) {
|
|
||||||
has_unsuggestable_args = true;
|
|
||||||
match arg.unpack() {
|
|
||||||
GenericArgKind::Lifetime(_) => self
|
|
||||||
.next_region_var(RegionVariableOrigin::MiscVariable(
|
|
||||||
rustc_span::DUMMY_SP,
|
|
||||||
))
|
|
||||||
.into(),
|
|
||||||
GenericArgKind::Type(_) => self
|
|
||||||
.next_ty_var(TypeVariableOrigin {
|
|
||||||
span: rustc_span::DUMMY_SP,
|
|
||||||
kind: TypeVariableOriginKind::MiscVariable,
|
|
||||||
})
|
|
||||||
.into(),
|
|
||||||
GenericArgKind::Const(arg) => self
|
|
||||||
.next_const_var(
|
|
||||||
arg.ty(),
|
|
||||||
ConstVariableOrigin {
|
|
||||||
span: rustc_span::DUMMY_SP,
|
|
||||||
kind: ConstVariableOriginKind::MiscVariable,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
.into(),
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
arg
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.collect::<Vec<_>>();
|
|
||||||
|
|
||||||
tcx.value_path_str_with_substs(
|
|
||||||
def_actual.did(),
|
|
||||||
tcx.intern_substs(&infer_substs),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
_ => self.ty_to_value_string(ty.peel_refs()),
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
self.ty_to_value_string(actual.peel_refs())
|
|
||||||
};
|
|
||||||
if let SelfSource::MethodCall(_) = source {
|
|
||||||
let first_arg = if let Some(CandidateSource::Impl(impl_did)) = static_candidates.get(0) &&
|
|
||||||
let Some(assoc) = self.associated_value(*impl_did, item_name) {
|
|
||||||
let sig = self.tcx.fn_sig(assoc.def_id);
|
|
||||||
if let Some(first) = sig.inputs().skip_binder().get(0) {
|
|
||||||
if first.peel_refs() == rcvr_ty.peel_refs() {
|
|
||||||
None
|
|
||||||
} else {
|
|
||||||
Some(if first.is_region_ptr() {
|
|
||||||
if first.is_mutable_ptr() { "&mut " } else { "&" }
|
|
||||||
} else {
|
|
||||||
""
|
|
||||||
})
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
None
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
None
|
|
||||||
};
|
|
||||||
let mut applicability = Applicability::MachineApplicable;
|
|
||||||
let args = if let Some((receiver, args)) = args {
|
|
||||||
// The first arg is the same kind as the receiver
|
|
||||||
let explicit_args = if first_arg.is_some() {
|
|
||||||
std::iter::once(receiver).chain(args.iter()).collect::<Vec<_>>()
|
|
||||||
} else {
|
|
||||||
// There is no `Self` kind to infer the arguments from
|
|
||||||
if has_unsuggestable_args {
|
|
||||||
applicability = Applicability::HasPlaceholders;
|
|
||||||
}
|
|
||||||
args.iter().collect()
|
|
||||||
};
|
|
||||||
format!(
|
|
||||||
"({}{})",
|
|
||||||
first_arg.unwrap_or(""),
|
|
||||||
explicit_args
|
|
||||||
.iter()
|
|
||||||
.map(|arg| tcx
|
|
||||||
.sess
|
|
||||||
.source_map()
|
|
||||||
.span_to_snippet(arg.span)
|
|
||||||
.unwrap_or_else(|_| {
|
|
||||||
applicability = Applicability::HasPlaceholders;
|
|
||||||
"_".to_owned()
|
|
||||||
}))
|
|
||||||
.collect::<Vec<_>>()
|
|
||||||
.join(", "),
|
|
||||||
)
|
|
||||||
} else {
|
|
||||||
applicability = Applicability::HasPlaceholders;
|
|
||||||
"(...)".to_owned()
|
|
||||||
};
|
|
||||||
err.span_suggestion(
|
|
||||||
sugg_span,
|
|
||||||
"use associated function syntax instead",
|
|
||||||
format!("{}::{}{}", ty_str, item_name, args),
|
|
||||||
applicability,
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
err.help(&format!("try with `{}::{}`", ty_str, item_name,));
|
|
||||||
}
|
|
||||||
|
|
||||||
report_candidates(span, &mut err, &mut static_candidates, sugg_span);
|
report_candidates(span, &mut err, &mut static_candidates, sugg_span);
|
||||||
} else if static_candidates.len() > 1 {
|
} else if static_candidates.len() > 1 {
|
||||||
|
@ -523,7 +415,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
let mut bound_spans = vec![];
|
let mut bound_spans = vec![];
|
||||||
let mut restrict_type_params = false;
|
let mut restrict_type_params = false;
|
||||||
let mut unsatisfied_bounds = false;
|
let mut unsatisfied_bounds = false;
|
||||||
if item_name.name == sym::count && self.is_slice_ty(actual, span) {
|
if item_name.name == sym::count && self.is_slice_ty(rcvr_ty, span) {
|
||||||
let msg = "consider using `len` instead";
|
let msg = "consider using `len` instead";
|
||||||
if let SelfSource::MethodCall(_expr) = source {
|
if let SelfSource::MethodCall(_expr) = source {
|
||||||
err.span_suggestion_short(
|
err.span_suggestion_short(
|
||||||
|
@ -537,7 +429,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
}
|
}
|
||||||
if let Some(iterator_trait) = self.tcx.get_diagnostic_item(sym::Iterator) {
|
if let Some(iterator_trait) = self.tcx.get_diagnostic_item(sym::Iterator) {
|
||||||
let iterator_trait = self.tcx.def_path_str(iterator_trait);
|
let iterator_trait = self.tcx.def_path_str(iterator_trait);
|
||||||
err.note(&format!("`count` is defined on `{iterator_trait}`, which `{actual}` does not implement"));
|
err.note(&format!("`count` is defined on `{iterator_trait}`, which `{rcvr_ty}` does not implement"));
|
||||||
}
|
}
|
||||||
} else if !unsatisfied_predicates.is_empty() {
|
} else if !unsatisfied_predicates.is_empty() {
|
||||||
let mut type_params = FxHashMap::default();
|
let mut type_params = FxHashMap::default();
|
||||||
|
@ -876,7 +768,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
.map(|(_, path)| path)
|
.map(|(_, path)| path)
|
||||||
.collect::<Vec<_>>()
|
.collect::<Vec<_>>()
|
||||||
.join("\n");
|
.join("\n");
|
||||||
let actual_prefix = actual.prefix_string(self.tcx);
|
let actual_prefix = rcvr_ty.prefix_string(self.tcx);
|
||||||
info!("unimplemented_traits.len() == {}", unimplemented_traits.len());
|
info!("unimplemented_traits.len() == {}", unimplemented_traits.len());
|
||||||
let (primary_message, label) =
|
let (primary_message, label) =
|
||||||
if unimplemented_traits.len() == 1 && unimplemented_traits_only {
|
if unimplemented_traits.len() == 1 && unimplemented_traits_only {
|
||||||
|
@ -885,7 +777,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
.next()
|
.next()
|
||||||
.map(|(_, (trait_ref, obligation))| {
|
.map(|(_, (trait_ref, obligation))| {
|
||||||
if trait_ref.self_ty().references_error()
|
if trait_ref.self_ty().references_error()
|
||||||
|| actual.references_error()
|
|| rcvr_ty.references_error()
|
||||||
{
|
{
|
||||||
// Avoid crashing.
|
// Avoid crashing.
|
||||||
return (None, None);
|
return (None, None);
|
||||||
|
@ -921,7 +813,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
let label_span_not_found = |err: &mut Diagnostic| {
|
let label_span_not_found = |err: &mut Diagnostic| {
|
||||||
if unsatisfied_predicates.is_empty() {
|
if unsatisfied_predicates.is_empty() {
|
||||||
err.span_label(span, format!("{item_kind} not found in `{ty_str}`"));
|
err.span_label(span, format!("{item_kind} not found in `{ty_str}`"));
|
||||||
let is_string_or_ref_str = match actual.kind() {
|
let is_string_or_ref_str = match rcvr_ty.kind() {
|
||||||
ty::Ref(_, ty, _) => {
|
ty::Ref(_, ty, _) => {
|
||||||
ty.is_str()
|
ty.is_str()
|
||||||
|| matches!(
|
|| matches!(
|
||||||
|
@ -957,7 +849,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
// different from the received one
|
// different from the received one
|
||||||
// So we avoid suggestion method with Box<Self>
|
// So we avoid suggestion method with Box<Self>
|
||||||
// for instance
|
// for instance
|
||||||
self.tcx.at(span).type_of(*def_id) != actual
|
self.tcx.at(span).type_of(*def_id) != rcvr_ty
|
||||||
&& self.tcx.at(span).type_of(*def_id) != rcvr_ty
|
&& self.tcx.at(span).type_of(*def_id) != rcvr_ty
|
||||||
}
|
}
|
||||||
(Mode::Path, false, _) => true,
|
(Mode::Path, false, _) => true,
|
||||||
|
@ -1017,10 +909,12 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
// Don't suggest (for example) `expr.field.clone()` if `expr.clone()`
|
// Don't suggest (for example) `expr.field.clone()` if `expr.clone()`
|
||||||
// can't be called due to `typeof(expr): Clone` not holding.
|
// can't be called due to `typeof(expr): Clone` not holding.
|
||||||
if unsatisfied_predicates.is_empty() {
|
if unsatisfied_predicates.is_empty() {
|
||||||
self.suggest_calling_method_on_field(&mut err, source, span, actual, item_name);
|
self.suggest_calling_method_on_field(
|
||||||
|
&mut err, source, span, rcvr_ty, item_name,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
self.check_for_inner_self(&mut err, source, span, actual, item_name);
|
self.check_for_inner_self(&mut err, source, span, rcvr_ty, item_name);
|
||||||
|
|
||||||
bound_spans.sort();
|
bound_spans.sort();
|
||||||
bound_spans.dedup();
|
bound_spans.dedup();
|
||||||
|
@ -1028,7 +922,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
err.span_label(span, &msg);
|
err.span_label(span, &msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
if actual.is_numeric() && actual.is_fresh() || restrict_type_params {
|
if rcvr_ty.is_numeric() && rcvr_ty.is_fresh() || restrict_type_params {
|
||||||
} else {
|
} else {
|
||||||
self.suggest_traits_to_import(
|
self.suggest_traits_to_import(
|
||||||
&mut err,
|
&mut err,
|
||||||
|
@ -1046,8 +940,8 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
|
|
||||||
// Don't emit a suggestion if we found an actual method
|
// Don't emit a suggestion if we found an actual method
|
||||||
// that had unsatisfied trait bounds
|
// that had unsatisfied trait bounds
|
||||||
if unsatisfied_predicates.is_empty() && actual.is_enum() {
|
if unsatisfied_predicates.is_empty() && rcvr_ty.is_enum() {
|
||||||
let adt_def = actual.ty_adt_def().expect("enum is not an ADT");
|
let adt_def = rcvr_ty.ty_adt_def().expect("enum is not an ADT");
|
||||||
if let Some(suggestion) = lev_distance::find_best_match_for_name(
|
if let Some(suggestion) = lev_distance::find_best_match_for_name(
|
||||||
&adt_def.variants().iter().map(|s| s.name).collect::<Vec<_>>(),
|
&adt_def.variants().iter().map(|s| s.name).collect::<Vec<_>>(),
|
||||||
item_name.name,
|
item_name.name,
|
||||||
|
@ -1062,7 +956,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if item_name.name == sym::as_str && actual.peel_refs().is_str() {
|
if item_name.name == sym::as_str && rcvr_ty.peel_refs().is_str() {
|
||||||
let msg = "remove this method call";
|
let msg = "remove this method call";
|
||||||
let mut fallback_span = true;
|
let mut fallback_span = true;
|
||||||
if let SelfSource::MethodCall(expr) = source {
|
if let SelfSource::MethodCall(expr) = source {
|
||||||
|
@ -1178,6 +1072,138 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Suggest calling `Ty::method` if `.method()` isn't found because the method
|
||||||
|
/// doesn't take a `self` receiver.
|
||||||
|
fn suggest_associated_call_syntax(
|
||||||
|
&self,
|
||||||
|
err: &mut Diagnostic,
|
||||||
|
static_candidates: &Vec<CandidateSource>,
|
||||||
|
rcvr_ty: Ty<'tcx>,
|
||||||
|
source: SelfSource<'tcx>,
|
||||||
|
item_name: Ident,
|
||||||
|
args: Option<(&hir::Expr<'tcx>, &[hir::Expr<'tcx>])>,
|
||||||
|
sugg_span: Span,
|
||||||
|
) {
|
||||||
|
let mut has_unsuggestable_args = false;
|
||||||
|
let ty_str = if let Some(CandidateSource::Impl(impl_did)) = static_candidates.get(0) {
|
||||||
|
// When the "method" is resolved through dereferencing, we really want the
|
||||||
|
// original type that has the associated function for accurate suggestions.
|
||||||
|
// (#61411)
|
||||||
|
let impl_ty = self.tcx.type_of(*impl_did);
|
||||||
|
let target_ty = self
|
||||||
|
.autoderef(sugg_span, rcvr_ty)
|
||||||
|
.find(|(rcvr_ty, _)| {
|
||||||
|
DeepRejectCtxt { treat_obligation_params: TreatParams::AsInfer }
|
||||||
|
.types_may_unify(*rcvr_ty, impl_ty)
|
||||||
|
})
|
||||||
|
.map_or(impl_ty, |(ty, _)| ty)
|
||||||
|
.peel_refs();
|
||||||
|
if let ty::Adt(def, substs) = target_ty.kind() {
|
||||||
|
// If there are any inferred arguments, (`{integer}`), we should replace
|
||||||
|
// them with underscores to allow the compiler to infer them
|
||||||
|
let infer_substs = self.tcx.mk_substs(substs.into_iter().map(|arg| {
|
||||||
|
if !arg.is_suggestable(self.tcx, true) {
|
||||||
|
has_unsuggestable_args = true;
|
||||||
|
match arg.unpack() {
|
||||||
|
GenericArgKind::Lifetime(_) => self
|
||||||
|
.next_region_var(RegionVariableOrigin::MiscVariable(
|
||||||
|
rustc_span::DUMMY_SP,
|
||||||
|
))
|
||||||
|
.into(),
|
||||||
|
GenericArgKind::Type(_) => self
|
||||||
|
.next_ty_var(TypeVariableOrigin {
|
||||||
|
span: rustc_span::DUMMY_SP,
|
||||||
|
kind: TypeVariableOriginKind::MiscVariable,
|
||||||
|
})
|
||||||
|
.into(),
|
||||||
|
GenericArgKind::Const(arg) => self
|
||||||
|
.next_const_var(
|
||||||
|
arg.ty(),
|
||||||
|
ConstVariableOrigin {
|
||||||
|
span: rustc_span::DUMMY_SP,
|
||||||
|
kind: ConstVariableOriginKind::MiscVariable,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
.into(),
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
arg
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
|
||||||
|
self.tcx.value_path_str_with_substs(def.did(), infer_substs)
|
||||||
|
} else {
|
||||||
|
self.ty_to_value_string(target_ty)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
self.ty_to_value_string(rcvr_ty.peel_refs())
|
||||||
|
};
|
||||||
|
if let SelfSource::MethodCall(_) = source {
|
||||||
|
let first_arg = if let Some(CandidateSource::Impl(impl_did)) = static_candidates.get(0)
|
||||||
|
&& let Some(assoc) = self.associated_value(*impl_did, item_name)
|
||||||
|
&& assoc.kind == ty::AssocKind::Fn
|
||||||
|
{
|
||||||
|
let sig = self.tcx.fn_sig(assoc.def_id);
|
||||||
|
if let Some(first) = sig.inputs().skip_binder().get(0) {
|
||||||
|
if first.peel_refs() == rcvr_ty.peel_refs() {
|
||||||
|
None
|
||||||
|
} else {
|
||||||
|
Some(if first.is_region_ptr() {
|
||||||
|
if first.is_mutable_ptr() { "&mut " } else { "&" }
|
||||||
|
} else {
|
||||||
|
""
|
||||||
|
})
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
};
|
||||||
|
let mut applicability = Applicability::MachineApplicable;
|
||||||
|
let args = if let Some((receiver, args)) = args {
|
||||||
|
// The first arg is the same kind as the receiver
|
||||||
|
let explicit_args = if first_arg.is_some() {
|
||||||
|
std::iter::once(receiver).chain(args.iter()).collect::<Vec<_>>()
|
||||||
|
} else {
|
||||||
|
// There is no `Self` kind to infer the arguments from
|
||||||
|
if has_unsuggestable_args {
|
||||||
|
applicability = Applicability::HasPlaceholders;
|
||||||
|
}
|
||||||
|
args.iter().collect()
|
||||||
|
};
|
||||||
|
format!(
|
||||||
|
"({}{})",
|
||||||
|
first_arg.unwrap_or(""),
|
||||||
|
explicit_args
|
||||||
|
.iter()
|
||||||
|
.map(|arg| self
|
||||||
|
.tcx
|
||||||
|
.sess
|
||||||
|
.source_map()
|
||||||
|
.span_to_snippet(arg.span)
|
||||||
|
.unwrap_or_else(|_| {
|
||||||
|
applicability = Applicability::HasPlaceholders;
|
||||||
|
"_".to_owned()
|
||||||
|
}))
|
||||||
|
.collect::<Vec<_>>()
|
||||||
|
.join(", "),
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
applicability = Applicability::HasPlaceholders;
|
||||||
|
"(...)".to_owned()
|
||||||
|
};
|
||||||
|
err.span_suggestion(
|
||||||
|
sugg_span,
|
||||||
|
"use associated function syntax instead",
|
||||||
|
format!("{}::{}{}", ty_str, item_name, args),
|
||||||
|
applicability,
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
err.help(&format!("try with `{}::{}`", ty_str, item_name,));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Suggest calling a field with a type that implements the `Fn*` traits instead of a method with
|
/// Suggest calling a field with a type that implements the `Fn*` traits instead of a method with
|
||||||
/// the same name as the field i.e. `(a.my_fn_ptr)(10)` instead of `a.my_fn_ptr(10)`.
|
/// the same name as the field i.e. `(a.my_fn_ptr)(10)` instead of `a.my_fn_ptr(10)`.
|
||||||
fn suggest_calling_field_as_fn(
|
fn suggest_calling_field_as_fn(
|
||||||
|
|
|
@ -11,7 +11,8 @@ declare_lint! {
|
||||||
/// scope.
|
/// scope.
|
||||||
///
|
///
|
||||||
/// ### Example
|
/// ### Example
|
||||||
/// ```
|
///
|
||||||
|
/// ```rust
|
||||||
/// struct SomeStruct;
|
/// struct SomeStruct;
|
||||||
/// impl Drop for SomeStruct {
|
/// impl Drop for SomeStruct {
|
||||||
/// fn drop(&mut self) {
|
/// fn drop(&mut self) {
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
#include "llvm/IR/IntrinsicsARM.h"
|
#include "llvm/IR/IntrinsicsARM.h"
|
||||||
#include "llvm/IR/Mangler.h"
|
#include "llvm/IR/Mangler.h"
|
||||||
#if LLVM_VERSION_GE(16, 0)
|
#if LLVM_VERSION_GE(16, 0)
|
||||||
#include "llvm/IR/ModRef.h"
|
#include "llvm/Support/ModRef.h"
|
||||||
#endif
|
#endif
|
||||||
#include "llvm/Object/Archive.h"
|
#include "llvm/Object/Archive.h"
|
||||||
#include "llvm/Object/COFFImportFile.h"
|
#include "llvm/Object/COFFImportFile.h"
|
||||||
|
|
|
@ -170,8 +170,6 @@ symbols! {
|
||||||
Count,
|
Count,
|
||||||
Cow,
|
Cow,
|
||||||
Debug,
|
Debug,
|
||||||
DebugStruct,
|
|
||||||
DebugTuple,
|
|
||||||
Decodable,
|
Decodable,
|
||||||
Decoder,
|
Decoder,
|
||||||
DecorateLint,
|
DecorateLint,
|
||||||
|
@ -190,9 +188,6 @@ symbols! {
|
||||||
Error,
|
Error,
|
||||||
File,
|
File,
|
||||||
FileType,
|
FileType,
|
||||||
Fn,
|
|
||||||
FnMut,
|
|
||||||
FnOnce,
|
|
||||||
FormatSpec,
|
FormatSpec,
|
||||||
Formatter,
|
Formatter,
|
||||||
From,
|
From,
|
||||||
|
@ -211,7 +206,6 @@ symbols! {
|
||||||
Input,
|
Input,
|
||||||
Into,
|
Into,
|
||||||
IntoDiagnostic,
|
IntoDiagnostic,
|
||||||
IntoFuture,
|
|
||||||
IntoIterator,
|
IntoIterator,
|
||||||
IoRead,
|
IoRead,
|
||||||
IoWrite,
|
IoWrite,
|
||||||
|
@ -256,7 +250,6 @@ symbols! {
|
||||||
Pointer,
|
Pointer,
|
||||||
Poll,
|
Poll,
|
||||||
ProcMacro,
|
ProcMacro,
|
||||||
ProcMacroHack,
|
|
||||||
ProceduralMasqueradeDummyType,
|
ProceduralMasqueradeDummyType,
|
||||||
Range,
|
Range,
|
||||||
RangeFrom,
|
RangeFrom,
|
||||||
|
@ -332,7 +325,6 @@ symbols! {
|
||||||
abi_vectorcall,
|
abi_vectorcall,
|
||||||
abi_x86_interrupt,
|
abi_x86_interrupt,
|
||||||
abort,
|
abort,
|
||||||
aborts,
|
|
||||||
add,
|
add,
|
||||||
add_assign,
|
add_assign,
|
||||||
add_with_overflow,
|
add_with_overflow,
|
||||||
|
@ -344,7 +336,6 @@ symbols! {
|
||||||
align,
|
align,
|
||||||
align_offset,
|
align_offset,
|
||||||
alignment,
|
alignment,
|
||||||
alignstack,
|
|
||||||
all,
|
all,
|
||||||
alloc,
|
alloc,
|
||||||
alloc_error_handler,
|
alloc_error_handler,
|
||||||
|
@ -433,7 +424,6 @@ symbols! {
|
||||||
bool,
|
bool,
|
||||||
borrowck_graphviz_format,
|
borrowck_graphviz_format,
|
||||||
borrowck_graphviz_postflow,
|
borrowck_graphviz_postflow,
|
||||||
borrowck_graphviz_preflow,
|
|
||||||
box_free,
|
box_free,
|
||||||
box_patterns,
|
box_patterns,
|
||||||
box_syntax,
|
box_syntax,
|
||||||
|
@ -462,7 +452,6 @@ symbols! {
|
||||||
cfg_doctest,
|
cfg_doctest,
|
||||||
cfg_eval,
|
cfg_eval,
|
||||||
cfg_hide,
|
cfg_hide,
|
||||||
cfg_macro,
|
|
||||||
cfg_panic,
|
cfg_panic,
|
||||||
cfg_sanitize,
|
cfg_sanitize,
|
||||||
cfg_target_abi,
|
cfg_target_abi,
|
||||||
|
@ -470,7 +459,6 @@ symbols! {
|
||||||
cfg_target_feature,
|
cfg_target_feature,
|
||||||
cfg_target_has_atomic,
|
cfg_target_has_atomic,
|
||||||
cfg_target_has_atomic_equal_alignment,
|
cfg_target_has_atomic_equal_alignment,
|
||||||
cfg_target_has_atomic_load_store,
|
|
||||||
cfg_target_thread_local,
|
cfg_target_thread_local,
|
||||||
cfg_target_vendor,
|
cfg_target_vendor,
|
||||||
cfg_version,
|
cfg_version,
|
||||||
|
@ -495,19 +483,15 @@ symbols! {
|
||||||
cold,
|
cold,
|
||||||
collapse_debuginfo,
|
collapse_debuginfo,
|
||||||
column,
|
column,
|
||||||
column_macro,
|
|
||||||
compare_and_swap,
|
|
||||||
compare_exchange,
|
compare_exchange,
|
||||||
compare_exchange_weak,
|
compare_exchange_weak,
|
||||||
compile_error,
|
compile_error,
|
||||||
compile_error_macro,
|
|
||||||
compiler,
|
compiler,
|
||||||
compiler_builtins,
|
compiler_builtins,
|
||||||
compiler_fence,
|
compiler_fence,
|
||||||
concat,
|
concat,
|
||||||
concat_bytes,
|
concat_bytes,
|
||||||
concat_idents,
|
concat_idents,
|
||||||
concat_macro,
|
|
||||||
conservative_impl_trait,
|
conservative_impl_trait,
|
||||||
console,
|
console,
|
||||||
const_allocate,
|
const_allocate,
|
||||||
|
@ -528,7 +512,6 @@ symbols! {
|
||||||
const_fn_unsize,
|
const_fn_unsize,
|
||||||
const_for,
|
const_for,
|
||||||
const_format_args,
|
const_format_args,
|
||||||
const_generic_defaults,
|
|
||||||
const_generics,
|
const_generics,
|
||||||
const_generics_defaults,
|
const_generics_defaults,
|
||||||
const_if_match,
|
const_if_match,
|
||||||
|
@ -547,22 +530,19 @@ symbols! {
|
||||||
const_trait,
|
const_trait,
|
||||||
const_trait_bound_opt_out,
|
const_trait_bound_opt_out,
|
||||||
const_trait_impl,
|
const_trait_impl,
|
||||||
const_transmute,
|
|
||||||
const_try,
|
const_try,
|
||||||
constant,
|
constant,
|
||||||
constructor,
|
constructor,
|
||||||
contents,
|
|
||||||
context,
|
context,
|
||||||
convert,
|
|
||||||
copy,
|
copy,
|
||||||
copy_closures,
|
copy_closures,
|
||||||
copy_nonoverlapping,
|
copy_nonoverlapping,
|
||||||
copysignf32,
|
copysignf32,
|
||||||
copysignf64,
|
copysignf64,
|
||||||
core,
|
core,
|
||||||
core_intrinsics,
|
|
||||||
core_panic,
|
core_panic,
|
||||||
core_panic_2015_macro,
|
core_panic_2015_macro,
|
||||||
|
core_panic_2021_macro,
|
||||||
core_panic_macro,
|
core_panic_macro,
|
||||||
cosf32,
|
cosf32,
|
||||||
cosf64,
|
cosf64,
|
||||||
|
@ -598,7 +578,6 @@ symbols! {
|
||||||
debug_assertions,
|
debug_assertions,
|
||||||
debug_struct,
|
debug_struct,
|
||||||
debug_struct_fields_finish,
|
debug_struct_fields_finish,
|
||||||
debug_trait_builder,
|
|
||||||
debug_tuple,
|
debug_tuple,
|
||||||
debug_tuple_fields_finish,
|
debug_tuple_fields_finish,
|
||||||
debugger_visualizer,
|
debugger_visualizer,
|
||||||
|
@ -630,7 +609,6 @@ symbols! {
|
||||||
discriminant_type,
|
discriminant_type,
|
||||||
discriminant_value,
|
discriminant_value,
|
||||||
dispatch_from_dyn,
|
dispatch_from_dyn,
|
||||||
display_trait,
|
|
||||||
div,
|
div,
|
||||||
div_assign,
|
div_assign,
|
||||||
doc,
|
doc,
|
||||||
|
@ -661,7 +639,6 @@ symbols! {
|
||||||
dyn_star,
|
dyn_star,
|
||||||
dyn_trait,
|
dyn_trait,
|
||||||
e,
|
e,
|
||||||
edition_macro_pats,
|
|
||||||
edition_panic,
|
edition_panic,
|
||||||
eh_catch_typeinfo,
|
eh_catch_typeinfo,
|
||||||
eh_personality,
|
eh_personality,
|
||||||
|
@ -674,7 +651,6 @@ symbols! {
|
||||||
encode,
|
encode,
|
||||||
end,
|
end,
|
||||||
env,
|
env,
|
||||||
env_macro,
|
|
||||||
eprint_macro,
|
eprint_macro,
|
||||||
eprintln_macro,
|
eprintln_macro,
|
||||||
eq,
|
eq,
|
||||||
|
@ -724,9 +700,7 @@ symbols! {
|
||||||
field,
|
field,
|
||||||
field_init_shorthand,
|
field_init_shorthand,
|
||||||
file,
|
file,
|
||||||
file_macro,
|
|
||||||
fill,
|
fill,
|
||||||
finish,
|
|
||||||
flags,
|
flags,
|
||||||
float,
|
float,
|
||||||
float_to_int_unchecked,
|
float_to_int_unchecked,
|
||||||
|
@ -735,8 +709,6 @@ symbols! {
|
||||||
fmaf32,
|
fmaf32,
|
||||||
fmaf64,
|
fmaf64,
|
||||||
fmt,
|
fmt,
|
||||||
fmt_as_str,
|
|
||||||
fmt_internals,
|
|
||||||
fmul_fast,
|
fmul_fast,
|
||||||
fn_align,
|
fn_align,
|
||||||
fn_must_use,
|
fn_must_use,
|
||||||
|
@ -751,7 +723,6 @@ symbols! {
|
||||||
format_args_macro,
|
format_args_macro,
|
||||||
format_args_nl,
|
format_args_nl,
|
||||||
format_macro,
|
format_macro,
|
||||||
fp,
|
|
||||||
freeze,
|
freeze,
|
||||||
freg,
|
freg,
|
||||||
frem_fast,
|
frem_fast,
|
||||||
|
@ -814,7 +785,6 @@ symbols! {
|
||||||
ignore,
|
ignore,
|
||||||
impl_header_lifetime_elision,
|
impl_header_lifetime_elision,
|
||||||
impl_lint_pass,
|
impl_lint_pass,
|
||||||
impl_macros,
|
|
||||||
impl_trait_in_bindings,
|
impl_trait_in_bindings,
|
||||||
impl_trait_in_fn_trait_return,
|
impl_trait_in_fn_trait_return,
|
||||||
implied_by,
|
implied_by,
|
||||||
|
@ -826,7 +796,6 @@ symbols! {
|
||||||
include,
|
include,
|
||||||
include_bytes,
|
include_bytes,
|
||||||
include_bytes_macro,
|
include_bytes_macro,
|
||||||
include_macro,
|
|
||||||
include_str,
|
include_str,
|
||||||
include_str_macro,
|
include_str_macro,
|
||||||
inclusive_range_syntax,
|
inclusive_range_syntax,
|
||||||
|
@ -844,7 +813,6 @@ symbols! {
|
||||||
instruction_set,
|
instruction_set,
|
||||||
integer_: "integer",
|
integer_: "integer",
|
||||||
integral,
|
integral,
|
||||||
intel,
|
|
||||||
into_future,
|
into_future,
|
||||||
into_iter,
|
into_iter,
|
||||||
intra_doc_pointers,
|
intra_doc_pointers,
|
||||||
|
@ -881,7 +849,6 @@ symbols! {
|
||||||
lifetimes,
|
lifetimes,
|
||||||
likely,
|
likely,
|
||||||
line,
|
line,
|
||||||
line_macro,
|
|
||||||
link,
|
link,
|
||||||
link_args,
|
link_args,
|
||||||
link_cfg,
|
link_cfg,
|
||||||
|
@ -926,7 +893,6 @@ symbols! {
|
||||||
masked,
|
masked,
|
||||||
match_beginning_vert,
|
match_beginning_vert,
|
||||||
match_default_bindings,
|
match_default_bindings,
|
||||||
matches_macro,
|
|
||||||
maxnumf32,
|
maxnumf32,
|
||||||
maxnumf64,
|
maxnumf64,
|
||||||
may_dangle,
|
may_dangle,
|
||||||
|
@ -965,7 +931,6 @@ symbols! {
|
||||||
modifiers,
|
modifiers,
|
||||||
module,
|
module,
|
||||||
module_path,
|
module_path,
|
||||||
module_path_macro,
|
|
||||||
more_qualified_paths,
|
more_qualified_paths,
|
||||||
more_struct_aliases,
|
more_struct_aliases,
|
||||||
movbe_target_feature,
|
movbe_target_feature,
|
||||||
|
@ -1035,7 +1000,6 @@ symbols! {
|
||||||
non_exhaustive,
|
non_exhaustive,
|
||||||
non_exhaustive_omitted_patterns_lint,
|
non_exhaustive_omitted_patterns_lint,
|
||||||
non_modrs_mods,
|
non_modrs_mods,
|
||||||
none_error,
|
|
||||||
nontemporal_store,
|
nontemporal_store,
|
||||||
noop_method_borrow,
|
noop_method_borrow,
|
||||||
noop_method_clone,
|
noop_method_clone,
|
||||||
|
@ -1060,7 +1024,6 @@ symbols! {
|
||||||
optin_builtin_traits,
|
optin_builtin_traits,
|
||||||
option,
|
option,
|
||||||
option_env,
|
option_env,
|
||||||
option_env_macro,
|
|
||||||
options,
|
options,
|
||||||
or,
|
or,
|
||||||
or_patterns,
|
or_patterns,
|
||||||
|
@ -1103,7 +1066,6 @@ symbols! {
|
||||||
plugins,
|
plugins,
|
||||||
pointee_trait,
|
pointee_trait,
|
||||||
pointer,
|
pointer,
|
||||||
pointer_trait_fmt,
|
|
||||||
poll,
|
poll,
|
||||||
position,
|
position,
|
||||||
post_dash_lto: "post-lto",
|
post_dash_lto: "post-lto",
|
||||||
|
@ -1130,7 +1092,6 @@ symbols! {
|
||||||
proc_dash_macro: "proc-macro",
|
proc_dash_macro: "proc-macro",
|
||||||
proc_macro,
|
proc_macro,
|
||||||
proc_macro_attribute,
|
proc_macro_attribute,
|
||||||
proc_macro_def_site,
|
|
||||||
proc_macro_derive,
|
proc_macro_derive,
|
||||||
proc_macro_expr,
|
proc_macro_expr,
|
||||||
proc_macro_gen,
|
proc_macro_gen,
|
||||||
|
@ -1231,9 +1192,6 @@ symbols! {
|
||||||
rust_cold_cc,
|
rust_cold_cc,
|
||||||
rust_eh_catch_typeinfo,
|
rust_eh_catch_typeinfo,
|
||||||
rust_eh_personality,
|
rust_eh_personality,
|
||||||
rust_eh_register_frames,
|
|
||||||
rust_eh_unregister_frames,
|
|
||||||
rust_oom,
|
|
||||||
rustc,
|
rustc,
|
||||||
rustc_allocator,
|
rustc_allocator,
|
||||||
rustc_allocator_zeroed,
|
rustc_allocator_zeroed,
|
||||||
|
@ -1306,7 +1264,6 @@ symbols! {
|
||||||
rustc_serialize,
|
rustc_serialize,
|
||||||
rustc_skip_array_during_method_dispatch,
|
rustc_skip_array_during_method_dispatch,
|
||||||
rustc_specialization_trait,
|
rustc_specialization_trait,
|
||||||
rustc_stable,
|
|
||||||
rustc_std_internal_symbol,
|
rustc_std_internal_symbol,
|
||||||
rustc_strict_coherence,
|
rustc_strict_coherence,
|
||||||
rustc_symbol_name,
|
rustc_symbol_name,
|
||||||
|
@ -1434,7 +1391,6 @@ symbols! {
|
||||||
static_recursion,
|
static_recursion,
|
||||||
staticlib,
|
staticlib,
|
||||||
std,
|
std,
|
||||||
std_inject,
|
|
||||||
std_panic,
|
std_panic,
|
||||||
std_panic_2015_macro,
|
std_panic_2015_macro,
|
||||||
std_panic_macro,
|
std_panic_macro,
|
||||||
|
@ -1449,7 +1405,6 @@ symbols! {
|
||||||
str_trim_start,
|
str_trim_start,
|
||||||
strict_provenance,
|
strict_provenance,
|
||||||
stringify,
|
stringify,
|
||||||
stringify_macro,
|
|
||||||
struct_field_attributes,
|
struct_field_attributes,
|
||||||
struct_inherit,
|
struct_inherit,
|
||||||
struct_variant,
|
struct_variant,
|
||||||
|
@ -1477,10 +1432,8 @@ symbols! {
|
||||||
target_has_atomic_load_store,
|
target_has_atomic_load_store,
|
||||||
target_os,
|
target_os,
|
||||||
target_pointer_width,
|
target_pointer_width,
|
||||||
target_target_vendor,
|
|
||||||
target_thread_local,
|
target_thread_local,
|
||||||
target_vendor,
|
target_vendor,
|
||||||
task,
|
|
||||||
tbm_target_feature,
|
tbm_target_feature,
|
||||||
termination,
|
termination,
|
||||||
termination_trait,
|
termination_trait,
|
||||||
|
@ -1492,7 +1445,6 @@ symbols! {
|
||||||
test_removed_feature,
|
test_removed_feature,
|
||||||
test_runner,
|
test_runner,
|
||||||
test_unstable_lint,
|
test_unstable_lint,
|
||||||
then_with,
|
|
||||||
thread,
|
thread,
|
||||||
thread_local,
|
thread_local,
|
||||||
thread_local_macro,
|
thread_local_macro,
|
||||||
|
@ -1524,7 +1476,6 @@ symbols! {
|
||||||
try_trait_v2,
|
try_trait_v2,
|
||||||
tt,
|
tt,
|
||||||
tuple,
|
tuple,
|
||||||
tuple_from_req,
|
|
||||||
tuple_indexing,
|
tuple_indexing,
|
||||||
tuple_trait,
|
tuple_trait,
|
||||||
two_phase,
|
two_phase,
|
||||||
|
@ -1568,7 +1519,6 @@ symbols! {
|
||||||
unreachable_2015,
|
unreachable_2015,
|
||||||
unreachable_2015_macro,
|
unreachable_2015_macro,
|
||||||
unreachable_2021,
|
unreachable_2021,
|
||||||
unreachable_2021_macro,
|
|
||||||
unreachable_code,
|
unreachable_code,
|
||||||
unreachable_display,
|
unreachable_display,
|
||||||
unreachable_macro,
|
unreachable_macro,
|
||||||
|
@ -1587,7 +1537,6 @@ symbols! {
|
||||||
from crates.io via `Cargo.toml` instead?",
|
from crates.io via `Cargo.toml` instead?",
|
||||||
untagged_unions,
|
untagged_unions,
|
||||||
unused_imports,
|
unused_imports,
|
||||||
unused_qualifications,
|
|
||||||
unwind,
|
unwind,
|
||||||
unwind_attributes,
|
unwind_attributes,
|
||||||
unwind_safe_trait,
|
unwind_safe_trait,
|
||||||
|
|
|
@ -650,41 +650,14 @@ impl<'tcx> TypeErrCtxtExt<'tcx> for TypeErrCtxt<'_, 'tcx> {
|
||||||
))
|
))
|
||||||
);
|
);
|
||||||
|
|
||||||
if is_try_conversion {
|
if is_try_conversion && let Some(ret_span) = self.return_type_span(&obligation) {
|
||||||
let none_error = self
|
err.span_label(
|
||||||
.tcx
|
ret_span,
|
||||||
.get_diagnostic_item(sym::none_error)
|
&format!(
|
||||||
.map(|def_id| tcx.type_of(def_id));
|
"expected `{}` because of this",
|
||||||
let should_convert_option_to_result =
|
trait_ref.skip_binder().self_ty()
|
||||||
Some(trait_ref.skip_binder().substs.type_at(1)) == none_error;
|
),
|
||||||
let should_convert_result_to_option =
|
);
|
||||||
Some(trait_ref.self_ty().skip_binder()) == none_error;
|
|
||||||
if should_convert_option_to_result {
|
|
||||||
err.span_suggestion_verbose(
|
|
||||||
span.shrink_to_lo(),
|
|
||||||
"consider converting the `Option<T>` into a `Result<T, _>` \
|
|
||||||
using `Option::ok_or` or `Option::ok_or_else`",
|
|
||||||
".ok_or_else(|| /* error value */)",
|
|
||||||
Applicability::HasPlaceholders,
|
|
||||||
);
|
|
||||||
} else if should_convert_result_to_option {
|
|
||||||
err.span_suggestion_verbose(
|
|
||||||
span.shrink_to_lo(),
|
|
||||||
"consider converting the `Result<T, _>` into an `Option<T>` \
|
|
||||||
using `Result::ok`",
|
|
||||||
".ok()",
|
|
||||||
Applicability::MachineApplicable,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if let Some(ret_span) = self.return_type_span(&obligation) {
|
|
||||||
err.span_label(
|
|
||||||
ret_span,
|
|
||||||
&format!(
|
|
||||||
"expected `{}` because of this",
|
|
||||||
trait_ref.skip_binder().self_ty()
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if Some(trait_ref.def_id()) == tcx.lang_items().tuple_trait() {
|
if Some(trait_ref.def_id()) == tcx.lang_items().tuple_trait() {
|
||||||
|
|
|
@ -1054,7 +1054,6 @@ pub trait UpperHex {
|
||||||
pub trait Pointer {
|
pub trait Pointer {
|
||||||
/// Formats the value using the given formatter.
|
/// Formats the value using the given formatter.
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_diagnostic_item = "pointer_trait_fmt"]
|
|
||||||
fn fmt(&self, f: &mut Formatter<'_>) -> Result;
|
fn fmt(&self, f: &mut Formatter<'_>) -> Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -338,7 +338,6 @@ pub macro debug_assert_matches($($arg:tt)*) {
|
||||||
/// ```
|
/// ```
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[stable(feature = "matches_macro", since = "1.42.0")]
|
#[stable(feature = "matches_macro", since = "1.42.0")]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "matches_macro")]
|
|
||||||
macro_rules! matches {
|
macro_rules! matches {
|
||||||
($expression:expr, $(|)? $( $pattern:pat_param )|+ $( if $guard: expr )? $(,)?) => {
|
($expression:expr, $(|)? $( $pattern:pat_param )|+ $( if $guard: expr )? $(,)?) => {
|
||||||
match $expression {
|
match $expression {
|
||||||
|
@ -820,7 +819,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "compile_error_macro", since = "1.20.0")]
|
#[stable(feature = "compile_error_macro", since = "1.20.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "compile_error_macro")]
|
|
||||||
macro_rules! compile_error {
|
macro_rules! compile_error {
|
||||||
($msg:expr $(,)?) => {{ /* compiler built-in */ }};
|
($msg:expr $(,)?) => {{ /* compiler built-in */ }};
|
||||||
}
|
}
|
||||||
|
@ -944,7 +942,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "env_macro")]
|
|
||||||
macro_rules! env {
|
macro_rules! env {
|
||||||
($name:expr $(,)?) => {{ /* compiler built-in */ }};
|
($name:expr $(,)?) => {{ /* compiler built-in */ }};
|
||||||
($name:expr, $error_msg:expr $(,)?) => {{ /* compiler built-in */ }};
|
($name:expr, $error_msg:expr $(,)?) => {{ /* compiler built-in */ }};
|
||||||
|
@ -973,7 +970,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "option_env_macro")]
|
|
||||||
macro_rules! option_env {
|
macro_rules! option_env {
|
||||||
($name:expr $(,)?) => {{ /* compiler built-in */ }};
|
($name:expr $(,)?) => {{ /* compiler built-in */ }};
|
||||||
}
|
}
|
||||||
|
@ -1058,7 +1054,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "concat_macro")]
|
|
||||||
macro_rules! concat {
|
macro_rules! concat {
|
||||||
($($e:expr),* $(,)?) => {{ /* compiler built-in */ }};
|
($($e:expr),* $(,)?) => {{ /* compiler built-in */ }};
|
||||||
}
|
}
|
||||||
|
@ -1084,7 +1079,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "line_macro")]
|
|
||||||
macro_rules! line {
|
macro_rules! line {
|
||||||
() => {
|
() => {
|
||||||
/* compiler built-in */
|
/* compiler built-in */
|
||||||
|
@ -1124,7 +1118,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "column_macro")]
|
|
||||||
macro_rules! column {
|
macro_rules! column {
|
||||||
() => {
|
() => {
|
||||||
/* compiler built-in */
|
/* compiler built-in */
|
||||||
|
@ -1150,7 +1143,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "file_macro")]
|
|
||||||
macro_rules! file {
|
macro_rules! file {
|
||||||
() => {
|
() => {
|
||||||
/* compiler built-in */
|
/* compiler built-in */
|
||||||
|
@ -1175,7 +1167,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "stringify_macro")]
|
|
||||||
macro_rules! stringify {
|
macro_rules! stringify {
|
||||||
($($t:tt)*) => {
|
($($t:tt)*) => {
|
||||||
/* compiler built-in */
|
/* compiler built-in */
|
||||||
|
@ -1282,7 +1273,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "module_path_macro")]
|
|
||||||
macro_rules! module_path {
|
macro_rules! module_path {
|
||||||
() => {
|
() => {
|
||||||
/* compiler built-in */
|
/* compiler built-in */
|
||||||
|
@ -1316,7 +1306,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "cfg_macro")]
|
|
||||||
macro_rules! cfg {
|
macro_rules! cfg {
|
||||||
($($cfg:tt)*) => {
|
($($cfg:tt)*) => {
|
||||||
/* compiler built-in */
|
/* compiler built-in */
|
||||||
|
@ -1367,7 +1356,6 @@ pub(crate) mod builtin {
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_builtin_macro]
|
#[rustc_builtin_macro]
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "include_macro")]
|
|
||||||
macro_rules! include {
|
macro_rules! include {
|
||||||
($file:expr $(,)?) => {{ /* compiler built-in */ }};
|
($file:expr $(,)?) => {{ /* compiler built-in */ }};
|
||||||
}
|
}
|
||||||
|
|
|
@ -321,7 +321,6 @@ macro_rules! nonzero_unsigned_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let one = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let one = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -356,7 +355,6 @@ macro_rules! nonzero_unsigned_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let one = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let one = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -391,8 +389,8 @@ macro_rules! nonzero_unsigned_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(nonzero_ops)]
|
/// #![feature(nonzero_ops)]
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
|
||||||
///
|
///
|
||||||
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let one = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let one = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -420,7 +418,6 @@ macro_rules! nonzero_unsigned_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
||||||
|
@ -461,7 +458,6 @@ macro_rules! nonzero_unsigned_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(7).unwrap().ilog2(), 2);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(7).unwrap().ilog2(), 2);")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(8).unwrap().ilog2(), 3);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(8).unwrap().ilog2(), 3);")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(9).unwrap().ilog2(), 3);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(9).unwrap().ilog2(), 3);")]
|
||||||
|
@ -486,7 +482,6 @@ macro_rules! nonzero_unsigned_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(99).unwrap().ilog10(), 1);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(99).unwrap().ilog10(), 1);")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(100).unwrap().ilog10(), 2);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(100).unwrap().ilog10(), 2);")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(101).unwrap().ilog10(), 2);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::new(101).unwrap().ilog10(), 2);")]
|
||||||
|
@ -526,7 +521,6 @@ macro_rules! nonzero_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -556,7 +550,6 @@ macro_rules! nonzero_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -591,7 +584,6 @@ macro_rules! nonzero_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -626,7 +618,6 @@ macro_rules! nonzero_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -662,7 +653,6 @@ macro_rules! nonzero_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
#[doc = concat!("let pos = ", stringify!($Ty), "::new(1)?;")]
|
||||||
|
@ -905,7 +895,6 @@ macro_rules! nonzero_unsigned_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
||||||
|
@ -941,7 +930,6 @@ macro_rules! nonzero_unsigned_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
||||||
|
@ -986,8 +974,8 @@ macro_rules! nonzero_unsigned_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(nonzero_ops)]
|
/// #![feature(nonzero_ops)]
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
|
||||||
///
|
///
|
||||||
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
#[doc = concat!("let two = ", stringify!($Ty), "::new(2)?;")]
|
||||||
|
@ -1014,7 +1002,6 @@ macro_rules! nonzero_unsigned_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let three = ", stringify!($Ty), "::new(3)?;")]
|
#[doc = concat!("let three = ", stringify!($Ty), "::new(3)?;")]
|
||||||
|
@ -1058,7 +1045,6 @@ macro_rules! nonzero_unsigned_signed_operations {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
///
|
|
||||||
/// # fn main() { test().unwrap(); }
|
/// # fn main() { test().unwrap(); }
|
||||||
/// # fn test() -> Option<()> {
|
/// # fn test() -> Option<()> {
|
||||||
#[doc = concat!("let three = ", stringify!($Ty), "::new(3)?;")]
|
#[doc = concat!("let three = ", stringify!($Ty), "::new(3)?;")]
|
||||||
|
@ -1162,8 +1148,8 @@ macro_rules! nonzero_min_max_unsigned {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(nonzero_min_max)]
|
/// #![feature(nonzero_min_max)]
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
|
||||||
///
|
///
|
||||||
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MIN.get(), 1", stringify!($Int), ");")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MIN.get(), 1", stringify!($Int), ");")]
|
||||||
/// ```
|
/// ```
|
||||||
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
||||||
|
@ -1177,8 +1163,8 @@ macro_rules! nonzero_min_max_unsigned {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(nonzero_min_max)]
|
/// #![feature(nonzero_min_max)]
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
|
||||||
///
|
///
|
||||||
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MAX.get(), ", stringify!($Int), "::MAX);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MAX.get(), ", stringify!($Int), "::MAX);")]
|
||||||
/// ```
|
/// ```
|
||||||
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
||||||
|
@ -1204,8 +1190,8 @@ macro_rules! nonzero_min_max_signed {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(nonzero_min_max)]
|
/// #![feature(nonzero_min_max)]
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
|
||||||
///
|
///
|
||||||
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MIN.get(), ", stringify!($Int), "::MIN);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MIN.get(), ", stringify!($Int), "::MIN);")]
|
||||||
/// ```
|
/// ```
|
||||||
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
||||||
|
@ -1223,8 +1209,8 @@ macro_rules! nonzero_min_max_signed {
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// #![feature(nonzero_min_max)]
|
/// #![feature(nonzero_min_max)]
|
||||||
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
|
||||||
///
|
///
|
||||||
|
#[doc = concat!("# use std::num::", stringify!($Ty), ";")]
|
||||||
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MAX.get(), ", stringify!($Int), "::MAX);")]
|
#[doc = concat!("assert_eq!(", stringify!($Ty), "::MAX.get(), ", stringify!($Int), "::MAX);")]
|
||||||
/// ```
|
/// ```
|
||||||
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
#[unstable(feature = "nonzero_min_max", issue = "89065")]
|
||||||
|
|
|
@ -57,7 +57,6 @@ use crate::marker::Tuple;
|
||||||
#[cfg(bootstrap)]
|
#[cfg(bootstrap)]
|
||||||
#[lang = "fn"]
|
#[lang = "fn"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_diagnostic_item = "Fn"]
|
|
||||||
#[rustc_paren_sugar]
|
#[rustc_paren_sugar]
|
||||||
#[rustc_on_unimplemented(
|
#[rustc_on_unimplemented(
|
||||||
on(
|
on(
|
||||||
|
@ -138,7 +137,6 @@ pub trait Fn<Args>: FnMut<Args> {
|
||||||
#[cfg(not(bootstrap))]
|
#[cfg(not(bootstrap))]
|
||||||
#[lang = "fn"]
|
#[lang = "fn"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_diagnostic_item = "Fn"]
|
|
||||||
#[rustc_paren_sugar]
|
#[rustc_paren_sugar]
|
||||||
#[rustc_on_unimplemented(
|
#[rustc_on_unimplemented(
|
||||||
on(
|
on(
|
||||||
|
@ -227,7 +225,6 @@ pub trait Fn<Args: Tuple>: FnMut<Args> {
|
||||||
#[cfg(bootstrap)]
|
#[cfg(bootstrap)]
|
||||||
#[lang = "fn_mut"]
|
#[lang = "fn_mut"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_diagnostic_item = "FnMut"]
|
|
||||||
#[rustc_paren_sugar]
|
#[rustc_paren_sugar]
|
||||||
#[rustc_on_unimplemented(
|
#[rustc_on_unimplemented(
|
||||||
on(
|
on(
|
||||||
|
@ -316,7 +313,6 @@ pub trait FnMut<Args>: FnOnce<Args> {
|
||||||
#[cfg(not(bootstrap))]
|
#[cfg(not(bootstrap))]
|
||||||
#[lang = "fn_mut"]
|
#[lang = "fn_mut"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_diagnostic_item = "FnMut"]
|
|
||||||
#[rustc_paren_sugar]
|
#[rustc_paren_sugar]
|
||||||
#[rustc_on_unimplemented(
|
#[rustc_on_unimplemented(
|
||||||
on(
|
on(
|
||||||
|
@ -397,7 +393,6 @@ pub trait FnMut<Args: Tuple>: FnOnce<Args> {
|
||||||
#[cfg(bootstrap)]
|
#[cfg(bootstrap)]
|
||||||
#[lang = "fn_once"]
|
#[lang = "fn_once"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_diagnostic_item = "FnOnce"]
|
|
||||||
#[rustc_paren_sugar]
|
#[rustc_paren_sugar]
|
||||||
#[rustc_on_unimplemented(
|
#[rustc_on_unimplemented(
|
||||||
on(
|
on(
|
||||||
|
@ -483,7 +478,6 @@ pub trait FnOnce<Args> {
|
||||||
#[cfg(not(bootstrap))]
|
#[cfg(not(bootstrap))]
|
||||||
#[lang = "fn_once"]
|
#[lang = "fn_once"]
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_diagnostic_item = "FnOnce"]
|
|
||||||
#[rustc_paren_sugar]
|
#[rustc_paren_sugar]
|
||||||
#[rustc_on_unimplemented(
|
#[rustc_on_unimplemented(
|
||||||
on(
|
on(
|
||||||
|
|
|
@ -80,7 +80,6 @@ pub macro unreachable_2015 {
|
||||||
#[doc(hidden)]
|
#[doc(hidden)]
|
||||||
#[unstable(feature = "edition_panic", issue = "none", reason = "use unreachable!() instead")]
|
#[unstable(feature = "edition_panic", issue = "none", reason = "use unreachable!() instead")]
|
||||||
#[allow_internal_unstable(core_panic)]
|
#[allow_internal_unstable(core_panic)]
|
||||||
#[rustc_diagnostic_item = "unreachable_2021_macro"]
|
|
||||||
#[rustc_macro_transparency = "semitransparent"]
|
#[rustc_macro_transparency = "semitransparent"]
|
||||||
pub macro unreachable_2021 {
|
pub macro unreachable_2021 {
|
||||||
() => (
|
() => (
|
||||||
|
|
|
@ -16,7 +16,7 @@ panic_unwind = { path = "../panic_unwind", optional = true }
|
||||||
panic_abort = { path = "../panic_abort" }
|
panic_abort = { path = "../panic_abort" }
|
||||||
core = { path = "../core" }
|
core = { path = "../core" }
|
||||||
libc = { version = "0.2.135", default-features = false, features = ['rustc-dep-of-std'] }
|
libc = { version = "0.2.135", default-features = false, features = ['rustc-dep-of-std'] }
|
||||||
compiler_builtins = { version = "0.1.73" }
|
compiler_builtins = { version = "0.1.82" }
|
||||||
profiler_builtins = { path = "../profiler_builtins", optional = true }
|
profiler_builtins = { path = "../profiler_builtins", optional = true }
|
||||||
unwind = { path = "../unwind" }
|
unwind = { path = "../unwind" }
|
||||||
hashbrown = { version = "0.12", default-features = false, features = ['rustc-dep-of-std'] }
|
hashbrown = { version = "0.12", default-features = false, features = ['rustc-dep-of-std'] }
|
||||||
|
|
|
@ -73,7 +73,6 @@ pub enum IpAddr {
|
||||||
/// assert!("0xcb.0x0.0x71.0x00".parse::<Ipv4Addr>().is_err()); // all octets are in hex
|
/// assert!("0xcb.0x0.0x71.0x00".parse::<Ipv4Addr>().is_err()); // all octets are in hex
|
||||||
/// ```
|
/// ```
|
||||||
#[derive(Copy, Clone, PartialEq, Eq, Hash)]
|
#[derive(Copy, Clone, PartialEq, Eq, Hash)]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "Ipv4Addr")]
|
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
pub struct Ipv4Addr {
|
pub struct Ipv4Addr {
|
||||||
octets: [u8; 4],
|
octets: [u8; 4],
|
||||||
|
@ -156,7 +155,6 @@ pub struct Ipv4Addr {
|
||||||
/// assert_eq!(localhost.is_loopback(), true);
|
/// assert_eq!(localhost.is_loopback(), true);
|
||||||
/// ```
|
/// ```
|
||||||
#[derive(Copy, Clone, PartialEq, Eq, Hash)]
|
#[derive(Copy, Clone, PartialEq, Eq, Hash)]
|
||||||
#[cfg_attr(not(test), rustc_diagnostic_item = "Ipv6Addr")]
|
|
||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
pub struct Ipv6Addr {
|
pub struct Ipv6Addr {
|
||||||
octets: [u8; 16],
|
octets: [u8; 16],
|
||||||
|
|
1041
src/ci/docker/scripts/fuchsia-test-runner.py
Normal file
1041
src/ci/docker/scripts/fuchsia-test-runner.py
Normal file
File diff suppressed because it is too large
Load diff
|
@ -641,8 +641,60 @@ available on the [Fuchsia devsite].
|
||||||
|
|
||||||
### Running the compiler test suite
|
### Running the compiler test suite
|
||||||
|
|
||||||
Running the Rust test suite on Fuchsia is [not currently supported], but work is
|
Pre-requisites for running the Rust test suite on Fuchsia are:
|
||||||
underway to enable it.
|
1. Checkout of Rust source.
|
||||||
|
1. Setup of `config-env.sh` and `config.toml` from "[Targeting Fuchsia with a compiler built from source](#targeting-fuchsia-with-a-compiler-built-from-source)".
|
||||||
|
1. Download of the Fuchsia SDK. Minimum supported SDK version is [9.20220726.1.1](https://chrome-infra-packages.appspot.com/p/fuchsia/sdk/core/linux-amd64/+/version:9.20220726.1.1)
|
||||||
|
|
||||||
|
Interfacing with the Fuchsia emulator is handled by our test runner script located
|
||||||
|
at `${RUST_SRC_PATH}/src/ci/docker/scripts/fuchsia-test-runner.py`.
|
||||||
|
|
||||||
|
We start by activating our Fuchsia test environment. From a terminal:
|
||||||
|
|
||||||
|
**Issue command from ${RUST_SRC_PATH}**
|
||||||
|
```sh
|
||||||
|
src/ci/docker/scripts/fuchsia-test-runner.py start
|
||||||
|
--rust .
|
||||||
|
--sdk ${SDK_PATH}
|
||||||
|
--target-arch {x64,arm64}
|
||||||
|
```
|
||||||
|
|
||||||
|
Next, for ease of commands, we copy `config-env.sh` and `config.toml` into our Rust source
|
||||||
|
code path, `${RUST_SRC_PATH}`.
|
||||||
|
|
||||||
|
From there, we utilize `x.py` to run our tests, using the test runner script to
|
||||||
|
run the tests on our emulator. To run the full `src/test/ui` test suite:
|
||||||
|
|
||||||
|
**Run from ${RUST_SRC_PATH}**
|
||||||
|
```sh
|
||||||
|
( \
|
||||||
|
source config-env.sh && \
|
||||||
|
./x.py \
|
||||||
|
--config config.toml \
|
||||||
|
--stage=2 \
|
||||||
|
test src/test/ui \
|
||||||
|
--target x86_64-fuchsia \
|
||||||
|
--run=always --jobs 1 \
|
||||||
|
--test-args --target-rustcflags -L \
|
||||||
|
--test-args --target-rustcflags ${SDK_PATH}/arch/{x64|arm64}/sysroot/lib \
|
||||||
|
--test-args --target-rustcflags -L \
|
||||||
|
--test-args --target-rustcflags ${SDK_PATH}/arch/{x64|arm64}/lib \
|
||||||
|
--test-args --target-rustcflags -Cpanic=abort \
|
||||||
|
--test-args --target-rustcflags -Zpanic_abort_tests \
|
||||||
|
--test-args --remote-test-client \
|
||||||
|
--test-args src/ci/docker/scripts/fuchsia-test-runner.py \
|
||||||
|
)
|
||||||
|
```
|
||||||
|
|
||||||
|
*Note: The test suite cannot be run in parallel at the moment, so `x.py`
|
||||||
|
must be run with `--jobs 1` to ensure only one test runs at a time.*
|
||||||
|
|
||||||
|
When finished, stop the test environment:
|
||||||
|
|
||||||
|
**Issue command from ${RUST_SRC_PATH}**
|
||||||
|
```sh
|
||||||
|
src/ci/docker/scripts/fuchsia-test-runner.py stop
|
||||||
|
```
|
||||||
|
|
||||||
## Debugging
|
## Debugging
|
||||||
|
|
||||||
|
|
|
@ -1262,10 +1262,6 @@ h3.variant {
|
||||||
margin-left: 24px;
|
margin-left: 24px;
|
||||||
}
|
}
|
||||||
|
|
||||||
:target > code, :target > .code-header {
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
:target {
|
:target {
|
||||||
padding-right: 3px;
|
padding-right: 3px;
|
||||||
background-color: var(--target-background-color);
|
background-color: var(--target-background-color);
|
||||||
|
|
|
@ -1491,6 +1491,7 @@ function initSearch(rawSearchIndex) {
|
||||||
const target = searchState.focusedByTab[searchState.currentTab] ||
|
const target = searchState.focusedByTab[searchState.currentTab] ||
|
||||||
document.querySelectorAll(".search-results.active a").item(0) ||
|
document.querySelectorAll(".search-results.active a").item(0) ||
|
||||||
document.querySelectorAll("#titles > button").item(searchState.currentTab);
|
document.querySelectorAll("#titles > button").item(searchState.currentTab);
|
||||||
|
searchState.focusedByTab[searchState.currentTab] = null;
|
||||||
if (target) {
|
if (target) {
|
||||||
target.focus();
|
target.focus();
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,9 +19,13 @@ impl StaticFile {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn minified(&self) -> Vec<u8> {
|
pub(crate) fn minified(&self) -> Vec<u8> {
|
||||||
if self.filename.ends_with(".css") {
|
let extension = match self.filename.extension() {
|
||||||
|
Some(e) => e,
|
||||||
|
None => return self.bytes.to_owned(),
|
||||||
|
};
|
||||||
|
if extension == "css" {
|
||||||
minifier::css::minify(str::from_utf8(self.bytes).unwrap()).unwrap().to_string().into()
|
minifier::css::minify(str::from_utf8(self.bytes).unwrap()).unwrap().to_string().into()
|
||||||
} else if self.filename.ends_with(".js") {
|
} else if extension == "js" {
|
||||||
minifier::js::minify(str::from_utf8(self.bytes).unwrap()).to_string().into()
|
minifier::js::minify(str::from_utf8(self.bytes).unwrap()).to_string().into()
|
||||||
} else {
|
} else {
|
||||||
self.bytes.to_owned()
|
self.bytes.to_owned()
|
||||||
|
|
28
src/test/rustdoc-gui/search-keyboard.goml
Normal file
28
src/test/rustdoc-gui/search-keyboard.goml
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
// Checks that the search tab results work correctly with function signature syntax
|
||||||
|
// First, try a search-by-name
|
||||||
|
goto: "file://" + |DOC_PATH| + "/test_docs/index.html"
|
||||||
|
write: (".search-input", "Foo")
|
||||||
|
// To be SURE that the search will be run.
|
||||||
|
press-key: 'Enter'
|
||||||
|
// Waiting for the search results to appear...
|
||||||
|
wait-for: "#titles"
|
||||||
|
|
||||||
|
// Now use the keyboard commands to switch to the third result.
|
||||||
|
press-key: "ArrowDown"
|
||||||
|
press-key: "ArrowDown"
|
||||||
|
press-key: "ArrowDown"
|
||||||
|
assert: ".search-results.active > a:focus:nth-of-type(3)"
|
||||||
|
|
||||||
|
// Now switch to the second tab, then back to the first one, then arrow back up.
|
||||||
|
press-key: "ArrowRight"
|
||||||
|
assert: ".search-results.active:nth-of-type(2) > a:focus:nth-of-type(1)"
|
||||||
|
press-key: "ArrowLeft"
|
||||||
|
assert: ".search-results.active:nth-of-type(1) > a:focus:nth-of-type(3)"
|
||||||
|
press-key: "ArrowUp"
|
||||||
|
assert: ".search-results.active > a:focus:nth-of-type(2)"
|
||||||
|
press-key: "ArrowUp"
|
||||||
|
assert: ".search-results.active > a:focus:nth-of-type(1)"
|
||||||
|
press-key: "ArrowUp"
|
||||||
|
assert: ".search-input:focus"
|
||||||
|
press-key: "ArrowDown"
|
||||||
|
assert: ".search-results.active > a:focus:nth-of-type(1)"
|
13
src/test/rustdoc/issue-102154.rs
Normal file
13
src/test/rustdoc/issue-102154.rs
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
trait A<Y, N> {
|
||||||
|
type B;
|
||||||
|
}
|
||||||
|
type MaybeBox<T> = <T as A<T, Box<T>>>::B;
|
||||||
|
struct P {
|
||||||
|
t: MaybeBox<P>
|
||||||
|
}
|
||||||
|
impl<Y, N> A<Y, N> for P {
|
||||||
|
type B = N;
|
||||||
|
}
|
||||||
|
fn main() {
|
||||||
|
let t: MaybeBox<P>;
|
||||||
|
}
|
4
src/test/ui/suggestions/dont-suggest-ufcs-for-const.rs
Normal file
4
src/test/ui/suggestions/dont-suggest-ufcs-for-const.rs
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
fn main() {
|
||||||
|
1_u32.MAX();
|
||||||
|
//~^ ERROR no method named `MAX` found for type `u32` in the current scope
|
||||||
|
}
|
15
src/test/ui/suggestions/dont-suggest-ufcs-for-const.stderr
Normal file
15
src/test/ui/suggestions/dont-suggest-ufcs-for-const.stderr
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
error[E0599]: no method named `MAX` found for type `u32` in the current scope
|
||||||
|
--> $DIR/dont-suggest-ufcs-for-const.rs:2:11
|
||||||
|
|
|
||||||
|
LL | 1_u32.MAX();
|
||||||
|
| ------^^^--
|
||||||
|
| | |
|
||||||
|
| | this is an associated function, not a method
|
||||||
|
| help: use associated function syntax instead: `u32::MAX()`
|
||||||
|
|
|
||||||
|
= note: found the following associated functions; to be used as methods, functions must have a `self` parameter
|
||||||
|
= note: the candidate is defined in an impl for the type `u32`
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0599`.
|
15
src/test/ui/suggestions/suggest-assoc-fn-call-deref.fixed
Normal file
15
src/test/ui/suggestions/suggest-assoc-fn-call-deref.fixed
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
// run-rustfix
|
||||||
|
|
||||||
|
#![allow(unused)]
|
||||||
|
|
||||||
|
struct Foo<T>(T);
|
||||||
|
|
||||||
|
impl<T> Foo<T> {
|
||||||
|
fn test() -> i32 { 1 }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let x = Box::new(Foo(1i32));
|
||||||
|
Foo::<i32>::test();
|
||||||
|
//~^ ERROR no method named `test` found for struct `Box<Foo<i32>>` in the current scope
|
||||||
|
}
|
15
src/test/ui/suggestions/suggest-assoc-fn-call-deref.rs
Normal file
15
src/test/ui/suggestions/suggest-assoc-fn-call-deref.rs
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
// run-rustfix
|
||||||
|
|
||||||
|
#![allow(unused)]
|
||||||
|
|
||||||
|
struct Foo<T>(T);
|
||||||
|
|
||||||
|
impl<T> Foo<T> {
|
||||||
|
fn test() -> i32 { 1 }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let x = Box::new(Foo(1i32));
|
||||||
|
x.test();
|
||||||
|
//~^ ERROR no method named `test` found for struct `Box<Foo<i32>>` in the current scope
|
||||||
|
}
|
19
src/test/ui/suggestions/suggest-assoc-fn-call-deref.stderr
Normal file
19
src/test/ui/suggestions/suggest-assoc-fn-call-deref.stderr
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
error[E0599]: no method named `test` found for struct `Box<Foo<i32>>` in the current scope
|
||||||
|
--> $DIR/suggest-assoc-fn-call-deref.rs:13:7
|
||||||
|
|
|
||||||
|
LL | x.test();
|
||||||
|
| --^^^^--
|
||||||
|
| | |
|
||||||
|
| | this is an associated function, not a method
|
||||||
|
| help: use associated function syntax instead: `Foo::<i32>::test()`
|
||||||
|
|
|
||||||
|
= note: found the following associated functions; to be used as methods, functions must have a `self` parameter
|
||||||
|
note: the candidate is defined in an impl for the type `Foo<T>`
|
||||||
|
--> $DIR/suggest-assoc-fn-call-deref.rs:8:5
|
||||||
|
|
|
||||||
|
LL | fn test() -> i32 { 1 }
|
||||||
|
| ^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0599`.
|
|
@ -199,12 +199,12 @@ pub fn first_node_in_macro(cx: &LateContext<'_>, node: &impl HirNode) -> Option<
|
||||||
pub fn is_panic(cx: &LateContext<'_>, def_id: DefId) -> bool {
|
pub fn is_panic(cx: &LateContext<'_>, def_id: DefId) -> bool {
|
||||||
let Some(name) = cx.tcx.get_diagnostic_name(def_id) else { return false };
|
let Some(name) = cx.tcx.get_diagnostic_name(def_id) else { return false };
|
||||||
matches!(
|
matches!(
|
||||||
name.as_str(),
|
name,
|
||||||
"core_panic_macro"
|
sym::core_panic_macro
|
||||||
| "std_panic_macro"
|
| sym::std_panic_macro
|
||||||
| "core_panic_2015_macro"
|
| sym::core_panic_2015_macro
|
||||||
| "std_panic_2015_macro"
|
| sym::std_panic_2015_macro
|
||||||
| "core_panic_2021_macro"
|
| sym::core_panic_2021_macro
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue