X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=CMakeLists.txt;h=83490d56b3d7e17c2230a6ccd0c7d9c725e25acc;hb=ea79919d0046555a2ecfba699c3b80439562120e;hp=09633c14f98a08fe2cf61f6dc2e45f4bad782b21;hpb=76efdcb9194d78a63307122570f9fa9c8ab62557;p=apitrace diff --git a/CMakeLists.txt b/CMakeLists.txt index 09633c1..83490d5 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -35,11 +35,17 @@ set (ENABLE_EGL true CACHE BOOL "Enable EGL support.") # Find dependencies # Ensure __thread is support -if (APPLE) +if (NOT MSVC) include (CheckCXXSourceCompiles) check_cxx_source_compiles("__thread int i; int main() { return 0; }" HAVE_COMPILER_TLS) if (NOT HAVE_COMPILER_TLS) - message (FATAL_ERROR "C++ compiler does not support __thread keyword. Please install XCode 4.5 or higher.") + if (APPLE) + message (FATAL_ERROR "C++ compiler does not support __thread keyword. Please install XCode 4.5 or higher.") + else (MINGW32) + message (FATAL_ERROR "C++ compiler does not support __thread keyword. Please use MinGW g++ version 4.4 or higher") + else () + message (FATAL_ERROR "C++ compiler does not support __thread keyword.") + endif () endif () endif () @@ -63,7 +69,6 @@ if (ENABLE_GUI) set (REQUIRE_GUI REQUIRED) endif () find_package (Qt4 4.7 COMPONENTS QtCore QtGui QtWebKit ${REQUIRE_GUI}) - find_package (QJSON ${REQUIRE_GUI}) endif () if (WIN32) @@ -77,6 +82,10 @@ else () if (X11_FOUND) include_directories (${X11_INCLUDE_DIR}) add_definitions (-DHAVE_X11) + else () + # Print a clear message when X11 is not found + include (FindPackageMessage) + find_package_message (X11 "Could not find X11" "") endif () endif () @@ -210,16 +219,12 @@ if (WIN32) add_subdirectory (thirdparty/less) endif () -# The Qt website provides binaries for Windows and MacOSX, and they are -# automatically found by cmake without any manual intervention. The situation -# for QJSON is substantially different: there are no binaries for QJSON -# available, and there is no standard installation directory that is detected -# by cmake. -# -# By bundling the QJSON source, we make it much more easier to build the GUI on -# Windows and MacOSX. But we only use the bundled sources when ENABLE_GUI is -# AUTO. -if (QT4_FOUND AND NOT QJSON_FOUND AND (ENABLE_GUI STREQUAL "AUTO")) +# Always use bundled QJSon. +# - The packaged versions QJson are very old, and do not support NaN/Infinity. +# - To make it easier to build the GUI on Windows and MacOSX, as there are no +# binaries at all. +if (QT4_FOUND) + add_definitions (-DQJSON_EXPORT=) add_subdirectory (thirdparty/qjson EXCLUDE_FROM_ALL) set (QJSON_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty) set (QJSON_LIBRARY_DIRS) @@ -322,7 +327,6 @@ add_library (common STATIC common/image_pnm.cpp common/image_png.cpp common/${os} - common/workqueue.cpp ) set_target_properties (common PROPERTIES