diff options
-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | inc/cub3d.h | 128 | ||||
-rw-r--r-- | inc/cub3d_structs.h | 1 | ||||
-rw-r--r-- | map/lvl_one.cub | 1 | ||||
-rw-r--r-- | src/ft_exit.c | 1 | ||||
-rw-r--r-- | src/ft_get_path_nl.c | 41 | ||||
-rw-r--r-- | src/ft_get_tex.c | 2 | ||||
-rw-r--r-- | src/ft_get_tex_nl.c | 41 | ||||
-rw-r--r-- | src/ft_select_get.c | 4 |
9 files changed, 155 insertions, 66 deletions
@@ -178,7 +178,7 @@ fclean: clean re: fclean all #--------------------------------------------------------------------------------------------------# run: all - @./${NAME} "map/map_one.cub" + @./${NAME} "map/lvl_one.cub" #--------------------------------------------------------------------------------------------------# .PHONY: all clean clean fclean re run default #============================================== EOF ===============================================# diff --git a/inc/cub3d.h b/inc/cub3d.h index 5f1c6f8..41d669f 100644 --- a/inc/cub3d.h +++ b/inc/cub3d.h @@ -28,68 +28,70 @@ ** 6: read error */ -int8_t ft_init_cub3d(t_cub **clist); -t_map *ft_init_map(void); -void ft_wall_tex_init(t_cub *clist); -void ft_choose_tex(t_cub *clist); -void ft_hooks_and_loops(t_win *wl, t_cub *cl); -int ft_key_event(int keycode, t_cub *clist); -int ft_click_close(int keycode, t_cub *clist); -int ft_exit(uint8_t exit_code, t_cub *clist); -void ft_draw_square(int a, int b, int rgb, t_cub *clist); -void ft_parse_map(const char *map_path, t_cub *clist); -int8_t ft_select_get(char **words, t_cub *clist); -int8_t ft_get_screen_size(t_win *wlist); -int8_t ft_get_res(char **words, t_cub *clist); -int8_t ft_get_tex_no(char **words, t_cub *clist); -int8_t ft_get_tex_so(char **words, t_cub *clist); -int8_t ft_get_tex_ea(char **words, t_cub *clist); -int8_t ft_get_tex_we(char **words, t_cub *clist); -int8_t ft_get_sprite(char **words, t_cub *clist); -int8_t ft_get_f_color(char **words, t_cub *clist); -int8_t ft_get_c_color(char **words, t_cub *clist); -int ft_get_map_first_line(char *line, t_cub *clist); -int ft_get_map_core(int fd, t_cub *clist); -void ft_get_player_spawn(t_player *plist, t_cub *clist); -void ft_set_minimap_scale(t_cub *clist); -int ft_check_missing(t_cub *clist); -int8_t ft_check_map_line(char *line, uint8_t l, t_cub *clist); -size_t ft_get_line_len(char *line); -int ft_missing_error(const char *err, t_cub *clist); -uint8_t ft_free_words(char **words); -int ft_map_error(const char *errmsg, t_cub *clist); -int ft_init_winlx(t_cub *clist); -void ft_draw_scene(t_cub *clist); -void ft_print_list(t_cub *clist); -uint32_t ft_rgb_to_hex(t_rgb rgb); -t_ray ft_init_s_ray(void); -void ft_detect(t_cub *cl); -int8_t ft_draw_verline(t_cub *cl, int32_t x, - int32_t y1, int32_t y2); -void ft_castray(t_cub *cl); -void ft_draw_map(char **map, t_cub *clist); -int ft_w_key(t_cub *clist); -int ft_a_key(t_cub *clist); -int ft_s_key(t_cub *clist); -int ft_d_key(t_cub *clist); -int ft_f1_key(t_cub *clist); -int ft_left_key(t_cub *clist); -int ft_right_key(t_cub *clist); -int ft_key_release(int keycode, t_cub *clist); -int8_t ft_check_ext(const char *filep, const char *ext); -int32_t ft_convert_keycode(const int32_t tmp_code); -int ft_key_loop(t_cub *cl); -void ft_draw_circle(float a, float b, - int32_t color, t_cub *cl); -void ft_draw_texture(t_cub *cl, int x, int y, int tex_y); -int8_t ft_check_not_found(const char *path); -void ft_calc_tex(t_cub *clist); -void ft_draw_hud(t_cub *clist); -void ft_draw_life_bar(size_t map_w, - const uint16_t scale, - const int8_t life, - t_cub *cl); -void ft_music(t_cub *cl); -void ft_draw_sprite(t_cub *cl, int i); +int8_t ft_init_cub3d(t_cub **clist); +t_map *ft_init_map(void); +void ft_wall_tex_init(t_cub *clist); +void ft_choose_tex(t_cub *clist); +void ft_hooks_and_loops(t_win *wl, t_cub *cl); +int ft_key_event(int keycode, t_cub *clist); +int ft_click_close(int keycode, t_cub *clist); +int ft_exit(uint8_t exit_code, t_cub *clist); +void ft_draw_square(int a, int b, int rgb, t_cub *clist); +void ft_parse_map(const char *map_path, t_cub *clist); +int8_t ft_select_get(char **words, t_cub *clist); +int8_t ft_get_screen_size(t_win *wlist); +int8_t ft_get_res(char **words, t_cub *clist); +int8_t ft_get_tex_no(char **words, t_cub *clist); +int8_t ft_get_tex_so(char **words, t_cub *clist); +int8_t ft_get_tex_ea(char **words, t_cub *clist); +int8_t ft_get_tex_we(char **words, t_cub *clist); +int8_t ft_get_sprite(char **words, t_cub *clist); +int8_t ft_get_f_color(char **words, t_cub *clist); +int8_t ft_get_c_color(char **words, t_cub *clist); +int8_t ft_get_path_nl(char **words, t_cub *clist); +int8_t ft_get_tex_nl(char **words, t_cub *clist); +int ft_get_map_first_line(char *line, t_cub *clist); +int ft_get_map_core(int fd, t_cub *clist); +void ft_get_player_spawn(t_player *plist, t_cub *clist); +void ft_set_minimap_scale(t_cub *clist); +int ft_check_missing(t_cub *clist); +int8_t ft_check_map_line(char *line, uint8_t l, t_cub *clist); +size_t ft_get_line_len(char *line); +int ft_missing_error(const char *err, t_cub *clist); +uint8_t ft_free_words(char **words); +int ft_map_error(const char *errmsg, t_cub *clist); +int ft_init_winlx(t_cub *clist); +void ft_draw_scene(t_cub *clist); +void ft_print_list(t_cub *clist); +uint32_t ft_rgb_to_hex(t_rgb rgb); +t_ray ft_init_s_ray(void); +void ft_detect(t_cub *cl); +int8_t ft_draw_verline(t_cub *cl, int32_t x, + int32_t y1, int32_t y2); +void ft_castray(t_cub *cl); +void ft_draw_map(char **map, t_cub *clist); +int ft_w_key(t_cub *clist); +int ft_a_key(t_cub *clist); +int ft_s_key(t_cub *clist); +int ft_d_key(t_cub *clist); +int ft_f1_key(t_cub *clist); +int ft_left_key(t_cub *clist); +int ft_right_key(t_cub *clist); +int ft_key_release(int keycode, t_cub *clist); +int8_t ft_check_ext(const char *filep, const char *ext); +int32_t ft_convert_keycode(const int32_t tmp_code); +int ft_key_loop(t_cub *cl); +void ft_draw_circle(float a, float b, + int32_t color, t_cub *cl); +void ft_draw_texture(t_cub *cl, int x, int y, int tex_y); +int8_t ft_check_not_found(const char *path); +void ft_calc_tex(t_cub *clist); +void ft_draw_hud(t_cub *clist); +void ft_draw_life_bar(size_t map_w, + const uint16_t scale, + const int8_t life, + t_cub *cl); +void ft_music(t_cub *cl); +void ft_draw_sprite(t_cub *cl, int i); # endif diff --git a/inc/cub3d_structs.h b/inc/cub3d_structs.h index ebea0f7..33a291d 100644 --- a/inc/cub3d_structs.h +++ b/inc/cub3d_structs.h @@ -110,6 +110,7 @@ typedef struct s_map char *ea_tex_path; char *we_tex_path; char *sprite_path; + char *nl_tex_path; char *nlevel_path; char *mapl; char **map; diff --git a/map/lvl_one.cub b/map/lvl_one.cub index 627a774..9a3b511 100644 --- a/map/lvl_one.cub +++ b/map/lvl_one.cub @@ -10,6 +10,7 @@ C 50,100,200 F 50,190,124 L ./map/lvl_two.cub +LT ./media/img/crapaud.xpm 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 L 0 0 1 diff --git a/src/ft_exit.c b/src/ft_exit.c index 97671d6..83e4b2e 100644 --- a/src/ft_exit.c +++ b/src/ft_exit.c @@ -25,6 +25,7 @@ static void ft_memdel((void**)&clist->mlist->ea_tex_path); ft_memdel((void**)&clist->mlist->we_tex_path); ft_memdel((void**)&clist->mlist->sprite_path); + ft_memdel((void**)&clist->mlist->nl_tex_path); ft_memdel((void**)&clist->mlist->nlevel_path); ft_memdel((void**)&clist->mlist->mapl); ft_free_words(clist->mlist->map); diff --git a/src/ft_get_path_nl.c b/src/ft_get_path_nl.c new file mode 100644 index 0000000..0b5e987 --- /dev/null +++ b/src/ft_get_path_nl.c @@ -0,0 +1,41 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_get_path_nl.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/28 18:30:18 by rbousset #+# #+# */ +/* Updated: 2020/02/28 18:30:19 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <cub3d.h> +#include <stdint.h> + +int8_t + ft_get_path_nl(char **words, t_cub *clist) +{ + if (!(*words) || !(*(words + 1)) || (*(words + 2))) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_ARGS); + return (-1); + } + if (ft_check_ext(*(words + 1), ".cub") < 0) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_NOT_A_XPM); + return (-1); + } + ft_memdel((void**)&clist->mlist->nlevel_path); + if (!(clist->mlist->nlevel_path = ft_strdup(*(words + 1)))) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_ALLOCATE); + return (-1); + } + if (ft_check_not_found(clist->mlist->nlevel_path) < 0) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_RD_NO); + return (-1); + } + return (0); +} diff --git a/src/ft_get_tex.c b/src/ft_get_tex.c index 1327d58..2611fef 100644 --- a/src/ft_get_tex.c +++ b/src/ft_get_tex.c @@ -12,7 +12,7 @@ #include <libft.h> #include <cub3d.h> -#include <stdlib.h> +#include <stdint.h> int8_t ft_get_tex_no(char **words, t_cub *clist) diff --git a/src/ft_get_tex_nl.c b/src/ft_get_tex_nl.c new file mode 100644 index 0000000..e1ee5ce --- /dev/null +++ b/src/ft_get_tex_nl.c @@ -0,0 +1,41 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_get_tex_nl.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/28 18:24:52 by rbousset #+# #+# */ +/* Updated: 2020/02/28 18:24:56 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <cub3d.h> +#include <stdint.h> + +int8_t + ft_get_tex_nl(char **words, t_cub *clist) +{ + if (!(*words) || !(*(words + 1)) || (*(words + 2))) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_ARGS); + return (-1); + } + if (ft_check_ext(*(words + 1), ".xpm") < 0) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_NOT_A_XPM); + return (-1); + } + ft_memdel((void**)&clist->mlist->nl_tex_path); + if (!(clist->mlist->nl_tex_path = ft_strdup(*(words + 1)))) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_ALLOCATE); + return (-1); + } + if (ft_check_not_found(clist->mlist->nl_tex_path) < 0) + { + ft_sprintf(clist->errmsg, "%s", FT_ERR_RD_NO); + return (-1); + } + return (0); +} diff --git a/src/ft_select_get.c b/src/ft_select_get.c index 4b82430..b5df1bc 100644 --- a/src/ft_select_get.c +++ b/src/ft_select_get.c @@ -67,7 +67,7 @@ static int8_t int8_t ft_select_get(char **words, t_cub *clist) { - int8_t (*fun_ptr[8])(char**, t_cub*); + int8_t (*fun_ptr[10])(char**, t_cub*); int8_t id; fun_ptr[0] = ft_get_res; @@ -78,6 +78,8 @@ int8_t fun_ptr[5] = ft_get_sprite; fun_ptr[6] = ft_get_f_color; fun_ptr[7] = ft_get_c_color; + fun_ptr[8] = ft_get_path_nl; + fun_ptr[9] = ft_get_tex_nl; if ((id = ft_get_id(words, clist)) == 12) { ft_free_words(words); |