InputCommon/ControllerEmu: Break out functionality of EmulatedController

to eliminate redundant unused members in Wii Remote extension objects.
This commit is contained in:
Jordan Woyak
2025-01-20 23:19:56 -06:00
parent 225039f742
commit ddb82a5e8c
26 changed files with 312 additions and 245 deletions

View File

@ -5,11 +5,16 @@
namespace ControllerEmu
{
void AttachedController::LoadDefaults()
{
}
Attachments::Attachments(const std::string& name_) : ControlGroup(name_, GroupType::Attachments)
{
}
void Attachments::AddAttachment(std::unique_ptr<EmulatedController> att)
void Attachments::AddAttachment(std::unique_ptr<AttachedController> att)
{
m_attachments.emplace_back(std::move(att));
}
@ -40,9 +45,61 @@ SubscribableSettingValue<int>& Attachments::GetAttachmentSetting()
return m_selection_value;
}
const std::vector<std::unique_ptr<EmulatedController>>& Attachments::GetAttachmentList() const
const std::vector<std::unique_ptr<AttachedController>>& Attachments::GetAttachmentList() const
{
return m_attachments;
}
void Attachments::LoadConfig(Common::IniFile::Section* sec, const std::string& base)
{
ControlGroup::LoadConfig(sec, base);
SetSelectedAttachment(0);
std::string attachment_text;
sec->Get(base + name, &attachment_text, "");
// First assume attachment string is a valid expression.
// If it instead matches one of the names of our attachments it is overridden below.
GetSelectionSetting().GetInputReference().SetExpression(attachment_text);
u32 n = 0;
for (auto& ai : GetAttachmentList())
{
ai->LoadGroupsConfig(sec, base + ai->GetName() + "/");
if (ai->GetName() == attachment_text)
SetSelectedAttachment(n);
++n;
}
}
void Attachments::SaveConfig(Common::IniFile::Section* sec, const std::string& base)
{
if (GetSelectionSetting().IsSimpleValue())
{
sec->Set(base + name, GetAttachmentList()[GetSelectedAttachment()]->GetName(), "None");
}
else
{
std::string expression = GetSelectionSetting().GetInputReference().GetExpression();
ReplaceBreaksWithSpaces(expression);
sec->Set(base + name, expression, "None");
}
for (auto& ai : GetAttachmentList())
ai->SaveGroupsConfig(sec, base + ai->GetName() + "/");
}
void Attachments::UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env)
{
ControlGroup::UpdateReferences(env);
GetSelectionSetting().GetInputReference().UpdateReference(env);
for (auto& attachment : GetAttachmentList())
attachment->UpdateGroupsReferences(env);
}
} // namespace ControllerEmu

View File

@ -3,19 +3,23 @@
#pragma once
#include <atomic>
#include <memory>
#include <string>
#include <vector>
#include "Common/CommonTypes.h"
#include "Core/HW/WiimoteEmu/ExtensionPort.h"
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
#include "InputCommon/ControllerEmu/ControllerEmu.h"
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
namespace ControllerEmu
{
class AttachedController : public ControlGroupContainer
{
public:
virtual void LoadDefaults();
};
// A container of the selected and available attachments
// for configuration saving/loading purposes
class Attachments : public ControlGroup
@ -23,7 +27,7 @@ class Attachments : public ControlGroup
public:
explicit Attachments(const std::string& name);
void AddAttachment(std::unique_ptr<EmulatedController> att);
void AddAttachment(std::unique_ptr<AttachedController> att);
u32 GetSelectedAttachment() const;
void SetSelectedAttachment(u32 val);
@ -31,16 +35,20 @@ public:
NumericSetting<int>& GetSelectionSetting();
SubscribableSettingValue<int>& GetAttachmentSetting();
const std::vector<std::unique_ptr<EmulatedController>>& GetAttachmentList() const;
const std::vector<std::unique_ptr<AttachedController>>& GetAttachmentList() const;
void LoadConfig(Common::IniFile::Section* sec, const std::string& base) override;
void SaveConfig(Common::IniFile::Section* sec, const std::string& base) override;
void UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env) override;
private:
SubscribableSettingValue<int> m_selection_value;
// This is here and not added to the list of numeric_settings because it's serialized differently,
// by string (to be independent from the enum), and visualized differently in the UI.
// For the rest, it's treated similarly to other numeric_settings in the group.
NumericSetting<int> m_selection_setting = {
&m_selection_value, {""}, 0, 0, WiimoteEmu::ExtensionNumber::MAX - 1};
NumericSetting<int> m_selection_setting = {&m_selection_value, {""}, 0, 0, 0};
std::vector<std::unique_ptr<EmulatedController>> m_attachments;
std::vector<std::unique_ptr<AttachedController>> m_attachments;
};
} // namespace ControllerEmu

View File

@ -3,13 +3,11 @@
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
#include "Common/CommonTypes.h"
#include "Common/IniFile.h"
#include "InputCommon/ControlReference/ControlReference.h"
#include "InputCommon/ControllerEmu/Control/Input.h"
#include "InputCommon/ControllerEmu/Control/Output.h"
#include "InputCommon/ControllerEmu/ControlGroup/Attachments.h"
#include "InputCommon/ControllerEmu/ControllerEmu.h"
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
@ -50,8 +48,7 @@ void ControlGroup::AddDeadzoneSetting(SettingValue<double>* value, double maximu
ControlGroup::~ControlGroup() = default;
void ControlGroup::LoadConfig(Common::IniFile::Section* sec, const std::string& defdev,
const std::string& base)
void ControlGroup::LoadConfig(Common::IniFile::Section* sec, const std::string& base)
{
const std::string group(base + name + "/");
@ -75,36 +72,9 @@ void ControlGroup::LoadConfig(Common::IniFile::Section* sec, const std::string&
sec->Get(group + c->name + "/Range", &c->control_ref->range, 100.0);
c->control_ref->range /= 100;
}
// extensions
if (type == GroupType::Attachments)
{
auto* const ext = static_cast<Attachments*>(this);
ext->SetSelectedAttachment(0);
u32 n = 0;
std::string attachment_text;
sec->Get(base + name, &attachment_text, "");
// First assume attachment string is a valid expression.
// If it instead matches one of the names of our attachments it is overridden below.
ext->GetSelectionSetting().GetInputReference().SetExpression(attachment_text);
for (auto& ai : ext->GetAttachmentList())
{
ai->SetDefaultDevice(defdev);
ai->LoadConfig(sec, base + ai->GetName() + "/");
if (ai->GetName() == attachment_text)
ext->SetSelectedAttachment(n);
n++;
}
}
}
void ControlGroup::SaveConfig(Common::IniFile::Section* sec, const std::string& defdev,
const std::string& base)
void ControlGroup::SaveConfig(Common::IniFile::Section* sec, const std::string& base)
{
const std::string group(base + name + "/");
@ -125,27 +95,15 @@ void ControlGroup::SaveConfig(Common::IniFile::Section* sec, const std::string&
// range
sec->Set(group + c->name + "/Range", c->control_ref->range * 100.0, 100.0);
}
}
// extensions
if (type == GroupType::Attachments)
{
auto* const ext = static_cast<Attachments*>(this);
void ControlGroup::UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env)
{
for (auto& control : controls)
control->control_ref->UpdateReference(env);
if (ext->GetSelectionSetting().IsSimpleValue())
{
sec->Set(base + name, ext->GetAttachmentList()[ext->GetSelectedAttachment()]->GetName(),
"None");
}
else
{
std::string expression = ext->GetSelectionSetting().GetInputReference().GetExpression();
ReplaceBreaksWithSpaces(expression);
sec->Set(base + name, expression, "None");
}
for (auto& ai : ext->GetAttachmentList())
ai->SaveConfig(sec, base + ai->GetName() + "/");
}
for (auto& setting : numeric_settings)
setting->GetInputReference().UpdateReference(env);
}
void ControlGroup::SetControlExpression(int index, const std::string& expression)

View File

@ -13,7 +13,6 @@
#include <type_traits>
#include <vector>
#include "Common/CommonTypes.h"
#include "Common/IniFile.h"
#include "InputCommon/ControllerEmu/Control/Control.h"
#include "InputCommon/ControllerInterface/CoreDevice.h"
@ -69,10 +68,10 @@ public:
DefaultValue default_value = DefaultValue::AlwaysEnabled);
virtual ~ControlGroup();
virtual void LoadConfig(Common::IniFile::Section* sec, const std::string& defdev = "",
const std::string& base = "");
virtual void SaveConfig(Common::IniFile::Section* sec, const std::string& defdev = "",
const std::string& base = "");
virtual void LoadConfig(Common::IniFile::Section* sec, const std::string& base);
virtual void SaveConfig(Common::IniFile::Section* sec, const std::string& base);
virtual void UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env);
void SetControlExpression(int index, const std::string& expression);