g voulu implementer le code client dans le handler et g tout cassee

This commit is contained in:
hugogogo
2021-09-01 19:06:07 +02:00
parent 016e16e7be
commit bb90704a0c
7 changed files with 86 additions and 42 deletions

Binary file not shown.

Binary file not shown.

BIN
client

Binary file not shown.

View File

@@ -6,7 +6,15 @@
# include <unistd.h> // for getpid # include <unistd.h> // for getpid
# include "libft.h" # include "libft.h"
int msg_received; typedef struct s_client
{
int mask;
int count_char;
int server_pid;
char *text;
} t_client;
t_client client;
#endif #endif

BIN
server

Binary file not shown.

View File

@@ -6,48 +6,77 @@ int usage(void)
return (0); return (0);
} }
void send_char(int server_pid, char c) // void send_char(int server_pid, char c)
{ // {
int mask; // int mask;
//
// mask = 1 << 6;
// while (mask != 0)
// {
// if (msg_received == 1)
// {
// if ((c & mask) != 0)
// kill(server_pid, SIGUSR1);
// if ((c & mask) == 0)
// kill(server_pid, SIGUSR2);
// msg_received = 0;
// mask >>= 1;
// }
// }
// }
//
// void send_message(int sig_num)
// {
// (void)sig_num;
// while (*(client.text))
// {
// send_char(client.server_pid, *(client.text));
// (client.text)++;
// }
// send_char(client.server_pid, *(client.text));
// }
mask = 1 << 6; void send_char(char c, int mask, int server_pid)
while (mask != 0) {
{ if ((c & mask) != 0)
if (msg_received == 1) kill(server_pid, SIGUSR1);
{ if ((c & mask) == 0)
if ((c & mask) != 0) kill(server_pid, SIGUSR2);
kill(server_pid, SIGUSR1);
if ((c & mask) == 0)
kill(server_pid, SIGUSR2);
msg_received = 0;
mask >>= 1;
}
}
} }
void send_message(int server_pid, char *msg) void send_message(int sig_num)
{
while (*msg)
{
send_char(server_pid, *msg);
msg++;
}
send_char(server_pid, *msg);
}
void message_received(int sig_num)
{ {
(void)sig_num; (void)sig_num;
msg_received = 1; if (client.text[client.count_char] != '\0')
{
if (client.mask == 0)
{
client.mask = 1 << 6;
(client.count_char)++;
}
else
client.mask >>= 1;
send_char(client.text[client.count_char], client.mask, client.server_pid);
}
send_char(client.text[client.count_char], client.mask, client.server_pid);
ft_putnbrbase(client.mask, "01"); ft_printf(" (%i) - [%i] %s\n", client.mask, client.count_char, client.text + client.count_char);
}
void init_client(int pid, char *msg)
{
client.mask = 0;
client.count_char = 1 << 7;
client.server_pid = pid;
client.text = msg;
} }
int main(int ac, char **av) int main(int ac, char **av)
{ {
signal(SIGUSR1, message_received); signal(SIGUSR1, send_message);
if (ac != 3) if (ac != 3)
return (usage()); return (usage());
msg_received = 1; init_client(ft_atoi(av[1]), av[2]);
ft_putnbrendl((int)getpid()); kill((int)getpid(), SIGUSR1);
send_message(ft_atoi(av[1]), av[2]);
return (0); return (0);
} }

View File

@@ -4,17 +4,21 @@ void sig_handler_1(int sig_num, siginfo_t *info, void *context)
{ {
(void)sig_num; (void)sig_num;
(void)context; (void)context;
kill(info->si_pid, SIGUSR1);
message.character ^= 1 << (6 - message.count_bits); message.character ^= 1 << (6 - message.count_bits);
message.count_bits++; message.count_bits++;
kill(info->si_pid, SIGUSR1);
// if (kill(info->si_pid, SIGUSR1) == 0)
// ft_putstr("client->server signal 1 received, server->client signal 1 sent");
} }
void sig_handler_2(int sig_num, siginfo_t *info, void *context) void sig_handler_2(int sig_num, siginfo_t *info, void *context)
{ {
(void)sig_num; (void)sig_num;
(void)context; (void)context;
kill(info->si_pid, SIGUSR1);
message.count_bits++; message.count_bits++;
kill(info->si_pid, SIGUSR1);
// if (kill(info->si_pid, SIGUSR1) == 0)
// ft_putstr("client->server signal 2 received, server->client signal 1 sent");
} }
void handler_1(int sig_num) void handler_1(int sig_num)
@@ -41,13 +45,16 @@ void concat_msg()
{ {
if (message.count_bits == 7) if (message.count_bits == 7)
{ {
if (message.character == 0)
{ ft_putchar(message.character);
ft_printf("%s\n", message.text);
message.text = ft_strdup(""); // if (message.character == 0)
} // {
else // ft_printf("%s\n", message.text);
message.text = ft_strjoinfree(message.text, ft_strdup(&(message.character))); // message.text = ft_strdup("");
// }
// else
// message.text = ft_strjoinfree(message.text, ft_strdup(&(message.character)));
message.count_bits = 0; message.count_bits = 0;
message.character = 0; message.character = 0;
} }