Task #3960 - Split CMSWindowsHookLibraryLoader into hook and shellex loaders

- reordered include order for winsock2.h (more robust)
- removed Windows.h include from synwinxt.h (not needed)
This commit is contained in:
Nick Bolton 2014-03-17 14:34:13 +00:00
parent 407378fbc5
commit 1b5cdecc60
10 changed files with 311 additions and 220 deletions

View File

@ -25,9 +25,9 @@
#include "arch/IArchNetwork.h" #include "arch/IArchNetwork.h"
#include "arch/IArchMultithread.h" #include "arch/IArchMultithread.h"
#include <WinSock2.h>
#define WIN32_LEAN_AND_MEAN #define WIN32_LEAN_AND_MEAN
#include <Windows.h> #include <Windows.h>
#include <winsock2.h>
#include <list> #include <list>
#define ARCH_NETWORK CArchNetworkWinsock #define ARCH_NETWORK CArchNetworkWinsock

View File

@ -0,0 +1,128 @@
/*
* synergy -- mouse and keyboard sharing utility
* Copyright (C) 2012 Bolton Software Ltd.
* Copyright (C) 2011 Chris Schoeneman
*
* This package is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* found in the file COPYING that should have accompanied this file.
*
* This package is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "platform/MSWindowsHook.h"
#include "synergy/XScreen.h"
#include "base/Log.h"
static const char* g_name = "synwinhk";
CMSWindowsHook::CMSWindowsHook() :
m_initFunc(NULL),
m_cleanupFunc(NULL),
m_setSidesFunc(NULL),
m_setZoneFunc(NULL),
m_setModeFunc(NULL),
m_instance(NULL)
{
}
CMSWindowsHook::~CMSWindowsHook()
{
cleanup();
if (m_instance != NULL) {
FreeLibrary(m_instance);
}
}
void
CMSWindowsHook::loadLibrary()
{
// load library
m_instance = LoadLibrary(g_name);
if (m_instance == NULL) {
LOG((CLOG_ERR "failed to load hook library, %s.dll is missing or invalid", g_name));
throw XScreenOpenFailure();
}
// look up functions
m_setSidesFunc = (SetSidesFunc)GetProcAddress(m_instance, "setSides");
m_setZoneFunc = (SetZoneFunc)GetProcAddress(m_instance, "setZone");
m_setModeFunc = (SetModeFunc)GetProcAddress(m_instance, "setMode");
m_initFunc = (InitFunc)GetProcAddress(m_instance, "init");
m_cleanupFunc = (CleanupFunc)GetProcAddress(m_instance, "cleanup");
if (m_setSidesFunc == NULL ||
m_setZoneFunc == NULL ||
m_setModeFunc == NULL ||
m_initFunc == NULL ||
m_cleanupFunc == NULL) {
LOG((CLOG_ERR "failed to load hook function, %s.dll could be out of date", g_name));
throw XScreenOpenFailure();
}
// initialize library
if (init(GetCurrentThreadId()) == 0) {
LOG((CLOG_ERR "failed to init %s.dll, another program may be using it", g_name));
LOG((CLOG_INFO "restarting your computer may solve this error"));
throw XScreenOpenFailure();
}
}
HINSTANCE
CMSWindowsHook::getInstance() const
{
return m_instance;
}
int
CMSWindowsHook::init(DWORD threadID)
{
if (m_initFunc == NULL) {
return NULL;
}
return m_initFunc(threadID);
}
int
CMSWindowsHook::cleanup()
{
if (m_cleanupFunc == NULL) {
return NULL;
}
return m_cleanupFunc();
}
void
CMSWindowsHook::setSides(UInt32 sides)
{
if (m_setSidesFunc == NULL) {
return;
}
m_setSidesFunc(sides);
}
void
CMSWindowsHook::setZone(SInt32 x, SInt32 y, SInt32 w, SInt32 h, SInt32 jumpZoneSize)
{
if (m_setZoneFunc == NULL) {
return;
}
m_setZoneFunc(x, y, w, h, jumpZoneSize);
}
void
CMSWindowsHook::setMode(EHookMode mode)
{
if (m_setModeFunc == NULL) {
return;
}
m_setModeFunc(mode);
}

View File

@ -19,30 +19,30 @@
#pragma once #pragma once
#include "synwinhk/synwinhk.h" #include "synwinhk/synwinhk.h"
#include "synwinxt/synwinxt.h"
#define WIN32_LEAN_AND_MEAN #define WIN32_LEAN_AND_MEAN
#include <Windows.h> #include <Windows.h>
//! Loads Windows hook DLLs. //! Loads and provides functions for the Windows hook
class CMSWindowsHookLibraryLoader class CMSWindowsHook
{ {
public: public:
CMSWindowsHookLibraryLoader(); CMSWindowsHook();
virtual ~CMSWindowsHookLibraryLoader(); virtual ~CMSWindowsHook();
HINSTANCE openHookLibrary(const char* name); void loadLibrary();
HINSTANCE openShellLibrary(const char* name); HINSTANCE getInstance() const;
int init(DWORD threadID);
int cleanup();
void setSides(UInt32 sides);
void setZone(SInt32 x, SInt32 y, SInt32 w, SInt32 h, SInt32 jumpZoneSize);
void setMode(EHookMode mode);
// TODO: either make these private or expose properly private:
InitFunc m_init; InitFunc m_initFunc;
CleanupFunc m_cleanup; CleanupFunc m_cleanupFunc;
SetSidesFunc m_setSides; SetSidesFunc m_setSidesFunc;
SetZoneFunc m_setZone; SetZoneFunc m_setZoneFunc;
SetModeFunc m_setMode; SetModeFunc m_setModeFunc;
HINSTANCE m_instance;
GetDraggingFilenameFunc
m_getDraggingFilename;
ClearDraggingFilenameFunc
m_clearDraggingFilename;
}; };

View File

@ -1,107 +0,0 @@
/*
* synergy -- mouse and keyboard sharing utility
* Copyright (C) 2012 Bolton Software Ltd.
* Copyright (C) 2011 Chris Schoeneman
*
* This package is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* found in the file COPYING that should have accompanied this file.
*
* This package is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "platform/MSWindowsHookLibraryLoader.h"
#include "synergy/XScreen.h"
#include "base/Log.h"
CMSWindowsHookLibraryLoader::CMSWindowsHookLibraryLoader() :
m_init(NULL),
m_cleanup(NULL),
m_setSides(NULL),
m_setZone(NULL),
m_setMode(NULL),
m_getDraggingFilename(NULL),
m_clearDraggingFilename(NULL)
{
}
CMSWindowsHookLibraryLoader::~CMSWindowsHookLibraryLoader()
{
// TODO: take ownership of m_ and delete them.
}
HINSTANCE
CMSWindowsHookLibraryLoader::openHookLibrary(const char* name)
{
// load the hook library
HINSTANCE hookLibrary = LoadLibrary(name);
if (hookLibrary == NULL) {
LOG((CLOG_ERR "failed to load hook library, %s.dll is missing or invalid", name));
throw XScreenOpenFailure();
}
// look up functions
m_setSides = (SetSidesFunc)GetProcAddress(hookLibrary, "setSides");
m_setZone = (SetZoneFunc)GetProcAddress(hookLibrary, "setZone");
m_setMode = (SetModeFunc)GetProcAddress(hookLibrary, "setMode");
m_init = (InitFunc)GetProcAddress(hookLibrary, "init");
m_cleanup = (CleanupFunc)GetProcAddress(hookLibrary, "cleanup");
if (m_setSides == NULL ||
m_setZone == NULL ||
m_setMode == NULL ||
m_init == NULL ||
m_cleanup == NULL) {
LOG((CLOG_ERR "failed to load hook function, %s.dll could be out of date", name));
throw XScreenOpenFailure();
}
// initialize hook library
if (m_init(GetCurrentThreadId()) == 0) {
LOG((CLOG_ERR "failed to init %s.dll, another program may be using it", name));
LOG((CLOG_INFO "restarting your computer may solve this error"));
throw XScreenOpenFailure();
}
return hookLibrary;
}
HINSTANCE
CMSWindowsHookLibraryLoader::openShellLibrary(const char* name)
{
OSVERSIONINFO osvi;
ZeroMemory(&osvi, sizeof(OSVERSIONINFO));
osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
GetVersionEx(&osvi);
if (osvi.dwMajorVersion < 6) {
LOG((CLOG_INFO "skipping shell extension library load, %s.dll not supported before vista", name));
return NULL;
}
// load the hook library
HINSTANCE shellLibrary = LoadLibrary(name);
if (shellLibrary == NULL) {
LOG((CLOG_ERR "failed to load shell extension library, %s.dll is missing or invalid", name));
throw XScreenOpenFailure();
}
// look up functions
m_getDraggingFilename = (GetDraggingFilenameFunc)GetProcAddress(shellLibrary, "getDraggingFilename");
m_clearDraggingFilename = (ClearDraggingFilenameFunc)GetProcAddress(shellLibrary, "clearDraggingFilename");
if (m_getDraggingFilename == NULL ||
m_clearDraggingFilename == NULL) {
LOG((CLOG_ERR "failed to load shell extension function, %s.dll could be out of date", name));
throw XScreenOpenFailure();
}
return shellLibrary;
}

View File

@ -117,8 +117,6 @@ CMSWindowsScreen::CMSWindowsScreen(
m_nextClipboardWindow(NULL), m_nextClipboardWindow(NULL),
m_ownClipboard(false), m_ownClipboard(false),
m_desks(NULL), m_desks(NULL),
m_hookLibrary(NULL),
m_shellLibrary(NULL),
m_keyState(NULL), m_keyState(NULL),
m_hasMouse(GetSystemMetrics(SM_MOUSEPRESENT) != 0), m_hasMouse(GetSystemMetrics(SM_MOUSEPRESENT) != 0),
m_showingMouse(false), m_showingMouse(false),
@ -130,17 +128,19 @@ CMSWindowsScreen::CMSWindowsScreen(
s_screen = this; s_screen = this;
try { try {
if (m_isPrimary && !m_noHooks) { if (m_isPrimary && !m_noHooks) {
m_hookLibrary = openHookLibrary("synwinhk"); m_hook.loadLibrary();
} }
m_shellLibrary = openShellLibrary("synwinxt"); m_shellEx.loadLibrary();
m_screensaver = new CMSWindowsScreenSaver(); m_screensaver = new CMSWindowsScreenSaver();
m_desks = new CMSWindowsDesks( m_desks = new CMSWindowsDesks(
m_isPrimary, m_noHooks, m_isPrimary,
m_hookLibrary, m_screensaver, m_noHooks,
m_hook.getInstance(),
m_screensaver,
m_events, m_events,
new TMethodJob<CMSWindowsScreen>(this, new TMethodJob<CMSWindowsScreen>(
&CMSWindowsScreen::updateKeysCB), this, &CMSWindowsScreen::updateKeysCB),
stopOnDeskSwitch); stopOnDeskSwitch);
m_keyState = new CMSWindowsKeyState(m_desks, getEventTarget(), m_events); m_keyState = new CMSWindowsKeyState(m_desks, getEventTarget(), m_events);
updateScreenShape(); updateScreenShape();
@ -166,13 +166,6 @@ CMSWindowsScreen::CMSWindowsScreen(
delete m_screensaver; delete m_screensaver;
destroyWindow(m_window); destroyWindow(m_window);
destroyClass(m_class); destroyClass(m_class);
if (m_hookLibrary != NULL)
closeHookLibrary(m_hookLibrary);
if (m_shellLibrary != NULL)
closeShellLibrary(m_shellLibrary);
s_screen = NULL; s_screen = NULL;
throw; throw;
} }
@ -199,12 +192,6 @@ CMSWindowsScreen::~CMSWindowsScreen()
destroyWindow(m_window); destroyWindow(m_window);
destroyClass(m_class); destroyClass(m_class);
if (m_hookLibrary != NULL)
closeHookLibrary(m_hookLibrary);
if (m_shellLibrary != NULL)
closeShellLibrary(m_shellLibrary);
s_screen = NULL; s_screen = NULL;
} }
@ -241,13 +228,11 @@ CMSWindowsScreen::enable()
m_desks->enable(); m_desks->enable();
if (m_isPrimary) { if (m_isPrimary) {
if (m_hookLibrary != NULL) {
// set jump zones // set jump zones
m_hookLibraryLoader.m_setZone(m_x, m_y, m_w, m_h, getJumpZoneSize()); m_hook.setZone(m_x, m_y, m_w, m_h, getJumpZoneSize());
// watch jump zones // watch jump zones
m_hookLibraryLoader.m_setMode(kHOOK_WATCH_JUMP_ZONE); m_hook.setMode(kHOOK_WATCH_JUMP_ZONE);
}
} }
else { else {
// prevent the system from entering power saving modes. if // prevent the system from entering power saving modes. if
@ -264,10 +249,8 @@ CMSWindowsScreen::disable()
m_desks->disable(); m_desks->disable();
if (m_isPrimary) { if (m_isPrimary) {
if (m_hookLibrary != NULL) {
// disable hooks // disable hooks
m_hookLibraryLoader.m_setMode(kHOOK_DISABLE); m_hook.setMode(kHOOK_DISABLE);
}
// enable special key sequences on win95 family // enable special key sequences on win95 family
enableSpecialKeys(true); enableSpecialKeys(true);
@ -304,10 +287,8 @@ CMSWindowsScreen::enter()
// enable special key sequences on win95 family // enable special key sequences on win95 family
enableSpecialKeys(true); enableSpecialKeys(true);
if (m_hookLibrary != NULL) {
// watch jump zones // watch jump zones
m_hookLibraryLoader.m_setMode(kHOOK_WATCH_JUMP_ZONE); m_hook.setMode(kHOOK_WATCH_JUMP_ZONE);
}
// all messages prior to now are invalid // all messages prior to now are invalid
nextMark(); nextMark();
@ -359,10 +340,7 @@ CMSWindowsScreen::leave()
// reflected in the internal keyboard state. // reflected in the internal keyboard state.
m_keyState->saveModifiers(); m_keyState->saveModifiers();
if (m_hookLibrary != NULL) { m_hook.setMode(kHOOK_RELAY_EVENTS);
// capture events
m_hookLibraryLoader.m_setMode(kHOOK_RELAY_EVENTS);
}
} }
// now off screen // now off screen
@ -541,9 +519,7 @@ CMSWindowsScreen::reconfigure(UInt32 activeSides)
assert(m_isPrimary); assert(m_isPrimary);
LOG((CLOG_DEBUG "active sides: %x", activeSides)); LOG((CLOG_DEBUG "active sides: %x", activeSides));
m_hook.setSides(activeSides);
if (m_hookLibrary != NULL)
m_hookLibraryLoader.m_setSides(activeSides);
} }
void void
@ -812,35 +788,6 @@ CMSWindowsScreen::fakeAllKeysUp()
updateForceShowCursor(); updateForceShowCursor();
} }
HINSTANCE
CMSWindowsScreen::openHookLibrary(const char* name)
{
return m_hookLibraryLoader.openHookLibrary(name);
}
HINSTANCE
CMSWindowsScreen::openShellLibrary(const char* name)
{
return m_hookLibraryLoader.openShellLibrary(name);
}
void
CMSWindowsScreen::closeHookLibrary(HINSTANCE hookLibrary) const
{
if (hookLibrary != NULL) {
m_hookLibraryLoader.m_cleanup();
FreeLibrary(hookLibrary);
}
}
void
CMSWindowsScreen::closeShellLibrary(HINSTANCE shellLibrary) const
{
if (shellLibrary != NULL) {
FreeLibrary(shellLibrary);
}
}
HCURSOR HCURSOR
CMSWindowsScreen::createBlankCursor() const CMSWindowsScreen::createBlankCursor() const
{ {
@ -1517,7 +1464,7 @@ CMSWindowsScreen::onDisplayChange()
// tell hook about resize if on screen // tell hook about resize if on screen
else { else {
m_hookLibraryLoader.m_setZone(m_x, m_y, m_w, m_h, getJumpZoneSize()); m_hook.setZone(m_x, m_y, m_w, m_h, getJumpZoneSize());
} }
} }
@ -1908,7 +1855,7 @@ CMSWindowsScreen::getDraggingFilename()
{ {
if (m_draggingStarted) { if (m_draggingStarted) {
char filename[MAX_PATH]; char filename[MAX_PATH];
m_hookLibraryLoader.m_getDraggingFilename(filename); m_shellEx.getDraggingFilename(filename);
m_draggingFilename = filename; m_draggingFilename = filename;
} }
@ -1919,7 +1866,7 @@ void
CMSWindowsScreen::clearDraggingFilename() CMSWindowsScreen::clearDraggingFilename()
{ {
LOG((CLOG_DEBUG "clearing stored dragging file name")); LOG((CLOG_DEBUG "clearing stored dragging file name"));
m_hookLibraryLoader.m_clearDraggingFilename(); m_shellEx.clearDraggingFilename();
} }
const CString& const CString&

View File

@ -18,7 +18,8 @@
#pragma once #pragma once
#include "platform/MSWindowsHookLibraryLoader.h" #include "platform/MSWindowsShellEx.h"
#include "platform/MSWindowsHook.h"
#include "synergy/PlatformScreen.h" #include "synergy/PlatformScreen.h"
#include "synwinhk/synwinhk.h" #include "synwinhk/synwinhk.h"
#include "mt/CondVar.h" #include "mt/CondVar.h"
@ -128,10 +129,6 @@ protected:
private: private:
// initialization and shutdown operations // initialization and shutdown operations
HINSTANCE openHookLibrary(const char* name);
HINSTANCE openShellLibrary(const char* name);
void closeHookLibrary(HINSTANCE hookLibrary) const;
void closeShellLibrary(HINSTANCE shellLibrary) const;
HCURSOR createBlankCursor() const; HCURSOR createBlankCursor() const;
void destroyCursor(HCURSOR cursor) const; void destroyCursor(HCURSOR cursor) const;
ATOM createWindowClass() const; ATOM createWindowClass() const;
@ -290,10 +287,6 @@ private:
// one desk per desktop and a cond var to communicate with it // one desk per desktop and a cond var to communicate with it
CMSWindowsDesks* m_desks; CMSWindowsDesks* m_desks;
// hook library stuff
HINSTANCE m_hookLibrary;
HINSTANCE m_shellLibrary;
// keyboard stuff // keyboard stuff
CMSWindowsKeyState* m_keyState; CMSWindowsKeyState* m_keyState;
@ -322,9 +315,8 @@ private:
MOUSEKEYS m_mouseKeys; MOUSEKEYS m_mouseKeys;
MOUSEKEYS m_oldMouseKeys; MOUSEKEYS m_oldMouseKeys;
// loads synwinhk.dll CMSWindowsHook m_hook;
CMSWindowsHookLibraryLoader CMSWindowsShellEx m_shellEx;
m_hookLibraryLoader;
static CMSWindowsScreen* static CMSWindowsScreen*
s_screen; s_screen;

View File

@ -0,0 +1,92 @@
/*
* synergy -- mouse and keyboard sharing utility
* Copyright (C) 2014 Bolton Software Ltd.
*
* This package is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* found in the file COPYING that should have accompanied this file.
*
* This package is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "platform/MSWindowsShellEx.h"
#include "synergy/XScreen.h"
#include "base/Log.h"
static const char* g_name = "synwinxt";
CMSWindowsShellEx::CMSWindowsShellEx() :
m_getDraggingFilenameFunc(NULL),
m_clearDraggingFilenameFunc(NULL),
m_instance(NULL)
{
}
CMSWindowsShellEx::~CMSWindowsShellEx()
{
if (m_instance != NULL) {
FreeLibrary(m_instance);
}
}
void
CMSWindowsShellEx::loadLibrary()
{
OSVERSIONINFO osvi;
ZeroMemory(&osvi, sizeof(OSVERSIONINFO));
osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
GetVersionEx(&osvi);
if (osvi.dwMajorVersion < 6) {
LOG((CLOG_INFO "skipping shell extension library load, %s.dll not supported before vista", g_name));
return;
}
// load library
m_instance = LoadLibrary(g_name);
if (m_instance == NULL) {
LOG((CLOG_ERR "failed to load shell extension library, %s.dll is missing or invalid", g_name));
throw XScreenOpenFailure();
}
// look up functions
m_getDraggingFilenameFunc = (GetDraggingFilenameFunc)GetProcAddress(m_instance, "getDraggingFilename");
m_clearDraggingFilenameFunc = (ClearDraggingFilenameFunc)GetProcAddress(m_instance, "clearDraggingFilename");
if (m_getDraggingFilenameFunc == NULL ||
m_clearDraggingFilenameFunc == NULL) {
LOG((CLOG_ERR "failed to load shell extension function, %s.dll could be out of date", g_name));
throw XScreenOpenFailure();
}
}
HINSTANCE
CMSWindowsShellEx::getInstance() const
{
return m_instance;
}
void
CMSWindowsShellEx::getDraggingFilename(char* filename) const
{
if (m_getDraggingFilenameFunc == NULL) {
return;
}
m_getDraggingFilenameFunc(filename);
}
void
CMSWindowsShellEx::clearDraggingFilename()
{
if (m_getDraggingFilenameFunc == NULL) {
return;
}
m_clearDraggingFilenameFunc();
}

View File

@ -0,0 +1,43 @@
/*
* synergy -- mouse and keyboard sharing utility
* Copyright (C) 2014 Bolton Software Ltd.
*
* This package is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* found in the file COPYING that should have accompanied this file.
*
* This package is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include "synwinxt/synwinxt.h"
#define WIN32_LEAN_AND_MEAN
#include <Windows.h>
//! Loads and provides functions for the Windows shell extension
class CMSWindowsShellEx
{
public:
CMSWindowsShellEx();
virtual ~CMSWindowsShellEx();
void loadLibrary();
HINSTANCE getInstance() const;
void getDraggingFilename(char* filename) const;
void clearDraggingFilename();
private:
HINSTANCE m_instance;
GetDraggingFilenameFunc
m_getDraggingFilenameFunc;
ClearDraggingFilenameFunc
m_clearDraggingFilenameFunc;
};

View File

@ -17,8 +17,6 @@
#pragma once #pragma once
#include <Windows.h>
#if defined(synwinxt_EXPORTS) #if defined(synwinxt_EXPORTS)
#define CSYNERGYSHELLEXE_API __declspec(dllexport) #define CSYNERGYSHELLEXE_API __declspec(dllexport)
#else #else

View File

@ -40,8 +40,7 @@ class CMSWindowsKeyStateTests : public ::testing::Test
protected: protected:
virtual void SetUp() virtual void SetUp()
{ {
// load synwinhk.dll m_hook.loadLibrary();
m_hookLibrary = m_hookLibraryLoader.openHookLibrary("synwinhk");
m_screensaver = new CMSWindowsScreenSaver(); m_screensaver = new CMSWindowsScreenSaver();
} }
@ -53,7 +52,7 @@ protected:
CMSWindowsDesks* newDesks(IEventQueue* eventQueue) CMSWindowsDesks* newDesks(IEventQueue* eventQueue)
{ {
return new CMSWindowsDesks( return new CMSWindowsDesks(
true, false, m_hookLibrary, m_screensaver, eventQueue, true, false, m_hook.getInstance(), m_screensaver, eventQueue,
new TMethodJob<CMSWindowsKeyStateTests>( new TMethodJob<CMSWindowsKeyStateTests>(
this, &CMSWindowsKeyStateTests::updateKeysCB), false); this, &CMSWindowsKeyStateTests::updateKeysCB), false);
} }
@ -65,9 +64,8 @@ protected:
private: private:
void updateKeysCB(void*) { } void updateKeysCB(void*) { }
HINSTANCE m_hookLibrary;
IScreenSaver* m_screensaver; IScreenSaver* m_screensaver;
CMSWindowsHookLibraryLoader m_hookLibraryLoader; CMSWindowsHook m_hook;
}; };
TEST_F(CMSWindowsKeyStateTests, disable_nonWin95OS_eventQueueNotUsed) TEST_F(CMSWindowsKeyStateTests, disable_nonWin95OS_eventQueueNotUsed)