controller_patcher/source/config/ConfigValues.cpp

134 lines
5.5 KiB
C++
Raw Permalink Normal View History

/****************************************************************************
* Copyright (C) 2016,2017 Maschell
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
****************************************************************************/
2017-05-07 14:44:09 +02:00
#include "./ConfigValues.hpp"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
2017-05-07 14:44:09 +02:00
2017-10-29 09:34:47 +01:00
#include <utils/logger.h>
ConfigValues *ConfigValues::instance = NULL;
2018-06-19 17:46:37 +02:00
ConfigValues::ConfigValues() {
InitValues();
}
2018-06-19 17:46:37 +02:00
ConfigValues::~ConfigValues() {
2023-04-10 11:45:58 +02:00
if (HID_DEBUG) {
2018-06-19 17:46:37 +02:00
DEBUG_FUNCTION_LINE("\n");
}
}
2023-04-10 11:45:58 +02:00
const uint8_t *ConfigValues::getValuesForPreset(std::map<std::string, const uint8_t *> values, std::string possibleValue) {
std::map<std::string, const uint8_t *>::iterator it;
it = values.find(possibleValue);
2018-06-19 17:46:37 +02:00
if (it != values.end()) {
return it->second;
}
return NULL;
}
2023-04-10 11:45:58 +02:00
BOOL ConfigValues::setIfValueIsAControllerPresetEx(std::string value, int32_t slot, int32_t keyslot) {
if (setIfValueIsPreset(presetGCValues, value, slot, keyslot)) return true;
if (setIfValueIsPreset(presetDS3Values, value, slot, keyslot)) return true;
if (setIfValueIsPreset(presetDS4Values, value, slot, keyslot)) return true;
if (setIfValueIsPreset(presetXInputValues, value, slot, keyslot)) return true;
if (setIfValueIsPreset(presetSwitchProValues, value, slot, keyslot)) return true;
return false;
}
//We need this function here so we can use preset sticks.
2023-04-10 11:45:58 +02:00
BOOL ConfigValues::setIfValueIsPreset(std::map<std::string, const uint8_t *> values, std::string possibleValue, int32_t slot, int32_t keyslot) {
2024-10-13 10:37:09 +02:00
if (slot >= gHIDMaxDevices || slot < 0 || keyslot < 0 || keyslot >= CONTRPS_MAX_VALUE) {
return false;
}
2023-04-10 11:45:58 +02:00
const uint8_t *values_ = NULL;
if (keyslot == CONTRPS_VPAD_BUTTON_L_STICK_X ||
keyslot == CONTRPS_VPAD_BUTTON_L_STICK_Y ||
keyslot == CONTRPS_VPAD_BUTTON_R_STICK_X ||
keyslot == CONTRPS_VPAD_BUTTON_R_STICK_Y) {
if (HID_DEBUG) {
DEBUG_FUNCTION_LINE("This may be a predefined stick %s", possibleValue.c_str());
2018-06-19 17:46:37 +02:00
}
2023-04-10 11:45:58 +02:00
if ((values_ = ConfigValues::getValuesStickPreset(possibleValue)) != NULL) {
if (HID_DEBUG) {
2020-12-16 02:04:31 +01:00
DEBUG_FUNCTION_LINE("Found predefined stick!");
2018-06-19 17:46:37 +02:00
}
2023-04-10 11:45:58 +02:00
config_controller[slot][keyslot][0] = values_[STICK_CONF_BYTE]; //CONTRPS_VPAD_BUTTON_L_STICK_X
config_controller[slot][keyslot][1] = values_[STICK_CONF_DEFAULT];
config_controller[slot][keyslot + DEF_STICK_OFFSET_INVERT][0] = CONTROLLER_PATCHER_VALUE_SET; //CONTRPS_VPAD_BUTTON_L_STICK_X_INVERT
config_controller[slot][keyslot + DEF_STICK_OFFSET_INVERT][1] = values_[STICK_CONF_INVERT];
config_controller[slot][keyslot + DEF_STICK_OFFSET_DEADZONE][0] = CONTROLLER_PATCHER_VALUE_SET; //CONTRPS_VPAD_BUTTON_L_STICK_X_DEADZONE
config_controller[slot][keyslot + DEF_STICK_OFFSET_DEADZONE][1] = values_[STICK_CONF_DEADZONE];
config_controller[slot][keyslot + DEF_STICK_OFFSET_MINMAX][0] = values_[STICK_CONF_MIN]; //CONTRPS_VPAD_BUTTON_L_STICK_X_MINMAX
config_controller[slot][keyslot + DEF_STICK_OFFSET_MINMAX][1] = values_[STICK_CONF_MAX];
return true;
}
}
2023-04-10 11:45:58 +02:00
if ((values_ = getValuesForPreset(values, possibleValue)) != NULL) {
config_controller[slot][keyslot][0] = values_[0];
config_controller[slot][keyslot][1] = values_[1];
return true;
}
return false;
}
2023-04-10 11:45:58 +02:00
int32_t ConfigValues::getValueFromMap(std::map<std::string, int> values, std::string nameOfString) {
std::map<std::string, int>::iterator it;
it = values.find(nameOfString);
2018-06-19 17:46:37 +02:00
if (it != values.end()) {
return it->second;
}
//Value not found
return -1;
}
2018-06-20 15:07:15 +02:00
int32_t ConfigValues::getPresetValueEx(std::string possibleString) {
int32_t rightValue = -1;
2023-04-10 11:45:58 +02:00
if ((rightValue = getValueFromMap(gGamePadValuesToCONTRPSString, possibleString)) != -1) {
if (HID_DEBUG) {
DEBUG_FUNCTION_LINE("Used pre-defined VPAD_VALUE! \"%s\" is %d", possibleString.c_str(), rightValue);
2018-06-19 17:46:37 +02:00
}
2023-04-10 11:45:58 +02:00
} else if ((rightValue = getValueFromMap(presetValues, possibleString)) != -1) {
if (HID_DEBUG) {
DEBUG_FUNCTION_LINE("Used pre-defined value! \"%s\" is %d", possibleString.c_str(), rightValue);
2018-06-19 17:46:37 +02:00
}
}
return rightValue;
}
2023-04-10 11:45:58 +02:00
void ConfigValues::addDeviceNameEx(uint16_t vid, uint16_t pid, std::string value) {
deviceNames[StringTools::strfmt("%04X%04X", vid, pid).c_str()] = value;
2018-06-19 17:46:37 +02:00
}
2023-04-10 11:45:58 +02:00
std::string ConfigValues::getStringByVIDPIDEx(uint16_t vid, uint16_t pid) {
std::string result = "";
2023-04-10 11:45:58 +02:00
std::map<std::string, std::string>::iterator it;
2023-04-10 11:45:58 +02:00
it = deviceNames.find(StringTools::strfmt("%04X%04X", vid, pid));
2018-06-19 17:46:37 +02:00
if (it != deviceNames.end()) {
result = it->second;
2018-06-19 17:46:37 +02:00
} else {
2024-10-13 10:37:09 +02:00
result = StringTools::strfmt("0x%04X / 0x%04X", vid, pid);
}
return result;
}