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
95
96
97
|
#include <libft.h>
#include <cub3d.h>
#include <stddef.h>
#include <stdlib.h>
static int
ft_linecpy(char *line, char *mapl, size_t start)
{
size_t i;
size_t j;
i = 0;
j = start;
while (i < ft_strlen(line) && line[i])
{
mapl[j] = line[i];
i += 2;
j++;
}
mapl[j] = '\n';
return (0);
}
static int
ft_check_err(char *line, size_t size)
{
size_t i;
i = 1;
if (ft_strlen(line) != size || line[0] != '1'
|| line[ft_strlen(line) - 1] != '1')
return (-1);
while (i < ft_strlen(line) && line[i])
{
if (line[i] != ' ')
return (-1);
i += 2;
}
return (0);
}
static char
*ft_get_first_line(char *line, t_cub *clist)
{
size_t len;
char *mapl;
len = ft_strlen(line);
if (len < 2 || ft_check_err(line, len) < 0)
return (NULL);
if (!(mapl = (char*)malloc(((len / 2) + 2) * sizeof(char))))
return (NULL);
ft_linecpy(line, mapl, 0);
ft_memdel(line);
clist->map_width = len;
return (mapl);
}
int
ft_get_map(int fd, t_cub *clist)
{
size_t i;
size_t len;
int ret;
char *line;
char *mapl;
if (get_next_line(fd, &line) <= 0 ||
!(mapl = ft_get_first_line(line, clist)))
{
ft_memdel(line);
return (-1);
}
i = 1;
ret = 1;
len = clist->map_width;
while (ret > 0)
{
ret = get_next_line(fd, &line);
if (ft_check_err(line, len) < 0)
{
ft_memdel(line);
ft_memdel(mapl);
return (-1);
}
mapl = (char*)ft_nrealloc(mapl, (((len / 2) + 2) * i) * sizeof(char),
((((len / 2) + 2) * i) + (len / 2) + 2) * sizeof(char));
ft_linecpy(line, mapl, ((len / 2) + 2) * i);
ft_memdel(line);
i++;
}
mapl[(i * ((len / 2) + 2)) - 1] = '\0';
ft_free_words(clist->map, NULL);
clist->map = ft_split(mapl, '\n');
ft_memdel(mapl);
return (0);
}
|