-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathft_printf_format_01_bonus.c
68 lines (63 loc) · 1.87 KB
/
ft_printf_format_01_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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_printf_format_01_bonus.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: tmendes- <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/07/18 08:20:06 by tmendes- #+# #+# */
/* Updated: 2020/08/07 08:16:18 by tmendes- ### ########.fr */
/* */
/* ************************************************************************** */
#include "libftprintf_bonus.h"
static char *repeat_chr(char chr, int nbr)
{
char *str;
int k;
if (!(str = (char *)malloc((nbr + 1) * sizeof(char))))
return (NULL);
k = 0;
while (k < nbr)
{
*(str + k) = chr;
k++;
}
*(str + k) = 0;
return (str);
}
static char *pad_aux(char *str, t_fields fld, char chr)
{
if ((*fld.str == '-' || *fld.str == '+' ||
*fld.str == ' ') && chr == 'p')
fld.itg++;
if (!(str = repeat_chr('0', fld.itg)))
return (NULL);
if ((*fld.str == '-' || *fld.str == ' ' ||
*fld.str == '+') && fld.itg != 0)
{
*str = *fld.str;
*fld.str = '0';
}
return (str);
}
char *pad_str(char *str, t_fields fld, int len, char chr)
{
fld.itg = len - ft_strlen(str);
if (fld.itg >= 0)
{
if (fld.flag[4] && chr != 'p')
fld.str = repeat_chr(' ', fld.itg);
else
{
fld.str = str;
if (fld.flag[3])
str = pad_aux(str, fld, chr);
else
str = repeat_chr(' ', fld.itg);
}
str = ft_concat(str, fld.str);
free(fld.str);
fld.str = NULL;
}
return (str);
}