| // Copyright (c) 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. |
| |
| #ifndef CHROME_BROWSER_UI_SINGLETON_TABS_H_ |
| #define CHROME_BROWSER_UI_SINGLETON_TABS_H_ |
| |
| #include "chrome/browser/ui/browser_navigator_params.h" |
| |
| class Browser; |
| class GURL; |
| |
| // Methods for opening "singleton tabs". Tabs are guaranteed unique by varying |
| // metrics within a particular Browser window. |
| |
| // Core singleton tab API: |
| |
| // Show a given a URL. If a tab with the same URL (ignoring the ref) is |
| // already visible in this browser, it becomes selected. Otherwise a new tab |
| // is created. |
| void ShowSingletonTab(Browser* browser, const GURL& url); |
| |
| // Same as ShowSingletonTab, but does not ignore ref. |
| void ShowSingletonTabRespectRef(Browser* browser, const GURL& url); |
| |
| // As ShowSingletonTab, but if the current tab is the new tab page or |
| // about:blank, then overwrite it with the passed contents. |
| void ShowSingletonTabOverwritingNTP(Browser* browser, NavigateParams params); |
| |
| // Creates a NavigateParams struct for a singleton tab navigation. |
| NavigateParams GetSingletonTabNavigateParams(Browser* browser, const GURL& url); |
| |
| // If the given navigational URL is already open in |browser|, return |
| // the tab and tab index for it. Otherwise, returns -1. |
| int GetIndexOfExistingTab(Browser* browser, const NavigateParams& params); |
| |
| // This simply calls GetIndexOfExistingTab() for each browser that |
| // matches the passed |profile|, and returns the first found tab. |
| std::pair<Browser*, int> GetIndexAndBrowserOfExistingTab( |
| Profile* profile, |
| const NavigateParams& params); |
| |
| #endif // CHROME_BROWSER_UI_SINGLETON_TABS_H_ |