aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ft_get_sprite.c29
-rw-r--r--src/ft_get_sprite_tex.c2
-rw-r--r--src/ft_get_tex.c111
-rw-r--r--src/ft_parse_map.c4
-rw-r--r--src/ft_select_get.c19
5 files changed, 69 insertions, 96 deletions
diff --git a/src/ft_get_sprite.c b/src/ft_get_sprite.c
new file mode 100644
index 0000000..568e513
--- /dev/null
+++ b/src/ft_get_sprite.c
@@ -0,0 +1,29 @@
+#include <libft.h>
+#include <cub3d.h>
+#include <stdlib.h>
+
+int
+ft_get_sprite(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(7, clist));
+ }
+ if (!(*words) || ft_strcmp(*words, "S") || !words[1] || words[2])
+ {
+ ft_free_words(words, line);
+ return (ft_map_error(7, clist));
+ }
+ ft_memdel(clist->sprite_path);
+ if (!(clist->sprite_path = ft_strdup(*(words + 1))))
+ {
+ ft_free_words(words, line);
+ return (-1);
+ }
+ ft_free_words(words, line);
+ return (0);
+}
diff --git a/src/ft_get_sprite_tex.c b/src/ft_get_sprite_tex.c
index 4db469a..8eb9481 100644
--- a/src/ft_get_sprite_tex.c
+++ b/src/ft_get_sprite_tex.c
@@ -3,7 +3,7 @@
#include <stdlib.h>
int
-ft_get_sprite_tex(int fd, t_cub *clist)
+ft_get_sprite(char **words, t_cub *clist)
{
char *line;
char **words;
diff --git a/src/ft_get_tex.c b/src/ft_get_tex.c
index 1a936bd..a409a3c 100644
--- a/src/ft_get_tex.c
+++ b/src/ft_get_tex.c
@@ -2,121 +2,50 @@
#include <cub3d.h>
#include <stdlib.h>
-static int
-ft_get_tex_no(int fd, t_cub *clist)
+int
+ft_get_tex_no(char **words, 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));
- }
+ if (!(*words) || !(*(words + 1)) || (*(words + 2)))
+ return (-1);
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);
+ ft_free_words(words);
return (0);
}
-static int
-ft_get_tex_so(int fd, t_cub *clist)
+int
+ft_get_tex_so(char **words, 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));
- }
+ if (!(*words) || !(*(words + 1)) || (*(words + 2)))
+ return (-1);
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);
+ ft_free_words(words);
return (0);
}
-static int
-ft_get_tex_we(int fd, t_cub *clist)
+int
+ft_get_tex_ea(char **words, 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);
+ if (!(*words) || !(*(words + 1)) || (*(words + 2)))
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);
+ ft_free_words(words);
return (0);
}
int
-ft_get_tex(int fd, t_cub *clist)
+ft_get_tex_we(char **words, 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)
+ if (!(*words) || !(*(words + 1)) || (*(words + 2)))
+ return (-1);
+ ft_memdel(clist->we_tex_path);
+ if (!(clist->we_tex_path = ft_strdup(*(words + 1))))
return (-1);
+ ft_free_words(words);
return (0);
}
diff --git a/src/ft_parse_map.c b/src/ft_parse_map.c
index dfa1ba6..7704ff2 100644
--- a/src/ft_parse_map.c
+++ b/src/ft_parse_map.c
@@ -91,7 +91,7 @@ ft_parse_map(const char *map_path, t_cub *clist)
ret = 1;
while (ret != 12)
ret = ft_parse_it(fd, clist);
- ft_get_map(void);
+ /* ft_get_map(void); */
/* if (ft_get_tex(fd, clist) < 0) */
/* return ; */
/* ft_check_empty_line(fd, 6, clist); */
@@ -102,6 +102,6 @@ ft_parse_map(const char *map_path, t_cub *clist)
/* if (ft_get_map(fd, clist) < 0) */
/* ft_map_error(11, clist); */
/* ft_check_map_last_line(clist); */
- /* ft_print_list(clist); */
+ ft_print_list(clist);
close(fd);
}
diff --git a/src/ft_select_get.c b/src/ft_select_get.c
index 25320d7..7b1b524 100644
--- a/src/ft_select_get.c
+++ b/src/ft_select_get.c
@@ -9,19 +9,34 @@ ft_get_id(char **words)
return (0);
if (!ft_strcmp(words[0], "NO"))
return (1);
+ if (!ft_strcmp(words[0], "SO"))
+ return (2);
+ if (!ft_strcmp(words[0], "EA"))
+ return (3);
+ if (!ft_strcmp(words[0], "WE"))
+ return (4);
+ if (!ft_strcmp(words[0], "S"))
+ return (5);
return (12);
}
uint8_t
ft_select_get(char **words, t_cub *clist)
{
- int (*fun_ptr[4])(char**, t_cub*);
+ int (*fun_ptr[6])(char**, t_cub*);
uint8_t id;
fun_ptr[0] = ft_get_res;
- fun_ptr[1] = ft_get_tex;
+ fun_ptr[1] = ft_get_tex_no;
+ fun_ptr[2] = ft_get_tex_so;
+ fun_ptr[3] = ft_get_tex_ea;
+ fun_ptr[4] = ft_get_tex_we;
+ fun_ptr[5] = ft_get_sprite;
if ((id = ft_get_id(words)) == 12)
+ {
+ ft_free_words(words);
return (12);
+ }
if ((*fun_ptr[id])(words, clist) < 0)
{
ft_free_words(words);