-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathft_printf_conversions_02_bonus.c
94 lines (88 loc) · 2.96 KB
/
ft_printf_conversions_02_bonus.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_printf_conversions_02_bonus.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: tmendes- <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/07/18 08:20:06 by tmendes- #+# #+# */
/* Updated: 2020/08/07 08:15:46 by tmendes- ### ########.fr */
/* */
/* ************************************************************************** */
#include "libftprintf_bonus.h"
static char *ld_signal(long double flt)
{
char *str;
if ((1 / flt) < 0)
str = ft_strdup("-");
else
str = ft_strdup("");
return (str);
}
t_printf e____type(t_printf ptf, t_fields fld, va_list ap)
{
if (fld.width < 0)
fld.flag[4] += 1;
fld.width = ft_abs(fld.width);
if (fld.prec < 0)
fld.prec = 6;
fld.flt = (long double)va_arg(ap, double);
fld.itg = nbr_exp(fld.flt, fld.prec);
ptf.txt = ld_signal(fld.flt);
fld.flt = ft_ldabs(fld.flt);
if (fld.prec >= fld.itg)
fld.str = ft_ftoa(fld.flt, (fld.prec - fld.itg), 'r');
else
fld.str = ft_ftoa(fld.flt, 1, 0);
fld.str = scntfc_not(fld.str, fld.prec);
ptf.txt = ft_concat(ptf.txt, fld.str);
free(fld.str);
fld.str = NULL;
if (fld.prec == 0 && fld.flag[0] == 0)
ptf.txt = unpad(ptf.txt, 'e');
ptf.txt = signal_space(ptf.txt, fld);
ptf.txt = pad_str(ptf.txt, fld, fld.width, 'w');
return (ptf);
}
static t_printf g_aux(t_printf ptf, t_fields fld)
{
fld.itg = nbr_exp(fld.flt, fld.prec);
*ptf.end = 'e';
ptf.txt = ld_signal(fld.flt);
fld.flt = ft_ldabs(fld.flt);
if (fld.prec >= (fld.itg + 1))
fld.str = ft_ftoa(fld.flt, (fld.prec - fld.itg - 1), 'r');
else
fld.str = ft_ftoa(fld.flt, 1, 0);
fld.str = scntfc_not(fld.str, fld.prec - 1);
if (fld.flag[0] == 0)
fld.str = unpad(fld.str, *ptf.end);
ptf.txt = ft_concat(ptf.txt, fld.str);
free(fld.str);
fld.str = NULL;
return (ptf);
}
t_printf g____type(t_printf ptf, t_fields fld, va_list ap)
{
if (fld.prec == 0)
fld.prec++;
if (fld.width < 0)
fld.flag[4] += 1;
fld.width = ft_abs(fld.width);
if (fld.prec < 0)
fld.prec = 6;
fld.flt = (long double)va_arg(ap, double);
fld.itg = nbr_exp(fld.flt, fld.prec);
fld.itg = nbr_exp((fld.flt + 5 *
(ft_ldabs(fld.flt) / fld.flt) *
ft_ld_pot_b(10, (fld.itg - fld.prec))), fld.prec);
if (fld.itg < -4 || fld.itg >= fld.prec)
ptf = g_aux(ptf, fld);
else
ptf.txt = ft_ftoa(fld.flt, fld.prec - (fld.itg + 1), 'r');
if (fld.flag[0] == 0 && *ptf.end != 'e')
ptf.txt = unpad(ptf.txt, 'f');
ptf.txt = signal_space(ptf.txt, fld);
ptf.txt = pad_str(ptf.txt, fld, fld.width, 'w');
return (ptf);
}