mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 23:04:33 +00:00
Use PatKind::Error
instead of PatKind::Wild
to report errors
This commit is contained in:
parent
aab3b9327e
commit
8646afb9c5
@ -426,6 +426,12 @@ impl<'p, 'tcx> MatchVisitor<'_, 'p, 'tcx> {
|
|||||||
|
|
||||||
#[instrument(level = "trace", skip(self))]
|
#[instrument(level = "trace", skip(self))]
|
||||||
fn check_irrefutable(&mut self, pat: &Pat<'tcx>, origin: &str, sp: Option<Span>) {
|
fn check_irrefutable(&mut self, pat: &Pat<'tcx>, origin: &str, sp: Option<Span>) {
|
||||||
|
// If we got errors while lowering, don't emit anything more.
|
||||||
|
if let Err(err) = pat.pat_error_reported() {
|
||||||
|
self.error = Err(err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
let mut cx = self.new_cx(self.lint_level, false);
|
let mut cx = self.new_cx(self.lint_level, false);
|
||||||
|
|
||||||
let pattern = self.lower_pattern(&mut cx, pat);
|
let pattern = self.lower_pattern(&mut cx, pat);
|
||||||
|
@ -252,10 +252,8 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
|
|
||||||
hir::PatKind::Range(ref lo_expr, ref hi_expr, end) => {
|
hir::PatKind::Range(ref lo_expr, ref hi_expr, end) => {
|
||||||
let (lo_expr, hi_expr) = (lo_expr.as_deref(), hi_expr.as_deref());
|
let (lo_expr, hi_expr) = (lo_expr.as_deref(), hi_expr.as_deref());
|
||||||
// FIXME?: returning `_` can cause inaccurate "unreachable" warnings. This can be
|
self.lower_pattern_range(lo_expr, hi_expr, end, ty, span)
|
||||||
// fixed by returning `PatKind::Const(ConstKind::Error(...))` if #115937 gets
|
.unwrap_or_else(PatKind::Error)
|
||||||
// merged.
|
|
||||||
self.lower_pattern_range(lo_expr, hi_expr, end, ty, span).unwrap_or(PatKind::Wild)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
hir::PatKind::Path(ref qpath) => {
|
hir::PatKind::Path(ref qpath) => {
|
||||||
@ -423,9 +421,9 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
if adt_def.is_enum() {
|
if adt_def.is_enum() {
|
||||||
let args = match ty.kind() {
|
let args = match ty.kind() {
|
||||||
ty::Adt(_, args) | ty::FnDef(_, args) => args,
|
ty::Adt(_, args) | ty::FnDef(_, args) => args,
|
||||||
ty::Error(_) => {
|
ty::Error(e) => {
|
||||||
// Avoid ICE (#50585)
|
// Avoid ICE (#50585)
|
||||||
return PatKind::Wild;
|
return PatKind::Error(*e);
|
||||||
}
|
}
|
||||||
_ => bug!("inappropriate type for def: {:?}", ty),
|
_ => bug!("inappropriate type for def: {:?}", ty),
|
||||||
};
|
};
|
||||||
@ -452,7 +450,7 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
| Res::SelfTyAlias { .. }
|
| Res::SelfTyAlias { .. }
|
||||||
| Res::SelfCtor(..) => PatKind::Leaf { subpatterns },
|
| Res::SelfCtor(..) => PatKind::Leaf { subpatterns },
|
||||||
_ => {
|
_ => {
|
||||||
match res {
|
let e = match res {
|
||||||
Res::Def(DefKind::ConstParam, _) => {
|
Res::Def(DefKind::ConstParam, _) => {
|
||||||
self.tcx.sess.emit_err(ConstParamInPattern { span })
|
self.tcx.sess.emit_err(ConstParamInPattern { span })
|
||||||
}
|
}
|
||||||
@ -461,7 +459,7 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
}
|
}
|
||||||
_ => self.tcx.sess.emit_err(NonConstPath { span }),
|
_ => self.tcx.sess.emit_err(NonConstPath { span }),
|
||||||
};
|
};
|
||||||
PatKind::Wild
|
PatKind::Error(e)
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -513,14 +511,13 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
// It should be assoc consts if there's no error but we cannot resolve it.
|
// It should be assoc consts if there's no error but we cannot resolve it.
|
||||||
debug_assert!(is_associated_const);
|
debug_assert!(is_associated_const);
|
||||||
|
|
||||||
self.tcx.sess.emit_err(AssocConstInPattern { span });
|
let e = self.tcx.sess.emit_err(AssocConstInPattern { span });
|
||||||
|
return pat_from_kind(PatKind::Error(e));
|
||||||
return pat_from_kind(PatKind::Wild);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
self.tcx.sess.emit_err(CouldNotEvalConstPattern { span });
|
let e = self.tcx.sess.emit_err(CouldNotEvalConstPattern { span });
|
||||||
return pat_from_kind(PatKind::Wild);
|
return pat_from_kind(PatKind::Error(e));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -574,12 +571,12 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
Err(ErrorHandled::TooGeneric(_)) => {
|
Err(ErrorHandled::TooGeneric(_)) => {
|
||||||
// While `Reported | Linted` cases will have diagnostics emitted already
|
// While `Reported | Linted` cases will have diagnostics emitted already
|
||||||
// it is not true for TooGeneric case, so we need to give user more information.
|
// it is not true for TooGeneric case, so we need to give user more information.
|
||||||
self.tcx.sess.emit_err(ConstPatternDependsOnGenericParameter { span });
|
let e = self.tcx.sess.emit_err(ConstPatternDependsOnGenericParameter { span });
|
||||||
pat_from_kind(PatKind::Wild)
|
pat_from_kind(PatKind::Error(e))
|
||||||
}
|
}
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
self.tcx.sess.emit_err(CouldNotEvalConstPattern { span });
|
let e = self.tcx.sess.emit_err(CouldNotEvalConstPattern { span });
|
||||||
pat_from_kind(PatKind::Wild)
|
pat_from_kind(PatKind::Error(e))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -629,7 +626,7 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
let uneval = mir::UnevaluatedConst { def: def_id.to_def_id(), args, promoted: None };
|
let uneval = mir::UnevaluatedConst { def: def_id.to_def_id(), args, promoted: None };
|
||||||
debug_assert!(!args.has_free_regions());
|
debug_assert!(!args.has_free_regions());
|
||||||
|
|
||||||
let ct = ty::UnevaluatedConst { def: def_id.to_def_id(), args: args };
|
let ct = ty::UnevaluatedConst { def: def_id.to_def_id(), args };
|
||||||
// First try using a valtree in order to destructure the constant into a pattern.
|
// First try using a valtree in order to destructure the constant into a pattern.
|
||||||
// FIXME: replace "try to do a thing, then fall back to another thing"
|
// FIXME: replace "try to do a thing, then fall back to another thing"
|
||||||
// but something more principled, like a trait query checking whether this can be turned into a valtree.
|
// but something more principled, like a trait query checking whether this can be turned into a valtree.
|
||||||
@ -649,10 +646,10 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
Ok(val) => self.const_to_pat(mir::Const::Val(val, ty), id, span, None).kind,
|
Ok(val) => self.const_to_pat(mir::Const::Val(val, ty), id, span, None).kind,
|
||||||
Err(ErrorHandled::TooGeneric(_)) => {
|
Err(ErrorHandled::TooGeneric(_)) => {
|
||||||
// If we land here it means the const can't be evaluated because it's `TooGeneric`.
|
// If we land here it means the const can't be evaluated because it's `TooGeneric`.
|
||||||
self.tcx.sess.emit_err(ConstPatternDependsOnGenericParameter { span });
|
let e = self.tcx.sess.emit_err(ConstPatternDependsOnGenericParameter { span });
|
||||||
PatKind::Wild
|
PatKind::Error(e)
|
||||||
}
|
}
|
||||||
Err(ErrorHandled::Reported(..)) => PatKind::Wild,
|
Err(ErrorHandled::Reported(err, ..)) => PatKind::Error(err.into()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -685,7 +682,7 @@ impl<'a, 'tcx> PatCtxt<'a, 'tcx> {
|
|||||||
Ok(constant) => {
|
Ok(constant) => {
|
||||||
self.const_to_pat(Const::Ty(constant), expr.hir_id, lit.span, None).kind
|
self.const_to_pat(Const::Ty(constant), expr.hir_id, lit.span, None).kind
|
||||||
}
|
}
|
||||||
Err(LitToConstError::Reported(_)) => PatKind::Wild,
|
Err(LitToConstError::Reported(e)) => PatKind::Error(e),
|
||||||
Err(LitToConstError::TypeError) => bug!("lower_lit: had type error"),
|
Err(LitToConstError::TypeError) => bug!("lower_lit: had type error"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user