Made discord/socket use the right format types on Linux vs Windows

This commit is contained in:
MysterD 2022-01-28 00:15:06 -08:00
parent f0ad3dd7d0
commit 4c4b2b826c
7 changed files with 21 additions and 16 deletions

View file

@ -15,7 +15,7 @@ static void on_activity_update_callback(UNUSED void* data, enum EDiscordResult r
} }
static void on_activity_join_callback(UNUSED void* data, enum EDiscordResult result, struct DiscordLobby* lobby) { static void on_activity_join_callback(UNUSED void* data, enum EDiscordResult result, struct DiscordLobby* lobby) {
LOGFILE_INFO(LFT_DISCORD, "> on_activity_join_callback returned %d, lobby %ld, owner %ld", result, lobby->id, lobby->owner_id); LOGFILE_INFO(LFT_DISCORD, "> on_activity_join_callback returned %d, lobby " DISCORD_ID_FORMAT ", owner " DISCORD_ID_FORMAT, result, lobby->id, lobby->owner_id);
DISCORD_REQUIRE(result); DISCORD_REQUIRE(result);
if (gNetworkType != NT_NONE) { if (gNetworkType != NT_NONE) {
LOGFILE_ERROR(LFT_DISCORD, "Joined lobby when already connected somewhere!"); LOGFILE_ERROR(LFT_DISCORD, "Joined lobby when already connected somewhere!");
@ -25,7 +25,7 @@ static void on_activity_join_callback(UNUSED void* data, enum EDiscordResult res
network_init(NT_CLIENT); network_init(NT_CLIENT);
gCurActivity.type = DiscordActivityType_Playing; gCurActivity.type = DiscordActivityType_Playing;
snprintf(gCurActivity.party.id, 128, "%ld", lobby->id); snprintf(gCurActivity.party.id, 128, DISCORD_ID_FORMAT, lobby->id);
gCurActivity.party.size.current_size = 2; gCurActivity.party.size.current_size = 2;
gCurActivity.party.size.max_size = lobby->capacity; gCurActivity.party.size.max_size = lobby->capacity;
@ -57,7 +57,7 @@ static void on_activity_join_request_callback(UNUSED void* data, enum EDiscordRe
} }
static void on_activity_join_request(UNUSED void* data, struct DiscordUser* user) { static void on_activity_join_request(UNUSED void* data, struct DiscordUser* user) {
LOGFILE_INFO(LFT_DISCORD, "> on_activity_join_request from %ld", user->id); LOGFILE_INFO(LFT_DISCORD, "> on_activity_join_request from " DISCORD_ID_FORMAT, user->id);
//app.activities->send_request_reply(app.activities, user->id, DiscordActivityJoinRequestReply_Yes, NULL, on_activity_join_request_callback); //app.activities->send_request_reply(app.activities, user->id, DiscordActivityJoinRequestReply_Yes, NULL, on_activity_join_request_callback);
} }

View file

@ -7,8 +7,10 @@
#include "discord_game_sdk.h" #include "discord_game_sdk.h"
#pragma pack(pop) #pragma pack(pop)
#ifdef _WIN32 #ifdef _WIN32
#define DISCORD_ID_FORMAT "%lld"
#include <Windows.h> #include <Windows.h>
#else #else
#define DISCORD_ID_FORMAT "%ld"
#include <unistd.h> #include <unistd.h>
#include <string.h> #include <string.h>
#endif #endif

View file

@ -48,14 +48,14 @@ void ns_discord_save_id(u8 localId, s64 networkId) {
assert(localId > 0); assert(localId > 0);
assert(localId < MAX_PLAYERS); assert(localId < MAX_PLAYERS);
gNetworkUserIds[localId] = (networkId == 0) ? gNetworkUserIds[0] : networkId; gNetworkUserIds[localId] = (networkId == 0) ? gNetworkUserIds[0] : networkId;
LOGFILE_INFO(LFT_DISCORD, "saved user id %d == %ld", localId, gNetworkUserIds[localId]); LOGFILE_INFO(LFT_DISCORD, "saved user id %d == " DISCORD_ID_FORMAT, localId, gNetworkUserIds[localId]);
} }
void ns_discord_clear_id(u8 localId) { void ns_discord_clear_id(u8 localId) {
if (localId == 0) { return; } if (localId == 0) { return; }
assert(localId < MAX_PLAYERS); assert(localId < MAX_PLAYERS);
gNetworkUserIds[localId] = 0; gNetworkUserIds[localId] = 0;
LOGFILE_INFO(LFT_DISCORD, "cleared user id %d == %ld", localId, gNetworkUserIds[localId]); LOGFILE_INFO(LFT_DISCORD, "cleared user id %d == " DISCORD_ID_FORMAT, localId, gNetworkUserIds[localId]);
} }
void discord_network_init(int64_t lobbyId) { void discord_network_init(int64_t lobbyId) {
@ -68,5 +68,5 @@ void discord_network_shutdown(void) {
app.lobbies->flush_network(app.lobbies); app.lobbies->flush_network(app.lobbies);
if (gCurLobbyId == 0) { return; } if (gCurLobbyId == 0) { return; }
app.lobbies->disconnect_network(app.lobbies, gCurLobbyId); app.lobbies->disconnect_network(app.lobbies, gCurLobbyId);
LOGFILE_INFO(LFT_DISCORD, "shutdown network, lobby = %ld", gCurLobbyId); LOGFILE_INFO(LFT_DISCORD, "shutdown network, lobby = " DISCORD_ID_FORMAT, gCurLobbyId);
} }

View file

@ -35,20 +35,20 @@ static void on_lobby_create_callback(UNUSED void* data, enum EDiscordResult resu
} }
DISCORD_REQUIRE(result); DISCORD_REQUIRE(result);
LOGFILE_INFO(LFT_DISCORD, "Lobby id: %ld", lobby->id); LOGFILE_INFO(LFT_DISCORD, "Lobby id: " DISCORD_ID_FORMAT, lobby->id);
LOGFILE_INFO(LFT_DISCORD, "Lobby type: %u", lobby->type); LOGFILE_INFO(LFT_DISCORD, "Lobby type: %u", lobby->type);
LOGFILE_INFO(LFT_DISCORD, "Lobby owner id: %ld", lobby->owner_id); LOGFILE_INFO(LFT_DISCORD, "Lobby owner id: " DISCORD_ID_FORMAT, lobby->owner_id);
LOGFILE_INFO(LFT_DISCORD, "Lobby secret: %s", lobby->secret); LOGFILE_INFO(LFT_DISCORD, "Lobby secret: %s", lobby->secret);
LOGFILE_INFO(LFT_DISCORD, "Lobby capacity: %u", lobby->capacity); LOGFILE_INFO(LFT_DISCORD, "Lobby capacity: %u", lobby->capacity);
LOGFILE_INFO(LFT_DISCORD, "Lobby locked: %d", lobby->locked); LOGFILE_INFO(LFT_DISCORD, "Lobby locked: %d", lobby->locked);
gCurActivity.type = DiscordActivityType_Playing; gCurActivity.type = DiscordActivityType_Playing;
snprintf(gCurActivity.party.id, 128, "%ld", lobby->id); snprintf(gCurActivity.party.id, 128, DISCORD_ID_FORMAT, lobby->id);
gCurActivity.party.size.current_size = 1; gCurActivity.party.size.current_size = 1;
gCurActivity.party.size.max_size = MAX_PLAYERS; gCurActivity.party.size.max_size = MAX_PLAYERS;
char secretJoin[128] = ""; char secretJoin[128] = "";
snprintf(secretJoin, 128, "%ld:%s", lobby->id, lobby->secret); snprintf(secretJoin, 128, DISCORD_ID_FORMAT ":%s", lobby->id, lobby->secret);
strcpy(gCurActivity.secrets.join, secretJoin); strcpy(gCurActivity.secrets.join, secretJoin);
isHosting = true; isHosting = true;
@ -59,21 +59,21 @@ static void on_lobby_create_callback(UNUSED void* data, enum EDiscordResult resu
} }
static void on_lobby_update(UNUSED void* data, int64_t lobbyId) { static void on_lobby_update(UNUSED void* data, int64_t lobbyId) {
LOGFILE_INFO(LFT_DISCORD, "> on_lobby_update id: %ld", lobbyId); LOGFILE_INFO(LFT_DISCORD, "> on_lobby_update id: " DISCORD_ID_FORMAT, lobbyId);
} }
static void on_member_connect(UNUSED void* data, int64_t lobbyId, int64_t userId) { static void on_member_connect(UNUSED void* data, int64_t lobbyId, int64_t userId) {
LOGFILE_INFO(LFT_DISCORD, "> on_member_connect lobby: %ld, user: %ld", lobbyId, userId); LOGFILE_INFO(LFT_DISCORD, "> on_member_connect lobby: " DISCORD_ID_FORMAT ", user: " DISCORD_ID_FORMAT, lobbyId, userId);
gCurActivity.party.size.current_size++; gCurActivity.party.size.current_size++;
discord_activity_update(true); discord_activity_update(true);
} }
static void on_member_update(UNUSED void* data, int64_t lobbyId, int64_t userId) { static void on_member_update(UNUSED void* data, int64_t lobbyId, int64_t userId) {
LOGFILE_INFO(LFT_DISCORD, "> on_member_update lobby: %ld, user: %ld", lobbyId, userId); LOGFILE_INFO(LFT_DISCORD, "> on_member_update lobby: " DISCORD_ID_FORMAT ", user: " DISCORD_ID_FORMAT, lobbyId, userId);
} }
static void on_member_disconnect(UNUSED void* data, int64_t lobbyId, int64_t userId) { static void on_member_disconnect(UNUSED void* data, int64_t lobbyId, int64_t userId) {
LOGFILE_INFO(LFT_DISCORD, "> on_member_disconnect lobby: %ld, user: %ld", lobbyId, userId); LOGFILE_INFO(LFT_DISCORD, "> on_member_disconnect lobby: " DISCORD_ID_FORMAT ", user: " DISCORD_ID_FORMAT, lobbyId, userId);
u8 localIndex = discord_user_id_to_local_index(userId); u8 localIndex = discord_user_id_to_local_index(userId);
if (localIndex != UNKNOWN_LOCAL_INDEX && gNetworkPlayers[localIndex].connected) { if (localIndex != UNKNOWN_LOCAL_INDEX && gNetworkPlayers[localIndex].connected) {
network_player_disconnected(gNetworkPlayers[localIndex].globalIndex); network_player_disconnected(gNetworkPlayers[localIndex].globalIndex);
@ -108,7 +108,7 @@ void discord_lobby_leave(void) {
app.lobbies->disconnect_lobby(app.lobbies, gCurLobbyId, NULL, on_lobby_leave_callback); app.lobbies->disconnect_lobby(app.lobbies, gCurLobbyId, NULL, on_lobby_leave_callback);
} }
LOGFILE_INFO(LFT_DISCORD, "left lobby %ld", gCurLobbyId); LOGFILE_INFO(LFT_DISCORD, "left lobby " DISCORD_ID_FORMAT, gCurLobbyId);
isHosting = false; isHosting = false;
gCurLobbyId = 0; gCurLobbyId = 0;

View file

@ -36,7 +36,7 @@ static int socket_send(SOCKET socket, struct sockaddr_in* addr, u8* buffer, u16
static int socket_receive(SOCKET socket, struct sockaddr_in* rxAddr, u8* buffer, u16 bufferLength, u16* receiveLength, u8* localIndex) { static int socket_receive(SOCKET socket, struct sockaddr_in* rxAddr, u8* buffer, u16 bufferLength, u16* receiveLength, u8* localIndex) {
*receiveLength = 0; *receiveLength = 0;
unsigned int rxAddrSize = sizeof(struct sockaddr_in); RX_ADDR_SIZE_TYPE rxAddrSize = sizeof(struct sockaddr_in);
int rc = recvfrom(socket, (char*)buffer, bufferLength, 0, (struct sockaddr*)rxAddr, &rxAddrSize); int rc = recvfrom(socket, (char*)buffer, bufferLength, 0, (struct sockaddr*)rxAddr, &rxAddrSize);
for (int i = 1; i < MAX_PLAYERS; i++) { for (int i = 1; i < MAX_PLAYERS; i++) {

View file

@ -17,5 +17,6 @@
#define closesocket(fd) close(fd) #define closesocket(fd) close(fd)
#define SOCKET_EWOULDBLOCK EWOULDBLOCK #define SOCKET_EWOULDBLOCK EWOULDBLOCK
#define SOCKET_ECONNRESET ECONNRESET #define SOCKET_ECONNRESET ECONNRESET
#define RX_ADDR_SIZE_TYPE unsigned int
#endif #endif

View file

@ -7,4 +7,6 @@
#define SOCKET_LAST_ERROR WSAGetLastError() #define SOCKET_LAST_ERROR WSAGetLastError()
#define SOCKET_EWOULDBLOCK WSAEWOULDBLOCK #define SOCKET_EWOULDBLOCK WSAEWOULDBLOCK
#define SOCKET_ECONNRESET WSAECONNRESET #define SOCKET_ECONNRESET WSAECONNRESET
#define RX_ADDR_SIZE_TYPE int
#endif #endif