summaryrefslogtreecommitdiff
path: root/src/core/frontend/applets/controller.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/frontend/applets/controller.cpp')
-rw-r--r--src/core/frontend/applets/controller.cpp19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/core/frontend/applets/controller.cpp b/src/core/frontend/applets/controller.cpp
index 34eacbb45..715d9fffd 100644
--- a/src/core/frontend/applets/controller.cpp
+++ b/src/core/frontend/applets/controller.cpp
@@ -44,19 +44,24 @@ void DefaultControllerApplet::ReconfigureControllers(std::function<void()> callb
44 } 44 }
45 45
46 // Connect controllers based on the following priority list from highest to lowest priority: 46 // Connect controllers based on the following priority list from highest to lowest priority:
47 // Pro Controller -> Dual Joycons -> Left Joycon -> Right Joycon -> Handheld 47 // Pro Controller -> Dual Joycons -> Left Joycon/Right Joycon -> Handheld
48 if (parameters.allow_pro_controller) { 48 if (parameters.allow_pro_controller) {
49 npad.AddNewControllerAt( 49 npad.AddNewControllerAt(
50 npad.MapSettingsTypeToNPad(Settings::ControllerType::ProController), index); 50 npad.MapSettingsTypeToNPad(Settings::ControllerType::ProController), index);
51 } else if (parameters.allow_dual_joycons) { 51 } else if (parameters.allow_dual_joycons) {
52 npad.AddNewControllerAt( 52 npad.AddNewControllerAt(
53 npad.MapSettingsTypeToNPad(Settings::ControllerType::DualJoyconDetached), index); 53 npad.MapSettingsTypeToNPad(Settings::ControllerType::DualJoyconDetached), index);
54 } else if (parameters.allow_left_joycon) { 54 } else if (parameters.allow_left_joycon && parameters.allow_right_joycon) {
55 npad.AddNewControllerAt( 55 // Assign left joycons to even player indices and right joycons to odd player indices.
56 npad.MapSettingsTypeToNPad(Settings::ControllerType::LeftJoycon), index); 56 // We do this since Captain Toad Treasure Tracker expects a left joycon for Player 1 and
57 } else if (parameters.allow_right_joycon) { 57 // a right Joycon for Player 2 in 2 Player Assist mode.
58 npad.AddNewControllerAt( 58 if (index % 2 == 0) {
59 npad.MapSettingsTypeToNPad(Settings::ControllerType::RightJoycon), index); 59 npad.AddNewControllerAt(
60 npad.MapSettingsTypeToNPad(Settings::ControllerType::LeftJoycon), index);
61 } else {
62 npad.AddNewControllerAt(
63 npad.MapSettingsTypeToNPad(Settings::ControllerType::RightJoycon), index);
64 }
60 } else if (index == 0 && parameters.enable_single_mode && parameters.allow_handheld && 65 } else if (index == 0 && parameters.enable_single_mode && parameters.allow_handheld &&
61 !Settings::values.use_docked_mode) { 66 !Settings::values.use_docked_mode) {
62 // We should *never* reach here under any normal circumstances. 67 // We should *never* reach here under any normal circumstances.