pf_x_up.c 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /* ************************************************************************** */
  2. /* */
  3. /* ::: :::::::: */
  4. /* pf_x_up.c :+: :+: :+: */
  5. /* +:+ +:+ +:+ */
  6. /* By: bchanot <bchanot@students.42.fr> +#+ +:+ +#+ */
  7. /* +#+#+#+#+#+ +#+ */
  8. /* Created: 2016/02/27 01:57:47 by bchanot #+# #+# */
  9. /* Updated: 2016/05/29 03:51:43 by bchanot ### ########.fr */
  10. /* */
  11. /* ************************************************************************** */
  12. #include "libftprintf.h"
  13. static int pf_width_xl(long long unsigned int nb, t_inf *inf, int len)
  14. {
  15. if (inf->prec > pf_hexulen(nb))
  16. {
  17. if (len < inf->width - (inf->prec + inf->di * 2))
  18. return (1);
  19. }
  20. else if (len < inf->width - (pf_hexulen(nb) + inf->di * 2))
  21. return (1);
  22. return (0);
  23. }
  24. static int pf_width_x(unsigned int nb, t_inf inf, int len)
  25. {
  26. if (inf.prec > pf_hexlen(nb))
  27. {
  28. if (len < inf.width - (inf.prec + inf.di * 2))
  29. return (1);
  30. }
  31. else if (len < inf.width - (pf_hexlen(nb) + inf.di * 2))
  32. return (1);
  33. return (0);
  34. }
  35. static int pf_x_uplong(va_list ap, t_inf *inf)
  36. {
  37. long long unsigned int nb;
  38. int len;
  39. int cpt;
  40. nb = va_arg(ap, long long unsigned int);
  41. len = 0;
  42. if (inf->di == 1 && nb != 0 && inf->zero && !inf->prec)
  43. {
  44. inf->di = 0;
  45. len += pf_putstr("0X", inf->fd);
  46. }
  47. if (inf->width > 0 && inf->min == 0)
  48. while (pf_width_xl(nb, inf, len) && len++ >= 0)
  49. ft_putchar_fd((inf->zero && !inf->prec ? '0' : ' '), inf->fd);
  50. if (inf->di == 1 && nb != 0)
  51. len += pf_putstr("0X", inf->fd);
  52. cpt = -1;
  53. while (++cpt < inf->prec - pf_hexulen(nb) && len++ >= 0)
  54. ft_putchar_fd('0', inf->fd);
  55. return (pf_x_uplong2(len, inf, nb));
  56. }
  57. static int pf_x_up2(unsigned int nb, t_inf inf, int len)
  58. {
  59. len += pf_puthexm(nb, inf.fd);
  60. if (inf.width > 0 && inf.min == 1)
  61. while (len < inf.width && len++ >= 0)
  62. ft_putchar_fd(' ', inf.fd);
  63. return (len);
  64. }
  65. int pf_x_up(va_list ap, t_inf inf)
  66. {
  67. unsigned int nb;
  68. int len;
  69. int cpt;
  70. if (inf.z || inf.l || inf.ll || inf.j)
  71. return (pf_x_uplong(ap, &inf));
  72. nb = inf.hh ? (unsigned char)va_arg(ap, unsigned int) :
  73. va_arg(ap, unsigned int);
  74. len = 0;
  75. if (inf.di == 1 && nb != 0 && inf.zero && !inf.prec)
  76. {
  77. inf.di = 0;
  78. len += pf_putstr("0X", inf.fd);
  79. }
  80. if (inf.width > 0 && inf.min == 0)
  81. while (pf_width_x(nb, inf, len) && len++ >= 0)
  82. ft_putchar_fd((inf.zero && !inf.prec ? '0' : ' '), inf.fd);
  83. if (inf.di == 1 && nb != 0)
  84. len += pf_putstr("0X", inf.fd);
  85. cpt = -1;
  86. while (++cpt < inf.prec - pf_hexlen(nb) && len++ >= 0)
  87. ft_putchar_fd('0', inf.fd);
  88. return (pf_x_up2(nb, inf, len));
  89. }