ioq3quest/Makefile

2994 lines
78 KiB
Makefile
Raw Normal View History

2005-08-26 17:39:27 +00:00
#
# ioq3 Makefile
2005-08-26 17:39:27 +00:00
#
# GNU Make required
#
COMPILE_PLATFORM=$(shell uname | sed -e 's/_.*//' | tr '[:upper:]' '[:lower:]' | sed -e 's/\//_/g')
COMPILE_ARCH=$(shell uname -m | sed -e 's/i.86/x86/' | sed -e 's/^arm.*/arm/')
2007-12-07 10:11:47 +00:00
ifeq ($(COMPILE_PLATFORM),sunos)
# Solaris uname and GNU uname differ
COMPILE_ARCH=$(shell uname -p | sed -e 's/i.86/x86/')
2006-03-21 22:21:05 +00:00
endif
ifndef BUILD_STANDALONE
BUILD_STANDALONE =
endif
ifndef BUILD_CLIENT
BUILD_CLIENT =
endif
ifndef BUILD_SERVER
BUILD_SERVER =
endif
ifndef BUILD_GAME_SO
BUILD_GAME_SO =
endif
ifndef BUILD_GAME_QVM
BUILD_GAME_QVM =
endif
ifndef BUILD_BASEGAME
BUILD_BASEGAME =
endif
ifndef BUILD_MISSIONPACK
BUILD_MISSIONPACK=
endif
ifndef BUILD_RENDERER_OPENGL2
BUILD_RENDERER_OPENGL2=
2007-08-27 07:02:54 +00:00
endif
ifndef BUILD_AUTOUPDATER # DON'T build unless you mean to!
BUILD_AUTOUPDATER=0
endif
2007-08-27 07:02:54 +00:00
#############################################################################
#
# If you require a different configuration from the defaults below, create a
# new file named "Makefile.local" in the same directory as this file and define
# your parameters there. This allows you to change configuration without
# causing problems with keeping up to date with the repository.
#
#############################################################################
-include Makefile.local
ifeq ($(COMPILE_PLATFORM),cygwin)
PLATFORM=mingw32
endif
2005-12-29 00:04:41 +00:00
ifndef PLATFORM
PLATFORM=$(COMPILE_PLATFORM)
endif
export PLATFORM
2015-01-30 21:52:53 +00:00
ifeq ($(PLATFORM),mingw32)
MINGW=1
endif
ifeq ($(PLATFORM),mingw64)
MINGW=1
endif
ifeq ($(COMPILE_ARCH),i86pc)
COMPILE_ARCH=x86
endif
ifeq ($(COMPILE_ARCH),amd64)
COMPILE_ARCH=x86_64
endif
ifeq ($(COMPILE_ARCH),x64)
COMPILE_ARCH=x86_64
endif
ifeq ($(COMPILE_ARCH),powerpc)
COMPILE_ARCH=ppc
2005-12-29 00:04:41 +00:00
endif
ifeq ($(COMPILE_ARCH),powerpc64)
COMPILE_ARCH=ppc64
endif
2005-12-29 00:04:41 +00:00
ifeq ($(COMPILE_ARCH),axp)
COMPILE_ARCH=alpha
endif
ifndef ARCH
ARCH=$(COMPILE_ARCH)
2005-12-29 00:04:41 +00:00
endif
export ARCH
ifneq ($(PLATFORM),$(COMPILE_PLATFORM))
CROSS_COMPILING=1
else
CROSS_COMPILING=0
ifneq ($(ARCH),$(COMPILE_ARCH))
CROSS_COMPILING=1
endif
endif
export CROSS_COMPILING
ifndef VERSION
VERSION=1.36
endif
ifndef CLIENTBIN
CLIENTBIN=ioquake3
endif
2020-09-06 11:40:32 +00:00
ifndef LIBPREFIX
LIBPREFIX=
endif
ifndef SERVERBIN
SERVERBIN=ioq3ded
endif
ifndef BASEGAME
BASEGAME=baseq3
endif
ifndef BASEGAME_CFLAGS
BASEGAME_CFLAGS=
endif
ifndef MISSIONPACK
MISSIONPACK=missionpack
endif
ifndef MISSIONPACK_CFLAGS
MISSIONPACK_CFLAGS=-DMISSIONPACK
endif
2005-09-03 22:45:50 +00:00
ifndef COPYDIR
COPYDIR="/usr/local/games/quake3"
endif
2005-08-26 17:39:27 +00:00
ifndef COPYBINDIR
COPYBINDIR=$(COPYDIR)
endif
ifndef MOUNT_DIR
MOUNT_DIR=android/app/src/main/cpp/code
endif
ifndef BUILD_DIR
BUILD_DIR=build
endif
2005-08-26 17:39:27 +00:00
ifndef TEMPDIR
TEMPDIR=/tmp
endif
ifndef GENERATE_DEPENDENCIES
GENERATE_DEPENDENCIES=1
endif
2005-08-26 17:39:27 +00:00
ifndef USE_OPENAL
USE_OPENAL=1
endif
ifndef USE_OPENAL_DLOPEN
USE_OPENAL_DLOPEN=1
endif
ifndef USE_CURL
USE_CURL=1
endif
ifndef USE_CURL_DLOPEN
2015-01-30 21:52:53 +00:00
ifdef MINGW
USE_CURL_DLOPEN=0
else
USE_CURL_DLOPEN=1
endif
endif
ifndef USE_CODEC_VORBIS
USE_CODEC_VORBIS=1
endif
2013-02-18 00:32:05 +00:00
ifndef USE_CODEC_OPUS
USE_CODEC_OPUS=1
endif
ifndef USE_MUMBLE
USE_MUMBLE=1
endif
ifndef USE_VOIP
USE_VOIP=1
endif
ifndef USE_FREETYPE
USE_FREETYPE=0
endif
ifndef USE_INTERNAL_LIBS
USE_INTERNAL_LIBS=1
endif
2013-02-18 00:56:06 +00:00
ifndef USE_INTERNAL_OGG
USE_INTERNAL_OGG=$(USE_INTERNAL_LIBS)
2013-02-18 00:56:06 +00:00
endif
2014-02-08 08:26:03 +00:00
ifndef USE_INTERNAL_VORBIS
2014-07-20 10:58:38 +00:00
USE_INTERNAL_VORBIS=$(USE_INTERNAL_LIBS)
2014-02-08 08:26:03 +00:00
endif
2013-02-18 00:32:05 +00:00
ifndef USE_INTERNAL_OPUS
USE_INTERNAL_OPUS=$(USE_INTERNAL_LIBS)
2013-02-18 00:32:05 +00:00
endif
2009-10-19 14:00:16 +00:00
ifndef USE_INTERNAL_ZLIB
USE_INTERNAL_ZLIB=$(USE_INTERNAL_LIBS)
2009-10-19 14:00:16 +00:00
endif
ifndef USE_INTERNAL_JPEG
USE_INTERNAL_JPEG=$(USE_INTERNAL_LIBS)
endif
ifndef USE_LOCAL_HEADERS
USE_LOCAL_HEADERS=$(USE_INTERNAL_LIBS)
endif
ifndef USE_RENDERER_DLOPEN
USE_RENDERER_DLOPEN=1
endif
ifndef USE_YACC
USE_YACC=0
endif
ifndef USE_AUTOUPDATER # DON'T include unless you mean to!
USE_AUTOUPDATER=0
endif
ifndef DEBUG_CFLAGS
DEBUG_CFLAGS=-ggdb -O0
endif
2005-08-26 17:39:27 +00:00
#############################################################################
BD=$(BUILD_DIR)/debug-$(PLATFORM)-$(ARCH)
BR=$(BUILD_DIR)/release-$(PLATFORM)-$(ARCH)
2005-08-26 17:39:27 +00:00
CDIR=$(MOUNT_DIR)/client
SDIR=$(MOUNT_DIR)/server
2013-02-16 12:14:48 +00:00
RCOMMONDIR=$(MOUNT_DIR)/renderercommon
RGL2DIR=$(MOUNT_DIR)/renderergles3
2005-08-26 17:39:27 +00:00
CMDIR=$(MOUNT_DIR)/qcommon
SDLDIR=$(MOUNT_DIR)/sdl
ANDROIDDIR=$(MOUNT_DIR)/android
2020-09-06 11:40:32 +00:00
VRDIR=$(MOUNT_DIR)/vr
ASMDIR=$(MOUNT_DIR)/asm
SYSDIR=$(MOUNT_DIR)/sys
2005-08-26 17:39:27 +00:00
GDIR=$(MOUNT_DIR)/game
CGDIR=$(MOUNT_DIR)/cgame
BLIBDIR=$(MOUNT_DIR)/botlib
NDIR=$(MOUNT_DIR)/null
UIDIR=$(MOUNT_DIR)/ui
Q3UIDIR=$(MOUNT_DIR)/q3_ui
JPDIR=$(MOUNT_DIR)/jpeg-8c
OGGDIR=$(MOUNT_DIR)/libogg-1.3.3
VORBISDIR=$(MOUNT_DIR)/libvorbis-1.3.6
OPUSDIR=$(MOUNT_DIR)/opus-1.2.1
OPUSFILEDIR=$(MOUNT_DIR)/opusfile-0.9
2009-10-19 14:00:16 +00:00
ZDIR=$(MOUNT_DIR)/zlib
Q3ASMDIR=$(MOUNT_DIR)/tools/asm
LBURGDIR=$(MOUNT_DIR)/tools/lcc/lburg
Q3CPPDIR=$(MOUNT_DIR)/tools/lcc/cpp
Q3LCCETCDIR=$(MOUNT_DIR)/tools/lcc/etc
Q3LCCSRCDIR=$(MOUNT_DIR)/tools/lcc/src
AUTOUPDATERSRCDIR=$(MOUNT_DIR)/autoupdater
2017-06-04 05:16:37 +00:00
LIBTOMCRYPTSRCDIR=$(AUTOUPDATERSRCDIR)/rsa_tools/libtomcrypt-1.17
TOMSFASTMATHSRCDIR=$(AUTOUPDATERSRCDIR)/rsa_tools/tomsfastmath-0.13.1
LOKISETUPDIR=misc/setup
2008-04-15 14:19:03 +00:00
NSISDIR=misc/nsis
2013-01-21 22:40:05 +00:00
SDLHDIR=$(MOUNT_DIR)/SDL2
LIBSDIR=$(MOUNT_DIR)/libs
Squashed commit of the following: commit 0adeb4ba3bc12d1efeab7f7b4876fc61d9566ed4 Merge: 7feea565 d8653ad7 Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:32:21 2022 +0100 Merge branch 'OpenXR' of https://github.com/DrBeef/ioq3quest into OpenXR commit 7feea56514c17b3f1e7c15c73676bd9d8374ed6c Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:32:14 2022 +0100 Update Version Number commit d8653ad70e1cc9bf1fb2e72d6ad9c9b330db32d8 Merge: 79983b2b 7e6aa6da Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:31:45 2022 +0100 Merge pull request #76 from lvonasek/OpenXR OpenXR delayed controller pose fixed commit 79983b2bc5174eeb7c674396f07288da80ce94c5 Merge: 325641f9 7f89d6d1 Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:31:31 2022 +0100 Merge pull request #77 from petr666/OpenXR Update gamma values to better suit OpenXR build commit 7f89d6d19b2e807b001577c06c5f254106f95e0e Author: Petr Bartos <petr.bartos@plus4u.net> Date: Sat May 7 13:56:03 2022 +0200 Update gamma values to better suit OpenXR build commit 7e6aa6dab80e6ec4010e6057be4c0e34e4325245 Author: Lubos <tridosm@gmail.com> Date: Sat May 7 11:32:11 2022 +0200 OpenXR sync actions before updating controllers commit 027a7e96c312c43389299648326736766c8bab67 Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:34:50 2022 +0200 OpenXR implement controller velocity again commit af80d5c284b5372eb9b2533284325ae43caa80ec Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:18:51 2022 +0200 Compile fix commit ab1e853554a02c7dd59b2f59afab2569eb64ebed Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:14:08 2022 +0200 OpenXR input cleanup commit be158b4ad98a6b615c5fc34a407e4333dc468225 Author: Lubos <tridosm@gmail.com> Date: Fri May 6 09:39:49 2022 +0200 OpenXR sync input actions from renderer commit ed96160ffc0b3fb9350f8801257cfee713d8713f Author: Lubos <tridosm@gmail.com> Date: Fri May 6 09:25:59 2022 +0200 OpenXR do not use pose velocity to track controllers commit 42bf984ef8075ce45d6788fc09236d40d6a61dc9 Author: Lubos <tridosm@gmail.com> Date: Thu May 5 22:39:10 2022 +0200 OpenXR apply controller pose from renderer commit 92941b3547e7c4c7f126f608dde7239ee9c03b8e Author: Lubos <tridosm@gmail.com> Date: Thu May 5 22:26:33 2022 +0200 OpenXR delayed controller pose fixed commit 325641f90edbb1ba7ef96d288c443dd824a7528c Merge: de198fba 3ee3f590 Author: Simon <simonbrown77@googlemail.com> Date: Thu May 5 16:30:07 2022 +0100 Merge pull request #75 from lvonasek/OpenXR OpenXR menuyaw and recenter support added commit 3ee3f590584f6a8ff8d1e5cace7b999965c7e5cd Author: Lubos <tridosm@gmail.com> Date: Thu May 5 12:22:36 2022 +0200 OpenXR do not recenter on renderer reload commit 7072b0b89e0313a3bb39e8bb49dfdfa78e2972d9 Author: Lubos <tridosm@gmail.com> Date: Wed May 4 21:05:45 2022 +0200 OpenXR recenter sets yaw always to 0 commit 8e5f6414a6cb598c17b7d3cdbd208fe11d0d4fb3 Author: Lubos <tridosm@gmail.com> Date: Wed May 4 16:19:48 2022 +0200 OpenXR recenter integrated commit 08a4fc7fbf95e70f4a467350129a79d8358b34bd Author: Lubos <tridosm@gmail.com> Date: Tue May 3 18:37:28 2022 +0200 OpenXR use the same coordinate system in all layers commit a1de0e1ffe5081d0a15f4bd50b99f6a1c1439eac Author: Lubos <tridosm@gmail.com> Date: Mon May 2 22:17:53 2022 +0200 OpenXR menuYaw support added commit de198fba0da8130af67cfa9224c484e007d3a897 Author: Simon <simonbrown77@googlemail.com> Date: Mon May 2 10:01:42 2022 +0100 Update version numbers and add openxr identifier commit b83f99fe5b8db293a652f22d7adea825bf6a6549 Merge: c623bf13 9c14728b Author: Simon <simonbrown77@googlemail.com> Date: Mon May 2 09:43:47 2022 +0100 Merge pull request #74 from lvonasek/OpenXR OpenXR left controller mapping fixed commit 9c14728bc98f037dff8d7825692463b44915babe Merge: 11a849b1 0695c7ac Author: Lubos <tridosm@gmail.com> Date: Sun May 1 19:41:45 2022 +0200 Merge branch 'master' into OpenXR commit 11a849b189b4a5a8ab9676cd2cfeaae826e09187 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 19:09:12 2022 +0200 OpenXR controller mapping fixed commit 712584eae8dbcec3b10e0e39b2266f83487d4ecb Merge: df4bc0c0 c623bf13 Author: Luboš Vonásek <tridosm@gmail.com> Date: Sun May 1 19:04:45 2022 +0200 Merge branch 'DrBeef:OpenXR' into OpenXR commit c623bf1399406c24a1e9bf25fc54de758ac70c94 Merge: cb152467 e42a2f4e Author: Simon <simonbrown77@googlemail.com> Date: Sun May 1 14:10:23 2022 +0100 Merge pull request #72 from lvonasek/OpenXR OpenXR jitter fixed commit e42a2f4e0d4a0c48a266ef03b6599e70aadc1875 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 14:34:38 2022 +0200 Compile fix commit acbff1e7364c40d9f1a0820a561be40237c94994 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 13:59:41 2022 +0200 OpenXR camera view moved into renderer commit cb152467bacd5b7a92513b4279cf85a17f9c08e2 Merge: decc2d02 26071937 Author: Simon <simonbrown77@googlemail.com> Date: Sun May 1 10:20:40 2022 +0100 Merge pull request #69 from lvonasek/feature_openxr OpenXR integration commit 26071937c8b5053fe20e10d07fab5b9a695bfcc2 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 11:17:50 2022 +0200 OpenXR frameskip integrated commit f735535dcef2675678e1731ec67f4f5b7537bd49 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 22:57:48 2022 +0200 OpenXR attempt to fix flickering commit 0eb1d43b4aaa18550384d3689df9233bb293cbcc Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 21:28:26 2022 +0200 2D aspect ratio fixed commit 9d07c2760463062fa2afb52f533f8af4001c9576 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 21:23:53 2022 +0200 Hud model rendering fixed commit 30c9b4eaa0c3ecf235c592de0e52771a7d79453c Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 17:03:54 2022 +0200 Release build fixed commit 405ca571ad31d6bbd99de96e87cb0564d5daa60b Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 14:10:27 2022 +0200 OpenXR foveation removed commit 61b3192bce97b48587cd360c0318c4708a9e1828 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 14:02:21 2022 +0200 OpenXR projection matrix calculation from example code commit ecd50dbcb1b72baa1c730dbb900033febd4b81a8 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 21:21:10 2022 +0200 OpenXR low framerate fixed commit f5a8429fc1c094eb07b6a6ac463405a5ec44c63b Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 19:21:29 2022 +0200 Solution for black rectangles in the scene commit 9ae93a5fe9d684d7d739e1a9217324d770c4712a Merge: 10548445 decc2d02 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 14:58:35 2022 +0200 Merge branch 'master' into feature_openxr commit 10548445245439c1b245270fadc1a92f5be4650a Merge: 65e2031e 3cdf1858 Author: Lubos <tridosm@gmail.com> Date: Wed Apr 27 21:52:55 2022 +0200 Merge branch 'master' into feature_openxr commit 65e2031e954fe075189d1ab90eb6edce1b726731 Author: Lubos <tridosm@gmail.com> Date: Tue Apr 26 22:02:04 2022 +0200 OpenXR integration fixes commit c321b97894fa9dc240b82a89426a5b4516a6eb5b Author: Lubos <tridosm@gmail.com> Date: Mon Apr 25 16:48:09 2022 +0200 OpenXR multiview integrated commit 594716896626c4c2190dc620ed66bd69c858031d Author: Lubos <tridosm@gmail.com> Date: Sun Apr 24 20:25:19 2022 +0200 OpenXR minor fixes commit 249847930be0230b6d99008475b2f4c9bb1636f0 Author: Lubos <tridosm@gmail.com> Date: Sun Apr 24 18:06:02 2022 +0200 OpenXR use just one framebuffer commit b11122e36882e5c62511528a6f107821f0a8de24 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 21:06:35 2022 +0200 OpenXR touch controllers completely implemented commit 0bf485664c41ffa742d703ec358c9c38d01b51cc Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 19:44:18 2022 +0200 OpenXR haptics and refreshrate fixed commit 4716387e5274674a9432bf3867fc05a2ac62b597 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 15:54:07 2022 +0200 OpenXR input except buttons implemented commit 7bd1fe31c2e9321af2fdd7ffee42ef94c08b5fdc Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 21:18:49 2022 +0200 OpenXR input in progress commit 3c26e08f011d25a907d05926c073baa93c94692d Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 18:41:26 2022 +0200 Old code removed commit 4d2644cae27c031e5c5d0c487e87c8e6b66b4857 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 18:32:42 2022 +0200 OpenXR fov fixed commit 501869a05128802049bb347eecb2c38d87391162 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 17:56:14 2022 +0200 OpenXR motion tracking in game mode added commit b152d21ddc669a135c7b2113440124ddbc1672df Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 16:14:36 2022 +0200 OpenXR cylinder projection added commit 3e9c80679e7c0adbeb20a3aa14ca20c48422b54a Merge: 0de4a0d1 39f669dd Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 14:13:18 2022 +0200 Merge branch 'master' into feature_openxr commit 0de4a0d19645706b6579ef00714e6291432f6543 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 13:45:22 2022 +0200 OpenXR tracking added init, first working rendering commit 8431b1aa83be613e4c3f6d1b771f5e80b28e798b Author: Lubos <tridosm@gmail.com> Date: Thu Apr 21 21:15:02 2022 +0200 OpenXR add missing foveation commit 4ff90d8ba07eeaa554943e72fb69d40eaed1dd1f Author: Lubos <tridosm@gmail.com> Date: Thu Apr 21 21:00:02 2022 +0200 OpenXR renderer cleanup commit d736af15bd22b3f8f38f6b4c4dc1e1b53ddc7dae Merge: 7b9d51ec fe180129 Author: Lubos <tridosm@gmail.com> Date: Thu Mar 31 17:47:45 2022 +0200 Merge branch 'master' into feature_openxr commit 7b9d51ec30570dde2c5159037a4ceac1882acf55 Author: Lubos <tridosm@gmail.com> Date: Thu Mar 31 17:47:36 2022 +0200 OpenXR renderer in progress commit e7a2229edc46ac2c9821c1fbf0ecada57ac1d31f Merge: abeaf046 bcf9287a Author: Lubos <tridosm@gmail.com> Date: Wed Mar 30 09:44:15 2022 +0200 Merge branch 'master' into feature_openxr commit abeaf046074997aa90d315565189f8977416bcc9 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 19:57:47 2022 +0200 OpenXR initialization fixed commit f2fefbf7081ddcf8cd28272cea786f55e3260132 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 17:13:48 2022 +0200 OpenXR initialization added commit 96bf69cb15c6953b8ad1a9907de15b2032301ac3 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 12:56:37 2022 +0200 VR API removed
2022-05-07 13:34:37 +00:00
OPENXRDIR=$(MOUNT_DIR)/OpenXR
OPENXRSDKDIR=$(MOUNT_DIR)/OpenXR-SDK
2005-08-26 17:39:27 +00:00
bin_path=$(shell which $(1) 2> /dev/null)
# The autoupdater uses curl, so figure out its flags no matter what.
2009-10-08 22:29:55 +00:00
# We won't need this if we only build the server
# set PKG_CONFIG_PATH or PKG_CONFIG to influence this, e.g.
# PKG_CONFIG_PATH=/opt/cross/i386-mingw32msvc/lib/pkgconfig or
# PKG_CONFIG=arm-linux-gnueabihf-pkg-config
ifeq ($(CROSS_COMPILING),0)
PKG_CONFIG ?= pkg-config
else
ifneq ($(PKG_CONFIG_PATH),)
PKG_CONFIG ?= pkg-config
else
# Don't use host pkg-config when cross-compiling.
# (unknown-pkg-config is meant to be a non-existant command.)
PKG_CONFIG ?= unknown-pkg-config
endif
endif
ifneq ($(call bin_path, $(PKG_CONFIG)),)
CURL_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags libcurl)
CURL_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs libcurl)
OPENAL_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags openal)
OPENAL_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs openal)
SDL_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags sdl2|sed 's/-Dmain=SDL_main//')
SDL_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs sdl2)
else
# assume they're in the system default paths (no -I or -L needed)
CURL_LIBS ?= -lcurl
OPENAL_LIBS ?= -lopenal
endif
# Use sdl2-config if all else fails
ifeq ($(SDL_CFLAGS),)
ifneq ($(call bin_path, sdl2-config),)
SDL_CFLAGS = $(shell sdl2-config --cflags)
SDL_LIBS = $(shell sdl2-config --libs)
endif
endif
# Add git version info
USE_GIT=
ifeq ($(wildcard .git),.git)
2013-01-05 15:05:30 +00:00
GIT_REV=$(shell git show -s --pretty=format:%h-%ad --date=short)
ifneq ($(GIT_REV),)
VERSION:=$(VERSION)_GIT_$(GIT_REV)
USE_GIT=1
endif
endif
2005-08-26 17:39:27 +00:00
#############################################################################
# SETUP AND BUILD -- LINUX
#############################################################################
INSTALL=install
MKDIR=mkdir -p
2014-08-26 15:59:33 +00:00
EXTRA_FILES=
CLIENT_EXTRA_FILES=
build: define ARCH_STRING in Makefile on Linux and other GNU platforms GNU platforms (Linux, kFreeBSD, Hurd) have endian.h to determine endianness, so all architectures except x86_64 are in fact treated identically, except that their ARCH_STRING is different. The ARCH_STRING must always be identical to the ARCH from the Makefile, otherwise the engine will not find its cgame, game and ui plugins under their expected names and startup will fail. If we pass it in from the Makefile, then an identical value is guaranteed, and we can get rid of an increasingly long list of defined(__some_cpu__) tests. The one remaining quirk is that we test __x86_64__ to determine whether to define idx64; I've kept that, but separated it from the ARCH_STRING. On non-Linux platforms we only support a few architectures anyway, so keeping the list up to date is less of a burden; *BSD porters could probably use the same technique to get support for lots of architectures with little effort, but I have not done that here, because I cannot test it. Windows must continue to support preprocessor-based architecture tests in any case, so that the MSVC solutions (which do not use the Makefile) can continue to work. However, Windows only runs on a few CPU families, so this shouldn't be a significant burden in practice. When cross-compiling, the tools are compiled for the build architecture (COMPILE_PLATFORM, COMPILE_ARCH) rather than the host architecture (PLATFORM, ARCH), so define ARCH_STRING to COMPILE_ARCH on a GNU COMPILE_PLATFORM.
2015-07-14 21:51:57 +00:00
ifneq (,$(findstring "$(COMPILE_PLATFORM)", "linux" "gnu_kfreebsd" "kfreebsd-gnu" "gnu"))
TOOLS_CFLAGS += -DARCH_STRING=\"$(COMPILE_ARCH)\"
endif
ifneq (,$(findstring "$(PLATFORM)", "linux" "gnu_kfreebsd" "kfreebsd-gnu" "gnu"))
BASE_CFLAGS = -Wall -fno-strict-aliasing -Wimplicit -Wstrict-prototypes \
build: define ARCH_STRING in Makefile on Linux and other GNU platforms GNU platforms (Linux, kFreeBSD, Hurd) have endian.h to determine endianness, so all architectures except x86_64 are in fact treated identically, except that their ARCH_STRING is different. The ARCH_STRING must always be identical to the ARCH from the Makefile, otherwise the engine will not find its cgame, game and ui plugins under their expected names and startup will fail. If we pass it in from the Makefile, then an identical value is guaranteed, and we can get rid of an increasingly long list of defined(__some_cpu__) tests. The one remaining quirk is that we test __x86_64__ to determine whether to define idx64; I've kept that, but separated it from the ARCH_STRING. On non-Linux platforms we only support a few architectures anyway, so keeping the list up to date is less of a burden; *BSD porters could probably use the same technique to get support for lots of architectures with little effort, but I have not done that here, because I cannot test it. Windows must continue to support preprocessor-based architecture tests in any case, so that the MSVC solutions (which do not use the Makefile) can continue to work. However, Windows only runs on a few CPU families, so this shouldn't be a significant burden in practice. When cross-compiling, the tools are compiled for the build architecture (COMPILE_PLATFORM, COMPILE_ARCH) rather than the host architecture (PLATFORM, ARCH), so define ARCH_STRING to COMPILE_ARCH on a GNU COMPILE_PLATFORM.
2015-07-14 21:51:57 +00:00
-pipe -DUSE_ICON -DARCH_STRING=\\\"$(ARCH)\\\"
2011-08-01 12:48:31 +00:00
CLIENT_CFLAGS += $(SDL_CFLAGS)
2022-04-17 20:45:28 +00:00
# Flag -ffast-math replacement: https://pspdfkit.com/blog/2021/understanding-fast-math/
# Flags -ffp-contract=fast -fno-trapping-math are unused because they are causing lightmap issues
OPTIMIZEFASTMATH = -ffinite-math-only -fno-math-errno -fassociative-math -freciprocal-math -fno-signed-zeros
OPTIMIZEVM = -O3
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
2005-08-28 17:21:46 +00:00
ifeq ($(ARCH),x86_64)
OPTIMIZEVM = -O3
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
2005-12-18 15:36:07 +00:00
HAVE_VM_COMPILED = true
2005-08-26 17:39:27 +00:00
else
ifeq ($(ARCH),x86)
OPTIMIZEVM = -O3 -march=i586
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
HAVE_VM_COMPILED=true
else
ifeq ($(ARCH),ppc)
ALTIVEC_CFLAGS = -maltivec
HAVE_VM_COMPILED=true
endif
ifeq ($(ARCH),ppc64)
ALTIVEC_CFLAGS = -maltivec
HAVE_VM_COMPILED=true
endif
ifeq ($(ARCH),sparc)
OPTIMIZE += -mtune=ultrasparc3 -mv8plus
OPTIMIZEVM += -mtune=ultrasparc3 -mv8plus
HAVE_VM_COMPILED=true
endif
2014-10-23 11:00:17 +00:00
ifeq ($(ARCH),armv7l)
HAVE_VM_COMPILED=true
endif
ifeq ($(ARCH),alpha)
# According to http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=410555
# -ffast-math will cause the client to die with SIGFPE on Alpha
OPTIMIZE = $(OPTIMIZEVM)
endif
2005-08-28 17:21:46 +00:00
endif
2005-08-26 17:39:27 +00:00
endif
SHLIBEXT=so
SHLIBCFLAGS=-fPIC -fvisibility=hidden
2005-08-26 17:39:27 +00:00
SHLIBLDFLAGS=-shared $(LDFLAGS)
THREAD_LIBS=-lpthread
LIBS=-ldl -lm
AUTOUPDATER_LIBS += -ldl
2005-08-26 17:39:27 +00:00
CLIENT_LIBS=$(SDL_LIBS)
RENDERER_LIBS = $(SDL_LIBS)
ifeq ($(USE_OPENAL),1)
ifneq ($(USE_OPENAL_DLOPEN),1)
2014-07-20 22:31:37 +00:00
CLIENT_LIBS += $(THREAD_LIBS) $(OPENAL_LIBS)
endif
2005-11-15 22:22:45 +00:00
endif
ifeq ($(USE_CURL),1)
CLIENT_CFLAGS += $(CURL_CFLAGS)
ifneq ($(USE_CURL_DLOPEN),1)
CLIENT_LIBS += $(CURL_LIBS)
endif
endif
2005-11-15 22:22:45 +00:00
ifeq ($(USE_MUMBLE),1)
CLIENT_LIBS += -lrt
endif
ifeq ($(ARCH),x86)
# linux32 make ...
BASE_CFLAGS += -m32
2007-10-12 10:25:13 +00:00
else
ifeq ($(ARCH),ppc64)
BASE_CFLAGS += -m64
endif
endif
2005-08-26 17:39:27 +00:00
else # ifeq Linux
2020-09-06 11:40:32 +00:00
#############################################################################
# SETUP AND BUILD -- Android
#############################################################################
ifeq ($(PLATFORM),android)
ARCH = aarch64
CC = $(ANDROID_CC)
RANLIB = $(ANDROID_RANLIB)
2020-09-06 11:40:32 +00:00
TOOLS_CFLAGS += -DARCH_STRING=\"$(COMPILE_ARCH)\"
BASE_CFLAGS = $(ANDROID_CFLAGS) -Wall -fno-strict-aliasing -Wimplicit -Wstrict-prototypes -pipe \
2020-09-06 11:40:32 +00:00
-fno-builtin-cos -fno-builtin-sin -fPIC -DARCH_STRING=\\\"$(ARCH)\\\"
CLIENT_CFLAGS += $(SDL_CFLAGS) -DSDL_DISABLE_IMMINTRIN_H -fno-builtin-cos -fno-builtin-sin
OPTIMIZEVM = -O3 -funroll-loops -fomit-frame-pointer
2022-03-30 16:28:41 +00:00
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
2020-09-06 11:40:32 +00:00
HAVE_VM_COMPILED = false
LIBPREFIX = lib
CLIENTBIN = $(LIBPREFIX)ioquake3
FULLBINEXT = .so
SHLIBEXT = so
SHLIBCFLAGS =
SHLIBLDFLAGS = -shared -lm $(LDFLAGS)
THREAD_LIBS =
LIBS = -ldl -lm -Wl,--no-undefined -shared
CLIENT_LIBS = -lGLESv3 -lOpenSLES
2020-09-06 11:40:32 +00:00
RENDERER_LIBS = -lGLESv3 -lEGL
# SDL
BASE_CFLAGS += -I$(SDLHDIR)/include
CLIENT_LIBS += $(LIBSDIR)/android/arm64-v8a/libSDL2.so
RENDERER_LIBS += $(LIBSDIR)/android/arm64-v8a/libSDL2.so
CLIENT_EXTRA_FILES += $(LIBSDIR)/android/arm64-v8a/libSDL2.so
Squashed commit of the following: commit 0adeb4ba3bc12d1efeab7f7b4876fc61d9566ed4 Merge: 7feea565 d8653ad7 Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:32:21 2022 +0100 Merge branch 'OpenXR' of https://github.com/DrBeef/ioq3quest into OpenXR commit 7feea56514c17b3f1e7c15c73676bd9d8374ed6c Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:32:14 2022 +0100 Update Version Number commit d8653ad70e1cc9bf1fb2e72d6ad9c9b330db32d8 Merge: 79983b2b 7e6aa6da Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:31:45 2022 +0100 Merge pull request #76 from lvonasek/OpenXR OpenXR delayed controller pose fixed commit 79983b2bc5174eeb7c674396f07288da80ce94c5 Merge: 325641f9 7f89d6d1 Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:31:31 2022 +0100 Merge pull request #77 from petr666/OpenXR Update gamma values to better suit OpenXR build commit 7f89d6d19b2e807b001577c06c5f254106f95e0e Author: Petr Bartos <petr.bartos@plus4u.net> Date: Sat May 7 13:56:03 2022 +0200 Update gamma values to better suit OpenXR build commit 7e6aa6dab80e6ec4010e6057be4c0e34e4325245 Author: Lubos <tridosm@gmail.com> Date: Sat May 7 11:32:11 2022 +0200 OpenXR sync actions before updating controllers commit 027a7e96c312c43389299648326736766c8bab67 Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:34:50 2022 +0200 OpenXR implement controller velocity again commit af80d5c284b5372eb9b2533284325ae43caa80ec Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:18:51 2022 +0200 Compile fix commit ab1e853554a02c7dd59b2f59afab2569eb64ebed Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:14:08 2022 +0200 OpenXR input cleanup commit be158b4ad98a6b615c5fc34a407e4333dc468225 Author: Lubos <tridosm@gmail.com> Date: Fri May 6 09:39:49 2022 +0200 OpenXR sync input actions from renderer commit ed96160ffc0b3fb9350f8801257cfee713d8713f Author: Lubos <tridosm@gmail.com> Date: Fri May 6 09:25:59 2022 +0200 OpenXR do not use pose velocity to track controllers commit 42bf984ef8075ce45d6788fc09236d40d6a61dc9 Author: Lubos <tridosm@gmail.com> Date: Thu May 5 22:39:10 2022 +0200 OpenXR apply controller pose from renderer commit 92941b3547e7c4c7f126f608dde7239ee9c03b8e Author: Lubos <tridosm@gmail.com> Date: Thu May 5 22:26:33 2022 +0200 OpenXR delayed controller pose fixed commit 325641f90edbb1ba7ef96d288c443dd824a7528c Merge: de198fba 3ee3f590 Author: Simon <simonbrown77@googlemail.com> Date: Thu May 5 16:30:07 2022 +0100 Merge pull request #75 from lvonasek/OpenXR OpenXR menuyaw and recenter support added commit 3ee3f590584f6a8ff8d1e5cace7b999965c7e5cd Author: Lubos <tridosm@gmail.com> Date: Thu May 5 12:22:36 2022 +0200 OpenXR do not recenter on renderer reload commit 7072b0b89e0313a3bb39e8bb49dfdfa78e2972d9 Author: Lubos <tridosm@gmail.com> Date: Wed May 4 21:05:45 2022 +0200 OpenXR recenter sets yaw always to 0 commit 8e5f6414a6cb598c17b7d3cdbd208fe11d0d4fb3 Author: Lubos <tridosm@gmail.com> Date: Wed May 4 16:19:48 2022 +0200 OpenXR recenter integrated commit 08a4fc7fbf95e70f4a467350129a79d8358b34bd Author: Lubos <tridosm@gmail.com> Date: Tue May 3 18:37:28 2022 +0200 OpenXR use the same coordinate system in all layers commit a1de0e1ffe5081d0a15f4bd50b99f6a1c1439eac Author: Lubos <tridosm@gmail.com> Date: Mon May 2 22:17:53 2022 +0200 OpenXR menuYaw support added commit de198fba0da8130af67cfa9224c484e007d3a897 Author: Simon <simonbrown77@googlemail.com> Date: Mon May 2 10:01:42 2022 +0100 Update version numbers and add openxr identifier commit b83f99fe5b8db293a652f22d7adea825bf6a6549 Merge: c623bf13 9c14728b Author: Simon <simonbrown77@googlemail.com> Date: Mon May 2 09:43:47 2022 +0100 Merge pull request #74 from lvonasek/OpenXR OpenXR left controller mapping fixed commit 9c14728bc98f037dff8d7825692463b44915babe Merge: 11a849b1 0695c7ac Author: Lubos <tridosm@gmail.com> Date: Sun May 1 19:41:45 2022 +0200 Merge branch 'master' into OpenXR commit 11a849b189b4a5a8ab9676cd2cfeaae826e09187 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 19:09:12 2022 +0200 OpenXR controller mapping fixed commit 712584eae8dbcec3b10e0e39b2266f83487d4ecb Merge: df4bc0c0 c623bf13 Author: Luboš Vonásek <tridosm@gmail.com> Date: Sun May 1 19:04:45 2022 +0200 Merge branch 'DrBeef:OpenXR' into OpenXR commit c623bf1399406c24a1e9bf25fc54de758ac70c94 Merge: cb152467 e42a2f4e Author: Simon <simonbrown77@googlemail.com> Date: Sun May 1 14:10:23 2022 +0100 Merge pull request #72 from lvonasek/OpenXR OpenXR jitter fixed commit e42a2f4e0d4a0c48a266ef03b6599e70aadc1875 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 14:34:38 2022 +0200 Compile fix commit acbff1e7364c40d9f1a0820a561be40237c94994 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 13:59:41 2022 +0200 OpenXR camera view moved into renderer commit cb152467bacd5b7a92513b4279cf85a17f9c08e2 Merge: decc2d02 26071937 Author: Simon <simonbrown77@googlemail.com> Date: Sun May 1 10:20:40 2022 +0100 Merge pull request #69 from lvonasek/feature_openxr OpenXR integration commit 26071937c8b5053fe20e10d07fab5b9a695bfcc2 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 11:17:50 2022 +0200 OpenXR frameskip integrated commit f735535dcef2675678e1731ec67f4f5b7537bd49 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 22:57:48 2022 +0200 OpenXR attempt to fix flickering commit 0eb1d43b4aaa18550384d3689df9233bb293cbcc Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 21:28:26 2022 +0200 2D aspect ratio fixed commit 9d07c2760463062fa2afb52f533f8af4001c9576 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 21:23:53 2022 +0200 Hud model rendering fixed commit 30c9b4eaa0c3ecf235c592de0e52771a7d79453c Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 17:03:54 2022 +0200 Release build fixed commit 405ca571ad31d6bbd99de96e87cb0564d5daa60b Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 14:10:27 2022 +0200 OpenXR foveation removed commit 61b3192bce97b48587cd360c0318c4708a9e1828 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 14:02:21 2022 +0200 OpenXR projection matrix calculation from example code commit ecd50dbcb1b72baa1c730dbb900033febd4b81a8 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 21:21:10 2022 +0200 OpenXR low framerate fixed commit f5a8429fc1c094eb07b6a6ac463405a5ec44c63b Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 19:21:29 2022 +0200 Solution for black rectangles in the scene commit 9ae93a5fe9d684d7d739e1a9217324d770c4712a Merge: 10548445 decc2d02 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 14:58:35 2022 +0200 Merge branch 'master' into feature_openxr commit 10548445245439c1b245270fadc1a92f5be4650a Merge: 65e2031e 3cdf1858 Author: Lubos <tridosm@gmail.com> Date: Wed Apr 27 21:52:55 2022 +0200 Merge branch 'master' into feature_openxr commit 65e2031e954fe075189d1ab90eb6edce1b726731 Author: Lubos <tridosm@gmail.com> Date: Tue Apr 26 22:02:04 2022 +0200 OpenXR integration fixes commit c321b97894fa9dc240b82a89426a5b4516a6eb5b Author: Lubos <tridosm@gmail.com> Date: Mon Apr 25 16:48:09 2022 +0200 OpenXR multiview integrated commit 594716896626c4c2190dc620ed66bd69c858031d Author: Lubos <tridosm@gmail.com> Date: Sun Apr 24 20:25:19 2022 +0200 OpenXR minor fixes commit 249847930be0230b6d99008475b2f4c9bb1636f0 Author: Lubos <tridosm@gmail.com> Date: Sun Apr 24 18:06:02 2022 +0200 OpenXR use just one framebuffer commit b11122e36882e5c62511528a6f107821f0a8de24 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 21:06:35 2022 +0200 OpenXR touch controllers completely implemented commit 0bf485664c41ffa742d703ec358c9c38d01b51cc Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 19:44:18 2022 +0200 OpenXR haptics and refreshrate fixed commit 4716387e5274674a9432bf3867fc05a2ac62b597 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 15:54:07 2022 +0200 OpenXR input except buttons implemented commit 7bd1fe31c2e9321af2fdd7ffee42ef94c08b5fdc Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 21:18:49 2022 +0200 OpenXR input in progress commit 3c26e08f011d25a907d05926c073baa93c94692d Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 18:41:26 2022 +0200 Old code removed commit 4d2644cae27c031e5c5d0c487e87c8e6b66b4857 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 18:32:42 2022 +0200 OpenXR fov fixed commit 501869a05128802049bb347eecb2c38d87391162 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 17:56:14 2022 +0200 OpenXR motion tracking in game mode added commit b152d21ddc669a135c7b2113440124ddbc1672df Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 16:14:36 2022 +0200 OpenXR cylinder projection added commit 3e9c80679e7c0adbeb20a3aa14ca20c48422b54a Merge: 0de4a0d1 39f669dd Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 14:13:18 2022 +0200 Merge branch 'master' into feature_openxr commit 0de4a0d19645706b6579ef00714e6291432f6543 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 13:45:22 2022 +0200 OpenXR tracking added init, first working rendering commit 8431b1aa83be613e4c3f6d1b771f5e80b28e798b Author: Lubos <tridosm@gmail.com> Date: Thu Apr 21 21:15:02 2022 +0200 OpenXR add missing foveation commit 4ff90d8ba07eeaa554943e72fb69d40eaed1dd1f Author: Lubos <tridosm@gmail.com> Date: Thu Apr 21 21:00:02 2022 +0200 OpenXR renderer cleanup commit d736af15bd22b3f8f38f6b4c4dc1e1b53ddc7dae Merge: 7b9d51ec fe180129 Author: Lubos <tridosm@gmail.com> Date: Thu Mar 31 17:47:45 2022 +0200 Merge branch 'master' into feature_openxr commit 7b9d51ec30570dde2c5159037a4ceac1882acf55 Author: Lubos <tridosm@gmail.com> Date: Thu Mar 31 17:47:36 2022 +0200 OpenXR renderer in progress commit e7a2229edc46ac2c9821c1fbf0ecada57ac1d31f Merge: abeaf046 bcf9287a Author: Lubos <tridosm@gmail.com> Date: Wed Mar 30 09:44:15 2022 +0200 Merge branch 'master' into feature_openxr commit abeaf046074997aa90d315565189f8977416bcc9 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 19:57:47 2022 +0200 OpenXR initialization fixed commit f2fefbf7081ddcf8cd28272cea786f55e3260132 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 17:13:48 2022 +0200 OpenXR initialization added commit 96bf69cb15c6953b8ad1a9907de15b2032301ac3 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 12:56:37 2022 +0200 VR API removed
2022-05-07 13:34:37 +00:00
# OpenXR
BASE_CFLAGS += -I$(OPENXRDIR)/Include -I$(OPENXRSDKDIR)/include
CLIENT_LIBS += $(OPENXRDIR)/Libs/Android/arm64-v8a/Release/libopenxr_loader.so
RENDERER_LIBS += $(OPENXRDIR)/Libs/Android/arm64-v8a/Release/libopenxr_loader.so
CLIENT_EXTRA_FILES += $(OPENXRDIR)/Libs/Android/arm64-v8a/Release/libopenxr_loader.so
2020-09-06 11:40:32 +00:00
else # ifeq Android
#############################################################################
# SETUP AND BUILD -- MAC OS X
#############################################################################
ifeq ($(PLATFORM),darwin)
HAVE_VM_COMPILED=true
LIBS = -framework Cocoa
CLIENT_LIBS=
RENDERER_LIBS=
OPTIMIZEVM = -O3
2013-01-05 15:35:50 +00:00
# Default minimum Mac OS X version
ifeq ($(MACOSX_VERSION_MIN),)
MACOSX_VERSION_MIN=10.7
endif
MACOSX_MAJOR=$(shell echo $(MACOSX_VERSION_MIN) | cut -d. -f1)
MACOSX_MINOR=$(shell echo $(MACOSX_VERSION_MIN) | cut -d. -f2)
ifeq ($(shell test $(MACOSX_MINOR) -gt 9; echo $$?),0)
# Multiply and then remove decimal. 10.10 -> 101000.0 -> 101000
MAC_OS_X_VERSION_MIN_REQUIRED=$(shell echo "$(MACOSX_MAJOR) * 10000 + $(MACOSX_MINOR) * 100" | bc | cut -d. -f1)
else
# Multiply by 100 and then remove decimal. 10.7 -> 1070.0 -> 1070
MAC_OS_X_VERSION_MIN_REQUIRED=$(shell echo "$(MACOSX_VERSION_MIN) * 100" | bc | cut -d. -f1)
endif
LDFLAGS += -mmacosx-version-min=$(MACOSX_VERSION_MIN)
BASE_CFLAGS += -mmacosx-version-min=$(MACOSX_VERSION_MIN) \
-DMAC_OS_X_VERSION_MIN_REQUIRED=$(MAC_OS_X_VERSION_MIN_REQUIRED)
ifeq ($(ARCH),ppc)
BASE_CFLAGS += -arch ppc
ALTIVEC_CFLAGS = -faltivec
endif
ifeq ($(ARCH),ppc64)
BASE_CFLAGS += -arch ppc64
ALTIVEC_CFLAGS = -faltivec
endif
ifeq ($(ARCH),x86)
OPTIMIZEVM += -march=prescott -mfpmath=sse
# x86 vm will crash without -mstackrealign since MMX instructions will be
# used no matter what and they corrupt the frame pointer in VM calls
2011-09-29 02:44:08 +00:00
BASE_CFLAGS += -arch i386 -m32 -mstackrealign
endif
ifeq ($(ARCH),x86_64)
OPTIMIZEVM += -mfpmath=sse
BASE_CFLAGS += -arch x86_64
endif
2013-03-28 09:55:53 +00:00
# When compiling on OSX for OSX, we're not cross compiling as far as the
# Makefile is concerned, as target architecture is specified as a compiler
# argument
ifeq ($(COMPILE_PLATFORM),darwin)
CROSS_COMPILING=0
endif
2013-03-25 22:41:15 +00:00
ifeq ($(CROSS_COMPILING),1)
2015-06-07 10:47:41 +00:00
ifeq ($(ARCH),x86_64)
CC=x86_64-apple-darwin13-cc
RANLIB=x86_64-apple-darwin13-ranlib
2013-03-25 22:41:15 +00:00
else
ifeq ($(ARCH),x86)
2015-06-07 10:47:41 +00:00
CC=i386-apple-darwin13-cc
RANLIB=i386-apple-darwin13-ranlib
2013-03-25 22:41:15 +00:00
else
$(error Architecture $(ARCH) is not supported when cross compiling)
endif
endif
endif
BASE_CFLAGS += -fno-strict-aliasing -fno-common -pipe
ifeq ($(USE_OPENAL),1)
ifneq ($(USE_LOCAL_HEADERS),1)
CLIENT_CFLAGS += -I/System/Library/Frameworks/OpenAL.framework/Headers
endif
ifneq ($(USE_OPENAL_DLOPEN),1)
CLIENT_LIBS += -framework OpenAL
endif
endif
2007-07-15 12:08:11 +00:00
ifeq ($(USE_CURL),1)
CLIENT_CFLAGS += $(CURL_CFLAGS)
ifneq ($(USE_CURL_DLOPEN),1)
CLIENT_LIBS += $(CURL_LIBS)
endif
endif
BASE_CFLAGS += -D_THREAD_SAFE=1
CLIENT_LIBS += -framework IOKit
RENDERER_LIBS += -framework OpenGL
ifeq ($(USE_LOCAL_HEADERS),1)
# libSDL2-2.0.0.dylib for PPC is SDL 2.0.1 + changes to compile
ifneq ($(findstring $(ARCH),ppc ppc64),)
BASE_CFLAGS += -I$(SDLHDIR)/include-macppc
else
BASE_CFLAGS += -I$(SDLHDIR)/include
endif
# We copy sdlmain before ranlib'ing it so that subversion doesn't think
# the file has been modified by each build.
LIBSDLMAIN=$(B)/libSDL2main.a
LIBSDLMAINSRC=$(LIBSDIR)/macosx/libSDL2main.a
CLIENT_LIBS += $(LIBSDIR)/macosx/libSDL2-2.0.0.dylib
RENDERER_LIBS += $(LIBSDIR)/macosx/libSDL2-2.0.0.dylib
CLIENT_EXTRA_FILES += $(LIBSDIR)/macosx/libSDL2-2.0.0.dylib
else
BASE_CFLAGS += -I/Library/Frameworks/SDL2.framework/Headers
CLIENT_LIBS += -framework SDL2
RENDERER_LIBS += -framework SDL2
endif
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
SHLIBEXT=dylib
SHLIBCFLAGS=-fPIC -fno-common
2011-09-29 02:44:08 +00:00
SHLIBLDFLAGS=-dynamiclib $(LDFLAGS) -Wl,-U,_com_altivec
NOTSHLIBCFLAGS=-mdynamic-no-pic
else # ifeq darwin
2005-09-22 03:21:33 +00:00
#############################################################################
# SETUP AND BUILD -- MINGW32
#############################################################################
2015-01-30 21:52:53 +00:00
ifdef MINGW
2005-09-22 03:21:33 +00:00
ifeq ($(CROSS_COMPILING),1)
# If CC is already set to something generic, we probably want to use
# something more specific
2013-03-22 14:47:37 +00:00
ifneq ($(findstring $(strip $(CC)),cc gcc),)
CC=
endif
2013-03-22 14:47:37 +00:00
# We need to figure out the correct gcc and windres
ifeq ($(ARCH),x86_64)
2016-11-01 22:44:40 +00:00
MINGW_PREFIXES=x86_64-w64-mingw32 amd64-mingw32msvc
2013-03-22 14:47:37 +00:00
endif
ifeq ($(ARCH),x86)
2016-11-01 22:44:40 +00:00
MINGW_PREFIXES=i686-w64-mingw32 i586-mingw32msvc i686-pc-mingw32
2013-03-22 14:47:37 +00:00
endif
2013-03-22 14:47:37 +00:00
ifndef CC
CC=$(firstword $(strip $(foreach MINGW_PREFIX, $(MINGW_PREFIXES), \
$(call bin_path, $(MINGW_PREFIX)-gcc))))
2013-03-22 14:47:37 +00:00
endif
2013-03-22 14:47:37 +00:00
ifndef WINDRES
WINDRES=$(firstword $(strip $(foreach MINGW_PREFIX, $(MINGW_PREFIXES), \
$(call bin_path, $(MINGW_PREFIX)-windres))))
endif
2013-03-22 14:26:29 +00:00
else
# Some MinGW installations define CC to cc, but don't actually provide cc,
# so check that CC points to a real binary and use gcc if it doesn't
ifeq ($(call bin_path, $(CC)),)
CC=gcc
endif
endif
# using generic windres if specific one is not present
ifndef WINDRES
WINDRES=windres
endif
2005-09-22 03:21:33 +00:00
ifeq ($(CC),)
$(error Cannot find a suitable cross compiler for $(PLATFORM))
endif
BASE_CFLAGS = -Wall -fno-strict-aliasing -Wimplicit -Wstrict-prototypes \
-DUSE_ICON
# In the absence of wspiapi.h, require Windows XP or later
ifeq ($(shell test -e $(CMDIR)/wspiapi.h; echo $$?),1)
BASE_CFLAGS += -DWINVER=0x501
endif
ifeq ($(USE_OPENAL),1)
CLIENT_CFLAGS += $(OPENAL_CFLAGS)
ifneq ($(USE_OPENAL_DLOPEN),1)
CLIENT_LDFLAGS += $(OPENAL_LDFLAGS)
endif
endif
2013-01-05 15:35:50 +00:00
ifeq ($(ARCH),x86_64)
OPTIMIZEVM = -O3
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
HAVE_VM_COMPILED = true
endif
ifeq ($(ARCH),x86)
OPTIMIZEVM = -O3 -march=i586
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
HAVE_VM_COMPILED = true
endif
2006-06-06 18:09:09 +00:00
2005-09-22 03:21:33 +00:00
SHLIBEXT=dll
SHLIBCFLAGS=
SHLIBLDFLAGS=-shared $(LDFLAGS)
BINEXT=.exe
ifeq ($(CROSS_COMPILING),0)
TOOLS_BINEXT=.exe
endif
ifeq ($(COMPILE_PLATFORM),cygwin)
TOOLS_BINEXT=.exe
TOOLS_CC=$(CC)
endif
2010-02-16 09:43:44 +00:00
LIBS= -lws2_32 -lwinmm -lpsapi
AUTOUPDATER_LIBS += -lwininet
# clang 3.4 doesn't support this
ifneq ("$(CC)", $(findstring "$(CC)", "clang" "clang++"))
CLIENT_LDFLAGS += -mwindows
endif
2011-08-01 13:25:55 +00:00
CLIENT_LIBS = -lgdi32 -lole32
RENDERER_LIBS = -lgdi32 -lole32 -static-libgcc
2013-01-05 15:35:50 +00:00
ifeq ($(USE_FREETYPE),1)
FREETYPE_CFLAGS = -Ifreetype2
endif
ifeq ($(USE_CURL),1)
CLIENT_CFLAGS += $(CURL_CFLAGS)
ifneq ($(USE_CURL_DLOPEN),1)
ifeq ($(USE_LOCAL_HEADERS),1)
CLIENT_CFLAGS += -DCURL_STATICLIB
ifeq ($(ARCH),x86_64)
2017-07-28 13:59:43 +00:00
CLIENT_LIBS += $(LIBSDIR)/win64/libcurl.a -lcrypt32
else
2017-07-28 13:59:43 +00:00
CLIENT_LIBS += $(LIBSDIR)/win32/libcurl.a -lcrypt32
endif
else
CLIENT_LIBS += $(CURL_LIBS)
endif
endif
endif
2005-09-22 03:21:33 +00:00
ifeq ($(ARCH),x86)
# build 32bit
BASE_CFLAGS += -m32
else
BASE_CFLAGS += -m64
2005-09-22 03:21:33 +00:00
endif
# libmingw32 must be linked before libSDLmain
CLIENT_LIBS += -lmingw32
2011-08-01 13:25:55 +00:00
RENDERER_LIBS += -lmingw32
2013-01-05 15:35:50 +00:00
ifeq ($(USE_LOCAL_HEADERS),1)
CLIENT_CFLAGS += -I$(SDLHDIR)/include
ifeq ($(ARCH),x86)
2013-01-21 22:40:05 +00:00
CLIENT_LIBS += $(LIBSDIR)/win32/libSDL2main.a \
$(LIBSDIR)/win32/libSDL2.dll.a
RENDERER_LIBS += $(LIBSDIR)/win32/libSDL2main.a \
$(LIBSDIR)/win32/libSDL2.dll.a
2014-03-09 03:00:38 +00:00
SDLDLL=SDL2.dll
2014-08-26 15:59:33 +00:00
CLIENT_EXTRA_FILES += $(LIBSDIR)/win32/SDL2.dll
else
2014-03-09 03:00:38 +00:00
CLIENT_LIBS += $(LIBSDIR)/win64/libSDL264main.a \
$(LIBSDIR)/win64/libSDL264.dll.a
RENDERER_LIBS += $(LIBSDIR)/win64/libSDL264main.a \
$(LIBSDIR)/win64/libSDL264.dll.a
SDLDLL=SDL264.dll
2014-08-26 15:59:33 +00:00
CLIENT_EXTRA_FILES += $(LIBSDIR)/win64/SDL264.dll
endif
else
CLIENT_CFLAGS += $(SDL_CFLAGS)
CLIENT_LIBS += $(SDL_LIBS)
2011-08-01 13:25:55 +00:00
RENDERER_LIBS += $(SDL_LIBS)
2014-03-09 03:00:38 +00:00
SDLDLL=SDL2.dll
endif
2015-01-30 21:52:53 +00:00
else # ifdef MINGW
2005-09-22 03:21:33 +00:00
2005-08-26 17:39:27 +00:00
#############################################################################
# SETUP AND BUILD -- FREEBSD
#############################################################################
ifeq ($(PLATFORM),freebsd)
# flags
BASE_CFLAGS = \
-Wall -fno-strict-aliasing -Wimplicit -Wstrict-prototypes \
-DUSE_ICON -DMAP_ANONYMOUS=MAP_ANON
2011-08-01 12:48:31 +00:00
CLIENT_CFLAGS += $(SDL_CFLAGS)
HAVE_VM_COMPILED = true
2017-03-27 21:21:48 +00:00
OPTIMIZEVM =
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
SHLIBEXT=so
SHLIBCFLAGS=-fPIC
SHLIBLDFLAGS=-shared $(LDFLAGS)
2005-08-26 17:39:27 +00:00
THREAD_LIBS=-lpthread
# don't need -ldl (FreeBSD)
LIBS=-lm
2005-08-26 17:39:27 +00:00
CLIENT_LIBS =
CLIENT_LIBS += $(SDL_LIBS)
RENDERER_LIBS = $(SDL_LIBS)
# optional features/libraries
ifeq ($(USE_OPENAL),1)
ifeq ($(USE_OPENAL_DLOPEN),1)
CLIENT_LIBS += $(THREAD_LIBS) $(OPENAL_LIBS)
endif
endif
ifeq ($(USE_CURL),1)
CLIENT_CFLAGS += $(CURL_CFLAGS)
ifeq ($(USE_CURL_DLOPEN),1)
CLIENT_LIBS += $(CURL_LIBS)
endif
endif
# cross-compiling tweaks
ifeq ($(ARCH),x86)
ifeq ($(CROSS_COMPILING),1)
BASE_CFLAGS += -m32
endif
endif
ifeq ($(ARCH),x86_64)
ifeq ($(CROSS_COMPILING),1)
BASE_CFLAGS += -m64
endif
endif
2005-08-26 17:39:27 +00:00
else # ifeq freebsd
#############################################################################
# SETUP AND BUILD -- OPENBSD
#############################################################################
ifeq ($(PLATFORM),openbsd)
BASE_CFLAGS = -Wall -fno-strict-aliasing -Wimplicit -Wstrict-prototypes \
2013-05-05 01:56:24 +00:00
-pipe -DUSE_ICON -DMAP_ANONYMOUS=MAP_ANON
2011-08-01 12:48:31 +00:00
CLIENT_CFLAGS += $(SDL_CFLAGS)
OPTIMIZEVM = -O3
2013-05-05 01:56:24 +00:00
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
ifeq ($(ARCH),x86_64)
OPTIMIZEVM = -O3
2013-05-05 01:56:24 +00:00
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
HAVE_VM_COMPILED = true
else
ifeq ($(ARCH),x86)
OPTIMIZEVM = -O3 -march=i586
2013-05-05 01:56:24 +00:00
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
HAVE_VM_COMPILED=true
else
ifeq ($(ARCH),ppc)
ALTIVEC_CFLAGS = -maltivec
2013-05-05 01:56:24 +00:00
HAVE_VM_COMPILED=true
endif
ifeq ($(ARCH),ppc64)
ALTIVEC_CFLAGS = -maltivec
2013-05-05 01:56:24 +00:00
HAVE_VM_COMPILED=true
endif
ifeq ($(ARCH),sparc64)
OPTIMIZE += -mtune=ultrasparc3 -mv8plus
OPTIMIZEVM += -mtune=ultrasparc3 -mv8plus
HAVE_VM_COMPILED=true
endif
ifeq ($(ARCH),alpha)
# According to http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=410555
# -ffast-math will cause the client to die with SIGFPE on Alpha
OPTIMIZE = $(OPTIMIZEVM)
endif
endif
endif
ifeq ($(USE_CURL),1)
CLIENT_CFLAGS += $(CURL_CFLAGS)
USE_CURL_DLOPEN=0
endif
# no shm_open on OpenBSD
USE_MUMBLE=0
SHLIBEXT=so
SHLIBCFLAGS=-fPIC
SHLIBLDFLAGS=-shared $(LDFLAGS)
2013-05-05 01:40:57 +00:00
THREAD_LIBS=-lpthread
LIBS=-lm
CLIENT_LIBS =
CLIENT_LIBS += $(SDL_LIBS)
RENDERER_LIBS = $(SDL_LIBS)
ifeq ($(USE_OPENAL),1)
ifneq ($(USE_OPENAL_DLOPEN),1)
CLIENT_LIBS += $(THREAD_LIBS) $(OPENAL_LIBS)
endif
endif
2013-01-05 15:35:50 +00:00
ifeq ($(USE_CURL),1)
ifneq ($(USE_CURL_DLOPEN),1)
CLIENT_LIBS += $(CURL_LIBS)
endif
endif
else # ifeq openbsd
#############################################################################
# SETUP AND BUILD -- NETBSD
#############################################################################
ifeq ($(PLATFORM),netbsd)
LIBS=-lm
SHLIBEXT=so
SHLIBCFLAGS=-fPIC
SHLIBLDFLAGS=-shared $(LDFLAGS)
THREAD_LIBS=-lpthread
BASE_CFLAGS = -Wall -fno-strict-aliasing -Wimplicit -Wstrict-prototypes
ifeq ($(ARCH),x86)
HAVE_VM_COMPILED=true
endif
BUILD_CLIENT = 0
else # ifeq netbsd
2005-08-26 17:39:27 +00:00
#############################################################################
# SETUP AND BUILD -- IRIX
#############################################################################
ifeq ($(PLATFORM),irix64)
LIB=lib
2005-08-26 17:39:27 +00:00
ARCH=mips
2005-08-26 17:39:27 +00:00
CC = c99
BASE_CFLAGS=-Dstricmp=strcasecmp -Xcpluscomm -woff 1185 \
-I. -I$(ROOT)/usr/include
2011-08-01 12:48:31 +00:00
CLIENT_CFLAGS += $(SDL_CFLAGS)
OPTIMIZE = -O3
2013-01-05 15:35:50 +00:00
SHLIBEXT=so
SHLIBCFLAGS=
SHLIBLDFLAGS=-shared
2005-08-26 17:39:27 +00:00
LIBS=-ldl -lm -lgen
AUTOUPDATER_LIBS += -ldl
# FIXME: The X libraries probably aren't necessary?
CLIENT_LIBS=-L/usr/X11/$(LIB) $(SDL_LIBS) \
-lX11 -lXext -lm
RENDERER_LIBS = $(SDL_LIBS)
2005-08-26 17:39:27 +00:00
else # ifeq IRIX
#############################################################################
# SETUP AND BUILD -- SunOS
#############################################################################
2006-04-04 07:12:24 +00:00
ifeq ($(PLATFORM),sunos)
2007-07-17 08:12:35 +00:00
CC=gcc
INSTALL=ginstall
MKDIR=gmkdir -p
COPYDIR="/usr/local/share/games/quake3"
ifneq ($(ARCH),x86)
ifneq ($(ARCH),sparc)
$(error arch $(ARCH) is currently not supported)
endif
endif
BASE_CFLAGS = -Wall -fno-strict-aliasing -Wimplicit -Wstrict-prototypes \
-pipe -DUSE_ICON
2011-08-01 12:48:31 +00:00
CLIENT_CFLAGS += $(SDL_CFLAGS)
2009-12-18 21:52:36 +00:00
OPTIMIZEVM = -O3 -funroll-loops
ifeq ($(ARCH),sparc)
OPTIMIZEVM += -O3 \
-fstrength-reduce -falign-functions=2 \
-mtune=ultrasparc3 -mv8plus -mno-faster-structs
HAVE_VM_COMPILED=true
else
ifeq ($(ARCH),x86)
OPTIMIZEVM += -march=i586 -fomit-frame-pointer \
-falign-functions=2 -fstrength-reduce
HAVE_VM_COMPILED=true
BASE_CFLAGS += -m32
CLIENT_CFLAGS += -I/usr/X11/include/NVIDIA
2007-11-30 15:08:57 +00:00
CLIENT_LDFLAGS += -L/usr/X11/lib/NVIDIA -R/usr/X11/lib/NVIDIA
endif
endif
2013-01-05 15:35:50 +00:00
OPTIMIZE = $(OPTIMIZEVM) -ffast-math
SHLIBEXT=so
SHLIBCFLAGS=-fPIC
SHLIBLDFLAGS=-shared $(LDFLAGS)
THREAD_LIBS=-lpthread
LIBS=-lsocket -lnsl -ldl -lm
AUTOUPDATER_LIBS += -ldl
2006-01-04 03:14:01 +00:00
BOTCFLAGS=-O0
CLIENT_LIBS +=$(SDL_LIBS) -lX11 -lXext -liconv -lm
RENDERER_LIBS = $(SDL_LIBS)
2006-04-04 07:12:24 +00:00
else # ifeq sunos
2005-08-26 17:39:27 +00:00
#############################################################################
# SETUP AND BUILD -- GENERIC
#############################################################################
BASE_CFLAGS=
2009-12-18 21:52:36 +00:00
OPTIMIZE = -O3
2005-08-26 17:39:27 +00:00
SHLIBEXT=so
SHLIBCFLAGS=-fPIC
SHLIBLDFLAGS=-shared
2005-08-26 17:39:27 +00:00
endif #Linux
2020-09-06 11:40:32 +00:00
endif #Android
endif #darwin
2015-01-30 21:52:53 +00:00
endif #MINGW
2005-08-26 17:39:27 +00:00
endif #FreeBSD
endif #OpenBSD
endif #NetBSD
2005-08-26 17:39:27 +00:00
endif #IRIX
endif #SunOS
2005-08-26 17:39:27 +00:00
2013-03-25 22:41:15 +00:00
ifndef CC
CC=gcc
endif
ifndef RANLIB
RANLIB=ranlib
2013-03-25 22:41:15 +00:00
endif
ifneq ($(HAVE_VM_COMPILED),true)
BASE_CFLAGS += -DNO_VM_COMPILED
BUILD_GAME_QVM=0
endif
TARGETS =
ifndef FULLBINEXT
FULLBINEXT=.$(ARCH)$(BINEXT)
endif
ifndef SHLIBNAME
SHLIBNAME=$(ARCH).$(SHLIBEXT)
endif
ifneq ($(BUILD_SERVER),0)
TARGETS += $(B)/$(SERVERBIN)$(FULLBINEXT)
endif
ifneq ($(BUILD_CLIENT),0)
ifneq ($(USE_RENDERER_DLOPEN),0)
2014-08-26 15:59:33 +00:00
ifneq ($(BUILD_RENDERER_OPENGL2),0)
2020-09-06 11:40:32 +00:00
TARGETS += $(B)/$(LIBPREFIX)renderer_opengl2_$(SHLIBNAME)
endif
else
2014-08-26 15:59:33 +00:00
ifneq ($(BUILD_RENDERER_OPENGL2),0)
TARGETS += $(B)/$(CLIENTBIN)_opengl2$(FULLBINEXT)
endif
endif
endif
ifneq ($(BUILD_GAME_SO),0)
ifneq ($(BUILD_BASEGAME),0)
TARGETS += \
2013-01-05 15:35:50 +00:00
$(B)/$(BASEGAME)/cgame$(SHLIBNAME) \
$(B)/$(BASEGAME)/qagame$(SHLIBNAME) \
$(B)/$(BASEGAME)/ui$(SHLIBNAME)
endif
ifneq ($(BUILD_MISSIONPACK),0)
TARGETS += \
2013-01-05 15:35:50 +00:00
$(B)/$(MISSIONPACK)/cgame$(SHLIBNAME) \
$(B)/$(MISSIONPACK)/qagame$(SHLIBNAME) \
$(B)/$(MISSIONPACK)/ui$(SHLIBNAME)
endif
2005-12-29 00:04:41 +00:00
endif
ifneq ($(BUILD_GAME_QVM),0)
ifneq ($(BUILD_BASEGAME),0)
TARGETS += \
$(B)/$(BASEGAME)/vm/cgame.qvm \
$(B)/$(BASEGAME)/vm/qagame.qvm \
$(B)/$(BASEGAME)/vm/ui.qvm
2013-01-05 15:35:50 +00:00
endif
ifneq ($(BUILD_MISSIONPACK),0)
TARGETS += \
$(B)/$(MISSIONPACK)/vm/cgame.qvm \
$(B)/$(MISSIONPACK)/vm/qagame.qvm \
$(B)/$(MISSIONPACK)/vm/ui.qvm
endif
endif
ifneq ($(BUILD_AUTOUPDATER),0)
# PLEASE NOTE that if you run an exe on Windows Vista or later
# with "setup", "install", "update" or other related terms, it
# will unconditionally trigger a UAC prompt, and in the case of
# ioq3 calling CreateProcess() on it, it'll just fail immediately.
# So don't call this thing "autoupdater" here!
AUTOUPDATER_BIN := autosyncerator$(FULLBINEXT)
TARGETS += $(B)/$(AUTOUPDATER_BIN)
endif
ifeq ($(USE_OPENAL),1)
CLIENT_CFLAGS += -DUSE_OPENAL
ifeq ($(USE_OPENAL_DLOPEN),1)
CLIENT_CFLAGS += -DUSE_OPENAL_DLOPEN
endif
endif
ifeq ($(USE_CURL),1)
CLIENT_CFLAGS += -DUSE_CURL
ifeq ($(USE_CURL_DLOPEN),1)
CLIENT_CFLAGS += -DUSE_CURL_DLOPEN
endif
endif
ifeq ($(USE_VOIP),1)
CLIENT_CFLAGS += -DUSE_VOIP
SERVER_CFLAGS += -DUSE_VOIP
NEED_OPUS=1
endif
2013-02-18 00:32:05 +00:00
ifeq ($(USE_CODEC_OPUS),1)
CLIENT_CFLAGS += -DUSE_CODEC_OPUS
NEED_OPUS=1
endif
ifeq ($(NEED_OPUS),1)
2013-02-18 00:32:05 +00:00
ifeq ($(USE_INTERNAL_OPUS),1)
OPUS_CFLAGS = -DOPUS_BUILD -DHAVE_LRINTF -DFLOATING_POINT -DFLOAT_APPROX -DUSE_ALLOCA \
2013-02-18 00:32:05 +00:00
-I$(OPUSDIR)/include -I$(OPUSDIR)/celt -I$(OPUSDIR)/silk \
-I$(OPUSDIR)/silk/float -I$(OPUSFILEDIR)/include
2013-02-18 00:32:05 +00:00
else
OPUS_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags opusfile opus || true)
OPUS_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs opusfile opus || echo -lopusfile -lopus)
2013-02-18 00:56:06 +00:00
endif
CLIENT_CFLAGS += $(OPUS_CFLAGS)
CLIENT_LIBS += $(OPUS_LIBS)
2013-02-18 00:56:06 +00:00
NEED_OGG=1
endif
ifeq ($(USE_CODEC_VORBIS),1)
2014-07-20 10:58:38 +00:00
CLIENT_CFLAGS += -DUSE_CODEC_VORBIS
2014-02-08 08:26:03 +00:00
ifeq ($(USE_INTERNAL_VORBIS),1)
CLIENT_CFLAGS += -I$(VORBISDIR)/include -I$(VORBISDIR)/lib
2014-07-20 10:58:38 +00:00
else
VORBIS_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags vorbisfile vorbis || true)
VORBIS_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs vorbisfile vorbis || echo -lvorbisfile -lvorbis)
2014-07-20 10:58:38 +00:00
endif
CLIENT_CFLAGS += $(VORBIS_CFLAGS)
CLIENT_LIBS += $(VORBIS_LIBS)
NEED_OGG=1
endif
2014-02-08 08:26:03 +00:00
2013-02-18 00:56:06 +00:00
ifeq ($(NEED_OGG),1)
ifeq ($(USE_INTERNAL_OGG),1)
OGG_CFLAGS = -I$(OGGDIR)/include
2014-02-08 08:26:03 +00:00
else
OGG_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags ogg || true)
OGG_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs ogg || echo -logg)
2014-02-08 08:26:03 +00:00
endif
CLIENT_CFLAGS += $(OGG_CFLAGS)
CLIENT_LIBS += $(OGG_LIBS)
2014-02-08 08:26:03 +00:00
endif
ifeq ($(USE_RENDERER_DLOPEN),1)
CLIENT_CFLAGS += -DUSE_RENDERER_DLOPEN
endif
ifeq ($(USE_MUMBLE),1)
CLIENT_CFLAGS += -DUSE_MUMBLE
endif
2009-10-19 14:00:16 +00:00
ifeq ($(USE_INTERNAL_ZLIB),1)
ZLIB_CFLAGS = -DNO_GZIP -I$(ZDIR)
2009-10-19 14:00:16 +00:00
else
ZLIB_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags zlib || true)
ZLIB_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs zlib || echo -lz)
2009-10-19 14:00:16 +00:00
endif
BASE_CFLAGS += $(ZLIB_CFLAGS)
LIBS += $(ZLIB_LIBS)
2009-10-19 14:00:16 +00:00
ifeq ($(USE_INTERNAL_JPEG),1)
BASE_CFLAGS += -DUSE_INTERNAL_JPEG
BASE_CFLAGS += -I$(JPDIR)
else
# IJG libjpeg doesn't have pkg-config, but libjpeg-turbo uses libjpeg.pc;
# we fall back to hard-coded answers if libjpeg.pc is unavailable
JPEG_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags libjpeg || true)
JPEG_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs libjpeg || echo -ljpeg)
BASE_CFLAGS += $(JPEG_CFLAGS)
RENDERER_LIBS += $(JPEG_LIBS)
endif
ifeq ($(USE_FREETYPE),1)
FREETYPE_CFLAGS ?= $(shell $(PKG_CONFIG) --silence-errors --cflags freetype2 || true)
FREETYPE_LIBS ?= $(shell $(PKG_CONFIG) --silence-errors --libs freetype2 || echo -lfreetype)
BASE_CFLAGS += -DBUILD_FREETYPE $(FREETYPE_CFLAGS)
RENDERER_LIBS += $(FREETYPE_LIBS)
endif
ifeq ($(USE_AUTOUPDATER),1)
CLIENT_CFLAGS += -DUSE_AUTOUPDATER -DAUTOUPDATER_BIN=\\\"$(AUTOUPDATER_BIN)\\\"
SERVER_CFLAGS += -DUSE_AUTOUPDATER -DAUTOUPDATER_BIN=\\\"$(AUTOUPDATER_BIN)\\\"
endif
ifeq ($(BUILD_AUTOUPDATER),1)
AUTOUPDATER_LIBS += $(LIBTOMCRYPTSRCDIR)/libtomcrypt.a $(TOMSFASTMATHSRCDIR)/libtfm.a
endif
ifeq ("$(CC)", $(findstring "$(CC)", "clang" "clang++"))
BASE_CFLAGS += -Qunused-arguments
endif
ifdef DEFAULT_BASEDIR
BASE_CFLAGS += -DDEFAULT_BASEDIR=\\\"$(DEFAULT_BASEDIR)\\\"
endif
ifeq ($(USE_LOCAL_HEADERS),1)
BASE_CFLAGS += -DUSE_LOCAL_HEADERS
endif
ifeq ($(BUILD_STANDALONE),1)
BASE_CFLAGS += -DSTANDALONE
endif
ifeq ($(GENERATE_DEPENDENCIES),1)
DEPEND_CFLAGS = -MMD
else
DEPEND_CFLAGS =
endif
ifeq ($(NO_STRIP),1)
STRIP_FLAG =
else
STRIP_FLAG = -s
endif
# https://reproducible-builds.org/specs/source-date-epoch/
ifdef SOURCE_DATE_EPOCH
BASE_CFLAGS += -DPRODUCT_DATE=\\\"$(shell date --date="@$$SOURCE_DATE_EPOCH" "+%b %_d %Y" | sed -e 's/ /\\\ /'g)\\\"
endif
BASE_CFLAGS += -DPRODUCT_VERSION=\\\"$(VERSION)\\\"
BASE_CFLAGS += -Wformat=2 -Wno-format-zero-length -Wformat-security -Wno-format-nonliteral
BASE_CFLAGS += -Wstrict-aliasing=2 -Wmissing-format-attribute
BASE_CFLAGS += -Wdisabled-optimization
BASE_CFLAGS += -Werror-implicit-function-declaration
ifeq ($(V),1)
echo_cmd=@:
Q=
else
echo_cmd=@echo
Q=@
endif
define DO_CC
2007-08-27 07:02:54 +00:00
$(echo_cmd) "CC $<"
2009-11-08 17:36:05 +00:00
$(Q)$(CC) $(NOTSHLIBCFLAGS) $(CFLAGS) $(CLIENT_CFLAGS) $(OPTIMIZE) -o $@ -c $<
endef
define DO_CC_ALTIVEC
$(echo_cmd) "CC $<"
$(Q)$(CC) $(NOTSHLIBCFLAGS) $(CFLAGS) $(CLIENT_CFLAGS) $(OPTIMIZE) $(ALTIVEC_CFLAGS) -o $@ -c $<
endef
define DO_REF_CC
$(echo_cmd) "REF_CC $<"
$(Q)$(CC) $(SHLIBCFLAGS) $(CFLAGS) $(CLIENT_CFLAGS) $(OPTIMIZE) -o $@ -c $<
endef
2022-04-17 20:45:28 +00:00
define DO_REF_CC_PRECISE
$(echo_cmd) "REF_CC $<"
$(Q)$(CC) $(SHLIBCFLAGS) $(CFLAGS) $(CLIENT_CFLAGS) $(OPTIMIZEVM) $(OPTIMIZEFASTMATH) -o $@ -c $<
endef
define DO_REF_CC_ALTIVEC
$(echo_cmd) "REF_CC $<"
$(Q)$(CC) $(SHLIBCFLAGS) $(CFLAGS) $(CLIENT_CFLAGS) $(OPTIMIZE) $(ALTIVEC_CFLAGS) -o $@ -c $<
endef
define DO_REF_STR
$(echo_cmd) "REF_STR $<"
$(Q)rm -f $@
$(Q)echo "const char *fallbackShader_$(notdir $(basename $<)) =" >> $@
$(Q)cat $< | sed -e 's/^\(.*\)$$/\"\1\"/' >> $@
$(Q)echo ";" >> $@
endef
define DO_BOT_CC
2007-08-27 07:02:54 +00:00
$(echo_cmd) "BOT_CC $<"
2009-11-08 17:36:05 +00:00
$(Q)$(CC) $(NOTSHLIBCFLAGS) $(CFLAGS) $(BOTCFLAGS) $(OPTIMIZE) -DBOTLIB -o $@ -c $<
endef
ifeq ($(GENERATE_DEPENDENCIES),1)
DO_QVM_DEP=cat $(@:%.o=%.d) | sed -e 's/\.o/\.asm/g' >> $(@:%.o=%.d)
endif
define DO_SHLIB_CC
2007-08-27 07:02:54 +00:00
$(echo_cmd) "SHLIB_CC $<"
$(Q)$(CC) $(BASEGAME_CFLAGS) $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
2007-08-27 07:02:54 +00:00
$(Q)$(DO_QVM_DEP)
endef
define DO_GAME_CC
$(echo_cmd) "GAME_CC $<"
$(Q)$(CC) $(BASEGAME_CFLAGS) -DQAGAME $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
$(Q)$(DO_QVM_DEP)
endef
define DO_CGAME_CC
$(echo_cmd) "CGAME_CC $<"
$(Q)$(CC) $(BASEGAME_CFLAGS) -DCGAME $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
$(Q)$(DO_QVM_DEP)
endef
define DO_UI_CC
$(echo_cmd) "UI_CC $<"
$(Q)$(CC) $(BASEGAME_CFLAGS) -DUI $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
$(Q)$(DO_QVM_DEP)
endef
define DO_SHLIB_CC_MISSIONPACK
2007-08-27 07:02:54 +00:00
$(echo_cmd) "SHLIB_CC_MISSIONPACK $<"
$(Q)$(CC) $(MISSIONPACK_CFLAGS) $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
2007-08-27 07:02:54 +00:00
$(Q)$(DO_QVM_DEP)
endef
define DO_GAME_CC_MISSIONPACK
$(echo_cmd) "GAME_CC_MISSIONPACK $<"
$(Q)$(CC) $(MISSIONPACK_CFLAGS) -DQAGAME $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
$(Q)$(DO_QVM_DEP)
endef
define DO_CGAME_CC_MISSIONPACK
$(echo_cmd) "CGAME_CC_MISSIONPACK $<"
$(Q)$(CC) $(MISSIONPACK_CFLAGS) -DCGAME $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
$(Q)$(DO_QVM_DEP)
endef
define DO_UI_CC_MISSIONPACK
$(echo_cmd) "UI_CC_MISSIONPACK $<"
$(Q)$(CC) $(MISSIONPACK_CFLAGS) -DUI $(SHLIBCFLAGS) $(CFLAGS) $(OPTIMIZEVM) -o $@ -c $<
$(Q)$(DO_QVM_DEP)
endef
define DO_AS
2007-08-27 07:02:54 +00:00
$(echo_cmd) "AS $<"
2009-11-08 17:36:05 +00:00
$(Q)$(CC) $(CFLAGS) $(OPTIMIZE) -x assembler-with-cpp -o $@ -c $<
endef
define DO_DED_CC
2007-08-27 07:02:54 +00:00
$(echo_cmd) "DED_CC $<"
2009-11-08 17:36:05 +00:00
$(Q)$(CC) $(NOTSHLIBCFLAGS) -DDEDICATED $(CFLAGS) $(SERVER_CFLAGS) $(OPTIMIZE) -o $@ -c $<
endef
define DO_WINDRES
2007-08-27 07:02:54 +00:00
$(echo_cmd) "WINDRES $<"
$(Q)$(WINDRES) -i $< -o $@
endef
2005-08-26 17:39:27 +00:00
#############################################################################
# MAIN TARGETS
#############################################################################
2005-08-26 17:39:27 +00:00
default: release
all: debug release
debug:
2009-11-08 17:36:05 +00:00
@$(MAKE) targets B=$(BD) CFLAGS="$(CFLAGS) $(BASE_CFLAGS) $(DEPEND_CFLAGS)" \
OPTIMIZE="$(DEBUG_CFLAGS)" OPTIMIZEVM="$(DEBUG_CFLAGS)" \
CLIENT_CFLAGS="$(CLIENT_CFLAGS)" SERVER_CFLAGS="$(SERVER_CFLAGS)" V=$(V)
release:
2009-11-08 17:36:05 +00:00
@$(MAKE) targets B=$(BR) CFLAGS="$(CFLAGS) $(BASE_CFLAGS) $(DEPEND_CFLAGS)" \
2009-12-18 21:52:36 +00:00
OPTIMIZE="-DNDEBUG $(OPTIMIZE)" OPTIMIZEVM="-DNDEBUG $(OPTIMIZEVM)" \
CLIENT_CFLAGS="$(CLIENT_CFLAGS)" SERVER_CFLAGS="$(SERVER_CFLAGS)" V=$(V)
2013-03-26 23:12:17 +00:00
ifneq ($(call bin_path, tput),)
TERM_COLUMNS=$(shell if c=`tput cols`; then echo $$(($$c-4)); else echo 76; fi)
2013-03-26 23:12:17 +00:00
else
TERM_COLUMNS=76
endif
2014-08-26 15:59:33 +00:00
define ADD_COPY_TARGET
TARGETS += $2
$2: $1
$(echo_cmd) "CP $$<"
@cp $1 $2
endef
# These functions allow us to generate rules for copying a list of files
# into the base directory of the build; this is useful for bundling libs,
# README files or whatever else
define GENERATE_COPY_TARGETS
$(foreach FILE,$1, \
$(eval $(call ADD_COPY_TARGET, \
$(FILE), \
$(addprefix $(B)/,$(notdir $(FILE))))))
endef
$(call GENERATE_COPY_TARGETS,$(EXTRA_FILES))
ifneq ($(BUILD_CLIENT),0)
$(call GENERATE_COPY_TARGETS,$(CLIENT_EXTRA_FILES))
endif
2013-03-26 23:12:17 +00:00
NAKED_TARGETS=$(shell echo $(TARGETS) | sed -e "s!$(B)/!!g")
print_list=-@for i in $(1); \
2013-03-26 23:12:17 +00:00
do \
echo " $$i"; \
done
ifneq ($(call bin_path, fmt),)
print_wrapped=@echo $(1) | fmt -w $(TERM_COLUMNS) | sed -e "s/^\(.*\)$$/ \1/"
else
print_wrapped=$(print_list)
endif
# Create the build directories, check libraries and print out
# an informational message, then start building
targets: makedirs
@echo ""
2013-03-26 23:12:17 +00:00
@echo "Building in $(B):"
@echo " PLATFORM: $(PLATFORM)"
2007-08-27 07:02:54 +00:00
@echo " ARCH: $(ARCH)"
@echo " VERSION: $(VERSION)"
2007-08-27 07:02:54 +00:00
@echo " COMPILE_PLATFORM: $(COMPILE_PLATFORM)"
@echo " COMPILE_ARCH: $(COMPILE_ARCH)"
2014-10-23 11:00:17 +00:00
@echo " HAVE_VM_COMPILED: $(HAVE_VM_COMPILED)"
@echo " PKG_CONFIG: $(PKG_CONFIG)"
@echo " CC: $(CC)"
2013-03-22 14:26:29 +00:00
ifeq ($(PLATFORM),mingw32)
@echo " WINDRES: $(WINDRES)"
endif
@echo ""
@echo " CFLAGS:"
2013-03-26 23:12:17 +00:00
$(call print_wrapped, $(CFLAGS) $(OPTIMIZE))
2009-11-08 17:36:05 +00:00
@echo ""
@echo " CLIENT_CFLAGS:"
2013-03-26 23:12:17 +00:00
$(call print_wrapped, $(CLIENT_CFLAGS))
2009-11-08 17:36:05 +00:00
@echo ""
@echo " SERVER_CFLAGS:"
2013-03-26 23:12:17 +00:00
$(call print_wrapped, $(SERVER_CFLAGS))
@echo ""
@echo " LDFLAGS:"
2013-03-26 23:12:17 +00:00
$(call print_wrapped, $(LDFLAGS))
@echo ""
@echo " LIBS:"
2013-03-26 23:12:17 +00:00
$(call print_wrapped, $(LIBS))
@echo ""
@echo " CLIENT_LIBS:"
2013-03-26 23:12:17 +00:00
$(call print_wrapped, $(CLIENT_LIBS))
@echo ""
@echo " AUTOUPDATER_LIBS:"
$(call print_wrapped, $(AUTOUPDATER_LIBS))
@echo ""
@echo " Output:"
2013-03-26 23:12:17 +00:00
$(call print_list, $(NAKED_TARGETS))
@echo ""
ifneq ($(TARGETS),)
ifndef DEBUG_MAKEFILE
@$(MAKE) $(TARGETS) $(B).zip V=$(V)
endif
endif
2005-08-26 17:39:27 +00:00
$(B).zip: $(TARGETS)
ifeq ($(PLATFORM),darwin)
ifdef ARCHIVE
@("./make-macosx-app.sh" release $(ARCH); if [ "$$?" -eq 0 ] && [ -d "$(B)/ioquake3.app" ]; then rm -f $@; cd $(B) && zip --symlinks -r9 ../../$@ `find "ioquake3.app" -print | sed -e "s!$(B)/!!g"`; else rm -f $@; cd $(B) && zip -r9 ../../$@ $(NAKED_TARGETS); fi)
endif
endif
ifneq ($(PLATFORM),darwin)
ifdef ARCHIVE
@rm -f $@
@(cd $(B) && zip -r9 ../../$@ $(NAKED_TARGETS))
endif
endif
2005-08-26 17:39:27 +00:00
makedirs:
@$(MKDIR) $(B)/autoupdater
@$(MKDIR) $(B)/client/opus
@$(MKDIR) $(B)/client/vorbis
@$(MKDIR) $(B)/renderergles3
@$(MKDIR) $(B)/renderergles3/glsl
@$(MKDIR) $(B)/ded
@$(MKDIR) $(B)/$(BASEGAME)/android
@$(MKDIR) $(B)/$(BASEGAME)/cgame
@$(MKDIR) $(B)/$(BASEGAME)/game
@$(MKDIR) $(B)/$(BASEGAME)/ui
@$(MKDIR) $(B)/$(BASEGAME)/qcommon
@$(MKDIR) $(B)/$(BASEGAME)/vm
@$(MKDIR) $(B)/$(MISSIONPACK)/cgame
@$(MKDIR) $(B)/$(MISSIONPACK)/game
@$(MKDIR) $(B)/$(MISSIONPACK)/ui
@$(MKDIR) $(B)/$(MISSIONPACK)/qcommon
@$(MKDIR) $(B)/$(MISSIONPACK)/vm
@$(MKDIR) $(B)/tools/asm
@$(MKDIR) $(B)/tools/etc
@$(MKDIR) $(B)/tools/rcc
@$(MKDIR) $(B)/tools/cpp
@$(MKDIR) $(B)/tools/lburg
2005-08-26 17:39:27 +00:00
#############################################################################
# QVM BUILD TOOLS
#############################################################################
ifndef TOOLS_CC
# A compiler which probably produces native binaries
TOOLS_CC = gcc
endif
ifndef YACC
YACC = yacc
endif
TOOLS_OPTIMIZE = -g -Wall -fno-strict-aliasing
TOOLS_CFLAGS += $(TOOLS_OPTIMIZE) \
-DTEMPDIR=\"$(TEMPDIR)\" -DSYSTEM=\"\" \
-I$(Q3LCCSRCDIR) \
-I$(LBURGDIR)
TOOLS_LIBS =
TOOLS_LDFLAGS =
ifeq ($(GENERATE_DEPENDENCIES),1)
2013-01-05 15:35:50 +00:00
TOOLS_CFLAGS += -MMD
endif
define DO_YACC
$(echo_cmd) "YACC $<"
$(Q)$(YACC) $<
$(Q)mv -f y.tab.c $@
endef
define DO_TOOLS_CC
$(echo_cmd) "TOOLS_CC $<"
$(Q)$(TOOLS_CC) $(TOOLS_CFLAGS) -o $@ -c $<
endef
define DO_TOOLS_CC_DAGCHECK
$(echo_cmd) "TOOLS_CC_DAGCHECK $<"
$(Q)$(TOOLS_CC) $(TOOLS_CFLAGS) -Wno-unused -o $@ -c $<
endef
LBURG = $(B)/tools/lburg/lburg$(TOOLS_BINEXT)
DAGCHECK_C = $(B)/tools/rcc/dagcheck.c
Q3RCC = $(B)/tools/q3rcc$(TOOLS_BINEXT)
Q3CPP = $(B)/tools/q3cpp$(TOOLS_BINEXT)
Q3LCC = $(B)/tools/q3lcc$(TOOLS_BINEXT)
Q3ASM = $(B)/tools/q3asm$(TOOLS_BINEXT)
LBURGOBJ= \
2013-01-05 15:35:50 +00:00
$(B)/tools/lburg/lburg.o \
$(B)/tools/lburg/gram.o
# override GNU Make built-in rule for converting gram.y to gram.c
%.c: %.y
ifeq ($(USE_YACC),1)
$(DO_YACC)
endif
$(B)/tools/lburg/%.o: $(LBURGDIR)/%.c
$(DO_TOOLS_CC)
$(LBURG): $(LBURGOBJ)
$(echo_cmd) "LD $@"
$(Q)$(TOOLS_CC) $(TOOLS_CFLAGS) $(TOOLS_LDFLAGS) -o $@ $^ $(TOOLS_LIBS)
Q3RCCOBJ = \
$(B)/tools/rcc/alloc.o \
$(B)/tools/rcc/bind.o \
$(B)/tools/rcc/bytecode.o \
$(B)/tools/rcc/dag.o \
$(B)/tools/rcc/dagcheck.o \
$(B)/tools/rcc/decl.o \
$(B)/tools/rcc/enode.o \
$(B)/tools/rcc/error.o \
$(B)/tools/rcc/event.o \
$(B)/tools/rcc/expr.o \
$(B)/tools/rcc/gen.o \
$(B)/tools/rcc/init.o \
$(B)/tools/rcc/inits.o \
$(B)/tools/rcc/input.o \
$(B)/tools/rcc/lex.o \
$(B)/tools/rcc/list.o \
$(B)/tools/rcc/main.o \
$(B)/tools/rcc/null.o \
$(B)/tools/rcc/output.o \
$(B)/tools/rcc/prof.o \
$(B)/tools/rcc/profio.o \
$(B)/tools/rcc/simp.o \
$(B)/tools/rcc/stmt.o \
$(B)/tools/rcc/string.o \
$(B)/tools/rcc/sym.o \
$(B)/tools/rcc/symbolic.o \
$(B)/tools/rcc/trace.o \
$(B)/tools/rcc/tree.o \
$(B)/tools/rcc/types.o
$(DAGCHECK_C): $(LBURG) $(Q3LCCSRCDIR)/dagcheck.md
$(echo_cmd) "LBURG $(Q3LCCSRCDIR)/dagcheck.md"
$(Q)$(LBURG) $(Q3LCCSRCDIR)/dagcheck.md $@
$(B)/tools/rcc/dagcheck.o: $(DAGCHECK_C)
$(DO_TOOLS_CC_DAGCHECK)
$(B)/tools/rcc/%.o: $(Q3LCCSRCDIR)/%.c
$(DO_TOOLS_CC)
$(Q3RCC): $(Q3RCCOBJ)
$(echo_cmd) "LD $@"
$(Q)$(TOOLS_CC) $(TOOLS_CFLAGS) $(TOOLS_LDFLAGS) -o $@ $^ $(TOOLS_LIBS)
Q3CPPOBJ = \
2013-01-05 15:35:50 +00:00
$(B)/tools/cpp/cpp.o \
$(B)/tools/cpp/lex.o \
$(B)/tools/cpp/nlist.o \
$(B)/tools/cpp/tokens.o \
$(B)/tools/cpp/macro.o \
$(B)/tools/cpp/eval.o \
$(B)/tools/cpp/include.o \
$(B)/tools/cpp/hideset.o \
$(B)/tools/cpp/getopt.o \
$(B)/tools/cpp/unix.o
$(B)/tools/cpp/%.o: $(Q3CPPDIR)/%.c
$(DO_TOOLS_CC)
$(Q3CPP): $(Q3CPPOBJ)
$(echo_cmd) "LD $@"
$(Q)$(TOOLS_CC) $(TOOLS_CFLAGS) $(TOOLS_LDFLAGS) -o $@ $^ $(TOOLS_LIBS)
Q3LCCOBJ = \
$(B)/tools/etc/lcc.o \
$(B)/tools/etc/bytecode.o
$(B)/tools/etc/%.o: $(Q3LCCETCDIR)/%.c
$(DO_TOOLS_CC)
$(Q3LCC): $(Q3LCCOBJ) $(Q3RCC) $(Q3CPP)
$(echo_cmd) "LD $@"
$(Q)$(TOOLS_CC) $(TOOLS_CFLAGS) $(TOOLS_LDFLAGS) -o $@ $(Q3LCCOBJ) $(TOOLS_LIBS)
define DO_Q3LCC
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3LCC $<"
$(Q)$(Q3LCC) $(BASEGAME_CFLAGS) -o $@ $<
endef
define DO_CGAME_Q3LCC
$(echo_cmd) "CGAME_Q3LCC $<"
$(Q)$(Q3LCC) $(BASEGAME_CFLAGS) -DCGAME -o $@ $<
endef
define DO_GAME_Q3LCC
$(echo_cmd) "GAME_Q3LCC $<"
$(Q)$(Q3LCC) $(BASEGAME_CFLAGS) -DQAGAME -o $@ $<
endef
define DO_UI_Q3LCC
$(echo_cmd) "UI_Q3LCC $<"
$(Q)$(Q3LCC) $(BASEGAME_CFLAGS) -DUI -o $@ $<
endef
define DO_Q3LCC_MISSIONPACK
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3LCC_MISSIONPACK $<"
$(Q)$(Q3LCC) $(MISSIONPACK_CFLAGS) -o $@ $<
endef
define DO_CGAME_Q3LCC_MISSIONPACK
$(echo_cmd) "CGAME_Q3LCC_MISSIONPACK $<"
$(Q)$(Q3LCC) $(MISSIONPACK_CFLAGS) -DCGAME -o $@ $<
endef
define DO_GAME_Q3LCC_MISSIONPACK
$(echo_cmd) "GAME_Q3LCC_MISSIONPACK $<"
$(Q)$(Q3LCC) $(MISSIONPACK_CFLAGS) -DQAGAME -o $@ $<
endef
define DO_UI_Q3LCC_MISSIONPACK
$(echo_cmd) "UI_Q3LCC_MISSIONPACK $<"
$(Q)$(Q3LCC) $(MISSIONPACK_CFLAGS) -DUI -o $@ $<
endef
Q3ASMOBJ = \
$(B)/tools/asm/q3asm.o \
$(B)/tools/asm/cmdlib.o
$(B)/tools/asm/%.o: $(Q3ASMDIR)/%.c
$(DO_TOOLS_CC)
$(Q3ASM): $(Q3ASMOBJ)
$(echo_cmd) "LD $@"
$(Q)$(TOOLS_CC) $(TOOLS_CFLAGS) $(TOOLS_LDFLAGS) -o $@ $^ $(TOOLS_LIBS)
#############################################################################
# AUTOUPDATER
#############################################################################
define DO_AUTOUPDATER_CC
$(echo_cmd) "AUTOUPDATER_CC $<"
2017-06-04 05:16:37 +00:00
$(Q)$(CC) $(CFLAGS) -I$(LIBTOMCRYPTSRCDIR)/src/headers -I$(TOMSFASTMATHSRCDIR)/src/headers $(CURL_CFLAGS) -o $@ -c $<
endef
Q3AUTOUPDATEROBJ = \
$(B)/autoupdater/autoupdater.o
$(B)/autoupdater/%.o: $(AUTOUPDATERSRCDIR)/%.c
$(DO_AUTOUPDATER_CC)
$(B)/$(AUTOUPDATER_BIN): $(Q3AUTOUPDATEROBJ)
$(echo_cmd) "AUTOUPDATER_LD $@"
$(Q)$(CC) $(LDFLAGS) -o $@ $(Q3AUTOUPDATEROBJ) $(AUTOUPDATER_LIBS)
2005-08-26 17:39:27 +00:00
#############################################################################
# CLIENT/SERVER
#############################################################################
Q3OBJ = \
$(B)/client/cl_cgame.o \
$(B)/client/cl_cin.o \
$(B)/client/cl_console.o \
$(B)/client/cl_input.o \
$(B)/client/cl_keys.o \
$(B)/client/cl_main.o \
$(B)/client/cl_net_chan.o \
$(B)/client/cl_parse.o \
$(B)/client/cl_scrn.o \
$(B)/client/cl_ui.o \
$(B)/client/cl_avi.o \
\
$(B)/client/cm_load.o \
$(B)/client/cm_patch.o \
$(B)/client/cm_polylib.o \
$(B)/client/cm_test.o \
$(B)/client/cm_trace.o \
\
$(B)/client/cmd.o \
$(B)/client/common.o \
$(B)/client/cvar.o \
$(B)/client/files.o \
$(B)/client/md4.o \
$(B)/client/md5.o \
$(B)/client/msg.o \
$(B)/client/net_chan.o \
$(B)/client/net_ip.o \
$(B)/client/huffman.o \
\
$(B)/client/snd_altivec.o \
$(B)/client/snd_adpcm.o \
$(B)/client/snd_dma.o \
$(B)/client/snd_mem.o \
$(B)/client/snd_mix.o \
$(B)/client/snd_wavelet.o \
\
$(B)/client/snd_main.o \
$(B)/client/snd_codec.o \
$(B)/client/snd_codec_wav.o \
$(B)/client/snd_codec_ogg.o \
2013-02-18 00:32:05 +00:00
$(B)/client/snd_codec_opus.o \
\
$(B)/client/qal.o \
$(B)/client/snd_openal.o \
\
$(B)/client/cl_curl.o \
\
$(B)/client/sv_bot.o \
$(B)/client/sv_ccmds.o \
$(B)/client/sv_client.o \
$(B)/client/sv_game.o \
$(B)/client/sv_init.o \
$(B)/client/sv_main.o \
$(B)/client/sv_net_chan.o \
$(B)/client/sv_snapshot.o \
$(B)/client/sv_world.o \
\
$(B)/client/q_math.o \
$(B)/client/q_shared.o \
\
$(B)/client/unzip.o \
2009-10-19 14:00:16 +00:00
$(B)/client/ioapi.o \
$(B)/client/puff.o \
$(B)/client/vm.o \
$(B)/client/vm_interpreted.o \
\
$(B)/client/be_aas_bspq3.o \
$(B)/client/be_aas_cluster.o \
$(B)/client/be_aas_debug.o \
$(B)/client/be_aas_entity.o \
$(B)/client/be_aas_file.o \
$(B)/client/be_aas_main.o \
$(B)/client/be_aas_move.o \
$(B)/client/be_aas_optimize.o \
$(B)/client/be_aas_reach.o \
$(B)/client/be_aas_route.o \
$(B)/client/be_aas_routealt.o \
$(B)/client/be_aas_sample.o \
$(B)/client/be_ai_char.o \
$(B)/client/be_ai_chat.o \
$(B)/client/be_ai_gen.o \
$(B)/client/be_ai_goal.o \
$(B)/client/be_ai_move.o \
$(B)/client/be_ai_weap.o \
$(B)/client/be_ai_weight.o \
$(B)/client/be_ea.o \
$(B)/client/be_interface.o \
$(B)/client/l_crc.o \
$(B)/client/l_libvar.o \
$(B)/client/l_log.o \
$(B)/client/l_memory.o \
$(B)/client/l_precomp.o \
$(B)/client/l_script.o \
$(B)/client/l_struct.o \
\
$(B)/client/sdl_input.o \
$(B)/client/android_snd.o \
\
2020-09-06 11:40:32 +00:00
$(B)/client/vr_base.o \
$(B)/client/vr_input.o \
$(B)/client/vr_renderer.o \
Squashed commit of the following: commit 0adeb4ba3bc12d1efeab7f7b4876fc61d9566ed4 Merge: 7feea565 d8653ad7 Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:32:21 2022 +0100 Merge branch 'OpenXR' of https://github.com/DrBeef/ioq3quest into OpenXR commit 7feea56514c17b3f1e7c15c73676bd9d8374ed6c Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:32:14 2022 +0100 Update Version Number commit d8653ad70e1cc9bf1fb2e72d6ad9c9b330db32d8 Merge: 79983b2b 7e6aa6da Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:31:45 2022 +0100 Merge pull request #76 from lvonasek/OpenXR OpenXR delayed controller pose fixed commit 79983b2bc5174eeb7c674396f07288da80ce94c5 Merge: 325641f9 7f89d6d1 Author: Simon <simonbrown77@googlemail.com> Date: Sat May 7 14:31:31 2022 +0100 Merge pull request #77 from petr666/OpenXR Update gamma values to better suit OpenXR build commit 7f89d6d19b2e807b001577c06c5f254106f95e0e Author: Petr Bartos <petr.bartos@plus4u.net> Date: Sat May 7 13:56:03 2022 +0200 Update gamma values to better suit OpenXR build commit 7e6aa6dab80e6ec4010e6057be4c0e34e4325245 Author: Lubos <tridosm@gmail.com> Date: Sat May 7 11:32:11 2022 +0200 OpenXR sync actions before updating controllers commit 027a7e96c312c43389299648326736766c8bab67 Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:34:50 2022 +0200 OpenXR implement controller velocity again commit af80d5c284b5372eb9b2533284325ae43caa80ec Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:18:51 2022 +0200 Compile fix commit ab1e853554a02c7dd59b2f59afab2569eb64ebed Author: Lubos <tridosm@gmail.com> Date: Fri May 6 10:14:08 2022 +0200 OpenXR input cleanup commit be158b4ad98a6b615c5fc34a407e4333dc468225 Author: Lubos <tridosm@gmail.com> Date: Fri May 6 09:39:49 2022 +0200 OpenXR sync input actions from renderer commit ed96160ffc0b3fb9350f8801257cfee713d8713f Author: Lubos <tridosm@gmail.com> Date: Fri May 6 09:25:59 2022 +0200 OpenXR do not use pose velocity to track controllers commit 42bf984ef8075ce45d6788fc09236d40d6a61dc9 Author: Lubos <tridosm@gmail.com> Date: Thu May 5 22:39:10 2022 +0200 OpenXR apply controller pose from renderer commit 92941b3547e7c4c7f126f608dde7239ee9c03b8e Author: Lubos <tridosm@gmail.com> Date: Thu May 5 22:26:33 2022 +0200 OpenXR delayed controller pose fixed commit 325641f90edbb1ba7ef96d288c443dd824a7528c Merge: de198fba 3ee3f590 Author: Simon <simonbrown77@googlemail.com> Date: Thu May 5 16:30:07 2022 +0100 Merge pull request #75 from lvonasek/OpenXR OpenXR menuyaw and recenter support added commit 3ee3f590584f6a8ff8d1e5cace7b999965c7e5cd Author: Lubos <tridosm@gmail.com> Date: Thu May 5 12:22:36 2022 +0200 OpenXR do not recenter on renderer reload commit 7072b0b89e0313a3bb39e8bb49dfdfa78e2972d9 Author: Lubos <tridosm@gmail.com> Date: Wed May 4 21:05:45 2022 +0200 OpenXR recenter sets yaw always to 0 commit 8e5f6414a6cb598c17b7d3cdbd208fe11d0d4fb3 Author: Lubos <tridosm@gmail.com> Date: Wed May 4 16:19:48 2022 +0200 OpenXR recenter integrated commit 08a4fc7fbf95e70f4a467350129a79d8358b34bd Author: Lubos <tridosm@gmail.com> Date: Tue May 3 18:37:28 2022 +0200 OpenXR use the same coordinate system in all layers commit a1de0e1ffe5081d0a15f4bd50b99f6a1c1439eac Author: Lubos <tridosm@gmail.com> Date: Mon May 2 22:17:53 2022 +0200 OpenXR menuYaw support added commit de198fba0da8130af67cfa9224c484e007d3a897 Author: Simon <simonbrown77@googlemail.com> Date: Mon May 2 10:01:42 2022 +0100 Update version numbers and add openxr identifier commit b83f99fe5b8db293a652f22d7adea825bf6a6549 Merge: c623bf13 9c14728b Author: Simon <simonbrown77@googlemail.com> Date: Mon May 2 09:43:47 2022 +0100 Merge pull request #74 from lvonasek/OpenXR OpenXR left controller mapping fixed commit 9c14728bc98f037dff8d7825692463b44915babe Merge: 11a849b1 0695c7ac Author: Lubos <tridosm@gmail.com> Date: Sun May 1 19:41:45 2022 +0200 Merge branch 'master' into OpenXR commit 11a849b189b4a5a8ab9676cd2cfeaae826e09187 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 19:09:12 2022 +0200 OpenXR controller mapping fixed commit 712584eae8dbcec3b10e0e39b2266f83487d4ecb Merge: df4bc0c0 c623bf13 Author: Luboš Vonásek <tridosm@gmail.com> Date: Sun May 1 19:04:45 2022 +0200 Merge branch 'DrBeef:OpenXR' into OpenXR commit c623bf1399406c24a1e9bf25fc54de758ac70c94 Merge: cb152467 e42a2f4e Author: Simon <simonbrown77@googlemail.com> Date: Sun May 1 14:10:23 2022 +0100 Merge pull request #72 from lvonasek/OpenXR OpenXR jitter fixed commit e42a2f4e0d4a0c48a266ef03b6599e70aadc1875 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 14:34:38 2022 +0200 Compile fix commit acbff1e7364c40d9f1a0820a561be40237c94994 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 13:59:41 2022 +0200 OpenXR camera view moved into renderer commit cb152467bacd5b7a92513b4279cf85a17f9c08e2 Merge: decc2d02 26071937 Author: Simon <simonbrown77@googlemail.com> Date: Sun May 1 10:20:40 2022 +0100 Merge pull request #69 from lvonasek/feature_openxr OpenXR integration commit 26071937c8b5053fe20e10d07fab5b9a695bfcc2 Author: Lubos <tridosm@gmail.com> Date: Sun May 1 11:17:50 2022 +0200 OpenXR frameskip integrated commit f735535dcef2675678e1731ec67f4f5b7537bd49 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 22:57:48 2022 +0200 OpenXR attempt to fix flickering commit 0eb1d43b4aaa18550384d3689df9233bb293cbcc Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 21:28:26 2022 +0200 2D aspect ratio fixed commit 9d07c2760463062fa2afb52f533f8af4001c9576 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 21:23:53 2022 +0200 Hud model rendering fixed commit 30c9b4eaa0c3ecf235c592de0e52771a7d79453c Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 17:03:54 2022 +0200 Release build fixed commit 405ca571ad31d6bbd99de96e87cb0564d5daa60b Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 14:10:27 2022 +0200 OpenXR foveation removed commit 61b3192bce97b48587cd360c0318c4708a9e1828 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 30 14:02:21 2022 +0200 OpenXR projection matrix calculation from example code commit ecd50dbcb1b72baa1c730dbb900033febd4b81a8 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 21:21:10 2022 +0200 OpenXR low framerate fixed commit f5a8429fc1c094eb07b6a6ac463405a5ec44c63b Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 19:21:29 2022 +0200 Solution for black rectangles in the scene commit 9ae93a5fe9d684d7d739e1a9217324d770c4712a Merge: 10548445 decc2d02 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 29 14:58:35 2022 +0200 Merge branch 'master' into feature_openxr commit 10548445245439c1b245270fadc1a92f5be4650a Merge: 65e2031e 3cdf1858 Author: Lubos <tridosm@gmail.com> Date: Wed Apr 27 21:52:55 2022 +0200 Merge branch 'master' into feature_openxr commit 65e2031e954fe075189d1ab90eb6edce1b726731 Author: Lubos <tridosm@gmail.com> Date: Tue Apr 26 22:02:04 2022 +0200 OpenXR integration fixes commit c321b97894fa9dc240b82a89426a5b4516a6eb5b Author: Lubos <tridosm@gmail.com> Date: Mon Apr 25 16:48:09 2022 +0200 OpenXR multiview integrated commit 594716896626c4c2190dc620ed66bd69c858031d Author: Lubos <tridosm@gmail.com> Date: Sun Apr 24 20:25:19 2022 +0200 OpenXR minor fixes commit 249847930be0230b6d99008475b2f4c9bb1636f0 Author: Lubos <tridosm@gmail.com> Date: Sun Apr 24 18:06:02 2022 +0200 OpenXR use just one framebuffer commit b11122e36882e5c62511528a6f107821f0a8de24 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 21:06:35 2022 +0200 OpenXR touch controllers completely implemented commit 0bf485664c41ffa742d703ec358c9c38d01b51cc Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 19:44:18 2022 +0200 OpenXR haptics and refreshrate fixed commit 4716387e5274674a9432bf3867fc05a2ac62b597 Author: Lubos <tridosm@gmail.com> Date: Sat Apr 23 15:54:07 2022 +0200 OpenXR input except buttons implemented commit 7bd1fe31c2e9321af2fdd7ffee42ef94c08b5fdc Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 21:18:49 2022 +0200 OpenXR input in progress commit 3c26e08f011d25a907d05926c073baa93c94692d Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 18:41:26 2022 +0200 Old code removed commit 4d2644cae27c031e5c5d0c487e87c8e6b66b4857 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 18:32:42 2022 +0200 OpenXR fov fixed commit 501869a05128802049bb347eecb2c38d87391162 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 17:56:14 2022 +0200 OpenXR motion tracking in game mode added commit b152d21ddc669a135c7b2113440124ddbc1672df Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 16:14:36 2022 +0200 OpenXR cylinder projection added commit 3e9c80679e7c0adbeb20a3aa14ca20c48422b54a Merge: 0de4a0d1 39f669dd Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 14:13:18 2022 +0200 Merge branch 'master' into feature_openxr commit 0de4a0d19645706b6579ef00714e6291432f6543 Author: Lubos <tridosm@gmail.com> Date: Fri Apr 22 13:45:22 2022 +0200 OpenXR tracking added init, first working rendering commit 8431b1aa83be613e4c3f6d1b771f5e80b28e798b Author: Lubos <tridosm@gmail.com> Date: Thu Apr 21 21:15:02 2022 +0200 OpenXR add missing foveation commit 4ff90d8ba07eeaa554943e72fb69d40eaed1dd1f Author: Lubos <tridosm@gmail.com> Date: Thu Apr 21 21:00:02 2022 +0200 OpenXR renderer cleanup commit d736af15bd22b3f8f38f6b4c4dc1e1b53ddc7dae Merge: 7b9d51ec fe180129 Author: Lubos <tridosm@gmail.com> Date: Thu Mar 31 17:47:45 2022 +0200 Merge branch 'master' into feature_openxr commit 7b9d51ec30570dde2c5159037a4ceac1882acf55 Author: Lubos <tridosm@gmail.com> Date: Thu Mar 31 17:47:36 2022 +0200 OpenXR renderer in progress commit e7a2229edc46ac2c9821c1fbf0ecada57ac1d31f Merge: abeaf046 bcf9287a Author: Lubos <tridosm@gmail.com> Date: Wed Mar 30 09:44:15 2022 +0200 Merge branch 'master' into feature_openxr commit abeaf046074997aa90d315565189f8977416bcc9 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 19:57:47 2022 +0200 OpenXR initialization fixed commit f2fefbf7081ddcf8cd28272cea786f55e3260132 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 17:13:48 2022 +0200 OpenXR initialization added commit 96bf69cb15c6953b8ad1a9907de15b2032301ac3 Author: Lubos <tridosm@gmail.com> Date: Tue Mar 29 12:56:37 2022 +0200 VR API removed
2022-05-07 13:34:37 +00:00
$(B)/client/vr_types.o \
2020-09-06 11:40:32 +00:00
\
$(B)/client/con_log.o \
$(B)/client/sys_autoupdater.o \
$(B)/client/sys_main.o
2015-01-30 21:52:53 +00:00
ifdef MINGW
Q3OBJ += \
2013-01-05 15:35:50 +00:00
$(B)/client/con_passive.o
else
Q3OBJ += \
2013-01-05 15:35:50 +00:00
$(B)/client/con_tty.o
endif
Q3R2OBJ = \
$(B)/renderergles3/tr_animation.o \
$(B)/renderergles3/tr_backend.o \
$(B)/renderergles3/tr_bsp.o \
$(B)/renderergles3/tr_cmds.o \
$(B)/renderergles3/tr_curve.o \
$(B)/renderergles3/tr_dsa.o \
$(B)/renderergles3/tr_extramath.o \
$(B)/renderergles3/tr_extensions.o \
$(B)/renderergles3/tr_fbo.o \
$(B)/renderergles3/tr_flares.o \
$(B)/renderergles3/tr_font.o \
$(B)/renderergles3/tr_glsl.o \
$(B)/renderergles3/tr_image.o \
$(B)/renderergles3/tr_image_bmp.o \
$(B)/renderergles3/tr_image_jpg.o \
$(B)/renderergles3/tr_image_pcx.o \
$(B)/renderergles3/tr_image_png.o \
$(B)/renderergles3/tr_image_tga.o \
$(B)/renderergles3/tr_image_dds.o \
$(B)/renderergles3/tr_init.o \
$(B)/renderergles3/tr_light.o \
$(B)/renderergles3/tr_main.o \
$(B)/renderergles3/tr_marks.o \
$(B)/renderergles3/tr_mesh.o \
$(B)/renderergles3/tr_model.o \
$(B)/renderergles3/tr_model_iqm.o \
$(B)/renderergles3/tr_noise.o \
$(B)/renderergles3/tr_postprocess.o \
$(B)/renderergles3/tr_scene.o \
$(B)/renderergles3/tr_shade.o \
$(B)/renderergles3/tr_shade_calc.o \
$(B)/renderergles3/tr_shader.o \
$(B)/renderergles3/tr_shadows.o \
$(B)/renderergles3/tr_sky.o \
$(B)/renderergles3/tr_surface.o \
$(B)/renderergles3/tr_vbo.o \
$(B)/renderergles3/tr_world.o \
$(B)/renderergles3/sdl_gamma.o \
$(B)/renderergles3/sdl_glimp.o
Q3R2STRINGOBJ = \
$(B)/renderergles3/glsl/bokeh_fp.o \
$(B)/renderergles3/glsl/bokeh_vp.o \
$(B)/renderergles3/glsl/calclevels4x_fp.o \
$(B)/renderergles3/glsl/calclevels4x_vp.o \
$(B)/renderergles3/glsl/depthblur_fp.o \
$(B)/renderergles3/glsl/depthblur_vp.o \
$(B)/renderergles3/glsl/dlight_fp.o \
$(B)/renderergles3/glsl/dlight_vp.o \
$(B)/renderergles3/glsl/down4x_fp.o \
$(B)/renderergles3/glsl/down4x_vp.o \
$(B)/renderergles3/glsl/fogpass_fp.o \
$(B)/renderergles3/glsl/fogpass_vp.o \
$(B)/renderergles3/glsl/generic_fp.o \
$(B)/renderergles3/glsl/generic_vp.o \
$(B)/renderergles3/glsl/lightall_fp.o \
$(B)/renderergles3/glsl/lightall_vp.o \
$(B)/renderergles3/glsl/pshadow_fp.o \
$(B)/renderergles3/glsl/pshadow_vp.o \
$(B)/renderergles3/glsl/shadowfill_fp.o \
$(B)/renderergles3/glsl/shadowfill_vp.o \
$(B)/renderergles3/glsl/shadowmask_fp.o \
$(B)/renderergles3/glsl/shadowmask_vp.o \
$(B)/renderergles3/glsl/ssao_fp.o \
$(B)/renderergles3/glsl/ssao_vp.o \
$(B)/renderergles3/glsl/texturecolor_fp.o \
$(B)/renderergles3/glsl/texturecolor_vp.o \
$(B)/renderergles3/glsl/tonemap_fp.o \
$(B)/renderergles3/glsl/tonemap_vp.o
ifneq ($(USE_RENDERER_DLOPEN), 0)
Q3R2OBJ += \
$(B)/renderergles3/q_shared.o \
$(B)/renderergles3/puff.o \
$(B)/renderergles3/q_math.o \
$(B)/renderergles3/tr_subs.o
endif
ifneq ($(USE_INTERNAL_JPEG),0)
JPGOBJ = \
$(B)/renderergles3/jaricom.o \
$(B)/renderergles3/jcapimin.o \
$(B)/renderergles3/jcapistd.o \
$(B)/renderergles3/jcarith.o \
$(B)/renderergles3/jccoefct.o \
$(B)/renderergles3/jccolor.o \
$(B)/renderergles3/jcdctmgr.o \
$(B)/renderergles3/jchuff.o \
$(B)/renderergles3/jcinit.o \
$(B)/renderergles3/jcmainct.o \
$(B)/renderergles3/jcmarker.o \
$(B)/renderergles3/jcmaster.o \
$(B)/renderergles3/jcomapi.o \
$(B)/renderergles3/jcparam.o \
$(B)/renderergles3/jcprepct.o \
$(B)/renderergles3/jcsample.o \
$(B)/renderergles3/jctrans.o \
$(B)/renderergles3/jdapimin.o \
$(B)/renderergles3/jdapistd.o \
$(B)/renderergles3/jdarith.o \
$(B)/renderergles3/jdatadst.o \
$(B)/renderergles3/jdatasrc.o \
$(B)/renderergles3/jdcoefct.o \
$(B)/renderergles3/jdcolor.o \
$(B)/renderergles3/jddctmgr.o \
$(B)/renderergles3/jdhuff.o \
$(B)/renderergles3/jdinput.o \
$(B)/renderergles3/jdmainct.o \
$(B)/renderergles3/jdmarker.o \
$(B)/renderergles3/jdmaster.o \
$(B)/renderergles3/jdmerge.o \
$(B)/renderergles3/jdpostct.o \
$(B)/renderergles3/jdsample.o \
$(B)/renderergles3/jdtrans.o \
$(B)/renderergles3/jerror.o \
$(B)/renderergles3/jfdctflt.o \
$(B)/renderergles3/jfdctfst.o \
$(B)/renderergles3/jfdctint.o \
$(B)/renderergles3/jidctflt.o \
$(B)/renderergles3/jidctfst.o \
$(B)/renderergles3/jidctint.o \
$(B)/renderergles3/jmemmgr.o \
$(B)/renderergles3/jmemnobs.o \
$(B)/renderergles3/jquant1.o \
$(B)/renderergles3/jquant2.o \
$(B)/renderergles3/jutils.o
endif
ifeq ($(ARCH),x86)
Q3OBJ += \
$(B)/client/snd_mixa.o \
$(B)/client/matha.o \
$(B)/client/snapvector.o \
$(B)/client/ftola.o
endif
ifeq ($(ARCH),x86_64)
Q3OBJ += \
$(B)/client/snapvector.o \
$(B)/client/ftola.o
endif
ifeq ($(NEED_OPUS),1)
2013-02-18 00:32:05 +00:00
ifeq ($(USE_INTERNAL_OPUS),1)
Q3OBJ += \
2014-02-08 03:21:02 +00:00
$(B)/client/opus/analysis.o \
$(B)/client/opus/mlp.o \
$(B)/client/opus/mlp_data.o \
2013-02-18 00:32:05 +00:00
$(B)/client/opus/opus.o \
$(B)/client/opus/opus_decoder.o \
$(B)/client/opus/opus_encoder.o \
$(B)/client/opus/opus_multistream.o \
2014-02-08 03:21:02 +00:00
$(B)/client/opus/opus_multistream_encoder.o \
$(B)/client/opus/opus_multistream_decoder.o \
2013-02-18 00:32:05 +00:00
$(B)/client/opus/repacketizer.o \
\
$(B)/client/opus/bands.o \
$(B)/client/opus/celt.o \
$(B)/client/opus/cwrs.o \
$(B)/client/opus/entcode.o \
$(B)/client/opus/entdec.o \
$(B)/client/opus/entenc.o \
$(B)/client/opus/kiss_fft.o \
$(B)/client/opus/laplace.o \
$(B)/client/opus/mathops.o \
$(B)/client/opus/mdct.o \
$(B)/client/opus/modes.o \
$(B)/client/opus/pitch.o \
2014-02-08 03:21:02 +00:00
$(B)/client/opus/celt_encoder.o \
$(B)/client/opus/celt_decoder.o \
2013-02-18 00:32:05 +00:00
$(B)/client/opus/celt_lpc.o \
$(B)/client/opus/quant_bands.o \
$(B)/client/opus/rate.o \
$(B)/client/opus/vq.o \
\
$(B)/client/opus/CNG.o \
$(B)/client/opus/code_signs.o \
$(B)/client/opus/init_decoder.o \
$(B)/client/opus/decode_core.o \
$(B)/client/opus/decode_frame.o \
$(B)/client/opus/decode_parameters.o \
$(B)/client/opus/decode_indices.o \
$(B)/client/opus/decode_pulses.o \
$(B)/client/opus/decoder_set_fs.o \
$(B)/client/opus/dec_API.o \
$(B)/client/opus/enc_API.o \
$(B)/client/opus/encode_indices.o \
$(B)/client/opus/encode_pulses.o \
$(B)/client/opus/gain_quant.o \
$(B)/client/opus/interpolate.o \
$(B)/client/opus/LP_variable_cutoff.o \
$(B)/client/opus/NLSF_decode.o \
$(B)/client/opus/NSQ.o \
$(B)/client/opus/NSQ_del_dec.o \
$(B)/client/opus/PLC.o \
$(B)/client/opus/shell_coder.o \
$(B)/client/opus/tables_gain.o \
$(B)/client/opus/tables_LTP.o \
$(B)/client/opus/tables_NLSF_CB_NB_MB.o \
$(B)/client/opus/tables_NLSF_CB_WB.o \
$(B)/client/opus/tables_other.o \
$(B)/client/opus/tables_pitch_lag.o \
$(B)/client/opus/tables_pulses_per_block.o \
$(B)/client/opus/VAD.o \
$(B)/client/opus/control_audio_bandwidth.o \
$(B)/client/opus/quant_LTP_gains.o \
$(B)/client/opus/VQ_WMat_EC.o \
$(B)/client/opus/HP_variable_cutoff.o \
$(B)/client/opus/NLSF_encode.o \
$(B)/client/opus/NLSF_VQ.o \
$(B)/client/opus/NLSF_unpack.o \
$(B)/client/opus/NLSF_del_dec_quant.o \
$(B)/client/opus/process_NLSFs.o \
$(B)/client/opus/stereo_LR_to_MS.o \
$(B)/client/opus/stereo_MS_to_LR.o \
$(B)/client/opus/check_control_input.o \
$(B)/client/opus/control_SNR.o \
$(B)/client/opus/init_encoder.o \
$(B)/client/opus/control_codec.o \
$(B)/client/opus/A2NLSF.o \
$(B)/client/opus/ana_filt_bank_1.o \
$(B)/client/opus/biquad_alt.o \
$(B)/client/opus/bwexpander_32.o \
$(B)/client/opus/bwexpander.o \
$(B)/client/opus/debug.o \
$(B)/client/opus/decode_pitch.o \
$(B)/client/opus/inner_prod_aligned.o \
$(B)/client/opus/lin2log.o \
$(B)/client/opus/log2lin.o \
$(B)/client/opus/LPC_analysis_filter.o \
2018-03-16 18:03:37 +00:00
$(B)/client/opus/LPC_fit.o \
2013-02-18 00:32:05 +00:00
$(B)/client/opus/LPC_inv_pred_gain.o \
$(B)/client/opus/table_LSF_cos.o \
$(B)/client/opus/NLSF2A.o \
$(B)/client/opus/NLSF_stabilize.o \
$(B)/client/opus/NLSF_VQ_weights_laroia.o \
$(B)/client/opus/pitch_est_tables.o \
$(B)/client/opus/resampler.o \
$(B)/client/opus/resampler_down2_3.o \
$(B)/client/opus/resampler_down2.o \
$(B)/client/opus/resampler_private_AR2.o \
$(B)/client/opus/resampler_private_down_FIR.o \
$(B)/client/opus/resampler_private_IIR_FIR.o \
$(B)/client/opus/resampler_private_up2_HQ.o \
$(B)/client/opus/resampler_rom.o \
$(B)/client/opus/sigm_Q15.o \
$(B)/client/opus/sort.o \
$(B)/client/opus/sum_sqr_shift.o \
$(B)/client/opus/stereo_decode_pred.o \
$(B)/client/opus/stereo_encode_pred.o \
$(B)/client/opus/stereo_find_predictor.o \
$(B)/client/opus/stereo_quant_pred.o \
\
$(B)/client/opus/apply_sine_window_FLP.o \
$(B)/client/opus/corrMatrix_FLP.o \
$(B)/client/opus/encode_frame_FLP.o \
$(B)/client/opus/find_LPC_FLP.o \
$(B)/client/opus/find_LTP_FLP.o \
$(B)/client/opus/find_pitch_lags_FLP.o \
$(B)/client/opus/find_pred_coefs_FLP.o \
$(B)/client/opus/LPC_analysis_filter_FLP.o \
$(B)/client/opus/LTP_analysis_filter_FLP.o \
$(B)/client/opus/LTP_scale_ctrl_FLP.o \
$(B)/client/opus/noise_shape_analysis_FLP.o \
$(B)/client/opus/process_gains_FLP.o \
$(B)/client/opus/regularize_correlations_FLP.o \
$(B)/client/opus/residual_energy_FLP.o \
$(B)/client/opus/warped_autocorrelation_FLP.o \
$(B)/client/opus/wrappers_FLP.o \
$(B)/client/opus/autocorrelation_FLP.o \
$(B)/client/opus/burg_modified_FLP.o \
$(B)/client/opus/bwexpander_FLP.o \
$(B)/client/opus/energy_FLP.o \
$(B)/client/opus/inner_product_FLP.o \
$(B)/client/opus/k2a_FLP.o \
$(B)/client/opus/LPC_inv_pred_gain_FLP.o \
$(B)/client/opus/pitch_analysis_core_FLP.o \
$(B)/client/opus/scale_copy_vector_FLP.o \
$(B)/client/opus/scale_vector_FLP.o \
$(B)/client/opus/schur_FLP.o \
$(B)/client/opus/sort_FLP.o \
\
$(B)/client/http.o \
$(B)/client/info.o \
$(B)/client/internal.o \
$(B)/client/opusfile.o \
2014-02-08 03:29:10 +00:00
$(B)/client/stream.o \
$(B)/client/wincerts.o
2013-02-18 00:32:05 +00:00
endif
endif
2013-02-18 00:56:06 +00:00
ifeq ($(NEED_OGG),1)
ifeq ($(USE_INTERNAL_OGG),1)
Q3OBJ += \
$(B)/client/bitwise.o \
$(B)/client/framing.o
endif
endif
ifeq ($(USE_CODEC_VORBIS),1)
2014-02-08 08:26:03 +00:00
ifeq ($(USE_INTERNAL_VORBIS),1)
Q3OBJ += \
$(B)/client/vorbis/analysis.o \
$(B)/client/vorbis/bitrate.o \
$(B)/client/vorbis/block.o \
$(B)/client/vorbis/codebook.o \
$(B)/client/vorbis/envelope.o \
$(B)/client/vorbis/floor0.o \
$(B)/client/vorbis/floor1.o \
$(B)/client/vorbis/info.o \
$(B)/client/vorbis/lookup.o \
$(B)/client/vorbis/lpc.o \
$(B)/client/vorbis/lsp.o \
$(B)/client/vorbis/mapping0.o \
$(B)/client/vorbis/mdct.o \
$(B)/client/vorbis/psy.o \
$(B)/client/vorbis/registry.o \
$(B)/client/vorbis/res0.o \
$(B)/client/vorbis/smallft.o \
$(B)/client/vorbis/sharedbook.o \
$(B)/client/vorbis/synthesis.o \
$(B)/client/vorbis/vorbisfile.o \
$(B)/client/vorbis/window.o
endif
endif
2009-10-19 14:00:16 +00:00
ifeq ($(USE_INTERNAL_ZLIB),1)
Q3OBJ += \
$(B)/client/adler32.o \
$(B)/client/crc32.o \
$(B)/client/inffast.o \
$(B)/client/inflate.o \
$(B)/client/inftrees.o \
$(B)/client/zutil.o
endif
2008-06-02 06:46:41 +00:00
2006-06-06 18:09:09 +00:00
ifeq ($(HAVE_VM_COMPILED),true)
ifneq ($(findstring $(ARCH),x86 x86_64),)
Q3OBJ += \
$(B)/client/vm_x86.o
2006-06-06 18:09:09 +00:00
endif
ifneq ($(findstring $(ARCH),ppc ppc64),)
Q3OBJ += $(B)/client/vm_powerpc.o $(B)/client/vm_powerpc_asm.o
endif
ifeq ($(ARCH),sparc)
Q3OBJ += $(B)/client/vm_sparc.o
endif
2014-10-23 11:00:17 +00:00
ifeq ($(ARCH),armv7l)
Q3OBJ += $(B)/client/vm_armv7l.o
endif
endif
2005-08-26 17:39:27 +00:00
2015-01-30 21:52:53 +00:00
ifdef MINGW
Q3OBJ += \
$(B)/client/win_resource.o \
$(B)/client/sys_win32.o
2005-09-22 03:21:33 +00:00
else
Q3OBJ += \
$(B)/client/sys_unix.o
endif
ifeq ($(PLATFORM),darwin)
Q3OBJ += \
$(B)/client/sys_osx.o
endif
ifeq ($(USE_MUMBLE),1)
Q3OBJ += \
$(B)/client/libmumblelink.o
endif
ifneq ($(USE_RENDERER_DLOPEN),0)
2020-09-06 11:40:32 +00:00
$(B)/$(LIBPREFIX)renderer_opengl2_$(SHLIBNAME): $(Q3R2OBJ) $(Q3R2STRINGOBJ) $(JPGOBJ)
$(echo_cmd) "LD $@"
2013-01-24 22:53:08 +00:00
$(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(Q3R2OBJ) $(Q3R2STRINGOBJ) $(JPGOBJ) \
$(THREAD_LIBS) $(LIBSDLMAIN) $(RENDERER_LIBS) $(LIBS)
else
$(B)/$(CLIENTBIN)_opengl2$(FULLBINEXT): $(Q3OBJ) $(Q3R2OBJ) $(Q3R2STRINGOBJ) $(JPGOBJ) $(LIBSDLMAIN)
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CLIENT_CFLAGS) $(CFLAGS) $(CLIENT_LDFLAGS) $(LDFLAGS) $(NOTSHLIBLDFLAGS) \
2013-01-24 22:53:08 +00:00
-o $@ $(Q3OBJ) $(Q3R2OBJ) $(Q3R2STRINGOBJ) $(JPGOBJ) \
$(LIBSDLMAIN) $(CLIENT_LIBS) $(RENDERER_LIBS) $(LIBS)
endif
ifneq ($(strip $(LIBSDLMAIN)),)
ifneq ($(strip $(LIBSDLMAINSRC)),)
$(LIBSDLMAIN) : $(LIBSDLMAINSRC)
cp $< $@
2013-03-25 22:41:15 +00:00
$(RANLIB) $@
endif
endif
2005-08-26 17:39:27 +00:00
#############################################################################
# DEDICATED SERVER
2005-08-26 17:39:27 +00:00
#############################################################################
Q3DOBJ = \
$(B)/ded/sv_bot.o \
$(B)/ded/sv_client.o \
$(B)/ded/sv_ccmds.o \
$(B)/ded/sv_game.o \
$(B)/ded/sv_init.o \
$(B)/ded/sv_main.o \
$(B)/ded/sv_net_chan.o \
$(B)/ded/sv_snapshot.o \
$(B)/ded/sv_world.o \
\
$(B)/ded/cm_load.o \
$(B)/ded/cm_patch.o \
$(B)/ded/cm_polylib.o \
$(B)/ded/cm_test.o \
$(B)/ded/cm_trace.o \
$(B)/ded/cmd.o \
$(B)/ded/common.o \
$(B)/ded/cvar.o \
$(B)/ded/files.o \
$(B)/ded/md4.o \
$(B)/ded/msg.o \
$(B)/ded/net_chan.o \
$(B)/ded/net_ip.o \
$(B)/ded/huffman.o \
\
$(B)/ded/q_math.o \
$(B)/ded/q_shared.o \
\
$(B)/ded/unzip.o \
2009-10-19 14:00:16 +00:00
$(B)/ded/ioapi.o \
$(B)/ded/vm.o \
$(B)/ded/vm_interpreted.o \
\
$(B)/ded/be_aas_bspq3.o \
$(B)/ded/be_aas_cluster.o \
$(B)/ded/be_aas_debug.o \
$(B)/ded/be_aas_entity.o \
$(B)/ded/be_aas_file.o \
$(B)/ded/be_aas_main.o \
$(B)/ded/be_aas_move.o \
$(B)/ded/be_aas_optimize.o \
$(B)/ded/be_aas_reach.o \
$(B)/ded/be_aas_route.o \
$(B)/ded/be_aas_routealt.o \
$(B)/ded/be_aas_sample.o \
$(B)/ded/be_ai_char.o \
$(B)/ded/be_ai_chat.o \
$(B)/ded/be_ai_gen.o \
$(B)/ded/be_ai_goal.o \
$(B)/ded/be_ai_move.o \
$(B)/ded/be_ai_weap.o \
$(B)/ded/be_ai_weight.o \
$(B)/ded/be_ea.o \
$(B)/ded/be_interface.o \
$(B)/ded/l_crc.o \
$(B)/ded/l_libvar.o \
$(B)/ded/l_log.o \
$(B)/ded/l_memory.o \
$(B)/ded/l_precomp.o \
$(B)/ded/l_script.o \
$(B)/ded/l_struct.o \
\
$(B)/ded/null_client.o \
$(B)/ded/null_input.o \
$(B)/ded/null_snddma.o \
\
$(B)/ded/con_log.o \
$(B)/ded/sys_autoupdater.o \
$(B)/ded/sys_main.o
2005-08-26 17:39:27 +00:00
ifeq ($(ARCH),x86)
Q3DOBJ += \
$(B)/ded/matha.o \
$(B)/ded/snapvector.o \
2013-01-05 15:35:50 +00:00
$(B)/ded/ftola.o
endif
ifeq ($(ARCH),x86_64)
Q3DOBJ += \
$(B)/ded/snapvector.o \
2013-01-05 15:35:50 +00:00
$(B)/ded/ftola.o
endif
2005-08-26 17:39:27 +00:00
2009-10-19 14:00:16 +00:00
ifeq ($(USE_INTERNAL_ZLIB),1)
Q3DOBJ += \
$(B)/ded/adler32.o \
$(B)/ded/crc32.o \
$(B)/ded/inffast.o \
$(B)/ded/inflate.o \
$(B)/ded/inftrees.o \
$(B)/ded/zutil.o
endif
2006-06-06 18:09:09 +00:00
ifeq ($(HAVE_VM_COMPILED),true)
ifneq ($(findstring $(ARCH),x86 x86_64),)
Q3DOBJ += \
$(B)/ded/vm_x86.o
2006-06-06 18:09:09 +00:00
endif
ifneq ($(findstring $(ARCH),ppc ppc64),)
Q3DOBJ += $(B)/ded/vm_powerpc.o $(B)/ded/vm_powerpc_asm.o
2005-08-26 17:39:27 +00:00
endif
ifeq ($(ARCH),sparc)
Q3DOBJ += $(B)/ded/vm_sparc.o
endif
2014-10-23 11:00:17 +00:00
ifeq ($(ARCH),armv7l)
Q3DOBJ += $(B)/client/vm_armv7l.o
endif
2005-08-26 17:39:27 +00:00
endif
2015-01-30 21:52:53 +00:00
ifdef MINGW
Q3DOBJ += \
$(B)/ded/win_resource.o \
$(B)/ded/sys_win32.o \
$(B)/ded/con_win32.o
else
Q3DOBJ += \
$(B)/ded/sys_unix.o \
$(B)/ded/con_tty.o
endif
ifeq ($(PLATFORM),darwin)
Q3DOBJ += \
$(B)/ded/sys_osx.o
endif
$(B)/$(SERVERBIN)$(FULLBINEXT): $(Q3DOBJ)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CFLAGS) $(LDFLAGS) $(NOTSHLIBLDFLAGS) -o $@ $(Q3DOBJ) $(LIBS)
2005-08-26 17:39:27 +00:00
#############################################################################
## BASEQ3 CGAME
#############################################################################
Q3CGOBJ_ = \
$(B)/$(BASEGAME)/cgame/cg_main.o \
$(B)/$(BASEGAME)/cgame/bg_misc.o \
$(B)/$(BASEGAME)/cgame/bg_pmove.o \
$(B)/$(BASEGAME)/cgame/bg_slidemove.o \
$(B)/$(BASEGAME)/cgame/bg_lib.o \
$(B)/$(BASEGAME)/cgame/cg_consolecmds.o \
$(B)/$(BASEGAME)/cgame/cg_draw.o \
$(B)/$(BASEGAME)/cgame/cg_drawtools.o \
$(B)/$(BASEGAME)/cgame/cg_effects.o \
$(B)/$(BASEGAME)/cgame/cg_ents.o \
$(B)/$(BASEGAME)/cgame/cg_event.o \
$(B)/$(BASEGAME)/cgame/cg_info.o \
$(B)/$(BASEGAME)/cgame/cg_localents.o \
$(B)/$(BASEGAME)/cgame/cg_marks.o \
$(B)/$(BASEGAME)/cgame/cg_particles.o \
$(B)/$(BASEGAME)/cgame/cg_players.o \
$(B)/$(BASEGAME)/cgame/cg_playerstate.o \
$(B)/$(BASEGAME)/cgame/cg_predict.o \
$(B)/$(BASEGAME)/cgame/cg_scoreboard.o \
$(B)/$(BASEGAME)/cgame/cg_servercmds.o \
$(B)/$(BASEGAME)/cgame/cg_snapshot.o \
$(B)/$(BASEGAME)/cgame/cg_view.o \
$(B)/$(BASEGAME)/cgame/cg_weapons.o \
\
$(B)/$(BASEGAME)/qcommon/q_math.o \
$(B)/$(BASEGAME)/qcommon/q_shared.o
2005-08-26 17:39:27 +00:00
Q3CGOBJ = $(Q3CGOBJ_) $(B)/$(BASEGAME)/cgame/cg_syscalls.o
Q3CGVMOBJ = $(Q3CGOBJ_:%.o=%.asm)
$(B)/$(BASEGAME)/cgame$(SHLIBNAME): $(Q3CGOBJ)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(Q3CGOBJ)
2005-08-26 17:39:27 +00:00
$(B)/$(BASEGAME)/vm/cgame.qvm: $(Q3CGVMOBJ) $(CGDIR)/cg_syscalls.asm $(Q3ASM)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3ASM $@"
$(Q)$(Q3ASM) -o $@ $(Q3CGVMOBJ) $(CGDIR)/cg_syscalls.asm
2005-08-26 17:39:27 +00:00
#############################################################################
## MISSIONPACK CGAME
#############################################################################
MPCGOBJ_ = \
$(B)/$(MISSIONPACK)/cgame/cg_main.o \
$(B)/$(MISSIONPACK)/cgame/bg_misc.o \
$(B)/$(MISSIONPACK)/cgame/bg_pmove.o \
$(B)/$(MISSIONPACK)/cgame/bg_slidemove.o \
$(B)/$(MISSIONPACK)/cgame/bg_lib.o \
$(B)/$(MISSIONPACK)/cgame/cg_consolecmds.o \
$(B)/$(MISSIONPACK)/cgame/cg_newdraw.o \
$(B)/$(MISSIONPACK)/cgame/cg_draw.o \
$(B)/$(MISSIONPACK)/cgame/cg_drawtools.o \
$(B)/$(MISSIONPACK)/cgame/cg_effects.o \
$(B)/$(MISSIONPACK)/cgame/cg_ents.o \
$(B)/$(MISSIONPACK)/cgame/cg_event.o \
$(B)/$(MISSIONPACK)/cgame/cg_info.o \
$(B)/$(MISSIONPACK)/cgame/cg_localents.o \
$(B)/$(MISSIONPACK)/cgame/cg_marks.o \
$(B)/$(MISSIONPACK)/cgame/cg_particles.o \
$(B)/$(MISSIONPACK)/cgame/cg_players.o \
$(B)/$(MISSIONPACK)/cgame/cg_playerstate.o \
$(B)/$(MISSIONPACK)/cgame/cg_predict.o \
$(B)/$(MISSIONPACK)/cgame/cg_scoreboard.o \
$(B)/$(MISSIONPACK)/cgame/cg_servercmds.o \
$(B)/$(MISSIONPACK)/cgame/cg_snapshot.o \
$(B)/$(MISSIONPACK)/cgame/cg_view.o \
$(B)/$(MISSIONPACK)/cgame/cg_weapons.o \
$(B)/$(MISSIONPACK)/ui/ui_shared.o \
\
$(B)/$(MISSIONPACK)/qcommon/q_math.o \
$(B)/$(MISSIONPACK)/qcommon/q_shared.o
2005-08-26 17:39:27 +00:00
MPCGOBJ = $(MPCGOBJ_) $(B)/$(MISSIONPACK)/cgame/cg_syscalls.o
MPCGVMOBJ = $(MPCGOBJ_:%.o=%.asm)
$(B)/$(MISSIONPACK)/cgame$(SHLIBNAME): $(MPCGOBJ)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(MPCGOBJ)
2005-08-26 17:39:27 +00:00
$(B)/$(MISSIONPACK)/vm/cgame.qvm: $(MPCGVMOBJ) $(CGDIR)/cg_syscalls.asm $(Q3ASM)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3ASM $@"
$(Q)$(Q3ASM) -o $@ $(MPCGVMOBJ) $(CGDIR)/cg_syscalls.asm
2005-08-26 17:39:27 +00:00
#############################################################################
## BASEQ3 GAME
#############################################################################
Q3GOBJ_ = \
$(B)/$(BASEGAME)/game/g_main.o \
$(B)/$(BASEGAME)/game/ai_chat.o \
$(B)/$(BASEGAME)/game/ai_cmd.o \
$(B)/$(BASEGAME)/game/ai_dmnet.o \
$(B)/$(BASEGAME)/game/ai_dmq3.o \
$(B)/$(BASEGAME)/game/ai_main.o \
$(B)/$(BASEGAME)/game/ai_team.o \
$(B)/$(BASEGAME)/game/ai_vcmd.o \
$(B)/$(BASEGAME)/game/bg_misc.o \
$(B)/$(BASEGAME)/game/bg_pmove.o \
$(B)/$(BASEGAME)/game/bg_slidemove.o \
$(B)/$(BASEGAME)/game/bg_lib.o \
$(B)/$(BASEGAME)/game/g_active.o \
$(B)/$(BASEGAME)/game/g_arenas.o \
$(B)/$(BASEGAME)/game/g_bot.o \
$(B)/$(BASEGAME)/game/g_client.o \
$(B)/$(BASEGAME)/game/g_cmds.o \
$(B)/$(BASEGAME)/game/g_combat.o \
$(B)/$(BASEGAME)/game/g_items.o \
$(B)/$(BASEGAME)/game/g_mem.o \
$(B)/$(BASEGAME)/game/g_misc.o \
$(B)/$(BASEGAME)/game/g_missile.o \
$(B)/$(BASEGAME)/game/g_mover.o \
$(B)/$(BASEGAME)/game/g_session.o \
$(B)/$(BASEGAME)/game/g_spawn.o \
$(B)/$(BASEGAME)/game/g_svcmds.o \
$(B)/$(BASEGAME)/game/g_target.o \
$(B)/$(BASEGAME)/game/g_team.o \
$(B)/$(BASEGAME)/game/g_trigger.o \
$(B)/$(BASEGAME)/game/g_utils.o \
$(B)/$(BASEGAME)/game/g_weapon.o \
\
$(B)/$(BASEGAME)/qcommon/q_math.o \
$(B)/$(BASEGAME)/qcommon/q_shared.o
2005-08-26 17:39:27 +00:00
Q3GOBJ = $(Q3GOBJ_) $(B)/$(BASEGAME)/game/g_syscalls.o
Q3GVMOBJ = $(Q3GOBJ_:%.o=%.asm)
$(B)/$(BASEGAME)/qagame$(SHLIBNAME): $(Q3GOBJ)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(Q3GOBJ)
2005-08-26 17:39:27 +00:00
$(B)/$(BASEGAME)/vm/qagame.qvm: $(Q3GVMOBJ) $(GDIR)/g_syscalls.asm $(Q3ASM)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3ASM $@"
$(Q)$(Q3ASM) -o $@ $(Q3GVMOBJ) $(GDIR)/g_syscalls.asm
2005-08-26 17:39:27 +00:00
#############################################################################
## MISSIONPACK GAME
#############################################################################
MPGOBJ_ = \
$(B)/$(MISSIONPACK)/game/g_main.o \
$(B)/$(MISSIONPACK)/game/ai_chat.o \
$(B)/$(MISSIONPACK)/game/ai_cmd.o \
$(B)/$(MISSIONPACK)/game/ai_dmnet.o \
$(B)/$(MISSIONPACK)/game/ai_dmq3.o \
$(B)/$(MISSIONPACK)/game/ai_main.o \
$(B)/$(MISSIONPACK)/game/ai_team.o \
$(B)/$(MISSIONPACK)/game/ai_vcmd.o \
$(B)/$(MISSIONPACK)/game/bg_misc.o \
$(B)/$(MISSIONPACK)/game/bg_pmove.o \
$(B)/$(MISSIONPACK)/game/bg_slidemove.o \
$(B)/$(MISSIONPACK)/game/bg_lib.o \
$(B)/$(MISSIONPACK)/game/g_active.o \
$(B)/$(MISSIONPACK)/game/g_arenas.o \
$(B)/$(MISSIONPACK)/game/g_bot.o \
$(B)/$(MISSIONPACK)/game/g_client.o \
$(B)/$(MISSIONPACK)/game/g_cmds.o \
$(B)/$(MISSIONPACK)/game/g_combat.o \
$(B)/$(MISSIONPACK)/game/g_items.o \
$(B)/$(MISSIONPACK)/game/g_mem.o \
$(B)/$(MISSIONPACK)/game/g_misc.o \
$(B)/$(MISSIONPACK)/game/g_missile.o \
$(B)/$(MISSIONPACK)/game/g_mover.o \
$(B)/$(MISSIONPACK)/game/g_session.o \
$(B)/$(MISSIONPACK)/game/g_spawn.o \
$(B)/$(MISSIONPACK)/game/g_svcmds.o \
$(B)/$(MISSIONPACK)/game/g_target.o \
$(B)/$(MISSIONPACK)/game/g_team.o \
$(B)/$(MISSIONPACK)/game/g_trigger.o \
$(B)/$(MISSIONPACK)/game/g_utils.o \
$(B)/$(MISSIONPACK)/game/g_weapon.o \
\
$(B)/$(MISSIONPACK)/qcommon/q_math.o \
$(B)/$(MISSIONPACK)/qcommon/q_shared.o
2005-08-26 17:39:27 +00:00
MPGOBJ = $(MPGOBJ_) $(B)/$(MISSIONPACK)/game/g_syscalls.o
MPGVMOBJ = $(MPGOBJ_:%.o=%.asm)
$(B)/$(MISSIONPACK)/qagame$(SHLIBNAME): $(MPGOBJ)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(MPGOBJ)
2005-08-26 17:39:27 +00:00
$(B)/$(MISSIONPACK)/vm/qagame.qvm: $(MPGVMOBJ) $(GDIR)/g_syscalls.asm $(Q3ASM)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3ASM $@"
$(Q)$(Q3ASM) -o $@ $(MPGVMOBJ) $(GDIR)/g_syscalls.asm
2005-08-26 17:39:27 +00:00
#############################################################################
## BASEQ3 UI
#############################################################################
Q3UIOBJ_ = \
$(B)/$(BASEGAME)/ui/ui_main.o \
$(B)/$(BASEGAME)/ui/bg_misc.o \
$(B)/$(BASEGAME)/ui/bg_lib.o \
$(B)/$(BASEGAME)/ui/ui_addbots.o \
$(B)/$(BASEGAME)/ui/ui_atoms.o \
$(B)/$(BASEGAME)/ui/ui_cdkey.o \
$(B)/$(BASEGAME)/ui/ui_cinematics.o \
$(B)/$(BASEGAME)/ui/ui_confirm.o \
$(B)/$(BASEGAME)/ui/ui_connect.o \
$(B)/$(BASEGAME)/ui/ui_controls2.o \
$(B)/$(BASEGAME)/ui/ui_credits.o \
$(B)/$(BASEGAME)/ui/ui_demo2.o \
$(B)/$(BASEGAME)/ui/ui_display.o \
$(B)/$(BASEGAME)/ui/ui_gameinfo.o \
$(B)/$(BASEGAME)/ui/ui_ingame.o \
$(B)/$(BASEGAME)/ui/ui_loadconfig.o \
$(B)/$(BASEGAME)/ui/ui_menu.o \
$(B)/$(BASEGAME)/ui/ui_mfield.o \
$(B)/$(BASEGAME)/ui/ui_mods.o \
$(B)/$(BASEGAME)/ui/ui_network.o \
$(B)/$(BASEGAME)/ui/ui_options.o \
$(B)/$(BASEGAME)/ui/ui_playermodel.o \
$(B)/$(BASEGAME)/ui/ui_players.o \
$(B)/$(BASEGAME)/ui/ui_playersettings.o \
$(B)/$(BASEGAME)/ui/ui_preferences.o \
$(B)/$(BASEGAME)/ui/ui_qmenu.o \
$(B)/$(BASEGAME)/ui/ui_removebots.o \
$(B)/$(BASEGAME)/ui/ui_saveconfig.o \
$(B)/$(BASEGAME)/ui/ui_serverinfo.o \
$(B)/$(BASEGAME)/ui/ui_servers2.o \
$(B)/$(BASEGAME)/ui/ui_setup.o \
$(B)/$(BASEGAME)/ui/ui_sound.o \
$(B)/$(BASEGAME)/ui/ui_sparena.o \
$(B)/$(BASEGAME)/ui/ui_specifyserver.o \
$(B)/$(BASEGAME)/ui/ui_splevel.o \
$(B)/$(BASEGAME)/ui/ui_sppostgame.o \
$(B)/$(BASEGAME)/ui/ui_spskill.o \
$(B)/$(BASEGAME)/ui/ui_startserver.o \
$(B)/$(BASEGAME)/ui/ui_team.o \
$(B)/$(BASEGAME)/ui/ui_teamorders.o \
$(B)/$(BASEGAME)/ui/ui_video.o \
$(B)/$(BASEGAME)/ui/ui_controls3.o \
$(B)/$(BASEGAME)/ui/ui_comfort.o \
\
$(B)/$(BASEGAME)/qcommon/q_math.o \
$(B)/$(BASEGAME)/qcommon/q_shared.o
Q3UIOBJ = $(Q3UIOBJ_) $(B)/$(MISSIONPACK)/ui/ui_syscalls.o
Q3UIVMOBJ = $(Q3UIOBJ_:%.o=%.asm)
2005-08-26 17:39:27 +00:00
$(B)/$(BASEGAME)/ui$(SHLIBNAME): $(Q3UIOBJ)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(Q3UIOBJ)
2005-08-26 17:39:27 +00:00
$(B)/$(BASEGAME)/vm/ui.qvm: $(Q3UIVMOBJ) $(UIDIR)/ui_syscalls.asm $(Q3ASM)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3ASM $@"
$(Q)$(Q3ASM) -o $@ $(Q3UIVMOBJ) $(UIDIR)/ui_syscalls.asm
2005-08-26 17:39:27 +00:00
#############################################################################
## MISSIONPACK UI
#############################################################################
MPUIOBJ_ = \
$(B)/$(MISSIONPACK)/ui/ui_main.o \
$(B)/$(MISSIONPACK)/ui/ui_atoms.o \
$(B)/$(MISSIONPACK)/ui/ui_gameinfo.o \
$(B)/$(MISSIONPACK)/ui/ui_players.o \
$(B)/$(MISSIONPACK)/ui/ui_shared.o \
\
$(B)/$(MISSIONPACK)/ui/bg_misc.o \
$(B)/$(MISSIONPACK)/ui/bg_lib.o \
\
$(B)/$(MISSIONPACK)/qcommon/q_math.o \
$(B)/$(MISSIONPACK)/qcommon/q_shared.o
2005-08-26 17:39:27 +00:00
MPUIOBJ = $(MPUIOBJ_) $(B)/$(MISSIONPACK)/ui/ui_syscalls.o
MPUIVMOBJ = $(MPUIOBJ_:%.o=%.asm)
$(B)/$(MISSIONPACK)/ui$(SHLIBNAME): $(MPUIOBJ)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "LD $@"
$(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(MPUIOBJ)
2005-08-26 17:39:27 +00:00
$(B)/$(MISSIONPACK)/vm/ui.qvm: $(MPUIVMOBJ) $(UIDIR)/ui_syscalls.asm $(Q3ASM)
2007-08-27 07:02:54 +00:00
$(echo_cmd) "Q3ASM $@"
$(Q)$(Q3ASM) -o $@ $(MPUIVMOBJ) $(UIDIR)/ui_syscalls.asm
2005-08-26 17:39:27 +00:00
#############################################################################
## CLIENT/SERVER RULES
#############################################################################
$(B)/client/%.o: $(ASMDIR)/%.s
$(DO_AS)
# k8 so inline assembler knows about SSE
$(B)/client/%.o: $(ASMDIR)/%.c
$(DO_CC) -march=k8
$(B)/client/snd_altivec.o: $(CDIR)/snd_altivec.c
$(DO_CC_ALTIVEC)
$(B)/client/%.o: $(CDIR)/%.c
$(DO_CC)
$(B)/client/%.o: $(SDIR)/%.c
$(DO_CC)
$(B)/client/%.o: $(CMDIR)/%.c
$(DO_CC)
$(B)/client/%.o: $(BLIBDIR)/%.c
$(DO_BOT_CC)
2013-02-18 00:56:06 +00:00
$(B)/client/%.o: $(OGGDIR)/src/%.c
$(DO_CC)
2014-02-08 08:26:03 +00:00
$(B)/client/vorbis/%.o: $(VORBISDIR)/lib/%.c
$(DO_CC)
2013-02-18 00:32:05 +00:00
$(B)/client/opus/%.o: $(OPUSDIR)/src/%.c
$(DO_CC)
$(B)/client/opus/%.o: $(OPUSDIR)/celt/%.c
$(DO_CC)
$(B)/client/opus/%.o: $(OPUSDIR)/silk/%.c
$(DO_CC)
$(B)/client/opus/%.o: $(OPUSDIR)/silk/float/%.c
$(DO_CC)
$(B)/client/%.o: $(OPUSFILEDIR)/src/%.c
$(DO_CC)
2009-10-19 14:00:16 +00:00
$(B)/client/%.o: $(ZDIR)/%.c
$(DO_CC)
$(B)/client/%.o: $(SDLDIR)/%.c
$(DO_CC)
$(B)/client/%.o: $(ANDROIDDIR)/%.c
$(DO_CC)
2020-09-06 11:40:32 +00:00
$(B)/client/%.o: $(VRDIR)/%.c
$(DO_CC)
$(B)/client/%.o: $(SYSDIR)/%.c
$(DO_CC)
$(B)/client/%.o: $(SYSDIR)/%.m
$(DO_CC)
$(B)/client/win_resource.o: $(SYSDIR)/win_resource.rc $(SYSDIR)/win_manifest.xml
$(DO_WINDRES)
$(B)/renderergles3/%.o: $(JPDIR)/%.c
$(DO_REF_CC)
$(B)/renderergles3/%.o: $(SDLDIR)/%.c
$(DO_REF_CC)
$(B)/renderergles3/%.o: $(RCOMMONDIR)/%.c
$(DO_REF_CC)
$(B)/renderergles3/%.o: $(RGL2DIR)/%.c
2022-04-17 20:45:28 +00:00
$(DO_REF_CC_PRECISE)
$(B)/renderergles3/glsl/%.c: $(RGL2DIR)/glsl/%.glsl
$(DO_REF_STR)
$(B)/renderergles3/glsl/%.o: $(B)/renderergles3/glsl/%.c
$(DO_REF_CC)
$(B)/ded/%.o: $(ASMDIR)/%.s
$(DO_AS)
# k8 so inline assembler knows about SSE
$(B)/ded/%.o: $(ASMDIR)/%.c
$(DO_CC) -march=k8
$(B)/ded/%.o: $(SDIR)/%.c
$(DO_DED_CC)
$(B)/ded/%.o: $(CMDIR)/%.c
$(DO_DED_CC)
2009-10-19 14:00:16 +00:00
$(B)/ded/%.o: $(ZDIR)/%.c
$(DO_DED_CC)
$(B)/ded/%.o: $(BLIBDIR)/%.c
$(DO_BOT_CC)
$(B)/ded/%.o: $(SYSDIR)/%.c
$(DO_DED_CC)
$(B)/ded/%.o: $(SYSDIR)/%.m
$(DO_DED_CC)
$(B)/ded/win_resource.o: $(SYSDIR)/win_resource.rc $(SYSDIR)/win_manifest.xml
$(DO_WINDRES)
$(B)/ded/%.o: $(NDIR)/%.c
$(DO_DED_CC)
# Extra dependencies to ensure the git version is incorporated
ifeq ($(USE_GIT),1)
$(B)/client/cl_console.o : .git
$(B)/client/common.o : .git
$(B)/ded/common.o : .git
endif
#############################################################################
## GAME MODULE RULES
#############################################################################
$(B)/$(BASEGAME)/cgame/bg_%.o: $(GDIR)/bg_%.c
$(DO_CGAME_CC)
$(B)/$(BASEGAME)/cgame/%.o: $(CGDIR)/%.c
$(DO_CGAME_CC)
$(B)/$(BASEGAME)/cgame/bg_%.asm: $(GDIR)/bg_%.c $(Q3LCC)
$(DO_CGAME_Q3LCC)
$(B)/$(BASEGAME)/cgame/%.asm: $(CGDIR)/%.c $(Q3LCC)
$(DO_CGAME_Q3LCC)
$(B)/$(MISSIONPACK)/cgame/bg_%.o: $(GDIR)/bg_%.c
$(DO_CGAME_CC_MISSIONPACK)
$(B)/$(MISSIONPACK)/cgame/%.o: $(CGDIR)/%.c
$(DO_CGAME_CC_MISSIONPACK)
$(B)/$(MISSIONPACK)/cgame/bg_%.asm: $(GDIR)/bg_%.c $(Q3LCC)
$(DO_CGAME_Q3LCC_MISSIONPACK)
$(B)/$(MISSIONPACK)/cgame/%.asm: $(CGDIR)/%.c $(Q3LCC)
$(DO_CGAME_Q3LCC_MISSIONPACK)
$(B)/$(BASEGAME)/game/%.o: $(GDIR)/%.c
$(DO_GAME_CC)
$(B)/$(BASEGAME)/game/%.asm: $(GDIR)/%.c $(Q3LCC)
$(DO_GAME_Q3LCC)
$(B)/$(MISSIONPACK)/game/%.o: $(GDIR)/%.c
$(DO_GAME_CC_MISSIONPACK)
$(B)/$(MISSIONPACK)/game/%.asm: $(GDIR)/%.c $(Q3LCC)
$(DO_GAME_Q3LCC_MISSIONPACK)
$(B)/$(BASEGAME)/ui/bg_%.o: $(GDIR)/bg_%.c
$(DO_UI_CC)
$(B)/$(BASEGAME)/ui/%.o: $(Q3UIDIR)/%.c
$(DO_UI_CC)
$(B)/$(BASEGAME)/ui/bg_%.asm: $(GDIR)/bg_%.c $(Q3LCC)
$(DO_UI_Q3LCC)
$(B)/$(BASEGAME)/ui/%.asm: $(Q3UIDIR)/%.c $(Q3LCC)
$(DO_UI_Q3LCC)
$(B)/$(MISSIONPACK)/ui/bg_%.o: $(GDIR)/bg_%.c
$(DO_UI_CC_MISSIONPACK)
$(B)/$(MISSIONPACK)/ui/%.o: $(UIDIR)/%.c
$(DO_UI_CC_MISSIONPACK)
$(B)/$(MISSIONPACK)/ui/bg_%.asm: $(GDIR)/bg_%.c $(Q3LCC)
$(DO_UI_Q3LCC_MISSIONPACK)
$(B)/$(MISSIONPACK)/ui/%.asm: $(UIDIR)/%.c $(Q3LCC)
$(DO_UI_Q3LCC_MISSIONPACK)
$(B)/$(BASEGAME)/qcommon/%.o: $(CMDIR)/%.c
$(DO_SHLIB_CC)
$(B)/$(BASEGAME)/qcommon/%.asm: $(CMDIR)/%.c $(Q3LCC)
$(DO_Q3LCC)
$(B)/$(MISSIONPACK)/qcommon/%.o: $(CMDIR)/%.c
$(DO_SHLIB_CC_MISSIONPACK)
$(B)/$(MISSIONPACK)/qcommon/%.asm: $(CMDIR)/%.c $(Q3LCC)
$(DO_Q3LCC_MISSIONPACK)
2005-08-26 17:39:27 +00:00
#############################################################################
# MISC
#############################################################################
2013-01-24 22:53:08 +00:00
OBJ = $(Q3OBJ) $(Q3ROBJ) $(Q3R2OBJ) $(Q3DOBJ) $(JPGOBJ) \
$(MPGOBJ) $(Q3GOBJ) $(Q3CGOBJ) $(MPCGOBJ) $(Q3UIOBJ) $(MPUIOBJ) \
$(MPGVMOBJ) $(Q3GVMOBJ) $(Q3CGVMOBJ) $(MPCGVMOBJ) $(Q3UIVMOBJ) $(MPUIVMOBJ)
TOOLSOBJ = $(LBURGOBJ) $(Q3CPPOBJ) $(Q3RCCOBJ) $(Q3LCCOBJ) $(Q3ASMOBJ)
STRINGOBJ = $(Q3R2STRINGOBJ)
copyfiles: release
@if [ ! -d $(COPYDIR)/$(BASEGAME) ]; then echo "You need to set COPYDIR to where your Quake3 data is!"; fi
ifneq ($(BUILD_GAME_SO),0)
ifneq ($(BUILD_BASEGAME),0)
-$(MKDIR) -m 0755 $(COPYDIR)/$(BASEGAME)
endif
ifneq ($(BUILD_MISSIONPACK),0)
-$(MKDIR) -m 0755 $(COPYDIR)/$(MISSIONPACK)
endif
endif
ifneq ($(BUILD_CLIENT),0)
ifneq ($(USE_RENDERER_DLOPEN),0)
ifneq ($(BUILD_RENDERER_OPENGL2),0)
2020-09-06 11:40:32 +00:00
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(LIBPREFIX)renderer_opengl2_$(SHLIBNAME) $(COPYBINDIR)/$(LIBPREFIX)renderer_opengl2_$(SHLIBNAME)
endif
else
ifneq ($(BUILD_RENDERER_OPENGL2),0)
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(CLIENTBIN)_opengl2$(FULLBINEXT) $(COPYBINDIR)/$(CLIENTBIN)_opengl2$(FULLBINEXT)
endif
endif
endif
2005-12-13 02:35:00 +00:00
ifneq ($(BUILD_SERVER),0)
@if [ -f $(BR)/$(SERVERBIN)$(FULLBINEXT) ]; then \
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(SERVERBIN)$(FULLBINEXT) $(COPYBINDIR)/$(SERVERBIN)$(FULLBINEXT); \
fi
endif
ifneq ($(BUILD_GAME_SO),0)
ifneq ($(BUILD_BASEGAME),0)
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(BASEGAME)/cgame$(SHLIBNAME) \
$(COPYDIR)/$(BASEGAME)/.
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(BASEGAME)/qagame$(SHLIBNAME) \
$(COPYDIR)/$(BASEGAME)/.
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(BASEGAME)/ui$(SHLIBNAME) \
$(COPYDIR)/$(BASEGAME)/.
endif
ifneq ($(BUILD_MISSIONPACK),0)
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(MISSIONPACK)/cgame$(SHLIBNAME) \
$(COPYDIR)/$(MISSIONPACK)/.
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(MISSIONPACK)/qagame$(SHLIBNAME) \
$(COPYDIR)/$(MISSIONPACK)/.
$(INSTALL) $(STRIP_FLAG) -m 0755 $(BR)/$(MISSIONPACK)/ui$(SHLIBNAME) \
$(COPYDIR)/$(MISSIONPACK)/.
endif
endif
clean: clean-debug clean-release
2008-04-15 14:19:03 +00:00
ifeq ($(PLATFORM),mingw32)
@$(MAKE) -C $(NSISDIR) clean
else
2007-07-15 12:08:11 +00:00
@$(MAKE) -C $(LOKISETUPDIR) clean
2008-04-15 14:19:03 +00:00
endif
2005-08-26 17:39:27 +00:00
clean-debug:
@$(MAKE) clean2 B=$(BD)
2005-08-26 17:39:27 +00:00
clean-release:
@$(MAKE) clean2 B=$(BR)
2005-08-26 17:39:27 +00:00
clean2:
@echo "CLEAN $(B)"
@rm -f $(OBJ)
@rm -f $(OBJ_D_FILES)
@rm -f $(STRINGOBJ)
@rm -f $(TARGETS)
toolsclean: toolsclean-debug toolsclean-release
toolsclean-debug:
@$(MAKE) toolsclean2 B=$(BD)
toolsclean-release:
@$(MAKE) toolsclean2 B=$(BR)
toolsclean2:
@echo "TOOLS_CLEAN $(B)"
@rm -f $(TOOLSOBJ)
@rm -f $(TOOLSOBJ_D_FILES)
@rm -f $(LBURG) $(DAGCHECK_C) $(Q3RCC) $(Q3CPP) $(Q3LCC) $(Q3ASM)
distclean: clean toolsclean
2007-07-15 12:08:11 +00:00
@rm -rf $(BUILD_DIR)
installer: release
2015-01-30 21:52:53 +00:00
ifdef MINGW
@$(MAKE) VERSION=$(VERSION) -C $(NSISDIR) V=$(V) \
2012-02-07 09:29:13 +00:00
SDLDLL=$(SDLDLL) \
USE_RENDERER_DLOPEN=$(USE_RENDERER_DLOPEN) \
USE_OPENAL_DLOPEN=$(USE_OPENAL_DLOPEN) \
USE_CURL_DLOPEN=$(USE_CURL_DLOPEN) \
2013-02-18 00:32:05 +00:00
USE_INTERNAL_OPUS=$(USE_INTERNAL_OPUS) \
USE_INTERNAL_ZLIB=$(USE_INTERNAL_ZLIB) \
USE_INTERNAL_JPEG=$(USE_INTERNAL_JPEG)
2008-04-15 14:19:03 +00:00
else
2007-08-27 07:02:54 +00:00
@$(MAKE) VERSION=$(VERSION) -C $(LOKISETUPDIR) V=$(V)
2008-04-15 14:19:03 +00:00
endif
dist:
git archive --format zip --output $(CLIENTBIN)-$(VERSION).zip HEAD
#############################################################################
# DEPENDENCIES
#############################################################################
ifneq ($(B),)
OBJ_D_FILES=$(filter %.d,$(OBJ:%.o=%.d))
TOOLSOBJ_D_FILES=$(filter %.d,$(TOOLSOBJ:%.o=%.d))
-include $(OBJ_D_FILES) $(TOOLSOBJ_D_FILES)
endif
.PHONY: all clean clean2 clean-debug clean-release copyfiles \
debug default dist distclean installer makedirs \
release targets \
toolsclean toolsclean2 toolsclean-debug toolsclean-release \
$(OBJ_D_FILES) $(TOOLSOBJ_D_FILES)
2013-03-26 20:58:55 +00:00
# If the target name contains "clean", don't do a parallel build
ifneq ($(findstring clean, $(MAKECMDGOALS)),)
.NOTPARALLEL:
endif