vavaas est mauv...meilleur

This commit is contained in:
Kbz-8
2024-01-22 17:05:05 +01:00
parent 16cf37d1c0
commit 8ec29c4008
3 changed files with 24 additions and 17 deletions

View File

@@ -6,7 +6,7 @@
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */ /* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/01/21 09:12:28 by maldavid #+# #+# */ /* 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: public:
Server(int port, const std::string& password); Server(int port, const std::string& password);
inline void closeMainSocket() { close(_main_socket); }
void wait(); void wait();
~Server(); ~Server();
private: private:

View File

@@ -6,7 +6,7 @@
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */ /* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/01/20 09:27:04 by maldavid #+# #+# */ /* 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 <cstring>
#include <cerrno> #include <cerrno>
#include <server.hpp> #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) 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) if(errno == ERANGE || *end != 0 || port < 0 || port > 0xFFFF || std::strlen(av[1]) == 0)
irc::logs::report(irc::log_fatal_error, "invalid port"); irc::logs::report(irc::log_fatal_error, "invalid port");
irc::Server server(port, av[2]); unstd::SharedPtr<irc::Server> serv(new irc::Server(port, av[2]));
server.wait(); server_ref = serv;
signal(SIGINT, signalsHandler);
signal(SIGQUIT, signalsHandler);
serv->wait();
serv->closeMainSocket();
return 0; return 0;
} }

View File

@@ -6,7 +6,7 @@
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */ /* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/01/21 09:31:17 by maldavid #+# #+# */ /* 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 <config.hpp>
#include <message.hpp> #include <message.hpp>
#include <algorithm> #include <algorithm>
#include <signal.h>
namespace irc 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) 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)); std::memset(&_s_data, 0, sizeof(sockaddr));
initSocket(); initSocket();
signal(SIGINT, signalsHandler);
signal(SIGQUIT, signalsHandler);
} }
void Server::initSocketData() void Server::initSocketData()
@@ -103,7 +92,7 @@ namespace irc
int i = 0; int i = 0;
socklen_t len = sizeof(sockaddr_in); socklen_t len = sizeof(sockaddr_in);
while(_active && !__quit_required) while(_active)
{ {
FD_ZERO(&_fd_set); FD_ZERO(&_fd_set);
FD_SET(_main_socket, &_fd_set); FD_SET(_main_socket, &_fd_set);