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:
Lioncash 2019-08-02 10:16:26 -04:00
parent c70da390a7
commit 37d643c7d3
1 changed files with 2 additions and 3 deletions

View File

@ -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);
} }