From f40d09cb8f712e87691af4912f3630d92d692779 Mon Sep 17 00:00:00 2001 From: untodesu Date: Thu, 11 Dec 2025 15:14:26 +0500 Subject: Shuffle stuff around - Use the new and improved hierarchy I figured out when making Prospero chat - Re-add NSIS scripts, again from Prospero - Update most build and utility scripts with their most recent versions --- src/game/server/sessions.hh | 55 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 src/game/server/sessions.hh (limited to 'src/game/server/sessions.hh') diff --git a/src/game/server/sessions.hh b/src/game/server/sessions.hh new file mode 100644 index 0000000..656b76d --- /dev/null +++ b/src/game/server/sessions.hh @@ -0,0 +1,55 @@ +#pragma once + +namespace world +{ +class Dimension; +} // namespace world + +namespace config +{ +class Unsigned; +} // namespace config + +struct Session final { + std::uint16_t client_index; + std::uint64_t client_identity; + std::string client_username; + entt::entity player_entity; + world::Dimension* dimension; + ENetPeer* peer; +}; + +namespace sessions +{ +extern config::Unsigned max_players; +extern unsigned int num_players; +} // namespace sessions + +namespace sessions +{ +void init(void); +void init_late(void); +void init_post_universe(void); +void shutdown(void); +} // namespace sessions + +namespace sessions +{ +Session* create(ENetPeer* peer, std::string_view client_username); +Session* find(std::string_view client_username); +Session* find(std::uint16_t client_index); +Session* find(std::uint64_t client_identity); +Session* find(ENetPeer* peer); +void destroy(Session* session); +} // namespace sessions + +namespace sessions +{ +void broadcast(const world::Dimension* dimension, ENetPacket* packet); +void broadcast(const world::Dimension* dimension, ENetPacket* packet, ENetPeer* except); +} // namespace sessions + +namespace sessions +{ +void refresh_scoreboard(void); +} // namespace sessions -- cgit