diff --git a/src/librustdoc/clean/mod.rs b/src/librustdoc/clean/mod.rs index 0dd6c2a7ce7..a0e4d0a30a0 100644 --- a/src/librustdoc/clean/mod.rs +++ b/src/librustdoc/clean/mod.rs @@ -683,23 +683,32 @@ impl Clean> for ty::Region { } #[deriving(Clone, RustcEncodable, RustcDecodable, PartialEq)] -pub struct WherePredicate { - pub ty: Type, - pub bounds: Vec +pub enum WherePredicate { + BoundPredicate { ty: Type, bounds: Vec }, + RegionPredicate { lifetime: Lifetime, bounds: Vec}, + // FIXME (#20041) + EqPredicate } impl Clean for ast::WherePredicate { fn clean(&self, cx: &DocContext) -> WherePredicate { match *self { ast::WherePredicate::BoundPredicate(ref wbp) => { - WherePredicate { + WherePredicate::BoundPredicate { ty: wbp.bounded_ty.clean(cx), bounds: wbp.bounds.clean(cx) } } - // FIXME(#20048) - _ => { - unimplemented!(); + + ast::WherePredicate::RegionPredicate(ref wrp) => { + WherePredicate::RegionPredicate { + lifetime: wrp.lifetime.clean(cx), + bounds: wrp.bounds.clean(cx) + } + } + + ast::WherePredicate::EqPredicate(_) => { + WherePredicate::EqPredicate } } } diff --git a/src/librustdoc/html/format.rs b/src/librustdoc/html/format.rs index a2d5530692c..9b39b223f8e 100644 --- a/src/librustdoc/html/format.rs +++ b/src/librustdoc/html/format.rs @@ -128,8 +128,26 @@ impl<'a> fmt::Show for WhereClause<'a> { if i > 0 { try!(f.write(", ".as_bytes())); } - let bounds = pred.bounds.as_slice(); - try!(write!(f, "{}: {}", pred.ty, TyParamBounds(bounds))); + match pred { + &clean::WherePredicate::BoundPredicate {ref ty, ref bounds } => { + let bounds = bounds.as_slice(); + try!(write!(f, "{}: {}", ty, TyParamBounds(bounds))); + }, + &clean::WherePredicate::RegionPredicate { ref lifetime, + ref bounds } => { + try!(write!(f, "{}: ", lifetime)); + for (i, lifetime) in bounds.iter().enumerate() { + if i > 0 { + try!(f.write(" + ".as_bytes())); + } + + try!(write!(f, "{}", lifetime)); + } + }, + &clean::WherePredicate::EqPredicate => { + unimplemented!() + } + } } Ok(()) }