| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include <algorithm> | 5 #include <algorithm> |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/json/json_writer.h" | 8 #include "base/json/json_writer.h" |
| 9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
| 10 #include "base/string_number_conversions.h" | 10 #include "base/string_number_conversions.h" |
| 11 #include "base/stringprintf.h" | 11 #include "base/stringprintf.h" |
| 12 #include "base/utf_string_conversions.h" | 12 #include "base/utf_string_conversions.h" |
| 13 #include "base/values.h" | 13 #include "base/values.h" |
| 14 #include "chrome/browser/browser_process.h" | 14 #include "chrome/browser/browser_process.h" |
| 15 #include "chrome/browser/debugger/devtools_window.h" | 15 #include "chrome/browser/debugger/devtools_window.h" |
| 16 #include "chrome/browser/extensions/api/debugger/debugger_api.h" | 16 #include "chrome/browser/extensions/api/debugger/debugger_api.h" |
| 17 #include "chrome/browser/extensions/extension_service.h" | 17 #include "chrome/browser/extensions/extension_service.h" |
| 18 #include "chrome/browser/extensions/extension_system.h" | 18 #include "chrome/browser/extensions/extension_system.h" |
| 19 #include "chrome/browser/file_select_helper.h" | 19 #include "chrome/browser/file_select_helper.h" |
| 20 #include "chrome/browser/prefs/pref_service.h" | 20 #include "chrome/browser/prefs/pref_service.h" |
| 21 #include "chrome/browser/prefs/scoped_user_pref_update.h" | 21 #include "chrome/browser/prefs/scoped_user_pref_update.h" |
| 22 #include "chrome/browser/profiles/profile.h" | 22 #include "chrome/browser/profiles/profile.h" |
| 23 #include "chrome/browser/sessions/session_tab_helper.h" | 23 #include "chrome/browser/sessions/session_tab_helper.h" |
| 24 #include "chrome/browser/themes/theme_service.h" | 24 #include "chrome/browser/themes/theme_service.h" |
| 25 #include "chrome/browser/themes/theme_service_factory.h" | 25 #include "chrome/browser/themes/theme_service_factory.h" |
| 26 #include "chrome/browser/ui/browser.h" | 26 #include "chrome/browser/ui/browser.h" |
| 27 #include "chrome/browser/ui/browser_list.h" | 27 #include "chrome/browser/ui/browser_list.h" |
| 28 #include "chrome/browser/ui/browser_list_impl.h" |
| 28 #include "chrome/browser/ui/browser_window.h" | 29 #include "chrome/browser/ui/browser_window.h" |
| 29 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 30 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| 30 #include "chrome/common/chrome_notification_types.h" | 31 #include "chrome/common/chrome_notification_types.h" |
| 31 #include "chrome/common/chrome_switches.h" | 32 #include "chrome/common/chrome_switches.h" |
| 32 #include "chrome/common/pref_names.h" | 33 #include "chrome/common/pref_names.h" |
| 33 #include "chrome/common/render_messages.h" | 34 #include "chrome/common/render_messages.h" |
| 34 #include "chrome/common/url_constants.h" | 35 #include "chrome/common/url_constants.h" |
| 35 #include "content/public/browser/content_browser_client.h" | 36 #include "content/public/browser/content_browser_client.h" |
| 36 #include "content/public/browser/devtools_agent_host_registry.h" | 37 #include "content/public/browser/devtools_agent_host_registry.h" |
| 37 #include "content/public/browser/devtools_manager.h" | 38 #include "content/public/browser/devtools_manager.h" |
| (...skipping 358 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 396 browser_->tab_strip_model()->AddWebContents( | 397 browser_->tab_strip_model()->AddWebContents( |
| 397 web_contents_, -1, content::PAGE_TRANSITION_AUTO_TOPLEVEL, | 398 web_contents_, -1, content::PAGE_TRANSITION_AUTO_TOPLEVEL, |
| 398 TabStripModel::ADD_ACTIVE); | 399 TabStripModel::ADD_ACTIVE); |
| 399 } | 400 } |
| 400 | 401 |
| 401 bool DevToolsWindow::FindInspectedBrowserAndTabIndex(Browser** browser, | 402 bool DevToolsWindow::FindInspectedBrowserAndTabIndex(Browser** browser, |
| 402 int* tab) { | 403 int* tab) { |
| 403 if (!inspected_web_contents_) | 404 if (!inspected_web_contents_) |
| 404 return false; | 405 return false; |
| 405 | 406 |
| 406 for (BrowserList::const_iterator it = BrowserList::begin(); | 407 bool found = FindInspectedBrowserAndTabIndexFromBrowserList( |
| 407 it != BrowserList::end(); ++it) { | 408 chrome::BrowserListImpl::GetInstance(chrome::HOST_DESKTOP_TYPE_NATIVE), |
| 409 browser, |
| 410 tab); |
| 411 // On Windows 8 we can have the desktop environment and the ASH environment |
| 412 // active concurrently. If we fail to find the inspected web contents in the |
| 413 // native browser list, then we should look in the ASH browser list. |
| 414 #if defined(OS_WIN) && defined(USE_AURA) |
| 415 if (!found) { |
| 416 found = FindInspectedBrowserAndTabIndexFromBrowserList( |
| 417 chrome::BrowserListImpl::GetInstance(chrome::HOST_DESKTOP_TYPE_ASH), |
| 418 browser, |
| 419 tab); |
| 420 } |
| 421 #endif |
| 422 return found; |
| 423 } |
| 424 |
| 425 bool DevToolsWindow::FindInspectedBrowserAndTabIndexFromBrowserList( |
| 426 chrome::BrowserListImpl* browser_list, |
| 427 Browser** browser, |
| 428 int* tab) { |
| 429 if (!inspected_web_contents_) |
| 430 return false; |
| 431 |
| 432 for (chrome::BrowserListImpl::const_iterator it = browser_list->begin(); |
| 433 it != browser_list->end(); ++it) { |
| 408 int tab_index = (*it)->tab_strip_model()->GetIndexOfWebContents( | 434 int tab_index = (*it)->tab_strip_model()->GetIndexOfWebContents( |
| 409 inspected_web_contents_); | 435 inspected_web_contents_); |
| 410 if (tab_index != TabStripModel::kNoTab) { | 436 if (tab_index != TabStripModel::kNoTab) { |
| 411 *browser = *it; | 437 *browser = *it; |
| 412 *tab = tab_index; | 438 *tab = tab_index; |
| 413 return true; | 439 return true; |
| 414 } | 440 } |
| 415 } | 441 } |
| 416 return false; | 442 return false; |
| 417 } | 443 } |
| (...skipping 461 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 879 | 905 |
| 880 // static | 906 // static |
| 881 DevToolsDockSide DevToolsWindow::SideFromString( | 907 DevToolsDockSide DevToolsWindow::SideFromString( |
| 882 const std::string& dock_side) { | 908 const std::string& dock_side) { |
| 883 if (dock_side == kDockSideRight) | 909 if (dock_side == kDockSideRight) |
| 884 return DEVTOOLS_DOCK_SIDE_RIGHT; | 910 return DEVTOOLS_DOCK_SIDE_RIGHT; |
| 885 if (dock_side == kDockSideBottom) | 911 if (dock_side == kDockSideBottom) |
| 886 return DEVTOOLS_DOCK_SIDE_BOTTOM; | 912 return DEVTOOLS_DOCK_SIDE_BOTTOM; |
| 887 return DEVTOOLS_DOCK_SIDE_UNDOCKED; | 913 return DEVTOOLS_DOCK_SIDE_UNDOCKED; |
| 888 } | 914 } |
| OLD | NEW |