diff options
-rw-r--r-- | inc/cub3d.h | 44 | ||||
-rw-r--r-- | src/ft_check_empty_line.c | 6 | ||||
-rw-r--r-- | src/ft_drawsquare.c | 4 | ||||
-rw-r--r-- | src/ft_exit.c | 26 | ||||
-rw-r--r-- | src/ft_get_colors.c | 38 | ||||
-rw-r--r-- | src/ft_get_map.c | 74 | ||||
-rw-r--r-- | src/ft_get_res.c | 18 | ||||
-rw-r--r-- | src/ft_get_sprite_tex.c | 10 | ||||
-rw-r--r-- | src/ft_get_tex.c | 50 | ||||
-rw-r--r-- | src/ft_init_lists.c | 1 | ||||
-rw-r--r-- | src/ft_init_winlx.c | 18 | ||||
-rw-r--r-- | src/ft_key_events.c | 2 | ||||
-rw-r--r-- | src/ft_map_error.c | 4 | ||||
-rw-r--r-- | src/ft_parse_map.c | 29 | ||||
-rw-r--r-- | src/ft_print_list.c | 25 | ||||
-rw-r--r-- | src/main.c | 24 |
16 files changed, 197 insertions, 176 deletions
diff --git a/inc/cub3d.h b/inc/cub3d.h index 7df93ad..9462035 100644 --- a/inc/cub3d.h +++ b/inc/cub3d.h @@ -2,6 +2,7 @@ #define CUB3D_H #include <inttypes.h> +#include <stddef.h> #ifndef FT_W_KEY #define FT_W_KEY 13 @@ -19,6 +20,14 @@ #define FT_ESC_KEY 53 #endif +typedef struct s_win +{ + void *wlx; + void *winptr; + int x_size; + int y_size; +} t_win; + typedef struct s_cub { char *no_tex_path; @@ -29,34 +38,27 @@ typedef struct s_cub int f_color; int c_color; char **map; + size_t map_width; + struct s_win *wlist; } t_cub; -typedef struct s_win -{ - void *wlx; - void *winptr; - int x_size; - int y_size; - struct s_cub *clist; -} t_win; - t_win *ft_init_win(void); t_cub *ft_init_cub(void); -void ft_parse_map(const char *map_path, t_win *wlist); +void ft_parse_map(const char *map_path, t_cub *clist); int ft_key_event(int keycode, void *param); -int ft_exit(uint8_t exit_code, t_win *wlist); -void ft_drawsquare(int a, int b, int rgb, t_win *wlist); -int ft_get_res(int fd, t_win *wlist); -int ft_get_tex(int fd, t_win *wlist); -int ft_get_sprite_tex(int fd, t_win *wlist); -int ft_get_colors(int fd, t_win *wlist); -int ft_get_map(int fd, t_win *wlist); +int ft_exit(uint8_t exit_code, t_cub *clist); +void ft_drawsquare(int a, int b, int rgb, t_cub *clist); +int ft_get_res(int fd, t_cub *clist); +int ft_get_tex(int fd, t_cub *clist); +int ft_get_sprite_tex(int fd, t_cub *clist); +int ft_get_colors(int fd, t_cub *clist); +int ft_get_map(int fd, t_cub *clist); void ft_check_empty_line(int fd, unsigned int linum, - t_win *wlist); + t_cub *clist); void ft_free_words(char **words, char *line); -int ft_map_error(unsigned int linum, t_win *wlist); -int ft_init_winlx(t_win *wlist); -void ft_print_list(t_win *wlist); +int ft_map_error(unsigned int linum, t_cub *clist); +int ft_init_winlx(t_cub *clist); +void ft_print_list(t_cub *clist); #endif diff --git a/src/ft_check_empty_line.c b/src/ft_check_empty_line.c index 5515c90..5f98f7d 100644 --- a/src/ft_check_empty_line.c +++ b/src/ft_check_empty_line.c @@ -2,19 +2,19 @@ #include <cub3d.h> void -ft_check_empty_line(int fd, unsigned int linum, t_win *wlist) +ft_check_empty_line(int fd, unsigned int linum, t_cub *clist) { char *line; if (get_next_line(fd, &line) <= 0) { ft_memdel(line); - ft_map_error(linum, wlist); + ft_map_error(linum, clist); } if (*line) { ft_memdel(line); - ft_map_error(linum, wlist); + ft_map_error(linum, clist); } ft_memdel(line); } diff --git a/src/ft_drawsquare.c b/src/ft_drawsquare.c index 1f1334b..3bf891b 100644 --- a/src/ft_drawsquare.c +++ b/src/ft_drawsquare.c @@ -2,7 +2,7 @@ #include <cub3d.h> void -ft_drawsquare(int a, int b, int rgb, t_win *wlist) +ft_drawsquare(int a, int b, int rgb, t_cub *clist) { int x; int y; @@ -13,7 +13,7 @@ ft_drawsquare(int a, int b, int rgb, t_win *wlist) { while (y > b - 40) { - mlx_pixel_put(wlist->wlx, wlist->winptr, x, y, rgb); + mlx_pixel_put(clist->wlist->wlx, clist->wlist->winptr, x, y, rgb); y--; } y = b; diff --git a/src/ft_exit.c b/src/ft_exit.c index 14f1f2a..925bbd5 100644 --- a/src/ft_exit.c +++ b/src/ft_exit.c @@ -4,27 +4,27 @@ #include <inttypes.h> static void -ft_free_lists(t_win *wlist) +ft_free_lists(t_cub *clist) { - ft_memdel(wlist->clist->no_tex_path); - ft_memdel(wlist->clist->so_tex_path); - ft_memdel(wlist->clist->ea_tex_path); - ft_memdel(wlist->clist->we_tex_path); - ft_memdel(wlist->clist->sprite_path); - ft_free_words(wlist->clist->map, NULL); - ft_memdel(wlist->clist); - ft_memdel(wlist->winptr); - ft_memdel(wlist->wlx); - ft_memdel(wlist); + ft_memdel(clist->no_tex_path); + ft_memdel(clist->so_tex_path); + ft_memdel(clist->ea_tex_path); + ft_memdel(clist->we_tex_path); + ft_memdel(clist->sprite_path); + ft_free_words(clist->map, NULL); + ft_memdel(clist->wlist->winptr); + ft_memdel(clist->wlist->wlx); + ft_memdel(clist->wlist); + ft_memdel(clist); } int -ft_exit(uint8_t exit_code, t_win *wlist) +ft_exit(uint8_t exit_code, t_cub *clist) { ft_printf("Exiting program\n"); if (exit_code < 0 || exit_code > 0) ft_printf("Exit code: %hhu\n", exit_code); - ft_free_lists(wlist); + ft_free_lists(clist); exit(exit_code); return (0); } diff --git a/src/ft_get_colors.c b/src/ft_get_colors.c index 2e09fc6..750ebed 100644 --- a/src/ft_get_colors.c +++ b/src/ft_get_colors.c @@ -16,7 +16,7 @@ ft_check_digits(const char *word) } static int -ft_get_f_color(char *line, char **words, t_win *wlist) +ft_get_f_color(char *line, char **words, t_cub *clist) { char **num; @@ -32,18 +32,18 @@ ft_get_f_color(char *line, char **words, t_win *wlist) ft_free_words(num, NULL); return (-1); } - wlist->clist->f_color = ft_atoi(num[0]); - wlist->clist->f_color *= 1000; - wlist->clist->f_color += ft_atoi(num[1]); - wlist->clist->f_color *= 1000; - wlist->clist->f_color += ft_atoi(num[2]); + clist->f_color = ft_atoi(num[0]); + clist->f_color *= 1000; + clist->f_color += ft_atoi(num[1]); + clist->f_color *= 1000; + clist->f_color += ft_atoi(num[2]); ft_free_words(num, NULL); ft_free_words(words, line); return (0); } static int -ft_get_c_color(char *line, char **words, t_win *wlist) +ft_get_c_color(char *line, char **words, t_cub *clist) { char **num; @@ -59,18 +59,18 @@ ft_get_c_color(char *line, char **words, t_win *wlist) ft_free_words(num, NULL); return (-1); } - wlist->clist->c_color = ft_atoi(num[0]); - wlist->clist->c_color *= 1000; - wlist->clist->c_color += ft_atoi(num[1]); - wlist->clist->c_color *= 1000; - wlist->clist->c_color += ft_atoi(num[2]); + clist->c_color = ft_atoi(num[0]); + clist->c_color *= 1000; + clist->c_color += ft_atoi(num[1]); + clist->c_color *= 1000; + clist->c_color += ft_atoi(num[2]); ft_free_words(num, NULL); ft_free_words(words, line); return (0); } int -ft_get_colors(int fd, t_win *wlist) +ft_get_colors(int fd, t_cub *clist) { char *line; char **words; @@ -78,22 +78,22 @@ ft_get_colors(int fd, t_win *wlist) if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(8, wlist)); + return (ft_map_error(8, clist)); } - if (ft_get_f_color(line, words, wlist) < 0) + if (ft_get_f_color(line, words, clist) < 0) { ft_free_words(words, line); - return (ft_map_error(8, wlist)); + return (ft_map_error(8, clist)); } if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(9, wlist)); + return (ft_map_error(9, clist)); } - if (ft_get_c_color(line, words, wlist) < 0) + if (ft_get_c_color(line, words, clist) < 0) { ft_free_words(words, line); - return (ft_map_error(9, wlist)); + return (ft_map_error(9, clist)); } return (0); } diff --git a/src/ft_get_map.c b/src/ft_get_map.c index a8a6fe0..e41ffd6 100644 --- a/src/ft_get_map.c +++ b/src/ft_get_map.c @@ -3,31 +3,26 @@ #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 start) +ft_linecpy(char *line, char *mapl, size_t start) { size_t i; size_t j; i = 0; j = start; - while (i < ft_strlen(line)) + while (i < ft_strlen(line) && line[i]) { - mapL[j] = line[i]; + mapl[j] = line[i]; i += 2; j++; } - mapL[j + 1] = '\n'; + mapl[j] = '\n'; return (0); } static int -ft_check_err(char *line, size_t size, t_win *wlist) +ft_check_err(char *line, size_t size) { size_t i; @@ -37,45 +32,60 @@ ft_check_err(char *line, size_t size, t_win *wlist) while (i < ft_strlen(line) && line[i]) { if (line[i] != ' ') - return (ft_map_error(11, wlist)); + 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_win *wlist) +ft_get_map(int fd, t_cub *clist) { size_t i; size_t len; + int ret; char *line; - char *mapL; + 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) + if (get_next_line(fd, &line) <= 0 || + !(mapl = ft_get_first_line(line, clist))) { - len = ft_strlen(line); - ft_check_err(line, len, wlist); - if (!(mapL = (char*)malloc((len + 1) * sizeof(char)))) - return (-1); - ft_linecpy(line, mapL, 0); ft_memdel(line); - } - else return (-1); + } i = 1; - while (get_next_line(fd, &line) > 0) + ret = 1; + len = clist->map_width; + while (ret > 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, (len + 1) * i); + ret = get_next_line(fd, &line); + ft_check_err(line, len); + mapl = (char*)ft_nrealloc(mapl, (((len / 2) + 2) * i) * sizeof(char), + ((((len / 2) + 2) * i) + (ft_strlen(line) / 2) + 2) * sizeof(char)); + ft_linecpy(line, mapl, ((len / 2) + 2) * i); 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); + mapl[(i * ((len / 2) + 2)) - 1] = '\0'; + ft_free_words(clist->map, NULL); + clist->map = ft_split(mapl, '\n'); + ft_memdel(mapl); return (0); } diff --git a/src/ft_get_res.c b/src/ft_get_res.c index 337d3d7..66eb1df 100644 --- a/src/ft_get_res.c +++ b/src/ft_get_res.c @@ -2,7 +2,7 @@ #include <cub3d.h> static void -ft_checkdigit(const char *word, t_win *wlist) +ft_checkdigit(const char *word, t_cub *clist) { size_t i; @@ -10,11 +10,11 @@ ft_checkdigit(const char *word, t_win *wlist) while (ft_isdigit(word[i])) i++; if (i != ft_strlen(word)) - ft_map_error(1, wlist); + ft_map_error(1, clist); } int -ft_get_res(int fd, t_win *wlist) +ft_get_res(int fd, t_cub *clist) { char *line; char **words; @@ -22,18 +22,18 @@ ft_get_res(int fd, t_win *wlist) if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(1, wlist)); + return (ft_map_error(1, clist)); } if (!(*words) || ft_strcmp(*words, "R") || !(*(words + 1)) || !(*(words + 2)) || (*(words + 3))) { ft_free_words(words, line); - return (ft_map_error(1, wlist)); + return (ft_map_error(1, clist)); } - ft_checkdigit(words[1], wlist); - ft_checkdigit(words[2], wlist); - wlist->x_size = ft_atoi(words[1]); - wlist->y_size = ft_atoi(words[2]); + ft_checkdigit(words[1], clist); + ft_checkdigit(words[2], clist); + clist->wlist->x_size = ft_atoi(words[1]); + clist->wlist->y_size = ft_atoi(words[2]); ft_free_words(words, line); return (0); } diff --git a/src/ft_get_sprite_tex.c b/src/ft_get_sprite_tex.c index 308ff84..4db469a 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_win *wlist) +ft_get_sprite_tex(int fd, t_cub *clist) { char *line; char **words; @@ -11,15 +11,15 @@ ft_get_sprite_tex(int fd, t_win *wlist) if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(7, wlist)); + 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, wlist)); + return (ft_map_error(7, clist)); } - ft_memdel(wlist->clist->sprite_path); - if (!(wlist->clist->sprite_path = ft_strdup(*(words + 1)))) + ft_memdel(clist->sprite_path); + if (!(clist->sprite_path = ft_strdup(*(words + 1)))) { ft_free_words(words, line); return (-1); diff --git a/src/ft_get_tex.c b/src/ft_get_tex.c index 4c80c89..1a936bd 100644 --- a/src/ft_get_tex.c +++ b/src/ft_get_tex.c @@ -3,7 +3,7 @@ #include <stdlib.h> static int -ft_get_tex_no(int fd, t_win *wlist) +ft_get_tex_no(int fd, t_cub *clist) { char *line; char **words; @@ -11,16 +11,16 @@ ft_get_tex_no(int fd, t_win *wlist) if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(2, wlist)); + 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, wlist)); + return (ft_map_error(2, clist)); } - ft_memdel(wlist->clist->no_tex_path); - if (!(wlist->clist->no_tex_path = ft_strdup(*(words + 1)))) + ft_memdel(clist->no_tex_path); + if (!(clist->no_tex_path = ft_strdup(*(words + 1)))) { ft_free_words(words, line); return (-1); @@ -30,7 +30,7 @@ ft_get_tex_no(int fd, t_win *wlist) } static int -ft_get_tex_so(int fd, t_win *wlist) +ft_get_tex_so(int fd, t_cub *clist) { char *line; char **words; @@ -38,16 +38,16 @@ ft_get_tex_so(int fd, t_win *wlist) if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(3, wlist)); + 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, wlist)); + return (ft_map_error(3, clist)); } - ft_memdel(wlist->clist->so_tex_path); - if (!(wlist->clist->so_tex_path = ft_strdup(*(words + 1)))) + ft_memdel(clist->so_tex_path); + if (!(clist->so_tex_path = ft_strdup(*(words + 1)))) { ft_free_words(words, line); return (-1); @@ -57,7 +57,7 @@ ft_get_tex_so(int fd, t_win *wlist) } static int -ft_get_tex_we(int fd, t_win *wlist) +ft_get_tex_we(int fd, t_cub *clist) { char *line; char **words; @@ -65,16 +65,16 @@ ft_get_tex_we(int fd, t_win *wlist) if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(4, wlist)); + 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, wlist)); + return (ft_map_error(4, clist)); } - ft_memdel(wlist->clist->we_tex_path); - if (!(wlist->clist->we_tex_path = ft_strdup(*(words + 1)))) + ft_memdel(clist->we_tex_path); + if (!(clist->we_tex_path = ft_strdup(*(words + 1)))) { ft_free_words(words, line); return (-1); @@ -84,7 +84,7 @@ ft_get_tex_we(int fd, t_win *wlist) } static int -ft_get_tex_ea(int fd, t_win *wlist) +ft_get_tex_ea(int fd, t_cub *clist) { char *line; char **words; @@ -92,16 +92,16 @@ ft_get_tex_ea(int fd, t_win *wlist) if (get_next_line(fd, &line) <= 0 || !(words = ft_split(line, ' '))) { ft_memdel(line); - return (ft_map_error(5, wlist)); + 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, wlist)); + return (ft_map_error(5, clist)); } - ft_memdel(wlist->clist->ea_tex_path); - if (!(wlist->clist->ea_tex_path = ft_strdup(*(words + 1)))) + ft_memdel(clist->ea_tex_path); + if (!(clist->ea_tex_path = ft_strdup(*(words + 1)))) { ft_free_words(words, line); return (-1); @@ -111,12 +111,12 @@ ft_get_tex_ea(int fd, t_win *wlist) } int -ft_get_tex(int fd, t_win *wlist) +ft_get_tex(int fd, t_cub *clist) { - if (ft_get_tex_no(fd, wlist) < 0 || - ft_get_tex_so(fd, wlist) < 0 || - ft_get_tex_we(fd, wlist) < 0 || - ft_get_tex_ea(fd, wlist) < 0) + 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); } diff --git a/src/ft_init_lists.c b/src/ft_init_lists.c index b395840..3554e5e 100644 --- a/src/ft_init_lists.c +++ b/src/ft_init_lists.c @@ -37,5 +37,6 @@ t_cub if (!(clist->map[0] = (char*)ft_calloc(1, sizeof(char)))) return (NULL); clist->map[1] = 0; + clist->map_width = 0; return (clist); } diff --git a/src/ft_init_winlx.c b/src/ft_init_winlx.c index a4b7208..931e19b 100644 --- a/src/ft_init_winlx.c +++ b/src/ft_init_winlx.c @@ -4,17 +4,19 @@ #include <stdlib.h> int -ft_init_winlx(t_win *wlist) +ft_init_winlx(t_cub *clist) { - ft_memdel(wlist->wlx); - if (!(wlist->wlx = mlx_init())) + ft_memdel(clist->wlist->wlx); + if (!(clist->wlist->wlx = mlx_init())) return (-1); - ft_memdel(wlist->winptr); - if (!(wlist->winptr = (void*)malloc(wlist->x_size * wlist->y_size))) + ft_memdel(clist->wlist->winptr); + if (!(clist->wlist->winptr = malloc(clist->wlist->x_size + * clist->wlist->y_size))) return (-1); - if (!(wlist->winptr = mlx_new_window(wlist->wlx, wlist->x_size,\ - wlist->y_size, "Cub3D"))) + if (!(clist->wlist->winptr = mlx_new_window(clist->wlist->wlx, + clist->wlist->x_size, clist->wlist->y_size, "Cub3D"))) return (-1); - ft_printf("Created window of size %dx%d\n", wlist->x_size, wlist->y_size); + ft_printf("Created window of size %dx%d\n", + clist->wlist->x_size, clist->wlist->y_size); return (0); } diff --git a/src/ft_key_events.c b/src/ft_key_events.c index 8c8167a..7b3cdf2 100644 --- a/src/ft_key_events.c +++ b/src/ft_key_events.c @@ -46,6 +46,6 @@ ft_key_event(int keycode, void *param) (keycode == FT_D_KEY) ? (keycode = 3) : 0; (keycode <= 3) ? ((*fun_ptr[keycode])()) : 0; if (keycode == FT_ESC_KEY) - ft_exit(0, ((t_win*)param)); + ft_exit(0, ((t_cub*)param)); return (0); } diff --git a/src/ft_map_error.c b/src/ft_map_error.c index 2e8a9ff..df7a2fc 100644 --- a/src/ft_map_error.c +++ b/src/ft_map_error.c @@ -3,9 +3,9 @@ #include <unistd.h> int -ft_map_error(unsigned int linum, t_win *wlist) +ft_map_error(unsigned int linum, t_cub *clist) { ft_dprintf(STDERR_FILENO, "Error\n"); ft_dprintf(STDERR_FILENO, "\033[1;31mMap error: line %d\033[0m\n", linum); - return (ft_exit(1, wlist)); + return (ft_exit(1, clist)); } diff --git a/src/ft_parse_map.c b/src/ft_parse_map.c index 70b81d4..1f31ca1 100644 --- a/src/ft_parse_map.c +++ b/src/ft_parse_map.c @@ -5,7 +5,7 @@ #include <unistd.h> static void -ft_check_cub(const char *map_path, t_win *wlist) +ft_check_cub(const char *map_path, t_cub *clist) { char **words; size_t i; @@ -15,7 +15,7 @@ ft_check_cub(const char *map_path, t_win *wlist) ft_dprintf(STDERR_FILENO, "Error\n"); ft_dprintf(STDERR_FILENO, "\033[31;1mMap is not a .cub\033[0m\n"); ft_free_words(words, NULL); - ft_exit(2, wlist); + ft_exit(2, clist); } i = 0; while (words[i]) @@ -25,7 +25,7 @@ ft_check_cub(const char *map_path, t_win *wlist) ft_dprintf(STDERR_FILENO, "Error\n"); ft_dprintf(STDERR_FILENO, "\033[31;1mMap is not a .cub\033[0m\n"); ft_free_words(words, NULL); - ft_exit(2, wlist); + ft_exit(2, clist); } ft_free_words(words, NULL); } @@ -35,26 +35,27 @@ ft_check_cub(const char *map_path, t_win *wlist) */ void -ft_parse_map(const char *map_path, t_win *wlist) +ft_parse_map(const char *map_path, t_cub *clist) { int fd; - ft_check_cub(map_path, wlist); + ft_check_cub(map_path, clist); fd = open(map_path, O_RDONLY); if (fd < 0) { ft_dprintf(STDERR_FILENO, "Error\n"); ft_dprintf(STDERR_FILENO, "\033[31;1mNo map\033[0m\n"); - ft_exit(2, wlist); + ft_exit(2, clist); } - ft_get_res(fd, wlist); - if (ft_get_tex(fd, wlist) < 0) + ft_get_res(fd, clist); + if (ft_get_tex(fd, clist) < 0) return ; - ft_check_empty_line(fd, 6, wlist); - if (ft_get_sprite_tex(fd, wlist) < 0) + ft_check_empty_line(fd, 6, clist); + if (ft_get_sprite_tex(fd, clist) < 0) return ; - ft_get_colors(fd, wlist); - ft_print_list(wlist); - ft_check_empty_line(fd, 10, wlist); - ft_get_map(fd, wlist); + ft_get_colors(fd, clist); + ft_check_empty_line(fd, 10, clist); + if (ft_get_map(fd, clist) < 0) + ft_map_error(11, clist); + ft_print_list(clist); } diff --git a/src/ft_print_list.c b/src/ft_print_list.c index f038740..e48b2a2 100644 --- a/src/ft_print_list.c +++ b/src/ft_print_list.c @@ -2,23 +2,24 @@ #include <cub3d.h> void -ft_print_list(t_win *wlist) +ft_print_list(t_cub *clist) { size_t i; - ft_printf("x size [%d]\n", wlist->x_size); - ft_printf("y size [%d]\n", wlist->y_size); - ft_printf("North - [%s]\n", wlist->clist->no_tex_path); - ft_printf("South - [%s]\n", wlist->clist->so_tex_path); - ft_printf("West -- [%s]\n", wlist->clist->we_tex_path); - ft_printf("East -- [%s]\n", wlist->clist->ea_tex_path); - ft_printf("Sprite [%s]\n", wlist->clist->sprite_path); - ft_printf("F color [%d]\n", wlist->clist->f_color); - ft_printf("C color [%d]\n", wlist->clist->c_color); + ft_printf("x size [%d]\n", clist->wlist->x_size); + ft_printf("y size [%d]\n", clist->wlist->y_size); + ft_printf("North - [%s]\n", clist->no_tex_path); + ft_printf("South - [%s]\n", clist->so_tex_path); + ft_printf("West -- [%s]\n", clist->we_tex_path); + ft_printf("East -- [%s]\n", clist->ea_tex_path); + ft_printf("Sprite [%s]\n", clist->sprite_path); + ft_printf("F color [%d]\n", clist->f_color); + ft_printf("C color [%d]\n", clist->c_color); i = 0; - while (wlist->clist->map[i]) + ft_printf("Map\n----\n"); + while (clist->map[i]) { - ft_printf("Map Line %zu [%s]\n", i + 1, wlist->clist->map[i]); + ft_printf("%2zu [%s]\n", i + 1, clist->map[i]); i++; } } @@ -5,20 +5,24 @@ int main(void) { - t_win *wlist; + t_cub *clist; - if (!(wlist = ft_init_win())) + if (!(clist = ft_init_cub())) + { + ft_memdel(clist); return (1); - if (!(wlist->clist = ft_init_cub())) + } + if (!(clist->wlist = ft_init_win())) { - ft_memdel(wlist); + ft_memdel(clist->wlist); + ft_memdel(clist); return (1); } - ft_parse_map("map/map_one.cub", wlist); - if (ft_init_winlx(wlist) < 0) - return (ft_exit(3, wlist)); - mlx_key_hook(wlist->winptr, ft_key_event, wlist); - ft_drawsquare(80, 80, wlist->clist->f_color, wlist); - mlx_loop(wlist->wlx); + ft_parse_map("map/map_one.cub", clist); + if (ft_init_winlx(clist) < 0) + return (ft_exit(3, clist)); + mlx_key_hook(clist->wlist->winptr, ft_key_event, clist); + ft_drawsquare(80, 80, clist->f_color, clist); + mlx_loop(clist->wlist->wlx); return (0); } |