Index: ash/mus/window_manager.h |
diff --git a/ash/mus/window_manager.h b/ash/mus/window_manager.h |
index 1f94114c66e653933109c7018948b803f42c838d..e31e3884397453a2dc5920483a97edb63220c2bd 100644 |
--- a/ash/mus/window_manager.h |
+++ b/ash/mus/window_manager.h |
@@ -14,10 +14,11 @@ |
#include "base/memory/ref_counted.h" |
#include "base/observer_list.h" |
#include "services/ui/common/types.h" |
-#include "services/ui/public/cpp/window_manager_delegate.h" |
-#include "services/ui/public/cpp/window_tree_client_delegate.h" |
#include "services/ui/public/interfaces/display/display_controller.mojom.h" |
#include "services/ui/public/interfaces/window_manager.mojom.h" |
+#include "ui/aura/env_observer.h" |
+#include "ui/aura/mus/window_manager_delegate.h" |
+#include "ui/aura/mus/window_tree_client_delegate.h" |
namespace base { |
class SequencedWorkerPool; |
@@ -25,7 +26,6 @@ class SequencedWorkerPool; |
namespace display { |
class Display; |
-class ScreenBase; |
} |
namespace service_manager { |
@@ -33,10 +33,20 @@ class Connector; |
} |
namespace views { |
-class PointerWatcherEventRouter; |
+class PointerWatcherEventRouter2; |
James Cook
2016/12/05 19:21:45
Ugh. Is there a bug open to track getting rid of P
sky
2016/12/05 21:39:20
671363 (just filed)
|
+} |
+ |
+namespace wm { |
+class FocusController; |
+class WMState; |
} |
namespace ash { |
+ |
+class EventClientImpl; |
+class ScreenPositionController; |
+class ScreenMus; |
+ |
namespace mus { |
class AcceleratorHandler; |
@@ -51,33 +61,41 @@ class WmTestHelper; |
// WindowTreeClientDelegate for mash. WindowManager creates (and owns) |
// a RootWindowController per Display. WindowManager takes ownership of |
// the WindowTreeClient. |
-class WindowManager : public ui::WindowManagerDelegate, |
- public ui::WindowTreeClientDelegate { |
+class WindowManager : public aura::WindowManagerDelegate, |
+ public aura::WindowTreeClientDelegate, |
+ public aura::EnvObserver { |
public: |
explicit WindowManager(service_manager::Connector* connector); |
~WindowManager() override; |
- void Init(std::unique_ptr<ui::WindowTreeClient> window_tree_client, |
+ void Init(std::unique_ptr<aura::WindowTreeClient> window_tree_client, |
const scoped_refptr<base::SequencedWorkerPool>& blocking_pool); |
WmShellMus* shell() { return shell_.get(); } |
- display::ScreenBase* screen() { return screen_.get(); } |
+ ScreenMus* screen() { return screen_.get(); } |
- ui::WindowTreeClient* window_tree_client() { |
+ aura::WindowTreeClient* window_tree_client() { |
return window_tree_client_.get(); |
} |
- ui::WindowManagerClient* window_manager_client() { |
+ aura::WindowManagerClient* window_manager_client() { |
return window_manager_client_; |
} |
+ ::wm::FocusController* focus_controller() { return focus_controller_.get(); } |
+ |
service_manager::Connector* connector() { return connector_; } |
+ aura::PropertyConverter* property_converter() { |
+ return property_converter_.get(); |
+ } |
+ |
void SetScreenLocked(bool is_locked); |
// Creates a new top level window. |
- ui::Window* NewTopLevelWindow( |
+ aura::Window* NewTopLevelWindow( |
+ ui::mojom::WindowType window_type, |
std::map<std::string, std::vector<uint8_t>>* properties); |
std::set<RootWindowController*> GetRootWindowControllers(); |
@@ -102,7 +120,7 @@ class WindowManager : public ui::WindowManagerDelegate, |
using RootWindowControllers = std::set<std::unique_ptr<RootWindowController>>; |
RootWindowController* CreateRootWindowController( |
- ui::Window* window, |
+ std::unique_ptr<aura::WindowTreeHostMus> window_tree_host, |
const display::Display& display); |
// Deletes the specified RootWindowController. Called when a display is |
@@ -112,12 +130,6 @@ class WindowManager : public ui::WindowManagerDelegate, |
void Shutdown(); |
- // Returns an iterator into |root_window_controllers_|. Returns |
- // root_window_controllers_.end() if |window| is not the root of a |
- // RootWindowController. |
- RootWindowControllers::iterator FindRootWindowControllerByWindow( |
- ui::Window* window); |
- |
RootWindowController* GetPrimaryRootWindowController(); |
// Returns the RootWindowController where new top levels are created. |
@@ -126,43 +138,59 @@ class WindowManager : public ui::WindowManagerDelegate, |
std::map<std::string, std::vector<uint8_t>>* properties); |
// WindowTreeClientDelegate: |
- void OnEmbed(ui::Window* root) override; |
- void OnEmbedRootDestroyed(ui::Window* root) override; |
- void OnLostConnection(ui::WindowTreeClient* client) override; |
+ void OnEmbed( |
+ std::unique_ptr<aura::WindowTreeHostMus> window_tree_host) override; |
+ void OnEmbedRootDestroyed(aura::Window* root) override; |
+ void OnLostConnection(aura::WindowTreeClient* client) override; |
void OnPointerEventObserved(const ui::PointerEvent& event, |
- ui::Window* target) override; |
+ aura::Window* target) override; |
+ aura::client::CaptureClient* GetCaptureClient() override; |
+ aura::PropertyConverter* GetPropertyConverter() override; |
// WindowManagerDelegate: |
- void SetWindowManagerClient(ui::WindowManagerClient* client) override; |
- bool OnWmSetBounds(ui::Window* window, gfx::Rect* bounds) override; |
+ void SetWindowManagerClient(aura::WindowManagerClient* client) override; |
+ bool OnWmSetBounds(aura::Window* window, gfx::Rect* bounds) override; |
bool OnWmSetProperty( |
- ui::Window* window, |
+ aura::Window* window, |
const std::string& name, |
std::unique_ptr<std::vector<uint8_t>>* new_data) override; |
- ui::Window* OnWmCreateTopLevelWindow( |
+ aura::Window* OnWmCreateTopLevelWindow( |
+ ui::mojom::WindowType window_type, |
std::map<std::string, std::vector<uint8_t>>* properties) override; |
- void OnWmClientJankinessChanged(const std::set<ui::Window*>& client_windows, |
+ void OnWmClientJankinessChanged(const std::set<aura::Window*>& client_windows, |
bool not_responding) override; |
- void OnWmNewDisplay(ui::Window* window, |
+ void OnWmWillCreateDisplay(const display::Display& display) override; |
+ void OnWmNewDisplay(std::unique_ptr<aura::WindowTreeHostMus> window_tree_host, |
const display::Display& display) override; |
- void OnWmDisplayRemoved(ui::Window* window) override; |
+ void OnWmDisplayRemoved(aura::WindowTreeHostMus* window_tree_host) override; |
void OnWmDisplayModified(const display::Display& display) override; |
- void OnWmPerformMoveLoop(ui::Window* window, |
+ void OnWmPerformMoveLoop(aura::Window* window, |
ui::mojom::MoveLoopSource source, |
const gfx::Point& cursor_location, |
const base::Callback<void(bool)>& on_done) override; |
- void OnWmCancelMoveLoop(ui::Window* window) override; |
+ void OnWmCancelMoveLoop(aura::Window* window) override; |
ui::mojom::EventResult OnAccelerator(uint32_t id, |
const ui::Event& event) override; |
+ void OnWmSetClientArea( |
+ aura::Window* window, |
+ const gfx::Insets& insets, |
+ const std::vector<gfx::Rect>& additional_client_areas) override; |
+ |
+ // aura::EnvObserver: |
+ void OnWindowInitialized(aura::Window* window) override; |
service_manager::Connector* connector_; |
display::mojom::DisplayControllerPtr display_controller_; |
- std::unique_ptr<ui::WindowTreeClient> window_tree_client_; |
+ std::unique_ptr<::wm::FocusController> focus_controller_; |
+ std::unique_ptr<::wm::WMState> wm_state_; |
+ std::unique_ptr<aura::PropertyConverter> property_converter_; |
- ui::WindowManagerClient* window_manager_client_ = nullptr; |
+ std::unique_ptr<aura::WindowTreeClient> window_tree_client_; |
- std::unique_ptr<views::PointerWatcherEventRouter> |
+ aura::WindowManagerClient* window_manager_client_ = nullptr; |
+ |
+ std::unique_ptr<views::PointerWatcherEventRouter2> |
pointer_watcher_event_router_; |
std::unique_ptr<ShadowController> shadow_controller_; |
@@ -171,7 +199,7 @@ class WindowManager : public ui::WindowManagerDelegate, |
base::ObserverList<WindowManagerObserver> observers_; |
- std::unique_ptr<display::ScreenBase> screen_; |
+ std::unique_ptr<ScreenMus> screen_; |
std::unique_ptr<WmShellMus> shell_; |
@@ -180,6 +208,10 @@ class WindowManager : public ui::WindowManagerDelegate, |
std::map<uint16_t, AcceleratorHandler*> accelerator_handlers_; |
uint16_t next_accelerator_namespace_id_ = 0u; |
+ std::unique_ptr<EventClientImpl> event_client_; |
+ |
+ std::unique_ptr<ScreenPositionController> screen_position_controller_; |
+ |
DISALLOW_COPY_AND_ASSIGN(WindowManager); |
}; |