mirror of
				https://github.com/raysan5/raylib.git
				synced 2025-10-25 20:06:58 +00:00 
			
		
		
		
	Merge pull request #417 from a3f/develop
Add library versioning to Make/CMake build systems
This commit is contained in:
		
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -110,9 +110,6 @@ docs/examples/web/*/*.html | |||||||
| !docs/examples/web/shaders/loader.html | !docs/examples/web/shaders/loader.html | ||||||
| !docs/examples/web/models/loader.html | !docs/examples/web/models/loader.html | ||||||
|  |  | ||||||
| # Meson build system |  | ||||||
| builddir/ |  | ||||||
|  |  | ||||||
| # CMake stuff | # CMake stuff | ||||||
| CMakeCache.txt | CMakeCache.txt | ||||||
| CMakeFiles | CMakeFiles | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								meson.build
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								meson.build
									
									
									
									
									
								
							| @@ -1,15 +0,0 @@ | |||||||
| project('raylib', 'c', version:	'1.8.0', |  | ||||||
| 		license: 'zlib', |  | ||||||
| 		meson_version: '>= 0.39.1', |  | ||||||
| 		default_options : 'c_std=gnu99') |  | ||||||
|  |  | ||||||
| cc = meson.get_compiler('c') |  | ||||||
|  |  | ||||||
| glfw_dep = dependency('glfw3', version : '>=3.2') |  | ||||||
| gl_dep = dependency('gl') |  | ||||||
| openal_dep = dependency('openal') |  | ||||||
| x11_dep = dependency('x11') |  | ||||||
| m_dep = cc.find_library('m', required : false) |  | ||||||
|  |  | ||||||
| subdir('src') |  | ||||||
|  |  | ||||||
| @@ -2,7 +2,8 @@ | |||||||
| project(raylib) | project(raylib) | ||||||
| include("../utils.cmake") | include("../utils.cmake") | ||||||
|  |  | ||||||
| set(PROJECT_VERSION 1.9.1-dev) | set(PROJECT_VERSION 1.9.2) | ||||||
|  | set(API_VERSION 1) | ||||||
| set(RAYLIB raylib)    # Name of the generated library | set(RAYLIB raylib)    # Name of the generated library | ||||||
|  |  | ||||||
| ### Config options ### | ### Config options ### | ||||||
| @@ -123,7 +124,11 @@ if(${PLATFORM} MATCHES "PLATFORM_DESKTOP") | |||||||
|     set(CMAKE_MACOSX_RPATH ON) |     set(CMAKE_MACOSX_RPATH ON) | ||||||
|  |  | ||||||
|     target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) |     target_link_libraries(${RAYLIB}_shared ${LIBS_PRIVATE}) | ||||||
|     set_target_properties(${RAYLIB}_shared PROPERTIES PUBLIC_HEADER "raylib.h") |     set_target_properties(${RAYLIB}_shared PROPERTIES | ||||||
|  |         VERSION   ${PROJECT_VERSION} | ||||||
|  |         SOVERSION ${API_VERSION} | ||||||
|  |         PUBLIC_HEADER "raylib.h" | ||||||
|  |     ) | ||||||
|     if(WIN32) |     if(WIN32) | ||||||
|       install( |       install( | ||||||
|         TARGETS ${RAYLIB}_shared |         TARGETS ${RAYLIB}_shared | ||||||
|   | |||||||
							
								
								
									
										39
									
								
								src/Makefile
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								src/Makefile
									
									
									
									
									
								
							| @@ -42,6 +42,8 @@ | |||||||
| .PHONY: all clean install uninstall | .PHONY: all clean install uninstall | ||||||
|  |  | ||||||
| # Define required raylib variables | # Define required raylib variables | ||||||
|  | VERSION     = 1.9.2 | ||||||
|  | API_VERSION = 1 | ||||||
| PLATFORM ?= PLATFORM_DESKTOP | PLATFORM ?= PLATFORM_DESKTOP | ||||||
| RAYLIB_PATH = .. | RAYLIB_PATH = .. | ||||||
|  |  | ||||||
| @@ -172,6 +174,7 @@ ifeq ($(PLATFORM),PLATFORM_DESKTOP) | |||||||
|     ifeq ($(PLATFORM_OS),OSX) |     ifeq ($(PLATFORM_OS),OSX) | ||||||
|         # OSX default compiler |         # OSX default compiler | ||||||
|         CC = clang |         CC = clang | ||||||
|  |         GLFW_CFLAGS = -x objective-c | ||||||
|     endif |     endif | ||||||
|     ifeq ($(PLATFORM_OS),FREEBSD) |     ifeq ($(PLATFORM_OS),FREEBSD) | ||||||
|         # FreeBSD default compiler |         # FreeBSD default compiler | ||||||
| @@ -291,7 +294,7 @@ endif | |||||||
|  |  | ||||||
| # Define linker options | # Define linker options | ||||||
| ifeq ($(PLATFORM),PLATFORM_ANDROID) | ifeq ($(PLATFORM),PLATFORM_ANDROID) | ||||||
|     LDFLAGS = -Wl,-soname,libraylib.so -Wl,--exclude-libs,libatomic.a  |     LDFLAGS = -Wl,-soname,libraylib.$(API_VERSION).so -Wl,--exclude-libs,libatomic.a  | ||||||
|     LDFLAGS += -Wl,--build-id -Wl,--no-undefined -Wl,-z,noexecstack -Wl,-z,relro -Wl,-z,now -Wl,--warn-shared-textrel -Wl,--fatal-warnings  |     LDFLAGS += -Wl,--build-id -Wl,--no-undefined -Wl,-z,noexecstack -Wl,-z,relro -Wl,-z,now -Wl,--warn-shared-textrel -Wl,--fatal-warnings  | ||||||
|     # Force linking of library module to define symbol |     # Force linking of library module to define symbol | ||||||
|     LDFLAGS += -u ANativeActivity_onCreate |     LDFLAGS += -u ANativeActivity_onCreate | ||||||
| @@ -353,22 +356,30 @@ else | |||||||
|         ifeq ($(PLATFORM_OS),LINUX) |         ifeq ($(PLATFORM_OS),LINUX) | ||||||
|             # Compile raylib to shared library version for GNU/Linux. |             # Compile raylib to shared library version for GNU/Linux. | ||||||
|             # WARNING: you should type "make clean" before doing this target |             # WARNING: you should type "make clean" before doing this target | ||||||
| 			$(CC) -shared -o $(RAYLIB_RELEASE_PATH)/libraylib.so $(OBJS) -lGL -lm -lpthread -ldl -lrt | 			$(CC) -shared -o $(RAYLIB_RELEASE_PATH)/libraylib.$(VERSION).so $(OBJS) -Wl,-soname,libraylib.$(API_VERSION).so -lGL -lm -lpthread -ldl -lrt | ||||||
| 			@echo "raylib shared library generated (libraylib.so)!" | 			@echo "raylib shared library generated (libraylib.$(VERSION).so)!" | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).so libraylib.$(API_VERSION).so | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).so libraylib.so | ||||||
|         endif |         endif | ||||||
|         ifeq ($(PLATFORM_OS),OSX) |         ifeq ($(PLATFORM_OS),OSX) | ||||||
| 			$(CC) -dynamiclib -o $(RAYLIB_RELEASE_PATH)/libraylib.dylib $(OBJS) -L/usr/local/Cellar/glfw/3.2.1/lib -framework OpenGL -framework OpenAL -framework Cocoa | 			$(CC) -dynamiclib -o $(RAYLIB_RELEASE_PATH)/libraylib.$(VERSION).dylib $(OBJS) -compatibility_version $(API_VERSION) -current_version $(VERSION) -framework OpenGL -framework OpenAL -framework IOKit -framework CoreVideo -framework Cocoa | ||||||
| 			install_name_tool -id "libraylib.dylib" $(RAYLIB_RELEASE_PATH)/libraylib.dylib | 			install_name_tool -id "libraylib.$(VERSION).dylib" $(RAYLIB_RELEASE_PATH)/libraylib.$(VERSION).dylib | ||||||
| 			@echo "raylib shared library generated (libraylib.dylib)!" | 			@echo "raylib shared library generated (libraylib.$(VERSION).dylib)!" | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).dylib libraylib.$(API_VERSION).dylib | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).dylib libraylib.dylib | ||||||
|         endif |         endif | ||||||
|         ifeq ($(PLATFORM_OS),FREEBSD) |         ifeq ($(PLATFORM_OS),FREEBSD) | ||||||
|         # WARNING: you should type "gmake clean" before doing this target |         # WARNING: you should type "gmake clean" before doing this target | ||||||
| 			$(CC) -shared -o $(RAYLIB_RELEASE_PATH)/libraylib.so $(OBJS) -lGL -lpthread | 			$(CC) -shared -o $(RAYLIB_RELEASE_PATH)/libraylib.$(VERSION).so $(OBJS) -Wl,-soname,libraylib.$(API_VERSION).so -lGL -lpthread | ||||||
| 			@echo "raylib shared library generated (libraylib.so)!" | 			@echo "raylib shared library generated (libraylib.$(VERSION).so)!" | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).so libraylib.$(API_VERSION).so | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).so libraylib.so | ||||||
|         endif |         endif | ||||||
|         ifeq ($(PLATFORM),PLATFORM_ANDROID) |         ifeq ($(PLATFORM),PLATFORM_ANDROID) | ||||||
| 			$(CC) -shared -o $(RAYLIB_RELEASE_PATH)/libraylib.so $(OBJS) $(LDFLAGS) $(LDLIBS) | 			$(CC) -shared -o $(RAYLIB_RELEASE_PATH)/libraylib.$(VERSION).so $(OBJS) $(LDFLAGS) $(LDLIBS) | ||||||
| 			@echo "raylib shared library generated (libraylib.so)!" | 			@echo "raylib shared library generated (libraylib.$(VERSION).so)!" | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).so libraylib.$(API_VERSION).so | ||||||
|  | 			cd $(RAYLIB_RELEASE_PATH) && ln -fs libraylib.$(VERSION).so libraylib.so | ||||||
|         endif |         endif | ||||||
|     else |     else | ||||||
|         # Compile raylib static library |         # Compile raylib static library | ||||||
| @@ -386,7 +397,7 @@ core.o : core.c raylib.h rlgl.h utils.h raymath.h gestures.h | |||||||
|      |      | ||||||
| # Compile rglfw module | # Compile rglfw module | ||||||
| rglfw.o : rglfw.c | rglfw.o : rglfw.c | ||||||
| 	$(CC) -c $< $(CFLAGS) $(INCLUDE_PATHS) -D$(PLATFORM) -D$(GRAPHICS) | 	$(CC) $(GLFW_CFLAGS) -c $< $(CFLAGS) $(INCLUDE_PATHS) -D$(PLATFORM) -D$(GRAPHICS) | ||||||
|  |  | ||||||
| # Compile rlgl module | # Compile rlgl module | ||||||
| rlgl.o : rlgl.c rlgl.h raymath.h | rlgl.o : rlgl.c rlgl.h raymath.h | ||||||
| @@ -434,6 +445,8 @@ ifeq ($(ROOT),root) | |||||||
|         # /usr/local/include/) are for libraries that are installed |         # /usr/local/include/) are for libraries that are installed | ||||||
|         # manually (without a package manager). |         # manually (without a package manager). | ||||||
|         ifeq ($(RAYLIB_LIBTYPE),SHARED) |         ifeq ($(RAYLIB_LIBTYPE),SHARED) | ||||||
|  | 			cp --update $(RAYLIB_RELEASE_PATH)/libraylib.$(VERSION).so /usr/local/lib/libraylib.$(VERSION).so | ||||||
|  | 			cp --update $(RAYLIB_RELEASE_PATH)/libraylib.$(API_VERSION).so /usr/local/lib/libraylib.$(API_VERSION).so | ||||||
| 			cp --update $(RAYLIB_RELEASE_PATH)/libraylib.so /usr/local/lib/libraylib.so | 			cp --update $(RAYLIB_RELEASE_PATH)/libraylib.so /usr/local/lib/libraylib.so | ||||||
|         else |         else | ||||||
| 			cp --update raylib.h /usr/local/include/raylib.h | 			cp --update raylib.h /usr/local/include/raylib.h | ||||||
| @@ -455,6 +468,8 @@ ifeq ($(ROOT),root) | |||||||
| 			rm --force /usr/local/include/raylib.h | 			rm --force /usr/local/include/raylib.h | ||||||
|         ifeq ($(RAYLIB_LIBTYPE),SHARED) |         ifeq ($(RAYLIB_LIBTYPE),SHARED) | ||||||
| 			rm --force /usr/local/lib/libraylib.so | 			rm --force /usr/local/lib/libraylib.so | ||||||
|  | 			rm --force /usr/local/lib/libraylib.$(API_VERSION).so | ||||||
|  | 			rm --force /usr/local/lib/libraylib.$(VERSION).so | ||||||
|         else |         else | ||||||
| 			rm --force /usr/local/lib/libraylib.a | 			rm --force /usr/local/lib/libraylib.a | ||||||
|         endif |         endif | ||||||
| @@ -471,7 +486,7 @@ clean: | |||||||
| ifeq ($(PLATFORM_OS),WINDOWS) | ifeq ($(PLATFORM_OS),WINDOWS) | ||||||
| 	del *.o $(RAYLIB_RELEASE_PATH)/libraylib.a $(RAYLIB_RELEASE_PATH)/libraylib.bc $(RAYLIB_RELEASE_PATH)/libraylib.so external/stb_vorbis.o | 	del *.o $(RAYLIB_RELEASE_PATH)/libraylib.a $(RAYLIB_RELEASE_PATH)/libraylib.bc $(RAYLIB_RELEASE_PATH)/libraylib.so external/stb_vorbis.o | ||||||
| else | else | ||||||
| 	rm -f *.o $(RAYLIB_RELEASE_PATH)/libraylib.a $(RAYLIB_RELEASE_PATH)/libraylib.bc $(RAYLIB_RELEASE_PATH)/libraylib.so external/stb_vorbis.o | 	rm -f *.o $(RAYLIB_RELEASE_PATH)/libraylib.a $(RAYLIB_RELEASE_PATH)/libraylib.bc $(RAYLIB_RELEASE_PATH)/libraylib.so $(RAYLIB_RELEASE_PATH)/libraylib.$(API_VERSION).so $(RAYLIB_RELEASE_PATH)/libraylib.$(VERSION).so external/stb_vorbis.o | ||||||
| endif | endif | ||||||
| ifeq ($(PLATFORM),PLATFORM_ANDROID) | ifeq ($(PLATFORM),PLATFORM_ANDROID) | ||||||
| 	rm -rf $(ANDROID_TOOLCHAIN) | 	rm -rf $(ANDROID_TOOLCHAIN) | ||||||
|   | |||||||
| @@ -1,22 +0,0 @@ | |||||||
| install_headers('raylib.h') |  | ||||||
|  |  | ||||||
| source_c = [ |  | ||||||
|   'audio.c', |  | ||||||
|   'core.c', |  | ||||||
|   'models.c', |  | ||||||
|   'rlgl.c', |  | ||||||
|   'shapes.c', |  | ||||||
|   'text.c', |  | ||||||
|   'textures.c', |  | ||||||
|   'utils.c', |  | ||||||
|   'external/stb_vorbis.c', |  | ||||||
| ] |  | ||||||
|  |  | ||||||
| # use 'meson --default-library=static builddir' to build as static, if no builddir yet exists |  | ||||||
| # use 'mesonconf -Ddefault_library=static builddir' to change the type |  | ||||||
| raylib = library('raylib', |  | ||||||
|                   source_c, |  | ||||||
|                   dependencies : [ glfw_dep, gl_dep, openal_dep, m_dep, x11_dep], |  | ||||||
|                   install : true, |  | ||||||
|                   version : '1.8.0') |  | ||||||
|  |  | ||||||
		Reference in New Issue
	
	Block a user
	 Ray
					Ray