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
|
#include <libft.h>
#include <cub3d.h>
#include <stddef.h>
#include <stdlib.h>
/* static char */
/* **ft_split_lines(char *line, int count) */
/* { */
/* } */
static int
ft_linecpy(char *line, char *mapL)
{
size_t i;
i = 0;
while (i < ft_strlen(line))
{
mapL[i] = line[i];
i += 2;
}
mapL[i + 1] = '\n';
return (0);
}
static int
ft_check_err(char *line, size_t size, t_win *wlist)
{
size_t i;
i = 1;
if (ft_strlen(line) != size)
return (-1);
while (i < ft_strlen(line) && line[i])
{
if (line[i] != ' ')
return (ft_map_error(11, wlist));
i += 2;
}
return (0);
}
int
ft_get_map(int fd, t_win *wlist)
{
size_t i;
size_t len;
char *line;
char *mapL;
/* ft_free_words(wlist->clist->map, NULL); */
/* if (!(wlist->clist->map = (char**)malloc(40 * sizeof(char*)))) */
/* return (-1); */
if (get_next_line(fd, &line) > 0)
{
len = ft_strlen(line);
ft_check_err(line, len, wlist);
if (!(mapL = (char*)malloc((len + 1) * sizeof(char))))
ft_linecpy(line, mapL);
ft_memdel(line);
}
else
return (-1);
i = 1;
while (get_next_line(fd, &line) > 0)
{
ft_check_err(line, len, wlist);
mapL = (char*)ft_nrealloc(mapL, ((len + 1) * i) * sizeof(char), (((len + 1) * i) + ft_strlen(line) + 1) * sizeof(char));
ft_linecpy(line, mapL);
ft_memdel(line);
i++;
}
mapL[(i * (len + 1)) + 1] = '\0';
ft_printf("mapL [%s]\n", mapL);
wlist->clist->map = ft_split(mapL, '\n');
ft_memdel(mapL);
return (0);
}
|