X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=CMakeLists.txt;h=e4276b470034b6f35d3ee466f67d8c76977e11d0;hb=e54e9fb019a185d9516b99d33d4c8aa8e44ccd7e;hp=0843a8ebb1e73f9a978540e5325cb9a64bb8817e;hpb=bb04ef30e802fa58550a0dec7b54e61aeefb0c7e;p=casparcg diff --git a/CMakeLists.txt b/CMakeLists.txt index 0843a8ebb..e4276b470 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -21,31 +21,49 @@ set(TBB_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/tbb/include") set(GLEW_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/glew/include") set(SFML_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/sfml/include") set(FREETYPE_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/freetype/include") -set(FFMPEG_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/ffmpeg/include") + +if (MSVC) + set(FFMPEG_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/ffmpeg/include" "${DEPENDENCIES_FOLDER}/ffmpeg/include-win32") +else () + set(FFMPEG_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/ffmpeg/include") +endif () + set(ASMLIB_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/asmlib") set(FREEIMAGE_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/freeimage/include") set(OPENAL_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/openal/include") set(BLUEFISH_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/bluefish/include") +set(CEF_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/cef/include") +set(GTEST_INCLUDE_PATH "${DEPENDENCIES_FOLDER}/gtest/include") + +if (MSVC) + set(PLATFORM_FOLDER_NAME "win32") +elseif (CMAKE_COMPILER_IS_GNUCXX) + set(PLATFORM_FOLDER_NAME "linux") +endif () -set(FFMPEG_BIN_PATH "${DEPENDENCIES_FOLDER}/ffmpeg/bin") -set(FREEIMAGE_BIN_PATH "${DEPENDENCIES_FOLDER}/freeimage/bin") -set(GLEW_BIN_PATH "${DEPENDENCIES_FOLDER}/glew/bin") -set(OPENAL_BIN_PATH "${DEPENDENCIES_FOLDER}/openal/bin") -set(TBB_BIN_PATH "${DEPENDENCIES_FOLDER}/tbb/bin") +set(FFMPEG_BIN_PATH "${DEPENDENCIES_FOLDER}/ffmpeg/bin/${PLATFORM_FOLDER_NAME}") +set(FREEIMAGE_BIN_PATH "${DEPENDENCIES_FOLDER}/freeimage/bin/${PLATFORM_FOLDER_NAME}") +set(GLEW_BIN_PATH "${DEPENDENCIES_FOLDER}/glew/bin/${PLATFORM_FOLDER_NAME}") +set(OPENAL_BIN_PATH "${DEPENDENCIES_FOLDER}/openal/bin/${PLATFORM_FOLDER_NAME}") +set(TBB_BIN_PATH "${DEPENDENCIES_FOLDER}/tbb/bin/${PLATFORM_FOLDER_NAME}") set(LIBERATION_FONTS_BIN_PATH "${DEPENDENCIES_FOLDER}/liberation-fonts") +set(CEF_PATH "${DEPENDENCIES_FOLDER}/cef") +set(CEF_BIN_PATH "${DEPENDENCIES_FOLDER}/cef/bin/${PLATFORM_FOLDER_NAME}") -link_directories("${DEPENDENCIES_FOLDER}/boost/stage/lib") -link_directories("${DEPENDENCIES_FOLDER}/tbb/lib") -link_directories("${DEPENDENCIES_FOLDER}/glew/lib") -link_directories("${DEPENDENCIES_FOLDER}/sfml/lib") +link_directories("${DEPENDENCIES_FOLDER}/boost/stage/lib/${PLATFORM_FOLDER_NAME}") +link_directories("${DEPENDENCIES_FOLDER}/tbb/lib/${PLATFORM_FOLDER_NAME}") +link_directories("${DEPENDENCIES_FOLDER}/glew/lib/${PLATFORM_FOLDER_NAME}") +link_directories("${DEPENDENCIES_FOLDER}/sfml/lib/${PLATFORM_FOLDER_NAME}") link_directories("${DEPENDENCIES_FOLDER}/sfml/extlibs/lib") link_directories("${DEPENDENCIES_FOLDER}/freetype/objs/win32/vc2010") -link_directories("${DEPENDENCIES_FOLDER}/ffmpeg/lib") +link_directories("${DEPENDENCIES_FOLDER}/ffmpeg/lib/${PLATFORM_FOLDER_NAME}") link_directories("${DEPENDENCIES_FOLDER}/asmlib") -link_directories("${DEPENDENCIES_FOLDER}/freeimage/lib") -link_directories("${DEPENDENCIES_FOLDER}/openal/lib") +link_directories("${DEPENDENCIES_FOLDER}/freeimage/lib/${PLATFORM_FOLDER_NAME}") +link_directories("${DEPENDENCIES_FOLDER}/openal/lib/${PLATFORM_FOLDER_NAME}") link_directories("${DEPENDENCIES_FOLDER}/bluefish/lib") link_directories("${DEPENDENCIES_FOLDER}/zlib/lib") +link_directories("${DEPENDENCIES_FOLDER}/cef/lib/${PLATFORM_FOLDER_NAME}") +link_directories("${DEPENDENCIES_FOLDER}/gtest/lib/${PLATFORM_FOLDER_NAME}") set_property(GLOBAL PROPERTY USE_FOLDERS ON) @@ -54,19 +72,89 @@ add_definitions( -DBOOST_THREAD_VERSION=4 ) add_definitions( -DTBB_USE_CAPTURED_EXCEPTION=0 ) add_definitions( -DUNICODE ) add_definitions( -D_UNICODE ) +add_definitions( -DGLEW_NO_GLU ) +add_definitions( "-DBOOST_ASIO_ERROR_CATEGORY_NOEXCEPT=noexcept(true)" ) # Workaround macro redefinition in boost +add_definitions( -D_GLIBCXX_USE_CXX11_ABI=0 ) # Allow compilation in GCC 5 while keeping old dependencies + +if (MSVC) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /EHa /Zi /W4 /WX /MP /fp:fast /Zm192 /FIcommon/compiler/vs/disable_silly_warnings.h") + set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /D TBB_USE_ASSERT=1 /D TBB_USE_DEBUG /bigobj") + set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /Oi /Ot /Gy /bigobj") + set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /Oi /Ot /Gy /bigobj /Ob2") +elseif (CMAKE_COMPILER_IS_GNUCXX) + set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "-O3 -g") + add_compile_options( -std=c++11 ) + add_compile_options( -msse3 ) + add_compile_options( -mssse3 ) + add_compile_options( -msse4.1 ) + add_compile_options( -pthread ) + add_compile_options( -fPIC ) + add_compile_options( -fnon-call-exceptions ) # Allow signal handler to throw exception + add_definitions( -DBOOST_NO_SWPRINTF ) # swprintf on Linux seems to always use , as decimal point regardless of C-locale or C++-locale +endif () -if (${MSVC}) - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /EHa /Zi /W4 /WX /MP /fp:fast /FIcommon/compiler/vs/disable_silly_warnings.h") - set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /D TBB_USE_ASSERT=1 /D TBB_USE_DEBUG /bigobj") - set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /Oi /Ot /Gy") +if (POLICY CMP0045) + cmake_policy(SET CMP0045 OLD) endif () -cmake_policy(SET CMP0045 OLD) include(CMake/PrecompiledHeader.cmake) +set(CASPARCG_MODULE_INCLUDE_STATEMENTS "" CACHE INTERNAL "") +set(CASPARCG_MODULE_INIT_STATEMENTS "" CACHE INTERNAL "") +set(CASPARCG_MODULE_UNINIT_STATEMENTS "" CACHE INTERNAL "") +set(CASPARCG_MODULE_COMMAND_LINE_ARG_INTERCEPTORS_STATEMENTS "" CACHE INTERNAL "") +set(CASPARCG_MODULE_PROJECTS "" CACHE INTERNAL "") +set(CASPARCG_RUNTIME_DEPENDENCIES "" CACHE INTERNAL "") + +function(casparcg_add_include_statement HEADER_FILE_TO_INCLUDE) + set(CASPARCG_MODULE_INCLUDE_STATEMENTS "${CASPARCG_MODULE_INCLUDE_STATEMENTS}" + "#include <${HEADER_FILE_TO_INCLUDE}>" + CACHE INTERNAL "") +endfunction() + +function(casparcg_add_init_statement INIT_FUNCTION_NAME NAME_TO_LOG) + set(CASPARCG_MODULE_INIT_STATEMENTS "${CASPARCG_MODULE_INIT_STATEMENTS}" + " ${INIT_FUNCTION_NAME}(dependencies)\;" + " CASPAR_LOG(info) << L\"Initialized ${NAME_TO_LOG} module.\"\;" + "" + CACHE INTERNAL "") +endfunction() + +function(casparcg_add_uninit_statement UNINIT_FUNCTION_NAME) + set(CASPARCG_MODULE_UNINIT_STATEMENTS + " ${UNINIT_FUNCTION_NAME}()\;" + "${CASPARCG_MODULE_UNINIT_STATEMENTS}" + CACHE INTERNAL "") +endfunction() + +function(casparcg_add_command_line_arg_interceptor INTERCEPTOR_FUNCTION_NAME) + set(CASPARCG_MODULE_COMMAND_LINE_ARG_INTERCEPTORS_STATEMENTS "${CASPARCG_MODULE_COMMAND_LINE_ARG_INTERCEPTORS_STATEMENTS}" + " if (${INTERCEPTOR_FUNCTION_NAME}(argc, argv))" + " return true\;" + "" + CACHE INTERNAL "") +endfunction() + +function(casparcg_add_module_project PROJECT) + set(CASPARCG_MODULE_PROJECTS "${CASPARCG_MODULE_PROJECTS}" "${PROJECT}" CACHE INTERNAL "") +endfunction() + +# http://stackoverflow.com/questions/7172670/best-shortest-way-to-join-a-list-in-cmake +function(join_list VALUES GLUE OUTPUT) + string (REGEX REPLACE "([^\\]|^);" "\\1${GLUE}" _TMP_STR "${VALUES}") + string (REGEX REPLACE "[\\](.)" "\\1" _TMP_STR "${_TMP_STR}") #fixes escaping + set (${OUTPUT} "${_TMP_STR}" PARENT_SCOPE) +endfunction() + +function(casparcg_add_runtime_dependency FILE_TO_COPY) + set(CASPARCG_RUNTIME_DEPENDENCIES "${CASPARCG_RUNTIME_DEPENDENCIES}" "${FILE_TO_COPY}" CACHE INTERNAL "") +endfunction() + add_subdirectory(accelerator) add_subdirectory(common) add_subdirectory(core) add_subdirectory(modules) + add_subdirectory(protocol) add_subdirectory(shell) +add_subdirectory(unit-test)