la communication fonctionne avec signal
This commit is contained in:
@@ -20,6 +20,22 @@ void init_message(void)
|
||||
message.text = ft_strdup("");
|
||||
}
|
||||
|
||||
void concat_msg()
|
||||
{
|
||||
if (message.count_bits == 7)
|
||||
{
|
||||
if (message.character == 0)
|
||||
{
|
||||
ft_printf("%s\n", message.text);
|
||||
message.text = ft_strdup("");
|
||||
}
|
||||
else
|
||||
message.text = ft_strjoinfree(message.text, ft_strdup(&(message.character)));
|
||||
message.count_bits = 0;
|
||||
message.character = 0;
|
||||
}
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
signal(SIGUSR1, sig_handler_1);
|
||||
@@ -27,25 +43,11 @@ int main()
|
||||
ft_putnbrendl((int)getpid());
|
||||
init_message();
|
||||
while (1)
|
||||
{
|
||||
if (message.count_bits == 7)
|
||||
{
|
||||
if (message.character == 0)
|
||||
{
|
||||
ft_printf("%s\n", message.text);
|
||||
message.text = ft_strdup("");
|
||||
}
|
||||
else
|
||||
message.text = ft_strjoinfree(message.text, ft_strdup(&(message.character)));
|
||||
message.count_bits = 0;
|
||||
message.character = 0;
|
||||
}
|
||||
}
|
||||
concat_msg();
|
||||
return (0);
|
||||
}
|
||||
|
||||
/*
|
||||
**
|
||||
** allowed functions :
|
||||
** - write
|
||||
** - signal
|
||||
@@ -61,6 +63,15 @@ int main()
|
||||
** - usleep
|
||||
** - exit
|
||||
**
|
||||
**
|
||||
** cmm
|
||||
** deii
|
||||
** enlc
|
||||
** ctlr
|
||||
** iiio
|
||||
** 0.0010
|
||||
** 10
|
||||
**
|
||||
** you can only use two signals :
|
||||
** - SIGUSR1
|
||||
** - SIGUSR2
|
||||
|
||||
Reference in New Issue
Block a user