From 81a32dd145c3cb55b456ba6666de6c80ff5ac92c Mon Sep 17 00:00:00 2001 From: JozanLeClerc Date: Thu, 19 Mar 2020 14:14:46 +0100 Subject: Parsed weapons spawns --- Makefile | 1 + inc/cub3d.h | 1 + src/ft_get_player_spawn.c | 1 + src/ft_get_weapon_spawn.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++ src/ft_warp_level.c | 6 +++--- 5 files changed, 55 insertions(+), 3 deletions(-) create mode 100644 src/ft_get_weapon_spawn.c diff --git a/Makefile b/Makefile index 01ac1ec..cad4b1b 100644 --- a/Makefile +++ b/Makefile @@ -106,6 +106,7 @@ SRCS_NAME += ft_draw_heals.c SRCS_NAME += ft_draw_heals_extra.c SRCS_NAME += ft_find_item.c SRCS_NAME += ft_tex_weap_init.c +SRCS_NAME += ft_get_weapon_spawn.c #--------------------------------------------------------------------------------------------------# SRCS = $(addprefix ${SRCS_DIR},${SRCS_NAME}) #--------------------------------------------------------------------------------------------------# diff --git a/inc/cub3d.h b/inc/cub3d.h index aedd550..33c8bba 100644 --- a/inc/cub3d.h +++ b/inc/cub3d.h @@ -122,6 +122,7 @@ size_t ft_get_map_w(char **map); void ft_get_sprite_spawn(t_cub *clist); void ft_get_trap_spawn(t_cub *clist); void ft_get_heal_spawn(t_cub *clist); +void ft_get_weapon_spawn(t_cub *clist); int8_t ft_check_map_line(char *line, uint8_t l, t_cub *clist); int8_t ft_check_ext(const char *filep, const char *ext); int8_t ft_check_not_found(const char *path); diff --git a/src/ft_get_player_spawn.c b/src/ft_get_player_spawn.c index 1ba6437..2f8fa0e 100644 --- a/src/ft_get_player_spawn.c +++ b/src/ft_get_player_spawn.c @@ -85,6 +85,7 @@ void ft_get_sprite_spawn(clist); ft_get_trap_spawn(clist); ft_get_heal_spawn(clist); + ft_get_weapon_spawn(clist); return ; } x++; diff --git a/src/ft_get_weapon_spawn.c b/src/ft_get_weapon_spawn.c new file mode 100644 index 0000000..d9b7d52 --- /dev/null +++ b/src/ft_get_weapon_spawn.c @@ -0,0 +1,49 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_get_weapon_spawn.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/28 20:54:28 by rbousset #+# #+# */ +/* Updated: 2020/02/28 20:54:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include +#include +#include + +static void + ft_get_weapon_id_spawn(uint8_t id, size_t y, size_t x, t_cub *clist) +{ + clist->mlist.weaps_nbr[id]++; + if (clist->mlist.weaps_nbr[id] > 1) + ft_map_error(FT_ERR_TOO_MUCH_W_ONE, clist); + clist->weaps[id][0].s_pos_x = x; + clist->weaps[id][0].s_pos_y = y; +} + +void + ft_get_weapon_spawn(t_cub *clist) +{ + size_t x; + size_t y; + + x = 1; + y = 1; + i = 0; + while (clist->mlist.map[y]) + { + while (clist->mlist.map[y][x]) + { + if (clist->mlist.map[y][x] == '!') + ft_get_weapon_one_spawn(0, y, x, clist); + else if (clist->mlist.map[y][x] == '@') + ft_get_weapon_two_spawn(1, y, x, clist); + x++; + } + x = 1; + y++; + } +} diff --git a/src/ft_warp_level.c b/src/ft_warp_level.c index d6a3d7f..6962a1d 100644 --- a/src/ft_warp_level.c +++ b/src/ft_warp_level.c @@ -12,13 +12,13 @@ #include #include -#include +#include #include +#include #include #include #include -#include -#include +#include static void ft_del_map(t_map *ml) -- cgit v1.2.3