Finito Echo
This commit is contained in:
parent
f346c5c2ce
commit
a4befa5fa6
@ -6,7 +6,7 @@
|
||||
/* By: erey-bet <marvin@42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2023/02/17 13:09:08 by erey-bet #+# #+# */
|
||||
/* Updated: 2023/02/21 23:31:04 by cchauvet ### ########.fr */
|
||||
/* Updated: 2023/02/22 13:23:16 by erey-bet ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@ -18,80 +18,44 @@ int is_space(char c)
|
||||
|| c == '\r' || c == '\n');
|
||||
}
|
||||
|
||||
int check_argument(char *str, int *check, int i)
|
||||
int check_argument(char *str, int *check)
|
||||
{
|
||||
int y;
|
||||
|
||||
y = 0;
|
||||
if (str[i] == '-')
|
||||
{
|
||||
while (!is_space(str[i]) || (str[i + 1] == '-' ))
|
||||
{
|
||||
i++;
|
||||
if (is_space(str[i]))
|
||||
{
|
||||
y = i;
|
||||
*check = 1;
|
||||
}
|
||||
else if (str[i] == '-' && str[i - 1] != '-')
|
||||
;
|
||||
else if (str[i] != 'n')
|
||||
break ;
|
||||
}
|
||||
i = y;
|
||||
while (is_space(str[i]))
|
||||
i++;
|
||||
}
|
||||
return (i);
|
||||
}
|
||||
|
||||
char *conca(char **strs)
|
||||
{
|
||||
int len;
|
||||
char *str;
|
||||
char *p;
|
||||
int i;
|
||||
int i;
|
||||
|
||||
i = -1;
|
||||
len = 0;
|
||||
while (strs[++i] != NULL)
|
||||
len += ft_strlen(strs[i]) + 2;
|
||||
str = (char *) ft_calloc(len + 1, sizeof(char));
|
||||
if (str == NULL)
|
||||
return NULL;
|
||||
i = -1;
|
||||
while (strs[++i] != NULL)
|
||||
{
|
||||
ft_strlcat(str, strs[i], ft_strlen(str) + ft_strlen(strs[i]) + 2);
|
||||
if (strs[i + 1] != NULL)
|
||||
str[ft_strlen(str)] = ' ';
|
||||
}
|
||||
str[ft_strlen(str)] = '\0';
|
||||
return (str);
|
||||
while (str[++i])
|
||||
if (str[i] != '-' && str[i] != 'n')
|
||||
return (1);
|
||||
if (ft_strnstr(str, "n", ft_strlen(str)))
|
||||
*check = 1;
|
||||
return (0);
|
||||
}
|
||||
|
||||
int echo(int fd, char **strs)
|
||||
{
|
||||
int check;
|
||||
int i;
|
||||
char *str;
|
||||
|
||||
str = conca(strs);
|
||||
check = 0;
|
||||
i = 0;
|
||||
while (is_space(str[i]))
|
||||
i++;
|
||||
i = check_argument(str, &check, i);
|
||||
while (str[i])
|
||||
ft_putchar_fd(str[i++], fd);
|
||||
i = -1;
|
||||
while (strs[++i])
|
||||
{
|
||||
while (is_space(*strs[i]))
|
||||
strs[i]++;
|
||||
if (check == 1 || check_argument(strs[i], &check))
|
||||
{
|
||||
ft_putstr_fd(strs[i], fd);
|
||||
if (strs[i + 1] != NULL)
|
||||
write(fd, " ", 1);
|
||||
}
|
||||
}
|
||||
if (!check)
|
||||
write(fd, "\n", 1);
|
||||
free(str);
|
||||
return (0);
|
||||
}
|
||||
|
||||
/*int main(int argc, char *argv[])
|
||||
{
|
||||
echo(1, argv);
|
||||
echo(1, argv + 1);
|
||||
return (0);
|
||||
}*/
|
||||
|
23
env3.c
23
env3.c
@ -6,7 +6,7 @@
|
||||
/* By: erey-bet <marvin@42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2023/02/17 17:25:09 by erey-bet #+# #+# */
|
||||
/* Updated: 2023/02/21 14:09:42 by cchauvet ### ########.fr */
|
||||
/* Updated: 2023/02/22 01:41:04 by erey-bet ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@ -61,3 +61,24 @@ int create_value_by_key_dup(char *key, char *value, t_list **env)
|
||||
return (1);
|
||||
return (0);
|
||||
}
|
||||
|
||||
int delete_by_key(char *key, t_list **head)
|
||||
{
|
||||
t_list *last;
|
||||
t_list *current;
|
||||
|
||||
current = *head;
|
||||
while (current->next != NULL)
|
||||
{
|
||||
if (ft_strcmp(((t_env *)current->content)->key, key) == 0)
|
||||
{
|
||||
if (last->next != NULL)
|
||||
last->next = current->next;
|
||||
else
|
||||
*head = current->next;
|
||||
}
|
||||
last = current;
|
||||
current = current->next;
|
||||
}
|
||||
return (1);
|
||||
}
|
||||
|
@ -6,7 +6,7 @@
|
||||
/* By: cchauvet <cchauvet@student.42angoulem +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2023/02/14 13:45:30 by cchauvet #+# #+# */
|
||||
/* Updated: 2023/02/21 22:03:41 by cchauvet ### ########.fr */
|
||||
/* Updated: 2023/02/22 01:47:21 by erey-bet ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@ -65,6 +65,7 @@ void env_del(void *ptr);
|
||||
char **env_to_strs(t_list **head);
|
||||
char *get_value(char *str);
|
||||
char *get_key(char *str);
|
||||
int delete_by_key(char *key, t_list **head);
|
||||
|
||||
/* Echo */
|
||||
int echo(int fd, char **strs);
|
||||
|
Loading…
Reference in New Issue
Block a user