aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile5
-rw-r--r--inc/cub3d_structs.h5
-rw-r--r--src/ft_sfx_footstep.c40
-rw-r--r--src/ft_sfx_trap.c3
4 files changed, 27 insertions, 26 deletions
diff --git a/Makefile b/Makefile
index e27b411..7c24e8b 100644
--- a/Makefile
+++ b/Makefile
@@ -127,7 +127,6 @@ CFLAGS += -Wall
CFLAGS += -Wextra
CFLAGS += -Werror
CFLAGS += -pedantic
-CFLAGS += -pthread
#--------------------------------------------------------------------------------------------------#
ifdef ASAN
CFLAGS += ${DEBUG}
@@ -164,10 +163,10 @@ else
@$(MAKE) --no-print-directory -C ${LFT_DIR} all
endif
ifeq (${OS}, Darwin)
- ${CC} ${CFLAGS} -o $@ ${OBJS} -L${LFT_DIR} -L${MLX_DIR} -lft -lmlx -lm -lpthread \
+ ${CC} ${CFLAGS} -o $@ ${OBJS} -L${LFT_DIR} -L${MLX_DIR} -lft -lmlx -lm \
-framework OpenGL -framework AppKit
else
- ${CC} ${CFLAGS} -o $@ ${OBJS} -L${LFT_DIR} -lft -lX11 -lXext -lmlx -lm -lbsd -lpthread
+ ${CC} ${CFLAGS} -o $@ ${OBJS} -L${LFT_DIR} -lft -lX11 -lXext -lmlx -lm -lbsd
endif
#--------------------------------------------------------------------------------------------------#
all: ${NAME}
diff --git a/inc/cub3d_structs.h b/inc/cub3d_structs.h
index 04ee59c..3d61900 100644
--- a/inc/cub3d_structs.h
+++ b/inc/cub3d_structs.h
@@ -69,6 +69,11 @@ typedef struct s_sfx
pid_t new_lvl_pid;
pid_t pain_pid;
pid_t trap_pid;
+ pthread_t death_tid;
+ pthread_t footstep_tid;
+ pthread_t new_lvl_tid;
+ pthread_t pain_tid;
+ pthread_t trap_tid;
} t_sfx;
typedef struct s_bmp_rgb
diff --git a/src/ft_sfx_footstep.c b/src/ft_sfx_footstep.c
index bccb847..d9f083d 100644
--- a/src/ft_sfx_footstep.c
+++ b/src/ft_sfx_footstep.c
@@ -16,29 +16,27 @@
#include <sys/types.h>
#include <sys/wait.h>
-#include <sys/types.h>
-#include <sys/time.h>
-#include <sys/resource.h>
-#include <libft.h>
void
ft_sfx_footstep(t_cub *cl)
{
- (void)cl;
- /* static uint8_t ref = 0; */
+ static uint8_t ref = 0;
- /* cl->sfx.footstep_pid = fork(); */
- /* if (cl->sfx.footstep_pid == 0) */
- /* { */
- /* ref += 1; */
- /* if (ref > 201) */
- /* ref = 0; */
- /* if (ref % 2) */
- /* execve(*(cl->sfx.footstep_one + 0), */
- /* cl->sfx.footstep_one, cl->envp); */
- /* else */
- /* execve(*(cl->sfx.footstep_two + 0), */
- /* cl->sfx.footstep_two, cl->envp); */
- /* } */
- /* else */
- /* wait(&cl->sfx.footstep_pid); */
+ if (waitpid(cl->sfx.footstep_pid, 0, WNOHANG) > 0)
+ {
+ cl->sfx.footstep_pid = fork();
+ if (cl->sfx.footstep_pid == 0)
+ {
+ ref += 1;
+ if (ref > 201)
+ ref = 0;
+ if (ref % 2)
+ execve(*(cl->sfx.footstep_one + 0),
+ cl->sfx.footstep_one, cl->envp);
+ else
+ execve(*(cl->sfx.footstep_two + 0),
+ cl->sfx.footstep_two, cl->envp);
+ }
+ else
+ wait(&cl->sfx.footstep_pid);
+ }
}
diff --git a/src/ft_sfx_trap.c b/src/ft_sfx_trap.c
index b52b9c1..1499ecf 100644
--- a/src/ft_sfx_trap.c
+++ b/src/ft_sfx_trap.c
@@ -15,7 +15,6 @@
#include <unistd.h>
#include <stdint.h>
-#include <pthread.h>
static void
ft_sfx_pain(t_cub *cl)
{
@@ -41,7 +40,7 @@ void
ft_sfx_trap(t_cub *cl)
{
cl->sfx.trap_pid = fork();
- else if (cl->sfx.trap_pid == 0)
+ if (cl->sfx.trap_pid == 0)
execve(*(cl->sfx.trap + 0), cl->sfx.trap, cl->envp);
else
{