Chromium Code Reviews| Index: chrome/browser/extensions/chrome_extension_function_details.h |
| diff --git a/chrome/browser/extensions/chrome_extension_function_details.h b/chrome/browser/extensions/chrome_extension_function_details.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..046e43c9badc7a2f90e08a4eea0cc87f4e96b573 |
| --- /dev/null |
| +++ b/chrome/browser/extensions/chrome_extension_function_details.h |
| @@ -0,0 +1,71 @@ |
| +// Copyright 2014 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_EXTENSIONS_CHROME_EXTENSION_FUNCTION_DETAILS_H_ |
| +#define CHROME_BROWSER_EXTENSIONS_CHROME_EXTENSION_FUNCTION_DETAILS_H_ |
| + |
| +#include "base/macros.h" |
| + |
| +class Browser; |
| +class Profile; |
| +class UIThreadExtensionFunction; |
| + |
| +namespace content { |
| +class WebContents; |
| +} |
| + |
| +namespace extensions { |
| +class WindowController; |
| +} // namespace extensions |
| + |
| +class ChromeExtensionFunctionDetails { |
|
Yoyo Zhou
2014/09/04 23:41:59
class description comment?
Ken Rockot(use gerrit already)
2014/09/05 00:45:02
Done.
|
| + public: |
| + explicit ChromeExtensionFunctionDetails(UIThreadExtensionFunction* function); |
| + ~ChromeExtensionFunctionDetails(); |
| + |
| + Profile* GetProfile() const; |
| + |
| + // Returns true if this function (and the profile and extension that it was |
| + // invoked from) can operate on the window wrapped by |window_controller|. |
| + bool CanOperateOnWindow( |
| + const extensions::WindowController* window_controller) const; |
| + |
| + // Gets the "current" browser, if any. |
| + // |
| + // Many extension APIs operate relative to the current browser, which is the |
| + // browser the calling code is running inside of. For example, popups, tabs, |
| + // and infobars all have a containing browser, but background pages and |
| + // notification bubbles do not. |
| + // |
| + // If there is no containing window, the current browser defaults to the |
| + // foremost one. |
| + // |
| + // Incognito browsers are not considered unless the calling extension has |
| + // incognito access enabled. |
| + // |
| + // This method can return NULL if there is no matching browser, which can |
| + // happen if only incognito windows are open, or early in startup or shutdown |
| + // shutdown when there are no active windows. |
| + // |
| + // TODO(stevenjb): Replace this with GetExtensionWindowController(). |
| + Browser* GetCurrentBrowser() const; |
| + |
| + // Same as above but uses WindowControllerList instead of BrowserList. |
| + extensions::WindowController* GetExtensionWindowController() const; |
| + |
| + // Gets the "current" web contents if any. If there is no associated web |
| + // contents then defaults to the foremost one. |
| + content::WebContents* GetAssociatedWebContents(); |
| + |
| + private: |
| + // The function for which these details have been created. Must outlive the |
| + // ChromeExtensionFunctionDetails instance; this should not be a problem |
| + // since such instances should only be created and owned exclusively by |
|
Yoyo Zhou
2014/09/04 23:41:58
This doesn't look exactly as you've described in t
Ken Rockot(use gerrit already)
2014/09/05 00:45:03
I just removed the inaccurate part.
|
| + // the functions themselves. |
| + UIThreadExtensionFunction* function_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(ChromeExtensionFunctionDetails); |
| +}; |
| + |
| +#endif // CHROME_BROWSER_EXTENSIONS_CHROME_EXTENSION_FUNCTION_DETAILS_H_ |