Rename all instances of "CemuhookUDPServer"/"UDPServer" to "DualShockUDPClient"/"DSUClient".
This commit is contained in:
parent
332cad21a4
commit
da1f153b47
Source/Core
Common
Core/ConfigLoaders
DolphinQt
CMakeLists.txt
Config/ControllerInterface
ControllerInterfaceWindow.cppControllerInterfaceWindow.hDualShockUDPClientWidget.cppDualShockUDPClientWidget.h
DolphinQt.vcxprojInputCommon
|
@ -85,7 +85,7 @@
|
||||||
#define GFX_CONFIG "GFX.ini"
|
#define GFX_CONFIG "GFX.ini"
|
||||||
#define DEBUGGER_CONFIG "Debugger.ini"
|
#define DEBUGGER_CONFIG "Debugger.ini"
|
||||||
#define LOGGER_CONFIG "Logger.ini"
|
#define LOGGER_CONFIG "Logger.ini"
|
||||||
#define CEMUHOOKUDPSERVER_CONFIG "UDPServer.ini"
|
#define DUALSHOCKUDPCLIENT_CONFIG "DSUClient.ini"
|
||||||
|
|
||||||
// Files in the directory returned by GetUserPath(D_LOGS_IDX)
|
// Files in the directory returned by GetUserPath(D_LOGS_IDX)
|
||||||
#define MAIN_LOG "dolphin.log"
|
#define MAIN_LOG "dolphin.log"
|
||||||
|
|
|
@ -141,7 +141,7 @@ static const std::map<System, std::string> system_to_name = {
|
||||||
{System::Logger, "Logger"},
|
{System::Logger, "Logger"},
|
||||||
{System::Debugger, "Debugger"},
|
{System::Debugger, "Debugger"},
|
||||||
{System::SYSCONF, "SYSCONF"},
|
{System::SYSCONF, "SYSCONF"},
|
||||||
{System::CemuHookUdpServer, "CemuHookUdpServer"}};
|
{System::DualShockUDPClient, "DualShockUDPClient"}};
|
||||||
|
|
||||||
const std::string& GetSystemName(System system)
|
const std::string& GetSystemName(System system)
|
||||||
{
|
{
|
||||||
|
|
|
@ -30,7 +30,7 @@ enum class System
|
||||||
GFX,
|
GFX,
|
||||||
Logger,
|
Logger,
|
||||||
Debugger,
|
Debugger,
|
||||||
CemuHookUdpServer,
|
DualShockUDPClient,
|
||||||
};
|
};
|
||||||
|
|
||||||
constexpr std::array<LayerType, 7> SEARCH_ORDER{{
|
constexpr std::array<LayerType, 7> SEARCH_ORDER{{
|
||||||
|
|
|
@ -794,8 +794,8 @@ static void RebuildUserDirectories(unsigned int dir_index)
|
||||||
s_user_paths[F_GFXCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + GFX_CONFIG;
|
s_user_paths[F_GFXCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + GFX_CONFIG;
|
||||||
s_user_paths[F_DEBUGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + DEBUGGER_CONFIG;
|
s_user_paths[F_DEBUGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + DEBUGGER_CONFIG;
|
||||||
s_user_paths[F_LOGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + LOGGER_CONFIG;
|
s_user_paths[F_LOGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + LOGGER_CONFIG;
|
||||||
s_user_paths[F_CEMUHOOKUDPSERVERCONFIG_IDX] =
|
s_user_paths[F_DUALSHOCKUDPCLIENTCONFIG_IDX] =
|
||||||
s_user_paths[D_CONFIG_IDX] + CEMUHOOKUDPSERVER_CONFIG;
|
s_user_paths[D_CONFIG_IDX] + DUALSHOCKUDPCLIENT_CONFIG;
|
||||||
s_user_paths[F_MAINLOG_IDX] = s_user_paths[D_LOGS_IDX] + MAIN_LOG;
|
s_user_paths[F_MAINLOG_IDX] = s_user_paths[D_LOGS_IDX] + MAIN_LOG;
|
||||||
s_user_paths[F_MEM1DUMP_IDX] = s_user_paths[D_DUMP_IDX] + MEM1_DUMP;
|
s_user_paths[F_MEM1DUMP_IDX] = s_user_paths[D_DUMP_IDX] + MEM1_DUMP;
|
||||||
s_user_paths[F_MEM2DUMP_IDX] = s_user_paths[D_DUMP_IDX] + MEM2_DUMP;
|
s_user_paths[F_MEM2DUMP_IDX] = s_user_paths[D_DUMP_IDX] + MEM2_DUMP;
|
||||||
|
|
|
@ -70,7 +70,7 @@ enum
|
||||||
F_MEMORYWATCHERLOCATIONS_IDX,
|
F_MEMORYWATCHERLOCATIONS_IDX,
|
||||||
F_MEMORYWATCHERSOCKET_IDX,
|
F_MEMORYWATCHERSOCKET_IDX,
|
||||||
F_WIISDCARD_IDX,
|
F_WIISDCARD_IDX,
|
||||||
F_CEMUHOOKUDPSERVERCONFIG_IDX,
|
F_DUALSHOCKUDPCLIENTCONFIG_IDX,
|
||||||
NUM_PATH_INDICES
|
NUM_PATH_INDICES
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -89,7 +89,7 @@ const std::map<Config::System, int> system_to_ini = {
|
||||||
{Config::System::GFX, F_GFXCONFIG_IDX},
|
{Config::System::GFX, F_GFXCONFIG_IDX},
|
||||||
{Config::System::Logger, F_LOGGERCONFIG_IDX},
|
{Config::System::Logger, F_LOGGERCONFIG_IDX},
|
||||||
{Config::System::Debugger, F_DEBUGGERCONFIG_IDX},
|
{Config::System::Debugger, F_DEBUGGERCONFIG_IDX},
|
||||||
{Config::System::CemuHookUdpServer, F_CEMUHOOKUDPSERVERCONFIG_IDX},
|
{Config::System::DualShockUDPClient, F_DUALSHOCKUDPCLIENTCONFIG_IDX},
|
||||||
};
|
};
|
||||||
|
|
||||||
// INI layer configuration loader
|
// INI layer configuration loader
|
||||||
|
|
|
@ -16,7 +16,7 @@ namespace ConfigLoaders
|
||||||
{
|
{
|
||||||
bool IsSettingSaveable(const Config::ConfigLocation& config_location)
|
bool IsSettingSaveable(const Config::ConfigLocation& config_location)
|
||||||
{
|
{
|
||||||
if (config_location.system == Config::System::CemuHookUdpServer)
|
if (config_location.system == Config::System::DualShockUDPClient)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (config_location.system == Config::System::Logger)
|
if (config_location.system == Config::System::Logger)
|
||||||
|
|
|
@ -51,8 +51,8 @@ add_executable(dolphin-emu
|
||||||
Config/CheatCodeEditor.h
|
Config/CheatCodeEditor.h
|
||||||
Config/CheatWarningWidget.cpp
|
Config/CheatWarningWidget.cpp
|
||||||
Config/CheatWarningWidget.h
|
Config/CheatWarningWidget.h
|
||||||
Config/ControllerInterface/CemuHookUDPServerWidget.cpp
|
Config/ControllerInterface/DualShockUDPClientWidget.cpp
|
||||||
Config/ControllerInterface/CemuHookUDPServerWidget.h
|
Config/ControllerInterface/DualShockUDPClientWidget.h
|
||||||
Config/ControllerInterface/ControllerInterfaceWindow.cpp
|
Config/ControllerInterface/ControllerInterfaceWindow.cpp
|
||||||
Config/ControllerInterface/ControllerInterfaceWindow.h
|
Config/ControllerInterface/ControllerInterfaceWindow.h
|
||||||
Config/ControllersWindow.cpp
|
Config/ControllersWindow.cpp
|
||||||
|
|
|
@ -9,8 +9,8 @@
|
||||||
#include <QTabWidget>
|
#include <QTabWidget>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
#if defined(CIFACE_USE_CEMUHOOKUDPSERVER)
|
#if defined(CIFACE_USE_DUALSHOCKUDPCLIENT)
|
||||||
#include "DolphinQt/Config/ControllerInterface/CemuHookUDPServerWidget.h"
|
#include "DolphinQt/Config/ControllerInterface/DualShockUDPClientWidget.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ControllerInterfaceWindow::ControllerInterfaceWindow(QWidget* parent) : QDialog(parent)
|
ControllerInterfaceWindow::ControllerInterfaceWindow(QWidget* parent) : QDialog(parent)
|
||||||
|
@ -27,9 +27,9 @@ void ControllerInterfaceWindow::CreateMainLayout()
|
||||||
connect(m_button_box, &QDialogButtonBox::rejected, this, &QDialog::reject);
|
connect(m_button_box, &QDialogButtonBox::rejected, this, &QDialog::reject);
|
||||||
|
|
||||||
m_tab_widget = new QTabWidget();
|
m_tab_widget = new QTabWidget();
|
||||||
#if defined(CIFACE_USE_CEMUHOOKUDPSERVER)
|
#if defined(CIFACE_USE_DUALSHOCKUDPCLIENT)
|
||||||
m_udpserver_widget = new CemuHookUDPServerWidget();
|
m_dsuclient_widget = new DualShockUDPClientWidget();
|
||||||
m_tab_widget->addTab(m_udpserver_widget, tr("UDPServer")); // TODO: use GetWrappedWidget()?
|
m_tab_widget->addTab(m_dsuclient_widget, tr("DSU Client")); // TODO: use GetWrappedWidget()?
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
auto* main_layout = new QVBoxLayout();
|
auto* main_layout = new QVBoxLayout();
|
||||||
|
|
|
@ -8,8 +8,8 @@
|
||||||
|
|
||||||
#include "InputCommon/ControllerInterface/ControllerInterface.h"
|
#include "InputCommon/ControllerInterface/ControllerInterface.h"
|
||||||
|
|
||||||
#if defined(CIFACE_USE_CEMUHOOKUDPSERVER)
|
#if defined(CIFACE_USE_DUALSHOCKUDPCLIENT)
|
||||||
class CemuHookUDPServerWidget;
|
class DualShockUDPClientWidget;
|
||||||
#endif
|
#endif
|
||||||
class QTabWidget;
|
class QTabWidget;
|
||||||
class QDialogButtonBox;
|
class QDialogButtonBox;
|
||||||
|
@ -26,7 +26,7 @@ private:
|
||||||
QTabWidget* m_tab_widget;
|
QTabWidget* m_tab_widget;
|
||||||
QDialogButtonBox* m_button_box;
|
QDialogButtonBox* m_button_box;
|
||||||
|
|
||||||
#if defined(CIFACE_USE_CEMUHOOKUDPSERVER)
|
#if defined(CIFACE_USE_DUALSHOCKUDPCLIENT)
|
||||||
CemuHookUDPServerWidget* m_udpserver_widget;
|
DualShockUDPClientWidget* m_dsuclient_widget;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
// Licensed under GPLv2+
|
// Licensed under GPLv2+
|
||||||
// Refer to the license.txt file included.
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
#include "DolphinQt/Config/ControllerInterface/CemuHookUDPServerWidget.h"
|
#include "DolphinQt/Config/ControllerInterface/DualShockUDPClientWidget.h"
|
||||||
|
|
||||||
#include <QCheckBox>
|
#include <QCheckBox>
|
||||||
#include <QGridLayout>
|
#include <QGridLayout>
|
||||||
|
@ -12,33 +12,33 @@
|
||||||
#include <QSpinBox>
|
#include <QSpinBox>
|
||||||
|
|
||||||
#include "Common/Config/Config.h"
|
#include "Common/Config/Config.h"
|
||||||
#include "InputCommon/ControllerInterface/CemuHookUDPServer/CemuHookUDPServer.h"
|
#include "InputCommon/ControllerInterface/DualShockUDPClient/DualShockUDPClient.h"
|
||||||
|
|
||||||
CemuHookUDPServerWidget::CemuHookUDPServerWidget()
|
DualShockUDPClientWidget::DualShockUDPClientWidget()
|
||||||
{
|
{
|
||||||
CreateWidgets();
|
CreateWidgets();
|
||||||
ConnectWidgets();
|
ConnectWidgets();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CemuHookUDPServerWidget::CreateWidgets()
|
void DualShockUDPClientWidget::CreateWidgets()
|
||||||
{
|
{
|
||||||
auto* main_layout = new QGridLayout;
|
auto* main_layout = new QGridLayout;
|
||||||
|
|
||||||
m_server_enabled = new QCheckBox(tr("Enable"));
|
m_server_enabled = new QCheckBox(tr("Enable"));
|
||||||
m_server_enabled->setChecked(Config::Get(ciface::CemuHookUDPServer::Settings::SERVER_ENABLED));
|
m_server_enabled->setChecked(Config::Get(ciface::DualShockUDPClient::Settings::SERVER_ENABLED));
|
||||||
|
|
||||||
m_server_address = new QLineEdit(
|
m_server_address = new QLineEdit(
|
||||||
QString::fromStdString(Config::Get(ciface::CemuHookUDPServer::Settings::SERVER_ADDRESS)));
|
QString::fromStdString(Config::Get(ciface::DualShockUDPClient::Settings::SERVER_ADDRESS)));
|
||||||
|
|
||||||
m_server_port = new QSpinBox();
|
m_server_port = new QSpinBox();
|
||||||
m_server_port->setMaximum(65535);
|
m_server_port->setMaximum(65535);
|
||||||
m_server_port->setValue(Config::Get(ciface::CemuHookUDPServer::Settings::SERVER_PORT));
|
m_server_port->setValue(Config::Get(ciface::DualShockUDPClient::Settings::SERVER_PORT));
|
||||||
|
|
||||||
auto* description =
|
auto* description =
|
||||||
new QLabel(tr("UDPServer protocol enables the use of input and motion data from compatible "
|
new QLabel(tr("DSU protocol enables the use of input and motion data from compatible "
|
||||||
"sources, like PlayStation, Nintendo Switch and Steam controllers.<br><br>"
|
"sources, like PlayStation, Nintendo Switch and Steam controllers.<br><br>"
|
||||||
"For setup instructions, "
|
"For setup instructions, "
|
||||||
"<a href=\"https://wiki.dolphin-emu.org/index.php?title=UDPServer\">"
|
"<a href=\"https://wiki.dolphin-emu.org/index.php?title=DSU_Client\">"
|
||||||
"refer to this page</a>."));
|
"refer to this page</a>."));
|
||||||
description->setTextFormat(Qt::RichText);
|
description->setTextFormat(Qt::RichText);
|
||||||
description->setWordWrap(true);
|
description->setWordWrap(true);
|
||||||
|
@ -55,21 +55,21 @@ void CemuHookUDPServerWidget::CreateWidgets()
|
||||||
setLayout(main_layout);
|
setLayout(main_layout);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CemuHookUDPServerWidget::ConnectWidgets()
|
void DualShockUDPClientWidget::ConnectWidgets()
|
||||||
{
|
{
|
||||||
connect(m_server_enabled, &QCheckBox::toggled, this, [this] {
|
connect(m_server_enabled, &QCheckBox::toggled, this, [this] {
|
||||||
Config::SetBaseOrCurrent(ciface::CemuHookUDPServer::Settings::SERVER_ENABLED,
|
Config::SetBaseOrCurrent(ciface::DualShockUDPClient::Settings::SERVER_ENABLED,
|
||||||
m_server_enabled->isChecked());
|
m_server_enabled->isChecked());
|
||||||
});
|
});
|
||||||
|
|
||||||
connect(m_server_address, &QLineEdit::editingFinished, this, [this] {
|
connect(m_server_address, &QLineEdit::editingFinished, this, [this] {
|
||||||
Config::SetBaseOrCurrent(ciface::CemuHookUDPServer::Settings::SERVER_ADDRESS,
|
Config::SetBaseOrCurrent(ciface::DualShockUDPClient::Settings::SERVER_ADDRESS,
|
||||||
m_server_address->text().toStdString());
|
m_server_address->text().toStdString());
|
||||||
});
|
});
|
||||||
|
|
||||||
connect(m_server_port, static_cast<void (QSpinBox::*)(int)>(&QSpinBox::valueChanged), this,
|
connect(m_server_port, static_cast<void (QSpinBox::*)(int)>(&QSpinBox::valueChanged), this,
|
||||||
[this] {
|
[this] {
|
||||||
Config::SetBaseOrCurrent(ciface::CemuHookUDPServer::Settings::SERVER_PORT,
|
Config::SetBaseOrCurrent(ciface::DualShockUDPClient::Settings::SERVER_PORT,
|
||||||
static_cast<u16>(m_server_port->value()));
|
static_cast<u16>(m_server_port->value()));
|
||||||
});
|
});
|
||||||
}
|
}
|
|
@ -10,11 +10,11 @@ class QCheckBox;
|
||||||
class QLineEdit;
|
class QLineEdit;
|
||||||
class QSpinBox;
|
class QSpinBox;
|
||||||
|
|
||||||
class CemuHookUDPServerWidget final : public QWidget
|
class DualShockUDPClientWidget final : public QWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit CemuHookUDPServerWidget();
|
explicit DualShockUDPClientWidget();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void CreateWidgets();
|
void CreateWidgets();
|
|
@ -106,7 +106,7 @@
|
||||||
<QtMoc Include="Config\Graphics\HacksWidget.h" />
|
<QtMoc Include="Config\Graphics\HacksWidget.h" />
|
||||||
<QtMoc Include="Config\Graphics\PostProcessingConfigWindow.h" />
|
<QtMoc Include="Config\Graphics\PostProcessingConfigWindow.h" />
|
||||||
<QtMoc Include="Config\Graphics\SoftwareRendererWidget.h" />
|
<QtMoc Include="Config\Graphics\SoftwareRendererWidget.h" />
|
||||||
<QtMoc Include="Config\ControllerInterface\CemuHookUDPServerWidget.h" />
|
<QtMoc Include="Config\ControllerInterface\DualShockUDPClientWidget.h" />
|
||||||
<QtMoc Include="Config\ControllerInterface\ControllerInterfaceWindow.h" />
|
<QtMoc Include="Config\ControllerInterface\ControllerInterfaceWindow.h" />
|
||||||
<QtMoc Include="Config\InfoWidget.h" />
|
<QtMoc Include="Config\InfoWidget.h" />
|
||||||
<QtMoc Include="Config\PatchesWidget.h" />
|
<QtMoc Include="Config\PatchesWidget.h" />
|
||||||
|
@ -189,7 +189,7 @@
|
||||||
<ClCompile Include="$(QtMocOutPrefix)ChunkedProgressDialog.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)ChunkedProgressDialog.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)CodeViewWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)CodeViewWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)CodeWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)CodeWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)CemuHookUDPServerWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)DualShockUDPClientWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)ControllerInterfaceWindow.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)ControllerInterfaceWindow.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)ControllersWindow.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)ControllersWindow.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)DiscordHandler.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)DiscordHandler.cpp" />
|
||||||
|
@ -295,7 +295,7 @@
|
||||||
<ClCompile Include="Config\CheatCodeEditor.cpp" />
|
<ClCompile Include="Config\CheatCodeEditor.cpp" />
|
||||||
<ClCompile Include="Config\ARCodeWidget.cpp" />
|
<ClCompile Include="Config\ARCodeWidget.cpp" />
|
||||||
<ClCompile Include="Config\CheatWarningWidget.cpp" />
|
<ClCompile Include="Config\CheatWarningWidget.cpp" />
|
||||||
<ClCompile Include="Config\ControllerInterface\CemuHookUDPServerWidget.cpp" />
|
<ClCompile Include="Config\ControllerInterface\DualShockUDPClientWidget.cpp" />
|
||||||
<ClCompile Include="Config\ControllerInterface\ControllerInterfaceWindow.cpp" />
|
<ClCompile Include="Config\ControllerInterface\ControllerInterfaceWindow.cpp" />
|
||||||
<ClCompile Include="Config\ControllersWindow.cpp" />
|
<ClCompile Include="Config\ControllersWindow.cpp" />
|
||||||
<ClCompile Include="Config\FilesystemWidget.cpp" />
|
<ClCompile Include="Config\FilesystemWidget.cpp" />
|
||||||
|
|
|
@ -43,9 +43,9 @@ add_library(inputcommon
|
||||||
ControllerEmu/ControlGroup/Triggers.h
|
ControllerEmu/ControlGroup/Triggers.h
|
||||||
ControllerEmu/Setting/NumericSetting.cpp
|
ControllerEmu/Setting/NumericSetting.cpp
|
||||||
ControllerEmu/Setting/NumericSetting.h
|
ControllerEmu/Setting/NumericSetting.h
|
||||||
ControllerInterface/CemuHookUDPServer/CemuHookUDPServer.cpp
|
ControllerInterface/DualShockUDPClient/DualShockUDPClient.cpp
|
||||||
ControllerInterface/CemuHookUDPServer/CemuHookUDPServer.h
|
ControllerInterface/DualShockUDPClient/DualShockUDPClient.h
|
||||||
ControllerInterface/CemuHookUDPServer/CemuHookUDPServerProto.h
|
ControllerInterface/DualShockUDPClient/DualShockUDPProto.h
|
||||||
ControllerInterface/ControllerInterface.cpp
|
ControllerInterface/ControllerInterface.cpp
|
||||||
ControllerInterface/ControllerInterface.h
|
ControllerInterface/ControllerInterface.h
|
||||||
ControllerInterface/Device.cpp
|
ControllerInterface/Device.cpp
|
||||||
|
|
|
@ -30,8 +30,8 @@
|
||||||
#ifdef CIFACE_USE_PIPES
|
#ifdef CIFACE_USE_PIPES
|
||||||
#include "InputCommon/ControllerInterface/Pipes/Pipes.h"
|
#include "InputCommon/ControllerInterface/Pipes/Pipes.h"
|
||||||
#endif
|
#endif
|
||||||
#ifdef CIFACE_USE_CEMUHOOKUDPSERVER
|
#ifdef CIFACE_USE_DUALSHOCKUDPCLIENT
|
||||||
#include "InputCommon/ControllerInterface/CemuHookUDPServer/CemuHookUDPServer.h"
|
#include "InputCommon/ControllerInterface/DualShockUDPClient/DualShockUDPClient.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ControllerInterface g_controller_interface;
|
ControllerInterface g_controller_interface;
|
||||||
|
@ -71,8 +71,8 @@ void ControllerInterface::Initialize(const WindowSystemInfo& wsi)
|
||||||
#ifdef CIFACE_USE_PIPES
|
#ifdef CIFACE_USE_PIPES
|
||||||
// nothing needed
|
// nothing needed
|
||||||
#endif
|
#endif
|
||||||
#ifdef CIFACE_USE_CEMUHOOKUDPSERVER
|
#ifdef CIFACE_USE_DUALSHOCKUDPCLIENT
|
||||||
ciface::CemuHookUDPServer::Init();
|
ciface::DualShockUDPClient::Init();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
RefreshDevices();
|
RefreshDevices();
|
||||||
|
@ -128,8 +128,8 @@ void ControllerInterface::RefreshDevices()
|
||||||
#ifdef CIFACE_USE_PIPES
|
#ifdef CIFACE_USE_PIPES
|
||||||
ciface::Pipes::PopulateDevices();
|
ciface::Pipes::PopulateDevices();
|
||||||
#endif
|
#endif
|
||||||
#ifdef CIFACE_USE_CEMUHOOKUDPSERVER
|
#ifdef CIFACE_USE_DUALSHOCKUDPCLIENT
|
||||||
ciface::CemuHookUDPServer::PopulateDevices();
|
ciface::DualShockUDPClient::PopulateDevices();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
m_is_populating_devices = false;
|
m_is_populating_devices = false;
|
||||||
|
@ -181,8 +181,8 @@ void ControllerInterface::Shutdown()
|
||||||
#ifdef CIFACE_USE_EVDEV
|
#ifdef CIFACE_USE_EVDEV
|
||||||
ciface::evdev::Shutdown();
|
ciface::evdev::Shutdown();
|
||||||
#endif
|
#endif
|
||||||
#ifdef CIFACE_USE_CEMUHOOKUDPSERVER
|
#ifdef CIFACE_USE_DUALSHOCKUDPCLIENT
|
||||||
ciface::CemuHookUDPServer::DeInit();
|
ciface::DualShockUDPClient::DeInit();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
#if defined(USE_PIPES)
|
#if defined(USE_PIPES)
|
||||||
#define CIFACE_USE_PIPES
|
#define CIFACE_USE_PIPES
|
||||||
#endif
|
#endif
|
||||||
#define CIFACE_USE_CEMUHOOKUDPSERVER
|
#define CIFACE_USE_DUALSHOCKUDPCLIENT
|
||||||
|
|
||||||
//
|
//
|
||||||
// ControllerInterface
|
// ControllerInterface
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
// Licensed under GPLv2+
|
// Licensed under GPLv2+
|
||||||
// Refer to the license.txt file included.
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
#include "InputCommon/ControllerInterface/CemuHookUDPServer/CemuHookUDPServer.h"
|
#include "InputCommon/ControllerInterface/DualShockUDPClient/DualShockUDPClient.h"
|
||||||
|
|
||||||
#include <chrono>
|
#include <chrono>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
@ -19,10 +19,10 @@
|
||||||
#include "Common/Thread.h"
|
#include "Common/Thread.h"
|
||||||
#include "Core/CoreTiming.h"
|
#include "Core/CoreTiming.h"
|
||||||
#include "Core/HW/SystemTimers.h"
|
#include "Core/HW/SystemTimers.h"
|
||||||
#include "InputCommon/ControllerInterface/CemuHookUDPServer/CemuHookUDPServerProto.h"
|
|
||||||
#include "InputCommon/ControllerInterface/ControllerInterface.h"
|
#include "InputCommon/ControllerInterface/ControllerInterface.h"
|
||||||
|
#include "InputCommon/ControllerInterface/DualShockUDPClient/DualShockUDPProto.h"
|
||||||
|
|
||||||
namespace ciface::CemuHookUDPServer
|
namespace ciface::DualShockUDPClient
|
||||||
{
|
{
|
||||||
class Device : public Core::Device
|
class Device : public Core::Device
|
||||||
{
|
{
|
||||||
|
@ -119,10 +119,10 @@ static constexpr int TOUCH_Y_AXIS_MAX = 500;
|
||||||
namespace Settings
|
namespace Settings
|
||||||
{
|
{
|
||||||
const Config::ConfigInfo<bool> SERVER_ENABLED{
|
const Config::ConfigInfo<bool> SERVER_ENABLED{
|
||||||
{Config::System::CemuHookUdpServer, "Server", "Enabled"}, false};
|
{Config::System::DualShockUDPClient, "Server", "Enabled"}, false};
|
||||||
const Config::ConfigInfo<std::string> SERVER_ADDRESS{
|
const Config::ConfigInfo<std::string> SERVER_ADDRESS{
|
||||||
{Config::System::CemuHookUdpServer, "Server", "IPAddress"}, DEFAULT_SERVER_ADDRESS};
|
{Config::System::DualShockUDPClient, "Server", "IPAddress"}, DEFAULT_SERVER_ADDRESS};
|
||||||
const Config::ConfigInfo<int> SERVER_PORT{{Config::System::CemuHookUdpServer, "Server", "Port"},
|
const Config::ConfigInfo<int> SERVER_PORT{{Config::System::DualShockUDPClient, "Server", "Port"},
|
||||||
DEFAULT_SERVER_PORT};
|
DEFAULT_SERVER_PORT};
|
||||||
} // namespace Settings
|
} // namespace Settings
|
||||||
|
|
||||||
|
@ -160,8 +160,8 @@ static sf::Socket::Status ReceiveWithTimeout(sf::UdpSocket& socket, void* data,
|
||||||
|
|
||||||
static void HotplugThreadFunc()
|
static void HotplugThreadFunc()
|
||||||
{
|
{
|
||||||
Common::SetCurrentThreadName("CemuHookUDPServer Hotplug Thread");
|
Common::SetCurrentThreadName("DualShockUDPClient Hotplug Thread");
|
||||||
NOTICE_LOG(SERIALINTERFACE, "CemuHookUDPServer hotplug thread started");
|
NOTICE_LOG(SERIALINTERFACE, "DualShockUDPClient hotplug thread started");
|
||||||
|
|
||||||
while (s_hotplug_thread_running.IsSet())
|
while (s_hotplug_thread_running.IsSet())
|
||||||
{
|
{
|
||||||
|
@ -181,7 +181,7 @@ static void HotplugThreadFunc()
|
||||||
msg.Finish();
|
msg.Finish();
|
||||||
if (s_socket.send(&list_ports, sizeof list_ports, s_server_address, s_server_port) !=
|
if (s_socket.send(&list_ports, sizeof list_ports, s_server_address, s_server_port) !=
|
||||||
sf::Socket::Status::Done)
|
sf::Socket::Status::Done)
|
||||||
ERROR_LOG(SERIALINTERFACE, "CemuHookUDPServer HotplugThreadFunc send failed");
|
ERROR_LOG(SERIALINTERFACE, "DualShockUDPClient HotplugThreadFunc send failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Receive controller port info
|
// Receive controller port info
|
||||||
|
@ -208,7 +208,7 @@ static void HotplugThreadFunc()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
NOTICE_LOG(SERIALINTERFACE, "CemuHookUDPServer hotplug thread stopped");
|
NOTICE_LOG(SERIALINTERFACE, "DualShockUDPClient hotplug thread stopped");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void StartHotplugThread()
|
static void StartHotplugThread()
|
||||||
|
@ -238,7 +238,7 @@ static void StopHotplugThread()
|
||||||
|
|
||||||
static void Restart()
|
static void Restart()
|
||||||
{
|
{
|
||||||
NOTICE_LOG(SERIALINTERFACE, "CemuHookUDPServer Restart");
|
NOTICE_LOG(SERIALINTERFACE, "DualShockUDPClient Restart");
|
||||||
|
|
||||||
StopHotplugThread();
|
StopHotplugThread();
|
||||||
|
|
||||||
|
@ -278,10 +278,10 @@ void Init()
|
||||||
|
|
||||||
void PopulateDevices()
|
void PopulateDevices()
|
||||||
{
|
{
|
||||||
NOTICE_LOG(SERIALINTERFACE, "CemuHookUDPServer PopulateDevices");
|
NOTICE_LOG(SERIALINTERFACE, "DualShockUDPClient PopulateDevices");
|
||||||
|
|
||||||
g_controller_interface.RemoveDevice(
|
g_controller_interface.RemoveDevice(
|
||||||
[](const auto* dev) { return dev->GetSource() == "UDPServer"; });
|
[](const auto* dev) { return dev->GetSource() == "DSUClient"; });
|
||||||
|
|
||||||
std::lock_guard<std::mutex> lock(s_port_info_mutex);
|
std::lock_guard<std::mutex> lock(s_port_info_mutex);
|
||||||
for (int port_index = 0; port_index < Proto::PORT_COUNT; port_index++)
|
for (int port_index = 0; port_index < Proto::PORT_COUNT; port_index++)
|
||||||
|
@ -374,7 +374,7 @@ std::string Device::GetName() const
|
||||||
|
|
||||||
std::string Device::GetSource() const
|
std::string Device::GetSource() const
|
||||||
{
|
{
|
||||||
return "UDPServer";
|
return "DSUClient";
|
||||||
}
|
}
|
||||||
|
|
||||||
void Device::UpdateInput()
|
void Device::UpdateInput()
|
||||||
|
@ -392,7 +392,7 @@ void Device::UpdateInput()
|
||||||
msg.Finish();
|
msg.Finish();
|
||||||
if (m_socket.send(&data_req, sizeof(data_req), s_server_address, s_server_port) !=
|
if (m_socket.send(&data_req, sizeof(data_req), s_server_address, s_server_port) !=
|
||||||
sf::Socket::Status::Done)
|
sf::Socket::Status::Done)
|
||||||
ERROR_LOG(SERIALINTERFACE, "CemuHookUDPServer UpdateInput send failed");
|
ERROR_LOG(SERIALINTERFACE, "DualShockUDPClient UpdateInput send failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Receive and handle controller data
|
// Receive and handle controller data
|
||||||
|
@ -441,4 +441,4 @@ std::optional<int> Device::GetPreferredId() const
|
||||||
return m_index;
|
return m_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace ciface::CemuHookUDPServer
|
} // namespace ciface::DualShockUDPClient
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
#include "Common/Config/Config.h"
|
#include "Common/Config/Config.h"
|
||||||
|
|
||||||
namespace ciface::CemuHookUDPServer
|
namespace ciface::DualShockUDPClient
|
||||||
{
|
{
|
||||||
namespace Settings
|
namespace Settings
|
||||||
{
|
{
|
||||||
|
@ -16,4 +16,4 @@ extern const Config::ConfigInfo<int> SERVER_PORT;
|
||||||
void Init();
|
void Init();
|
||||||
void PopulateDevices();
|
void PopulateDevices();
|
||||||
void DeInit();
|
void DeInit();
|
||||||
} // namespace ciface::CemuHookUDPServer
|
} // namespace ciface::DualShockUDPClient
|
|
@ -8,9 +8,9 @@
|
||||||
|
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
|
|
||||||
namespace ciface::CemuHookUDPServer::Proto
|
namespace ciface::DualShockUDPClient::Proto
|
||||||
{
|
{
|
||||||
// CemuHook UDPServer protocol implementation using UdpServer.cs from
|
// CemuHook DualShockUDP protocol implementation using UdpServer.cs from
|
||||||
// https://github.com/Ryochan7/DS4Windows as documentation.
|
// https://github.com/Ryochan7/DS4Windows as documentation.
|
||||||
//
|
//
|
||||||
// WARNING: Little endian host assumed
|
// WARNING: Little endian host assumed
|
||||||
|
@ -245,7 +245,7 @@ struct Message
|
||||||
if (crc32_in_header != crc32_calculated)
|
if (crc32_in_header != crc32_calculated)
|
||||||
{
|
{
|
||||||
NOTICE_LOG(SERIALINTERFACE,
|
NOTICE_LOG(SERIALINTERFACE,
|
||||||
"CemuHookUDPServer Received message with bad CRC in header: got %u, expected %u",
|
"DualShockUDPClient Received message with bad CRC in header: got %u, expected %u",
|
||||||
crc32_in_header, crc32_calculated);
|
crc32_in_header, crc32_calculated);
|
||||||
return std::nullopt;
|
return std::nullopt;
|
||||||
}
|
}
|
||||||
|
@ -267,4 +267,4 @@ struct Message
|
||||||
};
|
};
|
||||||
|
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
} // namespace ciface::CemuHookUDPServer::Proto
|
} // namespace ciface::DualShockUDPClient::Proto
|
|
@ -56,13 +56,13 @@
|
||||||
<ClCompile Include="ControllerEmu\ControlGroup\Tilt.cpp" />
|
<ClCompile Include="ControllerEmu\ControlGroup\Tilt.cpp" />
|
||||||
<ClCompile Include="ControllerEmu\ControlGroup\Triggers.cpp" />
|
<ClCompile Include="ControllerEmu\ControlGroup\Triggers.cpp" />
|
||||||
<ClCompile Include="ControllerEmu\Setting\NumericSetting.cpp" />
|
<ClCompile Include="ControllerEmu\Setting\NumericSetting.cpp" />
|
||||||
<ClCompile Include="ControllerInterface\CemuHookUDPServer\CemuHookUDPServer.cpp" />
|
|
||||||
<ClCompile Include="ControllerInterface\ControllerInterface.cpp" />
|
<ClCompile Include="ControllerInterface\ControllerInterface.cpp" />
|
||||||
<ClCompile Include="ControllerInterface\Device.cpp" />
|
<ClCompile Include="ControllerInterface\Device.cpp" />
|
||||||
<ClCompile Include="ControllerInterface\DInput\DInput.cpp" />
|
<ClCompile Include="ControllerInterface\DInput\DInput.cpp" />
|
||||||
<ClCompile Include="ControllerInterface\DInput\DInputJoystick.cpp" />
|
<ClCompile Include="ControllerInterface\DInput\DInputJoystick.cpp" />
|
||||||
<ClCompile Include="ControllerInterface\DInput\DInputKeyboardMouse.cpp" />
|
<ClCompile Include="ControllerInterface\DInput\DInputKeyboardMouse.cpp" />
|
||||||
<ClCompile Include="ControllerInterface\DInput\XInputFilter.cpp" />
|
<ClCompile Include="ControllerInterface\DInput\XInputFilter.cpp" />
|
||||||
|
<ClCompile Include="ControllerInterface\DualShockUDPClient\DualShockUDPClient.cpp" />
|
||||||
<ClCompile Include="ControlReference\ControlReference.cpp" />
|
<ClCompile Include="ControlReference\ControlReference.cpp" />
|
||||||
<ClCompile Include="ControlReference\ExpressionParser.cpp" />
|
<ClCompile Include="ControlReference\ExpressionParser.cpp" />
|
||||||
<ClCompile Include="ControllerInterface\ForceFeedback\ForceFeedbackDevice.cpp" />
|
<ClCompile Include="ControllerInterface\ForceFeedback\ForceFeedbackDevice.cpp" />
|
||||||
|
@ -100,8 +100,6 @@
|
||||||
<ClInclude Include="ControllerEmu\ControlGroup\Tilt.h" />
|
<ClInclude Include="ControllerEmu\ControlGroup\Tilt.h" />
|
||||||
<ClInclude Include="ControllerEmu\ControlGroup\Triggers.h" />
|
<ClInclude Include="ControllerEmu\ControlGroup\Triggers.h" />
|
||||||
<ClInclude Include="ControllerEmu\Setting\NumericSetting.h" />
|
<ClInclude Include="ControllerEmu\Setting\NumericSetting.h" />
|
||||||
<ClInclude Include="ControllerInterface\CemuHookUDPServer\CemuHookUDPServer.h" />
|
|
||||||
<ClInclude Include="ControllerInterface\CemuHookUDPServer\CemuHookUDPServerProto.h" />
|
|
||||||
<ClInclude Include="ControllerInterface\ControllerInterface.h" />
|
<ClInclude Include="ControllerInterface\ControllerInterface.h" />
|
||||||
<ClInclude Include="ControllerInterface\Device.h" />
|
<ClInclude Include="ControllerInterface\Device.h" />
|
||||||
<ClInclude Include="ControllerInterface\DInput\DInput.h" />
|
<ClInclude Include="ControllerInterface\DInput\DInput.h" />
|
||||||
|
@ -109,6 +107,8 @@
|
||||||
<ClInclude Include="ControllerInterface\DInput\DInputJoystick.h" />
|
<ClInclude Include="ControllerInterface\DInput\DInputJoystick.h" />
|
||||||
<ClInclude Include="ControllerInterface\DInput\DInputKeyboardMouse.h" />
|
<ClInclude Include="ControllerInterface\DInput\DInputKeyboardMouse.h" />
|
||||||
<ClInclude Include="ControllerInterface\DInput\XInputFilter.h" />
|
<ClInclude Include="ControllerInterface\DInput\XInputFilter.h" />
|
||||||
|
<ClInclude Include="ControllerInterface\DualShockUDPClient\DualShockUDPClient.h" />
|
||||||
|
<ClInclude Include="ControllerInterface\DualShockUDPClient\DualShockUDPProto.h" />
|
||||||
<ClInclude Include="ControlReference\ControlReference.h" />
|
<ClInclude Include="ControlReference\ControlReference.h" />
|
||||||
<ClInclude Include="ControlReference\FunctionExpression.h" />
|
<ClInclude Include="ControlReference\FunctionExpression.h" />
|
||||||
<ClInclude Include="ControlReference\ExpressionParser.h" />
|
<ClInclude Include="ControlReference\ExpressionParser.h" />
|
||||||
|
|
|
@ -28,8 +28,8 @@
|
||||||
<Filter Include="ControllerInterface\XInput">
|
<Filter Include="ControllerInterface\XInput">
|
||||||
<UniqueIdentifier>{07bad1aa-7e03-4f5c-ade2-a44857c5cbc3}</UniqueIdentifier>
|
<UniqueIdentifier>{07bad1aa-7e03-4f5c-ade2-a44857c5cbc3}</UniqueIdentifier>
|
||||||
</Filter>
|
</Filter>
|
||||||
<Filter Include="ControllerInterface\CemuHookUDPServer">
|
<Filter Include="ControllerInterface\DualShockUDPClient">
|
||||||
<UniqueIdentifier>{4f71c21c-85eb-4e76-ad64-40fd97bc3d6d}</UniqueIdentifier>
|
<UniqueIdentifier>{ff02580e-3a62-4de4-a135-3a6c2c339a90}</UniqueIdentifier>
|
||||||
</Filter>
|
</Filter>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
@ -126,15 +126,15 @@
|
||||||
<ClCompile Include="ControllerEmu\ControlGroup\IMUCursor.cpp">
|
<ClCompile Include="ControllerEmu\ControlGroup\IMUCursor.cpp">
|
||||||
<Filter>ControllerEmu\ControlGroup</Filter>
|
<Filter>ControllerEmu\ControlGroup</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ClCompile Include="ControllerInterface\CemuHookUDPServer\CemuHookUDPServer.cpp">
|
|
||||||
<Filter>ControllerInterface\CemuHookUDPServer</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="ControllerEmu\ControlGroup\IMUAccelerometer.cpp">
|
<ClCompile Include="ControllerEmu\ControlGroup\IMUAccelerometer.cpp">
|
||||||
<Filter>ControllerEmu\ControlGroup</Filter>
|
<Filter>ControllerEmu\ControlGroup</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ClCompile Include="ControllerEmu\ControlGroup\IMUGyroscope.cpp">
|
<ClCompile Include="ControllerEmu\ControlGroup\IMUGyroscope.cpp">
|
||||||
<Filter>ControllerEmu\ControlGroup</Filter>
|
<Filter>ControllerEmu\ControlGroup</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="ControllerInterface\DualShockUDPClient\DualShockUDPClient.cpp">
|
||||||
|
<Filter>ControllerInterface\DualShockUDPClient</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClInclude Include="GCAdapter.h" />
|
<ClInclude Include="GCAdapter.h" />
|
||||||
|
@ -224,9 +224,6 @@
|
||||||
<ClInclude Include="ControlReference\ControlReference.h">
|
<ClInclude Include="ControlReference\ControlReference.h">
|
||||||
<Filter>ControllerInterface</Filter>
|
<Filter>ControllerInterface</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClCompile Include="ControlReference\FunctionExpression.h">
|
|
||||||
<Filter>ControllerInterface</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClInclude Include="InputProfile.h" />
|
<ClInclude Include="InputProfile.h" />
|
||||||
<ClInclude Include="ControllerEmu\ControlGroup\Attachments.h">
|
<ClInclude Include="ControllerEmu\ControlGroup\Attachments.h">
|
||||||
<Filter>ControllerEmu\ControlGroup</Filter>
|
<Filter>ControllerEmu\ControlGroup</Filter>
|
||||||
|
@ -234,17 +231,18 @@
|
||||||
<ClInclude Include="ControllerEmu\ControlGroup\IMUCursor.h">
|
<ClInclude Include="ControllerEmu\ControlGroup\IMUCursor.h">
|
||||||
<Filter>ControllerEmu\ControlGroup</Filter>
|
<Filter>ControllerEmu\ControlGroup</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClInclude Include="ControllerInterface\CemuHookUDPServer\CemuHookUDPServer.h">
|
|
||||||
<Filter>ControllerInterface\CemuHookUDPServer</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="ControllerEmu\ControlGroup\IMUAccelerometer.h">
|
<ClInclude Include="ControllerEmu\ControlGroup\IMUAccelerometer.h">
|
||||||
<Filter>ControllerEmu\ControlGroup</Filter>
|
<Filter>ControllerEmu\ControlGroup</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClInclude Include="ControllerEmu\ControlGroup\IMUGyroscope.h">
|
<ClInclude Include="ControllerEmu\ControlGroup\IMUGyroscope.h">
|
||||||
<Filter>ControllerEmu\ControlGroup</Filter>
|
<Filter>ControllerEmu\ControlGroup</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClInclude Include="ControllerInterface\CemuHookUDPServer\CemuHookUDPServerProto.h">
|
<ClInclude Include="ControlReference\FunctionExpression.h" />
|
||||||
<Filter>ControllerInterface\CemuHookUDPServer</Filter>
|
<ClInclude Include="ControllerInterface\DualShockUDPClient\DualShockUDPClient.h">
|
||||||
|
<Filter>ControllerInterface\DualShockUDPClient</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="ControllerInterface\DualShockUDPClient\DualShockUDPProto.h">
|
||||||
|
<Filter>ControllerInterface\DualShockUDPClient</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|
Loading…
Reference in New Issue