pf_u_up.c 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /* ************************************************************************** */
  2. /* */
  3. /* ::: :::::::: */
  4. /* pf_u_up.c :+: :+: :+: */
  5. /* +:+ +:+ +:+ */
  6. /* By: bchanot <bchanot@students.42.fr> +#+ +:+ +#+ */
  7. /* +#+#+#+#+#+ +#+ */
  8. /* Created: 2016/02/27 03:07:31 by bchanot #+# #+# */
  9. /* Updated: 2018/10/12 02:47:20 by bchanot ### ########.fr */
  10. /* */
  11. /* ************************************************************************** */
  12. #include "libftprintf.h"
  13. static int pf_width_u_up(long long unsigned int nb, t_inf inf, int len)
  14. {
  15. if (inf.prec > (int)ft_nbrulen(nb))
  16. {
  17. if (len < inf.width - inf.prec)
  18. return (true);
  19. }
  20. else if (len < inf.width - (int)ft_nbrulen(nb))
  21. return (true);
  22. return (false);
  23. }
  24. int pf_u_up(va_list ap, t_inf inf)
  25. {
  26. long long unsigned int nb;
  27. int len;
  28. int cpt;
  29. nb = va_arg(ap, long long unsigned int);
  30. len = 0;
  31. if (inf.width > 0 && inf.min == 0)
  32. while (pf_width_u_up(nb, inf, len) && len++ >= 0)
  33. ft_putchar_fd((inf.zero == 1 && inf.prec == 0 ? '0' : ' '), inf.fd);
  34. cpt = -1;
  35. while (++cpt < inf.prec - (int)ft_nbrulen(nb) && len++ >= 0)
  36. ft_putchar_fd('0', inf.fd);
  37. len += pf_putunbrlong(nb, inf.fd);
  38. if (inf.width > 0 && inf.min == 1)
  39. while (len < inf.width && len++ >= 0)
  40. ft_putchar_fd(' ', inf.fd);
  41. return (len);
  42. }