mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
Use impl DoubleEndedIterator for two flow_list iterators
This commit is contained in:
parent
8419f96dc0
commit
a1af2cded8
3 changed files with 7 additions and 30 deletions
|
@ -31,7 +31,7 @@ use context::LayoutContext;
|
||||||
use display_list_builder::DisplayListBuildState;
|
use display_list_builder::DisplayListBuildState;
|
||||||
use euclid::{Point2D, Rect, Size2D};
|
use euclid::{Point2D, Rect, Size2D};
|
||||||
use floats::{Floats, SpeculatedFloatPlacement};
|
use floats::{Floats, SpeculatedFloatPlacement};
|
||||||
use flow_list::{FlowList, FlowListIterator, MutFlowListIterator};
|
use flow_list::{FlowList, MutFlowListIterator};
|
||||||
use flow_ref::{self, FlowRef, WeakFlowRef};
|
use flow_ref::{self, FlowRef, WeakFlowRef};
|
||||||
use fragment::{Fragment, FragmentBorderBoxIterator, Overflow, SpecificFragmentInfo};
|
use fragment::{Fragment, FragmentBorderBoxIterator, Overflow, SpecificFragmentInfo};
|
||||||
use gfx::display_list::{ClippingRegion, StackingContext};
|
use gfx::display_list::{ClippingRegion, StackingContext};
|
||||||
|
@ -432,7 +432,7 @@ pub fn base<T: ?Sized + Flow>(this: &T) -> &BaseFlow {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Iterates over the children of this immutable flow.
|
/// Iterates over the children of this immutable flow.
|
||||||
pub fn child_iter<'a>(flow: &'a Flow) -> FlowListIterator<'a> {
|
pub fn child_iter<'a>(flow: &'a Flow) -> impl Iterator<Item = &'a Flow> {
|
||||||
base(flow).children.iter()
|
base(flow).children.iter()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,10 +13,6 @@ pub struct FlowList {
|
||||||
flows: LinkedList<FlowRef>,
|
flows: LinkedList<FlowRef>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct FlowListIterator<'a> {
|
|
||||||
it: linked_list::Iter<'a, FlowRef>,
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct MutFlowListIterator<'a> {
|
pub struct MutFlowListIterator<'a> {
|
||||||
it: linked_list::IterMut<'a, FlowRef>,
|
it: linked_list::IterMut<'a, FlowRef>,
|
||||||
}
|
}
|
||||||
|
@ -58,10 +54,8 @@ impl FlowList {
|
||||||
|
|
||||||
/// Provide a forward iterator
|
/// Provide a forward iterator
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn iter(&self) -> FlowListIterator {
|
pub fn iter<'a>(&'a self) -> impl DoubleEndedIterator<Item = &'a Flow> {
|
||||||
FlowListIterator {
|
self.flows.iter().map(|flow| &**flow)
|
||||||
it: self.flows.iter(),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Provide a forward iterator with mutable references
|
/// Provide a forward iterator with mutable references
|
||||||
|
@ -74,7 +68,8 @@ impl FlowList {
|
||||||
|
|
||||||
/// Provide a forward iterator with FlowRef items
|
/// Provide a forward iterator with FlowRef items
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn iter_flow_ref_mut<'a>(&'a mut self) -> linked_list::IterMut<'a, FlowRef> {
|
pub fn iter_flow_ref_mut<'a>(&'a mut self)
|
||||||
|
-> impl DoubleEndedIterator<Item = &'a mut FlowRef> {
|
||||||
self.flows.iter_mut()
|
self.flows.iter_mut()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,25 +93,6 @@ impl FlowList {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Iterator for FlowListIterator<'a> {
|
|
||||||
type Item = &'a Flow;
|
|
||||||
#[inline]
|
|
||||||
fn next(&mut self) -> Option<&'a Flow> {
|
|
||||||
self.it.next().map(|x| &**x)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[inline]
|
|
||||||
fn size_hint(&self) -> (usize, Option<usize>) {
|
|
||||||
self.it.size_hint()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> DoubleEndedIterator for FlowListIterator<'a> {
|
|
||||||
fn next_back(&mut self) -> Option<&'a Flow> {
|
|
||||||
self.it.next_back().map(|x| &**x)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> DoubleEndedIterator for MutFlowListIterator<'a> {
|
impl<'a> DoubleEndedIterator for MutFlowListIterator<'a> {
|
||||||
fn next_back(&mut self) -> Option<&'a mut Flow> {
|
fn next_back(&mut self) -> Option<&'a mut Flow> {
|
||||||
self.it.next_back().map(flow_ref::deref_mut)
|
self.it.next_back().map(flow_ref::deref_mut)
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
#![feature(box_patterns)]
|
#![feature(box_patterns)]
|
||||||
#![feature(box_syntax)]
|
#![feature(box_syntax)]
|
||||||
|
#![feature(conservative_impl_trait)]
|
||||||
#![feature(custom_derive)]
|
#![feature(custom_derive)]
|
||||||
#![feature(nonzero)]
|
#![feature(nonzero)]
|
||||||
#![feature(plugin)]
|
#![feature(plugin)]
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue