InputCommon/DInputJoystick: Correct force-feedback flag testing
Introduced in a995e2f5ba
We need to be performing a bitwise AND on the flags and not a logical
AND, otherwise we could end up counting device objects that don't
support forced feedback.
This commit is contained in:
parent
c70da390a7
commit
37d643c7d3
|
@ -164,9 +164,8 @@ Joystick::Joystick(/*const LPCDIDEVICEINSTANCE lpddi, */ const LPDIRECTINPUTDEVI
|
||||||
if (SUCCEEDED(m_device->EnumObjects(DIEnumDeviceObjectsCallback, (LPVOID)&objects, DIDFT_AXIS)))
|
if (SUCCEEDED(m_device->EnumObjects(DIEnumDeviceObjectsCallback, (LPVOID)&objects, DIDFT_AXIS)))
|
||||||
{
|
{
|
||||||
const int num_ff_axes =
|
const int num_ff_axes =
|
||||||
std::count_if(std::begin(objects), std::end(objects), [](DIDEVICEOBJECTINSTANCE& pdidoi) {
|
std::count_if(std::begin(objects), std::end(objects),
|
||||||
return pdidoi.dwFlags && DIDOI_FFACTUATOR;
|
[](const auto& pdidoi) { return (pdidoi.dwFlags & DIDOI_FFACTUATOR) != 0; });
|
||||||
});
|
|
||||||
InitForceFeedback(m_device, num_ff_axes);
|
InitForceFeedback(m_device, num_ff_axes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue