The Battle for Wesnoth  1.19.9+dev
lobby.hpp
Go to the documentation of this file.
1 /*
2  Copyright (C) 2009 - 2025
3  by Tomasz Sniatowski <kailoran@gmail.com>
4  Part of the Battle for Wesnoth Project https://www.wesnoth.org/
5 
6  This program is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2 of the License, or
9  (at your option) any later version.
10  This program is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY.
12 
13  See the COPYING file for more details.
14 */
15 
16 #pragma once
17 
23 #include "quit_confirmation.hpp"
24 
26 
27 namespace gui2
28 {
29 class grid;
30 class listbox;
31 class text_box;
32 class window;
33 class chatbox;
34 
35 namespace dialogs
36 {
37 class mp_lobby : public modal_dialog, public quit_confirmation, private plugin_executor
38 {
39 public:
40  mp_lobby(mp::lobby_info& info, wesnothd_connection& connection, int& joined_game);
41 
42  ~mp_lobby();
43 
44  void update_gamelist();
45 
46 protected:
47  void update_visible_games();
48 
49  void update_gamelist_diff();
50 
52 
54 
55  void adjust_game_row_contents(const mp::game_info& game, grid* grid, bool add_callbacks = true);
56 
57 public:
58  void update_playerlist();
59 
60  enum lobby_result {
66  };
67 
68 private:
69  void update_selected_game();
70 
71  /**
72  * Network polling callback
73  */
74  void network_handler();
75 
76  void process_network_data(const config& data);
77 
78  void process_gamelist(const config& data);
79 
80  void process_gamelist_diff(const config& data);
81 
83 
84  /**
85  * Exits the lobby and enters the given game.
86  *
87  * This assembles the game request for the server and handles any applicable
88  * pre-join actions, such as prompting the player for the game's password or
89  * informing them additional content needs installing.
90  *
91  * The lobby window will be closed on completion, assuming an error wasn't
92  * encountered.
93  *
94  * @param game Info on the game we're attempting to join.
95  * @param mode Whether joining as player, observer or whichever works.
96  */
98 
99  /** Entry wrapper for @ref enter_game, where game is located by index. */
100  void enter_game_by_index(const int index, JOIN_MODE mode);
101 
102  /** Entry wrapper for @ref enter_game, where game is located by game id. */
103  void enter_game_by_id(const int game_id, JOIN_MODE mode);
104 
105  /** Enter game by index, where index is the selected game listbox row. */
107 
108  void show_help_callback();
109 
111 
112  void show_server_info();
113 
114  void open_profile_url();
115 
116  void open_match_history();
117 
118  void tab_switch_callback();
119 
120  void refresh_lobby();
121 
122  void game_filter_init();
123 
124  void game_filter_keypress_callback(const SDL_Keycode key);
125 
127 
129 
130  static bool logout_prompt();
131 
132  virtual const std::string& window_id() const override;
133 
134  virtual void pre_show() override;
135 
136  virtual void post_show() override;
137 
139 
141 
143 
149 
151 
153 
155 
157 
159 
160  std::chrono::steady_clock::time_point last_lobby_update_;
161 
163 
165 
166  /** Timer for updating the lobby. */
167  std::size_t lobby_update_timer_;
168 
169  std::vector<int> gamelist_id_at_row_;
170 
172 
174 
176 
178 
179  static inline std::string server_information_ = "";
180  static inline std::string announcements_ = "";
181 };
182 
183 } // namespace dialogs
184 } // namespace gui2
A config object defines a single node in a WML file, with access to child nodes.
Definition: config.hpp:158
Abstract base class for all modal dialogs.
void enter_selected_game(JOIN_MODE mode)
Enter game by index, where index is the selected game listbox row.
Definition: lobby.cpp:903
void process_gamelist(const config &data)
Definition: lobby.cpp:764
field_bool * filter_slots_
Definition: lobby.hpp:146
void update_visible_games()
Definition: lobby.cpp:364
void update_selected_game()
Definition: lobby.cpp:535
virtual void post_show() override
Actions to be taken after the window has been shown.
Definition: lobby.cpp:692
mp::lobby_info & lobby_info_
Definition: lobby.hpp:140
text_box * filter_text_
Definition: lobby.hpp:150
lobby_player_list_helper player_list_
Definition: lobby.hpp:154
void skip_replay_changed_callback()
Definition: lobby.cpp:997
static std::string announcements_
Definition: lobby.hpp:180
virtual const std::string & window_id() const override
The ID of the window to build.
wesnothd_connection & network_connection_
Definition: lobby.hpp:164
void update_gamelist_filter()
Definition: lobby.cpp:511
field_bool * filter_friends_
Definition: lobby.hpp:144
listbox * gamelistbox_
Definition: lobby.hpp:138
void process_network_data(const config &data)
Definition: lobby.cpp:743
widget_data make_game_row_data(const mp::game_info &game)
Definition: lobby.cpp:376
field_bool * filter_ignored_
Definition: lobby.hpp:145
void game_filter_keypress_callback(const SDL_Keycode key)
Definition: lobby.cpp:967
field_bool * filter_invert_
Definition: lobby.hpp:147
void enter_game_by_id(const int game_id, JOIN_MODE mode)
Entry wrapper for enter_game, where game is located by game id.
Definition: lobby.cpp:891
void update_gamelist_diff()
Definition: lobby.cpp:257
void show_preferences_button_callback()
Definition: lobby.cpp:918
static std::string server_information_
Definition: lobby.hpp:179
void enter_game(const mp::game_info &game, JOIN_MODE mode)
Exits the lobby and enters the given game.
Definition: lobby.cpp:796
static bool logout_prompt()
Definition: lobby.cpp:63
void user_dialog_callback(const mp::user_info *info)
Definition: lobby.cpp:974
void tab_switch_callback()
Definition: lobby.cpp:678
mp_lobby(mp::lobby_info &info, wesnothd_connection &connection, int &joined_game)
Definition: lobby.cpp:68
void process_gamelist_diff(const config &data)
Definition: lobby.cpp:774
std::size_t lobby_update_timer_
Timer for updating the lobby.
Definition: lobby.hpp:167
virtual void pre_show() override
Actions to be taken before showing the window.
Definition: lobby.cpp:555
void adjust_game_row_contents(const mp::game_info &game, grid *grid, bool add_callbacks=true)
Definition: lobby.cpp:405
std::vector< int > gamelist_id_at_row_
Definition: lobby.hpp:169
std::chrono::steady_clock::time_point last_lobby_update_
Definition: lobby.hpp:160
void network_handler()
Network polling callback.
Definition: lobby.cpp:707
void enter_game_by_index(const int index, JOIN_MODE mode)
Entry wrapper for enter_game, where game is located by index.
Definition: lobby.cpp:880
Specialized field class for boolean.
Definition: field.hpp:488
Base container class.
Definition: grid.hpp:32
The listbox class.
Definition: listbox.hpp:41
A widget that allows the user to input text in single line.
Definition: text_box.hpp:125
show_mode mode() const
Returns the dialog mode for this window.
Definition: window.hpp:695
This class represents the collective information the client has about the players and games on the se...
Definition: lobby_info.hpp:31
Implements a quit confirmation dialog.
A class that represents a TCP/IP connection to the wesnothd server.
Various uncategorised dialogs.
Generic file dialog.
std::map< std::string, widget_item > widget_data
Definition: widget.hpp:36
logger & info()
Definition: log.cpp:319
std::size_t index(std::string_view str, const std::size_t index)
Codepoint index corresponding to the nth character in a UTF-8 string.
Definition: unicode.cpp:70
std::string_view data
Definition: picture.cpp:178
This class represents the info a client has about a game on the server.
Definition: lobby_data.hpp:63
This class represents the information a client has about another player.
Definition: lobby_data.hpp:30