/
ft_dynalloc.c
78 lines (68 loc) · 1.85 KB
/
ft_dynalloc.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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_dynalloc.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: mghazari <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/01/11 14:17:32 by mghazari #+# #+# */
/* Updated: 2017/01/19 04:00:37 by mghazari ### ########.fr */
/* */
/* ************************************************************************** */
#include "fillit.h"
static int get_v(char *array[])
{
int i;
i = -1;
while (array[++i])
continue;
return (i);
}
char **ft_malloc2d(int x, int y)
{
char **array;
int i;
i = -1;
while (!(array = (char**)ft_memalloc(sizeof(char*) * (y + 1))))
continue;
while (++i < y)
{
while (!(array[i] = ft_strnew(x)))
continue;
ft_memset((void*)array[i], (int)'.', x);
}
return (array);
}
char ***ft_malloc3d(int x, int y, int z)
{
char ***array;
int i;
i = -1;
while (!(array = ft_memalloc(sizeof(char**) * (z + 1))))
continue;
while (++i < z)
while (!(array[i] = ft_malloc2d(x, y)))
continue;
return (array);
}
char **new_2d_cpy(char *actual[])
{
char **array;
int i;
int y;
y = get_v(actual);
i = -1;
while (!(array = (char**)ft_memalloc(sizeof(char*) * (y + 1))))
continue;
while (++i < y)
{
while (!(array[i] = ft_strdup(actual[i])))
continue;
}
return (array);
}
char **restore(char *actual[], char *cpy[])
{
actual = cpy;
return (actual);
}