Files
ft_printf/libftprintf/ft_vprintf_decimal.c

56 lines
1.5 KiB
C
Raw Normal View History

2022-04-13 08:01:46 +02:00
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_vprintf_decimal.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: gbaconni@student.42lausanne.ch +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/01/20 11:55:02 by gbaconni #+# #+# */
/* Updated: 2022/04/29 10:59:23 by gbaconni ### ########.fr */
2022-04-13 08:01:46 +02:00
/* */
/* ************************************************************************** */
#include "libftprintf.h"
int ft_vprintf_decimal(const char *format, va_list ap)
{
2022-04-17 09:59:41 +02:00
int ret;
unsigned int u;
int d;
char *s;
2022-04-26 17:53:39 +02:00
char c;
2022-04-13 08:01:46 +02:00
2022-04-26 17:53:39 +02:00
ret = 0;
c = *(format + ft_eoflags(format));
if (c == 'u')
2022-04-17 09:59:41 +02:00
{
u = va_arg(ap, unsigned int);
s = ft_ltoa_base((long) u, "0123456789");
}
else
{
d = va_arg(ap, int);
s = ft_itoa(d);
}
#ifdef BONUS
2022-04-26 17:53:39 +02:00
int precision;
int len;
precision = ft_vprintf_precision_bonus(format, ap);
2022-04-26 17:53:39 +02:00
len = 0;
if (precision > 0)
{
len = precision - ft_strlen(s);
while (len-- > 0)
2022-04-26 17:53:39 +02:00
{
if (flags & F_ZERO)
ret += ft_putchar('0');
else
ret += ft_putchar(' ');
}
}
#endif
2022-04-26 17:53:39 +02:00
ret += ft_puts(s);
2022-04-13 08:01:46 +02:00
free(s);
return (ret);
}