mirror of
https://github.com/yquake2/yquake2remaster.git
synced 2025-01-20 08:21:08 +00:00
Simplify the Vulkan renderer build.
* No need for global CXXFLAGS. The only difference to CFLAGS is the standard selector, use $(subst) to derive them from CFLAGS. * libstd++ must never be manually linked. Doing so only works for the GNU C++ stack, not for the LLVM stack and anything else. Link with the C++ frontend instead. * Force MingW to g++ as CXX.Force MingW to g++ as CXX. * No need to specify -lm, libm is already part of the global LDFLAGS. * Windows doesn't need -fPIC. * The Vulkan renderer doesn't use glad.
This commit is contained in:
parent
c895d004d2
commit
9801db5c5c
1 changed files with 16 additions and 32 deletions
48
Makefile
48
Makefile
|
@ -99,6 +99,7 @@ endif
|
|||
# On Windows / MinGW $(CC) is undefined by default.
|
||||
ifeq ($(YQ2_OSTYPE),Windows)
|
||||
CC ?= gcc
|
||||
CXX ?= g++
|
||||
endif
|
||||
|
||||
# Detect the compiler
|
||||
|
@ -167,27 +168,6 @@ endif
|
|||
|
||||
# ----------
|
||||
|
||||
# Base CPPFLAGS.
|
||||
#
|
||||
# -O2 are enough optimizations.
|
||||
#
|
||||
# -g to build always with debug symbols. Please DO NOT
|
||||
# CHANGE THIS, since it's our only chance to debug this
|
||||
# crap when random crashes happen!
|
||||
#
|
||||
# -fwrapv for defined integer wrapping. MSVC6 did this
|
||||
# and the game code requires it.
|
||||
ifeq ($(YQ2_OSTYPE), Darwin)
|
||||
CPPFLAGS := -O2 -fno-strict-aliasing -fomit-frame-pointer \
|
||||
-Wall -pipe -g -fwrapv
|
||||
CPPFLAGS += $(OSX_ARCH)
|
||||
else
|
||||
CPPFLAGS := -O2 -fno-strict-aliasing \
|
||||
-Wall -pipe -g -ggdb -MMD -fwrapv
|
||||
endif
|
||||
|
||||
# ----------
|
||||
|
||||
# Switch of some annoying warnings.
|
||||
ifeq ($(COMPILER), clang)
|
||||
# -Wno-missing-braces because otherwise clang complains
|
||||
|
@ -661,34 +641,35 @@ build/ref_soft/%.o: %.c
|
|||
# ----------
|
||||
|
||||
# The vk renderer lib
|
||||
#
|
||||
ifeq ($(YQ2_OSTYPE), Windows)
|
||||
ref_vk:
|
||||
@echo "===> Building ref_vk.dll"
|
||||
$(MAKE) release/ref_vk.dll
|
||||
|
||||
release/ref_vk.dll : CFLAGS += -fPIC
|
||||
release/ref_vk.dll : CPPFLAGS += -fPIC
|
||||
release/ref_vk.dll : LDFLAGS += -shared -lm -lvulkan -lstdc++
|
||||
release/ref_vk.dll : LDFLAGS += -shared -lvulkan
|
||||
else
|
||||
ref_vk:
|
||||
@echo "===> Building ref_vk.so"
|
||||
$(MAKE) release/ref_vk.so
|
||||
|
||||
release/ref_vk.so : CFLAGS += -fPIC
|
||||
release/ref_vk.so : CPPFLAGS += -fPIC
|
||||
release/ref_vk.so : LDFLAGS += -shared -lm -lvulkan -lstdc++
|
||||
release/ref_vk.so : LDFLAGS += -shared -lvulkan
|
||||
endif
|
||||
|
||||
build/ref_vk/%.o: %.c
|
||||
@echo "===> CC $<"
|
||||
${Q}mkdir -p $(@D)
|
||||
${Q}$(CC) -c $(CFLAGS) $(SDLCFLAGS) $(INCLUDE) $(GLAD_INCLUDE) -o $@ $<
|
||||
${Q}$(CC) -c $(CFLAGS) $(SDLCFLAGS) $(INCLUDE) -o $@ $<
|
||||
|
||||
# The Vulkan memory allocator must be build as C++.
|
||||
# Because of this we need to link the lib with the
|
||||
# C++ frontend and not the C frontend... Assume that
|
||||
# the system uses the same compiler for both C and
|
||||
# C++, e.g. clang and clang++. Not gcc and clang++.
|
||||
build/ref_vk/%.o: %.cpp
|
||||
@echo "===> CC $<"
|
||||
@echo "===> CXX $<"
|
||||
${Q}mkdir -p $(@D)
|
||||
${Q}$(CC) -c $(CPPFLAGS) $(SDLCFLAGS) $(INCLUDE) $(GLAD_INCLUDE) -o $@ $<
|
||||
${Q}$(CXX) -c $(subst gnu99,c++11,$(CFLAGS)) $(SDLCFLAGS) $(INCLUDE) -o $@ $<
|
||||
|
||||
# ----------
|
||||
|
||||
|
@ -1167,14 +1148,17 @@ release/ref_soft.so : $(REFSOFT_OBJS)
|
|||
endif
|
||||
|
||||
# release/ref_vk.so
|
||||
#
|
||||
# Must be linked with the C++ frontend, because the
|
||||
# Vulkan memory allocator is compiled as C++ source.
|
||||
ifeq ($(YQ2_OSTYPE), Windows)
|
||||
release/ref_vk.dll : $(REFVK_OBJS)
|
||||
@echo "===> LD $@"
|
||||
${Q}$(CC) $(REFVK_OBJS) $(LDFLAGS) $(SDLLDFLAGS) -o $@
|
||||
${Q}$(CXX) $(REFVK_OBJS) $(LDFLAGS) $(SDLLDFLAGS) -o $@
|
||||
else
|
||||
release/ref_vk.so : $(REFVK_OBJS)
|
||||
@echo "===> LD $@"
|
||||
${Q}$(CC) $(REFVK_OBJS) $(LDFLAGS) $(SDLLDFLAGS) -o $@
|
||||
${Q}$(CXX) $(REFVK_OBJS) $(LDFLAGS) $(SDLLDFLAGS) -o $@
|
||||
endif
|
||||
|
||||
# release/baseq2/game.so
|
||||
|
|
Loading…
Reference in a new issue