diff options
author | IronClawTrem <louie.nutman@gmail.com> | 2020-02-16 03:40:06 +0000 |
---|---|---|
committer | IronClawTrem <louie.nutman@gmail.com> | 2020-02-16 03:40:06 +0000 |
commit | 425decdf7e9284d15aa726e3ae96b9942fb0e3ea (patch) | |
tree | 6c0dd7edfefff1be7b9e75fe0b3a0a85fe1595f3 /src/client/CMakeLists.txt | |
parent | ccb0b2e4d6674a7a00c9bf491f08fc73b6898c54 (diff) |
create tremded branch
Diffstat (limited to 'src/client/CMakeLists.txt')
-rw-r--r-- | src/client/CMakeLists.txt | 209 |
1 files changed, 209 insertions, 0 deletions
diff --git a/src/client/CMakeLists.txt b/src/client/CMakeLists.txt new file mode 100644 index 0000000..c10fd9c --- /dev/null +++ b/src/client/CMakeLists.txt @@ -0,0 +1,209 @@ +# +## .o88b. db d888888b d88888b d8b db d888888b +## d8P Y8 88 `88' 88' 888o 88 `~~88~~' +## 8P 88 88 88ooooo 88V8o 88 88 +## 8b 88 88 88~~~~~ 88 V8o88 88 +## Y8b d8 88booo. .88. 88. 88 V888 88 +## `Y88P' Y88888P Y888888P Y88888P VP V8P YP +# + +find_package(CURL) +find_package(OpenGL) +find_package(OpenAL) +include(${CMAKE_SOURCE_DIR}/cmake/SDL2.cmake) + +add_definitions( + -DUSE_LOCAL_HEADERS + -DUSE_RESTCLIENT + -DUSE_CODEC_OPUS + -DUSE_OPENAL + -DUSE_OPENAL_DLOPEN + -DUSE_INTERNAL_JPEG + -DUSE_RENDERER_DLOPEN + -DNDEBUG + -DPRODUCT_VERSION="1.3.0 alpha" + ${SDL2_DEFINES} + ) + +set(PARENT_DIR ${CMAKE_CURRENT_SOURCE_DIR}/..) +set(EXTERNAL_DIR ${CMAKE_SOURCE_DIR}/external) +if(APPLE) +set(APPLE_SOURCES ${PARENT_DIR}/sys/sys_osx.mm) +endif(APPLE) + +add_executable( + tremulous + # + ${PARENT_DIR}/asm/snapvector.c + # + cl_avi.cpp + cl_cgame.cpp + cl_cin.cpp + cl_console.cpp + cl_curl.cpp + cl_input.cpp + cl_keys.cpp + cl_main.cpp + cl_net_chan.cpp + cl_parse.cpp + cl_rest.cpp + cl_scrn.cpp + cl_ui.cpp + cl_updates.cpp + libmumblelink.cpp + qal.cpp + snd_adpcm.cpp + snd_codec.cpp + snd_codec_ogg.cpp + snd_codec_opus.cpp + snd_codec_wav.cpp + snd_dma.cpp + snd_main.cpp + snd_mem.cpp + snd_mix.cpp + snd_openal.cpp + snd_wavelet.cpp + # + ${PARENT_DIR}/qcommon/cm_load.cpp + ${PARENT_DIR}/qcommon/cm_patch.cpp + ${PARENT_DIR}/qcommon/cm_polylib.cpp + ${PARENT_DIR}/qcommon/cm_test.cpp + ${PARENT_DIR}/qcommon/cm_trace.cpp + ${PARENT_DIR}/qcommon/cmd.cpp + ${PARENT_DIR}/qcommon/common.cpp + ${PARENT_DIR}/qcommon/crypto.cpp + ${PARENT_DIR}/qcommon/cvar.cpp + ${PARENT_DIR}/qcommon/cvar.h + ${PARENT_DIR}/qcommon/files.cpp + ${PARENT_DIR}/qcommon/files.h + ${PARENT_DIR}/qcommon/huffman.cpp + ${PARENT_DIR}/qcommon/huffman.h + ${PARENT_DIR}/qcommon/ioapi.cpp + ${PARENT_DIR}/qcommon/md4.cpp + ${PARENT_DIR}/qcommon/md5.cpp + ${PARENT_DIR}/qcommon/msg.cpp + ${PARENT_DIR}/qcommon/msg.h + ${PARENT_DIR}/qcommon/net_chan.cpp + ${PARENT_DIR}/qcommon/net_ip.cpp + ${PARENT_DIR}/qcommon/net.h + ${PARENT_DIR}/qcommon/parse.cpp + ${PARENT_DIR}/qcommon/puff.cpp + ${PARENT_DIR}/qcommon/q_shared.c + ${PARENT_DIR}/qcommon/q3_lauxlib.cpp + ${PARENT_DIR}/qcommon/q_math.c + ${PARENT_DIR}/qcommon/unzip.cpp + ${PARENT_DIR}/qcommon/vm.cpp + ${PARENT_DIR}/qcommon/vm_interpreted.cpp + ${PARENT_DIR}/qcommon/vm_x86.cpp + # + ${PARENT_DIR}/sdl/sdl_input.cpp + ${PARENT_DIR}/sdl/sdl_snd.cpp + # + ${PARENT_DIR}/server/sv_ccmds.cpp + ${PARENT_DIR}/server/sv_client.cpp + ${PARENT_DIR}/server/sv_game.cpp + ${PARENT_DIR}/server/sv_init.cpp + ${PARENT_DIR}/server/sv_main.cpp + ${PARENT_DIR}/server/sv_net_chan.cpp + ${PARENT_DIR}/server/sv_snapshot.cpp + ${PARENT_DIR}/server/sv_world.cpp + # + ${PARENT_DIR}/sys/con_log.cpp + ${PARENT_DIR}/sys/con_tty.cpp + ${PARENT_DIR}/sys/sys_main.cpp + ${PARENT_DIR}/sys/sys_unix.cpp + ${PARENT_DIR}/sys/sys_shared.h + ${APPLE_SOURCES} + + ${EXTERNAL_DIR}/semver/src/lib/semantic_version_v1.cpp + ${EXTERNAL_DIR}/semver/src/lib/semantic_version_v2.cpp + ) + +if(APPLE) + # FIXME Prefixed with "lua" to prevent cmake from doing "-l-framework Cocoa" + set(FRAMEWORKS "-framework Cocoa -framework Security -framework OpenAL -framework IOKit") +else(APPLE) + if(UNIX) + set(SYSLIBS dl rt) + endif(UNIX) +endif(APPLE) + +if(NOT USE_RENDERER_DLOPEN) + if(USE_OPENGL1) + set(RENDERER_LIBRARY renderergl1) + endif(USE_OPENGL1) + set(RENDERER_LIBRARY renderergl2) +endif(NOT USE_RENDERER_DLOPEN) + +target_link_libraries( + tremulous + # + lua + nettle + zlib + ogg + opus + opusfile + # + script_api + restclient + # + ${FRAMEWORKS} + ${CURL_LIBRARIES} + ${SDL2_LIBRARIES} + ${OPENGL_LIBRARIES} + ${OPENAL_LIBRARY} + ${SYSLIBS} + ) + +include_directories( + ${PARENT_DIR} + ${PARENT_DIR}/qcommon + ${EXTERNAL_DIR}/zlib + ${EXTERNAL_DIR}/restclient + ${EXTERNAL_DIR}/rapidjson + ${EXTERNAL_DIR}/SDL2/include + ${EXTERNAL_DIR}/jpeg-8c + ${EXTERNAL_DIR}/libogg-1.3.2/include + ${EXTERNAL_DIR}/lua-5.3.3/include + ${EXTERNAL_DIR}/sol + ${EXTERNAL_DIR}/nettle-3.3 + ${EXTERNAL_DIR}/opus-1.1.4/include + ${EXTERNAL_DIR}/opusfile-0.8/include + ${EXTERNAL_DIR}/restclient + ${EXTERNAL_DIR}/semver/src/include + ${SDL2_INCLUDE_DIRS} + ${OPENAL_INCLUDE_DIR} + ) + +# TODO: Turn this into a macro +if (USE_INTERNAL_SDL2) +add_custom_command( + TARGET tremulous + POST_BUILD COMMAND ${CMAKE_COMMAND} + ARGS -E copy ${CMAKE_SOURCE_DIR}/external/SDL2/libs/Darwin/libSDL2-2.0.0.dylib ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/libSDL2-2.0.0.dylib + ) +endif(USE_INTERNAL_SDL2) + +if (USE_RENDERER_DLOPEN) + add_custom_command( + TARGET tremulous + POST_BUILD COMMAND ${CMAKE_COMMAND} + ARGS -E copy ${CMAKE_BINARY_DIR}/src/renderergl1/librenderergl1${CMAKE_SHARED_LIBRARY_SUFFIX} ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/renderer_opengl1${CMAKE_SHARED_LIBRARY_SUFFIX} + ) + + add_custom_command( + TARGET tremulous + POST_BUILD COMMAND ${CMAKE_COMMAND} + ARGS -E copy ${CMAKE_BINARY_DIR}/src/renderergl2/librenderergl2${CMAKE_SHARED_LIBRARY_SUFFIX} ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/renderer_opengl2${CMAKE_SHARED_LIBRARY_SUFFIX} + ) +endif(USE_RENDERER_DLOPEN) + +add_dependencies( + tremulous + ui + game + cgame + renderergl1 + renderergl2 + ) |