a verifier demain a l'ecole
This commit is contained in:
@@ -1,15 +1,3 @@
|
||||
/* ************************************************************************** */
|
||||
/* */
|
||||
/* ::: :::::::: */
|
||||
/* get_next_line_bonus.c :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: hulamy <marvin@42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2019/12/29 18:06:33 by hulamy #+# #+# */
|
||||
/* Updated: 2019/12/29 18:07:19 by hulamy ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include "get_next_line_bonus.h"
|
||||
|
||||
/*
|
||||
@@ -25,12 +13,37 @@
|
||||
** #include <stdio.h> //for printf
|
||||
** #include <fcntl.h> //for open
|
||||
**
|
||||
** void ft_putchar(char c){
|
||||
** write(1, &c, 1);
|
||||
** }
|
||||
**
|
||||
** void ft_putstr(char *s)
|
||||
** {
|
||||
** while (s && *s)
|
||||
** ft_putchar(*s++);
|
||||
** }
|
||||
**
|
||||
** void ft_putnbr(int n)
|
||||
** {
|
||||
** long l;
|
||||
**
|
||||
** l = n;
|
||||
** if (l < 0)
|
||||
** {
|
||||
** ft_putchar('-');
|
||||
** l *= -1;
|
||||
** }
|
||||
** if (l >= 10)
|
||||
** ft_putnbr(l / 10);
|
||||
** ft_putchar((l % 10) + '0');
|
||||
** }
|
||||
**
|
||||
** int main(int ac, char **av)
|
||||
** {
|
||||
** int *fd;
|
||||
** int i = 0;
|
||||
** int j = 0;
|
||||
** int ret = 1;
|
||||
** int ret;
|
||||
** char *line = NULL;
|
||||
**
|
||||
** fd = (int *)malloc(sizeof(int) * ac);
|
||||
@@ -39,16 +52,24 @@
|
||||
** i = 0;
|
||||
** while (j < ac - 1)
|
||||
** {
|
||||
** if (ret > 0)
|
||||
** if ((ret = get_next_line(fd[i], &line)) > 0)
|
||||
** {
|
||||
** ret = get_next_line(fd[i], &line);
|
||||
** printf("[fd%i-%i] %s\n", fd[i], ret, line);
|
||||
** printf(" [fd%i-%i] \n", fd[i], ret );
|
||||
** free(line);
|
||||
** j = 0;
|
||||
** }
|
||||
** else if (ret == -1)
|
||||
** {
|
||||
** printf("[fd%i-%i]*ERROR*\n", fd[i], ret);
|
||||
** free(line);
|
||||
** j++;
|
||||
** }
|
||||
** else if (*line != '\0')
|
||||
** printf(" [fd%i-%i] \n", fd[i], ret);
|
||||
** else
|
||||
** {
|
||||
** printf("[fd%i-%i]*FINI*\n", fd[i], ret);
|
||||
** free(line);
|
||||
** j++;
|
||||
** }
|
||||
** i++;
|
||||
@@ -65,14 +86,23 @@ int free_lst(t_gnlist **lst, int ret)
|
||||
{
|
||||
t_gnlist *tmp;
|
||||
|
||||
tmp = *lst;
|
||||
while ((*lst)->next != tmp)
|
||||
(*lst) = (*lst)->next;
|
||||
(*lst)->next = (*lst)->next->next;
|
||||
free(tmp->str);
|
||||
free(tmp);
|
||||
tmp = NULL;
|
||||
*lst = tmp;
|
||||
tmp = *lst; // t_gnlist *tmp2;/*ft_putstr("\n");*/ft_putstr("(");
|
||||
while (tmp->next != *lst)
|
||||
{ // ft_putnbr(tmp->lfd);ft_putstr("-");
|
||||
tmp = tmp->next;
|
||||
} // ft_putnbr(tmp->lfd);ft_putstr("-(");ft_putnbr(tmp->next->lfd);ft_putstr("))");
|
||||
tmp->next = (*lst)->next; // ft_putstr("->(");ft_putnbr(tmp->lfd);ft_putstr("-");ft_putnbr(tmp->next->lfd);ft_putstr(")");
|
||||
free((*lst)->str);
|
||||
if (*lst == (*lst)->next)
|
||||
{
|
||||
free(*lst);
|
||||
*lst = NULL;
|
||||
}
|
||||
else
|
||||
{
|
||||
free(*lst);
|
||||
*lst = tmp;
|
||||
} // tmp2=tmp;ft_putstr("(");while(tmp2->next!=tmp){ft_putnbr(tmp2->lfd);ft_putstr("-");tmp2=tmp2->next;}ft_putnbr(tmp2->lfd);ft_putstr("-(");ft_putnbr(tmp2->next->lfd);ft_putstr("))");
|
||||
return (ret);
|
||||
}
|
||||
|
||||
@@ -80,11 +110,13 @@ int multi_fd(int fd, t_gnlist **lst)
|
||||
{
|
||||
t_gnlist *tmp;
|
||||
|
||||
tmp = *lst;
|
||||
tmp = *lst; // t_gnlist *tmp2;ft_putstr(" multi(fd:");ft_putnbr(fd);ft_putstr("-(check:");tmp2=tmp;while(tmp2 && tmp2->next!=tmp){ft_putnbr(tmp2->lfd);ft_putstr("-");tmp2=tmp2->next;}if(tmp2)ft_putnbr(tmp2->lfd);ft_putstr(")-(start:");
|
||||
while (*lst && (*lst)->lfd != fd && (*lst)->next != tmp)
|
||||
{ // ft_putnbr((*lst)->lfd);ft_putstr("-");
|
||||
*lst = (*lst)->next;
|
||||
} // if(*lst)ft_putnbr((*lst)->lfd);ft_putstr(")-(");
|
||||
if (!tmp || ((*lst)->next == tmp && (*lst)->lfd != fd))
|
||||
{
|
||||
{ // ft_putstr("create ");
|
||||
if (!(tmp = (t_gnlist*)malloc(sizeof(*tmp))))
|
||||
return (0);
|
||||
tmp->lfd = fd;
|
||||
@@ -98,7 +130,7 @@ int multi_fd(int fd, t_gnlist **lst)
|
||||
else
|
||||
tmp->next = tmp;
|
||||
*lst = tmp;
|
||||
}
|
||||
} // ft_putstr("lfd:");ft_putnbr((*lst)->lfd);ft_putstr(")-(");tmp2=*lst;while(tmp2->next!=*lst){ft_putnbr(tmp2->lfd);ft_putstr("-");tmp2=tmp2->next;}ft_putnbr(tmp2->lfd);ft_putstr("-(");ft_putnbr(tmp2->next->lfd);ft_putstr("))");
|
||||
return (1);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user