X-Git-Url: https://git.cworth.org/git?p=apitrace-tests;a=blobdiff_plain;f=CMakeLists.txt;h=2dff8574de0d8db7b37d5c3cc18e6d6b8c59d2e1;hp=9dee9dee82ae65888ff615c5fd15dca4e608e3f6;hb=883a8b3506e6818add1c162ce8de690afcfe79e3;hpb=609cb3a9519a3cd91f0975c95bfbc552fde707ca diff --git a/CMakeLists.txt b/CMakeLists.txt index 9dee9de..2dff857 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,5 +1,14 @@ cmake_minimum_required (VERSION 2.8) + +# Use clang on MacOSX. gcc doesn't support __thread key, and Apple has +# abandoned it for clang. This must be done before the project is defined. +if (APPLE) + set (CMAKE_C_COMPILER "clang") + set (CMAKE_CXX_COMPILER "clang++") +endif () + + project (apitrace-tests) find_path (APITRACE_SOURCE_DIR NAMES cmake/FindDirectX.cmake PATHS .. ../.. DOC "apitrace source tree" NO_DEFAULT_PATH) @@ -32,12 +41,25 @@ find_package (GLEW) if (WIN32) find_package (DirectX) -else () +elseif (PKG_CONFIG_FOUND) pkg_check_modules (EGL egl) pkg_check_modules (GLESV1 glesv1_cm) pkg_check_modules (GLESV2 glesv2) endif () +# Check for the presence of several python packages, which are needed to build +# generated tests. +execute_process( + COMMAND ${python} -c "import PIL" + OUTPUT_QUIET + ERROR_QUIET + RESULT_VARIABLE IMPORT_PIL_RESULT) +if (IMPORT_PIL_RESULT EQUAL 0) + set (PIL_FOUND 1) +else () + message (STATUS "python PIL module not found") +endif () + if (UNIX) link_libraries(m) endif (UNIX) @@ -81,3 +103,18 @@ enable_testing() add_subdirectory (apps) add_subdirectory (traces) +# FIXME: The tests in the cli directory are intended to be high-level +# tests of the apitrace command-line interface which would ideally be +# portable across all platforms. However, these tests all rely on +# doing image comparisons and the current implementation of the +# "apitrace dump-images" command relies on direct invocation of the +# glretrace command. +# +# Someday, we should have more unified commands for replaying traces, +# dumping images, etc. At that point these cli tests should be usable +# with all targets so that we can drop the "if (OPENGL_FOUND)" +# condition here. +if (OPENGL_FOUND AND PIL_FOUND) + add_subdirectory (cli) + add_subdirectory (trim_stress) +endif ()