From c892acab8002e250d9a23b3787da852e703d5162 Mon Sep 17 00:00:00 2001 From: snit Date: Mon, 28 Oct 2024 00:13:05 -0500 Subject: [PATCH] mostly just refactoring socket stuff --- doc/TODO.gmi | 2 +- server/src/game_data.h | 3 --- server/src/main.c | 3 +++ server/src/socket.c | 31 ++++++++++++++++++++----------- server/src/socket.h | 1 + 5 files changed, 25 insertions(+), 15 deletions(-) diff --git a/doc/TODO.gmi b/doc/TODO.gmi index c727903..a6b8d45 100644 --- a/doc/TODO.gmi +++ b/doc/TODO.gmi @@ -2,9 +2,9 @@ A list of things I'd like to accomplish ## In Progress -* Split game ticking and socket connecting logic (can only tick on connection atm) ## Completed +* Split game ticking and socket connecting logic (can only tick on connection atm) * Client send request * Server handle request and send response * Client handle response diff --git a/server/src/game_data.h b/server/src/game_data.h index 46a3e6c..577bff9 100644 --- a/server/src/game_data.h +++ b/server/src/game_data.h @@ -12,9 +12,6 @@ struct game_data_t { struct world_t world; pthread_mutex_t world_lock; - - int socket; - int socket_accept; }; #endif diff --git a/server/src/main.c b/server/src/main.c index 94894e2..dd77e23 100644 --- a/server/src/main.c +++ b/server/src/main.c @@ -114,6 +114,9 @@ int main(int argc, char **argv) { pthread_join(pthread_socket, (void **)&err); // No way this is correct lol if (err) goto handle_error; + pthread_join(pthread_simulation, (void **)&err); + if (err) goto handle_error; + // Deinitialisation pthread_mutex_destroy(&data.world_lock); diff --git a/server/src/socket.c b/server/src/socket.c index 4f19476..865f2be 100644 --- a/server/src/socket.c +++ b/server/src/socket.c @@ -43,25 +43,31 @@ void socket_free(int const *sockptr) { } -static enum error_t socket_handle(struct game_data_t *data) { +struct socket_data_t { + struct game_data_t *game_data; + int socket; +}; + + +static enum error_t socket_handle(struct socket_data_t *data) { enum error_t err = ERR_OK; char output_buffer[8192] = { 0 }; char input_buffer[8192] = { 0 }; // Receive request from client - read(data->socket_accept, input_buffer, 8192); + read(data->socket, input_buffer, 8192); struct request_t request = { 0 }; err = request_deserialise_str(&request, input_buffer); if (err != ERR_OK) return err; // Send response to client - struct response_t response = handle_request(&request, data); + struct response_t response = handle_request(&request, data->game_data); err = response_serialise_buf(&response, output_buffer, 8192); if (err != ERR_OK) return err; - write(data->socket_accept, output_buffer, 8192); + write(data->socket, output_buffer, 8192); return ERR_OK; } @@ -72,27 +78,30 @@ static enum error_t socket_thread_body(struct game_data_t *data) { enum error_t err = ERR_OK; - if ((err = socket_init(&data->socket))) return err; + struct socket_data_t socket_data = { data, 0 }; + + int socket = 0; + if ((err = socket_init(&socket))) return err; for (int sock_accept;;) { - if ((sock_accept = accept(data->socket, NULL, NULL)) < 0) { + if ((sock_accept = accept(socket, NULL, NULL)) < 0) { err = ERR_SOCKET; goto error_pre; }; - data->socket_accept = sock_accept; - if ((err = socket_handle(data))) goto error_pre; + socket_data.socket = sock_accept; + if ((err = socket_handle(&socket_data))) goto error_pre; - close(data->socket_accept); + close(socket_data.socket); continue; error_pre: - close(data->socket_accept); + close(socket_data.socket); goto error; } error: - socket_free(&data->socket); + socket_free(&socket); return err; } diff --git a/server/src/socket.h b/server/src/socket.h index 7fef344..37397fb 100644 --- a/server/src/socket.h +++ b/server/src/socket.h @@ -8,6 +8,7 @@ #define SOCKET_PATH "/tmp/swd.sock" // Socket path should be a shared setting between server and client + enum error_t socket_init(int *); void socket_free(int const *);