mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-30 23:42:45 +00:00 
			
		
		
		
	 4190fd2199
			
		
	
	
		4190fd2199
		
	
	
	
	
		
			
			Our "frame" concept very closely matches what the web specs call a "browsing context", so let's rename it to that. :^) The "main frame" becomes the "top-level browsing context", and "sub-frames" are now "nested browsing contexts".
		
			
				
	
	
		
			49 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Forward.h>
 | |
| #include <LibWeb/Forward.h>
 | |
| #include <LibWeb/Loader/Resource.h>
 | |
| 
 | |
| namespace Web {
 | |
| 
 | |
| constexpr size_t maximum_redirects_allowed = 20;
 | |
| 
 | |
| class FrameLoader final
 | |
|     : public ResourceClient {
 | |
| public:
 | |
|     enum class Type {
 | |
|         Navigation,
 | |
|         Reload,
 | |
|         IFrame,
 | |
|     };
 | |
| 
 | |
|     explicit FrameLoader(BrowsingContext&);
 | |
|     ~FrameLoader();
 | |
| 
 | |
|     bool load(const URL&, Type);
 | |
|     bool load(const LoadRequest&, Type);
 | |
| 
 | |
|     void load_html(const StringView&, const URL&);
 | |
| 
 | |
|     BrowsingContext& browsing_context() { return m_browsing_context; }
 | |
|     const BrowsingContext& browsing_context() const { return m_browsing_context; }
 | |
| 
 | |
| private:
 | |
|     // ^ResourceClient
 | |
|     virtual void resource_did_load() override;
 | |
|     virtual void resource_did_fail() override;
 | |
| 
 | |
|     void load_error_page(const URL& failed_url, const String& error_message);
 | |
|     bool parse_document(DOM::Document&, const ByteBuffer& data);
 | |
| 
 | |
|     BrowsingContext& m_browsing_context;
 | |
|     size_t m_redirects_count { 0 };
 | |
| };
 | |
| 
 | |
| }
 |