diff options
Diffstat (limited to '')
| -rw-r--r-- | src/ft_exit.c | 2 | ||||
| -rw-r--r-- | src/ft_get_music.c | 4 | ||||
| -rw-r--r-- | src/ft_init_lists.c | 1 | ||||
| -rw-r--r-- | src/ft_music.c | 2 | ||||
| -rw-r--r-- | src/ft_warp_level.c | 28 | 
5 files changed, 31 insertions, 6 deletions
| diff --git a/src/ft_exit.c b/src/ft_exit.c index a19bff3..c022627 100644 --- a/src/ft_exit.c +++ b/src/ft_exit.c @@ -63,7 +63,7 @@ int  		mlx_destroy_window(clist->wlist->wlx, clist->wlist->winptr);  		clist->wlist->winptr = NULL;  	} -	if (clist->mlist->ismusic) +	if (clist->isoldmus && clist->wlist->inited)  	{  		pthread_cancel(clist->tid);  		pthread_join(clist->tid, NULL); diff --git a/src/ft_get_music.c b/src/ft_get_music.c index 21c6331..df65a7f 100644 --- a/src/ft_get_music.c +++ b/src/ft_get_music.c @@ -30,8 +30,8 @@ static void  		return ;  	if (FT_OS == 2)  	{ -		ft_sprintf(mlist->music_cmd, -			"aplay -f cd -t wav -q %s", mlist->music_path); +		ft_sprintf(mlist->music_cmd, "aplay -f cd -t wav -q %s", +					mlist->music_path);  	}  	else {}  } diff --git a/src/ft_init_lists.c b/src/ft_init_lists.c index fd8c75d..eec8d5d 100644 --- a/src/ft_init_lists.c +++ b/src/ft_init_lists.c @@ -81,6 +81,7 @@ static t_cub  	while (++i < 5)  		clist->key_input[i] = -1;  	clist->ishud = 0; +	clist->isoldmus = 0;  	clist->f_rgb = ft_init_rgb();  	clist->c_rgb = ft_init_rgb();  	clist->rlist = ft_init_s_ray(); diff --git a/src/ft_music.c b/src/ft_music.c index 5eed915..d110256 100644 --- a/src/ft_music.c +++ b/src/ft_music.c @@ -22,7 +22,7 @@ void  	t_cub	*cl;  	cl = (t_cub *)vargp; -	ft_printf("%s\n", cl->mlist->music_cmd); +	cl->isoldmus = 1;  	system(cl->mlist->music_cmd);  	return (NULL);  } diff --git a/src/ft_warp_level.c b/src/ft_warp_level.c index 41d1a45..de87187 100644 --- a/src/ft_warp_level.c +++ b/src/ft_warp_level.c @@ -53,23 +53,41 @@ static void  	cl->c_rgb = ft_init_rgb();  	cl->rlist = ft_init_s_ray();  	i = 0; -	while (i < 5) +	while (i <= 5)  	{  		mlx_destroy_image(cl->wlist->wlx, cl->tlist[i].img);  		cl->tlist[i].img = NULL;  		i++;  	} -	if (cl->mlist->ismusic) +} + +static void +	ft_treat_music(uint8_t isoldmus, char *tmp_mup, t_cub *cl) +{ +	if (isoldmus && !cl->mlist->ismusic) +	{ +		pthread_cancel(cl->tid); +		pthread_join(cl->tid, NULL); +		cl->isoldmus = 0; +	} +	else if (isoldmus && cl->mlist->ismusic +		&& ft_strncmp(tmp_mup, cl->mlist->music_path, ft_strlen(tmp_mup) + 1))  	{  		pthread_cancel(cl->tid);  		pthread_join(cl->tid, NULL); +		pthread_create(&cl->tid, NULL, ft_music_thread, cl);  	} +	else if (isoldmus && cl->mlist->ismusic +		&& !ft_strncmp(tmp_mup, cl->mlist->music_path, ft_strlen(tmp_mup) + 1)) +		return ;  }  int8_t  	ft_warp_level(t_cub *cl)  {  	char	*next_path; +	char	*tmp_mup; +	uint8_t	isoldmus;  	if ((uint32_t)cl->plist->pos_x == cl->mlist->nlx &&  		(uint32_t)cl->plist->pos_y == cl->mlist->nly) @@ -78,11 +96,17 @@ int8_t  				cl->mlist->nlevel_path) + 1) * sizeof(char))))  			return (-1);  		ft_sprintf(next_path, "%s", cl->mlist->nlevel_path); +		isoldmus = cl->mlist->ismusic; +		if (isoldmus) +			tmp_mup = ft_strdup(cl->mlist->music_path);  		ft_del_some(cl);  		ft_del_map(cl->mlist);  		if (!(cl->mlist = ft_init_map()))  			return (-1);  		ft_parse_map(next_path, cl); +		ft_treat_music(isoldmus, tmp_mup, cl); +		if (isoldmus) +			ft_memdel((void**)&tmp_mup);  		ft_wall_tex_init(cl);  		ft_memdel((void**)&next_path);  	} | 
