Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
f051de0d
Commit
f051de0d
authored
Aug 19, 2016
by
Bruno Jesus
Committed by
Alexandre Julliard
Aug 22, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dinput: Return the correct error when CreateEffect is not supported.
Signed-off-by:
Bruno Jesus
<
00cpxxx@gmail.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
2f7a2fde
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
81 additions
and
62 deletions
+81
-62
device.c
dlls/dinput/device.c
+4
-1
joystick_linuxinput.c
dlls/dinput/joystick_linuxinput.c
+9
-3
joystick_osx.c
dlls/dinput/joystick_osx.c
+1
-1
joystick.c
dlls/dinput/tests/joystick.c
+67
-57
No files found.
dlls/dinput/device.c
View file @
f051de0d
...
@@ -1551,7 +1551,10 @@ HRESULT WINAPI IDirectInputDevice2WImpl_CreateEffect(LPDIRECTINPUTDEVICE8W iface
...
@@ -1551,7 +1551,10 @@ HRESULT WINAPI IDirectInputDevice2WImpl_CreateEffect(LPDIRECTINPUTDEVICE8W iface
LPDIRECTINPUTEFFECT
*
ppdef
,
LPUNKNOWN
pUnkOuter
)
LPDIRECTINPUTEFFECT
*
ppdef
,
LPUNKNOWN
pUnkOuter
)
{
{
FIXME
(
"(this=%p,%s,%p,%p,%p): stub!
\n
"
,
iface
,
debugstr_guid
(
rguid
),
lpeff
,
ppdef
,
pUnkOuter
);
FIXME
(
"(this=%p,%s,%p,%p,%p): stub!
\n
"
,
iface
,
debugstr_guid
(
rguid
),
lpeff
,
ppdef
,
pUnkOuter
);
return
DI_OK
;
FIXME
(
"not available in the generic implementation
\n
"
);
*
ppdef
=
NULL
;
return
DIERR_UNSUPPORTED
;
}
}
HRESULT
WINAPI
IDirectInputDevice2AImpl_CreateEffect
(
LPDIRECTINPUTDEVICE8A
iface
,
REFGUID
rguid
,
LPCDIEFFECT
lpeff
,
HRESULT
WINAPI
IDirectInputDevice2AImpl_CreateEffect
(
LPDIRECTINPUTDEVICE8A
iface
,
REFGUID
rguid
,
LPCDIEFFECT
lpeff
,
...
...
dlls/dinput/joystick_linuxinput.c
View file @
f051de0d
...
@@ -1049,10 +1049,16 @@ static HRESULT WINAPI JoystickWImpl_CreateEffect(LPDIRECTINPUTDEVICE8W iface, RE
...
@@ -1049,10 +1049,16 @@ static HRESULT WINAPI JoystickWImpl_CreateEffect(LPDIRECTINPUTDEVICE8W iface, RE
JoystickImpl
*
This
=
impl_from_IDirectInputDevice8W
(
iface
);
JoystickImpl
*
This
=
impl_from_IDirectInputDevice8W
(
iface
);
TRACE
(
"(this=%p,%p,%p,%p,%p)
\n
"
,
This
,
rguid
,
lpeff
,
ppdef
,
pUnkOuter
);
TRACE
(
"(this=%p,%p,%p,%p,%p)
\n
"
,
This
,
rguid
,
lpeff
,
ppdef
,
pUnkOuter
);
#ifndef HAVE_STRUCT_FF_EFFECT_DIRECTION
TRACE
(
"not available (compiled w/o ff support)
\n
"
);
*
ppdef
=
NULL
;
*
ppdef
=
NULL
;
return
DI_OK
;
if
(
!
This
->
joydev
->
has_ff
)
{
TRACE
(
"No force feedback support
\n
"
);
return
DIERR_UNSUPPORTED
;
}
#ifndef HAVE_STRUCT_FF_EFFECT_DIRECTION
TRACE
(
"not available (compiled w/o force feedback support)
\n
"
);
return
DIERR_UNSUPPORTED
;
#else
#else
if
(
!
(
new_effect
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
new_effect
))))
if
(
!
(
new_effect
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
new_effect
))))
...
...
dlls/dinput/joystick_osx.c
View file @
f051de0d
...
@@ -1398,7 +1398,7 @@ static HRESULT WINAPI JoystickWImpl_CreateEffect(IDirectInputDevice8W *iface,
...
@@ -1398,7 +1398,7 @@ static HRESULT WINAPI JoystickWImpl_CreateEffect(IDirectInputDevice8W *iface,
if
(
!
This
->
ff
){
if
(
!
This
->
ff
){
TRACE
(
"No force feedback support
\n
"
);
TRACE
(
"No force feedback support
\n
"
);
*
out
=
NULL
;
*
out
=
NULL
;
return
S_OK
;
return
DIERR_UNSUPPORTED
;
}
}
if
(
outer
)
if
(
outer
)
...
...
dlls/dinput/tests/joystick.c
View file @
f051de0d
...
@@ -186,6 +186,15 @@ static BOOL CALLBACK EnumJoysticks(const DIDEVICEINSTANCEA *lpddi, void *pvRef)
...
@@ -186,6 +186,15 @@ static BOOL CALLBACK EnumJoysticks(const DIDEVICEINSTANCEA *lpddi, void *pvRef)
WCHAR
nameBuffer
[
MAX_PATH
];
WCHAR
nameBuffer
[
MAX_PATH
];
HWND
hWnd
=
get_hwnd
();
HWND
hWnd
=
get_hwnd
();
char
oldstate
[
248
],
curstate
[
248
];
char
oldstate
[
248
],
curstate
[
248
];
DWORD
axes
[
2
]
=
{
DIJOFS_X
,
DIJOFS_Y
};
LONG
direction
[
2
]
=
{
0
,
0
};
DICONSTANTFORCE
force
=
{
0
};
DIEFFECT
eff
;
LPDIRECTINPUTEFFECT
effect
=
NULL
;
LONG
cnt1
,
cnt2
;
HWND
real_hWnd
;
HINSTANCE
hInstance
=
GetModuleHandleW
(
NULL
);
DIPROPDWORD
dip_gain_set
,
dip_gain_get
;
ok
(
data
->
version
>
0x0300
,
"Joysticks not supported in version 0x%04x
\n
"
,
data
->
version
);
ok
(
data
->
version
>
0x0300
,
"Joysticks not supported in version 0x%04x
\n
"
,
data
->
version
);
...
@@ -384,54 +393,46 @@ static BOOL CALLBACK EnumJoysticks(const DIDEVICEINSTANCEA *lpddi, void *pvRef)
...
@@ -384,54 +393,46 @@ static BOOL CALLBACK EnumJoysticks(const DIDEVICEINSTANCEA *lpddi, void *pvRef)
ok
(
js
.
rgdwPOV
[
3
]
==
-
1
,
"Default for unassigned POV should be -1 not: %d
\n
"
,
js
.
rgdwPOV
[
3
]);
ok
(
js
.
rgdwPOV
[
3
]
==
-
1
,
"Default for unassigned POV should be -1 not: %d
\n
"
,
js
.
rgdwPOV
[
3
]);
}
}
if
(
caps
.
dwFlags
&
DIDC_FORCEFEEDBACK
)
trace
(
"Testing force feedback
\n
"
);
{
memset
(
&
eff
,
0
,
sizeof
(
eff
));
DWORD
axes
[
2
]
=
{
DIJOFS_X
,
DIJOFS_Y
};
eff
.
dwSize
=
sizeof
(
eff
);
LONG
direction
[
2
]
=
{
0
,
0
};
eff
.
dwFlags
=
DIEFF_CARTESIAN
|
DIEFF_OBJECTOFFSETS
;
DICONSTANTFORCE
force
=
{
0
};
eff
.
dwDuration
=
INFINITE
;
DIEFFECT
eff
;
eff
.
dwGain
=
DI_FFNOMINALMAX
;
LPDIRECTINPUTEFFECT
effect
=
NULL
;
eff
.
dwTriggerButton
=
DIEB_NOTRIGGER
;
LONG
cnt1
,
cnt2
;
eff
.
cAxes
=
sizeof
(
axes
)
/
sizeof
(
axes
[
0
]);
HWND
real_hWnd
;
eff
.
rgdwAxes
=
axes
;
HINSTANCE
hInstance
=
GetModuleHandleW
(
NULL
);
eff
.
rglDirection
=
direction
;
DIPROPDWORD
dip_gain_set
,
dip_gain_get
;
eff
.
cbTypeSpecificParams
=
sizeof
(
force
);
eff
.
lpvTypeSpecificParams
=
&
force
;
trace
(
"Testing force-feedback
\n
"
);
memset
(
&
eff
,
0
,
sizeof
(
eff
));
/* Sending effects to joystick requires
eff
.
dwSize
=
sizeof
(
eff
);
* calling IDirectInputEffect_Initialize, which requires
eff
.
dwFlags
=
DIEFF_CARTESIAN
|
DIEFF_OBJECTOFFSETS
;
* having exclusive access to the device, which requires
eff
.
dwDuration
=
INFINITE
;
* - not having acquired the joystick when calling
eff
.
dwGain
=
DI_FFNOMINALMAX
;
* IDirectInputDevice_SetCooperativeLevel
eff
.
dwTriggerButton
=
DIEB_NOTRIGGER
;
* - a visible window
eff
.
cAxes
=
sizeof
(
axes
)
/
sizeof
(
axes
[
0
]);
*/
eff
.
rgdwAxes
=
axes
;
real_hWnd
=
CreateWindowExA
(
0
,
"EDIT"
,
"Test text"
,
0
,
10
,
10
,
300
,
300
,
NULL
,
NULL
,
eff
.
rglDirection
=
direction
;
hInstance
,
NULL
);
eff
.
cbTypeSpecificParams
=
sizeof
(
force
);
ok
(
real_hWnd
!=
0
,
"CreateWindowExA failed: %p
\n
"
,
real_hWnd
);
eff
.
lpvTypeSpecificParams
=
&
force
;
ShowWindow
(
real_hWnd
,
SW_SHOW
);
hr
=
IDirectInputDevice_Unacquire
(
pJoystick
);
/* Sending effects to joystick requires
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Unacquire() failed: %08x
\n
"
,
hr
);
* calling IDirectInputEffect_Initialize, which requires
hr
=
IDirectInputDevice_SetCooperativeLevel
(
pJoystick
,
real_hWnd
,
* having exclusive access to the device, which requires
DISCL_EXCLUSIVE
|
DISCL_FOREGROUND
);
* - not having acquired the joystick when calling
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_SetCooperativeLevel() failed: %08x
\n
"
,
hr
);
* IDirectInputDevice_SetCooperativeLevel
hr
=
IDirectInputDevice_Acquire
(
pJoystick
);
* - a visible window
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Acquire() failed: %08x
\n
"
,
hr
);
*/
real_hWnd
=
CreateWindowExA
(
0
,
"EDIT"
,
"Test text"
,
0
,
10
,
10
,
300
,
300
,
NULL
,
NULL
,
hInstance
,
NULL
);
ok
(
real_hWnd
!=
0
,
"CreateWindowExA failed: %p
\n
"
,
real_hWnd
);
ShowWindow
(
real_hWnd
,
SW_SHOW
);
hr
=
IDirectInputDevice_Unacquire
(
pJoystick
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Unacquire() failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_SetCooperativeLevel
(
pJoystick
,
real_hWnd
,
DISCL_EXCLUSIVE
|
DISCL_FOREGROUND
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_SetCooperativeLevel() failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_Acquire
(
pJoystick
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Acquire() failed: %08x
\n
"
,
hr
);
cnt1
=
get_refcount
((
IUnknown
*
)
pJoystick
);
cnt1
=
get_refcount
((
IUnknown
*
)
pJoystick
);
hr
=
IDirectInputDevice2_CreateEffect
((
IDirectInputDevice2A
*
)
pJoystick
,
&
GUID_ConstantForce
,
effect
=
(
void
*
)
0xdeadbeef
;
&
eff
,
&
effect
,
NULL
);
hr
=
IDirectInputDevice2_CreateEffect
((
IDirectInputDevice2A
*
)
pJoystick
,
&
GUID_ConstantForce
,
&
eff
,
&
effect
,
NULL
);
if
(
caps
.
dwFlags
&
DIDC_FORCEFEEDBACK
)
{
trace
(
"force feedback supported
\n
"
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_CreateEffect() failed: %08x
\n
"
,
hr
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_CreateEffect() failed: %08x
\n
"
,
hr
);
cnt2
=
get_refcount
((
IUnknown
*
)
pJoystick
);
cnt2
=
get_refcount
((
IUnknown
*
)
pJoystick
);
ok
(
cnt1
==
cnt2
,
"Ref count is wrong %d != %d
\n
"
,
cnt1
,
cnt2
);
ok
(
cnt1
==
cnt2
,
"Ref count is wrong %d != %d
\n
"
,
cnt1
,
cnt2
);
...
@@ -622,18 +623,27 @@ static BOOL CALLBACK EnumJoysticks(const DIDEVICEINSTANCEA *lpddi, void *pvRef)
...
@@ -622,18 +623,27 @@ static BOOL CALLBACK EnumJoysticks(const DIDEVICEINSTANCEA *lpddi, void *pvRef)
}
}
cnt1
=
get_refcount
((
IUnknown
*
)
pJoystick
);
cnt1
=
get_refcount
((
IUnknown
*
)
pJoystick
);
ok
(
cnt1
==
cnt2
,
"Ref count is wrong %d != %d
\n
"
,
cnt1
,
cnt2
);
ok
(
cnt1
==
cnt2
,
"Ref count is wrong %d != %d
\n
"
,
cnt1
,
cnt2
);
/* Before destroying the window, release joystick to revert to
* non-exclusive, background cooperative level. */
hr
=
IDirectInputDevice_Unacquire
(
pJoystick
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Unacquire() failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_SetCooperativeLevel
(
pJoystick
,
hWnd
,
DISCL_NONEXCLUSIVE
|
DISCL_BACKGROUND
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_SetCooperativeLevel() failed: %08x
\n
"
,
hr
);
DestroyWindow
(
real_hWnd
);
hr
=
IDirectInputDevice_Acquire
(
pJoystick
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Acquire() failed: %08x
\n
"
,
hr
);
}
}
/* No force feedback support, CreateEffect is supposed to fail. Fairy Bloom Freesia
* calls CreateEffect without checking the DIDC_FORCEFEEDBACK. It expects the correct
* error return to determine if force feedback is unsupported. */
else
{
trace
(
"No force feedback support
\n
"
);
ok
(
hr
==
DIERR_UNSUPPORTED
,
"IDirectInputDevice_CreateEffect() must fail with DIERR_UNSUPPORTED, got: %08x
\n
"
,
hr
);
ok
(
effect
==
NULL
,
"effect must be NULL, got %p
\n
"
,
effect
);
}
/* Before destroying the window, release joystick to revert to
* non-exclusive, background cooperative level. */
hr
=
IDirectInputDevice_Unacquire
(
pJoystick
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Unacquire() failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_SetCooperativeLevel
(
pJoystick
,
hWnd
,
DISCL_NONEXCLUSIVE
|
DISCL_BACKGROUND
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_SetCooperativeLevel() failed: %08x
\n
"
,
hr
);
DestroyWindow
(
real_hWnd
);
hr
=
IDirectInputDevice_Acquire
(
pJoystick
);
ok
(
hr
==
DI_OK
,
"IDirectInputDevice_Acquire() failed: %08x
\n
"
,
hr
);
if
(
winetest_interactive
)
{
if
(
winetest_interactive
)
{
trace
(
"You have 30 seconds to test all axes, sliders, POVs and buttons
\n
"
);
trace
(
"You have 30 seconds to test all axes, sliders, POVs and buttons
\n
"
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment