Remove unused Win32Window class

BUG=None

Change-Id: I1d6b4e64a01076166d841c7c72eb0e2b968dd812
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/306441
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Commit-Queue: Philipp Hancke <phancke@microsoft.com>
Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#40140}
This commit is contained in:
Philipp Hancke 2023-05-24 18:49:10 +02:00 committed by WebRTC LUCI CQ
parent 0f1376529a
commit 1cc41ea84f
4 changed files with 1 additions and 292 deletions

View file

@ -1065,8 +1065,6 @@ if (is_win) {
sources = [ sources = [
"win32.cc", "win32.cc",
"win32.h", "win32.h",
"win32_window.cc",
"win32_window.h",
] ]
deps = [ deps = [
@ -2042,10 +2040,7 @@ if (rtc_include_tests) {
deps += [ "synchronization:synchronization_unittests" ] deps += [ "synchronization:synchronization_unittests" ]
} }
if (is_win) { if (is_win) {
sources += [ sources += [ "win32_unittest.cc" ]
"win32_unittest.cc",
"win32_window_unittest.cc",
]
deps += [ ":win32" ] deps += [ ":win32" ]
} }
if (is_posix || is_fuchsia) { if (is_posix || is_fuchsia) {

View file

@ -1,150 +0,0 @@
/*
* Copyright 2004 The WebRTC Project Authors. All rights reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include "rtc_base/win32_window.h"
#include "rtc_base/checks.h"
#include "rtc_base/logging.h"
namespace rtc {
///////////////////////////////////////////////////////////////////////////////
// Win32Window
///////////////////////////////////////////////////////////////////////////////
static const wchar_t kWindowBaseClassName[] = L"RtcWindowBaseClass";
HINSTANCE Win32Window::instance_ = nullptr;
ATOM Win32Window::window_class_ = 0;
Win32Window::Win32Window() : wnd_(nullptr) {}
Win32Window::~Win32Window() {
RTC_DCHECK(nullptr == wnd_);
}
bool Win32Window::Create(HWND parent,
const wchar_t* title,
DWORD style,
DWORD exstyle,
int x,
int y,
int cx,
int cy) {
if (wnd_) {
// Window already exists.
return false;
}
if (!window_class_) {
if (!GetModuleHandleExW(GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS |
GET_MODULE_HANDLE_EX_FLAG_UNCHANGED_REFCOUNT,
reinterpret_cast<LPCWSTR>(&Win32Window::WndProc),
&instance_)) {
RTC_LOG_GLE(LS_ERROR) << "GetModuleHandleEx failed";
return false;
}
// Register or reregister the class as necessary. window_class_ == nullptr
// is not an infallible indicator that the class is unregistered.
WNDCLASSEXW wcex;
memset(&wcex, 0, sizeof(wcex));
wcex.cbSize = sizeof(wcex);
if (::GetClassInfoExW(instance_, kWindowBaseClassName, &wcex) &&
!::UnregisterClassW(kWindowBaseClassName, instance_)) {
RTC_LOG_GLE(LS_ERROR) << "UnregisterClass failed.";
}
memset(&wcex, 0, sizeof(wcex));
wcex.cbSize = sizeof(wcex);
wcex.hInstance = instance_;
wcex.lpfnWndProc = &Win32Window::WndProc;
wcex.lpszClassName = kWindowBaseClassName;
window_class_ = ::RegisterClassExW(&wcex);
if (!window_class_) {
RTC_LOG_GLE(LS_ERROR) << "RegisterClassEx failed";
return false;
}
}
wnd_ = ::CreateWindowExW(exstyle, kWindowBaseClassName, title, style, x, y,
cx, cy, parent, nullptr, instance_, this);
return (nullptr != wnd_);
}
void Win32Window::Destroy() {
const bool success = ::DestroyWindow(wnd_);
RTC_DCHECK(success);
}
void Win32Window::Shutdown() {
if (window_class_) {
if (!::UnregisterClass(MAKEINTATOM(window_class_), instance_)) {
RTC_LOG_GLE(LS_ERROR) << "UnregisterClass failed.";
}
window_class_ = 0;
}
}
bool Win32Window::OnMessage(UINT uMsg,
WPARAM wParam,
LPARAM lParam,
LRESULT& result) {
switch (uMsg) {
case WM_CLOSE:
if (!OnClose()) {
result = 0;
return true;
}
break;
}
return false;
}
bool Win32Window::OnClose() {
return true;
}
void Win32Window::OnNcDestroy() {
// Do nothing. }
}
LRESULT Win32Window::WndProc(HWND hwnd,
UINT uMsg,
WPARAM wParam,
LPARAM lParam) {
Win32Window* that =
reinterpret_cast<Win32Window*>(::GetWindowLongPtr(hwnd, GWLP_USERDATA));
if (!that && (WM_CREATE == uMsg)) {
CREATESTRUCT* cs = reinterpret_cast<CREATESTRUCT*>(lParam);
that = static_cast<Win32Window*>(cs->lpCreateParams);
that->wnd_ = hwnd;
::SetWindowLongPtr(hwnd, GWLP_USERDATA, reinterpret_cast<LONG_PTR>(that));
}
if (that) {
LRESULT result;
bool handled = that->OnMessage(uMsg, wParam, lParam, result);
if (WM_DESTROY == uMsg) {
for (HWND child = ::GetWindow(hwnd, GW_CHILD); child;
child = ::GetWindow(child, GW_HWNDNEXT)) {
RTC_LOG(LS_INFO) << "Child window: " << static_cast<void*>(child);
}
}
if (WM_NCDESTROY == uMsg) {
::SetWindowLongPtr(hwnd, GWLP_USERDATA, NULL);
that->wnd_ = nullptr;
that->OnNcDestroy();
}
if (handled) {
return result;
}
}
return ::DefWindowProc(hwnd, uMsg, wParam, lParam);
}
} // namespace rtc

View file

@ -1,70 +0,0 @@
/*
* Copyright 2004 The WebRTC Project Authors. All rights reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#ifndef RTC_BASE_WIN32_WINDOW_H_
#define RTC_BASE_WIN32_WINDOW_H_
#if defined(WEBRTC_WIN)
#include "rtc_base/win32.h"
namespace rtc {
///////////////////////////////////////////////////////////////////////////////
// Win32Window
///////////////////////////////////////////////////////////////////////////////
class Win32Window {
public:
Win32Window();
virtual ~Win32Window();
HWND handle() const { return wnd_; }
bool Create(HWND parent,
const wchar_t* title,
DWORD style,
DWORD exstyle,
int x,
int y,
int cx,
int cy);
void Destroy();
// Call this when your DLL unloads.
static void Shutdown();
protected:
virtual bool OnMessage(UINT uMsg,
WPARAM wParam,
LPARAM lParam,
LRESULT& result);
virtual bool OnClose();
virtual void OnNcDestroy();
private:
static LRESULT CALLBACK WndProc(HWND hwnd,
UINT uMsg,
WPARAM wParam,
LPARAM lParam);
HWND wnd_;
static HINSTANCE instance_;
static ATOM window_class_;
};
///////////////////////////////////////////////////////////////////////////////
} // namespace rtc
#endif // WEBRTC_WIN
#endif // RTC_BASE_WIN32_WINDOW_H_

View file

@ -1,66 +0,0 @@
/*
* Copyright 2009 The WebRTC Project Authors. All rights reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include "rtc_base/win32_window.h"
#include "rtc_base/gunit.h"
#include "rtc_base/logging.h"
static LRESULT kDummyResult = 0x1234ABCD;
class TestWindow : public rtc::Win32Window {
public:
TestWindow() : destroyed_(false) { memset(&msg_, 0, sizeof(msg_)); }
const MSG& msg() const { return msg_; }
bool destroyed() const { return destroyed_; }
bool OnMessage(UINT uMsg,
WPARAM wParam,
LPARAM lParam,
LRESULT& result) override {
msg_.message = uMsg;
msg_.wParam = wParam;
msg_.lParam = lParam;
result = kDummyResult;
return true;
}
void OnNcDestroy() override { destroyed_ = true; }
private:
MSG msg_;
bool destroyed_;
};
TEST(Win32WindowTest, Basics) {
TestWindow wnd;
EXPECT_TRUE(wnd.handle() == nullptr);
EXPECT_FALSE(wnd.destroyed());
EXPECT_TRUE(wnd.Create(0, L"Test", 0, 0, 0, 0, 100, 100));
EXPECT_TRUE(wnd.handle() != nullptr);
EXPECT_EQ(kDummyResult, ::SendMessage(wnd.handle(), WM_USER, 1, 2));
EXPECT_EQ(static_cast<UINT>(WM_USER), wnd.msg().message);
EXPECT_EQ(1u, wnd.msg().wParam);
EXPECT_EQ(2l, wnd.msg().lParam);
wnd.Destroy();
EXPECT_TRUE(wnd.handle() == nullptr);
EXPECT_TRUE(wnd.destroyed());
}
TEST(Win32WindowTest, MultipleWindows) {
TestWindow wnd1, wnd2;
EXPECT_TRUE(wnd1.Create(0, L"Test", 0, 0, 0, 0, 100, 100));
EXPECT_TRUE(wnd2.Create(0, L"Test", 0, 0, 0, 0, 100, 100));
EXPECT_TRUE(wnd1.handle() != nullptr);
EXPECT_TRUE(wnd2.handle() != nullptr);
wnd1.Destroy();
wnd2.Destroy();
EXPECT_TRUE(wnd2.handle() == nullptr);
EXPECT_TRUE(wnd1.handle() == nullptr);
}