diff --git a/chalk-solve/src/display/ty.rs b/chalk-solve/src/display/ty.rs index c751392f8d6..789b4b19e7f 100644 --- a/chalk-solve/src/display/ty.rs +++ b/chalk-solve/src/display/ty.rs @@ -39,9 +39,7 @@ impl RenderAsRust for TyData { TyData::Alias(alias_ty) => alias_ty.fmt(s, f), TyData::Apply(apply_ty) => apply_ty.fmt(s, f), TyData::Function(func) => func.fmt(s, f), - TyData::Placeholder(_) => unreachable!( - "cannot print placeholder variables; these should only be in goals not programs" - ), + TyData::Placeholder(_) => write!(f, ""), } } } @@ -214,9 +212,12 @@ impl RenderAsRust for ApplicationTy { )?; } TypeName::Error => write!(f, "{{error}}")?, - TypeName::Never => todo!("never type"), - TypeName::FnDef(_) => todo!("fn def type"), - TypeName::Closure(..) => todo!("closure type"), + TypeName::Never => write!(f, "!")?, + + // FIXME: write out valid types for these variants + TypeName::FnDef(_) => write!(f, "")?, + TypeName::Closure(..) => write!(f, "")?, + TypeName::Array => write!( f, "[{}; {}]", @@ -267,9 +268,9 @@ impl RenderAsRust for LifetimeData { match self { LifetimeData::BoundVar(v) => write!(f, "'{}", s.display_bound_var(v)), LifetimeData::InferenceVar(_) => write!(f, "'_"), - LifetimeData::Placeholder(_) => unreachable!( - "cannot print placeholder variables; these should only be in goals not programs" - ), + LifetimeData::Placeholder(ix) => { + write!(f, "'_placeholder_{}_{}", ix.ui.counter, ix.idx) + } // Matching the void ensures at compile time that this code is // unreachable LifetimeData::Phantom(void, _) => match *void {}, @@ -288,9 +289,7 @@ impl RenderAsRust for ConstValue { match self { ConstValue::BoundVar(v) => write!(f, "{}", s.display_bound_var(v)), ConstValue::InferenceVar(_) => write!(f, "_"), - ConstValue::Placeholder(_) => unreachable!( - "cannot print placeholder variables; these should only be in goals not programs" - ), + ConstValue::Placeholder(_) => write!(f, ""), ConstValue::Concrete(_value) => unimplemented!("const values"), } }