diff options
Diffstat (limited to 'src/ft_b_echo.c')
-rw-r--r-- | src/ft_b_echo.c | 33 |
1 files changed, 29 insertions, 4 deletions
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"); |