summaryrefslogtreecommitdiffhomepage
path: root/utils.cmake
diff options
context:
space:
mode:
authorMartinfx <[email protected]>2017-11-29 00:05:39 +0100
committerMartinfx <[email protected]>2017-11-29 00:05:39 +0100
commit2f471414c2f830e61a200ecd956f37e45ce94e96 (patch)
treebda66cc5cc0f48a1fa28adcb0c6c32949b32a43b /utils.cmake
parent2cf37708c024cb18267c41db3d604d570f6fe670 (diff)
downloadraylib-2f471414c2f830e61a200ecd956f37e45ce94e96.tar.gz
raylib-2f471414c2f830e61a200ecd956f37e45ce94e96.zip
Added compile with cmake for FreeBSD
Diffstat (limited to 'utils.cmake')
-rw-r--r--utils.cmake30
1 files changed, 24 insertions, 6 deletions
diff --git a/utils.cmake b/utils.cmake
index 84c73fe2..43b479da 100644
--- a/utils.cmake
+++ b/utils.cmake
@@ -1,9 +1,8 @@
# All sorts of things that we need cross project
cmake_minimum_required(VERSION 2.8.0)
-# Detect linux
-if(UNIX AND NOT APPLE)
- set(LINUX TRUE)
+if(CMAKE_SYSTEM_NAME STREQUAL Linux)
+ set(LINUX TRUE)
endif()
# Linking for OS X -framework options
@@ -18,17 +17,36 @@ if(APPLE)
set(LIBS_PRIVATE ${OPENGL_LIBRARY} ${OPENAL_LIBRARY} ${COCOA_LIBRARY}
${IOKIT_LIBRARY} ${COREFOUNDATION_LIBRARY} ${COREVIDEO_LIBRARY})
-elseif(LINUX)
+endif()
+
+if(CMAKE_SYSTEM_NAME STREQUAL Linux)
# Elsewhere (such as Linux), need `-lopenal -lGL`, etc...
set(LIBS_PRIVATE
m pthread dl
openal
GL
X11 Xrandr Xinerama Xi Xxf86vm Xcursor) # X11 stuff
-else()
- # TODO Windows
endif()
+if(CMAKE_SYSTEM_NAME STREQUAL FreeBSD)
+ find_package(OpenGL REQUIRED)
+ find_package(OpenAL REQUIRED)
+ include_directories(${OPENGL_INCLUDE_DIR} ${OPENAL_INCLUDE_DIR})
+
+ find_package(X11 REQUIRED)
+ find_library(OpenAL REQUIRED)
+ find_library(pthread NAMES pthread)
+ find_library(Xrandr NAMES Xrandr)
+ find_library(Xi NAMES Xi)
+ find_library(Xinerama NAMES Xinerama)
+ find_library(Xxf86vm NAMES Xxf86vm)
+ find_library(Xcursor NAMES Xcursor)
+
+ set(LIBS_PRIVATE m ${pthread} ${OPENAL_LIBRARY} ${X11_LIBRARIES} ${Xrandr} ${Xinerama} ${Xi} ${Xxf86vm} ${Xcursor})
+endif()
+
+# TODO Support Windows
+
# Do the linking for executables that are meant to link raylib
function(link_libraries_to_executable executable)
# And raylib