aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--inc/cub3d_defines.h3
-rw-r--r--inc/cub3d_structs.h2
-rw-r--r--src/ft_check_map_line.c3
-rw-r--r--src/ft_extra_keys.c9
-rw-r--r--src/ft_find_item.c12
-rw-r--r--src/ft_get_topsp.c32
-rw-r--r--src/ft_init_lists.c5
-rw-r--r--src/ft_init_map.c2
-rw-r--r--src/ft_warp_level.c13
9 files changed, 38 insertions, 43 deletions
diff --git a/inc/cub3d_defines.h b/inc/cub3d_defines.h
index 7df3de3..c3c5d66 100644
--- a/inc/cub3d_defines.h
+++ b/inc/cub3d_defines.h
@@ -289,5 +289,8 @@ enum
# define FT_TRAP_DAMAGE_AMOUNT 45
# define FT_HEAL_PACK_AMOUNT 20
# define FT_BOUNCE_FACTOR 4
+# define FT_WEAP_ONE_STRT_AMMO -4
+# define FT_WEAP_TWO_STRT_AMMO 30
+# define FT_WEAP_THREE_STRT_AMMO 24
# endif
diff --git a/inc/cub3d_structs.h b/inc/cub3d_structs.h
index babf3be..380b7f4 100644
--- a/inc/cub3d_structs.h
+++ b/inc/cub3d_structs.h
@@ -135,6 +135,7 @@ typedef struct s_player
int16_t life;
uint8_t has_weapon[3];
int8_t handles_weapon;
+ int16_t ammo[3];
} t_player;
typedef struct s_ray
@@ -214,7 +215,6 @@ typedef struct s_map
uint8_t isskybox;
uint8_t istraps;
uint8_t isheals;
- uint8_t isweapon[3];
uint8_t darklvl;
uint16_t scale;
int8_t topsp;
diff --git a/src/ft_check_map_line.c b/src/ft_check_map_line.c
index 9419ab2..44580db 100644
--- a/src/ft_check_map_line.c
+++ b/src/ft_check_map_line.c
@@ -39,9 +39,6 @@ static int8_t
}
cl->mlist.istraps = (line[i] == 'T') ? (1) : (cl->mlist.istraps);
cl->mlist.isheals = (line[i] == '+') ? (1) : (cl->mlist.isheals);
- cl->mlist.isweapon[0] = (line[i] == '!') ? (1) : (cl->mlist.isweapon[0]);
- cl->mlist.isweapon[1] = (line[i] == '@') ? (1) : (cl->mlist.isweapon[1]);
- ft_get_topsp(line[i], cl);
return (0);
}
diff --git a/src/ft_extra_keys.c b/src/ft_extra_keys.c
index a78f821..097e2e2 100644
--- a/src/ft_extra_keys.c
+++ b/src/ft_extra_keys.c
@@ -71,8 +71,15 @@ int
int
ft_space_key(t_cub *clist)
{
- if (clist->plist.fire == 0)
+ uint8_t w_id;
+
+ w_id = clist->plist.handles_weapon;
+ w_id = (w_id == 2) ? (1) : (w_id);
+ w_id = (w_id == 4) ? (2) : (w_id);
+ if (clist->plist.fire == 0 &&
+ (clist->plist.ammo[w_id] > 0 || clist->plist.ammo[w_id] == -4))
{
+ clist->plist.ammo[w_id] -= w_id;
clist->sfx[clist->plist.handles_weapon + 7].sfx_play(clist->sfx);
clist->plist.fire = 1;
}
diff --git a/src/ft_find_item.c b/src/ft_find_item.c
index caeb3f4..cea05fa 100644
--- a/src/ft_find_item.c
+++ b/src/ft_find_item.c
@@ -30,6 +30,17 @@ static uint16_t
}
static void
+ ft_set_ammo(uint8_t weap_id, t_player *pl)
+{
+ if (weap_id == 0)
+ pl->ammo[0] = FT_WEAP_ONE_STRT_AMMO;
+ else if (weap_id == 1)
+ pl->ammo[1] = FT_WEAP_TWO_STRT_AMMO;
+ else if (weap_id == 2)
+ pl->ammo[2] = FT_WEAP_THREE_STRT_AMMO;
+}
+
+static void
ft_weapon_check(const char map_char, t_player *pl, t_cub *cl)
{
uint8_t weap_id;
@@ -48,6 +59,7 @@ static void
pl->handles_weapon = (weap_id == 0) ? (0) : (pl->handles_weapon);
pl->handles_weapon = (weap_id == 1) ? (2) : (pl->handles_weapon);
pl->handles_weapon = (weap_id == 2) ? (4) : (pl->handles_weapon);
+ ft_set_ammo(weap_id, pl);
if (weap_id == 0)
cl->sfx[6].sfx_play(cl->sfx);
else if (weap_id == 1)
diff --git a/src/ft_get_topsp.c b/src/ft_get_topsp.c
deleted file mode 100644
index 84339c3..0000000
--- a/src/ft_get_topsp.c
+++ /dev/null
@@ -1,32 +0,0 @@
-/* ************************************************************************** */
-/* */
-/* ::: :::::::: */
-/* ft_check_map_line.c :+: :+: :+: */
-/* +:+ +:+ +:+ */
-/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */
-/* +#+#+#+#+#+ +#+ */
-/* Created: 2020/02/14 17:28:34 by rbousset #+# #+# */
-/* Updated: 2020/02/14 17:28:37 by rbousset ### ########lyon.fr */
-/* */
-/* ************************************************************************** */
-
-#include <libft.h>
-#include <cub3d.h>
-#include <stddef.h>
-#include <stdint.h>
-
-void
- ft_get_topsp(char c, t_cub *clist)
-{
- (void)c;
- (void)clist;
- /* int8_t x; */
-
- /* if ((x = ft_strlchr(FT_CHRST_SPRITES, c)) > 0) */
- /* { */
- /* if ((x + 2) > clist->mlist.topsp) */
- /* { */
- /* clist->mlist.topsp = x + 2; */
- /* } */
- /* } */
-}
diff --git a/src/ft_init_lists.c b/src/ft_init_lists.c
index d9a2ad2..b551aab 100644
--- a/src/ft_init_lists.c
+++ b/src/ft_init_lists.c
@@ -33,7 +33,7 @@ t_rgb
** -1: no weapon
** 0: weapon one
** 2: weapon two
-** 4: weapon two
+** 4: weapon three
*/
t_player
@@ -55,6 +55,9 @@ t_player
plist.has_weapon[1] = 0;
plist.has_weapon[2] = 0;
plist.handles_weapon = -1;
+ plist.ammo[0] = 0;
+ plist.ammo[1] = 0;
+ plist.ammo[2] = 0;
plist.life = FT_STRT_LIFE;
plist.fire = 0;
return (plist);
diff --git a/src/ft_init_map.c b/src/ft_init_map.c
index a2a9ce1..1b55d17 100644
--- a/src/ft_init_map.c
+++ b/src/ft_init_map.c
@@ -97,8 +97,6 @@ int8_t
mlist->isskybox = 0;
mlist->istraps = 0;
mlist->isheals = 0;
- mlist->isweapon[0] = 0;
- mlist->isweapon[1] = 0;
mlist->traps_nbr = 0;
mlist->heals_nbr = 0;
return (ft_init_map_norme(mlist));
diff --git a/src/ft_warp_level.c b/src/ft_warp_level.c
index 02911b0..5055445 100644
--- a/src/ft_warp_level.c
+++ b/src/ft_warp_level.c
@@ -21,14 +21,18 @@
static void
ft_player_keepings(t_cub *cl)
{
- int16_t tmp_life;
- uint8_t tmp_has[3];
- int8_t tmp_handles;
+ int16_t tmp_life;
+ uint8_t tmp_has[3];
+ uint16_t tmp_ammo[3];
+ int8_t tmp_handles;
tmp_life = cl->plist.life;
tmp_has[0] = cl->plist.has_weapon[0];
tmp_has[1] = cl->plist.has_weapon[1];
tmp_has[2] = cl->plist.has_weapon[2];
+ tmp_ammo[0] = cl->plist.ammo[0];
+ tmp_ammo[1] = cl->plist.ammo[1];
+ tmp_ammo[2] = cl->plist.ammo[2];
tmp_handles = cl->plist.handles_weapon;
cl->plist = ft_init_player();
if (!cl->isdead)
@@ -36,6 +40,9 @@ static void
cl->plist.has_weapon[0] = tmp_has[0];
cl->plist.has_weapon[1] = tmp_has[1];
cl->plist.has_weapon[2] = tmp_has[2];
+ cl->plist.ammo[0] = tmp_ammo[0];
+ cl->plist.ammo[1] = tmp_ammo[1];
+ cl->plist.ammo[2] = tmp_ammo[2];
cl->plist.handles_weapon = tmp_handles;
}