Rémi Bernon : dinput: Cleanup keyboard device enumeration and creation.
Alexandre Julliard
julliard at winehq.org
Fri Oct 22 14:46:10 CDT 2021
Module: wine
Branch: master
Commit: e85a5302770167bdd9c11be2939e80730a64b92f
URL: https://source.winehq.org/git/wine.git/?a=commit;h=e85a5302770167bdd9c11be2939e80730a64b92f
Author: Rémi Bernon <rbernon at codeweavers.com>
Date: Fri Oct 22 09:33:53 2021 +0200
dinput: Cleanup keyboard device enumeration and creation.
Signed-off-by: Rémi Bernon <rbernon at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>
---
dlls/dinput/keyboard.c | 120 ++++++++++++++++++-------------------------------
1 file changed, 44 insertions(+), 76 deletions(-)
diff --git a/dlls/dinput/keyboard.c b/dlls/dinput/keyboard.c
index fd8e9e8fd12..804ce8b7808 100644
--- a/dlls/dinput/keyboard.c
+++ b/dlls/dinput/keyboard.c
@@ -145,102 +145,70 @@ static DWORD get_keyboard_subtype(void)
return dev_subtype;
}
-static void fill_keyboard_dideviceinstanceW(LPDIDEVICEINSTANCEW lpddi, DWORD version, DWORD subtype) {
- DWORD dwSize;
- DIDEVICEINSTANCEW ddi;
-
- dwSize = lpddi->dwSize;
-
- TRACE("%d %p\n", dwSize, lpddi);
-
- memset(lpddi, 0, dwSize);
- memset(&ddi, 0, sizeof(ddi));
-
- ddi.dwSize = dwSize;
- ddi.guidInstance = GUID_SysKeyboard;/* DInput's GUID */
- ddi.guidProduct = GUID_SysKeyboard;
- if (version >= 0x0800)
- ddi.dwDevType = DI8DEVTYPE_KEYBOARD | (subtype << 8);
- else
- ddi.dwDevType = DIDEVTYPE_KEYBOARD | (subtype << 8);
- MultiByteToWideChar(CP_ACP, 0, "Keyboard", -1, ddi.tszInstanceName, MAX_PATH);
- MultiByteToWideChar(CP_ACP, 0, "Wine Keyboard", -1, ddi.tszProductName, MAX_PATH);
-
- memcpy(lpddi, &ddi, (dwSize < sizeof(ddi) ? dwSize : sizeof(ddi)));
-}
-
-static HRESULT keyboarddev_enum_device(DWORD dwDevType, DWORD dwFlags, LPDIDEVICEINSTANCEW lpddi, DWORD version, int id)
+static HRESULT keyboard_enum_device( DWORD type, DWORD flags, DIDEVICEINSTANCEW *instance, DWORD version, int index )
{
- if (id != 0)
- return E_FAIL;
-
- if (dwFlags & DIEDFL_FORCEFEEDBACK)
- return S_FALSE;
-
- if ((dwDevType == 0) ||
- ((dwDevType == DIDEVTYPE_KEYBOARD) && (version < 0x0800)) ||
- (((dwDevType == DI8DEVCLASS_KEYBOARD) || (dwDevType == DI8DEVTYPE_KEYBOARD)) && (version >= 0x0800))) {
- TRACE("Enumerating the Keyboard device\n");
-
- fill_keyboard_dideviceinstanceW(lpddi, version, get_keyboard_subtype());
-
- return S_OK;
- }
+ BYTE subtype = get_keyboard_subtype();
+ DWORD size;
+
+ TRACE( "type %#x, flags %#x, instance %p, version %#04x, index %d\n", type, flags, instance, version, index );
+
+ if (index != 0) return DIERR_GENERIC;
+ if (flags & DIEDFL_FORCEFEEDBACK) return DI_NOEFFECT;
+ if (version < 0x0800 && type != 0 && type != DIDEVTYPE_KEYBOARD) return DI_NOEFFECT;
+ if (version >= 0x0800 && type != DI8DEVCLASS_ALL && type != DI8DEVCLASS_KEYBOARD && type != DI8DEVTYPE_KEYBOARD)
+ return DI_NOEFFECT;
+
+ if (instance->dwSize != sizeof(DIDEVICEINSTANCEW) &&
+ instance->dwSize != sizeof(DIDEVICEINSTANCE_DX3W))
+ return DIERR_INVALIDPARAM;
+
+ size = instance->dwSize;
+ memset( instance, 0, size );
+ instance->dwSize = size;
+ instance->guidInstance = GUID_SysKeyboard;
+ instance->guidProduct = GUID_SysKeyboard;
+ if (version >= 0x0800) instance->dwDevType = DI8DEVTYPE_KEYBOARD | (subtype << 8);
+ else instance->dwDevType = DIDEVTYPE_KEYBOARD | (subtype << 8);
+ MultiByteToWideChar( CP_ACP, 0, "Keyboard", -1, instance->tszInstanceName, MAX_PATH );
+ MultiByteToWideChar( CP_ACP, 0, "Wine Keyboard", -1, instance->tszProductName, MAX_PATH );
- return S_FALSE;
+ return DI_OK;
}
-static HRESULT alloc_device( REFGUID rguid, IDirectInputImpl *dinput, SysKeyboardImpl **out )
+static HRESULT keyboard_create_device( IDirectInputImpl *dinput, const GUID *guid, IDirectInputDevice8W **out )
{
- BYTE subtype = get_keyboard_subtype();
- SysKeyboardImpl* newDevice;
+ SysKeyboardImpl *impl;
HRESULT hr;
+ TRACE( "dinput %p, guid %s, out %p\n", dinput, debugstr_guid( guid ), out );
+
+ *out = NULL;
+ if (!IsEqualGUID( &GUID_SysKeyboard, guid )) return DIERR_DEVICENOTREG;
+
if (FAILED(hr = direct_input_device_alloc( sizeof(SysKeyboardImpl), &SysKeyboardWvt, &keyboard_internal_vtbl,
- rguid, dinput, (void **)&newDevice )))
+ guid, dinput, (void **)&impl )))
return hr;
- newDevice->base.crit.DebugInfo->Spare[0] = (DWORD_PTR)(__FILE__ ": SysKeyboardImpl*->base.crit");
+ impl->base.crit.DebugInfo->Spare[0] = (DWORD_PTR)(__FILE__ ": SysKeyboardImpl*->base.crit");
- fill_keyboard_dideviceinstanceW( &newDevice->base.instance, newDevice->base.dinput->dwVersion, subtype );
- newDevice->base.caps.dwDevType = newDevice->base.instance.dwDevType;
- newDevice->base.caps.dwFirmwareRevision = 100;
- newDevice->base.caps.dwHardwareRevision = 100;
+ keyboard_enum_device( 0, 0, &impl->base.instance, dinput->dwVersion, 0 );
+ impl->base.caps.dwDevType = impl->base.instance.dwDevType;
+ impl->base.caps.dwFirmwareRevision = 100;
+ impl->base.caps.dwHardwareRevision = 100;
- if (FAILED(hr = direct_input_device_init( &newDevice->base.IDirectInputDevice8W_iface )))
+ if (FAILED(hr = direct_input_device_init( &impl->base.IDirectInputDevice8W_iface )))
{
- IDirectInputDevice_Release( &newDevice->base.IDirectInputDevice8W_iface );
+ IDirectInputDevice_Release( &impl->base.IDirectInputDevice8W_iface );
return hr;
}
- *out = newDevice;
+ *out = &impl->base.IDirectInputDevice8W_iface;
return DI_OK;
}
-static HRESULT keyboarddev_create_device( IDirectInputImpl *dinput, REFGUID rguid, IDirectInputDevice8W **out )
-{
- TRACE( "%p %s %p\n", dinput, debugstr_guid( rguid ), out );
- *out = NULL;
-
- if (IsEqualGUID(&GUID_SysKeyboard, rguid)) /* Wine Keyboard */
- {
- SysKeyboardImpl *This;
- HRESULT hr;
-
- if (FAILED(hr = alloc_device( rguid, dinput, &This ))) return hr;
-
- TRACE( "Created a Keyboard device (%p)\n", This );
-
- *out = &This->base.IDirectInputDevice8W_iface;
- return DI_OK;
- }
-
- return DIERR_DEVICENOTREG;
-}
-
const struct dinput_device keyboard_device = {
"Wine keyboard driver",
- keyboarddev_enum_device,
- keyboarddev_create_device
+ keyboard_enum_device,
+ keyboard_create_device
};
static HRESULT keyboard_internal_poll( IDirectInputDevice8W *iface )
More information about the wine-cvs
mailing list