mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-25 17:39:27 +00:00 
			
		
		
		
	...because existance of this method conflicts with the purpose of having a queue as it allows to start executing next task in the middle of ongoing task. For example: 1. SHTQ timer starts executing a task. 2. Task does SHTQ::process(). Another example: 1. SHTQ::process() start executing a task. 2. task does SHTQ::process().
		
			
				
	
	
		
			134 lines
		
	
	
	
		
			5.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
	
		
			5.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Vector.h>
 | |
| #include <LibWeb/HTML/Navigable.h>
 | |
| #include <LibWeb/HTML/NavigationType.h>
 | |
| #include <LibWeb/HTML/SessionHistoryTraversalQueue.h>
 | |
| #include <LibWeb/HTML/VisibilityState.h>
 | |
| 
 | |
| namespace Web::HTML {
 | |
| 
 | |
| // https://html.spec.whatwg.org/multipage/document-sequences.html#traversable-navigable
 | |
| class TraversableNavigable final : public Navigable {
 | |
|     JS_CELL(TraversableNavigable, Navigable);
 | |
|     JS_DECLARE_ALLOCATOR(TraversableNavigable);
 | |
| 
 | |
| public:
 | |
|     static WebIDL::ExceptionOr<JS::NonnullGCPtr<TraversableNavigable>> create_a_new_top_level_traversable(JS::NonnullGCPtr<Page>, JS::GCPtr<BrowsingContext> opener, String target_name);
 | |
|     static WebIDL::ExceptionOr<JS::NonnullGCPtr<TraversableNavigable>> create_a_fresh_top_level_traversable(JS::NonnullGCPtr<Page>, URL::URL const& initial_navigation_url, Variant<Empty, String, POSTResource> = Empty {});
 | |
| 
 | |
|     virtual ~TraversableNavigable() override;
 | |
| 
 | |
|     virtual bool is_top_level_traversable() const override;
 | |
| 
 | |
|     int current_session_history_step() const { return m_current_session_history_step; }
 | |
|     Vector<JS::NonnullGCPtr<SessionHistoryEntry>>& session_history_entries() { return m_session_history_entries; }
 | |
|     Vector<JS::NonnullGCPtr<SessionHistoryEntry>> const& session_history_entries() const { return m_session_history_entries; }
 | |
|     bool running_nested_apply_history_step() const { return m_running_nested_apply_history_step; }
 | |
| 
 | |
|     VisibilityState system_visibility_state() const { return m_system_visibility_state; }
 | |
|     void set_system_visibility_state(VisibilityState);
 | |
| 
 | |
|     struct HistoryObjectLengthAndIndex {
 | |
|         u64 script_history_length;
 | |
|         u64 script_history_index;
 | |
|     };
 | |
|     HistoryObjectLengthAndIndex get_the_history_object_length_and_index(int) const;
 | |
| 
 | |
|     enum class HistoryStepResult {
 | |
|         InitiatorDisallowed,
 | |
|         CanceledByBeforeUnload,
 | |
|         CanceledByNavigate,
 | |
|         Applied,
 | |
|     };
 | |
| 
 | |
|     HistoryStepResult apply_the_traverse_history_step(int, Optional<SourceSnapshotParams>, JS::GCPtr<Navigable>, UserNavigationInvolvement);
 | |
|     HistoryStepResult apply_the_reload_history_step();
 | |
|     enum class SynchronousNavigation : bool {
 | |
|         Yes,
 | |
|         No,
 | |
|     };
 | |
|     HistoryStepResult apply_the_push_or_replace_history_step(int step, HistoryHandlingBehavior history_handling, SynchronousNavigation);
 | |
|     HistoryStepResult update_for_navigable_creation_or_destruction();
 | |
| 
 | |
|     int get_the_used_step(int step) const;
 | |
|     Vector<JS::Handle<Navigable>> get_all_navigables_whose_current_session_history_entry_will_change_or_reload(int) const;
 | |
|     Vector<JS::Handle<Navigable>> get_all_navigables_that_only_need_history_object_length_index_update(int) const;
 | |
|     Vector<JS::Handle<Navigable>> get_all_navigables_that_might_experience_a_cross_document_traversal(int) const;
 | |
| 
 | |
|     Vector<int> get_all_used_history_steps() const;
 | |
|     void clear_the_forward_session_history();
 | |
|     void traverse_the_history_by_delta(int delta, Optional<DOM::Document&> source_document = {});
 | |
| 
 | |
|     void close_top_level_traversable();
 | |
|     void destroy_top_level_traversable();
 | |
| 
 | |
|     void append_session_history_traversal_steps(JS::SafeFunction<void()> steps)
 | |
|     {
 | |
|         m_session_history_traversal_queue.append(move(steps));
 | |
|     }
 | |
| 
 | |
|     void append_session_history_synchronous_navigation_steps(JS::NonnullGCPtr<Navigable> target_navigable, JS::SafeFunction<void()> steps)
 | |
|     {
 | |
|         m_session_history_traversal_queue.append_sync(move(steps), target_navigable);
 | |
|     }
 | |
| 
 | |
|     Page& page() { return m_page; }
 | |
|     Page const& page() const { return m_page; }
 | |
| 
 | |
|     String window_handle() const { return m_window_handle; }
 | |
|     void set_window_handle(String window_handle) { m_window_handle = move(window_handle); }
 | |
| 
 | |
| private:
 | |
|     TraversableNavigable(JS::NonnullGCPtr<Page>);
 | |
| 
 | |
|     virtual void visit_edges(Cell::Visitor&) override;
 | |
| 
 | |
|     // FIXME: Fix spec typo cancelation --> cancellation
 | |
|     HistoryStepResult apply_the_history_step(
 | |
|         int step,
 | |
|         bool check_for_cancelation,
 | |
|         Optional<SourceSnapshotParams>,
 | |
|         JS::GCPtr<Navigable> initiator_to_check,
 | |
|         Optional<UserNavigationInvolvement> user_involvement_for_navigate_events,
 | |
|         Optional<Bindings::NavigationType> navigation_type,
 | |
|         SynchronousNavigation);
 | |
| 
 | |
|     Vector<JS::NonnullGCPtr<SessionHistoryEntry>> get_session_history_entries_for_the_navigation_api(JS::NonnullGCPtr<Navigable>, int);
 | |
| 
 | |
|     // https://html.spec.whatwg.org/multipage/document-sequences.html#tn-current-session-history-step
 | |
|     int m_current_session_history_step { 0 };
 | |
| 
 | |
|     // https://html.spec.whatwg.org/multipage/document-sequences.html#tn-session-history-entries
 | |
|     Vector<JS::NonnullGCPtr<SessionHistoryEntry>> m_session_history_entries;
 | |
| 
 | |
|     // FIXME: https://html.spec.whatwg.org/multipage/document-sequences.html#tn-session-history-traversal-queue
 | |
| 
 | |
|     // https://html.spec.whatwg.org/multipage/document-sequences.html#tn-running-nested-apply-history-step
 | |
|     bool m_running_nested_apply_history_step { false };
 | |
| 
 | |
|     // https://html.spec.whatwg.org/multipage/document-sequences.html#system-visibility-state
 | |
|     VisibilityState m_system_visibility_state { VisibilityState::Visible };
 | |
| 
 | |
|     SessionHistoryTraversalQueue m_session_history_traversal_queue;
 | |
| 
 | |
|     JS::NonnullGCPtr<Page> m_page;
 | |
| 
 | |
|     String m_window_handle;
 | |
| };
 | |
| 
 | |
| struct BrowsingContextAndDocument {
 | |
|     JS::NonnullGCPtr<HTML::BrowsingContext> browsing_context;
 | |
|     JS::NonnullGCPtr<DOM::Document> document;
 | |
| };
 | |
| 
 | |
| WebIDL::ExceptionOr<BrowsingContextAndDocument> create_a_new_top_level_browsing_context_and_document(JS::NonnullGCPtr<Page> page);
 | |
| void finalize_a_same_document_navigation(JS::NonnullGCPtr<TraversableNavigable> traversable, JS::NonnullGCPtr<Navigable> target_navigable, JS::NonnullGCPtr<SessionHistoryEntry> target_entry, JS::GCPtr<SessionHistoryEntry> entry_to_replace, HistoryHandlingBehavior);
 | |
| 
 | |
| }
 |