Deny internal lints on librustc_mir
This commit is contained in:
parent
d2bc99135f
commit
e4b87f5edb
@ -223,7 +223,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
Some(ref name) => format!("`{}`", name),
|
Some(ref name) => format!("`{}`", name),
|
||||||
None => "value".to_owned(),
|
None => "value".to_owned(),
|
||||||
};
|
};
|
||||||
if let ty::TyKind::Param(param_ty) = ty.sty {
|
if let ty::Param(param_ty) = ty.sty {
|
||||||
let tcx = self.infcx.tcx;
|
let tcx = self.infcx.tcx;
|
||||||
let generics = tcx.generics_of(self.mir_def_id);
|
let generics = tcx.generics_of(self.mir_def_id);
|
||||||
let def_id = generics.type_param(¶m_ty, tcx).def_id;
|
let def_id = generics.type_param(¶m_ty, tcx).def_id;
|
||||||
@ -1529,7 +1529,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
if let TerminatorKind::Call {
|
if let TerminatorKind::Call {
|
||||||
func: Operand::Constant(box Constant {
|
func: Operand::Constant(box Constant {
|
||||||
literal: ty::Const {
|
literal: ty::Const {
|
||||||
ty: &ty::TyS { sty: ty::TyKind::FnDef(id, _), .. },
|
ty: &ty::TyS { sty: ty::FnDef(id, _), .. },
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
..
|
..
|
||||||
@ -1547,7 +1547,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
};
|
};
|
||||||
|
|
||||||
debug!("add_moved_or_invoked_closure_note: closure={:?}", closure);
|
debug!("add_moved_or_invoked_closure_note: closure={:?}", closure);
|
||||||
if let ty::TyKind::Closure(did, _) = self.mir.local_decls[closure].ty.sty {
|
if let ty::Closure(did, _) = self.mir.local_decls[closure].ty.sty {
|
||||||
let hir_id = self.infcx.tcx.hir().as_local_hir_id(did).unwrap();
|
let hir_id = self.infcx.tcx.hir().as_local_hir_id(did).unwrap();
|
||||||
|
|
||||||
if let Some((span, name)) = self.infcx.tcx.typeck_tables_of(did)
|
if let Some((span, name)) = self.infcx.tcx.typeck_tables_of(did)
|
||||||
@ -1570,7 +1570,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
|
|
||||||
// Check if we are just moving a closure after it has been invoked.
|
// Check if we are just moving a closure after it has been invoked.
|
||||||
if let Some(target) = target {
|
if let Some(target) = target {
|
||||||
if let ty::TyKind::Closure(did, _) = self.mir.local_decls[target].ty.sty {
|
if let ty::Closure(did, _) = self.mir.local_decls[target].ty.sty {
|
||||||
let hir_id = self.infcx.tcx.hir().as_local_hir_id(did).unwrap();
|
let hir_id = self.infcx.tcx.hir().as_local_hir_id(did).unwrap();
|
||||||
|
|
||||||
if let Some((span, name)) = self.infcx.tcx.typeck_tables_of(did)
|
if let Some((span, name)) = self.infcx.tcx.typeck_tables_of(did)
|
||||||
@ -1919,7 +1919,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
} else {
|
} else {
|
||||||
let ty = self.infcx.tcx.type_of(self.mir_def_id);
|
let ty = self.infcx.tcx.type_of(self.mir_def_id);
|
||||||
match ty.sty {
|
match ty.sty {
|
||||||
ty::TyKind::FnDef(_, _) | ty::TyKind::FnPtr(_) => self.annotate_fn_sig(
|
ty::FnDef(_, _) | ty::FnPtr(_) => self.annotate_fn_sig(
|
||||||
self.mir_def_id,
|
self.mir_def_id,
|
||||||
self.infcx.tcx.fn_sig(self.mir_def_id),
|
self.infcx.tcx.fn_sig(self.mir_def_id),
|
||||||
),
|
),
|
||||||
@ -2164,12 +2164,12 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
// anything.
|
// anything.
|
||||||
let return_ty = sig.output();
|
let return_ty = sig.output();
|
||||||
match return_ty.skip_binder().sty {
|
match return_ty.skip_binder().sty {
|
||||||
ty::TyKind::Ref(return_region, _, _) if return_region.has_name() && !is_closure => {
|
ty::Ref(return_region, _, _) if return_region.has_name() && !is_closure => {
|
||||||
// This is case 1 from above, return type is a named reference so we need to
|
// This is case 1 from above, return type is a named reference so we need to
|
||||||
// search for relevant arguments.
|
// search for relevant arguments.
|
||||||
let mut arguments = Vec::new();
|
let mut arguments = Vec::new();
|
||||||
for (index, argument) in sig.inputs().skip_binder().iter().enumerate() {
|
for (index, argument) in sig.inputs().skip_binder().iter().enumerate() {
|
||||||
if let ty::TyKind::Ref(argument_region, _, _) = argument.sty {
|
if let ty::Ref(argument_region, _, _) = argument.sty {
|
||||||
if argument_region == return_region {
|
if argument_region == return_region {
|
||||||
// Need to use the `rustc::ty` types to compare against the
|
// Need to use the `rustc::ty` types to compare against the
|
||||||
// `return_region`. Then use the `rustc::hir` type to get only
|
// `return_region`. Then use the `rustc::hir` type to get only
|
||||||
@ -2206,7 +2206,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
return_span,
|
return_span,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
ty::TyKind::Ref(_, _, _) if is_closure => {
|
ty::Ref(_, _, _) if is_closure => {
|
||||||
// This is case 2 from above but only for closures, return type is anonymous
|
// This is case 2 from above but only for closures, return type is anonymous
|
||||||
// reference so we select
|
// reference so we select
|
||||||
// the first argument.
|
// the first argument.
|
||||||
@ -2215,9 +2215,9 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
|
|
||||||
// Closure arguments are wrapped in a tuple, so we need to get the first
|
// Closure arguments are wrapped in a tuple, so we need to get the first
|
||||||
// from that.
|
// from that.
|
||||||
if let ty::TyKind::Tuple(elems) = argument_ty.sty {
|
if let ty::Tuple(elems) = argument_ty.sty {
|
||||||
let argument_ty = elems.first()?;
|
let argument_ty = elems.first()?;
|
||||||
if let ty::TyKind::Ref(_, _, _) = argument_ty.sty {
|
if let ty::Ref(_, _, _) = argument_ty.sty {
|
||||||
return Some(AnnotatedBorrowFnSignature::Closure {
|
return Some(AnnotatedBorrowFnSignature::Closure {
|
||||||
argument_ty,
|
argument_ty,
|
||||||
argument_span,
|
argument_span,
|
||||||
@ -2227,7 +2227,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
|
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
ty::TyKind::Ref(_, _, _) => {
|
ty::Ref(_, _, _) => {
|
||||||
// This is also case 2 from above but for functions, return type is still an
|
// This is also case 2 from above but for functions, return type is still an
|
||||||
// anonymous reference so we select the first argument.
|
// anonymous reference so we select the first argument.
|
||||||
let argument_span = fn_decl.inputs.first()?.span;
|
let argument_span = fn_decl.inputs.first()?.span;
|
||||||
@ -2238,7 +2238,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
|
|
||||||
// We expect the first argument to be a reference.
|
// We expect the first argument to be a reference.
|
||||||
match argument_ty.sty {
|
match argument_ty.sty {
|
||||||
ty::TyKind::Ref(_, _, _) => {}
|
ty::Ref(_, _, _) => {}
|
||||||
_ => return None,
|
_ => return None,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2366,8 +2366,8 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
// this by hooking into the pretty printer and telling it to label the
|
// this by hooking into the pretty printer and telling it to label the
|
||||||
// lifetimes without names with the value `'0`.
|
// lifetimes without names with the value `'0`.
|
||||||
match ty.sty {
|
match ty.sty {
|
||||||
ty::TyKind::Ref(ty::RegionKind::ReLateBound(_, br), _, _)
|
ty::Ref(ty::RegionKind::ReLateBound(_, br), _, _)
|
||||||
| ty::TyKind::Ref(
|
| ty::Ref(
|
||||||
ty::RegionKind::RePlaceholder(ty::PlaceholderRegion { name: br, .. }),
|
ty::RegionKind::RePlaceholder(ty::PlaceholderRegion { name: br, .. }),
|
||||||
_,
|
_,
|
||||||
_,
|
_,
|
||||||
@ -2386,7 +2386,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
let mut printer = ty::print::FmtPrinter::new(self.infcx.tcx, &mut s, Namespace::TypeNS);
|
let mut printer = ty::print::FmtPrinter::new(self.infcx.tcx, &mut s, Namespace::TypeNS);
|
||||||
|
|
||||||
let region = match ty.sty {
|
let region = match ty.sty {
|
||||||
ty::TyKind::Ref(region, _, _) => {
|
ty::Ref(region, _, _) => {
|
||||||
match region {
|
match region {
|
||||||
ty::RegionKind::ReLateBound(_, br)
|
ty::RegionKind::ReLateBound(_, br)
|
||||||
| ty::RegionKind::RePlaceholder(ty::PlaceholderRegion { name: br, .. }) => {
|
| ty::RegionKind::RePlaceholder(ty::PlaceholderRegion { name: br, .. }) => {
|
||||||
|
@ -1741,7 +1741,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
// no move out from an earlier location) then this is an attempt at initialization
|
// no move out from an earlier location) then this is an attempt at initialization
|
||||||
// of the union - we should error in that case.
|
// of the union - we should error in that case.
|
||||||
let tcx = this.infcx.tcx;
|
let tcx = this.infcx.tcx;
|
||||||
if let ty::TyKind::Adt(def, _) = base.ty(this.mir, tcx).ty.sty {
|
if let ty::Adt(def, _) = base.ty(this.mir, tcx).ty.sty {
|
||||||
if def.is_union() {
|
if def.is_union() {
|
||||||
if this.move_data.path_map[mpi].iter().any(|moi| {
|
if this.move_data.path_map[mpi].iter().any(|moi| {
|
||||||
this.move_data.moves[*moi].source.is_predecessor_of(
|
this.move_data.moves[*moi].source.is_predecessor_of(
|
||||||
|
@ -532,7 +532,7 @@ impl<'a, 'gcx, 'tcx> MirBorrowckCtxt<'a, 'gcx, 'tcx> {
|
|||||||
if let StatementKind::Assign(_, box Rvalue::Ref(_, _, source)) = &stmt.kind {
|
if let StatementKind::Assign(_, box Rvalue::Ref(_, _, source)) = &stmt.kind {
|
||||||
let ty = source.ty(self.mir, self.infcx.tcx).ty;
|
let ty = source.ty(self.mir, self.infcx.tcx).ty;
|
||||||
let ty = match ty.sty {
|
let ty = match ty.sty {
|
||||||
ty::TyKind::Ref(_, ty, _) => ty,
|
ty::Ref(_, ty, _) => ty,
|
||||||
_ => ty,
|
_ => ty,
|
||||||
};
|
};
|
||||||
debug!("borrowed_content_source: ty={:?}", ty);
|
debug!("borrowed_content_source: ty={:?}", ty);
|
||||||
@ -557,7 +557,7 @@ impl<'a, 'gcx, 'tcx> MirBorrowckCtxt<'a, 'gcx, 'tcx> {
|
|||||||
|
|
||||||
let ty = source.ty(self.mir, self.infcx.tcx).ty;
|
let ty = source.ty(self.mir, self.infcx.tcx).ty;
|
||||||
let ty = match ty.sty {
|
let ty = match ty.sty {
|
||||||
ty::TyKind::Ref(_, ty, _) => ty,
|
ty::Ref(_, ty, _) => ty,
|
||||||
_ => ty,
|
_ => ty,
|
||||||
};
|
};
|
||||||
debug!("borrowed_content_source: ty={:?}", ty);
|
debug!("borrowed_content_source: ty={:?}", ty);
|
||||||
|
@ -5,7 +5,7 @@ use rustc::mir::{
|
|||||||
Mutability, Operand, Place, PlaceBase, Projection, ProjectionElem, Static, StaticKind,
|
Mutability, Operand, Place, PlaceBase, Projection, ProjectionElem, Static, StaticKind,
|
||||||
};
|
};
|
||||||
use rustc::mir::{Terminator, TerminatorKind};
|
use rustc::mir::{Terminator, TerminatorKind};
|
||||||
use rustc::ty::{self, Const, DefIdTree, TyS, TyKind, TyCtxt};
|
use rustc::ty::{self, Const, DefIdTree, TyS, TyCtxt};
|
||||||
use rustc_data_structures::indexed_vec::Idx;
|
use rustc_data_structures::indexed_vec::Idx;
|
||||||
use syntax_pos::Span;
|
use syntax_pos::Span;
|
||||||
use syntax_pos::symbol::keywords;
|
use syntax_pos::symbol::keywords;
|
||||||
@ -261,7 +261,7 @@ impl<'a, 'gcx, 'tcx> MirBorrowckCtxt<'a, 'gcx, 'tcx> {
|
|||||||
// Otherwise, check if the name is the self kewyord - in which case
|
// Otherwise, check if the name is the self kewyord - in which case
|
||||||
// we have an explicit self. Do the same thing in this case and check
|
// we have an explicit self. Do the same thing in this case and check
|
||||||
// for a `self: &mut Self` to suggest removing the `&mut`.
|
// for a `self: &mut Self` to suggest removing the `&mut`.
|
||||||
if let ty::TyKind::Ref(
|
if let ty::Ref(
|
||||||
_, _, hir::Mutability::MutMutable
|
_, _, hir::Mutability::MutMutable
|
||||||
) = local_decl.ty.sty {
|
) = local_decl.ty.sty {
|
||||||
true
|
true
|
||||||
@ -476,7 +476,7 @@ impl<'a, 'gcx, 'tcx> MirBorrowckCtxt<'a, 'gcx, 'tcx> {
|
|||||||
func: Operand::Constant(box Constant {
|
func: Operand::Constant(box Constant {
|
||||||
literal: Const {
|
literal: Const {
|
||||||
ty: &TyS {
|
ty: &TyS {
|
||||||
sty: TyKind::FnDef(id, substs),
|
sty: ty::FnDef(id, substs),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
..
|
..
|
||||||
@ -633,8 +633,8 @@ fn annotate_struct_field(
|
|||||||
field: &mir::Field,
|
field: &mir::Field,
|
||||||
) -> Option<(Span, String)> {
|
) -> Option<(Span, String)> {
|
||||||
// Expect our local to be a reference to a struct of some kind.
|
// Expect our local to be a reference to a struct of some kind.
|
||||||
if let ty::TyKind::Ref(_, ty, _) = ty.sty {
|
if let ty::Ref(_, ty, _) = ty.sty {
|
||||||
if let ty::TyKind::Adt(def, _) = ty.sty {
|
if let ty::Adt(def, _) = ty.sty {
|
||||||
let field = def.all_fields().nth(field.index())?;
|
let field = def.all_fields().nth(field.index())?;
|
||||||
// Use the HIR types to construct the diagnostic message.
|
// Use the HIR types to construct the diagnostic message.
|
||||||
let hir_id = tcx.hir().as_local_hir_id(field.did)?;
|
let hir_id = tcx.hir().as_local_hir_id(field.did)?;
|
||||||
|
@ -589,7 +589,7 @@ impl<'cx, 'gcx, 'tcx> MirBorrowckCtxt<'cx, 'gcx, 'tcx> {
|
|||||||
// Check the type for a trait object.
|
// Check the type for a trait object.
|
||||||
return match ty.sty {
|
return match ty.sty {
|
||||||
// `&dyn Trait`
|
// `&dyn Trait`
|
||||||
ty::TyKind::Ref(_, ty, _) if ty.is_trait() => true,
|
ty::Ref(_, ty, _) if ty.is_trait() => true,
|
||||||
// `Box<dyn Trait>`
|
// `Box<dyn Trait>`
|
||||||
_ if ty.is_box() && ty.boxed_ty().is_trait() => true,
|
_ if ty.is_box() && ty.boxed_ty().is_trait() => true,
|
||||||
// `dyn Trait`
|
// `dyn Trait`
|
||||||
|
@ -583,7 +583,7 @@ impl<'tcx> RegionInferenceContext<'tcx> {
|
|||||||
(self.to_error_region(fr), self.to_error_region(outlived_fr))
|
(self.to_error_region(fr), self.to_error_region(outlived_fr))
|
||||||
{
|
{
|
||||||
if let Some(ty::TyS {
|
if let Some(ty::TyS {
|
||||||
sty: ty::TyKind::Opaque(did, substs),
|
sty: ty::Opaque(did, substs),
|
||||||
..
|
..
|
||||||
}) = infcx
|
}) = infcx
|
||||||
.tcx
|
.tcx
|
||||||
|
@ -39,7 +39,7 @@ use rustc::traits::{ObligationCause, PredicateObligations};
|
|||||||
use rustc::ty::fold::TypeFoldable;
|
use rustc::ty::fold::TypeFoldable;
|
||||||
use rustc::ty::subst::{Subst, SubstsRef, UnpackedKind, UserSubsts};
|
use rustc::ty::subst::{Subst, SubstsRef, UnpackedKind, UserSubsts};
|
||||||
use rustc::ty::{
|
use rustc::ty::{
|
||||||
self, RegionVid, ToPolyTraitRef, Ty, TyCtxt, TyKind, UserType,
|
self, RegionVid, ToPolyTraitRef, Ty, TyCtxt, UserType,
|
||||||
CanonicalUserTypeAnnotation, CanonicalUserTypeAnnotations,
|
CanonicalUserTypeAnnotation, CanonicalUserTypeAnnotations,
|
||||||
UserTypeAnnotationIndex,
|
UserTypeAnnotationIndex,
|
||||||
};
|
};
|
||||||
@ -746,7 +746,7 @@ impl<'a, 'b, 'gcx, 'tcx> TypeVerifier<'a, 'b, 'gcx, 'tcx> {
|
|||||||
let (variant, substs) = match base_ty {
|
let (variant, substs) = match base_ty {
|
||||||
PlaceTy { ty, variant_index: Some(variant_index) } => {
|
PlaceTy { ty, variant_index: Some(variant_index) } => {
|
||||||
match ty.sty {
|
match ty.sty {
|
||||||
ty::TyKind::Adt(adt_def, substs) => (&adt_def.variants[variant_index], substs),
|
ty::Adt(adt_def, substs) => (&adt_def.variants[variant_index], substs),
|
||||||
_ => bug!("can't have downcast of non-adt type"),
|
_ => bug!("can't have downcast of non-adt type"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1136,7 +1136,7 @@ impl<'a, 'gcx, 'tcx> TypeChecker<'a, 'gcx, 'tcx> {
|
|||||||
category: ConstraintCategory,
|
category: ConstraintCategory,
|
||||||
) -> Fallible<()> {
|
) -> Fallible<()> {
|
||||||
if let Err(terr) = self.sub_types(sub, sup, locations, category) {
|
if let Err(terr) = self.sub_types(sub, sup, locations, category) {
|
||||||
if let TyKind::Opaque(..) = sup.sty {
|
if let ty::Opaque(..) = sup.sty {
|
||||||
// When you have `let x: impl Foo = ...` in a closure,
|
// When you have `let x: impl Foo = ...` in a closure,
|
||||||
// the resulting inferend values are stored with the
|
// the resulting inferend values are stored with the
|
||||||
// def-id of the base function.
|
// def-id of the base function.
|
||||||
@ -1389,7 +1389,7 @@ impl<'a, 'gcx, 'tcx> TypeChecker<'a, 'gcx, 'tcx> {
|
|||||||
} => {
|
} => {
|
||||||
let place_type = place.ty(mir, tcx).ty;
|
let place_type = place.ty(mir, tcx).ty;
|
||||||
let adt = match place_type.sty {
|
let adt = match place_type.sty {
|
||||||
TyKind::Adt(adt, _) if adt.is_enum() => adt,
|
ty::Adt(adt, _) if adt.is_enum() => adt,
|
||||||
_ => {
|
_ => {
|
||||||
span_bug!(
|
span_bug!(
|
||||||
stmt.source_info.span,
|
stmt.source_info.span,
|
||||||
|
@ -425,7 +425,7 @@ impl<'b, 'a, 'gcx, 'tcx> Gatherer<'b, 'a, 'gcx, 'tcx> {
|
|||||||
base,
|
base,
|
||||||
elem: ProjectionElem::Field(_, _),
|
elem: ProjectionElem::Field(_, _),
|
||||||
}) if match base.ty(self.builder.mir, self.builder.tcx).ty.sty {
|
}) if match base.ty(self.builder.mir, self.builder.tcx).ty.sty {
|
||||||
ty::TyKind::Adt(def, _) if def.is_union() => true,
|
ty::Adt(def, _) if def.is_union() => true,
|
||||||
_ => false,
|
_ => false,
|
||||||
} => base,
|
} => base,
|
||||||
// Otherwise, lookup the place.
|
// Otherwise, lookup the place.
|
||||||
|
@ -1754,7 +1754,7 @@ fn specialize<'p, 'a: 'p, 'tcx: 'a>(
|
|||||||
// they should be pointing to memory is when they are subslices of nonzero
|
// they should be pointing to memory is when they are subslices of nonzero
|
||||||
// slices
|
// slices
|
||||||
let (opt_ptr, n, ty) = match value.ty.sty {
|
let (opt_ptr, n, ty) = match value.ty.sty {
|
||||||
ty::TyKind::Array(t, n) => {
|
ty::Array(t, n) => {
|
||||||
match value.val {
|
match value.val {
|
||||||
ConstValue::ByRef(ptr, alloc) => (
|
ConstValue::ByRef(ptr, alloc) => (
|
||||||
Some((ptr, alloc)),
|
Some((ptr, alloc)),
|
||||||
@ -1767,7 +1767,7 @@ fn specialize<'p, 'a: 'p, 'tcx: 'a>(
|
|||||||
),
|
),
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ty::TyKind::Slice(t) => {
|
ty::Slice(t) => {
|
||||||
match value.val {
|
match value.val {
|
||||||
ConstValue::Slice(ptr, n) => (
|
ConstValue::Slice(ptr, n) => (
|
||||||
ptr.to_ptr().ok().map(|ptr| (
|
ptr.to_ptr().ok().map(|ptr| (
|
||||||
|
@ -10,7 +10,7 @@ use rustc::middle::expr_use_visitor as euv;
|
|||||||
use rustc::middle::mem_categorization::cmt_;
|
use rustc::middle::mem_categorization::cmt_;
|
||||||
use rustc::middle::region;
|
use rustc::middle::region;
|
||||||
use rustc::session::Session;
|
use rustc::session::Session;
|
||||||
use rustc::ty::{self, Ty, TyCtxt, TyKind};
|
use rustc::ty::{self, Ty, TyCtxt};
|
||||||
use rustc::ty::subst::{InternalSubsts, SubstsRef};
|
use rustc::ty::subst::{InternalSubsts, SubstsRef};
|
||||||
use rustc::lint;
|
use rustc::lint;
|
||||||
use rustc_errors::{Applicability, DiagnosticBuilder};
|
use rustc_errors::{Applicability, DiagnosticBuilder};
|
||||||
@ -481,7 +481,7 @@ fn check_exhaustive<'p, 'a: 'p, 'tcx: 'a>(
|
|||||||
}
|
}
|
||||||
let patterns = witnesses.iter().map(|p| (**p).clone()).collect::<Vec<Pattern<'_>>>();
|
let patterns = witnesses.iter().map(|p| (**p).clone()).collect::<Vec<Pattern<'_>>>();
|
||||||
if patterns.len() < 4 {
|
if patterns.len() < 4 {
|
||||||
for sp in maybe_point_at_variant(cx, &scrut_ty.sty, patterns.as_slice()) {
|
for sp in maybe_point_at_variant(cx, scrut_ty, patterns.as_slice()) {
|
||||||
err.span_label(sp, "not covered");
|
err.span_label(sp, "not covered");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -498,11 +498,11 @@ fn check_exhaustive<'p, 'a: 'p, 'tcx: 'a>(
|
|||||||
|
|
||||||
fn maybe_point_at_variant(
|
fn maybe_point_at_variant(
|
||||||
cx: &mut MatchCheckCtxt<'a, 'tcx>,
|
cx: &mut MatchCheckCtxt<'a, 'tcx>,
|
||||||
sty: &TyKind<'tcx>,
|
ty: Ty<'tcx>,
|
||||||
patterns: &[Pattern<'_>],
|
patterns: &[Pattern<'_>],
|
||||||
) -> Vec<Span> {
|
) -> Vec<Span> {
|
||||||
let mut covered = vec![];
|
let mut covered = vec![];
|
||||||
if let ty::Adt(def, _) = sty {
|
if let ty::Adt(def, _) = ty.sty {
|
||||||
// Don't point at variants that have already been covered due to other patterns to avoid
|
// Don't point at variants that have already been covered due to other patterns to avoid
|
||||||
// visual clutter
|
// visual clutter
|
||||||
for pattern in patterns {
|
for pattern in patterns {
|
||||||
@ -518,7 +518,7 @@ fn maybe_point_at_variant(
|
|||||||
.map(|field_pattern| field_pattern.pattern.clone())
|
.map(|field_pattern| field_pattern.pattern.clone())
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
covered.extend(
|
covered.extend(
|
||||||
maybe_point_at_variant(cx, sty, subpatterns.as_slice()),
|
maybe_point_at_variant(cx, ty, subpatterns.as_slice()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -526,7 +526,7 @@ fn maybe_point_at_variant(
|
|||||||
let subpatterns = subpatterns.iter()
|
let subpatterns = subpatterns.iter()
|
||||||
.map(|field_pattern| field_pattern.pattern.clone())
|
.map(|field_pattern| field_pattern.pattern.clone())
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
covered.extend(maybe_point_at_variant(cx, sty, subpatterns.as_slice()));
|
covered.extend(maybe_point_at_variant(cx, ty, subpatterns.as_slice()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,6 +28,7 @@ Rust MIR: a lowered representation of Rust. Also: an experiment!
|
|||||||
#![recursion_limit="256"]
|
#![recursion_limit="256"]
|
||||||
|
|
||||||
#![deny(rust_2018_idioms)]
|
#![deny(rust_2018_idioms)]
|
||||||
|
#![cfg_attr(not(stage0), deny(internal))]
|
||||||
#![allow(explicit_outlives_requirements)]
|
#![allow(explicit_outlives_requirements)]
|
||||||
|
|
||||||
#[macro_use] extern crate log;
|
#[macro_use] extern crate log;
|
||||||
|
@ -4,7 +4,7 @@ use rustc::hir::intravisit::FnKind;
|
|||||||
use rustc::hir::map::blocks::FnLikeNode;
|
use rustc::hir::map::blocks::FnLikeNode;
|
||||||
use rustc::lint::builtin::UNCONDITIONAL_RECURSION;
|
use rustc::lint::builtin::UNCONDITIONAL_RECURSION;
|
||||||
use rustc::mir::{self, Mir, TerminatorKind};
|
use rustc::mir::{self, Mir, TerminatorKind};
|
||||||
use rustc::ty::{AssociatedItem, AssociatedItemContainer, Instance, TyCtxt, TyKind};
|
use rustc::ty::{self, AssociatedItem, AssociatedItemContainer, Instance, TyCtxt};
|
||||||
use rustc::ty::subst::InternalSubsts;
|
use rustc::ty::subst::InternalSubsts;
|
||||||
|
|
||||||
pub fn check(tcx: TyCtxt<'a, 'tcx, 'tcx>,
|
pub fn check(tcx: TyCtxt<'a, 'tcx, 'tcx>,
|
||||||
@ -86,7 +86,7 @@ fn check_fn_for_unconditional_recursion(tcx: TyCtxt<'a, 'tcx, 'tcx>,
|
|||||||
TerminatorKind::Call { ref func, .. } => {
|
TerminatorKind::Call { ref func, .. } => {
|
||||||
let func_ty = func.ty(mir, tcx);
|
let func_ty = func.ty(mir, tcx);
|
||||||
|
|
||||||
if let TyKind::FnDef(fn_def_id, substs) = func_ty.sty {
|
if let ty::FnDef(fn_def_id, substs) = func_ty.sty {
|
||||||
let (call_fn_id, call_substs) =
|
let (call_fn_id, call_substs) =
|
||||||
if let Some(instance) = Instance::resolve(tcx,
|
if let Some(instance) = Instance::resolve(tcx,
|
||||||
param_env,
|
param_env,
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
use rustc::mir::{Constant, Location, Place, PlaceBase, Mir, Operand, ProjectionElem, Rvalue, Local};
|
use rustc::mir::{Constant, Location, Place, PlaceBase, Mir, Operand, ProjectionElem, Rvalue, Local};
|
||||||
use rustc::mir::visit::{MutVisitor, Visitor};
|
use rustc::mir::visit::{MutVisitor, Visitor};
|
||||||
use rustc::ty::{TyCtxt, TyKind};
|
use rustc::ty::{self, TyCtxt};
|
||||||
use rustc::util::nodemap::{FxHashMap, FxHashSet};
|
use rustc::util::nodemap::{FxHashMap, FxHashSet};
|
||||||
use rustc_data_structures::indexed_vec::Idx;
|
use rustc_data_structures::indexed_vec::Idx;
|
||||||
use std::mem;
|
use std::mem;
|
||||||
@ -90,7 +90,7 @@ impl<'b, 'a, 'tcx> Visitor<'tcx> for OptimizationFinder<'b, 'a, 'tcx> {
|
|||||||
|
|
||||||
if let Rvalue::Len(ref place) = *rvalue {
|
if let Rvalue::Len(ref place) = *rvalue {
|
||||||
let place_ty = place.ty(&self.mir.local_decls, self.tcx).ty;
|
let place_ty = place.ty(&self.mir.local_decls, self.tcx).ty;
|
||||||
if let TyKind::Array(_, len) = place_ty.sty {
|
if let ty::Array(_, len) = place_ty.sty {
|
||||||
let span = self.mir.source_info(location).span;
|
let span = self.mir.source_info(location).span;
|
||||||
let ty = self.tcx.types.usize;
|
let ty = self.tcx.types.usize;
|
||||||
let constant = Constant { span, ty, literal: len, user_ty: None };
|
let constant = Constant { span, ty, literal: len, user_ty: None };
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
use rustc::hir::def_id::DefId;
|
use rustc::hir::def_id::DefId;
|
||||||
use rustc::middle::lang_items::LangItem;
|
use rustc::middle::lang_items::LangItem;
|
||||||
use rustc::mir::*;
|
use rustc::mir::*;
|
||||||
use rustc::ty::{List, Ty, TyCtxt, TyKind};
|
use rustc::ty::{self, List, Ty, TyCtxt};
|
||||||
use rustc_data_structures::indexed_vec::{Idx};
|
use rustc_data_structures::indexed_vec::{Idx};
|
||||||
use crate::transform::{MirPass, MirSource};
|
use crate::transform::{MirPass, MirSource};
|
||||||
|
|
||||||
@ -183,8 +183,8 @@ impl RhsKind {
|
|||||||
|
|
||||||
fn sign_of_128bit(ty: Ty<'_>) -> Option<bool> {
|
fn sign_of_128bit(ty: Ty<'_>) -> Option<bool> {
|
||||||
match ty.sty {
|
match ty.sty {
|
||||||
TyKind::Int(syntax::ast::IntTy::I128) => Some(true),
|
ty::Int(syntax::ast::IntTy::I128) => Some(true),
|
||||||
TyKind::Uint(syntax::ast::UintTy::U128) => Some(false),
|
ty::Uint(syntax::ast::UintTy::U128) => Some(false),
|
||||||
_ => None,
|
_ => None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user