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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
#include <libft.h>
#include <cub3d.h>
#include <stdlib.h>
static int
ft_get_tex_no(int fd, t_cub *clist)
{
char *line;
char **words;
if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' ')))
{
ft_memdel(line);
return (ft_map_error(2, clist));
}
if (!(*words) || ft_strcmp(*words, "NO")
|| !(*(words + 1)) || (*(words + 2)))
{
ft_free_words(words, line);
return (ft_map_error(2, clist));
}
ft_memdel(clist->no_tex_path);
if (!(clist->no_tex_path = ft_strdup(*(words + 1))))
{
ft_free_words(words, line);
return (-1);
}
ft_free_words(words, line);
return (0);
}
static int
ft_get_tex_so(int fd, t_cub *clist)
{
char *line;
char **words;
if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' ')))
{
ft_memdel(line);
return (ft_map_error(3, clist));
}
if (!(*words) || ft_strcmp(*words, "SO")
|| !(*(words + 1)) || (*(words + 2)))
{
ft_free_words(words, line);
return (ft_map_error(3, clist));
}
ft_memdel(clist->so_tex_path);
if (!(clist->so_tex_path = ft_strdup(*(words + 1))))
{
ft_free_words(words, line);
return (-1);
}
ft_free_words(words, line);
return (0);
}
static int
ft_get_tex_we(int fd, t_cub *clist)
{
char *line;
char **words;
if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' ')))
{
ft_memdel(line);
return (ft_map_error(4, clist));
}
if (!(*words) || ft_strcmp(*words, "WE")
|| !(*(words + 1)) || (*(words + 2)))
{
ft_free_words(words, line);
return (ft_map_error(4, clist));
}
ft_memdel(clist->we_tex_path);
if (!(clist->we_tex_path = ft_strdup(*(words + 1))))
{
ft_free_words(words, line);
return (-1);
}
ft_free_words(words, line);
return (0);
}
static int
ft_get_tex_ea(int fd, t_cub *clist)
{
char *line;
char **words;
if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' ')))
{
ft_memdel(line);
return (ft_map_error(5, clist));
}
if (!(*words) || ft_strcmp(*words, "EA")
|| !(*(words + 1)) || (*(words + 2)))
{
ft_free_words(words, line);
return (ft_map_error(5, clist));
}
ft_memdel(clist->ea_tex_path);
if (!(clist->ea_tex_path = ft_strdup(*(words + 1))))
{
ft_free_words(words, line);
return (-1);
}
ft_free_words(words, line);
return (0);
}
int
ft_get_tex(int fd, t_cub *clist)
{
if (ft_get_tex_no(fd, clist) < 0 ||
ft_get_tex_so(fd, clist) < 0 ||
ft_get_tex_we(fd, clist) < 0 ||
ft_get_tex_ea(fd, clist) < 0)
return (-1);
return (0);
}
|