From c1ecc06bafb81166c36e5ea113b0b8edbb73272c Mon Sep 17 00:00:00 2001 From: Tomaka17 Date: Fri, 1 Aug 2014 23:12:46 +0200 Subject: [PATCH] Change the RegisterClass code. Prevents an issue when creating multiple contexts. --- src/win32/init.rs | 49 +++++++++++++++++++++++++---------------------- 1 file changed, 26 insertions(+), 23 deletions(-) diff --git a/src/win32/init.rs b/src/win32/init.rs index 8987d2e3..81fc647d 100644 --- a/src/win32/init.rs +++ b/src/win32/init.rs @@ -31,30 +31,33 @@ pub fn new_window(dimensions: Option<(uint, uint)>, title: &str, // This is the only safe method. Using `nosend` wouldn't work for non-native runtime. TaskBuilder::new().native().spawn(proc() { // registering the window class - let class_name: Vec = "Window Class".utf16_units().collect::>() - .append_one(0); - - let class = ffi::WNDCLASSEX { - cbSize: mem::size_of::() as ffi::UINT, - style: ffi::CS_HREDRAW | ffi::CS_VREDRAW, - lpfnWndProc: callback, - cbClsExtra: 0, - cbWndExtra: 0, - hInstance: unsafe { ffi::GetModuleHandleW(ptr::null()) }, - hIcon: ptr::mut_null(), - hCursor: ptr::mut_null(), - hbrBackground: ptr::mut_null(), - lpszMenuName: ptr::null(), - lpszClassName: class_name.as_ptr(), - hIconSm: ptr::mut_null(), - }; + let class_name = { + let class_name: Vec = "Window Class".utf16_units().collect::>() + .append_one(0); + + let class = ffi::WNDCLASSEX { + cbSize: mem::size_of::() as ffi::UINT, + style: ffi::CS_HREDRAW | ffi::CS_VREDRAW, + lpfnWndProc: callback, + cbClsExtra: 0, + cbWndExtra: 0, + hInstance: unsafe { ffi::GetModuleHandleW(ptr::null()) }, + hIcon: ptr::mut_null(), + hCursor: ptr::mut_null(), + hbrBackground: ptr::mut_null(), + lpszMenuName: ptr::null(), + lpszClassName: class_name.as_ptr(), + hIconSm: ptr::mut_null(), + }; - if unsafe { ffi::RegisterClassExW(&class) } == 0 { - use std::os; - tx.send(Err(format!("RegisterClassEx function failed: {}", - os::error_string(os::errno() as uint)))); - return; - } + // We ignore errors because registering the same window class twice would trigger + // an error, and because errors here are detected during CreateWindowEx anyway. + // Also since there is no weird element in the struct, there is no reason for this + // call to fail. + unsafe { ffi::RegisterClassExW(&class) }; + + class_name + }; // building a RECT object with coordinates let mut rect = ffi::RECT {