Server: affect bind_addr on constructor instead of start() (#6474)
bind_addr is already ready when using constructor as we read is.IPv6 from it, instead pass the whole address
This commit is contained in:
parent
27eeb3581f
commit
2afe62952c
@ -1886,10 +1886,8 @@ bool Game::createSingleplayerServer(const std::string &map_dir,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
server = new Server(map_dir, gamespec, simple_singleplayer_mode,
|
server = new Server(map_dir, gamespec, simple_singleplayer_mode, bind_addr, false);
|
||||||
bind_addr.isIPv6(), false);
|
server->start();
|
||||||
|
|
||||||
server->start(bind_addr);
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -838,13 +838,13 @@ static bool run_dedicated_server(const GameParams &game_params, const Settings &
|
|||||||
try {
|
try {
|
||||||
// Create server
|
// Create server
|
||||||
Server server(game_params.world_path, game_params.game_spec,
|
Server server(game_params.world_path, game_params.game_spec,
|
||||||
false, bind_addr.isIPv6(), true, &iface);
|
false, bind_addr, true, &iface);
|
||||||
|
|
||||||
g_term_console.setup(&iface, &kill, admin_nick);
|
g_term_console.setup(&iface, &kill, admin_nick);
|
||||||
|
|
||||||
g_term_console.start();
|
g_term_console.start();
|
||||||
|
|
||||||
server.start(bind_addr);
|
server.start();
|
||||||
// Run server
|
// Run server
|
||||||
dedicated_server_loop(server, kill);
|
dedicated_server_loop(server, kill);
|
||||||
} catch (const ModError &e) {
|
} catch (const ModError &e) {
|
||||||
@ -872,8 +872,8 @@ static bool run_dedicated_server(const GameParams &game_params, const Settings &
|
|||||||
try {
|
try {
|
||||||
// Create server
|
// Create server
|
||||||
Server server(game_params.world_path, game_params.game_spec, false,
|
Server server(game_params.world_path, game_params.game_spec, false,
|
||||||
bind_addr.isIPv6(), true);
|
bind_addr, true);
|
||||||
server.start(bind_addr);
|
server.start();
|
||||||
|
|
||||||
// Run server
|
// Run server
|
||||||
bool &kill = *porting::signal_handler_killstatus();
|
bool &kill = *porting::signal_handler_killstatus();
|
||||||
|
@ -149,10 +149,11 @@ Server::Server(
|
|||||||
const std::string &path_world,
|
const std::string &path_world,
|
||||||
const SubgameSpec &gamespec,
|
const SubgameSpec &gamespec,
|
||||||
bool simple_singleplayer_mode,
|
bool simple_singleplayer_mode,
|
||||||
bool ipv6,
|
Address bind_addr,
|
||||||
bool dedicated,
|
bool dedicated,
|
||||||
ChatInterface *iface
|
ChatInterface *iface
|
||||||
):
|
):
|
||||||
|
m_bind_addr(bind_addr),
|
||||||
m_path_world(path_world),
|
m_path_world(path_world),
|
||||||
m_gamespec(gamespec),
|
m_gamespec(gamespec),
|
||||||
m_simple_singleplayer_mode(simple_singleplayer_mode),
|
m_simple_singleplayer_mode(simple_singleplayer_mode),
|
||||||
@ -161,7 +162,7 @@ Server::Server(
|
|||||||
m_con(std::make_shared<con::Connection>(PROTOCOL_ID,
|
m_con(std::make_shared<con::Connection>(PROTOCOL_ID,
|
||||||
512,
|
512,
|
||||||
CONNECTION_TIMEOUT,
|
CONNECTION_TIMEOUT,
|
||||||
ipv6,
|
m_bind_addr.isIPv6(),
|
||||||
this)),
|
this)),
|
||||||
m_itemdef(createItemDefManager()),
|
m_itemdef(createItemDefManager()),
|
||||||
m_nodedef(createNodeDefManager()),
|
m_nodedef(createNodeDefManager()),
|
||||||
@ -366,19 +367,17 @@ Server::~Server()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Server::start(Address bind_addr)
|
void Server::start()
|
||||||
{
|
{
|
||||||
m_bind_addr = bind_addr;
|
infostream << "Starting server on " << m_bind_addr.serializeString()
|
||||||
|
<< "..." << std::endl;
|
||||||
infostream<<"Starting server on "
|
|
||||||
<< bind_addr.serializeString() <<"..."<<std::endl;
|
|
||||||
|
|
||||||
// Stop thread if already running
|
// Stop thread if already running
|
||||||
m_thread->stop();
|
m_thread->stop();
|
||||||
|
|
||||||
// Initialize connection
|
// Initialize connection
|
||||||
m_con->SetTimeoutMs(30);
|
m_con->SetTimeoutMs(30);
|
||||||
m_con->Serve(bind_addr);
|
m_con->Serve(m_bind_addr);
|
||||||
|
|
||||||
// Start thread
|
// Start thread
|
||||||
m_thread->start();
|
m_thread->start();
|
||||||
@ -393,8 +392,8 @@ void Server::start(Address bind_addr)
|
|||||||
<< " \\/ \\/ \\/ \\/ \\/ " << std::endl;
|
<< " \\/ \\/ \\/ \\/ \\/ " << std::endl;
|
||||||
actionstream << "World at [" << m_path_world << "]" << std::endl;
|
actionstream << "World at [" << m_path_world << "]" << std::endl;
|
||||||
actionstream << "Server for gameid=\"" << m_gamespec.id
|
actionstream << "Server for gameid=\"" << m_gamespec.id
|
||||||
<<"\" listening on "<<bind_addr.serializeString()<<":"
|
<< "\" listening on " << m_bind_addr.serializeString() << ":"
|
||||||
<<bind_addr.getPort() << "."<<std::endl;
|
<< m_bind_addr.getPort() << "." << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Server::stop()
|
void Server::stop()
|
||||||
|
@ -118,14 +118,14 @@ public:
|
|||||||
const std::string &path_world,
|
const std::string &path_world,
|
||||||
const SubgameSpec &gamespec,
|
const SubgameSpec &gamespec,
|
||||||
bool simple_singleplayer_mode,
|
bool simple_singleplayer_mode,
|
||||||
bool ipv6,
|
Address bind_addr,
|
||||||
bool dedicated,
|
bool dedicated,
|
||||||
ChatInterface *iface = nullptr
|
ChatInterface *iface = nullptr
|
||||||
);
|
);
|
||||||
~Server();
|
~Server();
|
||||||
DISABLE_CLASS_COPY(Server);
|
DISABLE_CLASS_COPY(Server);
|
||||||
|
|
||||||
void start(Address bind_addr);
|
void start();
|
||||||
void stop();
|
void stop();
|
||||||
// This is mainly a way to pass the time to the server.
|
// This is mainly a way to pass the time to the server.
|
||||||
// Actual processing is done in an another thread.
|
// Actual processing is done in an another thread.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user