summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorFilip Gawin <filip.gawin@zoho.com>2021-01-13 12:45:10 +0100
committerFilip Gawin <filip.gawin@zoho.com>2021-01-13 12:45:10 +0100
commit4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1 (patch)
treedaf2382aa89b8b37077e931238755fc9804eab16 /src
parentsome loose ends (diff)
downloadre3-4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1.tar
re3-4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1.tar.gz
re3-4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1.tar.bz2
re3-4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1.tar.lz
re3-4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1.tar.xz
re3-4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1.tar.zst
re3-4741afd2cfc1c38ae0a81c1b71134b1a323b9ac1.zip
Diffstat (limited to 'src')
-rw-r--r--src/CMakeLists.txt166
1 files changed, 87 insertions, 79 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index e87878a8..dc204d17 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -1,92 +1,105 @@
set(THREADS_PREFER_PTHREAD_FLAG ON)
find_package(Threads REQUIRED)
-if(${REVC_AUDIO} STREQUAL "OAL")
- find_package(OpenAL REQUIRED)
- find_package(MPG123 REQUIRED)
- find_package(SndFile REQUIRED)
-endif()
+file(GLOB_RECURSE ${PROJECT}_SOURCES "*.cpp" "*.h" "*.rc")
-file(GLOB_RECURSE Sources "*.cpp" "*.h")
+function(header_directories RETURN_LIST)
+ file(GLOB_RECURSE ALL_SRCS *.h *.cpp *.c)
+ set(RELDIRS)
+ foreach(SRC ${ALL_SRCS})
+ file(RELATIVE_PATH RELSRC "${CMAKE_CURRENT_SOURCE_DIR}" "${SRC}")
+ get_filename_component(RELDIR "${RELSRC}" DIRECTORY)
+ list(APPEND RELDIRS ${RELDIR})
+ endforeach()
+ list(REMOVE_DUPLICATES RELDIRS)
+ set(${RETURN_LIST} ${RELDIRS} PARENT_SCOPE)
+endfunction()
-MACRO(HEADER_DIRECTORIES return_list)
- FILE(GLOB_RECURSE new_list *.cpp)
- SET(dir_list "animation"
- "audio"
- "collision"
- "control"
- "core"
- "entities"
- "extras"
- "fakerw"
- "math"
- "modelinfo"
- "objects"
- "peds"
- "render"
- "rw"
- "save"
- "skel"
- "text"
- "vehicles"
- "weapons")
- FOREACH(file_path ${new_list})
- GET_FILENAME_COMPONENT(dir_path ${file_path} PATH)
- SET(dir_list ${dir_list} ${dir_path})
- ENDFOREACH()
- LIST(REMOVE_DUPLICATES dir_list)
- SET(${return_list} ${dir_list})
-ENDMACRO()
+header_directories(${PROJECT}_INCLUDES)
-HEADER_DIRECTORIES(header_list)
-include_directories(${header_list})
+add_executable(${EXECUTABLE} WIN32
+ ${${PROJECT}_SOURCES}
+)
+target_link_libraries(${EXECUTABLE} PRIVATE
+ librw::librw
+ Threads::Threads
+)
-add_executable(reVC ${Sources})
-target_link_libraries(reVC librw)
-target_link_libraries(reVC Threads::Threads)
+target_include_directories(${EXECUTABLE}
+ PRIVATE
+ $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}>
+ $<BUILD_INTERFACE:${${PROJECT}_INCLUDES}>
+)
-if(${REVC_AUDIO} STREQUAL "OAL")
- target_link_libraries(reVC ${OPENAL_LIBRARY})
- target_link_libraries(reVC ${MPG123_LIBRARIES})
- target_link_libraries(reVC ${SNDFILE_LIBRARIES})
-endif()
+target_compile_definitions(${EXECUTABLE}
+ PRIVATE
+ $<IF:$<CONFIG:DEBUG>,DEBUG,NDEBUG>
+ LIBRW
+ ${PROJECT}_NO_AUTOLINK
+)
-target_include_directories(reVC
- INTERFACE
- $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}>
+if(LIBRW_PLATFORM_D3D9)
+ target_compile_definitions(${EXECUTABLE}
+ PUBLIC
+ USE_D3D9
)
+endif()
-target_compile_definitions(reVC
- PRIVATE
- "$<IF:$<CONFIG:DEBUG>,DEBUG,NDEBUG>"
- PUBLIC
- "RW_${REVC_PLATFORM}"
+if(${PROJECT}_AUDIO STREQUAL "OAL")
+ find_package(OpenAL REQUIRED)
+ target_include_directories(${EXECUTABLE} PRIVATE ${OPENAL_INCLUDE_DIR})
+ target_link_libraries(${EXECUTABLE} PRIVATE ${OPENAL_LIBRARY})
+ target_compile_definitions(${EXECUTABLE} PRIVATE ${OPENAL_DEFINITIONS})
+ target_compile_definitions(${EXECUTABLE} PRIVATE AUDIO_OAL)
+elseif(${PROJECT}_AUDIO STREQUAL "MSS")
+ find_package(MilesSDK REQUIRED)
+ target_compile_definitions(${EXECUTABLE} PRIVATE AUDIO_MSS)
+ target_link_libraries(${EXECUTABLE} PRIVATE MilesSDK::MilesSDK)
+endif()
+
+find_package(mpg123 REQUIRED)
+target_link_libraries(${EXECUTABLE} PRIVATE
+ MPG123::libmpg123
+)
+if(${PROJECT}_WITH_OPUS)
+ find_package(opusfile REQUIRED)
+ target_link_libraries(${EXECUTABLE} PRIVATE
+ opusfile::opusfile
+ )
+ target_compile_definitions(${EXECUTABLE} PRIVATE AUDIO_OPUS)
+endif()
+if(${PROJECT}_WITH_LIBSNDFILE)
+ find_package(SndFile REQUIRED)
+ target_link_libraries(${EXECUTABLE} PRIVATE
+ SndFile::SndFile
)
+ target_compile_definitions(${EXECUTABLE} PRIVATE AUDIO_OAL_USE_SNDFILE)
+endif()
-target_compile_definitions(reVC PRIVATE LIBRW=1 AUDIO_OAL=1)
+target_compile_definitions(${EXECUTABLE} PRIVATE )
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU" OR CMAKE_CXX_COMPILER_ID STREQUAL "Clang" OR CMAKE_CXX_COMPILER_ID STREQUAL "AppleClang")
- target_compile_options(reVC
+ target_compile_options(${EXECUTABLE}
PRIVATE
"-Wall"
- )
- if (NOT REVC_PLATFORM_PS2)
- target_compile_options(reVC
+ )
+ if (NOT LIBRW_PLATFORM_PS2)
+ target_compile_options(${EXECUTABLE}
PRIVATE
- "-Wextra"
- "-Wdouble-promotion"
- "-Wpedantic"
- )
+ -Wextra
+ -Wdouble-promotion
+ -Wpedantic
+ )
endif()
elseif(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
- target_compile_options(reVC
+ target_compile_options(${EXECUTABLE}
PUBLIC
- /wd4996 /wd4244
- )
+ /Zc:sizedDealloc-
+ )
endif()
-set_target_properties(reVC
+set_target_properties(${EXECUTABLE}
PROPERTIES
C_STANDARD 11
C_EXTENSIONS OFF
@@ -94,20 +107,15 @@ set_target_properties(reVC
CXX_STANDARD 11
CXX_EXTENSIONS OFF
CXX_STANDARD_REQUIRED ON
- PREFIX ""
- )
-
-if(REVC_INSTALL)
- target_include_directories(reVC
- INTERFACE
- $<INSTALL_INTERFACE:${REVC_INSTALL_INCLUDEDIR}>
- )
+)
+if(${PROJECT}_INSTALL)
install(
- TARGETS reVC
- EXPORT reVC-targets
- RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}"
- LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
- ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
- )
+ TARGETS ${EXECUTABLE}
+ EXPORT ${EXECUTABLE}-targets
+ RUNTIME DESTINATION "."
+ )
+ if(MSVC)
+ install(FILES $<TARGET_PDB_FILE:${EXECUTABLE}> DESTINATION "." OPTIONAL)
+ endif()
endif()