From c1f8a414ad01c4c2863ebef3b81d79f3c40b2da5 Mon Sep 17 00:00:00 2001 From: JozanLeClerc Date: Sat, 19 Sep 2020 14:40:37 +0200 Subject: Added retval as an option for the prompt with \? --- libft/Makefile | 2 ++ libft/include/libft.h | 2 ++ libft/src/ft_itoa.c | 3 +-- libft/src/ft_itoa_s.c | 37 +++++++++++++++++++++++++++++++++++++ libft/src/ft_uitoa.c | 3 +-- libft/src/ft_uitoa_s.c | 32 ++++++++++++++++++++++++++++++++ src/m_prompt.c | 5 +++++ 7 files changed, 80 insertions(+), 4 deletions(-) create mode 100644 libft/src/ft_itoa_s.c create mode 100644 libft/src/ft_uitoa_s.c diff --git a/libft/Makefile b/libft/Makefile index 3c11199..1c90f66 100644 --- a/libft/Makefile +++ b/libft/Makefile @@ -52,8 +52,10 @@ SRCS_NAME += ft_strjoin.c SRCS_NAME += ft_strtrim.c SRCS_NAME += ft_split.c SRCS_NAME += ft_itoa.c +SRCS_NAME += ft_itoa_s.c SRCS_NAME += ft_itoa_base.c SRCS_NAME += ft_uitoa.c +SRCS_NAME += ft_uitoa_s.c SRCS_NAME += ft_uitoa_base.c SRCS_NAME += ft_strmapi.c SRCS_NAME += ft_putchar_fd.c diff --git a/libft/include/libft.h b/libft/include/libft.h index c31482c..edd04d4 100644 --- a/libft/include/libft.h +++ b/libft/include/libft.h @@ -90,6 +90,8 @@ void ft_putnbr(long nb); void ft_putnbr_base(long nb, char *base); void ft_memdel(void **ptr); void ft_delwords(char **words); +void ft_itoa_s(char str[], long n); +void ft_uitoa_s(char str[], unsigned long n); void *ft_memset(void *b, int c, size_t len); void *ft_memcpy(void *dst, const void *src, size_t n); void *ft_memccpy(void *dst, const void *src, diff --git a/libft/src/ft_itoa.c b/libft/src/ft_itoa.c index e10fbab..255d0a8 100644 --- a/libft/src/ft_itoa.c +++ b/libft/src/ft_itoa.c @@ -14,8 +14,7 @@ #include #include -char - *ft_itoa(long n) +char *ft_itoa(long n) { char *s; long nb; diff --git a/libft/src/ft_itoa_s.c b/libft/src/ft_itoa_s.c new file mode 100644 index 0000000..68b6ae3 --- /dev/null +++ b/libft/src/ft_itoa_s.c @@ -0,0 +1,37 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_itoa_s.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:06:40 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:06:40 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include +#include + +void ft_itoa_s(char str[], long n) +{ + long nb; + uint8_t i; + + i = ft_intlen(n) - 1; + if (!n) + str[i] = '0'; + nb = n; + if (n < 0) + { + str[0] = '-'; + nb = -n; + } + str[i + 1] = '\0'; + while (nb > 0) + { + str[i] = 48 + (nb % 10); + nb = nb / 10; + i--; + } +} diff --git a/libft/src/ft_uitoa.c b/libft/src/ft_uitoa.c index f1a5fa2..cc41d91 100644 --- a/libft/src/ft_uitoa.c +++ b/libft/src/ft_uitoa.c @@ -14,8 +14,7 @@ #include #include -char - *ft_uitoa(unsigned long n) +char *ft_uitoa(unsigned long n) { char *s; unsigned long nb; diff --git a/libft/src/ft_uitoa_s.c b/libft/src/ft_uitoa_s.c new file mode 100644 index 0000000..e030c34 --- /dev/null +++ b/libft/src/ft_uitoa_s.c @@ -0,0 +1,32 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_uitoa_s.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:07:18 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:07:18 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include +#include + +void ft_uitoa_s(char str[], unsigned long n) +{ + unsigned long nb; + uint8_t i; + + i = ft_uintlen(n) - 1; + if (!n) + str[i] = '0'; + nb = n; + str[i + 1] = '\0'; + while (nb > 0) + { + str[i] = 48 + (nb % 10); + nb = nb / 10; + i--; + } +} diff --git a/src/m_prompt.c b/src/m_prompt.c index 5278c42..a7c257d 100644 --- a/src/m_prompt.c +++ b/src/m_prompt.c @@ -79,6 +79,11 @@ static char ft_strsubst_s(var, "\\v", FT_MSH_VERSION); else if (var[i + 1] == 's') ft_strsubst_s(var, "\\s", FT_PROGNAME); + else if (var[i + 1] == '?') + { + ft_uitoa_s(tmp, msh->ret); + ft_strsubst_s(var, "\\?", tmp); + } } i++; } -- cgit v1.2.3