Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(26)

Unified Diff: chrome/browser/ui/android/tab_model/android_live_tab_context.cc

Issue 2088443003: Shortcut ctrl+shift+T added on android. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Removed unused includes in recently_closed_tab_bridge.cc Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/android/tab_model/android_live_tab_context.cc
diff --git a/chrome/browser/ui/android/tab_model/android_live_tab_context.cc b/chrome/browser/ui/android/tab_model/android_live_tab_context.cc
new file mode 100644
index 0000000000000000000000000000000000000000..d6af75e8cffafd8176630ad2e016923bbbd8c67d
--- /dev/null
+++ b/chrome/browser/ui/android/tab_model/android_live_tab_context.cc
@@ -0,0 +1,136 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/android/tab_android.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/ui/android/tab_model/android_live_tab_context.h"
+#include "chrome/browser/ui/android/tab_model/tab_model.h"
+#include "chrome/browser/ui/android/tab_model/tab_model_list.h"
+#include "components/sessions/content/content_live_tab.h"
+#include "components/sessions/content/content_serialized_navigation_builder.h"
+#include "content/public/browser/browser_context.h"
+#include "content/public/browser/navigation_entry.h"
+
+
+AndroidLiveTabContext::AndroidLiveTabContext(TabModel* tab_model)
+ : tab_model_(tab_model) {}
+
+// Not supported by android.
+void AndroidLiveTabContext::ShowBrowserWindow() {
+}
+
+const SessionID& AndroidLiveTabContext::GetSessionID() const {
+ return tab_model_->SessionId();
+}
+
+int AndroidLiveTabContext::GetTabCount() const {
+ return tab_model_->GetTabCount();
+}
+
+int AndroidLiveTabContext::GetSelectedIndex() const {
+ return tab_model_->GetActiveIndex();
+}
+
+// Not supported by android.
+std::string AndroidLiveTabContext::GetAppName() const {
+ return std::string();
+}
+
+sessions::LiveTab* AndroidLiveTabContext::GetLiveTabAt(int index) const {
+ TabAndroid* tab_android = tab_model_->GetTabAt(index);
+ if (!tab_android || !tab_android->web_contents())
+ return nullptr;
+
+ return sessions::ContentLiveTab::GetForWebContents(
+ tab_android->web_contents());
+}
+
+sessions::LiveTab* AndroidLiveTabContext::GetActiveLiveTab() const {
+ content::WebContents* web_contents = tab_model_->GetActiveWebContents();
+ if (!web_contents)
+ return nullptr;
+
+ return sessions::ContentLiveTab::GetForWebContents(web_contents);
+}
+
+// Not supported by android.
+bool AndroidLiveTabContext::IsTabPinned(int index) const {
+ return false;
+}
+
+sessions::LiveTab* AndroidLiveTabContext::AddRestoredTab(
+ const std::vector<sessions::SerializedNavigationEntry>& navigations,
+ int tab_index,
+ int selected_navigation,
+ const std::string& extension_app_id,
+ bool select,
+ bool pin,
+ bool from_last_session,
+ const sessions::PlatformSpecificTabData* tab_platform_data,
+ const std::string& user_agent_override) {
+ Profile* profile = tab_model_->GetProfile();
+
+ // Prepare navigation history.
+ std::vector<std::unique_ptr<content::NavigationEntry>> nav_entries =
+ sessions::ContentSerializedNavigationBuilder::ToNavigationEntries(
+ navigations, profile);
+
+ // Restore web contents with navigation history.
+ content::WebContents* web_contents = content::WebContents::Create(
+ content::WebContents::CreateParams(profile));
+ web_contents->GetController().Restore(
+ selected_navigation,
+ content::NavigationController::RESTORE_CURRENT_SESSION,
+ &nav_entries);
+
+ // Create new tab.
+ tab_model_->CreateTab(NULL, web_contents, -1);
+ return sessions::ContentLiveTab::GetForWebContents(web_contents);
+}
+
+// Currently do nothing.
Theresa 2016/07/07 19:00:13 nit: "Currently does nothing."
xingliu 2016/07/08 21:26:48 Done.
+sessions::LiveTab* AndroidLiveTabContext::ReplaceRestoredTab(
+ const std::vector<sessions::SerializedNavigationEntry>& navigations,
+ int selected_navigation,
+ bool from_last_session,
+ const std::string& extension_app_id,
+ const sessions::PlatformSpecificTabData* tab_platform_data,
+ const std::string& user_agent_override) {
+ NOTIMPLEMENTED();
+ return nullptr;
+}
+
+// Currently do nothing.
+void AndroidLiveTabContext::CloseTab() {
+ NOTIMPLEMENTED();
+}
+
+// static.
+sessions::LiveTabContext* AndroidLiveTabContext::FindContextForWebContents(
Theresa 2016/07/07 19:00:14 Is there ever a case where this would need the fal
xingliu 2016/07/08 21:26:48 I think this is used in the flow that write the br
Theresa 2016/07/12 00:06:16 Can we add a comment to that effect so it's easier
+ const content::WebContents* contents) {
+ TabAndroid* tab_android = TabAndroid::FromWebContents(contents);
Theresa 2016/07/07 19:00:13 The comment above this method in tab_android.h say
xingliu 2016/07/08 21:26:48 Done.
+ TabModel* model = TabModelList::FindTabModelWithId(
+ tab_android->window_id().id());
+
+ return model ? model->GetLiveTabContext() : nullptr;
+}
+
+// static.
+sessions::LiveTabContext* AndroidLiveTabContext::FindContextWithID(
Theresa 2016/07/07 19:00:13 I think unit tests for the native side would be go
xingliu 2016/07/08 21:26:48 Added TODO. But current java unittest will call na
Theresa 2016/07/12 00:06:16 Thanks :) It's still (generally) good to do unit
+ SessionID::id_type desired_id) {
+ // Find the model with desired id.
+ TabModel* model = TabModelList::FindTabModelWithId(desired_id);
+
+ // if we can't find the correct model, fall back to first non-incognito model.
Theresa 2016/07/07 19:00:13 nit: capitalize If, "... fallback to the first..."
xingliu 2016/07/08 21:26:48 Done.
+ if (!model || model->IsOffTheRecord()) {
+ for (auto it = TabModelList::begin(); it != TabModelList::end(); ++it) {
+ TabModel* model = *it;
+ if (!model->IsOffTheRecord()) {
+ return model->GetLiveTabContext();
+ }
+ }
+ }
+
+ return model ? model->GetLiveTabContext() : nullptr;
+}

Powered by Google App Engine
This is Rietveld 408576698