pf_u.c 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /* ************************************************************************** */
  2. /* */
  3. /* ::: :::::::: */
  4. /* pf_u.c :+: :+: :+: */
  5. /* +:+ +:+ +:+ */
  6. /* By: bchanot <bchanot@students.42.fr> +#+ +:+ +#+ */
  7. /* +#+#+#+#+#+ +#+ */
  8. /* Created: 2016/02/27 01:55:55 by bchanot #+# #+# */
  9. /* Updated: 2016/06/13 21:57:29 by bchanot ### ########.fr */
  10. /* */
  11. /* ************************************************************************** */
  12. #include "libftprintf.h"
  13. static int pf_width_u(unsigned int nb, t_inf inf, int len)
  14. {
  15. int i;
  16. i = nb == 0 && inf.prec == -1 ? 0 : ft_nbrulen(nb);
  17. if (inf.prec > ft_nbrulen(nb))
  18. {
  19. if (len < inf.width - inf.prec)
  20. return (1);
  21. }
  22. else if (len < inf.width - ft_nbrulen(nb))
  23. return (1);
  24. return (0);
  25. }
  26. int pf_u(va_list ap, t_inf inf)
  27. {
  28. unsigned int nb;
  29. int len;
  30. int cpt;
  31. if (inf.l || inf.ll || inf.z || inf.j)
  32. return (pf_u_up(ap, inf));
  33. if (inf.h || inf.hh)
  34. nb = inf.hh ? (unsigned char)va_arg(ap, unsigned int) :
  35. (unsigned short)va_arg(ap, unsigned int);
  36. else
  37. nb = va_arg(ap, unsigned int);
  38. len = 0;
  39. if (inf.width > 0 && inf.min == 0)
  40. while (pf_width_u(nb, inf, len) && len++ >= 0)
  41. ft_putchar_fd((inf.zero == 1 && inf.prec == 0 ? '0' : ' '), inf.fd);
  42. cpt = -1;
  43. while (++cpt < inf.prec - ft_nbrulen(nb) && len++ >= 0)
  44. ft_putchar_fd('0', inf.fd);
  45. len += pf_putunbr(nb, inf.fd);
  46. if (inf.width > 0 && inf.min == 1)
  47. while (len < inf.width && len++ >= 0)
  48. ft_putchar_fd(' ', inf.fd);
  49. return (len);
  50. }