aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--Makefile13
-rw-r--r--inc/cub3d.h1
-rw-r--r--inc/cub3d_structs.h3
-rw-r--r--libft/Makefile12
-rw-r--r--src/ft_exit.c1
-rw-r--r--src/ft_get_skybox.c43
-rw-r--r--src/ft_init_funptr.c1
-rw-r--r--src/ft_init_map.c1
-rw-r--r--src/ft_warp_level.c1
9 files changed, 71 insertions, 5 deletions
diff --git a/Makefile b/Makefile
index f8fb71e..9fc6143 100644
--- a/Makefile
+++ b/Makefile
@@ -38,6 +38,7 @@ SRCS_NAME += ft_get_tex_nl.c
SRCS_NAME += ft_get_tex_extra.c
SRCS_NAME += ft_get_path_nl.c
SRCS_NAME += ft_get_nlvl_pos.c
+SRCS_NAME += ft_get_skybox.c
SRCS_NAME += ft_get_player_spawn.c
SRCS_NAME += ft_get_music.c
SRCS_NAME += ft_get_darkness.c
@@ -101,10 +102,18 @@ endif
#==================================================================================================#
#------------------------------------------ Compiler ----------------------------------------------#
#==================================================================================================#
-DEBUG = -glldb
+ifeq (${OS}, Darwin)
+ DEBUG = -glldb
+else
+ DEBUG = -ggdb
+endif
FSANITIZE = -fsanitize=address
#--------------------------------------------------------------------------------------------------#
-CC = clang
+ifeq (${OS}, Darwin)
+ CC = clang
+else
+ CC = gcc
+endif
#--------------------------------------------------------------------------------------------------#
CFLAGS = -std=c89
CFLAGS += -Wall
diff --git a/inc/cub3d.h b/inc/cub3d.h
index f255b00..6201b91 100644
--- a/inc/cub3d.h
+++ b/inc/cub3d.h
@@ -99,6 +99,7 @@ int8_t ft_get_c_color(char **words, t_cub *clist);
int8_t ft_get_c_tex(char **words, t_cub *clist);
int8_t ft_get_darkness(char **words, t_cub *clist);
int8_t ft_get_path_nl(char **words, t_cub *clist);
+int8_t ft_get_skybox(char **words, t_cub *clist);
int8_t ft_get_tex_nl(char **words, t_cub *clist);
int8_t ft_get_music(char **words, t_cub *clist);
size_t ft_get_map_h(char **map);
diff --git a/inc/cub3d_structs.h b/inc/cub3d_structs.h
index 845ae31..773c783 100644
--- a/inc/cub3d_structs.h
+++ b/inc/cub3d_structs.h
@@ -167,6 +167,7 @@ typedef struct s_map
char *fl_tex_path;
char *ce_tex_path;
char *nlevel_path;
+ char *skybox_path;
char *music_path;
char *music_cmd;
char *mapl;
@@ -208,7 +209,7 @@ typedef struct s_cub
int32_t key_input[5];
pid_t mpid;
int (*key_ptr[6])(struct s_cub*);
- int8_t (*get_ptr[12])(char**, struct s_cub*);
+ int8_t (*get_ptr[13])(char**, struct s_cub*);
char ref[14][3];
struct s_win wlist;
struct s_player plist;
diff --git a/libft/Makefile b/libft/Makefile
index d2053ee..1f93f13 100644
--- a/libft/Makefile
+++ b/libft/Makefile
@@ -119,10 +119,18 @@ USER = $(shell w | grep tty7 | awk '{print $$1}')
#==============================================================================#
#-------------------------------- Compiler ------------------------------------#
#==============================================================================#
-DEBUG = -glldb
+ifeq (${OS}, Darwin)
+ DEBUG = -glldb
+else
+ DEBUG = -ggdb
+endif
FSANITIZE = -fsanitize=address
#------------------------------------------------------------------------------#
-CC = clang
+ifeq (${OS}, Darwin)
+ CC = clang
+else
+ CC = gcc
+endif
#------------------------------------------------------------------------------#
CFLAGS = -std=c89
CFLAGS += -Wall
diff --git a/src/ft_exit.c b/src/ft_exit.c
index 659d0ec..97c9e02 100644
--- a/src/ft_exit.c
+++ b/src/ft_exit.c
@@ -32,6 +32,7 @@ static void
ft_memdel((void**)&clist->mlist.fl_tex_path);
ft_memdel((void**)&clist->mlist.ce_tex_path);
ft_memdel((void**)&clist->mlist.nlevel_path);
+ ft_memdel((void**)&clist->mlist.skybox_path);
ft_memdel((void**)&clist->mlist.music_path);
ft_memdel((void**)&clist->mlist.music_cmd);
ft_memdel((void**)&clist->mlist.mapl);
diff --git a/src/ft_get_skybox.c b/src/ft_get_skybox.c
new file mode 100644
index 0000000..011bec7
--- /dev/null
+++ b/src/ft_get_skybox.c
@@ -0,0 +1,43 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_get_skybox.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/02/14 17:28:53 by rbousset #+# #+# */
+/* Updated: 2020/02/14 17:28:53 by rbousset ### ########lyon.fr */
+/* */
+/* ************************************************************************** */
+
+#include <libft.h>
+#include <cub3d.h>
+#include <stdint.h>
+
+int8_t
+ ft_get_skybox(char **words, t_cub *clist)
+{
+ if (!(*words) || !(*(words + 1)) || (*(words + 2)))
+ {
+ ft_sprintf(clist->errmsg, FT_ERR_ARGS);
+ return (-1);
+ }
+ if (ft_check_ext(*(words + 1), ".xpm") < 0)
+ {
+ ft_sprintf(clist->errmsg, FT_ERR_NOT_A_XPM);
+ return (-1);
+ }
+ ft_memdel((void**)&clist->mlist.skybox_path);
+ if (!(clist->mlist.skybox_path = ft_strdup(*(words + 1))))
+ {
+ ft_sprintf(clist->errmsg, FT_ERR_ALLOCATE);
+ return (-1);
+ }
+ if (ft_check_not_found(clist->mlist.skybox_path) < 0)
+ {
+ ft_sprintf(clist->errmsg, FT_ERR_RD_NL_MAP);
+ return (-1);
+ }
+ clist->mlist.isskybox = 1;
+ return (0);
+}
diff --git a/src/ft_init_funptr.c b/src/ft_init_funptr.c
index 6d668dc..6bfa3f7 100644
--- a/src/ft_init_funptr.c
+++ b/src/ft_init_funptr.c
@@ -53,4 +53,5 @@ void
clist->get_ptr[9] = ft_get_tex_nl;
clist->get_ptr[10] = ft_get_music;
clist->get_ptr[11] = ft_get_darkness;
+ clist->get_ptr[12] = ft_get_skybox;
}
diff --git a/src/ft_init_map.c b/src/ft_init_map.c
index f8b91ec..27b4a39 100644
--- a/src/ft_init_map.c
+++ b/src/ft_init_map.c
@@ -28,6 +28,7 @@ static int8_t
!(mlist->fl_tex_path = (char*)ft_calloc(1, sizeof(char))) ||
!(mlist->ce_tex_path = (char*)ft_calloc(1, sizeof(char))) ||
!(mlist->nlevel_path = (char*)ft_calloc(1, sizeof(char))) ||
+ !(mlist->skybox_path = (char*)ft_calloc(1, sizeof(char))) ||
!(mlist->music_path = (char*)ft_calloc(1, sizeof(char))) ||
!(mlist->music_cmd = (char*)ft_calloc(1, sizeof(char))) ||
!(mlist->mapl = (char*)ft_calloc(1, sizeof(char))) ||
diff --git a/src/ft_warp_level.c b/src/ft_warp_level.c
index de2103d..0af4ecb 100644
--- a/src/ft_warp_level.c
+++ b/src/ft_warp_level.c
@@ -33,6 +33,7 @@ static void
ft_memdel((void**)&ml->fl_tex_path);
ft_memdel((void**)&ml->ce_tex_path);
ft_memdel((void**)&ml->nlevel_path);
+ ft_memdel((void**)&ml->skybox_path);
ft_memdel((void**)&ml->music_path);
ft_memdel((void**)&ml->music_cmd);
ft_memdel((void**)&ml->mapl);