add NOTICE cmd and error in privmsg/ check if chan is joined when msg
This commit is contained in:
parent
370e099b22
commit
0e3c48f3ad
5
Makefile
5
Makefile
@ -6,7 +6,7 @@
|
|||||||
# By: apommier <apommier@student.42.fr> +#+ +:+ +#+ #
|
# By: apommier <apommier@student.42.fr> +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2022/12/01 17:27:29 by apommier #+# #+# #
|
# Created: 2022/12/01 17:27:29 by apommier #+# #+# #
|
||||||
# Updated: 2023/02/13 00:20:18 by apommier ### ########.fr #
|
# Updated: 2023/02/14 22:21:45 by apommier ### ########.fr #
|
||||||
# #
|
# #
|
||||||
# **************************************************************************** #
|
# **************************************************************************** #
|
||||||
|
|
||||||
@ -32,9 +32,9 @@ SRCS := main.cpp\
|
|||||||
commands/channel/channel_utils.cpp\
|
commands/channel/channel_utils.cpp\
|
||||||
commands/channel/join.cpp\
|
commands/channel/join.cpp\
|
||||||
commands/channel/privmsg.cpp\
|
commands/channel/privmsg.cpp\
|
||||||
|
commands/channel/notice.cpp\
|
||||||
\
|
\
|
||||||
commands/other/quit.cpp\
|
commands/other/quit.cpp\
|
||||||
commands/other/squit.cpp\
|
|
||||||
commands/other/ping_pong.cpp\
|
commands/other/ping_pong.cpp\
|
||||||
\
|
\
|
||||||
commands/channel_op/invite.cpp\
|
commands/channel_op/invite.cpp\
|
||||||
@ -42,6 +42,7 @@ SRCS := main.cpp\
|
|||||||
commands/channel_op/mode.cpp\
|
commands/channel_op/mode.cpp\
|
||||||
commands/channel_op/topic.cpp\
|
commands/channel_op/topic.cpp\
|
||||||
\
|
\
|
||||||
|
commands/operator/squit.cpp\
|
||||||
commands/operator/oper.cpp\
|
commands/operator/oper.cpp\
|
||||||
\
|
\
|
||||||
commands/not_done_cmd.cpp #special (temporary)
|
commands/not_done_cmd.cpp #special (temporary)
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/12/01 17:27:37 by apommier #+# #+# */
|
/* Created: 2022/12/01 17:27:37 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/14 02:40:49 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 20:54:22 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -195,6 +195,7 @@ void split_but_keep(std::string const &str, const char delim, std::vector<std::s
|
|||||||
/* *******************************CHAN UTILS********************************* */
|
/* *******************************CHAN UTILS********************************* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
int is_joined(fdList &allFds, std::string chanName, int userNbr);
|
||||||
int find_channel(fdList &allFds, std::string chanName);
|
int find_channel(fdList &allFds, std::string chanName);
|
||||||
int find_user(fdList &allFds, std::string userName);
|
int find_user(fdList &allFds, std::string userName);
|
||||||
void send_msg(fdList &allFds, std::string msg, std::string dest, int userNbr); //in privmsg.cpp
|
void send_msg(fdList &allFds, std::string msg, std::string dest, int userNbr); //in privmsg.cpp
|
||||||
|
|||||||
@ -6,12 +6,14 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/02/06 14:40:42 by apommier #+# #+# */
|
/* Created: 2023/02/06 14:40:42 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/14 02:28:03 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 18:46:53 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "../../../includes/ft_irc.hpp"
|
#include "../../../includes/ft_irc.hpp"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void PASS(std::string buffer, fdList &allFds, int userNbr)
|
void PASS(std::string buffer, fdList &allFds, int userNbr)
|
||||||
{
|
{
|
||||||
std::string password;
|
std::string password;
|
||||||
@ -37,4 +39,11 @@ void PASS(std::string buffer, fdList &allFds, int userNbr)
|
|||||||
|
|
||||||
password = buffer.substr(5, buffer.npos);
|
password = buffer.substr(5, buffer.npos);
|
||||||
allFds.userData[userNbr].password = password;
|
allFds.userData[userNbr].password = password;
|
||||||
|
|
||||||
|
if (!allFds.userData[userNbr].userName.empty() && !allFds.userData[userNbr].nickname.empty())
|
||||||
|
{
|
||||||
|
connect_client(allFds, userNbr);
|
||||||
|
// allFds.userData[userNbr].registered = 1;
|
||||||
|
// print_registered_msg(allFds, userNbr);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@ -6,12 +6,29 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/02/09 17:21:57 by apommier #+# #+# */
|
/* Created: 2023/02/09 17:21:57 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/13 17:45:33 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 20:13:38 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "../../../includes/ft_irc.hpp"
|
#include "../../../includes/ft_irc.hpp"
|
||||||
|
|
||||||
|
int is_joined(fdList &allFds, std::string chanName, int userNbr)
|
||||||
|
{
|
||||||
|
std::vector<channelData*>::iterator start = allFds.userData[userNbr].joinedChan.begin();
|
||||||
|
std::vector<channelData*>::iterator pastEnd = allFds.userData[userNbr].joinedChan.end();
|
||||||
|
//std::cout << "name1= ---" << chanName << "---\n";
|
||||||
|
while (start != pastEnd)
|
||||||
|
{
|
||||||
|
//std::cout << "result in find chan = " << pastEnd - start << std::endl;
|
||||||
|
std::cout << "test = " << allFds.userData[userNbr].joinedChan[pastEnd - start - 1]->name << "---\n";
|
||||||
|
if (allFds.userData[userNbr].joinedChan[pastEnd - start - 1]->name == chanName)
|
||||||
|
return (pastEnd - start - 1);
|
||||||
|
start++;
|
||||||
|
}
|
||||||
|
std::cout << "chan not found\n";
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
|
||||||
int find_channel(fdList &allFds, std::string chanName)//return channel nbr
|
int find_channel(fdList &allFds, std::string chanName)//return channel nbr
|
||||||
{
|
{
|
||||||
std::_List_iterator<channelData> start = allFds.channelList.begin();
|
std::_List_iterator<channelData> start = allFds.channelList.begin();
|
||||||
@ -39,7 +56,7 @@ int find_user(fdList &allFds, std::string userName)//return direct user fd
|
|||||||
std::cout << "result in find user = " << pastEnd - start << std::endl;
|
std::cout << "result in find user = " << pastEnd - start << std::endl;
|
||||||
std::cout << "name2= ---" << allFds.userData[pastEnd - start - 1].nickname << "---\n";
|
std::cout << "name2= ---" << allFds.userData[pastEnd - start - 1].nickname << "---\n";
|
||||||
if (allFds.userData[pastEnd - start - 1].nickname == userName)
|
if (allFds.userData[pastEnd - start - 1].nickname == userName)
|
||||||
return (allFds.userData[pastEnd - start - 1].fd);
|
return (pastEnd - start - 1);
|
||||||
start++;
|
start++;
|
||||||
}
|
}
|
||||||
std::cout << "user not found\n";
|
std::cout << "user not found\n";
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/02/09 15:40:33 by apommier #+# #+# */
|
/* Created: 2023/02/09 15:40:33 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/14 00:41:43 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 14:50:57 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -109,6 +109,10 @@ void join_or_create(std::vector<std::string> splitBuff, fdList &allFds, int user
|
|||||||
send(joined_chan.userList[i]->fd, fullMsg.c_str(), fullMsg.size(), 0);
|
send(joined_chan.userList[i]->fd, fullMsg.c_str(), fullMsg.size(), 0);
|
||||||
std::cout << "loop here\n";
|
std::cout << "loop here\n";
|
||||||
}
|
}
|
||||||
|
// if (chanNbr == -1)
|
||||||
|
// {
|
||||||
|
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
70
srcs/commands/channel/notice.cpp
Normal file
70
srcs/commands/channel/notice.cpp
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
/* ************************************************************************** */
|
||||||
|
/* */
|
||||||
|
/* ::: :::::::: */
|
||||||
|
/* notice.cpp :+: :+: :+: */
|
||||||
|
/* +:+ +:+ +:+ */
|
||||||
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
|
/* +#+#+#+#+#+ +#+ */
|
||||||
|
/* Created: 2023/02/14 21:24:55 by apommier #+# #+# */
|
||||||
|
/* Updated: 2023/02/14 21:35:45 by apommier ### ########.fr */
|
||||||
|
/* */
|
||||||
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
#include "../../../includes/ft_irc.hpp"
|
||||||
|
|
||||||
|
// Commande: PRIVMSG
|
||||||
|
// Paramètres: <destinataire>{,<destinataire>} <texte à envoyer >
|
||||||
|
// ERR_NORECIPIENT ERR_NOTEXTTOSEND +
|
||||||
|
// ERR_CANNOTSENDTOCHAN ERR_NOTOPLEVEL
|
||||||
|
// ERR_WILDTOPLEVEL ERR_TOOMANYTARGETS
|
||||||
|
// ERR_NOSUCHNICK +
|
||||||
|
// RPL_AWAY
|
||||||
|
|
||||||
|
void send_notice_msg(fdList &allFds, std::string msg, std::string dest, int userNbr)
|
||||||
|
{
|
||||||
|
int pos;
|
||||||
|
std::string fullMsg;
|
||||||
|
|
||||||
|
fullMsg = ":" + allFds.userData[userNbr].nickname + "!" + allFds.userData[userNbr].userName + "@172.17.0.1 " + msg + "\n";
|
||||||
|
if (dest[0] == '&' || dest[0] == '#')
|
||||||
|
{
|
||||||
|
if (is_joined(allFds, dest, userNbr) == -1)
|
||||||
|
return ;
|
||||||
|
if ((pos = find_channel(allFds, dest)) == -1)
|
||||||
|
return ;
|
||||||
|
for (size_t i = 0; i < allFds.channelList[pos].userList.size(); i++)
|
||||||
|
{
|
||||||
|
std::cout << "send nickname " << allFds.channelList[pos].userList[i]->nickname << std::endl;
|
||||||
|
if (i != (size_t)userNbr)
|
||||||
|
send(allFds.channelList[pos].userList[i]->fd, fullMsg.c_str(), fullMsg.size(), 0);
|
||||||
|
std::cout << "loop here\n";
|
||||||
|
}
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
pos = find_user(allFds, dest); //return direct user fd
|
||||||
|
if (pos != -1)
|
||||||
|
{
|
||||||
|
send(allFds.userData[pos].fd, fullMsg.c_str(), fullMsg.size(), 0);
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void NOTICE(std::string buffer, fdList &allFds, int userNbr)
|
||||||
|
{
|
||||||
|
std::vector<std::string> splitBuff;
|
||||||
|
std::string msg;
|
||||||
|
|
||||||
|
std::cout << "notice bufer= --" << buffer << std::endl;
|
||||||
|
split(buffer, ' ', splitBuff);
|
||||||
|
if (splitBuff.size() < 2)
|
||||||
|
return ;
|
||||||
|
if (splitBuff.size() < 3)
|
||||||
|
return ;
|
||||||
|
|
||||||
|
std::cout << "notice =" << msg << std::endl;
|
||||||
|
std::vector<std::string> dest;
|
||||||
|
split(splitBuff[1], ',', dest);
|
||||||
|
for (size_t i = 0; i < dest.size(); i++)
|
||||||
|
send_notice_msg(allFds, buffer, dest[i], userNbr);
|
||||||
|
}
|
||||||
|
|
||||||
@ -6,12 +6,19 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/02/11 08:53:03 by apommier #+# #+# */
|
/* Created: 2023/02/11 08:53:03 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/13 20:28:11 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 20:58:20 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "../../../includes/ft_irc.hpp"
|
#include "../../../includes/ft_irc.hpp"
|
||||||
|
|
||||||
|
// Commande: PRIVMSG
|
||||||
|
// Paramètres: <destinataire>{,<destinataire>} <texte à envoyer >
|
||||||
|
// ERR_NORECIPIENT ERR_NOTEXTTOSEND +
|
||||||
|
// ERR_CANNOTSENDTOCHAN ERR_NOTOPLEVEL
|
||||||
|
// ERR_WILDTOPLEVEL ERR_TOOMANYTARGETS
|
||||||
|
// ERR_NOSUCHNICK +
|
||||||
|
// RPL_AWAY
|
||||||
|
|
||||||
void PRIVMSG(std::string buffer, fdList &allFds, int userNbr)
|
void PRIVMSG(std::string buffer, fdList &allFds, int userNbr)
|
||||||
{
|
{
|
||||||
@ -20,72 +27,55 @@ void PRIVMSG(std::string buffer, fdList &allFds, int userNbr)
|
|||||||
|
|
||||||
std::cout << "privmsg bufer= --" << buffer << std::endl;
|
std::cout << "privmsg bufer= --" << buffer << std::endl;
|
||||||
split(buffer, ' ', splitBuff);
|
split(buffer, ' ', splitBuff);
|
||||||
if (splitBuff.size() < 3)
|
if (splitBuff.size() < 2)
|
||||||
{
|
{
|
||||||
cmd_error(allFds, allFds.userData[userNbr].fd, "431 * PRIVMSG :Not enought argument\n");
|
cmd_error(allFds, allFds.userData[userNbr].fd, "431 * PRIVMSG :Not enought argument\n");
|
||||||
//write(allFds.userData[user].fd, "ERR_NEEDMOREPARAMS", 18);
|
|
||||||
return ;
|
return ;
|
||||||
}
|
}
|
||||||
|
if (splitBuff.size() < 3)
|
||||||
// for (size_t i = 2; i < splitBuff.size(); i++)
|
{
|
||||||
// {
|
cmd_error(allFds, allFds.userData[userNbr].fd, "412 * PRIVMSG :No text to send\n");
|
||||||
// msg += (" " + splitBuff[i]);
|
return ;
|
||||||
// }
|
}
|
||||||
//msg = buffer.substr(buffer.find(':') + 1, std::string::npos);
|
|
||||||
std::cout << "privmsg =" << msg << std::endl;
|
std::cout << "privmsg =" << msg << std::endl;
|
||||||
|
|
||||||
std::vector<std::string> dest;
|
std::vector<std::string> dest;
|
||||||
split(splitBuff[1], ',', dest);
|
split(splitBuff[1], ',', dest);
|
||||||
for (size_t i = 0; i < dest.size(); i++)
|
for (size_t i = 0; i < dest.size(); i++)
|
||||||
{
|
|
||||||
// std::cout << "dest[i] =" << dest[i] << "|" << std::endl;
|
|
||||||
// std::cout << "dest[i] =" << dest[i] << "|" << std::endl;
|
|
||||||
// std::cout << "dest[i] =" << dest[i] << "|" << std::endl;
|
|
||||||
// std::cout << "chan =" << allFds.channelList[0].name << "|" << std::endl;
|
|
||||||
// std::cout << "chan =" << allFds.channelList[0].name << "|" << std::endl;
|
|
||||||
// std::cout << "chan =" << allFds.channelList[0].name << "|" << std::endl;
|
|
||||||
// std::cout << "result =" << (allFds.channelList[0].name == dest[i]) << "|" << std::endl;
|
|
||||||
send_msg(allFds, buffer, dest[i], userNbr);
|
send_msg(allFds, buffer, dest[i], userNbr);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void send_msg(fdList &allFds, std::string msg, std::string dest, int userNbr)
|
void send_msg(fdList &allFds, std::string msg, std::string dest, int userNbr)
|
||||||
{
|
{
|
||||||
int pos;
|
int pos;
|
||||||
//find dest
|
|
||||||
std::string fullMsg;
|
std::string fullMsg;
|
||||||
//fullMsg = "*" + allFds.userData[userNbr].nickname + "* " + msg;
|
|
||||||
pos = find_channel(allFds, dest); //return channel nbr
|
fullMsg = ":" + allFds.userData[userNbr].nickname + "!" + allFds.userData[userNbr].userName + "@172.17.0.1 " + msg + "\n";
|
||||||
if (pos != -1)
|
if (dest[0] == '&' || dest[0] == '#')
|
||||||
{
|
{
|
||||||
//std::vector<clientData *>::iterator start = allFds.channelList[fd].userList.begin();
|
if (is_joined(allFds, dest, userNbr) == -1)
|
||||||
//std::vector<clientData *>::iterator pastEnd = allFds.channelList[fd].userList.end();
|
{
|
||||||
// while (start != pastEnd)
|
cmd_error(allFds, allFds.userData[userNbr].fd, "442 * PRIVMSG " + dest + " :You're not on that channel\n");
|
||||||
// {
|
return ;
|
||||||
// std::cout << "send nickname" << (*start)->nickname << std::endl;
|
}
|
||||||
// ft_putstr_fd((*start)->fd, fullMsg);
|
if ((pos = find_channel(allFds, dest)) == -1)
|
||||||
// start++;
|
{
|
||||||
// std::cout << "loop here\n";
|
cmd_error(allFds, allFds.userData[userNbr].fd, "401 * PRIVMSG " + dest + " :No such nick/channel\n");
|
||||||
// }
|
return ;
|
||||||
|
}
|
||||||
for (size_t i = 0; i < allFds.channelList[pos].userList.size(); i++)
|
for (size_t i = 0; i < allFds.channelList[pos].userList.size(); i++)
|
||||||
{
|
{
|
||||||
std::cout << "send nickname " << allFds.channelList[pos].userList[i]->nickname << std::endl;
|
std::cout << "send nickname " << allFds.channelList[pos].userList[i]->nickname << std::endl;
|
||||||
//ft_putstr_fd(allFds.channelList[fd].userList[i]->fd, fullMsg);
|
if (i != (size_t)userNbr)
|
||||||
fullMsg = ":" + allFds.userData[userNbr].nickname + "!" + allFds.userData[userNbr].userName + "@172.17.0.1 " + msg + "\n";
|
send(allFds.channelList[pos].userList[i]->fd, fullMsg.c_str(), fullMsg.size(), 0);
|
||||||
//:kinou2!kinou@172.17.0.1 PRIVMSG #test :cc
|
|
||||||
//send(allFds.channelList[pos].userList[i]->fd, fullMsg.c_str(), fullMsg.size(), 0);
|
|
||||||
send(allFds.channelList[pos].userList[i]->fd, fullMsg.c_str(), fullMsg.size(), 0);
|
|
||||||
std::cout << "loop here\n";
|
std::cout << "loop here\n";
|
||||||
}
|
}
|
||||||
return ;
|
return ;
|
||||||
}
|
}
|
||||||
|
|
||||||
pos = find_user(allFds, dest); //return direct user fd
|
pos = find_user(allFds, dest); //return direct user fd
|
||||||
if (pos != -1)
|
if (pos != -1)
|
||||||
{
|
{
|
||||||
ft_putstr_fd(pos, fullMsg);
|
send(allFds.userData[pos].fd, fullMsg.c_str(), fullMsg.size(), 0);
|
||||||
return ;
|
return ;
|
||||||
}
|
}
|
||||||
std::cout << "error msg\n";
|
cmd_error(allFds, allFds.userData[userNbr].fd, "401 * PRIVMSG " + dest + " :No such nick/channel\n");
|
||||||
//ft_putstr_fd(fd, msg);
|
|
||||||
}
|
}
|
||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/02/09 22:04:11 by apommier #+# #+# */
|
/* Created: 2023/02/09 22:04:11 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/13 16:32:24 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 21:28:14 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -131,13 +131,13 @@ void INFO(std::string buffer, fdList &allFds, int userNbr)
|
|||||||
// return ;
|
// return ;
|
||||||
// }
|
// }
|
||||||
|
|
||||||
void NOTICE(std::string buffer, fdList &allFds, int userNbr)
|
// void NOTICE(std::string buffer, fdList &allFds, int userNbr)
|
||||||
{
|
// {
|
||||||
(void)buffer;
|
// (void)buffer;
|
||||||
(void)allFds;
|
// (void)allFds;
|
||||||
(void)userNbr;
|
// (void)userNbr;
|
||||||
return ;
|
// return ;
|
||||||
}
|
// }
|
||||||
|
|
||||||
void WHO(std::string buffer, fdList &allFds, int userNbr)
|
void WHO(std::string buffer, fdList &allFds, int userNbr)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/02/13 00:16:27 by apommier #+# #+# */
|
/* Created: 2023/02/13 00:16:27 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/14 00:11:54 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 14:27:53 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/12/06 21:58:13 by apommier #+# #+# */
|
/* Created: 2022/12/06 21:58:13 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/13 16:47:16 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 18:11:44 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -23,15 +23,19 @@ void start_loop(fdList &allFds)
|
|||||||
|
|
||||||
|
|
||||||
allFds.alive = 1;
|
allFds.alive = 1;
|
||||||
std::cout << "serverFd: " << allFds.serverFd << std::endl;
|
//std::cout << "serverFd: " << allFds.serverFd << std::endl;
|
||||||
while (allFds.alive)
|
while (allFds.alive)
|
||||||
{
|
{
|
||||||
|
//std::cout << "---------start loop-----------\n";
|
||||||
//std::cout << "\n\n\nwhile alive event loop" << std::endl;
|
//std::cout << "\n\n\nwhile alive event loop" << std::endl;
|
||||||
//std::cout << "in loop nbr user = " << allFds.nbrUser << std::endl;
|
//std::cout << "in loop nbr user = " << allFds.nbrUser << std::endl;
|
||||||
eventNbr = epoll_wait(allFds.epollFd, allFds.events, MAX_EVENTS, 5000);
|
|
||||||
|
eventNbr = epoll_wait(allFds.epollFd, allFds.events, MAX_EVENTS, 0);
|
||||||
|
|
||||||
|
//eventNbr = epoll_wait(allFds.epollFd, allFds.events, MAX_EVENTS, 5000);
|
||||||
|
|
||||||
//std::cout << "eventNbr = " << eventNbr << std::endl;
|
//std::cout << "eventNbr = " << eventNbr << std::endl;
|
||||||
//std::cout << "eventNbr: " << eventNbr << std::endl;
|
//std::cout << "eventNbr: " << eventNbr << std::endl;
|
||||||
//std::cout << "in loop adress " << &allFds << std::endl;
|
//std::cout << "in loop adress " << &allFds << std::endl;
|
||||||
for (i = 0; i < eventNbr ; i++)
|
for (i = 0; i < eventNbr ; i++)
|
||||||
{
|
{
|
||||||
@ -50,9 +54,9 @@ void start_loop(fdList &allFds)
|
|||||||
// if (!clientRequest(allFds, nbr))
|
// if (!clientRequest(allFds, nbr))
|
||||||
// alive = false;
|
// alive = false;
|
||||||
clientRequest(allFds, nbr);
|
clientRequest(allFds, nbr);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//std::cout << "---------end loop-----------\n";
|
||||||
}
|
}
|
||||||
std::cout << "dead server\n";
|
std::cout << "dead server\n";
|
||||||
|
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/12/06 21:46:41 by apommier #+# #+# */
|
/* Created: 2022/12/06 21:46:41 by apommier #+# #+# */
|
||||||
/* Updated: 2023/02/14 02:56:48 by apommier ### ########.fr */
|
/* Updated: 2023/02/14 14:27:33 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ void ft_error(std::string str)
|
|||||||
if (errno)
|
if (errno)
|
||||||
{
|
{
|
||||||
std::cerr << "errno: " << strerror(errno) << std::endl;
|
std::cerr << "errno: " << strerror(errno) << std::endl;
|
||||||
throw std::bad_alloc();
|
throw ;//std::bad_alloc();
|
||||||
//exit(errno);
|
//exit(errno);
|
||||||
}
|
}
|
||||||
exit(1);
|
exit(1);
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user