| 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/ash/launcher/app_shortcut_launcher_item_controller.h
     " | 5 #include "chrome/browser/ui/ash/launcher/app_shortcut_launcher_item_controller.h
     " | 
| 6 | 6 | 
| 7 #include "ash/wm/window_util.h" | 7 #include "ash/wm/window_util.h" | 
| 8 #include "chrome/browser/favicon/favicon_tab_helper.h" | 8 #include "chrome/browser/favicon/favicon_tab_helper.h" | 
| 9 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item.h" | 9 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item.h" | 
| 10 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item_tab.h" | 10 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item_tab.h" | 
| 11 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller.h" | 11 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller.h" | 
| 12 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller_per_app.h" | 12 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller_per_app.h" | 
| 13 #include "chrome/browser/ui/ash/launcher/launcher_item_controller.h" | 13 #include "chrome/browser/ui/ash/launcher/launcher_item_controller.h" | 
| 14 #include "chrome/browser/ui/browser.h" | 14 #include "chrome/browser/ui/browser.h" | 
| 15 #include "chrome/browser/ui/browser_finder.h" | 15 #include "chrome/browser/ui/browser_finder.h" | 
| 16 #include "chrome/browser/ui/browser_list.h" | 16 #include "chrome/browser/ui/browser_list_impl.h" | 
| 17 #include "chrome/browser/ui/browser_window.h" | 17 #include "chrome/browser/ui/browser_window.h" | 
| 18 #include "chrome/browser/ui/extensions/native_app_window.h" | 18 #include "chrome/browser/ui/extensions/native_app_window.h" | 
|  | 19 #include "chrome/browser/ui/host_desktop.h" | 
| 19 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 20 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 
| 20 #include "content/public/browser/web_contents.h" | 21 #include "content/public/browser/web_contents.h" | 
| 21 | 22 | 
| 22 using extensions::Extension; | 23 using extensions::Extension; | 
| 23 | 24 | 
| 24 // Item controller for an app shortcut. Shortcuts track app and launcher ids, | 25 // Item controller for an app shortcut. Shortcuts track app and launcher ids, | 
| 25 // but do not have any associated windows (opening a shortcut will replace the | 26 // but do not have any associated windows (opening a shortcut will replace the | 
| 26 // item with the appropriate LauncherItemController type). | 27 // item with the appropriate LauncherItemController type). | 
| 27 AppShortcutLauncherItemController::AppShortcutLauncherItemController( | 28 AppShortcutLauncherItemController::AppShortcutLauncherItemController( | 
| 28     const std::string& app_id, | 29     const std::string& app_id, | 
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 137   refocus_pattern.SetMatchAllURLs(true); | 138   refocus_pattern.SetMatchAllURLs(true); | 
| 138 | 139 | 
| 139   if (!refocus_url_.is_empty()) { | 140   if (!refocus_url_.is_empty()) { | 
| 140     refocus_pattern.SetMatchAllURLs(false); | 141     refocus_pattern.SetMatchAllURLs(false); | 
| 141     refocus_pattern.Parse(refocus_url_.spec()); | 142     refocus_pattern.Parse(refocus_url_.spec()); | 
| 142   } | 143   } | 
| 143 | 144 | 
| 144   const Extension* extension = | 145   const Extension* extension = | 
| 145       launcher_controller()->GetExtensionForAppID(app_id()); | 146       launcher_controller()->GetExtensionForAppID(app_id()); | 
| 146 | 147 | 
| 147   for (BrowserList::const_reverse_iterator it = | 148   const chrome::BrowserListImpl* ash_browser_list = | 
| 148            BrowserList::begin_last_active(); | 149       chrome::BrowserListImpl::GetInstance(chrome::HOST_DESKTOP_TYPE_ASH); | 
| 149        it != BrowserList::end_last_active(); ++it) { | 150   for (chrome::BrowserListImpl::const_reverse_iterator it = | 
|  | 151            ash_browser_list->begin_last_active(); | 
|  | 152        it != ash_browser_list->end_last_active(); ++it) { | 
| 150     Browser* browser = *it; | 153     Browser* browser = *it; | 
| 151     TabStripModel* tab_strip = browser->tab_strip_model(); | 154     TabStripModel* tab_strip = browser->tab_strip_model(); | 
| 152     // We start to enumerate from the active index. | 155     // We start to enumerate from the active index. | 
| 153     int active_index = tab_strip->active_index(); | 156     int active_index = tab_strip->active_index(); | 
| 154     for (int index = 0; index  < tab_strip->count(); index++) { | 157     for (int index = 0; index  < tab_strip->count(); index++) { | 
| 155       content::WebContents* web_contents = tab_strip->GetWebContentsAt( | 158       content::WebContents* web_contents = tab_strip->GetWebContentsAt( | 
| 156           (index + active_index) % tab_strip->count()); | 159           (index + active_index) % tab_strip->count()); | 
| 157       const GURL tab_url = web_contents->GetURL(); | 160       const GURL tab_url = web_contents->GetURL(); | 
| 158       // There are three ways to identify the association of a URL with this | 161       // There are three ways to identify the association of a URL with this | 
| 159       // extension: | 162       // extension: | 
| 160       // - The refocus pattern is matched (needed for apps like drive). | 163       // - The refocus pattern is matched (needed for apps like drive). | 
| 161       // - The extension's origin + extent gets matched. | 164       // - The extension's origin + extent gets matched. | 
| 162       // - The launcher controller knows that the tab got created for this app. | 165       // - The launcher controller knows that the tab got created for this app. | 
| 163       if ((!refocus_pattern.match_all_urls() && | 166       if ((!refocus_pattern.match_all_urls() && | 
| 164            refocus_pattern.MatchesURL(tab_url)) || | 167            refocus_pattern.MatchesURL(tab_url)) || | 
| 165           (extension->OverlapsWithOrigin(tab_url) && | 168           (extension->OverlapsWithOrigin(tab_url) && | 
| 166            extension->web_extent().MatchesURL(tab_url)) || | 169            extension->web_extent().MatchesURL(tab_url)) || | 
| 167           launcher_controller()->GetPerAppInterface()-> | 170           launcher_controller()->GetPerAppInterface()-> | 
| 168              IsWebContentHandledByApplication(web_contents, app_id())) | 171              IsWebContentHandledByApplication(web_contents, app_id())) | 
| 169         items.push_back(web_contents); | 172         items.push_back(web_contents); | 
| 170     } | 173     } | 
| 171   } | 174   } | 
| 172   return items; | 175   return items; | 
| 173 } | 176 } | 
| OLD | NEW | 
|---|