aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile9
-rw-r--r--libft/Makefile20
-rw-r--r--src/ft_draw_hud.c30
-rw-r--r--src/ft_draw_verline.c3
4 files changed, 46 insertions, 16 deletions
diff --git a/Makefile b/Makefile
index 6ed66b4..4c10947 100644
--- a/Makefile
+++ b/Makefile
@@ -72,6 +72,7 @@ LFT_SRCS = $(shell find libft/src -name "*.c")
MKDIR = mkdir -p
RM = rm -rf
OS = $(shell uname)
+USER = $(shell w | grep tty7 | awk '{print $$1}')
ifeq (${OS}, Darwin)
SCR_SZE = $(shell osascript -e 'tell application "Finder" to get bounds of window of desktop' \
| tr ',' 'x' | tr -d '\n' | tr -d ' ' | cut -c 5-)
@@ -98,7 +99,13 @@ ifdef ASAN
endif
#--------------------------------------------------------------------------------------------------#
ifdef OPTI
- CFLAGS += -march=ivybridge
+ ifeq (${USER}, salaaad)
+ CFLAGS += -march=broadwell
+ else ifeq (${USER}, jozan)
+ CFLAGS += -march=ivybridge
+ else
+ CFLAGS += -march=native
+ endif
CFLAGS += -O2
CFLAGS += -pipe
endif
diff --git a/libft/Makefile b/libft/Makefile
index 0af47bb..e22c78a 100644
--- a/libft/Makefile
+++ b/libft/Makefile
@@ -109,6 +109,13 @@ SRCS = $(addprefix ${SRCS_DIR},${SRCS_NAME})
#------------------------------------------------------------------------------#
OBJS = $(patsubst ${SRCS_DIR}%.c,${OBJS_DIR}%.o,${SRCS})
#==============================================================================#
+#--------------------------------- UNIX ---------------------------------------#
+#==============================================================================#
+MKDIR = mkdir -p
+RM = rm -rf
+OS = $(shell uname)
+USER = $(shell w | grep tty7 | awk '{print $$1}')
+#==============================================================================#
#-------------------------------- Compiler ------------------------------------#
#==============================================================================#
DEBUG = -glldb
@@ -128,7 +135,13 @@ ifdef ASAN
endif
#------------------------------------------------------------------------------#
ifdef OPTI
- CFLAGS += -march=ivybridge
+ ifeq (${USER}, salaaad)
+ CFLAGS += -march=broadwell
+ else ifeq (${USER}, jozan)
+ CFLAGS += -march=ivybridge
+ else
+ CFLAGS += -march=native
+ endif
CFLAGS += -O2
CFLAGS += -pipe
endif
@@ -139,11 +152,6 @@ NAME = libft.a
#==============================================================================#
AR = ar rcs
#==============================================================================#
-#--------------------------------- UNIX ---------------------------------------#
-#==============================================================================#
-MKDIR = mkdir -p
-RM = rm -rf
-#==============================================================================#
#--------------------------------- Rules --------------------------------------#
#==============================================================================#
${OBJS_DIR}%.o: ${SRCS_DIR}%.c ${INCS_DIR}${INCS}
diff --git a/src/ft_draw_hud.c b/src/ft_draw_hud.c
index bd2bf37..d0ed81d 100644
--- a/src/ft_draw_hud.c
+++ b/src/ft_draw_hud.c
@@ -20,46 +20,60 @@ static void
const uint16_t scl = cl->mlist->scale;
uint32_t x;
uint32_t y;
+ int32_t col;
+ col = 0x00404040;
x = 0;
y = wl->y_size - ((cl->mlist->map_h * scl));
while (x < wl->x_size)
{
while (y < wl->y_size)
{
- *(int*)(cl->img.ptr + (x * 4 +
- (y * cl->img.sizeline))) = 0x00808080;
+ *(int*)(cl->img.ptr + (x * 4 + (y * cl->img.sizeline))) = col;
+ if (y % 2)
+ {
+ if (col < 0x00AAAAAA)
+ col += 0x00010101;
+ }
y++;
}
+ col = 0x00404040;
y = wl->y_size - ((cl->mlist->map_h * scl));
x++;
}
}
static void
- ft_draw_hud_back_top_r(size_t map_h, size_t map_w, t_win *wl, t_cub *cl)
+ ft_draw_hud_back_top_l(size_t map_h, size_t map_w, t_win *wl, t_cub *cl)
{
const uint16_t scl = cl->mlist->scale;
uint32_t x;
uint32_t y;
+ int32_t col;
+ col = 0x00353535;
x = 0;
y = wl->y_size - (map_h * scl) - 20;
while (x < (map_w * scl) + 20)
{
while (y < wl->y_size - (map_h * scl))
{
- *(int*)(cl->img.ptr + (x * 4 +
- (y * cl->img.sizeline))) = 0x00808080;
+ *(int*)(cl->img.ptr + (x * 4 + (y * cl->img.sizeline))) = col;
+ if (y % 2)
+ {
+ if (col < 0x00AAAAAA)
+ col += 0x00010101;
+ }
y++;
}
+ col = 0x00353535;
y = wl->y_size - (map_h * scl) - 20;
x++;
}
}
static void
- ft_draw_hud_back_top_l(size_t map_h, size_t map_w, t_win *wl, t_cub *cl)
+ ft_draw_hud_back_top_r(size_t map_h, size_t map_w, t_win *wl, t_cub *cl)
{
const uint16_t scl = cl->mlist->scale;
uint32_t x;
@@ -84,9 +98,9 @@ void
ft_draw_hud(t_cub *clist)
{
ft_draw_hud_back(clist->wlist, clist);
- ft_draw_hud_back_top_r(clist->mlist->map_h,
- clist->mlist->map_w, clist->wlist, clist);
ft_draw_hud_back_top_l(clist->mlist->map_h,
clist->mlist->map_w, clist->wlist, clist);
+ ft_draw_hud_back_top_r(clist->mlist->map_h,
+ clist->mlist->map_w, clist->wlist, clist);
ft_draw_map(clist->mlist->map, clist);
}
diff --git a/src/ft_draw_verline.c b/src/ft_draw_verline.c
index de54a3a..1a1b2fe 100644
--- a/src/ft_draw_verline.c
+++ b/src/ft_draw_verline.c
@@ -46,12 +46,13 @@ int8_t
(y < 0) ? (y = 0) : 0;
(y2 < 0) ? (y2 = 0) : 0;
ft_draw_ceil(cl, y, x);
+ (cl->rlist.line_h <= 0) ? (cl->rlist.line_h = 1) : 0;
while (y <= y2)
{
d = y * 256 - cl->wlist->y_size * 128 + cl->rlist.line_h * 128;
d = (d <= 0) ? (-d) : (d);
tex_y = ((d * cl->tlist[cl->w_side].img_h) / cl->rlist.line_h) / 256;
- (tex_y < 0) ? (tex_y = 0) : 0;
+ (tex_y <= 0) ? (tex_y = 1) : 0;
ft_draw_texture(cl, x, y, tex_y);
y++;
}