Makefile 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. #**************************************************************************************************
  2. #
  3. # raylib makefile for Desktop platforms, Raspberry Pi, Android and HTML5
  4. #
  5. # Copyright (c) 2013-2024 Ramon Santamaria (@raysan5)
  6. #
  7. # This software is provided "as-is", without any express or implied warranty. In no event
  8. # will the authors be held liable for any damages arising from the use of this software.
  9. #
  10. # Permission is granted to anyone to use this software for any purpose, including commercial
  11. # applications, and to alter it and redistribute it freely, subject to the following restrictions:
  12. #
  13. # 1. The origin of this software must not be misrepresented; you must not claim that you
  14. # wrote the original software. If you use this software in a product, an acknowledgment
  15. # in the product documentation would be appreciated but is not required.
  16. #
  17. # 2. Altered source versions must be plainly marked as such, and must not be misrepresented
  18. # as being the original software.
  19. #
  20. # 3. This notice may not be removed or altered from any source distribution.
  21. #
  22. #**************************************************************************************************
  23. .PHONY: all clean
  24. # Define required raylib variables
  25. PROJECT_NAME ?= game
  26. RAYLIB_VERSION ?= 4.2.0
  27. RAYLIB_PATH ?= ..\..
  28. # Define default options
  29. # One of PLATFORM_DESKTOP, PLATFORM_RPI, PLATFORM_ANDROID, PLATFORM_WEB
  30. PLATFORM ?= PLATFORM_DESKTOP
  31. # Locations of your newly installed library and associated headers. See ../src/Makefile
  32. # On Linux, if you have installed raylib but cannot compile the examples, check that
  33. # the *_INSTALL_PATH values here are the same as those in src/Makefile or point to known locations.
  34. # To enable system-wide compile-time and runtime linking to libraylib.so, run ../src/$ sudo make install RAYLIB_LIBTYPE_SHARED.
  35. # To enable compile-time linking to a special version of libraylib.so, change these variables here.
  36. # To enable runtime linking to a special version of libraylib.so, see EXAMPLE_RUNTIME_PATH below.
  37. # If there is a libraylib in both EXAMPLE_RUNTIME_PATH and RAYLIB_INSTALL_PATH, at runtime,
  38. # the library at EXAMPLE_RUNTIME_PATH, if present, will take precedence over the one at RAYLIB_INSTALL_PATH.
  39. # RAYLIB_INSTALL_PATH should be the desired full path to libraylib. No relative paths.
  40. DESTDIR ?= /usr/local
  41. RAYLIB_INSTALL_PATH ?= $(DESTDIR)/lib
  42. # RAYLIB_H_INSTALL_PATH locates the installed raylib header and associated source files.
  43. RAYLIB_H_INSTALL_PATH ?= $(DESTDIR)/include
  44. # Library type used for raylib: STATIC (.a) or SHARED (.so/.dll)
  45. RAYLIB_LIBTYPE ?= STATIC
  46. # Build mode for project: DEBUG or RELEASE
  47. BUILD_MODE ?= RELEASE
  48. # Use external GLFW library instead of rglfw module
  49. # TODO: Review usage on Linux. Target version of choice. Switch on -lglfw or -lglfw3
  50. USE_EXTERNAL_GLFW ?= FALSE
  51. # Use Wayland display server protocol on Linux desktop
  52. # by default it uses X11 windowing system
  53. USE_WAYLAND_DISPLAY ?= FALSE
  54. # Determine PLATFORM_OS in case PLATFORM_DESKTOP selected
  55. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  56. # No uname.exe on MinGW!, but OS=Windows_NT on Windows!
  57. # ifeq ($(UNAME),Msys) -> Windows
  58. ifeq ($(OS),Windows_NT)
  59. PLATFORM_OS=WINDOWS
  60. else
  61. UNAMEOS=$(shell uname)
  62. ifeq ($(UNAMEOS),Linux)
  63. PLATFORM_OS=LINUX
  64. endif
  65. ifeq ($(UNAMEOS),FreeBSD)
  66. PLATFORM_OS=BSD
  67. endif
  68. ifeq ($(UNAMEOS),OpenBSD)
  69. PLATFORM_OS=BSD
  70. endif
  71. ifeq ($(UNAMEOS),NetBSD)
  72. PLATFORM_OS=BSD
  73. endif
  74. ifeq ($(UNAMEOS),DragonFly)
  75. PLATFORM_OS=BSD
  76. endif
  77. ifeq ($(UNAMEOS),Darwin)
  78. PLATFORM_OS=OSX
  79. endif
  80. endif
  81. endif
  82. ifeq ($(PLATFORM),PLATFORM_RPI)
  83. UNAMEOS=$(shell uname)
  84. ifeq ($(UNAMEOS),Linux)
  85. PLATFORM_OS=LINUX
  86. endif
  87. endif
  88. # RAYLIB_PATH adjustment for different platforms.
  89. # If using GNU make, we can get the full path to the top of the tree. Windows? BSD?
  90. # Required for ldconfig or other tools that do not perform path expansion.
  91. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  92. ifeq ($(PLATFORM_OS),LINUX)
  93. RAYLIB_PREFIX ?= ..
  94. RAYLIB_PATH = $(realpath $(RAYLIB_PREFIX))
  95. endif
  96. endif
  97. # Default path for raylib on Raspberry Pi, if installed in different path, update it!
  98. # This is not currently used by src/Makefile. Not sure of its origin or usage. Refer to wiki.
  99. # TODO: update install: target in src/Makefile for RPI, consider relation to LINUX.
  100. ifeq ($(PLATFORM),PLATFORM_RPI)
  101. RAYLIB_PATH ?= /home/pi/raylib
  102. endif
  103. ifeq ($(PLATFORM),PLATFORM_WEB)
  104. # Emscripten required variables
  105. EMSDK_PATH ?= C:/raylib/emsdk
  106. EMSCRIPTEN_PATH ?= $(EMSDK_PATH)/upstream/emscripten
  107. CLANG_PATH = $(EMSDK_PATH)/upstream/bin
  108. PYTHON_PATH = $(EMSDK_PATH)/python/3.9.2-nuget_64bit
  109. NODE_PATH = $(EMSDK_PATH)/node/20.18.0_64bit/bin
  110. export PATH = $(EMSDK_PATH);$(EMSCRIPTEN_PATH);$(CLANG_PATH);$(NODE_PATH);$(PYTHON_PATH);C:\raylib\MinGW\bin:$$(PATH)
  111. endif
  112. # Define raylib release directory for compiled library.
  113. # RAYLIB_RELEASE_PATH points to provided binaries or your freshly built version
  114. RAYLIB_RELEASE_PATH ?= $(RAYLIB_PATH)/src
  115. # EXAMPLE_RUNTIME_PATH embeds a custom runtime location of libraylib.so or other desired libraries
  116. # into each example binary compiled with RAYLIB_LIBTYPE=SHARED. It defaults to RAYLIB_RELEASE_PATH
  117. # so that these examples link at runtime with your version of libraylib.so in ../release/libs/linux
  118. # without formal installation from ../src/Makefile. It aids portability and is useful if you have
  119. # multiple versions of raylib, have raylib installed to a non-standard location, or want to
  120. # bundle libraylib.so with your game. Change it to your liking.
  121. # NOTE: If, at runtime, there is a libraylib.so at both EXAMPLE_RUNTIME_PATH and RAYLIB_INSTALL_PATH,
  122. # The library at EXAMPLE_RUNTIME_PATH, if present, will take precedence over RAYLIB_INSTALL_PATH,
  123. # Implemented for LINUX below with CFLAGS += -Wl,-rpath,$(EXAMPLE_RUNTIME_PATH)
  124. # To see the result, run readelf -d core/core_basic_window; looking at the RPATH or RUNPATH attribute.
  125. # To see which libraries a built example is linking to, ldd core/core_basic_window;
  126. # Look for libraylib.so.1 => $(RAYLIB_INSTALL_PATH)/libraylib.so.1 or similar listing.
  127. EXAMPLE_RUNTIME_PATH ?= $(RAYLIB_RELEASE_PATH)
  128. # Define default C compiler: gcc
  129. # NOTE: define g++ compiler if using C++
  130. CC = gcc
  131. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  132. ifeq ($(PLATFORM_OS),OSX)
  133. # OSX default compiler
  134. CC = clang
  135. endif
  136. ifeq ($(PLATFORM_OS),BSD)
  137. # FreeBSD, OpenBSD, NetBSD, DragonFly default compiler
  138. CC = clang
  139. endif
  140. endif
  141. ifeq ($(PLATFORM),PLATFORM_RPI)
  142. ifeq ($(USE_RPI_CROSS_COMPILER),TRUE)
  143. # Define RPI cross-compiler
  144. #CC = armv6j-hardfloat-linux-gnueabi-gcc
  145. CC = $(RPI_TOOLCHAIN)/bin/arm-linux-gnueabihf-gcc
  146. endif
  147. endif
  148. ifeq ($(PLATFORM),PLATFORM_WEB)
  149. # HTML5 emscripten compiler
  150. # WARNING: To compile to HTML5, code must be redesigned
  151. # to use emscripten.h and emscripten_set_main_loop()
  152. CC = emcc
  153. endif
  154. # Define default make program: Mingw32-make
  155. MAKE = mingw32-make
  156. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  157. ifeq ($(PLATFORM_OS),LINUX)
  158. MAKE = make
  159. endif
  160. ifeq ($(PLATFORM_OS),OSX)
  161. MAKE = make
  162. endif
  163. endif
  164. # Define compiler flags:
  165. # -O1 defines optimization level
  166. # -g include debug information on compilation
  167. # -s strip unnecessary data from build
  168. # -Wall turns on most, but not all, compiler warnings
  169. # -std=c99 defines C language mode (standard C from 1999 revision)
  170. # -std=gnu99 defines C language mode (GNU C from 1999 revision)
  171. # -Wno-missing-braces ignore invalid warning (GCC bug 53119)
  172. # -D_DEFAULT_SOURCE use with -std=c99 on Linux and PLATFORM_WEB, required for timespec
  173. CFLAGS += -O1 -s -Wall -std=c99 -D_DEFAULT_SOURCE -Wno-missing-braces
  174. ifeq ($(BUILD_MODE),DEBUG)
  175. CFLAGS += -g
  176. endif
  177. # Additional flags for compiler (if desired)
  178. #CFLAGS += -Wextra -Wmissing-prototypes -Wstrict-prototypes
  179. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  180. ifeq ($(PLATFORM_OS),WINDOWS)
  181. # resource file contains windows executable icon and properties
  182. # -Wl,--subsystem,windows hides the console window
  183. CFLAGS += $(RAYLIB_PATH)/src/raylib.rc.data -Wl,--subsystem,windows
  184. endif
  185. ifeq ($(PLATFORM_OS),LINUX)
  186. ifeq ($(RAYLIB_LIBTYPE),STATIC)
  187. CFLAGS += -D_DEFAULT_SOURCE
  188. endif
  189. ifeq ($(RAYLIB_LIBTYPE),SHARED)
  190. # Explicitly enable runtime link to libraylib.so
  191. CFLAGS += -Wl,-rpath,$(EXAMPLE_RUNTIME_PATH)
  192. endif
  193. endif
  194. endif
  195. ifeq ($(PLATFORM),PLATFORM_RPI)
  196. CFLAGS += -std=gnu99
  197. endif
  198. ifeq ($(PLATFORM),PLATFORM_WEB)
  199. # -Os # size optimization
  200. # -O2 # optimization level 2, if used, also set --memory-init-file 0
  201. # -sUSE_GLFW=3 # Use glfw3 library (context/input management)
  202. # -sALLOW_MEMORY_GROWTH=1 # to allow memory resizing -> WARNING: Audio buffers could FAIL!
  203. # -sTOTAL_MEMORY=16777216 # to specify heap memory size (default = 16MB) (67108864 = 64MB)
  204. # -sUSE_PTHREADS=1 # multithreading support
  205. # -sWASM=0 # disable Web Assembly, emitted by default
  206. # -sASYNCIFY # lets synchronous C/C++ code interact with asynchronous JS
  207. # -sFORCE_FILESYSTEM=1 # force filesystem to load/save files data
  208. # -sASSERTIONS=1 # enable runtime checks for common memory allocation errors (-O1 and above turn it off)
  209. # -sMINIFY_HTML=0 # minify generated html from shell.html
  210. # --profiling # include information for code profiling
  211. # --memory-init-file 0 # to avoid an external memory initialization code file (.mem)
  212. # --preload-file resources # specify a resources folder for data compilation
  213. # --source-map-base # allow debugging in browser with source map
  214. # --shell-file shell.html # define a custom shell .html and output extension
  215. CFLAGS += -Os -sUSE_GLFW=3 -sTOTAL_MEMORY=16777216 --preload-file resources -sMINIFY_HTML=0
  216. ifeq ($(BUILD_MODE), DEBUG)
  217. CFLAGS += -sASSERTIONS=1 --profiling
  218. endif
  219. # Define a custom shell .html and output extension
  220. CFLAGS += --shell-file $(RAYLIB_PATH)/src/shell.html
  221. EXT = .html
  222. endif
  223. # Define include paths for required headers
  224. # NOTE: Several external required libraries (stb and others)
  225. INCLUDE_PATHS = -I. -I$(RAYLIB_PATH)/src -I$(RAYLIB_PATH)/src/external
  226. # Define additional directories containing required header files
  227. ifeq ($(PLATFORM),PLATFORM_RPI)
  228. # RPI required libraries
  229. INCLUDE_PATHS += -I/opt/vc/include
  230. INCLUDE_PATHS += -I/opt/vc/include/interface/vmcs_host/linux
  231. INCLUDE_PATHS += -I/opt/vc/include/interface/vcos/pthreads
  232. endif
  233. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  234. ifeq ($(PLATFORM_OS),BSD)
  235. # Consider -L$(RAYLIB_H_INSTALL_PATH)
  236. INCLUDE_PATHS += -I/usr/local/include
  237. endif
  238. ifeq ($(PLATFORM_OS),LINUX)
  239. # Reset everything.
  240. # Precedence: immediately local, installed version, raysan5 provided libs -I$(RAYLIB_H_INSTALL_PATH) -I$(RAYLIB_PATH)/release/include
  241. INCLUDE_PATHS = -I$(RAYLIB_H_INSTALL_PATH) -isystem. -isystem$(RAYLIB_PATH)/src -isystem$(RAYLIB_PATH)/release/include -isystem$(RAYLIB_PATH)/src/external
  242. endif
  243. endif
  244. # Define library paths containing required libs.
  245. LDFLAGS = -L. -L$(RAYLIB_RELEASE_PATH) -L$(RAYLIB_PATH)/src
  246. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  247. ifeq ($(PLATFORM_OS),BSD)
  248. # Consider -L$(RAYLIB_INSTALL_PATH)
  249. LDFLAGS += -L. -Lsrc -L/usr/local/lib
  250. endif
  251. ifeq ($(PLATFORM_OS),LINUX)
  252. # Reset everything.
  253. # Precedence: immediately local, installed version, raysan5 provided libs
  254. LDFLAGS = -L. -L$(RAYLIB_INSTALL_PATH) -L$(RAYLIB_RELEASE_PATH)
  255. endif
  256. endif
  257. ifeq ($(PLATFORM),PLATFORM_RPI)
  258. LDFLAGS += -L/opt/vc/lib
  259. endif
  260. # Define any libraries required on linking
  261. # if you want to link libraries (libname.so or libname.a), use the -lname
  262. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  263. ifeq ($(PLATFORM_OS),WINDOWS)
  264. # Libraries for Windows desktop compilation
  265. # NOTE: WinMM library required to set high-res timer resolution
  266. LDLIBS = -lraylib -lopengl32 -lgdi32 -lwinmm
  267. endif
  268. ifeq ($(PLATFORM_OS),LINUX)
  269. # Libraries for Debian GNU/Linux desktop compiling
  270. # NOTE: Required packages: libegl1-mesa-dev
  271. LDLIBS = -lraylib -lGL -lm -lpthread -ldl -lrt
  272. # On X11 requires also below libraries
  273. LDLIBS += -lX11
  274. # NOTE: It seems additional libraries are not required any more, latest GLFW just dlopen them
  275. #LDLIBS += -lXrandr -lXinerama -lXi -lXxf86vm -lXcursor
  276. # On Wayland windowing system, additional libraries requires
  277. ifeq ($(USE_WAYLAND_DISPLAY),TRUE)
  278. LDLIBS += -lwayland-client -lwayland-cursor -lwayland-egl -lxkbcommon
  279. endif
  280. # Explicit link to libc
  281. ifeq ($(RAYLIB_LIBTYPE),SHARED)
  282. LDLIBS += -lc
  283. endif
  284. endif
  285. ifeq ($(PLATFORM_OS),OSX)
  286. # Libraries for OSX 10.9 desktop compiling
  287. # NOTE: Required packages: libopenal-dev libegl1-mesa-dev
  288. LDLIBS = -lraylib -framework OpenGL -framework OpenAL -framework Cocoa
  289. endif
  290. ifeq ($(PLATFORM_OS),BSD)
  291. # Libraries for FreeBSD, OpenBSD, NetBSD, DragonFly desktop compiling
  292. # NOTE: Required packages: mesa-libs
  293. LDLIBS = -lraylib -lGL -lpthread -lm
  294. # On XWindow requires also below libraries
  295. LDLIBS += -lX11 -lXrandr -lXinerama -lXi -lXxf86vm -lXcursor
  296. endif
  297. ifeq ($(USE_EXTERNAL_GLFW),TRUE)
  298. # NOTE: It could require additional packages installed: libglfw3-dev
  299. LDLIBS += -lglfw
  300. endif
  301. endif
  302. ifeq ($(PLATFORM),PLATFORM_RPI)
  303. # Libraries for Raspberry Pi compiling
  304. # NOTE: Required packages: libasound2-dev (ALSA)
  305. LDLIBS = -lraylib -lbrcmGLESv2 -lbrcmEGL -lpthread -lrt -lm -lbcm_host -ldl
  306. endif
  307. ifeq ($(PLATFORM),PLATFORM_WEB)
  308. # Libraries for web (HTML5) compiling
  309. LDLIBS = $(RAYLIB_RELEASE_PATH)/libraylib.bc
  310. endif
  311. # Define a recursive wildcard function
  312. rwildcard=$(foreach d,$(wildcard $1*),$(call rwildcard,$d/,$2) $(filter $(subst *,%,$2),$d))
  313. # Define all source files required
  314. SRC_DIR = src
  315. OBJ_DIR = obj
  316. # Define all object files from source files
  317. SRC = $(call rwildcard, *.c, *.h)
  318. #OBJS = $(SRC:$(SRC_DIR)/%.c=$(OBJ_DIR)/%.o)
  319. OBJS = main.c
  320. # For Android platform we call a custom Makefile.Android
  321. ifeq ($(PLATFORM),PLATFORM_ANDROID)
  322. MAKEFILE_PARAMS = -f Makefile.Android
  323. export PROJECT_NAME
  324. export SRC_DIR
  325. else
  326. MAKEFILE_PARAMS = $(PROJECT_NAME)
  327. endif
  328. # Default target entry
  329. # NOTE: We call this Makefile target or Makefile.Android target
  330. all:
  331. $(MAKE) $(MAKEFILE_PARAMS)
  332. # Project target defined by PROJECT_NAME
  333. $(PROJECT_NAME): $(OBJS)
  334. $(CC) -o $(PROJECT_NAME)$(EXT) $(OBJS) $(CFLAGS) $(INCLUDE_PATHS) $(LDFLAGS) $(LDLIBS) -D$(PLATFORM)
  335. # Compile source files
  336. # NOTE: This pattern will compile every module defined on $(OBJS)
  337. #%.o: %.c
  338. $(OBJ_DIR)/%.o: $(SRC_DIR)/%.c
  339. $(CC) -c $< -o $@ $(CFLAGS) $(INCLUDE_PATHS) -D$(PLATFORM)
  340. # Clean everything
  341. clean:
  342. ifeq ($(PLATFORM),PLATFORM_DESKTOP)
  343. ifeq ($(PLATFORM_OS),WINDOWS)
  344. del *.o *.exe /s
  345. endif
  346. ifeq ($(PLATFORM_OS),LINUX)
  347. find -type f -executable | xargs file -i | grep -E 'x-object|x-archive|x-sharedlib|x-executable' | rev | cut -d ':' -f 2- | rev | xargs rm -fv
  348. endif
  349. ifeq ($(PLATFORM_OS),OSX)
  350. find . -type f -perm +ugo+x -delete
  351. rm -f *.o
  352. endif
  353. endif
  354. ifeq ($(PLATFORM),PLATFORM_RPI)
  355. find . -type f -executable -delete
  356. rm -fv *.o
  357. endif
  358. ifeq ($(PLATFORM),PLATFORM_WEB)
  359. del *.o *.html *.js
  360. endif
  361. @echo Cleaning done