Bug 1738520 - Make #[css(field_bound)] and #[css(iterable)] work properly. r=mats

For now, use IntoIterator to figure the right type to add the bound.

If we need this on types that are iterable but don't provide
IntoIterator, we can add another attribute field or something.

Differential Revision: https://phabricator.services.mozilla.com/D129962
This commit is contained in:
Mats Palmgren 2021-11-04 18:31:55 +00:00
Родитель 8e61f2da65
Коммит 039e1146f4
2 изменённых файлов: 22 добавлений и 10 удалений

Просмотреть файл

@ -135,11 +135,19 @@ fn derive_variant_fields_expr(
Some(pair) => pair,
None => return quote! { Ok(()) },
};
if !attrs.iterable && iter.peek().is_none() {
if attrs.field_bound {
let ty = &first.ast().ty;
cg::add_predicate(where_clause, parse_quote!(#ty: style_traits::ToCss));
// TODO(emilio): IntoIterator might not be enough for every type of
// iterable thing (like ArcSlice<> or what not). We might want to expose
// an `item = "T"` attribute to handle that in the future.
let predicate = if attrs.iterable {
parse_quote!(<#ty as IntoIterator>::Item: style_traits::ToCss)
} else {
parse_quote!(#ty: style_traits::ToCss)
};
cg::add_predicate(where_clause, predicate);
}
if !attrs.iterable && iter.peek().is_none() {
let mut expr = quote! { style_traits::ToCss::to_css(#first, dest) };
if let Some(condition) = attrs.skip_if {
expr = quote! {

Просмотреть файл

@ -93,12 +93,6 @@ impl<T: Sized> OwnedSlice<T> {
ret
}
/// Iterate over all the elements in the slice taking ownership of them.
#[inline]
pub fn into_iter(self) -> impl Iterator<Item = T> + ExactSizeIterator {
self.into_vec().into_iter()
}
/// Convert the regular slice into an owned slice.
#[inline]
pub fn from_slice(s: &[T]) -> Self
@ -109,6 +103,16 @@ impl<T: Sized> OwnedSlice<T> {
}
}
impl<T> IntoIterator for OwnedSlice<T> {
type Item = T;
type IntoIter = <Vec<T> as IntoIterator>::IntoIter;
#[inline]
fn into_iter(self) -> Self::IntoIter {
self.into_vec().into_iter()
}
}
impl<T> Deref for OwnedSlice<T> {
type Target = [T];