| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "mash/wm/property_util.h" | 5 #include "ash/mus/property_util.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include "ash/mus/shadow.h" |
| 9 #include "components/mus/public/cpp/property_type_converters.h" | 10 #include "components/mus/public/cpp/property_type_converters.h" |
| 10 #include "components/mus/public/cpp/window_property.h" | 11 #include "components/mus/public/cpp/window_property.h" |
| 11 #include "mash/wm/shadow.h" | |
| 12 #include "ui/gfx/geometry/rect.h" | 12 #include "ui/gfx/geometry/rect.h" |
| 13 #include "ui/gfx/geometry/size.h" | 13 #include "ui/gfx/geometry/size.h" |
| 14 | 14 |
| 15 namespace mash { | 15 namespace ash { |
| 16 namespace wm { | 16 namespace mus { |
| 17 namespace { | 17 namespace { |
| 18 | 18 |
| 19 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(Shadow*, kLocalShadowProperty, nullptr); | 19 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(Shadow*, kLocalShadowProperty, nullptr); |
| 20 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(bool, kWindowIsJankyProperty, false); | 20 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(bool, kWindowIsJankyProperty, false); |
| 21 | 21 |
| 22 } // namespace | 22 } // namespace |
| 23 | 23 |
| 24 void SetWindowShowState(mus::Window* window, mus::mojom::ShowState show_state) { | 24 void SetWindowShowState(::mus::Window* window, |
| 25 ::mus::mojom::ShowState show_state) { |
| 25 window->SetSharedProperty<int32_t>( | 26 window->SetSharedProperty<int32_t>( |
| 26 mus::mojom::WindowManager::kShowState_Property, | 27 ::mus::mojom::WindowManager::kShowState_Property, |
| 27 static_cast<uint32_t>(show_state)); | 28 static_cast<uint32_t>(show_state)); |
| 28 } | 29 } |
| 29 | 30 |
| 30 mus::mojom::ShowState GetWindowShowState(const mus::Window* window) { | 31 ::mus::mojom::ShowState GetWindowShowState(const ::mus::Window* window) { |
| 31 if (window->HasSharedProperty( | 32 if (window->HasSharedProperty( |
| 32 mus::mojom::WindowManager::kShowState_Property)) { | 33 ::mus::mojom::WindowManager::kShowState_Property)) { |
| 33 return static_cast<mus::mojom::ShowState>( | 34 return static_cast<::mus::mojom::ShowState>( |
| 34 window->GetSharedProperty<int32_t>( | 35 window->GetSharedProperty<int32_t>( |
| 35 mus::mojom::WindowManager::kShowState_Property)); | 36 ::mus::mojom::WindowManager::kShowState_Property)); |
| 36 } | 37 } |
| 37 return mus::mojom::ShowState::DEFAULT; | 38 return ::mus::mojom::ShowState::DEFAULT; |
| 38 } | 39 } |
| 39 | 40 |
| 40 void SetWindowUserSetBounds(mus::Window* window, const gfx::Rect& bounds) { | 41 void SetWindowUserSetBounds(::mus::Window* window, const gfx::Rect& bounds) { |
| 41 if (bounds.IsEmpty()) { | 42 if (bounds.IsEmpty()) { |
| 42 window->ClearSharedProperty( | 43 window->ClearSharedProperty( |
| 43 mus::mojom::WindowManager::kUserSetBounds_Property); | 44 ::mus::mojom::WindowManager::kUserSetBounds_Property); |
| 44 } else { | 45 } else { |
| 45 window->SetSharedProperty<gfx::Rect>( | 46 window->SetSharedProperty<gfx::Rect>( |
| 46 mus::mojom::WindowManager::kUserSetBounds_Property, bounds); | 47 ::mus::mojom::WindowManager::kUserSetBounds_Property, bounds); |
| 47 } | 48 } |
| 48 } | 49 } |
| 49 | 50 |
| 50 gfx::Rect GetWindowUserSetBounds(const mus::Window* window) { | 51 gfx::Rect GetWindowUserSetBounds(const ::mus::Window* window) { |
| 51 if (window->HasSharedProperty( | 52 if (window->HasSharedProperty( |
| 52 mus::mojom::WindowManager::kUserSetBounds_Property)) { | 53 ::mus::mojom::WindowManager::kUserSetBounds_Property)) { |
| 53 return window->GetSharedProperty<gfx::Rect>( | 54 return window->GetSharedProperty<gfx::Rect>( |
| 54 mus::mojom::WindowManager::kUserSetBounds_Property); | 55 ::mus::mojom::WindowManager::kUserSetBounds_Property); |
| 55 } | 56 } |
| 56 return gfx::Rect(); | 57 return gfx::Rect(); |
| 57 } | 58 } |
| 58 | 59 |
| 59 void SetWindowPreferredSize(mus::Window* window, const gfx::Size& size) { | 60 void SetWindowPreferredSize(::mus::Window* window, const gfx::Size& size) { |
| 60 window->SetSharedProperty<gfx::Size>( | 61 window->SetSharedProperty<gfx::Size>( |
| 61 mus::mojom::WindowManager::kPreferredSize_Property, size); | 62 ::mus::mojom::WindowManager::kPreferredSize_Property, size); |
| 62 } | 63 } |
| 63 | 64 |
| 64 gfx::Size GetWindowPreferredSize(const mus::Window* window) { | 65 gfx::Size GetWindowPreferredSize(const ::mus::Window* window) { |
| 65 if (window->HasSharedProperty( | 66 if (window->HasSharedProperty( |
| 66 mus::mojom::WindowManager::kPreferredSize_Property)) { | 67 ::mus::mojom::WindowManager::kPreferredSize_Property)) { |
| 67 return window->GetSharedProperty<gfx::Size>( | 68 return window->GetSharedProperty<gfx::Size>( |
| 68 mus::mojom::WindowManager::kPreferredSize_Property); | 69 ::mus::mojom::WindowManager::kPreferredSize_Property); |
| 69 } | 70 } |
| 70 return gfx::Size(); | 71 return gfx::Size(); |
| 71 } | 72 } |
| 72 | 73 |
| 73 ash::mojom::Container GetRequestedContainer(const mus::Window* window) { | 74 mojom::Container GetRequestedContainer(const ::mus::Window* window) { |
| 74 if (window->HasSharedProperty(ash::mojom::kWindowContainer_Property)) { | 75 if (window->HasSharedProperty(mojom::kWindowContainer_Property)) { |
| 75 return static_cast<ash::mojom::Container>( | 76 return static_cast<mojom::Container>( |
| 76 window->GetSharedProperty<int32_t>( | 77 window->GetSharedProperty<int32_t>(mojom::kWindowContainer_Property)); |
| 77 ash::mojom::kWindowContainer_Property)); | |
| 78 } | 78 } |
| 79 return ash::mojom::Container::USER_PRIVATE_WINDOWS; | 79 return mojom::Container::USER_PRIVATE_WINDOWS; |
| 80 } | 80 } |
| 81 | 81 |
| 82 int32_t GetResizeBehavior(const mus::Window* window) { | 82 int32_t GetResizeBehavior(const ::mus::Window* window) { |
| 83 if (window->HasSharedProperty( | 83 if (window->HasSharedProperty( |
| 84 mus::mojom::WindowManager::kResizeBehavior_Property)) { | 84 ::mus::mojom::WindowManager::kResizeBehavior_Property)) { |
| 85 return window->GetSharedProperty<int32_t>( | 85 return window->GetSharedProperty<int32_t>( |
| 86 mus::mojom::WindowManager::kResizeBehavior_Property); | 86 ::mus::mojom::WindowManager::kResizeBehavior_Property); |
| 87 } | 87 } |
| 88 return mus::mojom::kResizeBehaviorNone; | 88 return ::mus::mojom::kResizeBehaviorNone; |
| 89 } | 89 } |
| 90 | 90 |
| 91 void SetRestoreBounds(mus::Window* window, const gfx::Rect& bounds) { | 91 void SetRestoreBounds(::mus::Window* window, const gfx::Rect& bounds) { |
| 92 window->SetSharedProperty<gfx::Rect>( | 92 window->SetSharedProperty<gfx::Rect>( |
| 93 mus::mojom::WindowManager::kRestoreBounds_Property, bounds); | 93 ::mus::mojom::WindowManager::kRestoreBounds_Property, bounds); |
| 94 } | 94 } |
| 95 | 95 |
| 96 gfx::Rect GetRestoreBounds(const mus::Window* window) { | 96 gfx::Rect GetRestoreBounds(const ::mus::Window* window) { |
| 97 if (window->HasSharedProperty( | 97 if (window->HasSharedProperty( |
| 98 mus::mojom::WindowManager::kRestoreBounds_Property)) { | 98 ::mus::mojom::WindowManager::kRestoreBounds_Property)) { |
| 99 return window->GetSharedProperty<gfx::Rect>( | 99 return window->GetSharedProperty<gfx::Rect>( |
| 100 mus::mojom::WindowManager::kRestoreBounds_Property); | 100 ::mus::mojom::WindowManager::kRestoreBounds_Property); |
| 101 } | 101 } |
| 102 return gfx::Rect(); | 102 return gfx::Rect(); |
| 103 } | 103 } |
| 104 | 104 |
| 105 void SetShadow(mus::Window* window, Shadow* shadow) { | 105 void SetShadow(::mus::Window* window, Shadow* shadow) { |
| 106 window->SetLocalProperty(kLocalShadowProperty, shadow); | 106 window->SetLocalProperty(kLocalShadowProperty, shadow); |
| 107 } | 107 } |
| 108 | 108 |
| 109 Shadow* GetShadow(const mus::Window* window) { | 109 Shadow* GetShadow(const ::mus::Window* window) { |
| 110 return window->GetLocalProperty(kLocalShadowProperty); | 110 return window->GetLocalProperty(kLocalShadowProperty); |
| 111 } | 111 } |
| 112 | 112 |
| 113 mus::mojom::WindowType GetWindowType(const mus::Window* window) { | 113 ::mus::mojom::WindowType GetWindowType(const ::mus::Window* window) { |
| 114 if (window->HasSharedProperty( | 114 if (window->HasSharedProperty( |
| 115 mus::mojom::WindowManager::kWindowType_Property)) { | 115 ::mus::mojom::WindowManager::kWindowType_Property)) { |
| 116 return static_cast<mus::mojom::WindowType>( | 116 return static_cast<::mus::mojom::WindowType>( |
| 117 window->GetSharedProperty<int32_t>( | 117 window->GetSharedProperty<int32_t>( |
| 118 mus::mojom::WindowManager::kWindowType_Property)); | 118 ::mus::mojom::WindowManager::kWindowType_Property)); |
| 119 } | 119 } |
| 120 return mus::mojom::WindowType::POPUP; | 120 return ::mus::mojom::WindowType::POPUP; |
| 121 } | 121 } |
| 122 | 122 |
| 123 mus::mojom::WindowType GetWindowType( | 123 ::mus::mojom::WindowType GetWindowType( |
| 124 const mus::Window::SharedProperties& properties) { | 124 const ::mus::Window::SharedProperties& properties) { |
| 125 const auto iter = | 125 const auto iter = |
| 126 properties.find(mus::mojom::WindowManager::kWindowType_Property); | 126 properties.find(::mus::mojom::WindowManager::kWindowType_Property); |
| 127 if (iter != properties.end()) { | 127 if (iter != properties.end()) { |
| 128 return static_cast<mus::mojom::WindowType>( | 128 return static_cast<::mus::mojom::WindowType>( |
| 129 mojo::ConvertTo<int32_t>(iter->second)); | 129 mojo::ConvertTo<int32_t>(iter->second)); |
| 130 } | 130 } |
| 131 return mus::mojom::WindowType::POPUP; | 131 return ::mus::mojom::WindowType::POPUP; |
| 132 } | 132 } |
| 133 | 133 |
| 134 ui::wm::WindowType GetWmWindowType(const mus::Window* window) { | 134 ui::wm::WindowType GetWmWindowType(const ::mus::Window* window) { |
| 135 switch (GetWindowType(window)) { | 135 switch (GetWindowType(window)) { |
| 136 case mus::mojom::WindowType::WINDOW: | 136 case ::mus::mojom::WindowType::WINDOW: |
| 137 return ui::wm::WINDOW_TYPE_NORMAL; | 137 return ui::wm::WINDOW_TYPE_NORMAL; |
| 138 | 138 |
| 139 case mus::mojom::WindowType::PANEL: | 139 case ::mus::mojom::WindowType::PANEL: |
| 140 return ui::wm::WINDOW_TYPE_PANEL; | 140 return ui::wm::WINDOW_TYPE_PANEL; |
| 141 | 141 |
| 142 case mus::mojom::WindowType::CONTROL: | 142 case ::mus::mojom::WindowType::CONTROL: |
| 143 return ui::wm::WINDOW_TYPE_CONTROL; | 143 return ui::wm::WINDOW_TYPE_CONTROL; |
| 144 | 144 |
| 145 case mus::mojom::WindowType::WINDOW_FRAMELESS: | 145 case ::mus::mojom::WindowType::WINDOW_FRAMELESS: |
| 146 case mus::mojom::WindowType::POPUP: | 146 case ::mus::mojom::WindowType::POPUP: |
| 147 case mus::mojom::WindowType::BUBBLE: | 147 case ::mus::mojom::WindowType::BUBBLE: |
| 148 case mus::mojom::WindowType::DRAG: | 148 case ::mus::mojom::WindowType::DRAG: |
| 149 return ui::wm::WINDOW_TYPE_POPUP; | 149 return ui::wm::WINDOW_TYPE_POPUP; |
| 150 | 150 |
| 151 case mus::mojom::WindowType::MENU: | 151 case ::mus::mojom::WindowType::MENU: |
| 152 return ui::wm::WINDOW_TYPE_MENU; | 152 return ui::wm::WINDOW_TYPE_MENU; |
| 153 | 153 |
| 154 case mus::mojom::WindowType::TOOLTIP: | 154 case ::mus::mojom::WindowType::TOOLTIP: |
| 155 return ui::wm::WINDOW_TYPE_TOOLTIP; | 155 return ui::wm::WINDOW_TYPE_TOOLTIP; |
| 156 } | 156 } |
| 157 | 157 |
| 158 return ui::wm::WINDOW_TYPE_UNKNOWN; | 158 return ui::wm::WINDOW_TYPE_UNKNOWN; |
| 159 } | 159 } |
| 160 | 160 |
| 161 ash::mojom::AshWindowType GetAshWindowType(const mus::Window* window) { | 161 mojom::AshWindowType GetAshWindowType(const ::mus::Window* window) { |
| 162 if (!window->HasSharedProperty(ash::mojom::kAshWindowType_Property)) | 162 if (!window->HasSharedProperty(mojom::kAshWindowType_Property)) |
| 163 return ash::mojom::AshWindowType::COUNT; | 163 return mojom::AshWindowType::COUNT; |
| 164 | 164 |
| 165 return static_cast<ash::mojom::AshWindowType>( | 165 return static_cast<mojom::AshWindowType>( |
| 166 window->GetSharedProperty<int32_t>(ash::mojom::kAshWindowType_Property)); | 166 window->GetSharedProperty<int32_t>(mojom::kAshWindowType_Property)); |
| 167 } | 167 } |
| 168 | 168 |
| 169 base::string16 GetWindowTitle(const mus::Window* window) { | 169 base::string16 GetWindowTitle(const ::mus::Window* window) { |
| 170 if (!window->HasSharedProperty( | 170 if (!window->HasSharedProperty( |
| 171 mus::mojom::WindowManager::kWindowTitle_Property)) { | 171 ::mus::mojom::WindowManager::kWindowTitle_Property)) { |
| 172 return base::string16(); | 172 return base::string16(); |
| 173 } | 173 } |
| 174 | 174 |
| 175 return window->GetSharedProperty<base::string16>( | 175 return window->GetSharedProperty<base::string16>( |
| 176 mus::mojom::WindowManager::kWindowTitle_Property); | 176 ::mus::mojom::WindowManager::kWindowTitle_Property); |
| 177 } | 177 } |
| 178 | 178 |
| 179 mojo::Array<uint8_t> GetWindowAppIcon(const mus::Window* window) { | 179 mojo::Array<uint8_t> GetWindowAppIcon(const ::mus::Window* window) { |
| 180 if (window->HasSharedProperty( | 180 if (window->HasSharedProperty( |
| 181 mus::mojom::WindowManager::kWindowAppIcon_Property)) { | 181 ::mus::mojom::WindowManager::kWindowAppIcon_Property)) { |
| 182 return mojo::Array<uint8_t>::From( | 182 return mojo::Array<uint8_t>::From( |
| 183 window->GetSharedProperty<std::vector<uint8_t>>( | 183 window->GetSharedProperty<std::vector<uint8_t>>( |
| 184 mus::mojom::WindowManager::kWindowAppIcon_Property)); | 184 ::mus::mojom::WindowManager::kWindowAppIcon_Property)); |
| 185 } | 185 } |
| 186 return mojo::Array<uint8_t>(); | 186 return mojo::Array<uint8_t>(); |
| 187 } | 187 } |
| 188 | 188 |
| 189 void SetAppID(mus::Window* window, const base::string16& app_id) { | 189 void SetAppID(::mus::Window* window, const base::string16& app_id) { |
| 190 window->SetSharedProperty<base::string16>( | 190 window->SetSharedProperty<base::string16>( |
| 191 mus::mojom::WindowManager::kAppID_Property, app_id); | 191 ::mus::mojom::WindowManager::kAppID_Property, app_id); |
| 192 } | 192 } |
| 193 | 193 |
| 194 base::string16 GetAppID(const mus::Window* window) { | 194 base::string16 GetAppID(const ::mus::Window* window) { |
| 195 if (!window->HasSharedProperty(mus::mojom::WindowManager::kAppID_Property)) | 195 if (!window->HasSharedProperty(::mus::mojom::WindowManager::kAppID_Property)) |
| 196 return base::string16(); | 196 return base::string16(); |
| 197 | 197 |
| 198 return window->GetSharedProperty<base::string16>( | 198 return window->GetSharedProperty<base::string16>( |
| 199 mus::mojom::WindowManager::kAppID_Property); | 199 ::mus::mojom::WindowManager::kAppID_Property); |
| 200 } | 200 } |
| 201 | 201 |
| 202 bool GetWindowIgnoredByShelf(mus::Window* window) { | 202 bool GetWindowIgnoredByShelf(::mus::Window* window) { |
| 203 return window->HasSharedProperty( | 203 return window->HasSharedProperty( |
| 204 mus::mojom::WindowManager::kWindowIgnoredByShelf_Property) && | 204 ::mus::mojom::WindowManager::kWindowIgnoredByShelf_Property) && |
| 205 window->GetSharedProperty<bool>( | 205 window->GetSharedProperty<bool>( |
| 206 mus::mojom::WindowManager::kWindowIgnoredByShelf_Property); | 206 ::mus::mojom::WindowManager::kWindowIgnoredByShelf_Property); |
| 207 } | 207 } |
| 208 | 208 |
| 209 void SetWindowIsJanky(mus::Window* window, bool janky) { | 209 void SetWindowIsJanky(::mus::Window* window, bool janky) { |
| 210 window->SetLocalProperty(kWindowIsJankyProperty, janky); | 210 window->SetLocalProperty(kWindowIsJankyProperty, janky); |
| 211 } | 211 } |
| 212 | 212 |
| 213 bool IsWindowJanky(mus::Window* window) { | 213 bool IsWindowJanky(::mus::Window* window) { |
| 214 return window->GetLocalProperty(kWindowIsJankyProperty); | 214 return window->GetLocalProperty(kWindowIsJankyProperty); |
| 215 } | 215 } |
| 216 | 216 |
| 217 bool IsWindowJankyProperty(const void* key) { | 217 bool IsWindowJankyProperty(const void* key) { |
| 218 return key == kWindowIsJankyProperty; | 218 return key == kWindowIsJankyProperty; |
| 219 } | 219 } |
| 220 | 220 |
| 221 void SetAlwaysOnTop(mus::Window* window, bool value) { | 221 void SetAlwaysOnTop(::mus::Window* window, bool value) { |
| 222 window->SetSharedProperty<bool>( | 222 window->SetSharedProperty<bool>( |
| 223 mus::mojom::WindowManager::kAlwaysOnTop_Property, value); | 223 ::mus::mojom::WindowManager::kAlwaysOnTop_Property, value); |
| 224 } | 224 } |
| 225 | 225 |
| 226 bool IsAlwaysOnTop(mus::Window* window) { | 226 bool IsAlwaysOnTop(::mus::Window* window) { |
| 227 return window->HasSharedProperty( | 227 return window->HasSharedProperty( |
| 228 mus::mojom::WindowManager::kAlwaysOnTop_Property) && | 228 ::mus::mojom::WindowManager::kAlwaysOnTop_Property) && |
| 229 window->GetSharedProperty<bool>( | 229 window->GetSharedProperty<bool>( |
| 230 mus::mojom::WindowManager::kAlwaysOnTop_Property); | 230 ::mus::mojom::WindowManager::kAlwaysOnTop_Property); |
| 231 } | 231 } |
| 232 | 232 |
| 233 } // namespace wm | 233 } // namespace mus |
| 234 } // namespace mash | 234 } // namespace ash |
| OLD | NEW |