diff options
-rw-r--r-- | Userland/Applications/Browser/History.cpp | 34 | ||||
-rw-r--r-- | Userland/Applications/Browser/History.h | 16 | ||||
-rw-r--r-- | Userland/Applications/Browser/Tab.cpp | 12 |
3 files changed, 39 insertions, 23 deletions
diff --git a/Userland/Applications/Browser/History.cpp b/Userland/Applications/Browser/History.cpp index 9a2484ea70..20dfd3b117 100644 --- a/Userland/Applications/Browser/History.cpp +++ b/Userland/Applications/Browser/History.cpp @@ -13,21 +13,24 @@ void History::dump() const dbgln("Dump {} items(s)", m_items.size()); int i = 0; for (auto& item : m_items) { - dbgln("[{}] {} {}", i, item, m_current == i ? '*' : ' '); + dbgln("[{}] {} '{}' {}", i, item.url, item.title, m_current == i ? '*' : ' '); ++i; } } -void History::push(const URL& url) +void History::push(const URL& url, const String& title) { - if (!m_items.is_empty() && m_items[m_current] == url) + if (!m_items.is_empty() && m_items[m_current].url == url) return; m_items.shrink(m_current + 1); - m_items.append(url); + m_items.append(URLTitlePair { + .url = url, + .title = title, + }); m_current++; } -URL History::current() const +History::URLTitlePair History::current() const { if (m_current == -1) return {}; @@ -52,22 +55,27 @@ void History::clear() m_current = -1; } -const Vector<URL> History::get_back_history() +void History::update_title(const String& title) { - Vector<URL> back_history; + m_items[m_current].title = title; +} + +const Vector<StringView> History::get_back_title_history() +{ + Vector<StringView> back_title_history; for (int i = m_current - 1; i >= 0; i--) { - back_history.append(m_items[i]); + back_title_history.append(m_items[i].title); } - return back_history; + return back_title_history; } -const Vector<URL> History::get_forward_history() +const Vector<StringView> History::get_forward_title_history() { - Vector<URL> forward_history; + Vector<StringView> forward_title_history; for (int i = m_current + 1; i < static_cast<int>(m_items.size()); i++) { - forward_history.append(m_items[i]); + forward_title_history.append(m_items[i].title); } - return forward_history; + return forward_title_history; } } diff --git a/Userland/Applications/Browser/History.h b/Userland/Applications/Browser/History.h index ac91a84a5b..e7891b29a1 100644 --- a/Userland/Applications/Browser/History.h +++ b/Userland/Applications/Browser/History.h @@ -13,12 +13,18 @@ namespace Browser { class History { public: + struct URLTitlePair { + URL url; + String title; + }; void dump() const; - void push(const URL&); - URL current() const; - const Vector<URL> get_back_history(); - const Vector<URL> get_forward_history(); + void push(const URL& url, const String& title); + void update_title(const String& title); + URLTitlePair current() const; + + const Vector<StringView> get_back_title_history(); + const Vector<StringView> get_forward_title_history(); void go_back(int steps = 1); void go_forward(int steps = 1); @@ -28,7 +34,7 @@ public: void clear(); private: - Vector<URL> m_items; + Vector<URLTitlePair> m_items; int m_current { -1 }; }; diff --git a/Userland/Applications/Browser/Tab.cpp b/Userland/Applications/Browser/Tab.cpp index 373e756ace..3a47c87aa6 100644 --- a/Userland/Applications/Browser/Tab.cpp +++ b/Userland/Applications/Browser/Tab.cpp @@ -98,7 +98,7 @@ Tab::Tab(BrowserWindow& window, Type type) return; int i = 0; m_go_back_context_menu = GUI::Menu::construct(); - for (auto& url : m_history.get_back_history()) { + for (auto& url : m_history.get_back_title_history()) { i++; m_go_back_context_menu->add_action(GUI::Action::create(url.to_string(), Gfx::Bitmap::load_from_file("/res/icons/16x16/filetype-html.png"), @@ -113,7 +113,7 @@ Tab::Tab(BrowserWindow& window, Type type) return; int i = 0; m_go_forward_context_menu = GUI::Menu::construct(); - for (auto& url : m_history.get_forward_history()) { + for (auto& url : m_history.get_forward_title_history()) { i++; m_go_forward_context_menu->add_action(GUI::Action::create(url.to_string(), Gfx::Bitmap::load_from_file("/res/icons/16x16/filetype-html.png"), @@ -161,7 +161,7 @@ Tab::Tab(BrowserWindow& window, Type type) // don't add to history if back or forward is pressed if (!m_is_history_navigation) - m_history.push(url); + m_history.push(url, title()); m_is_history_navigation = false; update_actions(); @@ -231,8 +231,10 @@ Tab::Tab(BrowserWindow& window, Type type) hooks().on_title_change = [this](auto& title) { if (title.is_null()) { + m_history.update_title(url().to_string()); m_title = url().to_string(); } else { + m_history.update_title(title); m_title = title; } if (on_title_change) @@ -347,14 +349,14 @@ void Tab::go_back(int steps) { m_history.go_back(steps); update_actions(); - load(m_history.current(), LoadType::HistoryNavigation); + load(m_history.current().url, LoadType::HistoryNavigation); } void Tab::go_forward(int steps) { m_history.go_forward(steps); update_actions(); - load(m_history.current(), LoadType::HistoryNavigation); + load(m_history.current().url, LoadType::HistoryNavigation); } void Tab::update_actions() |