Improve hexadecimal and pointer by using ltoa instead of itoa
This commit is contained in:
5
Makefile
5
Makefile
@@ -6,7 +6,7 @@
|
||||
# By: gbaconni@student.42lausanne.ch +#+ +:+ +#+ #
|
||||
# +#+#+#+#+#+ +#+ #
|
||||
# Created: 2022/01/18 15:11:16 by gbaconni #+# #+# #
|
||||
# Updated: 2022/04/15 17:19:14 by gbaconni ### lausanne.ch #
|
||||
# Updated: 2022/04/15 20:37:26 by gbaconni ### lausanne.ch #
|
||||
# #
|
||||
# **************************************************************************** #
|
||||
#
|
||||
@@ -88,9 +88,10 @@ test: clean $(NAME)
|
||||
@$(PREFIX) ./$(NAME) "%d" 42 || true
|
||||
@$(PREFIX) ./$(NAME) "%x" 42 || true
|
||||
@$(PREFIX) ./$(NAME) "%X" 42 || true
|
||||
@$(PREFIX) ./$(NAME) "42" "" || true
|
||||
@$(PREFIX) ./$(NAME) "%%" "" || true
|
||||
@$(PREFIX) ./$(NAME) "%p" "" || true
|
||||
@$(PREFIX) ./$(NAME) "%p" "\n" || true
|
||||
@$(PREFIX) ./$(NAME) "Forty Two" "" || true
|
||||
|
||||
test2: leak
|
||||
@$(MAKE) test LEAK=1
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
# By: gbaconni@student.42lausanne.ch +#+ +:+ +#+ #
|
||||
# +#+#+#+#+#+ +#+ #
|
||||
# Created: 2022/01/18 15:11:16 by gbaconni #+# #+# #
|
||||
# Updated: 2022/04/15 17:19:30 by gbaconni ### lausanne.ch #
|
||||
# Updated: 2022/04/15 20:19:14 by gbaconni ### lausanne.ch #
|
||||
# #
|
||||
# **************************************************************************** #
|
||||
#
|
||||
@@ -30,7 +30,7 @@ SRC = \
|
||||
$(LIBFT)/ft_calloc.c \
|
||||
$(LIBFT)/ft_strlen.c \
|
||||
$(LIBFT)/ft_itoa.c \
|
||||
ft_itoa_base.c \
|
||||
ft_ltoa_base.c \
|
||||
ft_vprintf_char.c \
|
||||
ft_vprintf_string.c \
|
||||
ft_vprintf_pointer.c \
|
||||
|
||||
@@ -1,21 +1,21 @@
|
||||
/* ************************************************************************** */
|
||||
/* */
|
||||
/* ::: :::::::: */
|
||||
/* ft_itoa_base.c :+: :+: :+: */
|
||||
/* ft_ltoa_base.c :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2021/08/16 13:51:16 by gbaconni #+# #+# */
|
||||
/* Updated: 2022/04/15 00:08:27 by gbaconni ### lausanne.ch */
|
||||
/* Updated: 2022/04/15 20:20:23 by gbaconni ### lausanne.ch */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include "libftprintf.h"
|
||||
|
||||
static int ft_intlen_base(int n, int nbase);
|
||||
static long ft_longlen_base(long n, long nbase);
|
||||
static char *ft_strrev(char *s);
|
||||
|
||||
char *ft_itoa_base(int n, char *base)
|
||||
char *ft_ltoa_base(long n, char *base)
|
||||
{
|
||||
char *s;
|
||||
int i;
|
||||
@@ -23,7 +23,7 @@ char *ft_itoa_base(int n, char *base)
|
||||
long nbase;
|
||||
|
||||
nbase = ft_strlen(base);
|
||||
s = (char *) ft_calloc((ft_intlen_base(n, nbase) + 1), sizeof(char));
|
||||
s = (char *) ft_calloc((ft_longlen_base(n, nbase) + 1), sizeof(char));
|
||||
if (s == NULL)
|
||||
return (NULL);
|
||||
i = 0;
|
||||
@@ -43,7 +43,7 @@ char *ft_itoa_base(int n, char *base)
|
||||
return (ft_strrev(s));
|
||||
}
|
||||
|
||||
static int ft_intlen_base(int n, int nbase)
|
||||
static long ft_longlen_base(long n, long nbase)
|
||||
{
|
||||
size_t len;
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: gbaconni@student.42lausanne.ch +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/01/20 11:43:52 by gbaconni #+# #+# */
|
||||
/* Updated: 2022/04/15 16:37:06 by gbaconni ### lausanne.ch */
|
||||
/* Updated: 2022/04/15 20:44:24 by gbaconni ### lausanne.ch */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: gbaconni@student.42lausanne.ch +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/01/20 11:55:33 by gbaconni #+# #+# */
|
||||
/* Updated: 2022/04/15 00:13:02 by gbaconni ### lausanne.ch */
|
||||
/* Updated: 2022/04/15 20:22:19 by gbaconni ### lausanne.ch */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -16,17 +16,17 @@ int ft_vprintf_hexadecimal(const char *format, va_list ap)
|
||||
{
|
||||
int ret;
|
||||
int len;
|
||||
int d;
|
||||
long l;
|
||||
char *s;
|
||||
|
||||
(void) format;
|
||||
ret = 0;
|
||||
len = 0;
|
||||
d = va_arg(ap, int);
|
||||
l = va_arg(ap, long);
|
||||
if (format[0] == 'x')
|
||||
s = ft_itoa_base(d, "0123456789abcdef");
|
||||
s = ft_ltoa_base(l, "0123456789abcdef");
|
||||
else
|
||||
s = ft_itoa_base(d, "0123456789ABCDEF");
|
||||
s = ft_ltoa_base(l, "0123456789ABCDEF");
|
||||
len = ft_strlen(s);
|
||||
write(1, s, len);
|
||||
ret += len;
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: gbaconni@student.42lausanne.ch +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/01/20 11:56:16 by gbaconni #+# #+# */
|
||||
/* Updated: 2022/04/15 17:12:36 by gbaconni ### lausanne.ch */
|
||||
/* Updated: 2022/04/15 20:54:31 by gbaconni ### lausanne.ch */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -29,10 +29,11 @@ int ft_vprintf_pointer(const char *format, va_list ap)
|
||||
write(1, NIL, len);
|
||||
return (len);
|
||||
}
|
||||
s = ft_itoa_base((unsigned long) p, "0123456789ABCDEF");
|
||||
s = ft_ltoa_base((long) p, "0123456789abcdef");
|
||||
len = ft_strlen(s);
|
||||
write(1, "0x", 2);
|
||||
write(1, s, len);
|
||||
ret += len;
|
||||
ret += len + 2;
|
||||
free(s);
|
||||
return (ret);
|
||||
}
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: gbaconni@student.42lausanne.ch +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/01/18 15:26:06 by gbaconni #+# #+# */
|
||||
/* Updated: 2022/04/15 16:50:38 by gbaconni ### lausanne.ch */
|
||||
/* Updated: 2022/04/15 20:20:35 by gbaconni ### lausanne.ch */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -25,7 +25,7 @@
|
||||
|
||||
/* Helper */
|
||||
|
||||
char *ft_itoa_base(int n, char *base);
|
||||
char *ft_ltoa_base(long n, char *base);
|
||||
|
||||
/* Mandatory */
|
||||
|
||||
|
||||
44
main.c
44
main.c
@@ -6,7 +6,7 @@
|
||||
/* By: baco <baco@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/04/13 06:58:46 by gbaconni #+# #+# */
|
||||
/* Updated: 2022/04/15 17:19:36 by gbaconni ### lausanne.ch */
|
||||
/* Updated: 2022/04/15 20:48:55 by gbaconni ### lausanne.ch */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -87,15 +87,9 @@ int main(int argc, char *argv[])
|
||||
if (argc > 1)
|
||||
{
|
||||
format = argv[1];
|
||||
if (isnumber(argv[2]))
|
||||
if (format[0] == '%')
|
||||
{
|
||||
d = atoi(argv[2]);
|
||||
ret = printf(format, d);
|
||||
printf(": %d = printf(\"%s\", %d)\n", ret, format, d);
|
||||
ret = ft_printf(format, d);
|
||||
printf(": %d = ft_printf(\"%s\", %d)\n", ret, format, d);
|
||||
}
|
||||
else if (ft_strlen(argv[2]) == 1 && isalnum(argv[2][0]))
|
||||
if (format[1] == 'c')
|
||||
{
|
||||
c = argv[2][0];
|
||||
ret = printf(format, c);
|
||||
@@ -103,7 +97,7 @@ int main(int argc, char *argv[])
|
||||
ret = ft_printf(format, c);
|
||||
printf(": %d = ft_printf(\"%s\", '%c')\n", ret, format, c);
|
||||
}
|
||||
else if (ft_strlen(argv[2]) > 1 && isstring(argv[2]))
|
||||
else if (format[1] == 's')
|
||||
{
|
||||
s = argv[2];
|
||||
ret = printf(format, s);
|
||||
@@ -111,17 +105,43 @@ int main(int argc, char *argv[])
|
||||
ret = ft_printf(format, s);
|
||||
printf(": %d = ft_printf(\"%s\", \"%s\")\n", ret, format, s);
|
||||
}
|
||||
else if (ft_strlen(argv[2]) == 0)
|
||||
else if (format[1] == 'p')
|
||||
{
|
||||
s = argv[2];
|
||||
if (ft_strlen(s) == 0)
|
||||
{
|
||||
s = NULL;
|
||||
ptr = NULL;
|
||||
}
|
||||
ret = printf(format, ptr);
|
||||
printf(": %d = printf(\"%s\", \"%s\")\n", ret, format, s);
|
||||
ret = ft_printf(format, ptr);
|
||||
printf(": %d = ft_printf(\"%s\", \"%s\")\n", ret, format, s);
|
||||
}
|
||||
else if (format[1] == 'd' || format[1] == 'i' || format[1] == 'u')
|
||||
{
|
||||
d = atoi(argv[2]);
|
||||
ret = printf(format, d);
|
||||
printf(": %d = printf(\"%s\", %d)\n", ret, format, d);
|
||||
ret = ft_printf(format, d);
|
||||
printf(": %d = ft_printf(\"%s\", %d)\n", ret, format, d);
|
||||
}
|
||||
else if (format[1] == 'x' || format[1] == 'X')
|
||||
{
|
||||
d = atoi(argv[2]);
|
||||
ret = printf(format, d);
|
||||
printf(": %d = printf(\"%s\", %d)\n", ret, format, d);
|
||||
ret = ft_printf(format, d);
|
||||
printf(": %d = ft_printf(\"%s\", %d)\n", ret, format, d);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
printf("Error: invalid argument\n");
|
||||
s = argv[2];
|
||||
ret = printf(format, s);
|
||||
printf(": %d = printf(\"%s\", \"%s\")\n", ret, format, s);
|
||||
ret = ft_printf(format, s);
|
||||
printf(": %d = ft_printf(\"%s\", \"%s\")\n", ret, format, s);
|
||||
}
|
||||
}
|
||||
return (0);
|
||||
|
||||
Reference in New Issue
Block a user