mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-12-04 11:26:09 +00:00
servo: Merge #15815 - Use more idiomatic or_else construction (from crypto-universe:master); r=KiChjang
<!-- Please describe your changes on the following line: --> or_else in more ideomatic rust construction than match, where Some(x) => Some(x) --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: --> - [X] `./mach build -d` does not report any errors - [X] `./mach test-tidy` does not report any errors - [X] These changes fix #15812 (github issue number if applicable). <!-- Either: --> - [ ] There are tests for these changes OR - [ ] These changes do not require tests because _____ <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> Source-Repo: https://github.com/servo/servo Source-Revision: b4d7ed7351068c4655a423b4ca835aab4e8f3c39 --HG-- extra : subtree_source : https%3A//hg.mozilla.org/projects/converted-servo-linear extra : subtree_revision : 87fcd647c3da65c0aa894989afe14c01fe918ca8
This commit is contained in:
parent
cc9c50b366
commit
6825d43996
@ -953,19 +953,12 @@ impl<ConcreteNode> Iterator for ThreadSafeLayoutNodeChildrenIterator<ConcreteNod
|
||||
if let Some(ref node) = node {
|
||||
self.current_node = match node.get_pseudo_element_type() {
|
||||
PseudoElementType::Before(_) => {
|
||||
let first = self.parent_node.get_details_summary_pseudo().or_else(|| unsafe {
|
||||
self.parent_node.dangerous_first_child()
|
||||
});
|
||||
match first {
|
||||
Some(first) => Some(first),
|
||||
None => self.parent_node.get_after_pseudo(),
|
||||
}
|
||||
self.parent_node.get_details_summary_pseudo()
|
||||
.or_else(|| unsafe { self.parent_node.dangerous_first_child() })
|
||||
.or_else(|| self.parent_node.get_after_pseudo())
|
||||
},
|
||||
PseudoElementType::Normal => {
|
||||
match unsafe { node.dangerous_next_sibling() } {
|
||||
Some(next) => Some(next),
|
||||
None => self.parent_node.get_after_pseudo(),
|
||||
}
|
||||
unsafe { node.dangerous_next_sibling() }.or_else(|| self.parent_node.get_after_pseudo())
|
||||
},
|
||||
PseudoElementType::DetailsSummary(_) => self.parent_node.get_details_content_pseudo(),
|
||||
PseudoElementType::DetailsContent(_) => self.parent_node.get_after_pseudo(),
|
||||
|
Loading…
Reference in New Issue
Block a user