Fill missing fields of enum variants
This commit is contained in:
parent
7db7c86881
commit
9549aad525
@ -15,6 +15,7 @@
|
||||
use crate::{
|
||||
db::HirDatabase,
|
||||
diagnostics::{MissingFields, MissingOkInTailExpr},
|
||||
utils::variant_data,
|
||||
ApplicationTy, InferenceResult, Ty, TypeCtor,
|
||||
};
|
||||
|
||||
@ -27,6 +28,7 @@
|
||||
ArithOp, Array, BinaryOp, BindingAnnotation, CmpOp, Expr, ExprId, Literal, LogicOp,
|
||||
MatchArm, Ordering, Pat, PatId, RecordFieldPat, RecordLitField, Statement, UnaryOp,
|
||||
},
|
||||
VariantId,
|
||||
};
|
||||
|
||||
pub struct ExprValidator<'a, 'b: 'a> {
|
||||
@ -69,17 +71,19 @@ fn validate_record_literal(
|
||||
) {
|
||||
if spread.is_some() {
|
||||
return;
|
||||
};
|
||||
let variant_def: VariantId = match self.infer.variant_resolution_for_expr(id) {
|
||||
Some(VariantId::UnionId(_)) | None => return,
|
||||
Some(it) => it,
|
||||
};
|
||||
if let VariantId::UnionId(_) = variant_def {
|
||||
return;
|
||||
}
|
||||
|
||||
let struct_def = match self.infer[id].as_adt() {
|
||||
Some((AdtId::StructId(s), _)) => s,
|
||||
_ => return,
|
||||
};
|
||||
let struct_data = db.struct_data(struct_def);
|
||||
let variant_data = variant_data(db, variant_def);
|
||||
|
||||
let lit_fields: FxHashSet<_> = fields.iter().map(|f| &f.name).collect();
|
||||
let missed_fields: Vec<Name> = struct_data
|
||||
.variant_data
|
||||
let missed_fields: Vec<Name> = variant_data
|
||||
.fields()
|
||||
.iter()
|
||||
.filter_map(|(_f, d)| {
|
||||
|
@ -469,6 +469,35 @@ fn test_fn() {
|
||||
check_apply_diagnostic_fix(before, after);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_fill_struct_fields_enum() {
|
||||
let before = r"
|
||||
enum Expr {
|
||||
Bin { lhs: Box<Expr>, rhs: Box<Expr> }
|
||||
}
|
||||
|
||||
impl Expr {
|
||||
fn new_bin(lhs: Box<Expr>, rhs: Box<Expr>) -> Expr {
|
||||
Expr::Bin { <|> }
|
||||
}
|
||||
}
|
||||
|
||||
";
|
||||
let after = r"
|
||||
enum Expr {
|
||||
Bin { lhs: Box<Expr>, rhs: Box<Expr> }
|
||||
}
|
||||
|
||||
impl Expr {
|
||||
fn new_bin(lhs: Box<Expr>, rhs: Box<Expr>) -> Expr {
|
||||
Expr::Bin { lhs: (), rhs: () <|> }
|
||||
}
|
||||
}
|
||||
|
||||
";
|
||||
check_apply_diagnostic_fix(before, after);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_fill_struct_fields_partial() {
|
||||
let before = r"
|
||||
|
Loading…
Reference in New Issue
Block a user