| Age | Commit message (Collapse) | Author | 
|---|
|  |  | 
|  | input_common: Make button threshold customizable | 
|  | input_common: Support SDL toggle buttons | 
|  | - value return can be different 0, is not error is normal, error is only -1. | 
|  | Fixed upstream by
libsdl-org/SDL@25fc40b0bd44c484051064bc6b945ea9943f88dd | 
|  |  | 
|  |  | 
|  | input_common: Add dual joycon support | 
|  | input_common: Rewrite sdl analog mapping and fix controller disconnection crash | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | SDL 2.0.14 introduces an incompatibility with Clang, causing it to
trigger -Wimplicit-fallthrough even though it is marked. Ignore it for
now, with a comment mentioning why this is needed. | 
|  | InputCommon: Address mapping and naming issues with SDL2 | 
|  | - Removes a dependency on core and input_common from common. | 
|  | Nintendo Pro controllers | 
|  | compatibility problems with certain controllers"" | 
|  | Port citra-emu/citra#5123: "SDL: Disable hidapi drivers due to compatibility problems with certain controllers" | 
|  |  | 
|  |  | 
|  | Port citra-emu/citra#5509 "Look at direction of analog axis travel instead of instantaneous sample" | 
|  |  | 
|  |  | 
|  |  | 
|  | Migrates over warnings as errors for input common to match how the
common library treats warnings as errors. | 
|  |  | 
|  |  | 
|  | Not all controllers have a SDL_GameController binding. This caused controllers not present in the SDL GameController database to have buttons mapped instead of axes.
Furthermore, it was not possible to invert the axes when it could be useful such as emulating a horizontal single joycon or other potential cases. This allows us to invert the axes by reversing the order of mapping (vertical, then horizontal). | 
|  | Previously we used a vibration filter that filters out amplitudes close to each other. It turns out there are cases where this results into vibrations that are too inaccurate. Remove this and move the 100Hz vibration filter (Only allowing a maximum of 100 vibrations per second) from sdl_impl to npad when enable_accurate_vibrations is set to false. | 
|  | A vibration device is an input device that returns an unsigned byte as status.
It represents whether the vibration device supports vibration or not.
If the status returns 1, it supports vibration. Otherwise, it does not support vibration. | 
|  | Sending too many state changes in a short period of time can cause massive performance issues.
As a result, we have to use several heuristics to reduce the number of state changes to minimize/eliminate this performance impact while maintaining the quality of these vibrations as much as possible. | 
|  | It turns out that after a controller is disconnected, there is a chance that events from the previous controller are sent/processed after it has been disconnected.
This causes the previously disconnected controller to reappear as connected due to GetSDLJoystickBySDLID() emplacing this controller back to the map.
Fix this by only returning an SDLJoystick if and only if it exists in the map. | 
|  | Previously, disconnecting a controller still leaves a null SDLJoystick entry within the vector of SDLJoysticks mapped by GUID.
When a DirectInput device of the same GUID is reconnected, it adds that device to a new port causing non-detectable input.
Furthermore, opening the "Configure" menu would cause yuzu to crash since it first tries to resolve the name of a null SDLJoystick entry that was not removed.
Resolve this by properly erasing the SDLJoystick entry from the vector. | 
|  | Makes the input_common code warnings consistent with the rest of the
codebase. | 
|  | InputCommon: Add random motion input for buttons | 
|  |  | 
|  |  | 
|  | caused by them.
The main problem is the loss of compatibility with some controllers, but there are also
unwanted changes to the behaviour of PS4 controllers (hardcoded lightbar color). | 
|  | These maps can be constexpr arrays of std::pair. | 
|  | Avoids redundant copies. | 
|  | Avoids churning ParamPackage instances. | 
|  | default arguments
We need to add the 'f' suffix to make the right hand side a float and
not a double. | 
|  | The purpose of make_tuple is that you don't need to explicitly type out
the types of the things that comprise said tuple.
Given this just returns default values, we can simplify this a bit. | 
|  | This doesn't modify internal member state, so it can be marked as const. | 
|  |  | 
|  | The hardware tested value is 0.5 which translates to SHRT_MAX / 2 | 
|  |  | 
|  | Co-authored-by: James Rowe <jroweboy@gmail.com>
Co-authored-by: Its-Rei <kupfel@gmail.com> | 
|  | This PR is now only the Analog devices handling the range value defaulting at 100% |