From f00e66cd06e678b133cc1d086ff5d1f620ec4941 Mon Sep 17 00:00:00 2001 From: salad Date: Mon, 27 Apr 2020 19:39:19 +0200 Subject: backslashes as intended, multiline quotes vont me tuer --- src/ft_b_echo.c | 33 +++++++++++++++++++++++++++++---- 1 file changed, 29 insertions(+), 4 deletions(-) (limited to 'src/ft_b_echo.c') diff --git a/src/ft_b_echo.c b/src/ft_b_echo.c index 6b410b3..7d21811 100644 --- a/src/ft_b_echo.c +++ b/src/ft_b_echo.c @@ -22,6 +22,22 @@ /* echo kill\nbackslash\nbut\nnot\nn, echo "quoted\nnew\nlines" */ /* Might need to go full buffer */ +void +ft_e_put(char *str, + uint8_t op) +{ + size_t i; + + i = -1; + if (op == 0) + while (str[++i]) + { + if (str[i] == '\\') + i++; + ft_putchar(str[i]); + } +} + char *ft_e_initb(char *ptr[], char *str) @@ -35,14 +51,16 @@ char { len += ft_strlen(ptr[i]); } - if (!(str = malloc(len * sizeof(char)))) + if (!(str = (char*)malloc(len * sizeof(char)))) return (NULL); return (str); } void -ft_e_fill(char *ptr[], char **str) + ft_e_fill(char *ptr[], char **str) { + char *bs; + ft_sprintf(*str, "%s", *ptr); ptr++; while (*ptr) @@ -50,7 +68,15 @@ ft_e_fill(char *ptr[], char **str) ft_sprintf(*str + ft_strlen(*str), " %s", *ptr); ptr++; } - *str = ft_strtrim(*str, "\"\'"); + if (*str[0] == '\"' || *str[0] == '\'') + { + *str = ft_strtrim(*str, "\"\'"); + ft_printf("%s", *str); + } + else if ((bs = ft_strrchr(*str, '\\'))) + { + ft_e_put(*str, 0); + } } uint8_t @@ -77,7 +103,6 @@ uint8_t if (argc - nopt >= 1) ft_e_fill(ptr, &str); } - ft_printf("%s", str); free(str); if (nopt == 0) ft_printf("\n"); -- cgit v1.2.3