/* ************************************************************************** */ /* LE - / */ /* / */ /* ft_itoa.c .:: .:/ . .:: */ /* +:+:+ +: +: +:+:+ */ /* By: rbousset <marvin@le-101.fr> +:+ +: +: +:+ */ /* #+# #+ #+ #+# */ /* Created: 2019/10/13 02:22:48 by rbousset #+# ## ## #+# */ /* Updated: 2019/10/13 13:35:46 by rbousset ### #+. /#+ ###.fr */ /* / */ /* / */ /* ************************************************************************** */ #include "libft.h" #include <inttypes.h> #include <stdlib.h> static uint8_t ft_intlen(int n) { uint8_t len; len = 0; if (!n) return (1); if (n < 0) len = 1; while (n != 0) { n /= 10; len++; } return (len); } char *ft_itoa(int n) { char *s; unsigned int nb; uint8_t i; i = ft_intlen(n) - 1; if (!(s = (char*)malloc((i + 2) * sizeof(char)))) return (NULL); if (!n) s[i] = '0'; nb = n; if (n < 0) { s[0] = '-'; nb = -n; } s[i + 1] = '\0'; while (nb > 0) { s[i] = 48 + (nb % 10); nb = nb / 10; i--; } return (s); }