diff options
| author | 2018-06-13 13:44:46 -0400 | |
|---|---|---|
| committer | 2018-06-13 13:44:46 -0400 | |
| commit | a353322b58afa439eabce0694f457381fd80a7fe (patch) | |
| tree | 5bb987b214c4f2a2cd05457dc92200aafd3117d4 /src | |
| parent | Avoid initializing single-joycon layouts with handheld controller (diff) | |
| download | yuzu-a353322b58afa439eabce0694f457381fd80a7fe.tar.gz yuzu-a353322b58afa439eabce0694f457381fd80a7fe.tar.xz yuzu-a353322b58afa439eabce0694f457381fd80a7fe.zip | |
Move loop condition to free function
Diffstat (limited to 'src')
| -rw-r--r-- | src/core/hle/service/hid/hid.cpp | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/src/core/hle/service/hid/hid.cpp b/src/core/hle/service/hid/hid.cpp index d84c0a0b2..d4f741505 100644 --- a/src/core/hle/service/hid/hid.cpp +++ b/src/core/hle/service/hid/hid.cpp | |||
| @@ -16,6 +16,14 @@ | |||
| 16 | 16 | ||
| 17 | namespace Service::HID { | 17 | namespace Service::HID { |
| 18 | 18 | ||
| 19 | int GetNumberLayoutsForController(size_t controller_id) { | ||
| 20 | if (controller_id == Controller_Handheld) { | ||
| 21 | return HID_NUM_LAYOUTS_HANDHELD; | ||
| 22 | } else { | ||
| 23 | return HID_NUM_LAYOUTS; | ||
| 24 | } | ||
| 25 | } | ||
| 26 | |||
| 19 | // Updating period for each HID device. | 27 | // Updating period for each HID device. |
| 20 | // TODO(shinyquagsire23): These need better values. | 28 | // TODO(shinyquagsire23): These need better values. |
| 21 | constexpr u64 pad_update_ticks = CoreTiming::BASE_CLOCK_RATE / 10000; | 29 | constexpr u64 pad_update_ticks = CoreTiming::BASE_CLOCK_RATE / 10000; |
| @@ -83,10 +91,7 @@ private: | |||
| 83 | controller_header.left_color_buttons = JOYCON_BUTTONS_NEON_BLUE; | 91 | controller_header.left_color_buttons = JOYCON_BUTTONS_NEON_BLUE; |
| 84 | 92 | ||
| 85 | for (size_t controller = 0; controller < mem.controllers.size(); controller++) { | 93 | for (size_t controller = 0; controller < mem.controllers.size(); controller++) { |
| 86 | for (int index = 0; | 94 | for (int index = 0; index < GetNumberLayoutsForController(controller); index++) { |
| 87 | index < | ||
| 88 | (controller != Controller_Handheld ? HID_NUM_LAYOUTS : HID_NUM_LAYOUTS_HANDHELD); | ||
| 89 | index++) { | ||
| 90 | ControllerLayout& layout = mem.controllers[controller].layouts[index]; | 95 | ControllerLayout& layout = mem.controllers[controller].layouts[index]; |
| 91 | layout.header.num_entries = HID_NUM_ENTRIES; | 96 | layout.header.num_entries = HID_NUM_ENTRIES; |
| 92 | layout.header.max_entry_index = HID_NUM_ENTRIES - 1; | 97 | layout.header.max_entry_index = HID_NUM_ENTRIES - 1; |