pf_x.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /* ************************************************************************** */
  2. /* */
  3. /* ::: :::::::: */
  4. /* pf_x.c :+: :+: :+: */
  5. /* +:+ +:+ +:+ */
  6. /* By: bchanot <bchanot@students.42.fr> +#+ +:+ +#+ */
  7. /* +#+#+#+#+#+ +#+ */
  8. /* Created: 2016/02/27 01:56:52 by bchanot #+# #+# */
  9. /* Updated: 2017/04/15 00:43:31 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 (true);
  19. }
  20. else if (len < inf->width - (pf_hexulen(nb) + inf->di * 2))
  21. return (true);
  22. return (false);
  23. }
  24. static int pf_width_x(unsigned int nb, t_inf inf, int len)
  25. {
  26. int i;
  27. i = nb == 0 && inf.prec == -1 ? 0 : pf_hexlen(nb);
  28. if (inf.prec > i)
  29. {
  30. if (len < inf.width - (inf.prec + inf.di * 2))
  31. return (true);
  32. }
  33. else if (len < inf.width - (i + inf.di * 2))
  34. return (true);
  35. return (false);
  36. }
  37. static int pf_xlong(va_list ap, t_inf *inf)
  38. {
  39. long long unsigned int nb;
  40. int len;
  41. int cpt;
  42. nb = va_arg(ap, long long unsigned int);
  43. len = 0;
  44. if (inf->di == 1 && nb != 0 && inf->zero && !inf->prec)
  45. {
  46. inf->di = 0;
  47. len += pf_putstr("0x", inf->fd);
  48. }
  49. if (inf->width > 0 && inf->min == 0)
  50. while (pf_width_xl(nb, inf, len) && len++ >= 0)
  51. ft_putchar_fd((inf->zero && !inf->prec ? '0' : ' '), inf->fd);
  52. if (inf->di == 1 && nb != 0)
  53. len += pf_putstr("0x", inf->fd);
  54. cpt = -1;
  55. while (++cpt < inf->prec - pf_hexulen(nb) && len++ >= 0)
  56. ft_putchar_fd('0', inf->fd);
  57. return (pf_xlong2(len, inf, nb));
  58. }
  59. static int pf_x2(unsigned int nb, t_inf inf, int len)
  60. {
  61. len += pf_puthex(nb, inf.fd);
  62. if (inf.width > 0 && inf.min == 1)
  63. while (len < inf.width && len++ >= 0)
  64. ft_putchar_fd(' ', inf.fd);
  65. return (len);
  66. }
  67. int pf_x(va_list ap, t_inf inf)
  68. {
  69. unsigned int nb;
  70. int len;
  71. int cpt;
  72. if (inf.z || inf.l || inf.ll || inf.j)
  73. return (pf_xlong(ap, &inf));
  74. nb = inf.hh ? (unsigned char)va_arg(ap, unsigned int) :
  75. va_arg(ap, unsigned int);
  76. len = 0;
  77. if (inf.di == 1 && nb != 0 && inf.zero && !inf.prec)
  78. {
  79. inf.di = 0;
  80. len += pf_putstr("0x", inf.fd);
  81. }
  82. if (inf.width > 0 && inf.min == 0)
  83. while (pf_width_x(nb, inf, len) && len++ >= 0)
  84. ft_putchar_fd((inf.zero && !inf.prec ? '0' : ' '), inf.fd);
  85. if (inf.di == 1 && nb != 0)
  86. len += pf_putstr("0x", inf.fd);
  87. cpt = -1;
  88. while (++cpt < inf.prec - pf_hexlen(nb) && len++ >= 0)
  89. ft_putchar_fd('0', inf.fd);
  90. return (pf_x2(nb, inf, len));
  91. }