Merge pull request #10118 from lioncash/messageid
NetPlayProto: Remove lots of casts to MessageId when inserting enum values into packets
This commit is contained in:
commit
f19da1cf92
|
@ -3,18 +3,37 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <type_traits>
|
||||||
|
|
||||||
|
#include <SFML/Network/Packet.hpp>
|
||||||
|
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/Swap.h"
|
#include "Common/Swap.h"
|
||||||
|
|
||||||
namespace sf
|
|
||||||
{
|
|
||||||
class Packet;
|
|
||||||
}
|
|
||||||
|
|
||||||
sf::Packet& operator>>(sf::Packet& packet, Common::BigEndianValue<u16>& data);
|
sf::Packet& operator>>(sf::Packet& packet, Common::BigEndianValue<u16>& data);
|
||||||
sf::Packet& operator>>(sf::Packet& packet, Common::BigEndianValue<u32>& data);
|
sf::Packet& operator>>(sf::Packet& packet, Common::BigEndianValue<u32>& data);
|
||||||
sf::Packet& operator>>(sf::Packet& packet, Common::BigEndianValue<u64>& data);
|
sf::Packet& operator>>(sf::Packet& packet, Common::BigEndianValue<u64>& data);
|
||||||
|
|
||||||
|
template <typename Enum, std::enable_if_t<std::is_enum_v<Enum>>* = nullptr>
|
||||||
|
sf::Packet& operator<<(sf::Packet& packet, Enum e)
|
||||||
|
{
|
||||||
|
using Underlying = std::underlying_type_t<Enum>;
|
||||||
|
packet << static_cast<Underlying>(e);
|
||||||
|
return packet;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename Enum, std::enable_if_t<std::is_enum_v<Enum>>* = nullptr>
|
||||||
|
sf::Packet& operator>>(sf::Packet& packet, Enum& e)
|
||||||
|
{
|
||||||
|
using Underlying = std::underlying_type_t<Enum>;
|
||||||
|
|
||||||
|
Underlying value{};
|
||||||
|
packet >> value;
|
||||||
|
|
||||||
|
e = static_cast<Enum>(value);
|
||||||
|
return packet;
|
||||||
|
}
|
||||||
|
|
||||||
namespace Common
|
namespace Common
|
||||||
{
|
{
|
||||||
u64 PacketReadU64(sf::Packet& packet);
|
u64 PacketReadU64(sf::Packet& packet);
|
||||||
|
|
|
@ -244,25 +244,25 @@ bool NetPlayClient::Connect()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
MessageId error;
|
ConnectionError error;
|
||||||
rpac >> error;
|
rpac >> error;
|
||||||
|
|
||||||
// got error message
|
// got error message
|
||||||
if (error)
|
if (error != ConnectionError::NoError)
|
||||||
{
|
{
|
||||||
switch (error)
|
switch (error)
|
||||||
{
|
{
|
||||||
case CON_ERR_SERVER_FULL:
|
case ConnectionError::ServerFull:
|
||||||
m_dialog->OnConnectionError(_trans("The server is full."));
|
m_dialog->OnConnectionError(_trans("The server is full."));
|
||||||
break;
|
break;
|
||||||
case CON_ERR_VERSION_MISMATCH:
|
case ConnectionError::VersionMismatch:
|
||||||
m_dialog->OnConnectionError(
|
m_dialog->OnConnectionError(
|
||||||
_trans("The server and client's NetPlay versions are incompatible."));
|
_trans("The server and client's NetPlay versions are incompatible."));
|
||||||
break;
|
break;
|
||||||
case CON_ERR_GAME_RUNNING:
|
case ConnectionError::GameRunning:
|
||||||
m_dialog->OnConnectionError(_trans("The game is currently running."));
|
m_dialog->OnConnectionError(_trans("The game is currently running."));
|
||||||
break;
|
break;
|
||||||
case CON_ERR_NAME_TOO_LONG:
|
case ConnectionError::NameTooLong:
|
||||||
m_dialog->OnConnectionError(_trans("Nickname is too long."));
|
m_dialog->OnConnectionError(_trans("Nickname is too long."));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -313,143 +313,143 @@ static void ReceiveSyncIdentifier(sf::Packet& spac, SyncIdentifier& sync_identif
|
||||||
// called from ---NETPLAY--- thread
|
// called from ---NETPLAY--- thread
|
||||||
void NetPlayClient::OnData(sf::Packet& packet)
|
void NetPlayClient::OnData(sf::Packet& packet)
|
||||||
{
|
{
|
||||||
MessageId mid;
|
MessageID mid;
|
||||||
packet >> mid;
|
packet >> mid;
|
||||||
|
|
||||||
INFO_LOG_FMT(NETPLAY, "Got server message: {:x}", mid);
|
INFO_LOG_FMT(NETPLAY, "Got server message: {:x}", mid);
|
||||||
|
|
||||||
switch (mid)
|
switch (mid)
|
||||||
{
|
{
|
||||||
case NP_MSG_PLAYER_JOIN:
|
case MessageID::PlayerJoin:
|
||||||
OnPlayerJoin(packet);
|
OnPlayerJoin(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PLAYER_LEAVE:
|
case MessageID::PlayerLeave:
|
||||||
OnPlayerLeave(packet);
|
OnPlayerLeave(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHAT_MESSAGE:
|
case MessageID::ChatMessage:
|
||||||
OnChatMessage(packet);
|
OnChatMessage(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHUNKED_DATA_START:
|
case MessageID::ChunkedDataStart:
|
||||||
OnChunkedDataStart(packet);
|
OnChunkedDataStart(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHUNKED_DATA_END:
|
case MessageID::ChunkedDataEnd:
|
||||||
OnChunkedDataEnd(packet);
|
OnChunkedDataEnd(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHUNKED_DATA_PAYLOAD:
|
case MessageID::ChunkedDataPayload:
|
||||||
OnChunkedDataPayload(packet);
|
OnChunkedDataPayload(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHUNKED_DATA_ABORT:
|
case MessageID::ChunkedDataAbort:
|
||||||
OnChunkedDataAbort(packet);
|
OnChunkedDataAbort(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PAD_MAPPING:
|
case MessageID::PadMapping:
|
||||||
OnPadMapping(packet);
|
OnPadMapping(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GBA_CONFIG:
|
case MessageID::GBAConfig:
|
||||||
OnGBAConfig(packet);
|
OnGBAConfig(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_WIIMOTE_MAPPING:
|
case MessageID::WiimoteMapping:
|
||||||
OnWiimoteMapping(packet);
|
OnWiimoteMapping(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PAD_DATA:
|
case MessageID::PadData:
|
||||||
OnPadData(packet);
|
OnPadData(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PAD_HOST_DATA:
|
case MessageID::PadHostData:
|
||||||
OnPadHostData(packet);
|
OnPadHostData(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_WIIMOTE_DATA:
|
case MessageID::WiimoteData:
|
||||||
OnWiimoteData(packet);
|
OnWiimoteData(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PAD_BUFFER:
|
case MessageID::PadBuffer:
|
||||||
OnPadBuffer(packet);
|
OnPadBuffer(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_HOST_INPUT_AUTHORITY:
|
case MessageID::HostInputAuthority:
|
||||||
OnHostInputAuthority(packet);
|
OnHostInputAuthority(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GOLF_SWITCH:
|
case MessageID::GolfSwitch:
|
||||||
OnGolfSwitch(packet);
|
OnGolfSwitch(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GOLF_PREPARE:
|
case MessageID::GolfPrepare:
|
||||||
OnGolfPrepare(packet);
|
OnGolfPrepare(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHANGE_GAME:
|
case MessageID::ChangeGame:
|
||||||
OnChangeGame(packet);
|
OnChangeGame(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GAME_STATUS:
|
case MessageID::GameStatus:
|
||||||
OnGameStatus(packet);
|
OnGameStatus(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_START_GAME:
|
case MessageID::StartGame:
|
||||||
OnStartGame(packet);
|
OnStartGame(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_STOP_GAME:
|
case MessageID::StopGame:
|
||||||
case NP_MSG_DISABLE_GAME:
|
case MessageID::DisableGame:
|
||||||
OnStopGame(packet);
|
OnStopGame(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_POWER_BUTTON:
|
case MessageID::PowerButton:
|
||||||
OnPowerButton();
|
OnPowerButton();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PING:
|
case MessageID::Ping:
|
||||||
OnPing(packet);
|
OnPing(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PLAYER_PING_DATA:
|
case MessageID::PlayerPingData:
|
||||||
OnPlayerPingData(packet);
|
OnPlayerPingData(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_DESYNC_DETECTED:
|
case MessageID::DesyncDetected:
|
||||||
OnDesyncDetected(packet);
|
OnDesyncDetected(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_SYNC_GC_SRAM:
|
case MessageID::SyncGCSRAM:
|
||||||
OnSyncGCSRAM(packet);
|
OnSyncGCSRAM(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_SYNC_SAVE_DATA:
|
case MessageID::SyncSaveData:
|
||||||
OnSyncSaveData(packet);
|
OnSyncSaveData(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_SYNC_CODES:
|
case MessageID::SyncCodes:
|
||||||
OnSyncCodes(packet);
|
OnSyncCodes(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_COMPUTE_MD5:
|
case MessageID::ComputeMD5:
|
||||||
OnComputeMD5(packet);
|
OnComputeMD5(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_MD5_PROGRESS:
|
case MessageID::MD5Progress:
|
||||||
OnMD5Progress(packet);
|
OnMD5Progress(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_MD5_RESULT:
|
case MessageID::MD5Result:
|
||||||
OnMD5Result(packet);
|
OnMD5Result(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_MD5_ERROR:
|
case MessageID::MD5Error:
|
||||||
OnMD5Error(packet);
|
OnMD5Error(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_MD5_ABORT:
|
case MessageID::MD5Abort:
|
||||||
OnMD5Abort();
|
OnMD5Abort();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -547,7 +547,7 @@ void NetPlayClient::OnChunkedDataEnd(sf::Packet& packet)
|
||||||
m_dialog->HideChunkedProgressDialog();
|
m_dialog->HideChunkedProgressDialog();
|
||||||
|
|
||||||
sf::Packet complete_packet;
|
sf::Packet complete_packet;
|
||||||
complete_packet << static_cast<MessageId>(NP_MSG_CHUNKED_DATA_COMPLETE);
|
complete_packet << MessageID::ChunkedDataComplete;
|
||||||
complete_packet << cid;
|
complete_packet << cid;
|
||||||
Send(complete_packet, CHUNKED_DATA_CHANNEL);
|
Send(complete_packet, CHUNKED_DATA_CHANNEL);
|
||||||
}
|
}
|
||||||
|
@ -572,7 +572,7 @@ void NetPlayClient::OnChunkedDataPayload(sf::Packet& packet)
|
||||||
m_dialog->SetChunkedProgress(m_local_player->pid, data_packet.getDataSize());
|
m_dialog->SetChunkedProgress(m_local_player->pid, data_packet.getDataSize());
|
||||||
|
|
||||||
sf::Packet progress_packet;
|
sf::Packet progress_packet;
|
||||||
progress_packet << static_cast<MessageId>(NP_MSG_CHUNKED_DATA_PROGRESS);
|
progress_packet << MessageID::ChunkedDataProgress;
|
||||||
progress_packet << cid;
|
progress_packet << cid;
|
||||||
progress_packet << sf::Uint64{data_packet.getDataSize()};
|
progress_packet << sf::Uint64{data_packet.getDataSize()};
|
||||||
Send(progress_packet, CHUNKED_DATA_CHANNEL);
|
Send(progress_packet, CHUNKED_DATA_CHANNEL);
|
||||||
|
@ -731,13 +731,13 @@ void NetPlayClient::OnGolfSwitch(sf::Packet& packet)
|
||||||
if (m_local_player->pid == previous_golfer)
|
if (m_local_player->pid == previous_golfer)
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GOLF_RELEASE);
|
spac << MessageID::GolfRelease;
|
||||||
Send(spac);
|
Send(spac);
|
||||||
}
|
}
|
||||||
else if (m_local_player->pid == pid)
|
else if (m_local_player->pid == pid)
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GOLF_ACQUIRE);
|
spac << MessageID::GolfAcquire;
|
||||||
Send(spac);
|
Send(spac);
|
||||||
|
|
||||||
// Pads are already calibrated so we can just ignore this
|
// Pads are already calibrated so we can just ignore this
|
||||||
|
@ -771,7 +771,7 @@ void NetPlayClient::OnChangeGame(sf::Packet& packet)
|
||||||
SendGameStatus();
|
SendGameStatus();
|
||||||
|
|
||||||
sf::Packet client_capabilities_packet;
|
sf::Packet client_capabilities_packet;
|
||||||
client_capabilities_packet << static_cast<MessageId>(NP_MSG_CLIENT_CAPABILITIES);
|
client_capabilities_packet << MessageID::ClientCapabilities;
|
||||||
client_capabilities_packet << ExpansionInterface::CEXIIPL::HasIPLDump();
|
client_capabilities_packet << ExpansionInterface::CEXIIPL::HasIPLDump();
|
||||||
client_capabilities_packet << Config::Get(Config::SESSION_USE_FMA);
|
client_capabilities_packet << Config::Get(Config::SESSION_USE_FMA);
|
||||||
Send(client_capabilities_packet);
|
Send(client_capabilities_packet);
|
||||||
|
@ -784,10 +784,7 @@ void NetPlayClient::OnGameStatus(sf::Packet& packet)
|
||||||
|
|
||||||
{
|
{
|
||||||
std::lock_guard lkp(m_crit.players);
|
std::lock_guard lkp(m_crit.players);
|
||||||
Player& player = m_players[pid];
|
packet >> m_players[pid].game_status;
|
||||||
u32 status;
|
|
||||||
packet >> status;
|
|
||||||
player.game_status = static_cast<SyncIdentifierComparison>(status);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
m_dialog->Update();
|
m_dialog->Update();
|
||||||
|
@ -797,19 +794,12 @@ void NetPlayClient::OnStartGame(sf::Packet& packet)
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
std::lock_guard lkg(m_crit.game);
|
std::lock_guard lkg(m_crit.game);
|
||||||
packet >> m_current_game;
|
|
||||||
packet >> m_net_settings.m_CPUthread;
|
|
||||||
|
|
||||||
INFO_LOG_FMT(NETPLAY, "Start of game {}", m_selected_game.game_id);
|
INFO_LOG_FMT(NETPLAY, "Start of game {}", m_selected_game.game_id);
|
||||||
|
|
||||||
{
|
packet >> m_current_game;
|
||||||
std::underlying_type_t<PowerPC::CPUCore> core;
|
packet >> m_net_settings.m_CPUthread;
|
||||||
if (packet >> core)
|
packet >> m_net_settings.m_CPUcore;
|
||||||
m_net_settings.m_CPUcore = static_cast<PowerPC::CPUCore>(core);
|
|
||||||
else
|
|
||||||
m_net_settings.m_CPUcore = PowerPC::CPUCore::CachedInterpreter;
|
|
||||||
}
|
|
||||||
|
|
||||||
packet >> m_net_settings.m_EnableCheats;
|
packet >> m_net_settings.m_EnableCheats;
|
||||||
packet >> m_net_settings.m_SelectedLanguage;
|
packet >> m_net_settings.m_SelectedLanguage;
|
||||||
packet >> m_net_settings.m_OverrideRegionSettings;
|
packet >> m_net_settings.m_OverrideRegionSettings;
|
||||||
|
@ -819,24 +809,14 @@ void NetPlayClient::OnStartGame(sf::Packet& packet)
|
||||||
packet >> m_net_settings.m_RAMOverrideEnable;
|
packet >> m_net_settings.m_RAMOverrideEnable;
|
||||||
packet >> m_net_settings.m_Mem1Size;
|
packet >> m_net_settings.m_Mem1Size;
|
||||||
packet >> m_net_settings.m_Mem2Size;
|
packet >> m_net_settings.m_Mem2Size;
|
||||||
|
packet >> m_net_settings.m_FallbackRegion;
|
||||||
{
|
|
||||||
std::underlying_type_t<DiscIO::Region> tmp;
|
|
||||||
packet >> tmp;
|
|
||||||
m_net_settings.m_FallbackRegion = static_cast<DiscIO::Region>(tmp);
|
|
||||||
}
|
|
||||||
|
|
||||||
packet >> m_net_settings.m_AllowSDWrites;
|
packet >> m_net_settings.m_AllowSDWrites;
|
||||||
packet >> m_net_settings.m_CopyWiiSave;
|
packet >> m_net_settings.m_CopyWiiSave;
|
||||||
packet >> m_net_settings.m_OCEnable;
|
packet >> m_net_settings.m_OCEnable;
|
||||||
packet >> m_net_settings.m_OCFactor;
|
packet >> m_net_settings.m_OCFactor;
|
||||||
|
|
||||||
for (auto& device : m_net_settings.m_EXIDevice)
|
for (auto& device : m_net_settings.m_EXIDevice)
|
||||||
{
|
packet >> device;
|
||||||
int tmp;
|
|
||||||
packet >> tmp;
|
|
||||||
device = static_cast<ExpansionInterface::TEXIDevices>(tmp);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (u32& value : m_net_settings.m_SYSCONFSettings)
|
for (u32& value : m_net_settings.m_SYSCONFSettings)
|
||||||
packet >> value;
|
packet >> value;
|
||||||
|
@ -924,7 +904,7 @@ void NetPlayClient::OnPing(sf::Packet& packet)
|
||||||
packet >> ping_key;
|
packet >> ping_key;
|
||||||
|
|
||||||
sf::Packet response_packet;
|
sf::Packet response_packet;
|
||||||
response_packet << static_cast<MessageId>(NP_MSG_PONG);
|
response_packet << MessageID::Pong;
|
||||||
response_packet << ping_key;
|
response_packet << ping_key;
|
||||||
|
|
||||||
Send(response_packet);
|
Send(response_packet);
|
||||||
|
@ -981,7 +961,7 @@ void NetPlayClient::OnSyncGCSRAM(sf::Packet& packet)
|
||||||
|
|
||||||
void NetPlayClient::OnSyncSaveData(sf::Packet& packet)
|
void NetPlayClient::OnSyncSaveData(sf::Packet& packet)
|
||||||
{
|
{
|
||||||
MessageId sub_id;
|
SyncSaveDataID sub_id;
|
||||||
packet >> sub_id;
|
packet >> sub_id;
|
||||||
|
|
||||||
if (m_local_player->IsHost())
|
if (m_local_player->IsHost())
|
||||||
|
@ -989,23 +969,23 @@ void NetPlayClient::OnSyncSaveData(sf::Packet& packet)
|
||||||
|
|
||||||
switch (sub_id)
|
switch (sub_id)
|
||||||
{
|
{
|
||||||
case SYNC_SAVE_DATA_NOTIFY:
|
case SyncSaveDataID::Notify:
|
||||||
OnSyncSaveDataNotify(packet);
|
OnSyncSaveDataNotify(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_SAVE_DATA_RAW:
|
case SyncSaveDataID::RawData:
|
||||||
OnSyncSaveDataRaw(packet);
|
OnSyncSaveDataRaw(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_SAVE_DATA_GCI:
|
case SyncSaveDataID::GCIData:
|
||||||
OnSyncSaveDataGCI(packet);
|
OnSyncSaveDataGCI(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_SAVE_DATA_WII:
|
case SyncSaveDataID::WiiData:
|
||||||
OnSyncSaveDataWii(packet);
|
OnSyncSaveDataWii(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_SAVE_DATA_GBA:
|
case SyncSaveDataID::GBAData:
|
||||||
OnSyncSaveDataGBA(packet);
|
OnSyncSaveDataGBA(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1183,11 +1163,7 @@ void NetPlayClient::OnSyncSaveDataWii(sf::Packet& packet)
|
||||||
{
|
{
|
||||||
WiiSave::Storage::SaveFile file;
|
WiiSave::Storage::SaveFile file;
|
||||||
packet >> file.mode >> file.attributes;
|
packet >> file.mode >> file.attributes;
|
||||||
{
|
packet >> file.type;
|
||||||
u8 tmp;
|
|
||||||
packet >> tmp;
|
|
||||||
file.type = static_cast<WiiSave::Storage::SaveFile::Type>(tmp);
|
|
||||||
}
|
|
||||||
packet >> file.path;
|
packet >> file.path;
|
||||||
|
|
||||||
if (file.type == WiiSave::Storage::SaveFile::Type::File)
|
if (file.type == WiiSave::Storage::SaveFile::Type::File)
|
||||||
|
@ -1239,29 +1215,29 @@ void NetPlayClient::OnSyncSaveDataGBA(sf::Packet& packet)
|
||||||
void NetPlayClient::OnSyncCodes(sf::Packet& packet)
|
void NetPlayClient::OnSyncCodes(sf::Packet& packet)
|
||||||
{
|
{
|
||||||
// Recieve Data Packet
|
// Recieve Data Packet
|
||||||
MessageId sub_id;
|
SyncCodeID sub_id;
|
||||||
packet >> sub_id;
|
packet >> sub_id;
|
||||||
|
|
||||||
// Check Which Operation to Perform with This Packet
|
// Check Which Operation to Perform with This Packet
|
||||||
switch (sub_id)
|
switch (sub_id)
|
||||||
{
|
{
|
||||||
case SYNC_CODES_NOTIFY:
|
case SyncCodeID::Notify:
|
||||||
OnSyncCodesNotify();
|
OnSyncCodesNotify();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_CODES_NOTIFY_GECKO:
|
case SyncCodeID::NotifyGecko:
|
||||||
OnSyncCodesNotifyGecko(packet);
|
OnSyncCodesNotifyGecko(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_CODES_DATA_GECKO:
|
case SyncCodeID::GeckoData:
|
||||||
OnSyncCodesDataGecko(packet);
|
OnSyncCodesDataGecko(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_CODES_NOTIFY_AR:
|
case SyncCodeID::NotifyAR:
|
||||||
OnSyncCodesNotifyAR(packet);
|
OnSyncCodesNotifyAR(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_CODES_DATA_AR:
|
case SyncCodeID::ARData:
|
||||||
OnSyncCodesDataAR(packet);
|
OnSyncCodesDataAR(packet);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1643,7 +1619,7 @@ const NetSettings& NetPlayClient::GetNetSettings() const
|
||||||
void NetPlayClient::SendChatMessage(const std::string& msg)
|
void NetPlayClient::SendChatMessage(const std::string& msg)
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_CHAT_MESSAGE);
|
packet << MessageID::ChatMessage;
|
||||||
packet << msg;
|
packet << msg;
|
||||||
|
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
|
@ -1666,7 +1642,7 @@ void NetPlayClient::AddPadStateToPacket(const int in_game_pad, const GCPadStatus
|
||||||
void NetPlayClient::SendWiimoteState(const int in_game_pad, const WiimoteInput& nw)
|
void NetPlayClient::SendWiimoteState(const int in_game_pad, const WiimoteInput& nw)
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_WIIMOTE_DATA);
|
packet << MessageID::WiimoteData;
|
||||||
packet << static_cast<PadIndex>(in_game_pad);
|
packet << static_cast<PadIndex>(in_game_pad);
|
||||||
packet << static_cast<u8>(nw.report_id);
|
packet << static_cast<u8>(nw.report_id);
|
||||||
packet << static_cast<u8>(nw.data.size());
|
packet << static_cast<u8>(nw.data.size());
|
||||||
|
@ -1678,7 +1654,7 @@ void NetPlayClient::SendWiimoteState(const int in_game_pad, const WiimoteInput&
|
||||||
void NetPlayClient::SendStartGamePacket()
|
void NetPlayClient::SendStartGamePacket()
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_START_GAME);
|
packet << MessageID::StartGame;
|
||||||
packet << m_current_game;
|
packet << m_current_game;
|
||||||
|
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
|
@ -1688,7 +1664,7 @@ void NetPlayClient::SendStartGamePacket()
|
||||||
void NetPlayClient::SendStopGamePacket()
|
void NetPlayClient::SendStopGamePacket()
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_STOP_GAME);
|
packet << MessageID::StopGame;
|
||||||
|
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
}
|
}
|
||||||
|
@ -1760,8 +1736,8 @@ void NetPlayClient::SyncSaveDataResponse(const bool success)
|
||||||
if (++m_sync_save_data_success_count >= m_sync_save_data_count)
|
if (++m_sync_save_data_success_count >= m_sync_save_data_count)
|
||||||
{
|
{
|
||||||
sf::Packet response_packet;
|
sf::Packet response_packet;
|
||||||
response_packet << static_cast<MessageId>(NP_MSG_SYNC_SAVE_DATA);
|
response_packet << MessageID::SyncSaveData;
|
||||||
response_packet << static_cast<MessageId>(SYNC_SAVE_DATA_SUCCESS);
|
response_packet << SyncSaveDataID::Success;
|
||||||
|
|
||||||
Send(response_packet);
|
Send(response_packet);
|
||||||
}
|
}
|
||||||
|
@ -1769,8 +1745,8 @@ void NetPlayClient::SyncSaveDataResponse(const bool success)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sf::Packet response_packet;
|
sf::Packet response_packet;
|
||||||
response_packet << static_cast<MessageId>(NP_MSG_SYNC_SAVE_DATA);
|
response_packet << MessageID::SyncSaveData;
|
||||||
response_packet << static_cast<MessageId>(SYNC_SAVE_DATA_FAILURE);
|
response_packet << SyncSaveDataID::Failure;
|
||||||
|
|
||||||
Send(response_packet);
|
Send(response_packet);
|
||||||
}
|
}
|
||||||
|
@ -1784,8 +1760,8 @@ void NetPlayClient::SyncCodeResponse(const bool success)
|
||||||
m_dialog->AppendChat(Common::GetStringT("Error processing codes."));
|
m_dialog->AppendChat(Common::GetStringT("Error processing codes."));
|
||||||
|
|
||||||
sf::Packet response_packet;
|
sf::Packet response_packet;
|
||||||
response_packet << static_cast<MessageId>(NP_MSG_SYNC_CODES);
|
response_packet << MessageID::SyncCodes;
|
||||||
response_packet << static_cast<MessageId>(SYNC_CODES_FAILURE);
|
response_packet << SyncCodeID::Failure;
|
||||||
|
|
||||||
Send(response_packet);
|
Send(response_packet);
|
||||||
return;
|
return;
|
||||||
|
@ -1797,8 +1773,8 @@ void NetPlayClient::SyncCodeResponse(const bool success)
|
||||||
m_dialog->AppendChat(Common::GetStringT("Codes received!"));
|
m_dialog->AppendChat(Common::GetStringT("Codes received!"));
|
||||||
|
|
||||||
sf::Packet response_packet;
|
sf::Packet response_packet;
|
||||||
response_packet << static_cast<MessageId>(NP_MSG_SYNC_CODES);
|
response_packet << MessageID::SyncCodes;
|
||||||
response_packet << static_cast<MessageId>(SYNC_CODES_SUCCESS);
|
response_packet << SyncCodeID::Success;
|
||||||
|
|
||||||
Send(response_packet);
|
Send(response_packet);
|
||||||
}
|
}
|
||||||
|
@ -1960,7 +1936,7 @@ bool NetPlayClient::GetNetPads(const int pad_nb, const bool batching, GCPadStatu
|
||||||
{
|
{
|
||||||
// Tell the server we've acknowledged the message
|
// Tell the server we've acknowledged the message
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GOLF_PREPARE);
|
spac << MessageID::GolfPrepare;
|
||||||
Send(spac);
|
Send(spac);
|
||||||
|
|
||||||
m_wait_on_input_received = false;
|
m_wait_on_input_received = false;
|
||||||
|
@ -1972,7 +1948,7 @@ bool NetPlayClient::GetNetPads(const int pad_nb, const bool batching, GCPadStatu
|
||||||
if (IsFirstInGamePad(pad_nb) && batching)
|
if (IsFirstInGamePad(pad_nb) && batching)
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_PAD_DATA);
|
packet << MessageID::PadData;
|
||||||
|
|
||||||
bool send_packet = false;
|
bool send_packet = false;
|
||||||
const int num_local_pads = NumLocalPads();
|
const int num_local_pads = NumLocalPads();
|
||||||
|
@ -1990,11 +1966,11 @@ bool NetPlayClient::GetNetPads(const int pad_nb, const bool batching, GCPadStatu
|
||||||
|
|
||||||
if (!batching)
|
if (!batching)
|
||||||
{
|
{
|
||||||
int local_pad = InGamePadToLocalPad(pad_nb);
|
const int local_pad = InGamePadToLocalPad(pad_nb);
|
||||||
if (local_pad < 4)
|
if (local_pad < 4)
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_PAD_DATA);
|
packet << MessageID::PadData;
|
||||||
if (PollLocalPad(local_pad, packet))
|
if (PollLocalPad(local_pad, packet))
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
}
|
}
|
||||||
|
@ -2208,7 +2184,7 @@ void NetPlayClient::SendPadHostPoll(const PadIndex pad_num)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_PAD_HOST_DATA);
|
packet << MessageID::PadHostData;
|
||||||
|
|
||||||
if (pad_num < 0)
|
if (pad_num < 0)
|
||||||
{
|
{
|
||||||
|
@ -2309,7 +2285,7 @@ void NetPlayClient::RequestStopGame()
|
||||||
void NetPlayClient::SendPowerButtonEvent()
|
void NetPlayClient::SendPowerButtonEvent()
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_POWER_BUTTON);
|
packet << MessageID::PowerButton;
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2319,7 +2295,7 @@ void NetPlayClient::RequestGolfControl(const PlayerId pid)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_GOLF_REQUEST);
|
packet << MessageID::GolfRequest;
|
||||||
packet << pid;
|
packet << pid;
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
}
|
}
|
||||||
|
@ -2410,7 +2386,7 @@ bool NetPlayClient::IsLocalPlayer(const PlayerId pid) const
|
||||||
void NetPlayClient::SendGameStatus()
|
void NetPlayClient::SendGameStatus()
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_GAME_STATUS);
|
packet << MessageID::GameStatus;
|
||||||
|
|
||||||
SyncIdentifierComparison result;
|
SyncIdentifierComparison result;
|
||||||
m_dialog->FindGameFile(m_selected_game, &result);
|
m_dialog->FindGameFile(m_selected_game, &result);
|
||||||
|
@ -2436,7 +2412,7 @@ void NetPlayClient::SendTimeBase()
|
||||||
const sf::Uint64 timebase = SystemTimers::GetFakeTimeBase();
|
const sf::Uint64 timebase = SystemTimers::GetFakeTimeBase();
|
||||||
|
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_TIMEBASE);
|
packet << MessageID::TimeBase;
|
||||||
packet << timebase;
|
packet << timebase;
|
||||||
packet << netplay_client->m_timebase_frame;
|
packet << netplay_client->m_timebase_frame;
|
||||||
|
|
||||||
|
@ -2472,7 +2448,7 @@ void NetPlayClient::ComputeMD5(const SyncIdentifier& sync_identifier)
|
||||||
if (file.empty() || !File::Exists(file))
|
if (file.empty() || !File::Exists(file))
|
||||||
{
|
{
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_MD5_ERROR);
|
packet << MessageID::MD5Error;
|
||||||
packet << "file not found";
|
packet << "file not found";
|
||||||
Send(packet);
|
Send(packet);
|
||||||
return;
|
return;
|
||||||
|
@ -2483,7 +2459,7 @@ void NetPlayClient::ComputeMD5(const SyncIdentifier& sync_identifier)
|
||||||
m_MD5_thread = std::thread([this, file]() {
|
m_MD5_thread = std::thread([this, file]() {
|
||||||
std::string sum = MD5::MD5Sum(file, [&](int progress) {
|
std::string sum = MD5::MD5Sum(file, [&](int progress) {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_MD5_PROGRESS);
|
packet << MessageID::MD5Progress;
|
||||||
packet << progress;
|
packet << progress;
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
|
|
||||||
|
@ -2491,7 +2467,7 @@ void NetPlayClient::ComputeMD5(const SyncIdentifier& sync_identifier)
|
||||||
});
|
});
|
||||||
|
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << static_cast<MessageId>(NP_MSG_MD5_RESULT);
|
packet << MessageID::MD5Result;
|
||||||
packet << sum;
|
packet << sum;
|
||||||
SendAsync(std::move(packet));
|
SendAsync(std::move(packet));
|
||||||
});
|
});
|
||||||
|
|
|
@ -120,94 +120,96 @@ struct NetTraversalConfig
|
||||||
u16 traversal_port = 0;
|
u16 traversal_port = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
// messages
|
enum class MessageID : u8
|
||||||
enum
|
|
||||||
{
|
{
|
||||||
NP_MSG_PLAYER_JOIN = 0x10,
|
ConnectionSuccessful = 0,
|
||||||
NP_MSG_PLAYER_LEAVE = 0x11,
|
|
||||||
|
|
||||||
NP_MSG_CHAT_MESSAGE = 0x30,
|
PlayerJoin = 0x10,
|
||||||
|
PlayerLeave = 0x11,
|
||||||
|
|
||||||
NP_MSG_CHUNKED_DATA_START = 0x40,
|
ChatMessage = 0x30,
|
||||||
NP_MSG_CHUNKED_DATA_END = 0x41,
|
|
||||||
NP_MSG_CHUNKED_DATA_PAYLOAD = 0x42,
|
|
||||||
NP_MSG_CHUNKED_DATA_PROGRESS = 0x43,
|
|
||||||
NP_MSG_CHUNKED_DATA_COMPLETE = 0x44,
|
|
||||||
NP_MSG_CHUNKED_DATA_ABORT = 0x45,
|
|
||||||
|
|
||||||
NP_MSG_PAD_DATA = 0x60,
|
ChunkedDataStart = 0x40,
|
||||||
NP_MSG_PAD_MAPPING = 0x61,
|
ChunkedDataEnd = 0x41,
|
||||||
NP_MSG_PAD_BUFFER = 0x62,
|
ChunkedDataPayload = 0x42,
|
||||||
NP_MSG_PAD_HOST_DATA = 0x63,
|
ChunkedDataProgress = 0x43,
|
||||||
NP_MSG_GBA_CONFIG = 0x64,
|
ChunkedDataComplete = 0x44,
|
||||||
|
ChunkedDataAbort = 0x45,
|
||||||
|
|
||||||
NP_MSG_WIIMOTE_DATA = 0x70,
|
PadData = 0x60,
|
||||||
NP_MSG_WIIMOTE_MAPPING = 0x71,
|
PadMapping = 0x61,
|
||||||
|
PadBuffer = 0x62,
|
||||||
|
PadHostData = 0x63,
|
||||||
|
GBAConfig = 0x64,
|
||||||
|
|
||||||
NP_MSG_GOLF_REQUEST = 0x90,
|
WiimoteData = 0x70,
|
||||||
NP_MSG_GOLF_SWITCH = 0x91,
|
WiimoteMapping = 0x71,
|
||||||
NP_MSG_GOLF_ACQUIRE = 0x92,
|
|
||||||
NP_MSG_GOLF_RELEASE = 0x93,
|
|
||||||
NP_MSG_GOLF_PREPARE = 0x94,
|
|
||||||
|
|
||||||
NP_MSG_START_GAME = 0xA0,
|
GolfRequest = 0x90,
|
||||||
NP_MSG_CHANGE_GAME = 0xA1,
|
GolfSwitch = 0x91,
|
||||||
NP_MSG_STOP_GAME = 0xA2,
|
GolfAcquire = 0x92,
|
||||||
NP_MSG_DISABLE_GAME = 0xA3,
|
GolfRelease = 0x93,
|
||||||
NP_MSG_GAME_STATUS = 0xA4,
|
GolfPrepare = 0x94,
|
||||||
NP_MSG_CLIENT_CAPABILITIES = 0xA5,
|
|
||||||
NP_MSG_HOST_INPUT_AUTHORITY = 0xA6,
|
|
||||||
NP_MSG_POWER_BUTTON = 0xA7,
|
|
||||||
|
|
||||||
NP_MSG_TIMEBASE = 0xB0,
|
StartGame = 0xA0,
|
||||||
NP_MSG_DESYNC_DETECTED = 0xB1,
|
ChangeGame = 0xA1,
|
||||||
|
StopGame = 0xA2,
|
||||||
|
DisableGame = 0xA3,
|
||||||
|
GameStatus = 0xA4,
|
||||||
|
ClientCapabilities = 0xA5,
|
||||||
|
HostInputAuthority = 0xA6,
|
||||||
|
PowerButton = 0xA7,
|
||||||
|
|
||||||
NP_MSG_COMPUTE_MD5 = 0xC0,
|
TimeBase = 0xB0,
|
||||||
NP_MSG_MD5_PROGRESS = 0xC1,
|
DesyncDetected = 0xB1,
|
||||||
NP_MSG_MD5_RESULT = 0xC2,
|
|
||||||
NP_MSG_MD5_ABORT = 0xC3,
|
|
||||||
NP_MSG_MD5_ERROR = 0xC4,
|
|
||||||
|
|
||||||
NP_MSG_READY = 0xD0,
|
ComputeMD5 = 0xC0,
|
||||||
NP_MSG_NOT_READY = 0xD1,
|
MD5Progress = 0xC1,
|
||||||
|
MD5Result = 0xC2,
|
||||||
|
MD5Abort = 0xC3,
|
||||||
|
MD5Error = 0xC4,
|
||||||
|
|
||||||
NP_MSG_PING = 0xE0,
|
Ready = 0xD0,
|
||||||
NP_MSG_PONG = 0xE1,
|
NotReady = 0xD1,
|
||||||
NP_MSG_PLAYER_PING_DATA = 0xE2,
|
|
||||||
|
|
||||||
NP_MSG_SYNC_GC_SRAM = 0xF0,
|
Ping = 0xE0,
|
||||||
NP_MSG_SYNC_SAVE_DATA = 0xF1,
|
Pong = 0xE1,
|
||||||
NP_MSG_SYNC_CODES = 0xF2,
|
PlayerPingData = 0xE2,
|
||||||
|
|
||||||
|
SyncGCSRAM = 0xF0,
|
||||||
|
SyncSaveData = 0xF1,
|
||||||
|
SyncCodes = 0xF2,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum class ConnectionError : u8
|
||||||
{
|
{
|
||||||
CON_ERR_SERVER_FULL = 1,
|
NoError = 0,
|
||||||
CON_ERR_GAME_RUNNING = 2,
|
ServerFull = 1,
|
||||||
CON_ERR_VERSION_MISMATCH = 3,
|
GameRunning = 2,
|
||||||
CON_ERR_NAME_TOO_LONG = 4
|
VersionMismatch = 3,
|
||||||
|
NameTooLong = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum class SyncSaveDataID : u8
|
||||||
{
|
{
|
||||||
SYNC_SAVE_DATA_NOTIFY = 0,
|
Notify = 0,
|
||||||
SYNC_SAVE_DATA_SUCCESS = 1,
|
Success = 1,
|
||||||
SYNC_SAVE_DATA_FAILURE = 2,
|
Failure = 2,
|
||||||
SYNC_SAVE_DATA_RAW = 3,
|
RawData = 3,
|
||||||
SYNC_SAVE_DATA_GCI = 4,
|
GCIData = 4,
|
||||||
SYNC_SAVE_DATA_WII = 5,
|
WiiData = 5,
|
||||||
SYNC_SAVE_DATA_GBA = 6
|
GBAData = 6
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum class SyncCodeID : u8
|
||||||
{
|
{
|
||||||
SYNC_CODES_NOTIFY = 0,
|
Notify = 0,
|
||||||
SYNC_CODES_NOTIFY_GECKO = 1,
|
NotifyGecko = 1,
|
||||||
SYNC_CODES_NOTIFY_AR = 2,
|
NotifyAR = 2,
|
||||||
SYNC_CODES_DATA_GECKO = 3,
|
GeckoData = 3,
|
||||||
SYNC_CODES_DATA_AR = 4,
|
ARData = 4,
|
||||||
SYNC_CODES_SUCCESS = 5,
|
Success = 5,
|
||||||
SYNC_CODES_FAILURE = 6,
|
Failure = 6,
|
||||||
};
|
};
|
||||||
|
|
||||||
constexpr u32 MAX_NAME_LENGTH = 30;
|
constexpr u32 MAX_NAME_LENGTH = 30;
|
||||||
|
@ -225,7 +227,6 @@ struct WiimoteInput
|
||||||
u8 report_id;
|
u8 report_id;
|
||||||
std::vector<u8> data;
|
std::vector<u8> data;
|
||||||
};
|
};
|
||||||
using MessageId = u8;
|
|
||||||
using PlayerId = u8;
|
using PlayerId = u8;
|
||||||
using FrameNum = u32;
|
using FrameNum = u32;
|
||||||
using PadIndex = s8;
|
using PadIndex = s8;
|
||||||
|
|
|
@ -242,7 +242,7 @@ void NetPlayServer::ThreadFunc()
|
||||||
m_ping_key = Common::Timer::GetTimeMs();
|
m_ping_key = Common::Timer::GetTimeMs();
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_PING;
|
spac << MessageID::Ping;
|
||||||
spac << m_ping_key;
|
spac << m_ping_key;
|
||||||
|
|
||||||
m_ping_timer.Start();
|
m_ping_timer.Start();
|
||||||
|
@ -297,16 +297,16 @@ void NetPlayServer::ThreadFunc()
|
||||||
if (!netEvent.peer->data)
|
if (!netEvent.peer->data)
|
||||||
{
|
{
|
||||||
// uninitialized client, we'll assume this is their initialization packet
|
// uninitialized client, we'll assume this is their initialization packet
|
||||||
unsigned int error;
|
ConnectionError error;
|
||||||
{
|
{
|
||||||
std::lock_guard lkg(m_crit.game);
|
std::lock_guard lkg(m_crit.game);
|
||||||
error = OnConnect(netEvent.peer, rpac);
|
error = OnConnect(netEvent.peer, rpac);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (error)
|
if (error != ConnectionError::NoError)
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(error);
|
spac << error;
|
||||||
// don't need to lock, this client isn't in the client map
|
// don't need to lock, this client isn't in the client map
|
||||||
Send(netEvent.peer, spac);
|
Send(netEvent.peer, spac);
|
||||||
|
|
||||||
|
@ -374,7 +374,7 @@ static void SendSyncIdentifier(sf::Packet& spac, const SyncIdentifier& sync_iden
|
||||||
}
|
}
|
||||||
|
|
||||||
// called from ---NETPLAY--- thread
|
// called from ---NETPLAY--- thread
|
||||||
unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
ConnectionError NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
{
|
{
|
||||||
// give new client first available id
|
// give new client first available id
|
||||||
PlayerId pid = 1;
|
PlayerId pid = 1;
|
||||||
|
@ -392,15 +392,15 @@ unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
rpac >> npver;
|
rpac >> npver;
|
||||||
// Dolphin netplay version
|
// Dolphin netplay version
|
||||||
if (npver != Common::scm_rev_git_str)
|
if (npver != Common::scm_rev_git_str)
|
||||||
return CON_ERR_VERSION_MISMATCH;
|
return ConnectionError::VersionMismatch;
|
||||||
|
|
||||||
// game is currently running or game start is pending
|
// game is currently running or game start is pending
|
||||||
if (m_is_running || m_start_pending)
|
if (m_is_running || m_start_pending)
|
||||||
return CON_ERR_GAME_RUNNING;
|
return ConnectionError::GameRunning;
|
||||||
|
|
||||||
// too many players
|
// too many players
|
||||||
if (m_players.size() >= 255)
|
if (m_players.size() >= 255)
|
||||||
return CON_ERR_SERVER_FULL;
|
return ConnectionError::ServerFull;
|
||||||
|
|
||||||
Client player;
|
Client player;
|
||||||
player.pid = pid;
|
player.pid = pid;
|
||||||
|
@ -410,7 +410,7 @@ unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
rpac >> player.name;
|
rpac >> player.name;
|
||||||
|
|
||||||
if (StringUTF8CodePointCount(player.name) > MAX_NAME_LENGTH)
|
if (StringUTF8CodePointCount(player.name) > MAX_NAME_LENGTH)
|
||||||
return CON_ERR_NAME_TOO_LONG;
|
return ConnectionError::NameTooLong;
|
||||||
|
|
||||||
// cause pings to be updated
|
// cause pings to be updated
|
||||||
m_update_pings = true;
|
m_update_pings = true;
|
||||||
|
@ -427,13 +427,13 @@ unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
|
|
||||||
// send join message to already connected clients
|
// send join message to already connected clients
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_PLAYER_JOIN);
|
spac << MessageID::PlayerJoin;
|
||||||
spac << player.pid << player.name << player.revision;
|
spac << player.pid << player.name << player.revision;
|
||||||
SendToClients(spac);
|
SendToClients(spac);
|
||||||
|
|
||||||
// send new client success message with their id
|
// send new client success message with their ID
|
||||||
spac.clear();
|
spac.clear();
|
||||||
spac << static_cast<MessageId>(0);
|
spac << MessageID::ConnectionSuccessful;
|
||||||
spac << player.pid;
|
spac << player.pid;
|
||||||
Send(player.socket, spac);
|
Send(player.socket, spac);
|
||||||
|
|
||||||
|
@ -441,7 +441,7 @@ unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
if (!m_selected_game_name.empty())
|
if (!m_selected_game_name.empty())
|
||||||
{
|
{
|
||||||
spac.clear();
|
spac.clear();
|
||||||
spac << static_cast<MessageId>(NP_MSG_CHANGE_GAME);
|
spac << MessageID::ChangeGame;
|
||||||
SendSyncIdentifier(spac, m_selected_game_identifier);
|
SendSyncIdentifier(spac, m_selected_game_identifier);
|
||||||
spac << m_selected_game_name;
|
spac << m_selected_game_name;
|
||||||
Send(player.socket, spac);
|
Send(player.socket, spac);
|
||||||
|
@ -451,14 +451,14 @@ unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
{
|
{
|
||||||
// send the pad buffer value
|
// send the pad buffer value
|
||||||
spac.clear();
|
spac.clear();
|
||||||
spac << static_cast<MessageId>(NP_MSG_PAD_BUFFER);
|
spac << MessageID::PadBuffer;
|
||||||
spac << static_cast<u32>(m_target_buffer_size);
|
spac << m_target_buffer_size;
|
||||||
Send(player.socket, spac);
|
Send(player.socket, spac);
|
||||||
}
|
}
|
||||||
|
|
||||||
// send input authority state
|
// send input authority state
|
||||||
spac.clear();
|
spac.clear();
|
||||||
spac << static_cast<MessageId>(NP_MSG_HOST_INPUT_AUTHORITY);
|
spac << MessageID::HostInputAuthority;
|
||||||
spac << m_host_input_authority;
|
spac << m_host_input_authority;
|
||||||
Send(player.socket, spac);
|
Send(player.socket, spac);
|
||||||
|
|
||||||
|
@ -466,13 +466,13 @@ unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
for (const auto& p : m_players)
|
for (const auto& p : m_players)
|
||||||
{
|
{
|
||||||
spac.clear();
|
spac.clear();
|
||||||
spac << static_cast<MessageId>(NP_MSG_PLAYER_JOIN);
|
spac << MessageID::PlayerJoin;
|
||||||
spac << p.second.pid << p.second.name << p.second.revision;
|
spac << p.second.pid << p.second.name << p.second.revision;
|
||||||
Send(player.socket, spac);
|
Send(player.socket, spac);
|
||||||
|
|
||||||
spac.clear();
|
spac.clear();
|
||||||
spac << static_cast<MessageId>(NP_MSG_GAME_STATUS);
|
spac << MessageID::GameStatus;
|
||||||
spac << p.second.pid << static_cast<u32>(p.second.game_status);
|
spac << p.second.pid << p.second.game_status;
|
||||||
Send(player.socket, spac);
|
Send(player.socket, spac);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -488,7 +488,7 @@ unsigned int NetPlayServer::OnConnect(ENetPeer* socket, sf::Packet& rpac)
|
||||||
UpdateWiimoteMapping();
|
UpdateWiimoteMapping();
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return ConnectionError::NoError;
|
||||||
}
|
}
|
||||||
|
|
||||||
// called from ---NETPLAY--- thread
|
// called from ---NETPLAY--- thread
|
||||||
|
@ -506,7 +506,7 @@ unsigned int NetPlayServer::OnDisconnect(const Client& player)
|
||||||
m_is_running = false;
|
m_is_running = false;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_DISABLE_GAME;
|
spac << MessageID::DisableGame;
|
||||||
// this thread doesn't need players lock
|
// this thread doesn't need players lock
|
||||||
SendToClients(spac);
|
SendToClients(spac);
|
||||||
break;
|
break;
|
||||||
|
@ -522,7 +522,7 @@ unsigned int NetPlayServer::OnDisconnect(const Client& player)
|
||||||
}
|
}
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_PLAYER_LEAVE;
|
spac << MessageID::PlayerLeave;
|
||||||
spac << pid;
|
spac << pid;
|
||||||
|
|
||||||
enet_peer_disconnect(player.socket, 0);
|
enet_peer_disconnect(player.socket, 0);
|
||||||
|
@ -612,7 +612,7 @@ void NetPlayServer::SetWiimoteMapping(const PadMappingArray& mappings)
|
||||||
void NetPlayServer::UpdatePadMapping()
|
void NetPlayServer::UpdatePadMapping()
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_PAD_MAPPING;
|
spac << MessageID::PadMapping;
|
||||||
for (PlayerId mapping : m_pad_map)
|
for (PlayerId mapping : m_pad_map)
|
||||||
{
|
{
|
||||||
spac << mapping;
|
spac << mapping;
|
||||||
|
@ -624,7 +624,7 @@ void NetPlayServer::UpdatePadMapping()
|
||||||
void NetPlayServer::UpdateGBAConfig()
|
void NetPlayServer::UpdateGBAConfig()
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GBA_CONFIG);
|
spac << MessageID::GBAConfig;
|
||||||
for (const auto& config : m_gba_config)
|
for (const auto& config : m_gba_config)
|
||||||
{
|
{
|
||||||
spac << config.enabled << config.has_rom << config.title;
|
spac << config.enabled << config.has_rom << config.title;
|
||||||
|
@ -638,7 +638,7 @@ void NetPlayServer::UpdateGBAConfig()
|
||||||
void NetPlayServer::UpdateWiimoteMapping()
|
void NetPlayServer::UpdateWiimoteMapping()
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_WIIMOTE_MAPPING;
|
spac << MessageID::WiimoteMapping;
|
||||||
for (PlayerId mapping : m_wiimote_map)
|
for (PlayerId mapping : m_wiimote_map)
|
||||||
{
|
{
|
||||||
spac << mapping;
|
spac << mapping;
|
||||||
|
@ -658,8 +658,8 @@ void NetPlayServer::AdjustPadBufferSize(unsigned int size)
|
||||||
{
|
{
|
||||||
// tell clients to change buffer size
|
// tell clients to change buffer size
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_PAD_BUFFER);
|
spac << MessageID::PadBuffer;
|
||||||
spac << static_cast<u32>(m_target_buffer_size);
|
spac << m_target_buffer_size;
|
||||||
|
|
||||||
SendAsyncToClients(std::move(spac));
|
SendAsyncToClients(std::move(spac));
|
||||||
}
|
}
|
||||||
|
@ -673,7 +673,7 @@ void NetPlayServer::SetHostInputAuthority(const bool enable)
|
||||||
|
|
||||||
// tell clients about the new value
|
// tell clients about the new value
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_HOST_INPUT_AUTHORITY);
|
spac << MessageID::HostInputAuthority;
|
||||||
spac << m_host_input_authority;
|
spac << m_host_input_authority;
|
||||||
|
|
||||||
SendAsyncToClients(std::move(spac));
|
SendAsyncToClients(std::move(spac));
|
||||||
|
@ -727,7 +727,7 @@ void NetPlayServer::SendChunkedToClients(sf::Packet&& packet, const PlayerId ski
|
||||||
// called from ---NETPLAY--- thread
|
// called from ---NETPLAY--- thread
|
||||||
unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
{
|
{
|
||||||
MessageId mid;
|
MessageID mid;
|
||||||
packet >> mid;
|
packet >> mid;
|
||||||
|
|
||||||
INFO_LOG_FMT(NETPLAY, "Got client message: {:x}", mid);
|
INFO_LOG_FMT(NETPLAY, "Got client message: {:x}", mid);
|
||||||
|
@ -737,14 +737,14 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
|
|
||||||
switch (mid)
|
switch (mid)
|
||||||
{
|
{
|
||||||
case NP_MSG_CHAT_MESSAGE:
|
case MessageID::ChatMessage:
|
||||||
{
|
{
|
||||||
std::string msg;
|
std::string msg;
|
||||||
packet >> msg;
|
packet >> msg;
|
||||||
|
|
||||||
// send msg to other clients
|
// send msg to other clients
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_CHAT_MESSAGE;
|
spac << MessageID::ChatMessage;
|
||||||
spac << player.pid;
|
spac << player.pid;
|
||||||
spac << msg;
|
spac << msg;
|
||||||
|
|
||||||
|
@ -752,7 +752,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHUNKED_DATA_PROGRESS:
|
case MessageID::ChunkedDataProgress:
|
||||||
{
|
{
|
||||||
u32 cid;
|
u32 cid;
|
||||||
packet >> cid;
|
packet >> cid;
|
||||||
|
@ -762,7 +762,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CHUNKED_DATA_COMPLETE:
|
case MessageID::ChunkedDataComplete:
|
||||||
{
|
{
|
||||||
u32 cid;
|
u32 cid;
|
||||||
packet >> cid;
|
packet >> cid;
|
||||||
|
@ -775,14 +775,14 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PAD_DATA:
|
case MessageID::PadData:
|
||||||
{
|
{
|
||||||
// if this is pad data from the last game still being received, ignore it
|
// if this is pad data from the last game still being received, ignore it
|
||||||
if (player.current_game != m_current_game)
|
if (player.current_game != m_current_game)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(m_host_input_authority ? NP_MSG_PAD_HOST_DATA : NP_MSG_PAD_DATA);
|
spac << (m_host_input_authority ? MessageID::PadHostData : MessageID::PadData);
|
||||||
|
|
||||||
while (!packet.endOfPacket())
|
while (!packet.endOfPacket())
|
||||||
{
|
{
|
||||||
|
@ -822,14 +822,14 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PAD_HOST_DATA:
|
case MessageID::PadHostData:
|
||||||
{
|
{
|
||||||
// Kick player if they're not the golfer.
|
// Kick player if they're not the golfer.
|
||||||
if (m_current_golfer != 0 && player.pid != m_current_golfer)
|
if (m_current_golfer != 0 && player.pid != m_current_golfer)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_PAD_DATA);
|
spac << MessageID::PadData;
|
||||||
|
|
||||||
while (!packet.endOfPacket())
|
while (!packet.endOfPacket())
|
||||||
{
|
{
|
||||||
|
@ -853,7 +853,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_WIIMOTE_DATA:
|
case MessageID::WiimoteData:
|
||||||
{
|
{
|
||||||
// if this is Wiimote data from the last game still being received, ignore it
|
// if this is Wiimote data from the last game still being received, ignore it
|
||||||
if (player.current_game != m_current_game)
|
if (player.current_game != m_current_game)
|
||||||
|
@ -875,7 +875,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
|
|
||||||
// relay to clients
|
// relay to clients
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_WIIMOTE_DATA;
|
spac << MessageID::WiimoteData;
|
||||||
spac << map;
|
spac << map;
|
||||||
spac << size;
|
spac << size;
|
||||||
for (const u8& byte : data)
|
for (const u8& byte : data)
|
||||||
|
@ -885,7 +885,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GOLF_REQUEST:
|
case MessageID::GolfRequest:
|
||||||
{
|
{
|
||||||
PlayerId pid;
|
PlayerId pid;
|
||||||
packet >> pid;
|
packet >> pid;
|
||||||
|
@ -900,25 +900,25 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
m_pending_golfer = pid;
|
m_pending_golfer = pid;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GOLF_PREPARE);
|
spac << MessageID::GolfPrepare;
|
||||||
Send(m_players[pid].socket, spac);
|
Send(m_players[pid].socket, spac);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GOLF_RELEASE:
|
case MessageID::GolfRelease:
|
||||||
{
|
{
|
||||||
if (m_pending_golfer == 0)
|
if (m_pending_golfer == 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GOLF_SWITCH);
|
spac << MessageID::GolfSwitch;
|
||||||
spac << static_cast<PlayerId>(m_pending_golfer);
|
spac << m_pending_golfer;
|
||||||
SendToClients(spac);
|
SendToClients(spac);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GOLF_ACQUIRE:
|
case MessageID::GolfAcquire:
|
||||||
{
|
{
|
||||||
if (m_pending_golfer == 0)
|
if (m_pending_golfer == 0)
|
||||||
break;
|
break;
|
||||||
|
@ -928,7 +928,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GOLF_PREPARE:
|
case MessageID::GolfPrepare:
|
||||||
{
|
{
|
||||||
if (m_pending_golfer == 0)
|
if (m_pending_golfer == 0)
|
||||||
break;
|
break;
|
||||||
|
@ -936,13 +936,13 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
m_current_golfer = 0;
|
m_current_golfer = 0;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GOLF_SWITCH);
|
spac << MessageID::GolfSwitch;
|
||||||
spac << static_cast<PlayerId>(0);
|
spac << PlayerId{0};
|
||||||
SendToClients(spac);
|
SendToClients(spac);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_PONG:
|
case MessageID::Pong:
|
||||||
{
|
{
|
||||||
const u32 ping = (u32)m_ping_timer.GetTimeElapsed();
|
const u32 ping = (u32)m_ping_timer.GetTimeElapsed();
|
||||||
u32 ping_key = 0;
|
u32 ping_key = 0;
|
||||||
|
@ -954,7 +954,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_PLAYER_PING_DATA;
|
spac << MessageID::PlayerPingData;
|
||||||
spac << player.pid;
|
spac << player.pid;
|
||||||
spac << player.ping;
|
spac << player.ping;
|
||||||
|
|
||||||
|
@ -962,13 +962,13 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_START_GAME:
|
case MessageID::StartGame:
|
||||||
{
|
{
|
||||||
packet >> player.current_game;
|
packet >> player.current_game;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_STOP_GAME:
|
case MessageID::StopGame:
|
||||||
{
|
{
|
||||||
if (!m_is_running)
|
if (!m_is_running)
|
||||||
break;
|
break;
|
||||||
|
@ -977,23 +977,23 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
|
|
||||||
// tell clients to stop game
|
// tell clients to stop game
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_STOP_GAME;
|
spac << MessageID::StopGame;
|
||||||
|
|
||||||
std::lock_guard lkp(m_crit.players);
|
std::lock_guard lkp(m_crit.players);
|
||||||
SendToClients(spac);
|
SendToClients(spac);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_GAME_STATUS:
|
case MessageID::GameStatus:
|
||||||
{
|
{
|
||||||
u32 status;
|
SyncIdentifierComparison status;
|
||||||
packet >> status;
|
packet >> status;
|
||||||
|
|
||||||
m_players[player.pid].game_status = static_cast<SyncIdentifierComparison>(status);
|
m_players[player.pid].game_status = status;
|
||||||
|
|
||||||
// send msg to other clients
|
// send msg to other clients
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_GAME_STATUS);
|
spac << MessageID::GameStatus;
|
||||||
spac << player.pid;
|
spac << player.pid;
|
||||||
spac << status;
|
spac << status;
|
||||||
|
|
||||||
|
@ -1001,22 +1001,22 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_CLIENT_CAPABILITIES:
|
case MessageID::ClientCapabilities:
|
||||||
{
|
{
|
||||||
packet >> m_players[player.pid].has_ipl_dump;
|
packet >> m_players[player.pid].has_ipl_dump;
|
||||||
packet >> m_players[player.pid].has_hardware_fma;
|
packet >> m_players[player.pid].has_hardware_fma;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_POWER_BUTTON:
|
case MessageID::PowerButton:
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_POWER_BUTTON);
|
spac << MessageID::PowerButton;
|
||||||
SendToClients(spac, player.pid);
|
SendToClients(spac, player.pid);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_TIMEBASE:
|
case MessageID::TimeBase:
|
||||||
{
|
{
|
||||||
u64 timebase = Common::PacketReadU64(packet);
|
u64 timebase = Common::PacketReadU64(packet);
|
||||||
u32 frame;
|
u32 frame;
|
||||||
|
@ -1049,7 +1049,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << (MessageId)NP_MSG_DESYNC_DETECTED;
|
spac << MessageID::DesyncDetected;
|
||||||
spac << pid_to_blame;
|
spac << pid_to_blame;
|
||||||
spac << frame;
|
spac << frame;
|
||||||
SendToClients(spac);
|
SendToClients(spac);
|
||||||
|
@ -1061,13 +1061,13 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_MD5_PROGRESS:
|
case MessageID::MD5Progress:
|
||||||
{
|
{
|
||||||
int progress;
|
int progress;
|
||||||
packet >> progress;
|
packet >> progress;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_MD5_PROGRESS);
|
spac << MessageID::MD5Progress;
|
||||||
spac << player.pid;
|
spac << player.pid;
|
||||||
spac << progress;
|
spac << progress;
|
||||||
|
|
||||||
|
@ -1075,13 +1075,13 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_MD5_RESULT:
|
case MessageID::MD5Result:
|
||||||
{
|
{
|
||||||
std::string result;
|
std::string result;
|
||||||
packet >> result;
|
packet >> result;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_MD5_RESULT);
|
spac << MessageID::MD5Result;
|
||||||
spac << player.pid;
|
spac << player.pid;
|
||||||
spac << result;
|
spac << result;
|
||||||
|
|
||||||
|
@ -1089,13 +1089,13 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_MD5_ERROR:
|
case MessageID::MD5Error:
|
||||||
{
|
{
|
||||||
std::string error;
|
std::string error;
|
||||||
packet >> error;
|
packet >> error;
|
||||||
|
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_MD5_ERROR);
|
spac << MessageID::MD5Error;
|
||||||
spac << player.pid;
|
spac << player.pid;
|
||||||
spac << error;
|
spac << error;
|
||||||
|
|
||||||
|
@ -1103,14 +1103,14 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_SYNC_SAVE_DATA:
|
case MessageID::SyncSaveData:
|
||||||
{
|
{
|
||||||
MessageId sub_id;
|
SyncSaveDataID sub_id;
|
||||||
packet >> sub_id;
|
packet >> sub_id;
|
||||||
|
|
||||||
switch (sub_id)
|
switch (sub_id)
|
||||||
{
|
{
|
||||||
case SYNC_SAVE_DATA_SUCCESS:
|
case SyncSaveDataID::Success:
|
||||||
{
|
{
|
||||||
if (m_start_pending)
|
if (m_start_pending)
|
||||||
{
|
{
|
||||||
|
@ -1127,7 +1127,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_SAVE_DATA_FAILURE:
|
case SyncSaveDataID::Failure:
|
||||||
{
|
{
|
||||||
m_dialog->AppendChat(Common::FmtFormatT("{0} failed to synchronize.", player.name));
|
m_dialog->AppendChat(Common::FmtFormatT("{0} failed to synchronize.", player.name));
|
||||||
m_dialog->OnGameStartAborted();
|
m_dialog->OnGameStartAborted();
|
||||||
|
@ -1145,16 +1145,16 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NP_MSG_SYNC_CODES:
|
case MessageID::SyncCodes:
|
||||||
{
|
{
|
||||||
// Receive Status of Code Sync
|
// Receive Status of Code Sync
|
||||||
MessageId sub_id;
|
SyncCodeID sub_id;
|
||||||
packet >> sub_id;
|
packet >> sub_id;
|
||||||
|
|
||||||
// Check If Code Sync was successful or not
|
// Check If Code Sync was successful or not
|
||||||
switch (sub_id)
|
switch (sub_id)
|
||||||
{
|
{
|
||||||
case SYNC_CODES_SUCCESS:
|
case SyncCodeID::Success:
|
||||||
{
|
{
|
||||||
if (m_start_pending)
|
if (m_start_pending)
|
||||||
{
|
{
|
||||||
|
@ -1170,7 +1170,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SYNC_CODES_FAILURE:
|
case SyncCodeID::Failure:
|
||||||
{
|
{
|
||||||
m_dialog->AppendChat(Common::FmtFormatT("{0} failed to synchronize codes.", player.name));
|
m_dialog->AppendChat(Common::FmtFormatT("{0} failed to synchronize codes.", player.name));
|
||||||
m_dialog->OnGameStartAborted();
|
m_dialog->OnGameStartAborted();
|
||||||
|
@ -1217,8 +1217,8 @@ void NetPlayServer::OnTraversalStateChanged()
|
||||||
void NetPlayServer::SendChatMessage(const std::string& msg)
|
void NetPlayServer::SendChatMessage(const std::string& msg)
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_CHAT_MESSAGE);
|
spac << MessageID::ChatMessage;
|
||||||
spac << static_cast<PlayerId>(0); // server id always 0
|
spac << PlayerId{0}; // server ID always 0
|
||||||
spac << msg;
|
spac << msg;
|
||||||
|
|
||||||
SendAsyncToClients(std::move(spac));
|
SendAsyncToClients(std::move(spac));
|
||||||
|
@ -1235,7 +1235,7 @@ bool NetPlayServer::ChangeGame(const SyncIdentifier& sync_identifier,
|
||||||
|
|
||||||
// send changed game to clients
|
// send changed game to clients
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_CHANGE_GAME);
|
spac << MessageID::ChangeGame;
|
||||||
SendSyncIdentifier(spac, m_selected_game_identifier);
|
SendSyncIdentifier(spac, m_selected_game_identifier);
|
||||||
spac << m_selected_game_name;
|
spac << m_selected_game_name;
|
||||||
|
|
||||||
|
@ -1248,7 +1248,7 @@ bool NetPlayServer::ChangeGame(const SyncIdentifier& sync_identifier,
|
||||||
bool NetPlayServer::ComputeMD5(const SyncIdentifier& sync_identifier)
|
bool NetPlayServer::ComputeMD5(const SyncIdentifier& sync_identifier)
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_COMPUTE_MD5);
|
spac << MessageID::ComputeMD5;
|
||||||
SendSyncIdentifier(spac, sync_identifier);
|
SendSyncIdentifier(spac, sync_identifier);
|
||||||
|
|
||||||
SendAsyncToClients(std::move(spac));
|
SendAsyncToClients(std::move(spac));
|
||||||
|
@ -1260,10 +1260,9 @@ bool NetPlayServer::ComputeMD5(const SyncIdentifier& sync_identifier)
|
||||||
bool NetPlayServer::AbortMD5()
|
bool NetPlayServer::AbortMD5()
|
||||||
{
|
{
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_MD5_ABORT);
|
spac << MessageID::MD5Abort;
|
||||||
|
|
||||||
SendAsyncToClients(std::move(spac));
|
SendAsyncToClients(std::move(spac));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1462,7 +1461,7 @@ bool NetPlayServer::StartGame()
|
||||||
g_SRAM_netplay_initialized = true;
|
g_SRAM_netplay_initialized = true;
|
||||||
}
|
}
|
||||||
sf::Packet srampac;
|
sf::Packet srampac;
|
||||||
srampac << static_cast<MessageId>(NP_MSG_SYNC_GC_SRAM);
|
srampac << MessageID::SyncGCSRAM;
|
||||||
for (size_t i = 0; i < sizeof(g_SRAM) - offsetof(Sram, settings); ++i)
|
for (size_t i = 0; i < sizeof(g_SRAM) - offsetof(Sram, settings); ++i)
|
||||||
{
|
{
|
||||||
srampac << g_SRAM[offsetof(Sram, settings) + i];
|
srampac << g_SRAM[offsetof(Sram, settings) + i];
|
||||||
|
@ -1471,10 +1470,10 @@ bool NetPlayServer::StartGame()
|
||||||
|
|
||||||
// tell clients to start game
|
// tell clients to start game
|
||||||
sf::Packet spac;
|
sf::Packet spac;
|
||||||
spac << static_cast<MessageId>(NP_MSG_START_GAME);
|
spac << MessageID::StartGame;
|
||||||
spac << m_current_game;
|
spac << m_current_game;
|
||||||
spac << m_settings.m_CPUthread;
|
spac << m_settings.m_CPUthread;
|
||||||
spac << static_cast<std::underlying_type_t<PowerPC::CPUCore>>(m_settings.m_CPUcore);
|
spac << m_settings.m_CPUcore;
|
||||||
spac << m_settings.m_EnableCheats;
|
spac << m_settings.m_EnableCheats;
|
||||||
spac << m_settings.m_SelectedLanguage;
|
spac << m_settings.m_SelectedLanguage;
|
||||||
spac << m_settings.m_OverrideRegionSettings;
|
spac << m_settings.m_OverrideRegionSettings;
|
||||||
|
@ -1484,7 +1483,7 @@ bool NetPlayServer::StartGame()
|
||||||
spac << m_settings.m_RAMOverrideEnable;
|
spac << m_settings.m_RAMOverrideEnable;
|
||||||
spac << m_settings.m_Mem1Size;
|
spac << m_settings.m_Mem1Size;
|
||||||
spac << m_settings.m_Mem2Size;
|
spac << m_settings.m_Mem2Size;
|
||||||
spac << static_cast<std::underlying_type_t<DiscIO::Region>>(m_settings.m_FallbackRegion);
|
spac << m_settings.m_FallbackRegion;
|
||||||
spac << m_settings.m_AllowSDWrites;
|
spac << m_settings.m_AllowSDWrites;
|
||||||
spac << m_settings.m_CopyWiiSave;
|
spac << m_settings.m_CopyWiiSave;
|
||||||
spac << m_settings.m_OCEnable;
|
spac << m_settings.m_OCEnable;
|
||||||
|
@ -1620,8 +1619,8 @@ bool NetPlayServer::SyncSaveData()
|
||||||
|
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_SAVE_DATA);
|
pac << MessageID::SyncSaveData;
|
||||||
pac << static_cast<MessageId>(SYNC_SAVE_DATA_NOTIFY);
|
pac << SyncSaveDataID::Notify;
|
||||||
pac << save_count;
|
pac << save_count;
|
||||||
|
|
||||||
// send this on the chunked data channel to ensure it's sequenced properly
|
// send this on the chunked data channel to ensure it's sequenced properly
|
||||||
|
@ -1657,8 +1656,8 @@ bool NetPlayServer::SyncSaveData()
|
||||||
}
|
}
|
||||||
|
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_SAVE_DATA);
|
pac << MessageID::SyncSaveData;
|
||||||
pac << static_cast<MessageId>(SYNC_SAVE_DATA_RAW);
|
pac << SyncSaveDataID::RawData;
|
||||||
pac << is_slot_a << region << size_override;
|
pac << is_slot_a << region << size_override;
|
||||||
|
|
||||||
if (File::Exists(path))
|
if (File::Exists(path))
|
||||||
|
@ -1682,8 +1681,8 @@ bool NetPlayServer::SyncSaveData()
|
||||||
fmt::format("Card {}", is_slot_a ? 'A' : 'B');
|
fmt::format("Card {}", is_slot_a ? 'A' : 'B');
|
||||||
|
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_SAVE_DATA);
|
pac << MessageID::SyncSaveData;
|
||||||
pac << static_cast<MessageId>(SYNC_SAVE_DATA_GCI);
|
pac << SyncSaveDataID::GCIData;
|
||||||
pac << is_slot_a;
|
pac << is_slot_a;
|
||||||
|
|
||||||
if (File::IsDirectory(path))
|
if (File::IsDirectory(path))
|
||||||
|
@ -1734,8 +1733,8 @@ bool NetPlayServer::SyncSaveData()
|
||||||
std::vector<u64> titles;
|
std::vector<u64> titles;
|
||||||
|
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_SAVE_DATA);
|
pac << MessageID::SyncSaveData;
|
||||||
pac << static_cast<MessageId>(SYNC_SAVE_DATA_WII);
|
pac << SyncSaveDataID::WiiData;
|
||||||
|
|
||||||
// Shove the Mii data into the start the packet
|
// Shove the Mii data into the start the packet
|
||||||
{
|
{
|
||||||
|
@ -1798,7 +1797,7 @@ bool NetPlayServer::SyncSaveData()
|
||||||
// Files
|
// Files
|
||||||
for (const WiiSave::Storage::SaveFile& file : *files)
|
for (const WiiSave::Storage::SaveFile& file : *files)
|
||||||
{
|
{
|
||||||
pac << file.mode << file.attributes << static_cast<u8>(file.type) << file.path;
|
pac << file.mode << file.attributes << file.type << file.path;
|
||||||
|
|
||||||
if (file.type == WiiSave::Storage::SaveFile::Type::File)
|
if (file.type == WiiSave::Storage::SaveFile::Type::File)
|
||||||
{
|
{
|
||||||
|
@ -1825,8 +1824,8 @@ bool NetPlayServer::SyncSaveData()
|
||||||
if (m_gba_config[i].enabled && m_gba_config[i].has_rom)
|
if (m_gba_config[i].enabled && m_gba_config[i].has_rom)
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_SAVE_DATA);
|
pac << MessageID::SyncSaveData;
|
||||||
pac << static_cast<MessageId>(SYNC_SAVE_DATA_GBA);
|
pac << SyncSaveDataID::GBAData;
|
||||||
pac << static_cast<u8>(i);
|
pac << static_cast<u8>(i);
|
||||||
|
|
||||||
std::string path;
|
std::string path;
|
||||||
|
@ -1882,8 +1881,8 @@ bool NetPlayServer::SyncCodes()
|
||||||
// Notify Clients of Incoming Code Sync
|
// Notify Clients of Incoming Code Sync
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_CODES);
|
pac << MessageID::SyncCodes;
|
||||||
pac << static_cast<MessageId>(SYNC_CODES_NOTIFY);
|
pac << SyncCodeID::Notify;
|
||||||
SendAsyncToClients(std::move(pac));
|
SendAsyncToClients(std::move(pac));
|
||||||
}
|
}
|
||||||
// Sync Gecko Codes
|
// Sync Gecko Codes
|
||||||
|
@ -1910,8 +1909,8 @@ bool NetPlayServer::SyncCodes()
|
||||||
// Send initial packet. Notify of the sync operation and total number of lines being sent.
|
// Send initial packet. Notify of the sync operation and total number of lines being sent.
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_CODES);
|
pac << MessageID::SyncCodes;
|
||||||
pac << static_cast<MessageId>(SYNC_CODES_NOTIFY_GECKO);
|
pac << SyncCodeID::NotifyGecko;
|
||||||
pac << codelines;
|
pac << codelines;
|
||||||
SendAsyncToClients(std::move(pac));
|
SendAsyncToClients(std::move(pac));
|
||||||
}
|
}
|
||||||
|
@ -1919,8 +1918,8 @@ bool NetPlayServer::SyncCodes()
|
||||||
// Send entire codeset in the second packet
|
// Send entire codeset in the second packet
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_CODES);
|
pac << MessageID::SyncCodes;
|
||||||
pac << static_cast<MessageId>(SYNC_CODES_DATA_GECKO);
|
pac << SyncCodeID::GeckoData;
|
||||||
// Iterate through the active code vector and send each codeline
|
// Iterate through the active code vector and send each codeline
|
||||||
for (const Gecko::GeckoCode& active_code : s_active_codes)
|
for (const Gecko::GeckoCode& active_code : s_active_codes)
|
||||||
{
|
{
|
||||||
|
@ -1960,8 +1959,8 @@ bool NetPlayServer::SyncCodes()
|
||||||
// Send initial packet. Notify of the sync operation and total number of lines being sent.
|
// Send initial packet. Notify of the sync operation and total number of lines being sent.
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_CODES);
|
pac << MessageID::SyncCodes;
|
||||||
pac << static_cast<MessageId>(SYNC_CODES_NOTIFY_AR);
|
pac << SyncCodeID::NotifyAR;
|
||||||
pac << codelines;
|
pac << codelines;
|
||||||
SendAsyncToClients(std::move(pac));
|
SendAsyncToClients(std::move(pac));
|
||||||
}
|
}
|
||||||
|
@ -1969,8 +1968,8 @@ bool NetPlayServer::SyncCodes()
|
||||||
// Send entire codeset in the second packet
|
// Send entire codeset in the second packet
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_SYNC_CODES);
|
pac << MessageID::SyncCodes;
|
||||||
pac << static_cast<MessageId>(SYNC_CODES_DATA_AR);
|
pac << SyncCodeID::ARData;
|
||||||
// Iterate through the active code vector and send each codeline
|
// Iterate through the active code vector and send each codeline
|
||||||
for (const ActionReplay::ARCode& active_code : s_active_codes)
|
for (const ActionReplay::ARCode& active_code : s_active_codes)
|
||||||
{
|
{
|
||||||
|
@ -2160,7 +2159,7 @@ void NetPlayServer::ChunkedDataThreadFunc()
|
||||||
player_count = players.size();
|
player_count = players.size();
|
||||||
|
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_CHUNKED_DATA_START);
|
pac << MessageID::ChunkedDataStart;
|
||||||
pac << id << e.title << sf::Uint64{e.packet.getDataSize()};
|
pac << id << e.title << sf::Uint64{e.packet.getDataSize()};
|
||||||
|
|
||||||
ChunkedDataSend(std::move(pac), e.target_pid, e.target_mode);
|
ChunkedDataSend(std::move(pac), e.target_pid, e.target_mode);
|
||||||
|
@ -2182,7 +2181,7 @@ void NetPlayServer::ChunkedDataThreadFunc()
|
||||||
if (m_abort_chunked_data)
|
if (m_abort_chunked_data)
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_CHUNKED_DATA_ABORT);
|
pac << MessageID::ChunkedDataAbort;
|
||||||
pac << id;
|
pac << id;
|
||||||
ChunkedDataSend(std::move(pac), e.target_pid, e.target_mode);
|
ChunkedDataSend(std::move(pac), e.target_pid, e.target_mode);
|
||||||
break;
|
break;
|
||||||
|
@ -2199,7 +2198,7 @@ void NetPlayServer::ChunkedDataThreadFunc()
|
||||||
auto start = std::chrono::steady_clock::now();
|
auto start = std::chrono::steady_clock::now();
|
||||||
|
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_CHUNKED_DATA_PAYLOAD);
|
pac << MessageID::ChunkedDataPayload;
|
||||||
pac << id;
|
pac << id;
|
||||||
size_t len = std::min(CHUNKED_DATA_UNIT_SIZE, e.packet.getDataSize() - index);
|
size_t len = std::min(CHUNKED_DATA_UNIT_SIZE, e.packet.getDataSize() - index);
|
||||||
pac.append(static_cast<const u8*>(e.packet.getData()) + index, len);
|
pac.append(static_cast<const u8*>(e.packet.getData()) + index, len);
|
||||||
|
@ -2217,7 +2216,7 @@ void NetPlayServer::ChunkedDataThreadFunc()
|
||||||
if (!m_abort_chunked_data)
|
if (!m_abort_chunked_data)
|
||||||
{
|
{
|
||||||
sf::Packet pac;
|
sf::Packet pac;
|
||||||
pac << static_cast<MessageId>(NP_MSG_CHUNKED_DATA_END);
|
pac << MessageID::ChunkedDataEnd;
|
||||||
pac << id;
|
pac << id;
|
||||||
ChunkedDataSend(std::move(pac), e.target_pid, e.target_mode);
|
ChunkedDataSend(std::move(pac), e.target_pid, e.target_mode);
|
||||||
}
|
}
|
||||||
|
|
|
@ -129,7 +129,7 @@ private:
|
||||||
void SendToClients(const sf::Packet& packet, PlayerId skip_pid = 0,
|
void SendToClients(const sf::Packet& packet, PlayerId skip_pid = 0,
|
||||||
u8 channel_id = DEFAULT_CHANNEL);
|
u8 channel_id = DEFAULT_CHANNEL);
|
||||||
void Send(ENetPeer* socket, const sf::Packet& packet, u8 channel_id = DEFAULT_CHANNEL);
|
void Send(ENetPeer* socket, const sf::Packet& packet, u8 channel_id = DEFAULT_CHANNEL);
|
||||||
unsigned int OnConnect(ENetPeer* socket, sf::Packet& rpac);
|
ConnectionError OnConnect(ENetPeer* socket, sf::Packet& rpac);
|
||||||
unsigned int OnDisconnect(const Client& player);
|
unsigned int OnDisconnect(const Client& player);
|
||||||
unsigned int OnData(sf::Packet& packet, Client& player);
|
unsigned int OnData(sf::Packet& packet, Client& player);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue