impl HasAttrs for GenericParam {
fn attrs(&self) -> &[ast::Attribute] {
- match self {
- GenericParam::Lifetime(lifetime) => lifetime.attrs(),
- GenericParam::Type(ty) => ty.attrs(),
- }
+ &self.attrs
}
- fn map_attrs<F: FnOnce(Vec<Attribute>) -> Vec<Attribute>>(self, f: F) -> Self {
- match self {
- GenericParam::Lifetime(lifetime) => GenericParam::Lifetime(lifetime.map_attrs(f)),
- GenericParam::Type(ty) => GenericParam::Type(ty.map_attrs(f)),
- }
+ fn map_attrs<F: FnOnce(Vec<Attribute>) -> Vec<Attribute>>(mut self, f: F) -> Self {
+ self.attrs = self.attrs.map_attrs(f);
+ self
}
}
derive_has_attrs! {
Item, Expr, Local, ast::ForeignItem, ast::StructField, ast::ImplItem, ast::TraitItem, ast::Arm,
- ast::Field, ast::FieldPat, ast::Variant_, ast::LifetimeDef, ast::TyParam
+ ast::Field, ast::FieldPat, ast::Variant_
}
self.span_err(question_span,
"`?` may only modify trait bounds, not lifetime bounds");
}
- bounds.push(Outlives(RegionTyParamBound(self.expect_lifetime())));
+ bounds.push(Outlives(self.expect_lifetime()));
if has_parens {
self.expect(&token::CloseDelim(token::Paren))?;
self.span_err(self.prev_span,