Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(338)

Side by Side Diff: ui/ozone/platform/dri/dri_window_delegate_manager.cc

Issue 556073003: [Ozone-DRI] Do proper bounds checks when moving the cursor (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@restore-cursor
Patch Set: . Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/ozone/platform/dri/dri_window_manager.h" 5 #include "ui/ozone/platform/dri/dri_window_delegate_manager.h"
6 6
7 #include "ui/ozone/platform/dri/dri_window_delegate.h" 7 #include "ui/ozone/platform/dri/dri_window_delegate.h"
8 8
9 namespace ui { 9 namespace ui {
10 10
11 DriWindowManager::DriWindowManager() : last_allocated_widget_(0) { 11 DriWindowDelegateManager::DriWindowDelegateManager() {
12 } 12 }
13 13
14 DriWindowManager::~DriWindowManager() { 14 DriWindowDelegateManager::~DriWindowDelegateManager() {
15 DCHECK(delegate_map_.empty()); 15 DCHECK(delegate_map_.empty());
16 } 16 }
17 17
18 gfx::AcceleratedWidget DriWindowManager::NextAcceleratedWidget() { 18 void DriWindowDelegateManager::AddWindowDelegate(
19 // We're not using 0 since other code assumes that a 0 AcceleratedWidget is an
20 // invalid widget.
21 return ++last_allocated_widget_;
22 }
23
24 void DriWindowManager::AddWindowDelegate(
25 gfx::AcceleratedWidget widget, 19 gfx::AcceleratedWidget widget,
26 scoped_ptr<DriWindowDelegate> delegate) { 20 scoped_ptr<DriWindowDelegate> delegate) {
27 std::pair<WidgetToDelegateMap::iterator, bool> result = 21 std::pair<WidgetToDelegateMap::iterator, bool> result =
28 delegate_map_.add(widget, delegate.Pass()); 22 delegate_map_.add(widget, delegate.Pass());
29 DCHECK(result.second) << "Delegate already added."; 23 DCHECK(result.second) << "Delegate already added.";
30 } 24 }
31 25
32 scoped_ptr<DriWindowDelegate> DriWindowManager::RemoveWindowDelegate( 26 scoped_ptr<DriWindowDelegate> DriWindowDelegateManager::RemoveWindowDelegate(
33 gfx::AcceleratedWidget widget) { 27 gfx::AcceleratedWidget widget) {
34 scoped_ptr<DriWindowDelegate> delegate = delegate_map_.take_and_erase(widget); 28 scoped_ptr<DriWindowDelegate> delegate = delegate_map_.take_and_erase(widget);
35 DCHECK(delegate) << "Attempting to remove non-existing delegate."; 29 DCHECK(delegate) << "Attempting to remove non-existing delegate for "
30 << widget;
36 return delegate.Pass(); 31 return delegate.Pass();
37 } 32 }
38 33
39 DriWindowDelegate* DriWindowManager::GetWindowDelegate( 34 DriWindowDelegate* DriWindowDelegateManager::GetWindowDelegate(
40 gfx::AcceleratedWidget widget) { 35 gfx::AcceleratedWidget widget) {
41 WidgetToDelegateMap::iterator it = delegate_map_.find(widget); 36 WidgetToDelegateMap::iterator it = delegate_map_.find(widget);
42 if (it != delegate_map_.end()) 37 if (it != delegate_map_.end())
43 return it->second; 38 return it->second;
44 39
45 NOTREACHED(); 40 NOTREACHED() << "Attempting to get non-existing delegate for " << widget;
46 return NULL; 41 return NULL;
47 } 42 }
48 43
49 bool DriWindowManager::HasWindowDelegate(gfx::AcceleratedWidget widget) { 44 bool DriWindowDelegateManager::HasWindowDelegate(
45 gfx::AcceleratedWidget widget) {
50 return delegate_map_.find(widget) != delegate_map_.end(); 46 return delegate_map_.find(widget) != delegate_map_.end();
51 } 47 }
52 48
53 } // namespace ui 49 } // namespace ui
OLDNEW
« no previous file with comments | « ui/ozone/platform/dri/dri_window_delegate_manager.h ('k') | ui/ozone/platform/dri/dri_window_delegate_proxy.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698