New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
stylo: avoid traversing non element/text nodes in style and layout #13172
Merged
+86
−52
Merged
Changes from all commits
Commits
Show all changes
3 commits
Select commit
Hold shift + click to select a range
File filter...
Filter file types
Jump to…
Jump to file
Failed to load files.
| @@ -64,7 +64,33 @@ pub trait TRestyleDamage : Debug + PartialEq + BitOr<Output=Self> + Copy { | ||
| fn rebuild_and_reflow() -> Self; | ||
| } | ||
|
|
||
| pub trait TNode : Sized + Copy + Clone { | ||
| /// Simple trait to provide basic information about the type of an element. | ||
| /// | ||
| /// We avoid exposing the full type id, since computing it in the general case | ||
| /// would be difficult for Gecko nodes. | ||
| pub trait NodeInfo { | ||
| fn is_element(&self) -> bool; | ||
| fn is_text_node(&self) -> bool; | ||
|
|
||
| // Comments, doctypes, etc are ignored by layout algorithms. | ||
| fn needs_layout(&self) -> bool { self.is_element() || self.is_text_node() } | ||
| } | ||
|
|
||
| pub struct LayoutIterator<T>(pub T); | ||
| impl<T, I> Iterator for LayoutIterator<T> where T: Iterator<Item=I>, I: NodeInfo { | ||
| type Item = I; | ||
| fn next(&mut self) -> Option<I> { | ||
| loop { | ||
| // Filter out nodes that layout should ignore. | ||
| let n = self.0.next(); | ||
emilio
Member
|
||
| if n.is_none() || n.as_ref().unwrap().needs_layout() { | ||
| return n | ||
| } | ||
| } | ||
| } | ||
| } | ||
|
|
||
| pub trait TNode : Sized + Copy + Clone + NodeInfo { | ||
| type ConcreteElement: TElement<ConcreteNode = Self, ConcreteDocument = Self::ConcreteDocument>; | ||
| type ConcreteDocument: TDocument<ConcreteNode = Self, ConcreteElement = Self::ConcreteElement>; | ||
| type ConcreteRestyleDamage: TRestyleDamage; | ||
| @@ -73,19 +99,12 @@ pub trait TNode : Sized + Copy + Clone { | ||
| fn to_unsafe(&self) -> UnsafeNode; | ||
| unsafe fn from_unsafe(n: &UnsafeNode) -> Self; | ||
|
|
||
| /// Returns whether this is a text node. It turns out that this is all the style system cares | ||
| /// about, and thus obviates the need to compute the full type id, which would be expensive in | ||
| /// Gecko. | ||
| fn is_text_node(&self) -> bool; | ||
|
|
||
| fn is_element(&self) -> bool; | ||
|
|
||
| fn dump(self); | ||
|
|
||
| fn dump_style(self); | ||
|
|
||
| /// Returns an iterator over this node's children. | ||
| fn children(self) -> Self::ConcreteChildrenIterator; | ||
| fn children(self) -> LayoutIterator<Self::ConcreteChildrenIterator>; | ||
|
|
||
| /// Converts self into an `OpaqueNode`. | ||
| fn opaque(&self) -> OpaqueNode; | ||
ProTip!
Use n and p to navigate between commits in a pull request.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
nit: missing newline