mirror of
https://github.com/lubosz/overte.git
synced 2025-04-06 00:22:25 +02:00
This way there's no need to rebuild the test every time. Script dir is symlinked from the source into the binary dir.
519 lines
18 KiB
CMake
519 lines
18 KiB
CMake
# Copyright 2013-2019 High Fidelity, Inc.
|
|
# Copyright 2019-2021 Vircadia contributors.
|
|
# Copyright 2020-2022 Overte e.V.
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
# If we're running under the gradle build, HIFI_ANDROID will be set here, but
|
|
# ANDROID will not be set until after the `project` statement. This is the *ONLY*
|
|
# place you need to use `HIFI_ANDROID` instead of `ANDROID`
|
|
if (WIN32 AND NOT HIFI_ANDROID)
|
|
cmake_minimum_required(VERSION 3.7)
|
|
else()
|
|
cmake_minimum_required(VERSION 3.2)
|
|
endif()
|
|
|
|
# 3.14 is the minimum version that supports symlinks on Windows
|
|
cmake_minimum_required(VERSION 3.14)
|
|
|
|
# Passing of variables to vcpkg
|
|
#
|
|
# vcpkg runs cmake scripts in an isolated environment, see this for details:
|
|
# https://github.com/Microsoft/vcpkg/issues/3712
|
|
#
|
|
# Here's how this works and how we work around this issue:
|
|
#
|
|
# 1. This file (CMakeLists.txt) runs first and is authoritative. It is the one
|
|
# that reads the environment, sets variables and sets a default value.
|
|
# 2. It writes the contents of the variables to
|
|
# $CMAKE_CURRENT_BINARY_DIR/_env/$VARNAME
|
|
# 3. hifi_vcpkg.py takes the _env directory, and copies it to the vcpkg dir.
|
|
# This solves the issue of CMakeLists.txt not knowing where the vcpkg dir is.
|
|
# 4. cmake/ports/*/portfile.cmake does know where the vcpkg dir is, and can
|
|
# read the _env that was copied there to obtain the variable's name.
|
|
#
|
|
# To ensure no old data could be accidentally read, the _env directories are
|
|
# deleted on each execution and fully recreated.
|
|
|
|
# Ensure nothing is kept from any previous run
|
|
file(REMOVE_RECURSE "${CMAKE_CURRENT_BINARY_DIR}/_env")
|
|
file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/_env")
|
|
|
|
# Base URL for externally downloaded files
|
|
set(EXTERNAL_BUILD_ASSETS "https://build-deps.overte.org")
|
|
|
|
if( DEFINED ENV{EXTERNAL_BUILD_ASSETS} )
|
|
set(EXTERNAL_BUILD_ASSETS "$ENV{EXTERNAL_BUILD_ASSETS}")
|
|
endif()
|
|
|
|
file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/_env/EXTERNAL_BUILD_ASSETS.txt" "${EXTERNAL_BUILD_ASSETS}")
|
|
MESSAGE(STATUS "EXTERNAL_BUILD_ASSETS: ${EXTERNAL_BUILD_ASSETS}")
|
|
|
|
# read USE_GLES enviroment variable and sets it as GLES option
|
|
# TODO still gets overwritten by "use GLES on linux aarch64"
|
|
set(GLES_OPTION "$ENV{USE_GLES}")
|
|
|
|
# use GLES on linux aarch64
|
|
if (CMAKE_SYSTEM_NAME STREQUAL "Linux" AND CMAKE_SYSTEM_PROCESSOR STREQUAL "aarch64")
|
|
set(GLES_OPTION ON)
|
|
endif()
|
|
|
|
# Will affect VCPKG dependencies
|
|
file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/_env/USE_GLES.txt" "${GLES_OPTION}")
|
|
MESSAGE(STATUS "GLES_OPTION: ${GLES_OPTION}")
|
|
|
|
include("${CMAKE_CURRENT_SOURCE_DIR}/cmake/macros/TargetPython.cmake")
|
|
target_python()
|
|
|
|
if (WIN32 AND NOT HIFI_ANDROID AND NOT (CMAKE_GENERATOR STREQUAL "Ninja"))
|
|
# Force x64 toolset
|
|
set(CMAKE_GENERATOR_TOOLSET "host=x64" CACHE STRING "64-bit toolset" FORCE)
|
|
endif()
|
|
|
|
# set our OS X deployment target
|
|
# (needs to be set before first project() call and before prebuild.py)
|
|
# Will affect VCPKG dependencies
|
|
if (APPLE)
|
|
set(ENV{MACOSX_DEPLOYMENT_TARGET} 10.11)
|
|
endif()
|
|
|
|
set(RELEASE_TYPE "$ENV{RELEASE_TYPE}")
|
|
if ((NOT "${RELEASE_TYPE}" STREQUAL "PRODUCTION") AND (NOT "${RELEASE_TYPE}" STREQUAL "PR"))
|
|
set(RELEASE_TYPE "DEV")
|
|
endif()
|
|
|
|
# OVERTE_OPTIMIZE
|
|
# Variable determining Overte optimization. If not set, it defaults to true.
|
|
# It's used to determine build flags for main codebase and for VCPKG dependencies.
|
|
# Should be set to false to get completely unoptimized build for easier line-by-line debugging
|
|
|
|
if( NOT WIN32 )
|
|
if(NOT DEFINED OVERTE_OPTIMIZE)
|
|
message("Enabling code optimization for Overte and compiled dependencies")
|
|
set(OVERTE_OPTIMIZE true CACHE BOOL "Enable code optimization for Overte and compiled dependencies")
|
|
endif()
|
|
|
|
#compiler needs to be detected before building VCPKG dependencies
|
|
set(CMAKE_PLATFORM_INFO_DIR "${CMAKE_CURRENT_BINARY_DIR}")
|
|
include(CMakeDetermineCXXCompiler)
|
|
|
|
set(OVERTE_OPTIMIZE_FLAGS "")
|
|
|
|
if(OVERTE_OPTIMIZE)
|
|
|
|
file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/_env/OVERTE_OPTIMIZE.txt" "${OVERTE_OPTIMIZE}")
|
|
if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|
message("Clang compiler detected, adding -O3 -fPIC -g flags")
|
|
set(OVERTE_OPTIMIZE_FLAGS "-O3 -fPIC -g")
|
|
elseif (CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
|
message("GCC compiler detected, adding -O3 -fPIC -ggdb flags")
|
|
set(OVERTE_OPTIMIZE_FLAGS "-O3 -fPIC -ggdb")
|
|
else()
|
|
message("No predefined optimization flags for compiler ${CMAKE_CXX_COMPILER_ID}")
|
|
endif()
|
|
endif()
|
|
MESSAGE(STATUS "OVERTE_OPTIMIZE: ${OVERTE_OPTIMIZE}")
|
|
|
|
# OVERTE_CPU_ARCHITECTURE
|
|
# Variable determining CPU architecture for which Overte will be built.
|
|
# If defined, it's appended to CXXFLAGS and CFLAGS for both Overte and VCPKG dependencies
|
|
|
|
#Assume -march=native for compilers that allow it if architecture is not specified
|
|
if(NOT DEFINED OVERTE_CPU_ARCHITECTURE)
|
|
if(OVERTE_OPTIMIZE AND ( (CMAKE_CXX_COMPILER_ID MATCHES "Clang") OR (CMAKE_CXX_COMPILER_ID MATCHES "GNU") ) )
|
|
message("Optimization is enabled, but architecture is not specified. Assuming native build")
|
|
set(OVERTE_CPU_ARCHITECTURE "-march=native -mtune=native" CACHE STRING "Specify architecture dependent compiler flags here")
|
|
endif()
|
|
endif()
|
|
|
|
if(DEFINED OVERTE_CPU_ARCHITECTURE)
|
|
file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/_env/OVERTE_CPU_ARCHITECTURE.txt" "${OVERTE_CPU_ARCHITECTURE}")
|
|
set(OVERTE_OPTIMIZE_FLAGS "${OVERTE_OPTIMIZE_FLAGS} ${OVERTE_CPU_ARCHITECTURE}")
|
|
message("Adding CPU architecture flags: ${OVERTE_CPU_ARCHITECTURE}")
|
|
MESSAGE(STATUS "OVERTE_CPU_ARCHITECTURE: ${OVERTE_CPU_ARCHITECTURE}")
|
|
endif()
|
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${OVERTE_OPTIMIZE_FLAGS}")
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${OVERTE_OPTIMIZE_FLAGS}")
|
|
|
|
set(ENV{CXXFLAGS} "$ENV{CXXFLAGS} ${OVERTE_OPTIMIZE_FLAGS}")
|
|
set(ENV{CFLAGS} "$ENV{CFLAGS} ${OVERTE_OPTIMIZE_FLAGS}")
|
|
message($ENV{CXXFLAGS})
|
|
endif()
|
|
|
|
# OVERTE_WARNINGS
|
|
#
|
|
# Here we add the ability to whitelist warnings we've determined we can't fix, or are safe to
|
|
# ignore for one reason or another. The way of doing so is compiler-specific, so we deal with
|
|
# the detection of that in cmake, and just pass it down to the code from here.
|
|
#
|
|
# We can also treat warnings as errors. Without the whitelist this will almost certainly lead
|
|
# to a build failure.
|
|
|
|
if(NOT DEFINED OVERTE_WARNINGS_WHITELIST)
|
|
set(OVERTE_WARNINGS_WHITELIST true CACHE BOOL "Whitelist some warnings we can't currently fix")
|
|
endif()
|
|
|
|
if(NOT DEFINED OVERTE_WARNINGS_AS_ERRORS)
|
|
set(OVERTE_WARNINGS_AS_ERRORS false CACHE BOOL "Count warnings as errors")
|
|
endif()
|
|
|
|
if(OVERTE_WARNINGS_WHITELIST)
|
|
if (NOT WIN32)
|
|
set(CMAKE_PLATFORM_INFO_DIR "${CMAKE_CURRENT_BINARY_DIR}")
|
|
include(CMakeDetermineCXXCompiler)
|
|
endif()
|
|
|
|
if (CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
|
message("GCC compiler detected, suppressing some unsolvable warnings.")
|
|
add_compile_definitions(OVERTE_WARNINGS_WHITELIST_GCC)
|
|
elseif(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|
message("Clang compiler detected, suppressing some unsolvable warnings.")
|
|
add_compile_definitions(OVERTE_WARNINGS_WHITELIST_CLANG)
|
|
elseif(CMAKE_CXX_COMPILER_ID MATCHES "MSVC" OR (CMAKE_CXX_COMPILER_ID MATCHES "" AND WIN32))
|
|
message("Microsoft Visual Studio compiler detected, suppressing some unsolvable warnings.")
|
|
add_compile_definitions(OVERTE_WARNINGS_WHITELIST_MSVC)
|
|
else()
|
|
message("We don't know yet how to whitelist warnings for ${CMAKE_CXX_COMPILER_ID}")
|
|
endif()
|
|
endif()
|
|
|
|
if(OVERTE_WARNINGS_AS_ERRORS)
|
|
set(ENV{CXXFLAGS} "$ENV{CXXFLAGS} -Werror")
|
|
set(ENV{CFLAGS} "$ENV{CXXFLAGS} -Werror")
|
|
endif()
|
|
|
|
|
|
if (HIFI_ANDROID)
|
|
execute_process(
|
|
COMMAND ${HIFI_PYTHON_EXEC} ${CMAKE_CURRENT_SOURCE_DIR}/prebuild.py --release-type ${RELEASE_TYPE} --android ${HIFI_ANDROID_APP} --build-root ${CMAKE_BINARY_DIR}
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} RESULTS_VARIABLE PREBUILD_RET
|
|
)
|
|
else()
|
|
set(VCPKG_BUILD_TYPE_PARAM "")
|
|
if (VCPKG_BUILD_TYPE)
|
|
set(VCPKG_BUILD_TYPE_PARAM --vcpkg-build-type ${VCPKG_BUILD_TYPE})
|
|
endif()
|
|
execute_process(
|
|
COMMAND ${HIFI_PYTHON_EXEC} ${CMAKE_CURRENT_SOURCE_DIR}/prebuild.py --vcpkg-skip-clean --release-type ${RELEASE_TYPE} --build-root ${CMAKE_BINARY_DIR} ${VCPKG_BUILD_TYPE_PARAM}
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} RESULTS_VARIABLE PREBUILD_RET
|
|
)
|
|
# squelch the Policy CMP0074 warning without requiring an update to cmake 3.12.
|
|
if (CMAKE_VERSION VERSION_GREATER_EQUAL 3.12)
|
|
cmake_policy(SET CMP0074 NEW)
|
|
endif()
|
|
endif()
|
|
|
|
if (PREBUILD_RET GREATER 0)
|
|
message(FATAL_ERROR "prebuild.py failed with error ${PREBUILD_RET}")
|
|
endif()
|
|
if(NOT EXISTS "${CMAKE_BINARY_DIR}/vcpkg.cmake")
|
|
message(FATAL_ERROR "vcpkg configuration missing.")
|
|
endif()
|
|
include("${CMAKE_BINARY_DIR}/vcpkg.cmake")
|
|
|
|
if (HIFI_ANDROID)
|
|
set(QT_CMAKE_PREFIX_PATH "$ENV{HIFI_ANDROID_PRECOMPILED}/qt/lib/cmake")
|
|
else()
|
|
if ("$ENV{OVERTE_USE_SYSTEM_QT}" STREQUAL "")
|
|
if(NOT EXISTS "${CMAKE_BINARY_DIR}/qt.cmake")
|
|
message(FATAL_ERROR "qt configuration missing.")
|
|
endif()
|
|
include("${CMAKE_BINARY_DIR}/qt.cmake")
|
|
message(STATUS "${CMAKE_BINARY_DIR}/qt.cmake included!")
|
|
else()
|
|
message(STATUS "System Qt in use, not including qt.cmake!")
|
|
endif()
|
|
endif()
|
|
|
|
option(VCPKG_APPLOCAL_DEPS OFF)
|
|
|
|
project(overte)
|
|
include("cmake/init.cmake")
|
|
include("cmake/compiler.cmake")
|
|
option(VCPKG_APPLOCAL_DEPS OFF)
|
|
|
|
add_paths_to_fixup_libs(${VCPKG_INSTALL_ROOT}/bin)
|
|
add_paths_to_fixup_libs(${VCPKG_INSTALL_ROOT}/debug/bin)
|
|
|
|
if (NOT DEFINED CLIENT_ONLY)
|
|
set(CLIENT_ONLY 0)
|
|
endif()
|
|
|
|
if (NOT DEFINED SERVER_ONLY)
|
|
set(SERVER_ONLY 0)
|
|
endif()
|
|
|
|
if (ANDROID OR UWP)
|
|
set(MOBILE 1)
|
|
else()
|
|
set(MOBILE 0)
|
|
endif()
|
|
|
|
set(SCREENSHARE 0)
|
|
if (WIN32)
|
|
set(SCREENSHARE 1)
|
|
endif()
|
|
if (APPLE AND NOT CLIENT_ONLY)
|
|
# Don't include Screenshare in OSX client-only builds.
|
|
set(SCREENSHARE 1)
|
|
endif()
|
|
|
|
# Use default time server if none defined in environment
|
|
set_from_env(TIMESERVER_URL TIMESERVER_URL "http://timestamp.comodoca.com?td=sha256")
|
|
|
|
set(HIFI_USE_OPTIMIZED_IK_OPTION OFF)
|
|
set(BUILD_CLIENT_OPTION ON)
|
|
set(BUILD_SERVER_OPTION ON)
|
|
set(BUILD_TESTS_OPTION OFF)
|
|
set(BUILD_MANUAL_TESTS_OPTION ${BUILD_TESTS_OPTION})
|
|
set(BUILD_TOOLS_OPTION ON)
|
|
set(BUILD_INSTALLER_OPTION ON)
|
|
set(DISABLE_QML_OPTION OFF)
|
|
set(DOWNLOAD_SERVERLESS_CONTENT_OPTION OFF)
|
|
|
|
if (ANDROID OR UWP)
|
|
set(BUILD_SERVER_OPTION OFF)
|
|
set(BUILD_TOOLS_OPTION OFF)
|
|
set(BUILD_INSTALLER OFF)
|
|
endif()
|
|
|
|
if (CLIENT_ONLY)
|
|
set(BUILD_SERVER_OPTION OFF)
|
|
endif()
|
|
|
|
if (SERVER_ONLY)
|
|
set(BUILD_CLIENT_OPTION OFF)
|
|
set(BUILD_TESTS_OPTION OFF)
|
|
endif()
|
|
|
|
if (ANDROID)
|
|
set(GLES_OPTION ON)
|
|
set(PLATFORM_QT_COMPONENTS AndroidExtras WebView)
|
|
add_definitions(-DHIFI_ANDROID_APP=\"${HIFI_ANDROID_APP}\")
|
|
if (
|
|
(${HIFI_ANDROID_APP} STREQUAL "questInterface") OR
|
|
(${HIFI_ANDROID_APP} STREQUAL "questFramePlayer") OR
|
|
(${HIFI_ANDROID_APP} STREQUAL "framePlayer")
|
|
)
|
|
# We know the quest hardware has this extension, so we can force the use of instanced stereo
|
|
add_definitions(-DHAVE_EXT_clip_cull_distance)
|
|
# We can also use multiview stereo techniques
|
|
add_definitions(-DHAVE_OVR_multiview2)
|
|
add_definitions(-DHAVE_OVR_multiview)
|
|
# We can also use our own foveated textures
|
|
add_definitions(-DHAVE_QCOM_texture_foveated)
|
|
|
|
# if set, the application itself or some library it depends on MUST implement
|
|
# `DisplayPluginList getDisplayPlugins()` and `InputPluginList getInputPlugins()`
|
|
add_definitions(-DCUSTOM_INPUT_PLUGINS)
|
|
add_definitions(-DCUSTOM_DISPLAY_PLUGINS)
|
|
set(PLATFORM_PLUGIN_LIBRARIES oculusMobile oculusMobilePlugin)
|
|
endif()
|
|
|
|
# Allow client code to use preprocessor macros to distinguish between quest and non-quest builds
|
|
if (${HIFI_ANDROID_APP} STREQUAL "questInterface")
|
|
add_definitions(-DANDROID_APP_QUEST_INTERFACE)
|
|
elseif(${HIFI_ANDROID_APP} STREQUAL "interface")
|
|
add_definitions(-DANDROID_APP_INTERFACE)
|
|
endif()
|
|
else ()
|
|
set(PLATFORM_QT_COMPONENTS WebEngine Xml)
|
|
endif ()
|
|
|
|
if (USE_GLES AND (NOT ANDROID AND NOT UNIX))
|
|
set(DISABLE_QML_OPTION ON)
|
|
endif()
|
|
|
|
option(HIFI_USE_OPTIMIZED_IK "Use optimized IK" ${HIFI_USE_OPTIMIZED_IK_OPTION})
|
|
option(BUILD_CLIENT "Build client components" ${BUILD_CLIENT_OPTION})
|
|
option(BUILD_SERVER "Build server components" ${BUILD_SERVER_OPTION})
|
|
option(BUILD_TESTS "Build tests" ${BUILD_TESTS_OPTION})
|
|
option(BUILD_MANUAL_TESTS "Build manual tests" ${BUILD_MANUAL_TESTS_OPTION})
|
|
option(BUILD_TOOLS "Build tools" ${BUILD_TOOLS_OPTION})
|
|
option(BUILD_INSTALLER "Build installer" ${BUILD_INSTALLER_OPTION})
|
|
option(USE_GLES "Use OpenGL ES" ${GLES_OPTION})
|
|
option(USE_KHR_ROBUSTNESS "Use KHR_robustness" OFF)
|
|
option(DISABLE_QML "Disable QML" ${DISABLE_QML_OPTION})
|
|
option(DISABLE_KTX_CACHE "Disable KTX Cache" OFF)
|
|
option(
|
|
DOWNLOAD_SERVERLESS_CONTENT
|
|
"Download and setup default serverless content beside Interface"
|
|
${DOWNLOAD_SERVERLESS_CONTENT_OPTION}
|
|
)
|
|
|
|
set(PLATFORM_QT_GL OpenGL)
|
|
|
|
if (USE_KHR_ROBUSTNESS)
|
|
add_definitions(-DUSE_KHR_ROBUSTNESS)
|
|
endif()
|
|
|
|
if (USE_GLES)
|
|
add_definitions(-DUSE_GLES)
|
|
add_definitions(-DGPU_POINTER_STORAGE_SHARED)
|
|
set(PLATFORM_GL_BACKEND gpu-gl-common gpu-gles)
|
|
else()
|
|
add_definitions(-DGPU_POINTER_STORAGE_RAW)
|
|
set(PLATFORM_GL_BACKEND gpu-gl-common gpu-gl)
|
|
endif()
|
|
|
|
foreach(PLATFORM_QT_COMPONENT ${PLATFORM_QT_COMPONENTS})
|
|
list(APPEND PLATFORM_QT_LIBRARIES "Qt5::${PLATFORM_QT_COMPONENT}")
|
|
endforeach()
|
|
|
|
MESSAGE(STATUS "Use optimized IK: " ${HIFI_USE_OPTIMIZED_IK})
|
|
MESSAGE(STATUS "Build server: " ${BUILD_SERVER})
|
|
MESSAGE(STATUS "Build client: " ${BUILD_CLIENT})
|
|
MESSAGE(STATUS "Build tests: " ${BUILD_TESTS})
|
|
MESSAGE(STATUS "Build tools: " ${BUILD_TOOLS})
|
|
MESSAGE(STATUS "Build installer: " ${BUILD_INSTALLER})
|
|
MESSAGE(STATUS "GL ES: " ${USE_GLES})
|
|
MESSAGE(STATUS "DL serverless content: " ${DOWNLOAD_SERVERLESS_CONTENT})
|
|
|
|
if (DISABLE_QML)
|
|
MESSAGE(STATUS "QML disabled!")
|
|
add_definitions(-DDISABLE_QML)
|
|
endif()
|
|
|
|
if (DISABLE_KTX_CACHE)
|
|
MESSAGE(STATUS "KTX cache disabled!")
|
|
add_definitions(-DDISABLE_KTX_CACHE)
|
|
endif()
|
|
|
|
if (UNIX AND DEFINED ENV{HIFI_MEMORY_DEBUGGING})
|
|
MESSAGE(STATUS "Memory debugging is enabled")
|
|
endif()
|
|
|
|
#
|
|
# Helper projects
|
|
#
|
|
file(GLOB_RECURSE CMAKE_SRC cmake/*.cmake cmake/CMakeLists.txt)
|
|
add_custom_target(cmake SOURCES ${CMAKE_SRC})
|
|
GroupSources("cmake")
|
|
unset(CMAKE_SRC)
|
|
|
|
file(GLOB_RECURSE JS_SRC scripts/*.* unpublishedScripts/*.*)
|
|
add_custom_target(js SOURCES ${JS_SRC})
|
|
GroupSources("scripts")
|
|
GroupSources("unpublishedScripts")
|
|
unset(JS_SRC)
|
|
|
|
# Include Overte Web app files if cloned into a subdirectory.
|
|
if (IS_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/overte-web")
|
|
file(GLOB_RECURSE WEB_APP_SRC overte-web/*.*)
|
|
list(FILTER WEB_APP_SRC EXCLUDE REGEX "overte-web/(dist|node_modules|public)/*" )
|
|
overte(overte-web SOURCES ${WEB_APP_SRC})
|
|
GroupSources("overte-web")
|
|
unset(WEB_APP_SRC)
|
|
endif()
|
|
|
|
# Include Overte Web SDK files if cloned into a subdirectory.
|
|
if (IS_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/overte-web-sdk")
|
|
file(GLOB_RECURSE WEB_SDK_SRC overte-web-sdk/*.*)
|
|
list(FILTER WEB_SDK_SRC EXCLUDE REGEX "overte-web-sdk/(dist|node_modules|public)/*" )
|
|
add_custom_target(overte-web-sdk SOURCES ${WEB_SDK_SRC})
|
|
GroupSources("overte-web-sdk")
|
|
unset(WEB_SDK_SRC)
|
|
endif()
|
|
|
|
set_packaging_parameters()
|
|
|
|
# Locate the required Qt build on the filesystem
|
|
setup_qt()
|
|
|
|
if ("$ENV{OVERTE_USE_SYSTEM_QT}" STREQUAL "")
|
|
list(APPEND CMAKE_PREFIX_PATH "${QT_CMAKE_PREFIX_PATH}")
|
|
endif()
|
|
|
|
find_package( Threads )
|
|
|
|
add_definitions(-DGLM_FORCE_RADIANS)
|
|
add_definitions(-DGLM_ENABLE_EXPERIMENTAL)
|
|
add_definitions(-DGLM_FORCE_CTOR_INIT)
|
|
|
|
if (WIN32)
|
|
# Deal with fakakta Visual Studo 2017 bug
|
|
add_definitions(-DQT_NO_FLOAT16_OPERATORS)
|
|
endif()
|
|
|
|
if (HIFI_USE_OPTIMIZED_IK)
|
|
MESSAGE(STATUS "SET THE USE IK DEFINITION ")
|
|
add_definitions(-DHIFI_USE_OPTIMIZED_IK)
|
|
endif()
|
|
set(HIFI_LIBRARY_DIR "${CMAKE_CURRENT_SOURCE_DIR}/libraries")
|
|
|
|
set(EXTERNAL_PROJECT_PREFIX "project")
|
|
set_property(DIRECTORY PROPERTY EP_PREFIX ${EXTERNAL_PROJECT_PREFIX})
|
|
setup_externals_binary_dir()
|
|
|
|
option(USE_NSIGHT "Attempt to find the nSight libraries" 1)
|
|
|
|
# FIXME hack to work on the proper Android toolchain
|
|
if (ANDROID)
|
|
add_subdirectory(android/apps/${HIFI_ANDROID_APP})
|
|
return()
|
|
endif()
|
|
|
|
if (BUILD_GPU_FRAME_PLAYER_ONLY)
|
|
# This is for CI build testing
|
|
add_subdirectory(tools/gpu-frame-player)
|
|
else()
|
|
|
|
if (SCREENSHARE)
|
|
add_subdirectory(screenshare)
|
|
endif()
|
|
|
|
# BUILD_TOOLS option will be handled inside the tools's CMakeLists.txt because 'scribe' tool is required for build anyway
|
|
add_subdirectory(tools)
|
|
|
|
# add subdirectories for all targets
|
|
if (BUILD_SERVER)
|
|
add_subdirectory(assignment-client)
|
|
set_target_properties(assignment-client PROPERTIES FOLDER "Apps")
|
|
add_subdirectory(domain-server)
|
|
set_target_properties(domain-server PROPERTIES FOLDER "Apps")
|
|
add_subdirectory(ice-server)
|
|
set_target_properties(ice-server PROPERTIES FOLDER "Apps")
|
|
endif()
|
|
|
|
if (BUILD_CLIENT)
|
|
add_subdirectory(interface)
|
|
if (APPLE)
|
|
set_target_properties(Overte PROPERTIES FOLDER "Apps")
|
|
else()
|
|
set_target_properties(interface PROPERTIES FOLDER "Apps")
|
|
endif()
|
|
|
|
option(USE_SIXENSE "Build Interface with sixense library/plugin" OFF)
|
|
endif()
|
|
|
|
if (BUILD_CLIENT OR BUILD_SERVER)
|
|
add_subdirectory(plugins)
|
|
add_subdirectory(server-console)
|
|
endif()
|
|
|
|
endif()
|
|
|
|
if (BUILD_TESTS)
|
|
# Turn on testing so that add_test works
|
|
# MUST be in the root cmake file for ctest to work
|
|
include(CTest)
|
|
enable_testing()
|
|
add_subdirectory(tests)
|
|
if (BUILD_MANUAL_TESTS)
|
|
add_subdirectory(tests-manual)
|
|
endif()
|
|
endif()
|
|
|
|
if (BUILD_INSTALLER)
|
|
if (UNIX)
|
|
install(
|
|
DIRECTORY "${CMAKE_SOURCE_DIR}/scripts"
|
|
DESTINATION ${CMAKE_CURRENT_BINARY_DIR}/interface
|
|
COMPONENT ${CLIENT_COMPONENT}
|
|
)
|
|
endif()
|
|
generate_installers()
|
|
endif()
|
|
|
|
# QML import paths for Qt Creator and KDevelop code completion
|
|
set(QML_IMPORT_PATH ${CMAKE_SOURCE_DIR}/interface/resources/qml;${CMAKE_SOURCE_DIR}/launchers/qt/resources/qml CACHE PATH "Extra QML import paths for KDevelop and Qt Creator")
|