Apply suggestions from code review

Co-authored-by: bjorn3 <bjorn3@users.noreply.github.com>
This commit is contained in:
ivan770 2020-12-09 10:17:28 +02:00 committed by GitHub
parent 7738467e0a
commit 86c183716c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -77,16 +77,14 @@ impl<'a, 'b> ExprValidator<'a, 'b> {
} }
} }
let body_expr = &body[body.body_expr]; let body_expr = &body[body.body_expr];
if let Expr::Block { tail: Some(t), .. } = body_expr { if let Expr::Block { statements, tail, .. } = body_expr {
if let Some(t) = tail {
self.validate_results_in_tail_expr(body.body_expr, *t, db); self.validate_results_in_tail_expr(body.body_expr, *t, db);
} else { } else if let Some(Statement::Expr(id)) = statements.last() {
if let Expr::Block { statements, .. } = body_expr {
if let Some(Statement::Expr(id)) = statements.last() {
self.validate_missing_tail_expr(body.body_expr, *id, db); self.validate_missing_tail_expr(body.body_expr, *id, db);
} }
} }
} }
}
fn create_record_literal_missing_fields_diagnostic( fn create_record_literal_missing_fields_diagnostic(
&mut self, &mut self,
@ -336,10 +334,17 @@ impl<'a, 'b> ExprValidator<'a, 'b> {
None => return, None => return,
}; };
if let Some(possible_tail_ty) = self.infer.type_of_expr.get(possible_tail_id) { let possible_tail_ty = if let Some(possible_tail_ty) = self.infer.type_of_expr.get(possible_tail_id) {
if mismatch.actual == Ty::unit() && mismatch.expected == *possible_tail_ty { possible_tail_ty
let (_, source_map) = db.body_with_source_map(self.owner.into()); } else {
return;
};
if mismatch.actual != Ty::unit() || mismatch.expected != *possible_tail_ty {
return;
}
let (_, source_map) = db.body_with_source_map(self.owner.into());
if let Ok(source_ptr) = source_map.expr_syntax(possible_tail_id) { if let Ok(source_ptr) = source_map.expr_syntax(possible_tail_id) {
self.sink.push(RemoveThisSemicolon { self.sink.push(RemoveThisSemicolon {
file: source_ptr.file_id, file: source_ptr.file_id,
@ -348,8 +353,6 @@ impl<'a, 'b> ExprValidator<'a, 'b> {
} }
} }
} }
}
}
pub fn record_literal_missing_fields( pub fn record_literal_missing_fields(
db: &dyn HirDatabase, db: &dyn HirDatabase,