aboutsummaryrefslogtreecommitdiff
path: root/crates/hir_ty/src/infer/expr.rs
diff options
context:
space:
mode:
authorFlorian Diebold <[email protected]>2021-04-03 20:29:49 +0100
committerFlorian Diebold <[email protected]>2021-04-04 12:16:38 +0100
commit620769f32276bb7e8c580eae2c91ee535a06d9f8 (patch)
tree3d4541f18206d9ad538f8255e00d4632058d9af5 /crates/hir_ty/src/infer/expr.rs
parente6f007d9a8e676c4af5731001b211ca7a52bce16 (diff)
Add TyBuilder::adt
Diffstat (limited to 'crates/hir_ty/src/infer/expr.rs')
-rw-r--r--crates/hir_ty/src/infer/expr.rs27
1 files changed, 10 insertions, 17 deletions
diff --git a/crates/hir_ty/src/infer/expr.rs b/crates/hir_ty/src/infer/expr.rs
index db8aeead2..5eb07126e 100644
--- a/crates/hir_ty/src/infer/expr.rs
+++ b/crates/hir_ty/src/infer/expr.rs
@@ -539,17 +539,10 @@ impl<'a> InferenceContext<'a> {
539 Expr::Box { expr } => { 539 Expr::Box { expr } => {
540 let inner_ty = self.infer_expr_inner(*expr, &Expectation::none()); 540 let inner_ty = self.infer_expr_inner(*expr, &Expectation::none());
541 if let Some(box_) = self.resolve_boxed_box() { 541 if let Some(box_) = self.resolve_boxed_box() {
542 let mut sb = 542 TyBuilder::adt(self.db, box_)
543 Substitution::build_for_generics(&generics(self.db.upcast(), box_.into())); 543 .push(inner_ty)
544 sb = sb.push(inner_ty); 544 .fill_with_defaults(self.db, || self.table.new_type_var())
545 match self.db.generic_defaults(box_.into()).get(1) { 545 .build()
546 Some(alloc_ty) if !alloc_ty.value.is_unknown() && sb.remaining() > 0 => {
547 sb = sb.push(alloc_ty.value.clone());
548 }
549 _ => (),
550 }
551 sb = sb.fill(repeat_with(|| self.table.new_type_var()));
552 Ty::adt_ty(box_, sb.build())
553 } else { 546 } else {
554 self.err_ty() 547 self.err_ty()
555 } 548 }
@@ -639,31 +632,31 @@ impl<'a> InferenceContext<'a> {
639 let rhs_ty = rhs.map(|e| self.infer_expr(e, &rhs_expect)); 632 let rhs_ty = rhs.map(|e| self.infer_expr(e, &rhs_expect));
640 match (range_type, lhs_ty, rhs_ty) { 633 match (range_type, lhs_ty, rhs_ty) {
641 (RangeOp::Exclusive, None, None) => match self.resolve_range_full() { 634 (RangeOp::Exclusive, None, None) => match self.resolve_range_full() {
642 Some(adt) => Ty::adt_ty(adt, Substitution::empty(&Interner)), 635 Some(adt) => TyBuilder::adt(self.db, adt).build(),
643 None => self.err_ty(), 636 None => self.err_ty(),
644 }, 637 },
645 (RangeOp::Exclusive, None, Some(ty)) => match self.resolve_range_to() { 638 (RangeOp::Exclusive, None, Some(ty)) => match self.resolve_range_to() {
646 Some(adt) => Ty::adt_ty(adt, Substitution::single(ty)), 639 Some(adt) => TyBuilder::adt(self.db, adt).push(ty).build(),
647 None => self.err_ty(), 640 None => self.err_ty(),
648 }, 641 },
649 (RangeOp::Inclusive, None, Some(ty)) => { 642 (RangeOp::Inclusive, None, Some(ty)) => {
650 match self.resolve_range_to_inclusive() { 643 match self.resolve_range_to_inclusive() {
651 Some(adt) => Ty::adt_ty(adt, Substitution::single(ty)), 644 Some(adt) => TyBuilder::adt(self.db, adt).push(ty).build(),
652 None => self.err_ty(), 645 None => self.err_ty(),
653 } 646 }
654 } 647 }
655 (RangeOp::Exclusive, Some(_), Some(ty)) => match self.resolve_range() { 648 (RangeOp::Exclusive, Some(_), Some(ty)) => match self.resolve_range() {
656 Some(adt) => Ty::adt_ty(adt, Substitution::single(ty)), 649 Some(adt) => TyBuilder::adt(self.db, adt).push(ty).build(),
657 None => self.err_ty(), 650 None => self.err_ty(),
658 }, 651 },
659 (RangeOp::Inclusive, Some(_), Some(ty)) => { 652 (RangeOp::Inclusive, Some(_), Some(ty)) => {
660 match self.resolve_range_inclusive() { 653 match self.resolve_range_inclusive() {
661 Some(adt) => Ty::adt_ty(adt, Substitution::single(ty)), 654 Some(adt) => TyBuilder::adt(self.db, adt).push(ty).build(),
662 None => self.err_ty(), 655 None => self.err_ty(),
663 } 656 }
664 } 657 }
665 (RangeOp::Exclusive, Some(ty), None) => match self.resolve_range_from() { 658 (RangeOp::Exclusive, Some(ty), None) => match self.resolve_range_from() {
666 Some(adt) => Ty::adt_ty(adt, Substitution::single(ty)), 659 Some(adt) => TyBuilder::adt(self.db, adt).push(ty).build(),
667 None => self.err_ty(), 660 None => self.err_ty(),
668 }, 661 },
669 (RangeOp::Inclusive, _, None) => self.err_ty(), 662 (RangeOp::Inclusive, _, None) => self.err_ty(),