pf_x.c 3.0 KB

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