summaryrefslogtreecommitdiffstats
path: root/ui/base
diff options
context:
space:
mode:
authoralexeypa@chromium.org <alexeypa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-05-09 20:38:18 +0000
committeralexeypa@chromium.org <alexeypa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-05-09 20:38:18 +0000
commit7a66b99fbf5cd967ba12e643fc0072fc20514990 (patch)
treed4bec32782951f4c63a4aca99b655222017c6002 /ui/base
parentdecd4114476cb68ef734dd91cbea6d56c404bee5 (diff)
downloadchromium_src-7a66b99fbf5cd967ba12e643fc0072fc20514990.zip
chromium_src-7a66b99fbf5cd967ba12e643fc0072fc20514990.tar.gz
chromium_src-7a66b99fbf5cd967ba12e643fc0072fc20514990.tar.bz2
Added base::win::InitializeWindowClass() wrapper to make sure that window classes are properly associated with the modules containing their window procedures.
TEST=win,win_rel Review URL: https://chromiumcodereview.appspot.com/10315012 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@136116 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ui/base')
-rw-r--r--ui/base/clipboard/clipboard_win.cc13
-rw-r--r--ui/base/win/window_impl.cc54
2 files changed, 38 insertions, 29 deletions
diff --git a/ui/base/clipboard/clipboard_win.cc b/ui/base/clipboard/clipboard_win.cc
index 8b2eaea..3fa071f 100644
--- a/ui/base/clipboard/clipboard_win.cc
+++ b/ui/base/clipboard/clipboard_win.cc
@@ -188,12 +188,13 @@ Clipboard::FormatType Clipboard::FormatType::Deserialize(
Clipboard::Clipboard() : create_window_(false) {
if (MessageLoop::current()->type() == MessageLoop::TYPE_UI) {
// Make a dummy HWND to be the clipboard's owner.
- WNDCLASSEX wcex = {0};
- wcex.cbSize = sizeof(WNDCLASSEX);
- wcex.lpfnWndProc = base::win::WrappedWindowProc<ClipboardOwnerWndProc>;
- wcex.hInstance = GetModuleHandle(NULL);
- wcex.lpszClassName = L"ClipboardOwnerWindowClass";
- ::RegisterClassEx(&wcex);
+ WNDCLASSEX window_class;
+ base::win::InitializeWindowClass(
+ L"ClipboardOwnerWindowClass",
+ &base::win::WrappedWindowProc<ClipboardOwnerWndProc>,
+ 0, 0, 0, NULL, NULL, NULL, NULL, NULL,
+ &window_class);
+ ::RegisterClassEx(&window_class);
create_window_ = true;
}
diff --git a/ui/base/win/window_impl.cc b/ui/base/win/window_impl.cc
index 31d0fe3..76d4065 100644
--- a/ui/base/win/window_impl.cc
+++ b/ui/base/win/window_impl.cc
@@ -51,7 +51,7 @@ class ClassRegistrar {
~ClassRegistrar() {
for (RegisteredClasses::iterator i = registered_classes_.begin();
i != registered_classes_.end(); ++i) {
- if (!UnregisterClass(i->name.c_str(), NULL)) {
+ if (!UnregisterClass(MAKEINTATOM(i->atom), i->instance)) {
LOG(ERROR) << "Failed to unregister class " << i->name.c_str()
<< ". Error = " << GetLastError();
}
@@ -77,8 +77,10 @@ class ClassRegistrar {
void RegisterClass(const ClassInfo& class_info,
const std::wstring& name,
- ATOM atom) {
- registered_classes_.push_back(RegisteredClass(class_info, name, atom));
+ ATOM atom,
+ HMODULE instance) {
+ registered_classes_.push_back(
+ RegisteredClass(class_info, name, atom, instance));
}
private:
@@ -86,20 +88,25 @@ class ClassRegistrar {
struct RegisteredClass {
RegisteredClass(const ClassInfo& info,
const std::wstring& name,
- ATOM atom)
+ ATOM atom,
+ HMODULE instance)
: info(info),
name(name),
- atom(atom) {
+ atom(atom),
+ instance(instance) {
}
// Info used to create the class.
ClassInfo info;
- // The name given to the window.
+ // The name given to the window class.
std::wstring name;
- // The ATOM returned from creating the window.
+ // The ATOM returned from registering the window class.
ATOM atom;
+
+ // The handle of the module containing the window procedure.
+ HMODULE instance;
};
ClassRegistrar() : registered_count_(0) { }
@@ -241,24 +248,25 @@ std::wstring WindowImpl::GetWindowClassName() {
// No class found, need to register one.
HBRUSH background = NULL;
- WNDCLASSEX class_ex = {
- sizeof(WNDCLASSEX),
- class_info.style,
- base::win::WrappedWindowProc<&WindowImpl::WndProc>,
- 0,
- 0,
- GetModuleHandle(NULL),
- icon,
- NULL,
- reinterpret_cast<HBRUSH>(background + 1),
- NULL,
- name.c_str(),
- icon
- };
- ATOM atom = RegisterClassEx(&class_ex);
+ WNDCLASSEX window_class;
+ base::win::InitializeWindowClass(
+ name.c_str(),
+ &base::win::WrappedWindowProc<WindowImpl::WndProc>,
+ class_info.style,
+ 0,
+ 0,
+ NULL,
+ reinterpret_cast<HBRUSH>(background + 1),
+ NULL,
+ icon,
+ icon,
+ &window_class);
+ HMODULE instance = window_class.hInstance;
+ ATOM atom = RegisterClassEx(&window_class);
CHECK(atom) << GetLastError();
- ClassRegistrar::GetInstance()->RegisterClass(class_info, name, atom);
+ ClassRegistrar::GetInstance()->RegisterClass(
+ class_info, name, atom, instance);
return name;
}