diff options
author | JozanLeClerc <bousset.rudy@gmail.com> | 2020-03-31 16:19:22 +0200 |
---|---|---|
committer | JozanLeClerc <bousset.rudy@gmail.com> | 2020-03-31 16:19:22 +0200 |
commit | 2ea18fb7e893691389108ae7731e26576715ca13 (patch) | |
tree | c6a4ccfb785ff7289279d6b08997939c36b4c9ca /src/ft_sfx_bb_scream.c | |
parent | Good (diff) | |
download | 42-cub3d-2ea18fb7e893691389108ae7731e26576715ca13.tar.gz 42-cub3d-2ea18fb7e893691389108ae7731e26576715ca13.tar.bz2 42-cub3d-2ea18fb7e893691389108ae7731e26576715ca13.tar.xz 42-cub3d-2ea18fb7e893691389108ae7731e26576715ca13.tar.zst 42-cub3d-2ea18fb7e893691389108ae7731e26576715ca13.zip |
Alright sounds
Diffstat (limited to 'src/ft_sfx_bb_scream.c')
-rw-r--r-- | src/ft_sfx_bb_scream.c | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/src/ft_sfx_bb_scream.c b/src/ft_sfx_bb_scream.c new file mode 100644 index 0000000..da93bdc --- /dev/null +++ b/src/ft_sfx_bb_scream.c @@ -0,0 +1,48 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_sfx_bb_scream.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/24 17:17:54 by rbousset #+# #+# */ +/* Updated: 2020/02/24 17:17:56 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <cub3d.h> +#include <stdlib.h> +#include <pthread.h> + +void + *ft_sfx_bb_scream_thread(void *vargp) +{ + t_sfx *sfx; + static uint8_t ref = 0; + + if (FT_OS == 1) + pthread_setcancelstate(PTHREAD_CANCEL_ASYNCHRONOUS, NULL); + else + pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL); + sfx = (t_sfx *)vargp; + pthread_mutex_lock(&sfx[14].mutex); + while (1) + { + pthread_mutex_lock(&sfx[14].mutex); + ref = (ref > 201) ? (0) : (ref + 1); + if (ref % 3) + { + if (system(sfx[14].cmd)) + pthread_exit(NULL); + } + else if (system(sfx[14].cmd_alt)) + pthread_exit(NULL); + } + return (NULL); +} + +void + ft_sfx_bb_scream(t_sfx *sfx) +{ + pthread_mutex_unlock(&sfx[14].mutex); +} |