vavaas est mauv...meilleur
This commit is contained in:
@@ -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:
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
Reference in New Issue
Block a user