Avoid panic!, omit instead

This commit is contained in:
koka 2023-10-13 17:07:29 +09:00
parent 929a288aa7
commit eb6fb18a99
No known key found for this signature in database
GPG Key ID: A5917A40697774CD
3 changed files with 54 additions and 8 deletions

View File

@ -268,8 +268,8 @@ fn symbol(&self, symbol: &Binding<Symbol>) {
fn qpath(&self, qpath: &Binding<&QPath<'_>>) { fn qpath(&self, qpath: &Binding<&QPath<'_>>) {
if let QPath::LangItem(lang_item, ..) = *qpath.value { if let QPath::LangItem(lang_item, ..) = *qpath.value {
chain!(self, "matches!({qpath}, QPath::LangItem(LangItem::{lang_item:?}, _))"); chain!(self, "matches!({qpath}, QPath::LangItem(LangItem::{lang_item:?}, _))");
} else { } else if let Ok(path) = path_to_string(qpath.value) {
chain!(self, "match_qpath({qpath}, &[{}])", path_to_string(qpath.value)); chain!(self, "match_qpath({qpath}, &[{}])", path);
} }
} }
@ -738,8 +738,8 @@ fn has_attr(cx: &LateContext<'_>, hir_id: hir::HirId) -> bool {
get_attr(cx.sess(), attrs, "author").count() > 0 get_attr(cx.sess(), attrs, "author").count() > 0
} }
fn path_to_string(path: &QPath<'_>) -> String { fn path_to_string(path: &QPath<'_>) -> Result<String, ()> {
fn inner(s: &mut String, path: &QPath<'_>) { fn inner(s: &mut String, path: &QPath<'_>) -> Result<(), ()> {
match *path { match *path {
QPath::Resolved(_, path) => { QPath::Resolved(_, path) => {
for (i, segment) in path.segments.iter().enumerate() { for (i, segment) in path.segments.iter().enumerate() {
@ -751,16 +751,18 @@ fn inner(s: &mut String, path: &QPath<'_>) {
}, },
QPath::TypeRelative(ty, segment) => match &ty.kind { QPath::TypeRelative(ty, segment) => match &ty.kind {
hir::TyKind::Path(inner_path) => { hir::TyKind::Path(inner_path) => {
inner(s, inner_path); inner(s, inner_path)?;
*s += ", "; *s += ", ";
write!(s, "{:?}", segment.ident.as_str()).unwrap(); write!(s, "{:?}", segment.ident.as_str()).unwrap();
}, },
other => write!(s, "/* unimplemented: {other:?}*/").unwrap(), other => write!(s, "/* unimplemented: {other:?}*/").unwrap(),
}, },
QPath::LangItem(..) => panic!("path_to_string: called for lang item qpath"), QPath::LangItem(..) => return Err(()),
} }
Ok(())
} }
let mut s = String::new(); let mut s = String::new();
inner(&mut s, path); inner(&mut s, path)?;
s Ok(s)
} }

View File

@ -0,0 +1,5 @@
fn main() {
#[clippy::author]
let print_text = |x| println!("{}", x);
print_text("hello");
}

View File

@ -0,0 +1,39 @@
if let StmtKind::Local(local) = stmt.kind
&& let Some(init) = local.init
&& let ExprKind::Closure(CaptureBy::Ref, fn_decl, body_id, _, None) = init.kind
&& let FnRetTy::DefaultReturn(_) = fn_decl.output
&& expr = &cx.tcx.hir().body(body_id).value
&& let ExprKind::Block(block, None) = expr.kind
&& block.stmts.len() == 1
&& let StmtKind::Semi(e) = block.stmts[0].kind
&& let ExprKind::Call(func, args) = e.kind
&& let ExprKind::Path(ref qpath) = func.kind
&& match_qpath(qpath, &["$crate", "io", "_print"])
&& args.len() == 1
&& let ExprKind::Call(func1, args1) = args[0].kind
&& let ExprKind::Path(ref qpath1) = func1.kind
&& args1.len() == 2
&& let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner) = args1[0].kind
&& let ExprKind::Array(elements) = inner.kind
&& elements.len() == 2
&& let ExprKind::Lit(ref lit) = elements[0].kind
&& let LitKind::Str(s, _) = lit.node
&& s.as_str() == ""
&& let ExprKind::Lit(ref lit1) = elements[1].kind
&& let LitKind::Str(s1, _) = lit1.node
&& s1.as_str() == "\n"
&& let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner1) = args1[1].kind
&& let ExprKind::Array(elements1) = inner1.kind
&& elements1.len() == 1
&& let ExprKind::Call(func2, args2) = elements1[0].kind
&& let ExprKind::Path(ref qpath2) = func2.kind
&& args2.len() == 1
&& let ExprKind::AddrOf(BorrowKind::Ref, Mutability::Not, inner2) = args2[0].kind
&& let ExprKind::Path(ref qpath3) = inner2.kind
&& match_qpath(qpath3, &["x"])
&& block.expr.is_none()
&& let PatKind::Binding(BindingAnnotation::NONE, _, name, None) = local.pat.kind
&& name.as_str() == "print_text"
{
// report your lint here
}