| 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 "ui/views/mus/mus_client.h" | 5 #include "ui/views/mus/mus_client.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/memory/ptr_util.h" | 8 #include "base/memory/ptr_util.h" |
| 9 #include "base/threading/thread.h" | 9 #include "base/threading/thread.h" |
| 10 #include "components/discardable_memory/client/client_discardable_shared_memory_
manager.h" | 10 #include "components/discardable_memory/client/client_discardable_shared_memory_
manager.h" |
| (...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 83 | 83 |
| 84 discardable_memory::mojom::DiscardableSharedMemoryManagerPtr manager_ptr; | 84 discardable_memory::mojom::DiscardableSharedMemoryManagerPtr manager_ptr; |
| 85 connector->BindInterface(ui::mojom::kServiceName, &manager_ptr); | 85 connector->BindInterface(ui::mojom::kServiceName, &manager_ptr); |
| 86 | 86 |
| 87 discardable_shared_memory_manager_ = base::MakeUnique< | 87 discardable_shared_memory_manager_ = base::MakeUnique< |
| 88 discardable_memory::ClientDiscardableSharedMemoryManager>( | 88 discardable_memory::ClientDiscardableSharedMemoryManager>( |
| 89 std::move(manager_ptr), io_task_runner); | 89 std::move(manager_ptr), io_task_runner); |
| 90 base::DiscardableMemoryAllocator::SetInstance( | 90 base::DiscardableMemoryAllocator::SetInstance( |
| 91 discardable_shared_memory_manager_.get()); | 91 discardable_shared_memory_manager_.get()); |
| 92 | 92 |
| 93 gpu_ = ui::Gpu::Create(connector, std::move(io_task_runner)); | 93 window_tree_client_ = base::MakeUnique<aura::WindowTreeClient>( |
| 94 compositor_context_factory_ = | 94 connector, std::move(io_task_runner), this); |
| 95 base::MakeUnique<aura::MusContextFactory>(gpu_.get()); | |
| 96 aura::Env::GetInstance()->set_context_factory( | |
| 97 compositor_context_factory_.get()); | |
| 98 window_tree_client_ = | |
| 99 base::MakeUnique<aura::WindowTreeClient>(connector, this); | |
| 100 aura::Env::GetInstance()->SetWindowTreeClient(window_tree_client_.get()); | 95 aura::Env::GetInstance()->SetWindowTreeClient(window_tree_client_.get()); |
| 101 window_tree_client_->ConnectViaWindowTreeFactory(); | 96 window_tree_client_->ConnectViaWindowTreeFactory(); |
| 102 | 97 |
| 103 pointer_watcher_event_router_ = | 98 pointer_watcher_event_router_ = |
| 104 base::MakeUnique<PointerWatcherEventRouter>(window_tree_client_.get()); | 99 base::MakeUnique<PointerWatcherEventRouter>(window_tree_client_.get()); |
| 105 | 100 |
| 106 screen_ = base::MakeUnique<ScreenMus>(this); | 101 screen_ = base::MakeUnique<ScreenMus>(this); |
| 107 screen_->Init(connector); | 102 screen_->Init(connector); |
| 108 | 103 |
| 109 std::unique_ptr<ClipboardMus> clipboard = base::MakeUnique<ClipboardMus>(); | 104 std::unique_ptr<ClipboardMus> clipboard = base::MakeUnique<ClipboardMus>(); |
| 110 clipboard->Init(connector); | 105 clipboard->Init(connector); |
| 111 ui::Clipboard::SetClipboardForCurrentThread(std::move(clipboard)); | 106 ui::Clipboard::SetClipboardForCurrentThread(std::move(clipboard)); |
| 112 | 107 |
| 113 ui::OSExchangeDataProviderFactory::SetFactory(this); | 108 ui::OSExchangeDataProviderFactory::SetFactory(this); |
| 114 | 109 |
| 115 ViewsDelegate::GetInstance()->set_native_widget_factory( | 110 ViewsDelegate::GetInstance()->set_native_widget_factory( |
| 116 base::Bind(&MusClient::CreateNativeWidget, base::Unretained(this))); | 111 base::Bind(&MusClient::CreateNativeWidget, base::Unretained(this))); |
| 117 } | 112 } |
| 118 | 113 |
| 119 MusClient::~MusClient() { | 114 MusClient::~MusClient() { |
| 120 // ~WindowTreeClient calls back to us (we're its delegate), destroy it while | 115 // ~WindowTreeClient calls back to us (we're its delegate), destroy it while |
| 121 // we are still valid. | 116 // we are still valid. |
| 122 window_tree_client_.reset(); | 117 window_tree_client_.reset(); |
| 123 ui::OSExchangeDataProviderFactory::SetFactory(nullptr); | 118 ui::OSExchangeDataProviderFactory::SetFactory(nullptr); |
| 124 ui::Clipboard::DestroyClipboardForCurrentThread(); | 119 ui::Clipboard::DestroyClipboardForCurrentThread(); |
| 125 gpu_.reset(); | |
| 126 | 120 |
| 127 if (ViewsDelegate::GetInstance()) { | 121 if (ViewsDelegate::GetInstance()) { |
| 128 ViewsDelegate::GetInstance()->set_native_widget_factory( | 122 ViewsDelegate::GetInstance()->set_native_widget_factory( |
| 129 ViewsDelegate::NativeWidgetFactory()); | 123 ViewsDelegate::NativeWidgetFactory()); |
| 130 } | 124 } |
| 131 | 125 |
| 132 base::DiscardableMemoryAllocator::SetInstance(nullptr); | 126 base::DiscardableMemoryAllocator::SetInstance(nullptr); |
| 133 DCHECK_EQ(instance_, this); | 127 DCHECK_EQ(instance_, this); |
| 134 instance_ = nullptr; | 128 instance_ = nullptr; |
| 135 DCHECK(aura::Env::GetInstance()); | 129 DCHECK(aura::Env::GetInstance()); |
| (...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 274 return root->GetTopWindowContainingPoint(relative_point); | 268 return root->GetTopWindowContainingPoint(relative_point); |
| 275 } | 269 } |
| 276 return nullptr; | 270 return nullptr; |
| 277 } | 271 } |
| 278 | 272 |
| 279 std::unique_ptr<OSExchangeData::Provider> MusClient::BuildProvider() { | 273 std::unique_ptr<OSExchangeData::Provider> MusClient::BuildProvider() { |
| 280 return base::MakeUnique<aura::OSExchangeDataProviderMus>(); | 274 return base::MakeUnique<aura::OSExchangeDataProviderMus>(); |
| 281 } | 275 } |
| 282 | 276 |
| 283 } // namespace views | 277 } // namespace views |
| OLD | NEW |