| 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 "chrome/browser/ui/browser_finder.h" | 5 #include "chrome/browser/ui/browser_finder.h" |
| 6 | 6 |
| 7 #include "chrome/browser/profiles/profile.h" | 7 #include "chrome/browser/profiles/profile.h" |
| 8 #include "chrome/browser/ui/browser_iterator.h" | 8 #include "chrome/browser/ui/browser_iterator.h" |
| 9 #include "chrome/browser/ui/browser_list.h" | 9 #include "chrome/browser/ui/browser_list.h" |
| 10 #include "chrome/browser/ui/browser_window.h" | 10 #include "chrome/browser/ui/browser_window.h" |
| (...skipping 24 matching lines...) Expand all Loading... |
| 35 // . If it contains kMatchOriginalProfile then the original profile of the | 35 // . If it contains kMatchOriginalProfile then the original profile of the |
| 36 // browser must match |profile->GetOriginalProfile()|. This is used to match | 36 // browser must match |profile->GetOriginalProfile()|. This is used to match |
| 37 // incognito windows. | 37 // incognito windows. |
| 38 // . If it contains kMatchCanSupportWindowFeature | 38 // . If it contains kMatchCanSupportWindowFeature |
| 39 // |CanSupportWindowFeature(window_feature)| must return true. | 39 // |CanSupportWindowFeature(window_feature)| must return true. |
| 40 // . If it contains kMatchTabbed, the browser must be a tabbed browser. | 40 // . If it contains kMatchTabbed, the browser must be a tabbed browser. |
| 41 bool BrowserMatches(Browser* browser, | 41 bool BrowserMatches(Browser* browser, |
| 42 Profile* profile, | 42 Profile* profile, |
| 43 Browser::WindowFeature window_feature, | 43 Browser::WindowFeature window_feature, |
| 44 uint32 match_types) { | 44 uint32 match_types) { |
| 45 if (match_types & kMatchCanSupportWindowFeature && | 45 if ((match_types & kMatchCanSupportWindowFeature) && |
| 46 !browser->CanSupportWindowFeature(window_feature)) { | 46 !browser->CanSupportWindowFeature(window_feature)) { |
| 47 return false; | 47 return false; |
| 48 } | 48 } |
| 49 | 49 |
| 50 bool matches_profile = browser->profile() == profile; | |
| 51 #if defined(OS_CHROMEOS) | 50 #if defined(OS_CHROMEOS) |
| 52 // Get the profile on which the window is currently shown. | 51 // Get the profile on which the window is currently shown. |
| 53 // MultiUserWindowManager might be NULL under test scenario. | 52 // MultiUserWindowManager might be NULL under test scenario. |
| 54 chrome::MultiUserWindowManager* const window_manager = | 53 chrome::MultiUserWindowManager* const window_manager = |
| 55 chrome::MultiUserWindowManager::GetInstance(); | 54 chrome::MultiUserWindowManager::GetInstance(); |
| 55 Profile* shown_profile = nullptr; |
| 56 if (window_manager) { | 56 if (window_manager) { |
| 57 const std::string& shown_user_id = window_manager->GetUserPresentingWindow( | 57 const std::string& shown_user_id = window_manager->GetUserPresentingWindow( |
| 58 browser->window()->GetNativeWindow()); | 58 browser->window()->GetNativeWindow()); |
| 59 Profile* shown_profile = | 59 shown_profile = shown_user_id.empty() |
| 60 shown_user_id.empty() | 60 ? nullptr |
| 61 ? nullptr | 61 : multi_user_util::GetProfileFromUserID(shown_user_id); |
| 62 : multi_user_util::GetProfileFromUserID(shown_user_id); | |
| 63 matches_profile &= !shown_profile || shown_profile == profile; | |
| 64 } | 62 } |
| 65 #endif | 63 #endif |
| 66 | 64 |
| 67 if (match_types & kMatchOriginalProfile) { | 65 if (match_types & kMatchOriginalProfile) { |
| 68 if (browser->profile()->GetOriginalProfile() != | 66 if (browser->profile()->GetOriginalProfile() != |
| 69 profile->GetOriginalProfile()) | 67 profile->GetOriginalProfile()) |
| 70 return false; | 68 return false; |
| 71 } else if (!matches_profile) { | 69 #if defined(OS_CHROMEOS) |
| 72 return false; | 70 if (shown_profile && |
| 71 shown_profile->GetOriginalProfile() != profile->GetOriginalProfile()) { |
| 72 return false; |
| 73 } |
| 74 #endif |
| 75 } else { |
| 76 if (browser->profile() != profile) |
| 77 return false; |
| 78 #if defined(OS_CHROMEOS) |
| 79 if (shown_profile && shown_profile != profile) |
| 80 return false; |
| 81 #endif |
| 73 } | 82 } |
| 74 | 83 |
| 75 if (match_types & kMatchTabbed) | 84 if (match_types & kMatchTabbed) |
| 76 return browser->is_type_tabbed(); | 85 return browser->is_type_tabbed(); |
| 77 | 86 |
| 78 return true; | 87 return true; |
| 79 } | 88 } |
| 80 | 89 |
| 81 // Returns the first browser in the specified iterator that returns true from | 90 // Returns the first browser in the specified iterator that returns true from |
| 82 // |BrowserMatches|, or null if no browsers match the arguments. See | 91 // |BrowserMatches|, or null if no browsers match the arguments. See |
| (...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 224 | 233 |
| 225 size_t GetBrowserCount(Profile* profile, HostDesktopType type) { | 234 size_t GetBrowserCount(Profile* profile, HostDesktopType type) { |
| 226 return GetBrowserCountImpl(profile, type, kMatchAny); | 235 return GetBrowserCountImpl(profile, type, kMatchAny); |
| 227 } | 236 } |
| 228 | 237 |
| 229 size_t GetTabbedBrowserCount(Profile* profile, HostDesktopType type) { | 238 size_t GetTabbedBrowserCount(Profile* profile, HostDesktopType type) { |
| 230 return GetBrowserCountImpl(profile, type, kMatchTabbed); | 239 return GetBrowserCountImpl(profile, type, kMatchTabbed); |
| 231 } | 240 } |
| 232 | 241 |
| 233 } // namespace chrome | 242 } // namespace chrome |
| OLD | NEW |