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

Side by Side Diff: base/win/message_window.cc

Issue 16020005: Fixed the racy code around the message-only window in base::MessagePumpForUI on Windows. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: - Created 7 years, 6 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "remoting/host/win/message_window.h" 5 #include "base/win/message_window.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/process_util.h" 8 #include "base/process_util.h"
9 #include "base/stringprintf.h" 9 #include "base/stringprintf.h"
10 #include "base/utf_string_conversions.h" 10 #include "base/utf_string_conversions.h"
11 #include "base/win/wrapped_window_proc.h" 11 #include "base/win/wrapped_window_proc.h"
12 12
13 const char kClassNameFormat[] = "Chromoting_MessageWindow_%p"; 13 const char kClassNameFormat[] = "Chrome_MessageWindow_%p";
14 14
15 namespace remoting { 15 namespace base {
16 namespace win { 16 namespace win {
17 17
18 MessageWindow::MessageWindow() 18 MessageWindow::MessageWindow()
19 : atom_(0), 19 : atom_(0),
20 instance_(NULL), 20 instance_(NULL),
21 window_(NULL) { 21 window_(NULL) {
22 class_name_ = base::StringPrintf(kClassNameFormat, this); 22 class_name_ = base::StringPrintf(kClassNameFormat, this);
23 instance_ = base::GetModuleFromAddress(static_cast<WNDPROC>( 23 instance_ = base::GetModuleFromAddress(static_cast<WNDPROC>(
cpu_(ooo_6.6-7.5) 2013/06/10 21:27:19 I don't see any value on keeping instance_, you ca
24 &base::win::WrappedWindowProc<WindowProc>)); 24 &base::win::WrappedWindowProc<WindowProc>));
25 } 25 }
26 26
27 MessageWindow::MessageWindow(const std::string& class_name, HINSTANCE instance)
28 : atom_(0),
29 class_name_(class_name),
30 instance_(instance),
31 window_(NULL) {
32 }
33
34 MessageWindow::~MessageWindow() { 27 MessageWindow::~MessageWindow() {
35 DCHECK(CalledOnValidThread()); 28 DCHECK(CalledOnValidThread());
36 29
37 if (window_ != NULL) { 30 if (window_ != NULL) {
38 DestroyWindow(window_); 31 DestroyWindow(window_);
39 window_ = NULL; 32 window_ = NULL;
cpu_(ooo_6.6-7.5) 2013/06/10 21:27:19 we don't use that practice of setting member vars
40 } 33 }
41 34
42 if (atom_ != 0) { 35 if (atom_ != 0) {
43 UnregisterClass(MAKEINTATOM(atom_), instance_); 36 UnregisterClass(MAKEINTATOM(atom_), instance_);
44 atom_ = 0; 37 atom_ = 0;
45 } 38 }
46 } 39 }
47 40
48 bool MessageWindow::Create(Delegate* delegate) { 41 bool MessageWindow::Create(Delegate* delegate) {
49 DCHECK(CalledOnValidThread()); 42 DCHECK(CalledOnValidThread());
50 DCHECK(!atom_); 43 DCHECK(!atom_);
51 DCHECK(!window_); 44 DCHECK(!window_);
52 45
53 // Register a separate window class for each instance of |MessageWindow|. 46 // Register a separate window class for each instance of |MessageWindow|.
54 string16 class_name = UTF8ToUTF16(class_name_); 47 string16 class_name = UTF8ToUTF16(class_name_);
55 WNDCLASSEX window_class; 48 WNDCLASSEX window_class;
56 window_class.cbSize = sizeof(window_class); 49 window_class.cbSize = sizeof(window_class);
57 window_class.style = 0; 50 window_class.style = 0;
58 window_class.lpfnWndProc = &base::win::WrappedWindowProc<WindowProc>; 51 window_class.lpfnWndProc = &base::win::WrappedWindowProc<WindowProc>;
59 window_class.cbClsExtra = 0; 52 window_class.cbClsExtra = 0;
60 window_class.cbWndExtra = 0; 53 window_class.cbWndExtra = 0;
61 window_class.hInstance = instance_; 54 window_class.hInstance = instance_;
62 window_class.hIcon = NULL; 55 window_class.hIcon = NULL;
63 window_class.hCursor = NULL; 56 window_class.hCursor = NULL;
64 window_class.hbrBackground = NULL; 57 window_class.hbrBackground = NULL;
65 window_class.lpszMenuName = NULL; 58 window_class.lpszMenuName = NULL;
66 window_class.lpszClassName = class_name.c_str(); 59 window_class.lpszClassName = class_name.c_str();
67 window_class.hIconSm = NULL; 60 window_class.hIconSm = NULL;
68 atom_ = RegisterClassEx(&window_class); 61 atom_ = RegisterClassEx(&window_class);
cpu_(ooo_6.6-7.5) 2013/06/10 21:27:19 what is the value of keeping the class name and th
69 if (atom_ == 0) { 62 if (atom_ == 0) {
70 LOG_GETLASTERROR(ERROR) 63 LOG_GETLASTERROR(ERROR)
71 << "Failed to register the window class '" << class_name_ << "'"; 64 << "Failed to register the window class '" << class_name_ << "'";
72 return false; 65 return false;
73 } 66 }
74 67
75 window_ = CreateWindow(MAKEINTATOM(atom_), 0, 0, 0, 0, 0, 0, HWND_MESSAGE, 0, 68 window_ = CreateWindow(MAKEINTATOM(atom_), 0, 0, 0, 0, 0, 0, HWND_MESSAGE, 0,
76 instance_, delegate); 69 instance_, delegate);
77 if (!window_) { 70 if (!window_) {
78 LOG_GETLASTERROR(ERROR) << "Failed to create a message-only window"; 71 LOG_GETLASTERROR(ERROR) << "Failed to create a message-only window";
(...skipping 29 matching lines...) Expand all
108 if (delegate) { 101 if (delegate) {
109 LRESULT message_result; 102 LRESULT message_result;
110 if (delegate->HandleMessage(hwnd, message, wparam, lparam, &message_result)) 103 if (delegate->HandleMessage(hwnd, message, wparam, lparam, &message_result))
111 return message_result; 104 return message_result;
112 } 105 }
113 106
114 return DefWindowProc(hwnd, message, wparam, lparam); 107 return DefWindowProc(hwnd, message, wparam, lparam);
115 } 108 }
116 109
117 } // namespace win 110 } // namespace win
118 } // namespace remoting 111 } // namespace base
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698