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

Unified Diff: chrome/browser/metro_viewer/chrome_metro_viewer_process_host_aurawin.cc

Issue 1586843002: Remove remote tree host and some related input and metro_driver code (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@metro-mode-3
Patch Set: remove ash_unittests from being run Created 4 years, 11 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/metro_viewer/chrome_metro_viewer_process_host_aurawin.cc
diff --git a/chrome/browser/metro_viewer/chrome_metro_viewer_process_host_aurawin.cc b/chrome/browser/metro_viewer/chrome_metro_viewer_process_host_aurawin.cc
deleted file mode 100644
index 1c993f878d5459c7d415aef32db6cc47e95f10a3..0000000000000000000000000000000000000000
--- a/chrome/browser/metro_viewer/chrome_metro_viewer_process_host_aurawin.cc
+++ /dev/null
@@ -1,174 +0,0 @@
-// Copyright 2012 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/metro_viewer/chrome_metro_viewer_process_host_aurawin.h"
-
-#include "ash/display/display_info.h"
-#include "ash/display/display_manager.h"
-#include "ash/host/ash_remote_window_tree_host_win.h"
-#include "ash/shell.h"
-#include "ash/wm/window_positioner.h"
-#include "base/logging.h"
-#include "base/memory/ref_counted.h"
-#include "base/strings/stringprintf.h"
-#include "chrome/browser/browser_process.h"
-#include "chrome/browser/browser_process_platform_part_aurawin.h"
-#include "chrome/browser/browser_shutdown.h"
-#include "chrome/browser/chrome_notification_types.h"
-#include "chrome/browser/lifetime/application_lifetime.h"
-#include "chrome/browser/profiles/profile_manager.h"
-#include "chrome/browser/search_engines/template_url_service_factory.h"
-#include "chrome/browser/ui/ash/ash_init.h"
-#include "chrome/browser/ui/browser.h"
-#include "chrome/browser/ui/browser_list.h"
-#include "chrome/browser/ui/browser_navigator.h"
-#include "chrome/browser/ui/browser_navigator_params.h"
-#include "chrome/browser/ui/browser_window.h"
-#include "chrome/browser/ui/host_desktop.h"
-#include "chrome/browser/ui/tabs/tab_strip_model.h"
-#include "chrome/common/env_vars.h"
-#include "components/search_engines/util.h"
-#include "content/public/browser/browser_thread.h"
-#include "content/public/browser/gpu_data_manager.h"
-#include "content/public/browser/notification_service.h"
-#include "content/public/browser/page_navigator.h"
-#include "content/public/browser/web_contents.h"
-#include "ui/aura/remote_window_tree_host_win.h"
-#include "ui/gfx/win/dpi.h"
-#include "ui/metro_viewer/metro_viewer_messages.h"
-#include "url/gurl.h"
-
-namespace {
-
-void CloseOpenAshBrowsers() {
- BrowserList* browser_list =
- BrowserList::GetInstance(chrome::HOST_DESKTOP_TYPE_ASH);
- if (browser_list) {
- for (BrowserList::const_iterator i = browser_list->begin();
- i != browser_list->end(); ++i) {
- Browser* browser = *i;
- browser->window()->Close();
- // If the attempt to Close the browser fails due to unload handlers on
- // the page or in progress downloads, etc, destroy all tabs on the page.
- while (browser->tab_strip_model()->count())
- delete browser->tab_strip_model()->GetWebContentsAt(0);
- }
- }
-}
-
-void OpenURL(const GURL& url) {
- chrome::NavigateParams params(
- ProfileManager::GetActiveUserProfile(),
- GURL(url),
- ui::PAGE_TRANSITION_TYPED);
- params.disposition = NEW_FOREGROUND_TAB;
- params.host_desktop_type = chrome::HOST_DESKTOP_TYPE_ASH;
- chrome::Navigate(&params);
-}
-
-} // namespace
-
-ChromeMetroViewerProcessHost::ChromeMetroViewerProcessHost()
- : MetroViewerProcessHost(
- content::BrowserThread::GetMessageLoopProxyForThread(
- content::BrowserThread::IO)) {
- chrome::IncrementKeepAliveCount();
-}
-
-ChromeMetroViewerProcessHost::~ChromeMetroViewerProcessHost() {
-}
-
-void ChromeMetroViewerProcessHost::OnChannelError() {
- // TODO(cpu): At some point we only close the browser. Right now this
- // is very convenient for developing.
- DVLOG(1) << "viewer channel error : Quitting browser";
-
- // Unset environment variable to let breakpad know that metro process wasn't
- // connected.
- ::SetEnvironmentVariableA(env_vars::kMetroConnected, NULL);
-
- // It seems possible that channel is connected, but ASH desktop is not yet
- // created (instance is still NULL) and we receive channel error.
- if (aura::RemoteWindowTreeHostWin::Instance()) {
- aura::RemoteWindowTreeHostWin::Instance()->Disconnected();
-
- chrome::DecrementKeepAliveCount();
-
- // If browser is trying to quit, we shouldn't reenter the process.
- // TODO(shrikant): In general there seem to be issues with how AttemptExit
- // reentry works. In future release please clean up related code.
- if (!browser_shutdown::IsTryingToQuit()) {
- CloseOpenAshBrowsers();
- chrome::CloseAsh();
- }
- // Tell the rest of Chrome about it.
- content::NotificationService::current()->Notify(
- chrome::NOTIFICATION_ASH_SESSION_ENDED,
- content::NotificationService::AllSources(),
- content::NotificationService::NoDetails());
- return;
- }
-
- chrome::DecrementKeepAliveCount();
-
- // This will delete the MetroViewerProcessHost object. Don't access member
- // variables/functions after this call.
- g_browser_process->platform_part()->OnMetroViewerProcessTerminated();
-}
-
-void ChromeMetroViewerProcessHost::OnChannelConnected(int32_t /*peer_pid*/) {
- DVLOG(1) << "ChromeMetroViewerProcessHost::OnChannelConnected: ";
- // Set environment variable to let breakpad know that metro process was
- // connected.
- ::SetEnvironmentVariableA(env_vars::kMetroConnected, "1");
-}
-
-void ChromeMetroViewerProcessHost::OnSetTargetSurface(
- gfx::NativeViewId target_surface,
- float device_scale) {
- HWND hwnd = reinterpret_cast<HWND>(target_surface);
-
- gfx::SetDefaultDeviceScaleFactor(device_scale);
- chrome::OpenAsh(hwnd);
- DCHECK(aura::RemoteWindowTreeHostWin::Instance());
- DCHECK_EQ(hwnd, aura::RemoteWindowTreeHostWin::Instance()->remote_window());
- ash::Shell::GetInstance()->CreateShelf();
- ash::Shell::GetInstance()->ShowShelf();
-
- // Tell our root window host that the viewer has connected.
- aura::RemoteWindowTreeHostWin::Instance()->Connected(this);
-
- // On Windows 8 ASH we default to SHOW_STATE_MAXIMIZED for the browser
- // window. This is to ensure that we honor metro app conventions by default.
- ash::WindowPositioner::SetMaximizeFirstWindow(true);
- // Tell the rest of Chrome that Ash is running.
- content::NotificationService::current()->Notify(
- chrome::NOTIFICATION_ASH_SESSION_STARTED,
- content::NotificationService::AllSources(),
- content::NotificationService::NoDetails());
-}
-
-void ChromeMetroViewerProcessHost::OnOpenURL(const base::string16& url) {
- OpenURL(GURL(url));
-}
-
-void ChromeMetroViewerProcessHost::OnHandleSearchRequest(
- const base::string16& search_string) {
- GURL url(GetDefaultSearchURLForSearchTerms(
- TemplateURLServiceFactory::GetForProfile(
- ProfileManager::GetActiveUserProfile()), search_string));
- if (url.is_valid())
- OpenURL(url);
-}
-
-void ChromeMetroViewerProcessHost::OnWindowSizeChanged(uint32_t width,
- uint32_t height) {
- std::vector<ash::DisplayInfo> info_list;
- info_list.push_back(ash::DisplayInfo::CreateFromSpec(
- base::StringPrintf("%dx%d*%f", width, height, gfx::GetDPIScale())));
- ash::Shell::GetInstance()->display_manager()->OnNativeDisplaysChanged(
- info_list);
- aura::RemoteWindowTreeHostWin::Instance()->HandleWindowSizeChanged(width,
- height);
-}

Powered by Google App Engine
This is Rietveld 408576698