Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1648)

Unified Diff: chrome/browser/extensions/api/tabs/windows_util.h

Issue 1099553002: extensions: windows: list all windows from the current profile (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: AppWindowController extracted Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/tabs/windows_util.h
diff --git a/chrome/browser/extensions/api/tabs/windows_util.h b/chrome/browser/extensions/api/tabs/windows_util.h
index 0e0a8d2ff4a8bccc44e50e90379766500e65f8e5..166e4a5fe52cbc47c2403c633b6d986771afead9 100644
--- a/chrome/browser/extensions/api/tabs/windows_util.h
+++ b/chrome/browser/extensions/api/tabs/windows_util.h
@@ -5,24 +5,54 @@
#ifndef CHROME_BROWSER_EXTENSIONS_API_TABS_WINDOWS_UTIL_H__
#define CHROME_BROWSER_EXTENSIONS_API_TABS_WINDOWS_UTIL_H__
+#include "chrome/common/extensions/api/windows.h"
+
class UIThreadExtensionFunction;
+namespace content {
+class BrowserContext;
+}
+
namespace extensions {
+class Extension;
class WindowController;
}
namespace windows_util {
+namespace windows = extensions::api::windows;
+
+const std::vector<windows::WindowType>& GetDefaultWindowTypeFilters();
+
+const std::vector<windows::WindowType>& GetNoWindowTypeFilters();
stevenjb 2015/07/30 19:00:37 We should typedef std::vector<windows::WindowType>
llandwerlin-old 2015/07/31 13:58:32 Done in WindowControllerList. I kept vector<> bec
stevenjb 2015/07/31 17:27:16 I think a copy might be slightly cheaper than the
llandwerlin-old 2015/08/03 10:11:54 Switching to converting the array to a bit field.
+
+bool WindowMatchesTypeFilter(const extensions::WindowController* controller,
+ const std::vector<windows::WindowType>& filters);
+
// Populates |controller| for given |window_id|. If the window is not found,
// returns false and sets UIThreadExtensionFunction error_.
bool GetWindowFromWindowID(UIThreadExtensionFunction* function,
int window_id,
+ const std::vector<windows::WindowType>& type_filter,
extensions::WindowController** controller);
// Returns true if |function| (and the profile and extension that it was
// invoked from) can operate on the window wrapped by |window_controller|.
+// If |all_window_types| is set this function will return true for any
+// kind of window (including app and devtools), otherwise it will
+// return true only for normal browser windows as well as windows
+// created by the extension.
bool CanOperateOnWindow(const UIThreadExtensionFunction* function,
- const extensions::WindowController* controller);
+ const extensions::WindowController* controller,
+ const std::vector<windows::WindowType>& type_filter);
+
+// Same as |CanOperateOnWindow| but uses |extension| and |browser_context|
+// instead of a UIThreadExtensionFunction.
+bool ExtensionCanOperateOnWindow(
+ const extensions::Extension* extension,
+ content::BrowserContext* browser_context,
+ const extensions::WindowController* controller,
+ const std::vector<windows::WindowType>& type_filter);
} // namespace windows_util

Powered by Google App Engine
This is Rietveld 408576698