mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-28 07:12:07 +00:00 
			
		
		
		
	 c1161111a7
			
		
	
	
		c1161111a7
		
	
	
	
	
		
			
			If the loading of iframe's navigable has not finished by the time FrameBox layout occurs, we should not crash. Fixes https://github.com/SerenityOS/serenity/issues/22874
		
			
				
	
	
		
			41 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibWeb/DOM/Document.h>
 | |
| #include <LibWeb/Layout/FrameBox.h>
 | |
| #include <LibWeb/Layout/Viewport.h>
 | |
| #include <LibWeb/Painting/NestedBrowsingContextPaintable.h>
 | |
| 
 | |
| namespace Web::Layout {
 | |
| 
 | |
| FrameBox::FrameBox(DOM::Document& document, DOM::Element& element, NonnullRefPtr<CSS::StyleProperties> style)
 | |
|     : ReplacedBox(document, element, move(style))
 | |
| {
 | |
| }
 | |
| 
 | |
| FrameBox::~FrameBox() = default;
 | |
| 
 | |
| void FrameBox::prepare_for_replaced_layout()
 | |
| {
 | |
|     // FIXME: Do proper error checking, etc.
 | |
|     set_natural_width(dom_node().get_attribute_value(HTML::AttributeNames::width).to_number<int>().value_or(300));
 | |
|     set_natural_height(dom_node().get_attribute_value(HTML::AttributeNames::height).to_number<int>().value_or(150));
 | |
| }
 | |
| 
 | |
| void FrameBox::did_set_content_size()
 | |
| {
 | |
|     ReplacedBox::did_set_content_size();
 | |
| 
 | |
|     if (dom_node().content_navigable())
 | |
|         dom_node().content_navigable()->set_size(paintable_box()->content_size());
 | |
| }
 | |
| 
 | |
| JS::GCPtr<Painting::Paintable> FrameBox::create_paintable() const
 | |
| {
 | |
|     return Painting::NestedBrowsingContextPaintable::create(*this);
 | |
| }
 | |
| 
 | |
| }
 |