Commit cb987646 authored by Rémi Bernon's avatar Rémi Bernon Committed by Alexandre Julliard

dinput: Implement DIDBAM_PRESERVE BuildActionMap flag.

parent 782ad8f7
...@@ -1847,6 +1847,8 @@ static HRESULT WINAPI dinput_device_BuildActionMap( IDirectInputDevice8W *iface, ...@@ -1847,6 +1847,8 @@ static HRESULT WINAPI dinput_device_BuildActionMap( IDirectInputDevice8W *iface,
for (action = format->rgoAction; action < action_end; action++) for (action = format->rgoAction; action < action_end; action++)
{ {
if (!action->dwSemantic) return DIERR_INVALIDPARAM; if (!action->dwSemantic) return DIERR_INVALIDPARAM;
if (flags == DIDBAM_PRESERVE && !IsEqualCLSID( &action->guidInstance, &GUID_NULL ) &&
!IsEqualCLSID( &action->guidInstance, &impl->guid )) continue;
if (action->dwFlags & DIA_APPMAPPED) action->dwHow = DIAH_APPREQUESTED; if (action->dwFlags & DIA_APPMAPPED) action->dwHow = DIAH_APPREQUESTED;
else action->dwHow = 0; else action->dwHow = 0;
} }
...@@ -1864,6 +1866,8 @@ static HRESULT WINAPI dinput_device_BuildActionMap( IDirectInputDevice8W *iface, ...@@ -1864,6 +1866,8 @@ static HRESULT WINAPI dinput_device_BuildActionMap( IDirectInputDevice8W *iface,
for (action = format->rgoAction; action < action_end; action++) for (action = format->rgoAction; action < action_end; action++)
{ {
if (action->dwHow == DIAH_APPREQUESTED || action->dwHow == DIAH_USERCONFIG) continue; if (action->dwHow == DIAH_APPREQUESTED || action->dwHow == DIAH_USERCONFIG) continue;
if (flags == DIDBAM_PRESERVE && !IsEqualCLSID( &action->guidInstance, &GUID_NULL ) &&
!IsEqualCLSID( &action->guidInstance, &impl->guid )) continue;
if (action->dwFlags & DIA_APPNOMAP) continue; if (action->dwFlags & DIA_APPNOMAP) continue;
action->guidInstance = GUID_NULL; action->guidInstance = GUID_NULL;
action->dwHow = 0; action->dwHow = 0;
......
...@@ -209,8 +209,8 @@ static BOOL CALLBACK check_no_created_effect_objects( IDirectInputEffect *effect ...@@ -209,8 +209,8 @@ static BOOL CALLBACK check_no_created_effect_objects( IDirectInputEffect *effect
return DIENUM_CONTINUE; return DIENUM_CONTINUE;
} }
#define check_diactionw( a, b ) check_diactionw_( __LINE__, a, b, FALSE ) #define check_diactionw( a, b ) check_diactionw_( __LINE__, a, b )
static void check_diactionw_( int line, const DIACTIONW *actual, const DIACTIONW *expected, BOOL todo ) static void check_diactionw_( int line, const DIACTIONW *actual, const DIACTIONW *expected )
{ {
check_member_( __FILE__, line, *actual, *expected, "%#Ix", uAppData ); check_member_( __FILE__, line, *actual, *expected, "%#Ix", uAppData );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwSemantic ); check_member_( __FILE__, line, *actual, *expected, "%#lx", dwSemantic );
...@@ -219,15 +219,13 @@ static void check_diactionw_( int line, const DIACTIONW *actual, const DIACTIONW ...@@ -219,15 +219,13 @@ static void check_diactionw_( int line, const DIACTIONW *actual, const DIACTIONW
check_member_wstr_( __FILE__, line, *actual, *expected, lptszActionName ); check_member_wstr_( __FILE__, line, *actual, *expected, lptszActionName );
else else
check_member_( __FILE__, line, *actual, *expected, "%p", lptszActionName ); check_member_( __FILE__, line, *actual, *expected, "%p", lptszActionName );
todo_wine_if( todo )
check_member_guid_( __FILE__, line, *actual, *expected, guidInstance ); check_member_guid_( __FILE__, line, *actual, *expected, guidInstance );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwObjID ); check_member_( __FILE__, line, *actual, *expected, "%#lx", dwObjID );
todo_wine_if( todo )
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwHow ); check_member_( __FILE__, line, *actual, *expected, "%#lx", dwHow );
} }
#define check_diactionformatw( a, b ) check_diactionformatw_( __LINE__, a, b, FALSE ) #define check_diactionformatw( a, b ) check_diactionformatw_( __LINE__, a, b )
static void check_diactionformatw_( int line, const DIACTIONFORMATW *actual, const DIACTIONFORMATW *expected, BOOL todo ) static void check_diactionformatw_( int line, const DIACTIONFORMATW *actual, const DIACTIONFORMATW *expected )
{ {
DWORD i; DWORD i;
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwSize ); check_member_( __FILE__, line, *actual, *expected, "%#lx", dwSize );
...@@ -237,7 +235,7 @@ static void check_diactionformatw_( int line, const DIACTIONFORMATW *actual, con ...@@ -237,7 +235,7 @@ static void check_diactionformatw_( int line, const DIACTIONFORMATW *actual, con
for (i = 0; i < min( actual->dwNumActions, expected->dwNumActions ); ++i) for (i = 0; i < min( actual->dwNumActions, expected->dwNumActions ); ++i)
{ {
winetest_push_context( "action[%lu]", i ); winetest_push_context( "action[%lu]", i );
check_diactionw_( line, actual->rgoAction + i, expected->rgoAction + i, todo && i >= 2 ); check_diactionw_( line, actual->rgoAction + i, expected->rgoAction + i );
winetest_pop_context(); winetest_pop_context();
if (expected->dwActionSize != sizeof(DIACTIONW)) break; if (expected->dwActionSize != sizeof(DIACTIONW)) break;
if (actual->dwActionSize != sizeof(DIACTIONW)) break; if (actual->dwActionSize != sizeof(DIACTIONW)) break;
...@@ -1377,7 +1375,7 @@ static void test_action_map( IDirectInputDevice8W *device, HANDLE file, HANDLE e ...@@ -1377,7 +1375,7 @@ static void test_action_map( IDirectInputDevice8W *device, HANDLE file, HANDLE e
ok( hr == DI_OK, "BuildActionMap returned %#lx\n", hr ); ok( hr == DI_OK, "BuildActionMap returned %#lx\n", hr );
hr = IDirectInputDevice8_BuildActionMap( device, &action_format, L"username", DIDBAM_PRESERVE ); hr = IDirectInputDevice8_BuildActionMap( device, &action_format, L"username", DIDBAM_PRESERVE );
ok( hr == DI_OK, "BuildActionMap returned %#lx\n", hr ); ok( hr == DI_OK, "BuildActionMap returned %#lx\n", hr );
check_diactionformatw_( __LINE__, &action_format, &expect_action_format_4, TRUE ); check_diactionformatw( &action_format, &expect_action_format_4 );
IDirectInputDevice8_Release( keyboard ); IDirectInputDevice8_Release( keyboard );
IDirectInputDevice8_Release( mouse ); IDirectInputDevice8_Release( mouse );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment