citra/src/core/rpc/server.cpp
FearlessTobi da908a9ed1 core: Remove unnecessary enum casts in log calls
Follows the video core PR. fmt doesn't require casts for enum classes
anymore, so we can remove quite a few casts.

Co-Authored-By: LC <712067+lioncash@users.noreply.github.com>
2020-12-29 06:39:21 +01:00

43 lines
1.2 KiB
C++

#include <functional>
#include "core/core.h"
#include "core/rpc/packet.h"
#include "core/rpc/rpc_server.h"
#include "core/rpc/server.h"
#include "core/rpc/udp_server.h"
namespace RPC {
Server::Server(RPCServer& rpc_server) : rpc_server(rpc_server) {}
Server::~Server() = default;
void Server::Start() {
const auto callback = [this](std::unique_ptr<Packet> new_request) {
NewRequestCallback(std::move(new_request));
};
try {
udp_server = std::make_unique<UDPServer>(callback);
} catch (...) {
LOG_ERROR(RPC_Server, "Error starting UDP server");
}
}
void Server::Stop() {
udp_server.reset();
NewRequestCallback(nullptr); // Notify the RPC server to end
}
void Server::NewRequestCallback(std::unique_ptr<RPC::Packet> new_request) {
if (new_request) {
LOG_INFO(RPC_Server, "Received request version={} id={} type={} size={}",
new_request->GetVersion(), new_request->GetId(), new_request->GetPacketType(),
new_request->GetPacketDataSize());
} else {
LOG_INFO(RPC_Server, "Received end packet");
}
rpc_server.QueueRequest(std::move(new_request));
}
}; // namespace RPC