| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "components/mus/public/cpp/window.h" | 5 #include "components/mus/public/cpp/window.h" |
| 6 #include "components/mus/public/cpp/window_manager_delegate.h" | 6 #include "components/mus/public/cpp/window_manager_delegate.h" |
| 7 #include "components/mus/public/cpp/window_tree_connection.h" | 7 #include "components/mus/public/cpp/window_tree_client.h" |
| 8 #include "components/mus/public/cpp/window_tree_delegate.h" | 8 #include "components/mus/public/cpp/window_tree_client_delegate.h" |
| 9 #include "components/mus/public/interfaces/window_manager_factory.mojom.h" | 9 #include "components/mus/public/interfaces/window_manager_factory.mojom.h" |
| 10 #include "mojo/public/c/system/main.h" | 10 #include "mojo/public/c/system/main.h" |
| 11 #include "mojo/public/cpp/bindings/binding.h" | 11 #include "mojo/public/cpp/bindings/binding.h" |
| 12 #include "services/shell/public/cpp/application_runner.h" | 12 #include "services/shell/public/cpp/application_runner.h" |
| 13 #include "services/shell/public/cpp/connector.h" | 13 #include "services/shell/public/cpp/connector.h" |
| 14 #include "services/shell/public/cpp/shell_client.h" | 14 #include "services/shell/public/cpp/shell_client.h" |
| 15 #include "ui/display/display.h" | 15 #include "ui/display/display.h" |
| 16 #include "ui/display/mojo/display_type_converters.h" | 16 #include "ui/display/mojo/display_type_converters.h" |
| 17 | 17 |
| 18 namespace mus { | 18 namespace mus { |
| 19 namespace test { | 19 namespace test { |
| 20 | 20 |
| 21 class TestWM : public shell::ShellClient, | 21 class TestWM : public shell::ShellClient, |
| 22 public mus::mojom::WindowManagerFactory, | 22 public mus::mojom::WindowManagerFactory, |
| 23 public mus::WindowTreeDelegate, | 23 public mus::WindowTreeClientDelegate, |
| 24 public mus::WindowManagerDelegate { | 24 public mus::WindowManagerDelegate { |
| 25 public: | 25 public: |
| 26 TestWM() : window_manager_factory_binding_(this) {} | 26 TestWM() : window_manager_factory_binding_(this) {} |
| 27 ~TestWM() override {} | 27 ~TestWM() override {} |
| 28 | 28 |
| 29 private: | 29 private: |
| 30 // shell::ShellClient: | 30 // shell::ShellClient: |
| 31 void Initialize(shell::Connector* connector, | 31 void Initialize(shell::Connector* connector, |
| 32 const shell::Identity& identity, | 32 const shell::Identity& identity, |
| 33 uint32_t id) override { | 33 uint32_t id) override { |
| 34 mus::mojom::WindowManagerFactoryServicePtr wm_factory_service; | 34 mus::mojom::WindowManagerFactoryServicePtr wm_factory_service; |
| 35 connector->ConnectToInterface("mojo:mus", &wm_factory_service); | 35 connector->ConnectToInterface("mojo:mus", &wm_factory_service); |
| 36 wm_factory_service->SetWindowManagerFactory( | 36 wm_factory_service->SetWindowManagerFactory( |
| 37 window_manager_factory_binding_.CreateInterfacePtrAndBind()); | 37 window_manager_factory_binding_.CreateInterfacePtrAndBind()); |
| 38 } | 38 } |
| 39 bool AcceptConnection(shell::Connection* connection) override { | 39 bool AcceptConnection(shell::Connection* connection) override { |
| 40 return true; | 40 return true; |
| 41 } | 41 } |
| 42 | 42 |
| 43 // mus::mojom::WindowManagerFactory: | 43 // mus::mojom::WindowManagerFactory: |
| 44 void CreateWindowManager( | 44 void CreateWindowManager( |
| 45 mus::mojom::DisplayPtr display, | 45 mus::mojom::DisplayPtr display, |
| 46 mus::mojom::WindowTreeClientRequest request) override { | 46 mus::mojom::WindowTreeClientRequest request) override { |
| 47 mus::WindowTreeConnection::CreateForWindowManager( | 47 new mus::WindowTreeClient(this, this, std::move(request)); |
| 48 this, std::move(request), | |
| 49 mus::WindowTreeConnection::CreateType::DONT_WAIT_FOR_EMBED, this); | |
| 50 } | 48 } |
| 51 | 49 |
| 52 // mus::WindowTreeDelegate: | 50 // mus::WindowTreeClientDelegate: |
| 53 void OnEmbed(mus::Window* root) override { | 51 void OnEmbed(mus::Window* root) override { |
| 54 root_ = root; | 52 root_ = root; |
| 55 window_manager_client_->AddActivationParent(root_); | 53 window_manager_client_->AddActivationParent(root_); |
| 56 mus::mojom::FrameDecorationValuesPtr frame_decoration_values = | 54 mus::mojom::FrameDecorationValuesPtr frame_decoration_values = |
| 57 mus::mojom::FrameDecorationValues::New(); | 55 mus::mojom::FrameDecorationValues::New(); |
| 58 frame_decoration_values->max_title_bar_button_width = 0; | 56 frame_decoration_values->max_title_bar_button_width = 0; |
| 59 window_manager_client_->SetFrameDecorationValues( | 57 window_manager_client_->SetFrameDecorationValues( |
| 60 std::move(frame_decoration_values)); | 58 std::move(frame_decoration_values)); |
| 61 } | 59 } |
| 62 void OnConnectionLost(mus::WindowTreeConnection* connection) override { | 60 void OnWindowTreeClientDestroyed(mus::WindowTreeClient* client) override {} |
| 63 } | |
| 64 void OnEventObserved(const ui::Event& event, mus::Window* target) override { | 61 void OnEventObserved(const ui::Event& event, mus::Window* target) override { |
| 65 // Don't care. | 62 // Don't care. |
| 66 } | 63 } |
| 67 | 64 |
| 68 // mus::WindowManagerDelegate: | 65 // mus::WindowManagerDelegate: |
| 69 void SetWindowManagerClient(mus::WindowManagerClient* client) override { | 66 void SetWindowManagerClient(mus::WindowManagerClient* client) override { |
| 70 window_manager_client_ = client; | 67 window_manager_client_ = client; |
| 71 } | 68 } |
| 72 bool OnWmSetBounds(mus::Window* window, gfx::Rect* bounds) override { | 69 bool OnWmSetBounds(mus::Window* window, gfx::Rect* bounds) override { |
| 73 return true; | 70 return true; |
| 74 } | 71 } |
| 75 bool OnWmSetProperty( | 72 bool OnWmSetProperty( |
| 76 mus::Window* window, | 73 mus::Window* window, |
| 77 const std::string& name, | 74 const std::string& name, |
| 78 std::unique_ptr<std::vector<uint8_t>>* new_data) override { | 75 std::unique_ptr<std::vector<uint8_t>>* new_data) override { |
| 79 return true; | 76 return true; |
| 80 } | 77 } |
| 81 mus::Window* OnWmCreateTopLevelWindow( | 78 mus::Window* OnWmCreateTopLevelWindow( |
| 82 std::map<std::string, std::vector<uint8_t>>* properties) override { | 79 std::map<std::string, std::vector<uint8_t>>* properties) override { |
| 83 mus::Window* window = root_->connection()->NewWindow(properties); | 80 mus::Window* window = root_->window_tree()->NewWindow(properties); |
| 84 window->SetBounds(gfx::Rect(10, 10, 500, 500)); | 81 window->SetBounds(gfx::Rect(10, 10, 500, 500)); |
| 85 root_->AddChild(window); | 82 root_->AddChild(window); |
| 86 return window; | 83 return window; |
| 87 } | 84 } |
| 88 void OnWmClientJankinessChanged(const std::set<Window*>& client_windows, | 85 void OnWmClientJankinessChanged(const std::set<Window*>& client_windows, |
| 89 bool janky) override { | 86 bool janky) override { |
| 90 // Don't care. | 87 // Don't care. |
| 91 } | 88 } |
| 92 void OnAccelerator(uint32_t id, const ui::Event& event) override { | 89 void OnAccelerator(uint32_t id, const ui::Event& event) override { |
| 93 // Don't care. | 90 // Don't care. |
| 94 } | 91 } |
| 95 | 92 |
| 96 mojo::Binding<mus::mojom::WindowManagerFactory> | 93 mojo::Binding<mus::mojom::WindowManagerFactory> |
| 97 window_manager_factory_binding_; | 94 window_manager_factory_binding_; |
| 98 mus::Window* root_ = nullptr; | 95 mus::Window* root_ = nullptr; |
| 99 mus::WindowManagerClient* window_manager_client_ = nullptr; | 96 mus::WindowManagerClient* window_manager_client_ = nullptr; |
| 100 | 97 |
| 101 DISALLOW_COPY_AND_ASSIGN(TestWM); | 98 DISALLOW_COPY_AND_ASSIGN(TestWM); |
| 102 }; | 99 }; |
| 103 | 100 |
| 104 } // namespace test | 101 } // namespace test |
| 105 } // namespace mus | 102 } // namespace mus |
| 106 | 103 |
| 107 MojoResult MojoMain(MojoHandle shell_handle) { | 104 MojoResult MojoMain(MojoHandle shell_handle) { |
| 108 shell::ApplicationRunner runner(new mus::test::TestWM); | 105 shell::ApplicationRunner runner(new mus::test::TestWM); |
| 109 return runner.Run(shell_handle); | 106 return runner.Run(shell_handle); |
| 110 } | 107 } |
| OLD | NEW |