mirror of
https://github.com/RGBCube/serenity
synced 2025-10-24 06:52:32 +00:00

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 };
|
|
};
|
|
|
|
}
|