vavaas est mauv...meilleur
This commit is contained in:
@@ -6,7 +6,7 @@
|
||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2024/01/21 09:12:28 by maldavid #+# #+# */
|
||||
/* Updated: 2024/01/22 12:16:31 by maldavid ### ########.fr */
|
||||
/* Updated: 2024/01/22 17:00:02 by maldavid ### ########.fr */
|
||||
/* */
|
||||
/******************************************************************************/
|
||||
|
||||
@@ -27,7 +27,10 @@ namespace irc
|
||||
{
|
||||
public:
|
||||
Server(int port, const std::string& password);
|
||||
|
||||
inline void closeMainSocket() { close(_main_socket); }
|
||||
void wait();
|
||||
|
||||
~Server();
|
||||
|
||||
private:
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2024/01/20 09:27:04 by maldavid #+# #+# */
|
||||
/* Updated: 2024/01/22 09:30:16 by maldavid ### ########.fr */
|
||||
/* Updated: 2024/01/22 17:04:37 by maldavid ### ########.fr */
|
||||
/* */
|
||||
/******************************************************************************/
|
||||
|
||||
@@ -16,6 +16,17 @@
|
||||
#include <cstring>
|
||||
#include <cerrno>
|
||||
#include <server.hpp>
|
||||
#include <signal.h>
|
||||
|
||||
static unstd::SharedPtr<irc::Server> server_ref;
|
||||
|
||||
void signalsHandler(int foo)
|
||||
{
|
||||
(void)foo;
|
||||
if(server_ref)
|
||||
return;
|
||||
server_ref->closeMainSocket();
|
||||
}
|
||||
|
||||
int main(int ac, char** av)
|
||||
{
|
||||
@@ -32,8 +43,12 @@ int main(int ac, char** av)
|
||||
if(errno == ERANGE || *end != 0 || port < 0 || port > 0xFFFF || std::strlen(av[1]) == 0)
|
||||
irc::logs::report(irc::log_fatal_error, "invalid port");
|
||||
|
||||
irc::Server server(port, av[2]);
|
||||
server.wait();
|
||||
unstd::SharedPtr<irc::Server> serv(new irc::Server(port, av[2]));
|
||||
server_ref = serv;
|
||||
signal(SIGINT, signalsHandler);
|
||||
signal(SIGQUIT, signalsHandler);
|
||||
serv->wait();
|
||||
serv->closeMainSocket();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2024/01/21 09:31:17 by maldavid #+# #+# */
|
||||
/* Updated: 2024/01/22 16:44:54 by maldavid ### ########.fr */
|
||||
/* Updated: 2024/01/22 17:00:42 by maldavid ### ########.fr */
|
||||
/* */
|
||||
/******************************************************************************/
|
||||
|
||||
@@ -22,24 +22,13 @@
|
||||
#include <config.hpp>
|
||||
#include <message.hpp>
|
||||
#include <algorithm>
|
||||
#include <signal.h>
|
||||
|
||||
namespace irc
|
||||
{
|
||||
static bool __quit_required = false;
|
||||
|
||||
static void signalsHandler(int foo)
|
||||
{
|
||||
(void)foo;
|
||||
__quit_required = true;
|
||||
}
|
||||
|
||||
Server::Server(int port, const std::string& password) : _s_len(sizeof(_s_data)), _password(password), _port(port), _active(true)
|
||||
{
|
||||
std::memset(&_s_data, 0, sizeof(sockaddr));
|
||||
initSocket();
|
||||
signal(SIGINT, signalsHandler);
|
||||
signal(SIGQUIT, signalsHandler);
|
||||
}
|
||||
|
||||
void Server::initSocketData()
|
||||
@@ -103,7 +92,7 @@ namespace irc
|
||||
int i = 0;
|
||||
socklen_t len = sizeof(sockaddr_in);
|
||||
|
||||
while(_active && !__quit_required)
|
||||
while(_active)
|
||||
{
|
||||
FD_ZERO(&_fd_set);
|
||||
FD_SET(_main_socket, &_fd_set);
|
||||
|
||||
Reference in New Issue
Block a user