blob: 116d692a6cb6b35f9e4674576d17f685b9f1d505 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
// 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 EXTENSIONS_SHELL_BROWSER_DESKTOP_CONTROLLER_H_
#define EXTENSIONS_SHELL_BROWSER_DESKTOP_CONTROLLER_H_
namespace aura {
class Window;
class WindowTreeHost;
}
namespace content {
class BrowserContext;
}
namespace extensions {
class AppWindow;
class Extension;
class ShellAppWindow;
// DesktopController is an interface to construct the window environment in
// extensions shell. ShellDesktopController provides a default implementation
// for app_shell, and embedder (such as athena) can provide its own.
// TODO(jamescook|oshima): Clean up this interface now that there is only one
// way to create an app window.
class DesktopController {
public:
DesktopController();
virtual ~DesktopController();
// Returns the single instance of the desktop. (Stateless functions like
// ShellAppWindowCreateFunction need to be able to access the desktop, so
// we need a singleton somewhere).
static DesktopController* instance();
// Returns the WindowTreeHost created by this DesktopController.
virtual aura::WindowTreeHost* GetHost() = 0;
// Creates a new app window and adds it to the desktop. The desktop maintains
// ownership of the window. The window must be closed before |extension| is
// destroyed.
virtual AppWindow* CreateAppWindow(content::BrowserContext* context,
const Extension* extension) = 0;
// Attaches the window to our window hierarchy.
virtual void AddAppWindow(aura::Window* window) = 0;
// Closes and destroys the app windows.
virtual void CloseAppWindows() = 0;
};
} // namespace extensions
#endif // EXTENSIONS_SHELL_BROWSER_DESKTOP_CONTROLLER_H_
|