69 lines
1.7 KiB
C
69 lines
1.7 KiB
C
/* ************************************************************************** */
|
|
/* */
|
|
/* ::: :::::::: */
|
|
/* itoa.c :+: :+: :+: */
|
|
/* +:+ +:+ +:+ */
|
|
/* By: maiboyer <marvin@42.fr> +#+ +:+ +#+ */
|
|
/* +#+#+#+#+#+ +#+ */
|
|
/* Created: 2023/08/03 21:05:46 by maiboyer #+# #+# */
|
|
/* Updated: 2023/11/10 14:56:42 by maiboyer ### ########.fr */
|
|
/* */
|
|
/* ************************************************************************** */
|
|
|
|
#include "me/convert/itoa.h"
|
|
#include "me/mem/mem.h"
|
|
#include "me/str/str.h"
|
|
#include <stdlib.h>
|
|
|
|
static void me_itoa_inner(t_u64 nb, t_str out)
|
|
{
|
|
t_i32 modulus;
|
|
bool need_print;
|
|
char c;
|
|
t_usize idx;
|
|
|
|
need_print = false;
|
|
modulus = 1000000000;
|
|
idx = 0;
|
|
while (modulus)
|
|
{
|
|
c = (char)(nb / modulus) + '0';
|
|
if (c != '0' || need_print)
|
|
{
|
|
out[idx++] = c;
|
|
need_print = true;
|
|
}
|
|
nb = nb % modulus;
|
|
modulus /= 10;
|
|
}
|
|
}
|
|
|
|
t_str me_itoa(t_i32 nb)
|
|
{
|
|
char out[12];
|
|
t_u64 n;
|
|
|
|
n = (t_u64)nb;
|
|
mem_set(out, 0, 12);
|
|
if (nb < 0)
|
|
{
|
|
out[0] = '-';
|
|
me_itoa_inner(-n, out + 1);
|
|
}
|
|
else if (nb == 0)
|
|
out[0] = '0';
|
|
else
|
|
me_itoa_inner(n, out);
|
|
return (str_clone(out));
|
|
}
|
|
/*R
|
|
int main(void)
|
|
{
|
|
me_putnbr(-2147483648);
|
|
write(1, "\n", 1);
|
|
me_putnbr(0);
|
|
write(1, "\n", 1);
|
|
me_putnbr(12345);
|
|
return (0);
|
|
}
|
|
R*/
|