forked from mirrors/gecko-dev
		
	<!-- Please describe your changes on the following line: -->
```
│  │  │  │  │  │  │         floatspec-out=L 0px R 0px
│  │  │  │  │  │  │         overflow=Overflow { scroll: TypedRect(0px×0px at (0px,0px)), paint: TypedRect(0px×0px at (0px,0px)) }
│  │  │  │  │  │  │         damage=BUBBLE_ISIZES
│  │  │  │  │  │  │  └─ ↑↑ Fragment for block:
│  │  │  │  │  │  │  │         SpecificFragmentInfo::Table(2671) []
│  │  │  │  │  │  │  │         border_box=LogicalRect(H LTR, i0px×b0px, @ (i0px,b0px))
│  │  │  │  │  │  │  │         damage=REPOSITION | STORE_OVERFLOW | BUBBLE_ISIZES | REFLOW_OUT_OF_FLOW | REFLOW
│  │  │  │  ├─ Block(1268a9710)
│  │  │  │  │         sc=StackingContextId(0)
│  │  │  │  │         pos=LogicalRect(H LTR, i720px×b36px, @ (i152px,b2636.883333333333px))
│  │  │  │  │         floatspec-in=L 0px R 0px
│  │  │  │  │         floatspec-out=L 0px R 0px
│  │  │  │  │         overflow=Overflow { scroll: TypedRect(750px×36px at (-15px,0px)), paint: TypedRect(750px×36px at (-15px,0px)) }
│  │  │  │  │         children=1
│  │  │  │  │         damage=BUBBLE_ISIZES
│  │  │  │  │  ├─ ↑↑ Fragment for block:
│  │  │  │  │  │         SpecificFragmentInfo::Generic(2673) []
│  │  │  │  │  │         border_box=LogicalRect(H LTR, i720px×b36px, @ (i0px,b0px))
│  │  │  │  │  │         border_padding=LogicalMargin(H LTR, i:0px..0px b:6px..0px)
│  │  │  │  │  │         damage=REPOSITION | STORE_OVERFLOW
│  │  │  │  │  ├─ Block(128554f10)
│  │  │  │  │  │         sc=StackingContextId(0)
│  │  │  │  │  │         pos=LogicalRect(H LTR, i750px×b30px, @ (i0px,b6px))
│  │  │  │  │  │         floatspec-in=L 0px R 0px
│  │  │  │  │  │         floatspec-out=L 0px R 0px
│  │  │  │  │  │         overflow=Overflow { scroll: TypedRect(750px×30px at (-15px,0px)), paint: TypedRect(750px×30px at (-15px,0px)) }
│  │  │  │  │  │         children=6
│  │  │  │  │  │         damage=BUBBLE_ISIZES
│  │  │  │  │  │  ├─ ↑↑ Fragment for block:
│  │  │  │  │  │  │         SpecificFragmentInfo::Generic(2361) []
│  │  │  │  │  │  │         border_box=LogicalRect(H LTR, i750px×b30px, @ (i-15px,b0px))
│  │  │  │  │  │  │         margin=LogicalMargin(H LTR, i:-15px..-15px b:0px..0px)
│  │  │  │  │  │  │         damage=REPOSITION | STORE_OVERFLOW
│  │  │  │  │  │  ├─ TableWrapperFlow: Block(128555410)
│  │  │  │  │  │  │         sc=StackingContextId(0)
│  │  │  │  │  │  │         pos=LogicalRect(H LTR, i750px×b0px, @ (i-15px,b0px))
│  │  │  │  │  │  │         floatspec-in=L 0px R 0px
│  │  │  │  │  │  │         floatspec-out=L 0px R 0px
│  │  │  │  │  │  │         overflow=Overflow { scroll: TypedRect(0px×0px at (0px,0px)), paint: TypedRect(0px×0px at (0px,0px)) }
│  │  │  │  │  │  │         children=1
│  │  │  │  │  │  │         damage=BUBBLE_ISIZES
```
---
<!-- 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 #12675 (github issue number if applicable).
<!-- Either: -->
- [ ] There are tests for these changes OR
- [ ] These changes do not require tests because _____
<!-- Also, please make sure that "Allow edits from maintainers" checkbox is checked, so that we can help you if you get stuck somewhere along the way.-->
<!-- 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: 7aae164fcdb8ab308bfa0806e1123e9b7eb73a7c
--HG--
extra : subtree_source : https%3A//hg.mozilla.org/projects/converted-servo-linear
extra : subtree_revision : ce4a8508aef07608aa4f7c7a530c422a7acccbf2
		
	
			
		
			
				
	
	
		
			89 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
/* This Source Code Form is subject to the terms of the Mozilla Public
 | 
						|
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 | 
						|
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 | 
						|
 | 
						|
/// A struct that makes it easier to print out a pretty tree of data, which
 | 
						|
/// can be visually scanned more easily.
 | 
						|
pub struct PrintTree {
 | 
						|
    /// The current level of recursion.
 | 
						|
    level: u32,
 | 
						|
 | 
						|
    /// An item which is queued up, so that we can determine if we need
 | 
						|
    /// a mid-tree prefix or a branch ending prefix.
 | 
						|
    queued_item: Option<String>,
 | 
						|
}
 | 
						|
 | 
						|
impl PrintTree {
 | 
						|
    pub fn new(title: String) -> PrintTree {
 | 
						|
        println!("\u{250c} {}", title);
 | 
						|
        PrintTree {
 | 
						|
            level: 1,
 | 
						|
            queued_item: None,
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /// Descend one level in the tree with the given title string.
 | 
						|
    pub fn new_level(&mut self, queued_title: String) {
 | 
						|
        self.flush_queued_item("\u{251C}\u{2500}");
 | 
						|
 | 
						|
        self.print_level_prefix();
 | 
						|
 | 
						|
        let items: Vec<&str> = queued_title.split("\n").collect();
 | 
						|
        println!("\u{251C}\u{2500} {}", items[0]);
 | 
						|
        for i in 1..items.len() {
 | 
						|
            self.print_level_child_indentation();
 | 
						|
            print!("{}", items[i]);
 | 
						|
            if i < items.len() {
 | 
						|
                print!("\n");
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        self.level = self.level + 1;
 | 
						|
    }
 | 
						|
 | 
						|
    /// Ascend one level in the tree.
 | 
						|
    pub fn end_level(&mut self) {
 | 
						|
        self.flush_queued_item("\u{2514}\u{2500}");
 | 
						|
        self.level -= 1;
 | 
						|
    }
 | 
						|
 | 
						|
    /// Add an item to the current level in the tree.
 | 
						|
    pub fn add_item(&mut self, text: String) {
 | 
						|
        self.flush_queued_item("\u{251C}\u{2500}");
 | 
						|
        self.queued_item = Some(text);
 | 
						|
    }
 | 
						|
 | 
						|
    fn print_level_prefix(&self) {
 | 
						|
        for _ in 0..self.level {
 | 
						|
            print!("\u{2502}  ");
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    fn print_level_child_indentation(&self) {
 | 
						|
        for _ in 0..(self.level + 1) {
 | 
						|
            print!("\u{2502}  ");
 | 
						|
        }
 | 
						|
        print!("{}", " ".repeat(7));
 | 
						|
    }
 | 
						|
 | 
						|
    fn flush_queued_item(&mut self, prefix: &str) {
 | 
						|
        if let Some(queued_item) = self.queued_item.take() {
 | 
						|
            self.print_level_prefix();
 | 
						|
            let items: Vec<&str> = queued_item.split("\n").collect();
 | 
						|
            println!("{} {}", prefix, items[0]);
 | 
						|
            for i in 1..items.len() {
 | 
						|
                self.print_level_child_indentation();
 | 
						|
                print!("{}", items[i]);
 | 
						|
                if i < items.len() {
 | 
						|
                    print!("\n");
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
impl Drop for PrintTree {
 | 
						|
    fn drop(&mut self) {
 | 
						|
        self.flush_queued_item("\u{9492}\u{9472}");
 | 
						|
    }
 | 
						|
}
 |