X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=CMakeLists.txt;h=033d9fe5359079eb211266aa2e73bf1a91edf5cc;hb=af7fc5cf9847b5622dcb0901cce7199df80c101d;hp=28c86d372dfaf108f64110251bc5fc6808777035;hpb=fe806cb6c3a13071126f4eff4bcb8a28d8b0b777;p=apitrace diff --git a/CMakeLists.txt b/CMakeLists.txt old mode 100755 new mode 100644 index 28c86d3..033d9fe --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -75,8 +75,8 @@ else (WIN32) CHECK_CXX_COMPILER_FLAG("-fvisibility=hidden" CXX_COMPILER_FLAG_VISIBILITY) if (CXX_COMPILER_FLAG_VISIBILITY) add_definitions ("-fvisibility=hidden") - endif (CXX_COMPILER_FLAG_VISIBILITY) -endif (WIN32) + endif () +endif () if (MSVC) # C99 includes for msvc @@ -92,13 +92,15 @@ if (MSVC) add_definitions (-D_CRT_SECURE_NO_DEPRECATE -D_CRT_SECURE_NO_WARNINGS -D_CRT_NONSTDC_NO_WARNINGS) add_definitions (-D_SCL_SECURE_NO_DEPRECATE -D_SCL_SECURE_NO_WARNINGS) add_definitions (-W4) + # XXX: it's safer to use ssize_t everywhere instead of disabling warning + add_definitions (-wd4018) # signed/unsigned mismatch add_definitions (-wd4063) # not a valid value for switch of enum + add_definitions (-wd4100) # unreferenced formal parameter add_definitions (-wd4127) # conditional expression is constant add_definitions (-wd4244) # conversion from 'type1' to 'type2', possible loss of data add_definitions (-wd4505) # unreferenced local function has been removed + add_definitions (-wd4512) # assignment operator could not be generated add_definitions (-wd4800) # forcing value to bool 'true' or 'false' (performance warning) - # XXX: it's safer to use ssize_t everywhere instead of disabling warning - add_definitions (-wd4018) # signed/unsigned mismatch # Use static runtime # http://www.cmake.org/Wiki/CMake_FAQ#How_can_I_build_my_MSVC_application_with_a_static_runtime.3F @@ -108,7 +110,7 @@ if (MSVC) ) if (${flag_var} MATCHES "/MD") string (REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}") - endif (${flag_var} MATCHES "/MD") + endif () endforeach (flag_var) else () # Adjust warnings @@ -237,17 +239,6 @@ include_directories ( ${CMAKE_CURRENT_SOURCE_DIR}/common ) -add_custom_command ( - OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/glproc.hpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/glproc.py > ${CMAKE_CURRENT_BINARY_DIR}/glproc.hpp - DEPENDS glproc.py dispatch.py specs/wglapi.py specs/glxapi.py specs/cglapi.py specs/eglapi.py specs/glesapi.py specs/glapi.py specs/gltypes.py specs/stdapi.py -) - -# Wrap glproc.hpp as a target to prevent the command from being executed -# multiple times simulatenously, when the targets that depend on it are built -# in parallel. -add_custom_target (glproc DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/glproc.hpp) - if (WIN32) set (os os_win32.cpp) set (glws_os glws_wgl.cpp) @@ -296,380 +287,12 @@ endif () ############################################################################## -# API tracers - -if (WIN32) - if (MINGW) - # Silence warnings about @nn suffix mismatch - set (CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--enable-stdcall-fixup") - endif (MINGW) - - # ddraw.dll - if (DirectX_D3D_INCLUDE_DIR) - include_directories (SYSTEM ${DirectX_D3D_INCLUDE_DIR}) - add_custom_command ( - OUTPUT ddrawtrace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/ddrawtrace.py > ${CMAKE_CURRENT_BINARY_DIR}/ddrawtrace.cpp - DEPENDS ddrawtrace.py trace.py specs/d3d.py specs/d3dtypes.py specs/d3dcaps.py specs/ddraw.py specs/winapi.py specs/stdapi.py - ) - add_library (ddraw MODULE specs/ddraw.def ddrawtrace.cpp) - target_link_libraries (ddraw - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ) - set_target_properties (ddraw - PROPERTIES PREFIX "" - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - install (TARGETS ddraw LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) - endif (DirectX_D3D_INCLUDE_DIR) - - # d3d8.dll - if (DirectX_D3D8_INCLUDE_DIR AND DirectX_D3DX9_INCLUDE_DIR) - include_directories (SYSTEM ${DirectX_D3D8_INCLUDE_DIR} ${DirectX_D3DX9_INCLUDE_DIR}) - add_custom_command ( - OUTPUT d3d8trace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/d3d8trace.py > ${CMAKE_CURRENT_BINARY_DIR}/d3d8trace.cpp - DEPENDS d3d8trace.py trace.py specs/d3d8.py specs/d3d8types.py specs/d3d8caps.py specs/winapi.py specs/stdapi.py - ) - add_library (d3d8 MODULE specs/d3d8.def d3d8trace.cpp d3dshader.cpp) - target_link_libraries (d3d8 - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ) - set_target_properties (d3d8 - PROPERTIES PREFIX "" - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - install (TARGETS d3d8 LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) - endif (DirectX_D3D8_INCLUDE_DIR AND DirectX_D3DX9_INCLUDE_DIR) - - # d3d9.dll - if (DirectX_D3DX9_INCLUDE_DIR) - include_directories (SYSTEM ${DirectX_D3DX9_INCLUDE_DIR}) - add_custom_command ( - OUTPUT d3d9trace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/d3d9trace.py > ${CMAKE_CURRENT_BINARY_DIR}/d3d9trace.cpp - DEPENDS d3d9trace.py trace.py specs/d3d9.py specs/d3d9types.py specs/d3d9caps.py specs/winapi.py specs/stdapi.py - ) - add_library (d3d9 MODULE specs/d3d9.def d3d9trace.cpp d3dshader.cpp) - target_link_libraries (d3d9 - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ) - set_target_properties (d3d9 - PROPERTIES PREFIX "" - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - install (TARGETS d3d9 LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) - endif (DirectX_D3DX9_INCLUDE_DIR) - - # d3d10.dll - if (DirectX_D3D10_INCLUDE_DIR) - include_directories (SYSTEM ${DirectX_D3D10_INCLUDE_DIR}) - add_custom_command ( - OUTPUT d3d10trace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/d3d10trace.py > ${CMAKE_CURRENT_BINARY_DIR}/d3d10trace.cpp - DEPENDS d3d10trace.py trace.py specs/d3d10misc.py specs/d3d10.py specs/d3d10sdklayers.py specs/dxgi.py specs/dxgitype.py specs/dxgiformat.py specs/winapi.py specs/stdapi.py - ) - add_library (d3d10 MODULE specs/d3d10.def d3d10trace.cpp) - target_link_libraries (d3d10 - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ) - set_target_properties (d3d10 - PROPERTIES PREFIX "" - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - install (TARGETS d3d10 LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) - endif (DirectX_D3D10_INCLUDE_DIR) - - # d3d10_1.dll - if (DirectX_D3D10_INCLUDE_DIR) - include_directories (SYSTEM ${DirectX_D3D10_INCLUDE_DIR}) - add_custom_command ( - OUTPUT d3d10_1trace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/d3d10_1trace.py > ${CMAKE_CURRENT_BINARY_DIR}/d3d10_1trace.cpp - DEPENDS d3d10_1trace.py trace.py specs/d3d10_1.py specs/d3d10.py specs/d3d10sdklayers.py specs/dxgi.py specs/dxgitype.py specs/dxgiformat.py specs/winapi.py specs/stdapi.py - ) - add_library (d3d10_1 MODULE specs/d3d10_1.def d3d10_1trace.cpp) - target_link_libraries (d3d10_1 - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ) - set_target_properties (d3d10_1 - PROPERTIES PREFIX "" - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - install (TARGETS d3d10_1 LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) - endif (DirectX_D3D10_INCLUDE_DIR) - - # opengl32.dll - add_custom_command ( - OUTPUT wgltrace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/wgltrace.py > ${CMAKE_CURRENT_BINARY_DIR}/wgltrace.cpp - DEPENDS wgltrace.py gltrace.py trace.py specs/wglapi.py specs/wglenum.py specs/glapi.py specs/glparams.py specs/gltypes.py specs/winapi.py specs/stdapi.py - ) - add_library (wgltrace MODULE specs/opengl32.def - wgltrace.cpp - glcaps.cpp - glproc_gl.cpp - ) - add_dependencies (wgltrace glproc) - target_link_libraries (wgltrace - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ) - set_target_properties (wgltrace PROPERTIES - PREFIX "" - OUTPUT_NAME opengl32 - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - install (TARGETS wgltrace LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) - -elseif (APPLE) - # OpenGL framework - add_custom_command ( - OUTPUT cgltrace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/cgltrace.py > ${CMAKE_CURRENT_BINARY_DIR}/cgltrace.cpp - DEPENDS cgltrace.py gltrace.py trace.py specs/cglapi.py specs/glapi.py specs/glparams.py specs/gltypes.py specs/stdapi.py - ) - - add_library (cgltrace SHARED - cgltrace.cpp - glcaps.cpp - glproc_gl.cpp - ) - - add_dependencies (cgltrace glproc) - - set_target_properties (cgltrace PROPERTIES - # OpenGL framework name - PREFIX "" OUTPUT_NAME "OpenGL" SUFFIX "" - # Specificy the version and reexport GLU symbols - LINK_FLAGS "-compatibility_version 1 -current_version 1.0.0 -Wl,-reexport_library,/System/Library/Frameworks/OpenGL.framework/Versions/A/Libraries/libGLU.dylib" - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - - target_link_libraries (cgltrace - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ${CMAKE_THREAD_LIBS_INIT} - dl - ) - - install (TARGETS cgltrace LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) -elseif (X11_FOUND) - # libGL.so - add_custom_command ( - OUTPUT glxtrace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/glxtrace.py > ${CMAKE_CURRENT_BINARY_DIR}/glxtrace.cpp - DEPENDS glxtrace.py gltrace.py trace.py specs/glxapi.py specs/glapi.py specs/glparams.py specs/gltypes.py specs/stdapi.py - ) - - add_library (glxtrace SHARED - glxtrace.cpp - glcaps.cpp - glproc_gl.cpp - ) - - add_dependencies (glxtrace glproc) - - set_target_properties (glxtrace PROPERTIES - # avoid the default "lib" prefix - PREFIX "" - # Prevent symbol relocations internal to our wrapper library to be - # overwritten by the application. - LINK_FLAGS "-Wl,-Bsymbolic -Wl,-Bsymbolic-functions" - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - - target_link_libraries (glxtrace - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ${X11_X11_LIB} - ${CMAKE_THREAD_LIBS_INIT} - dl - ) - - install (TARGETS glxtrace LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) -endif () - - -if (ENABLE_EGL AND NOT WIN32 AND NOT APPLE) - # libEGL.so/libGL.so - add_custom_command ( - OUTPUT egltrace.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/egltrace.py > ${CMAKE_CURRENT_BINARY_DIR}/egltrace.cpp - DEPENDS egltrace.py gltrace.py trace.py specs/eglapi.py specs/glesapi.py specs/glapi.py specs/glparams.py specs/gltypes.py specs/stdapi.py - ) - - add_library (egltrace SHARED - egltrace.cpp - glcaps.cpp - glproc_egl.cpp - ) - - add_dependencies (egltrace glproc) - - set_target_properties (egltrace PROPERTIES - # avoid the default "lib" prefix - PREFIX "" - LINK_FLAGS "-Wl,-Bsymbolic -Wl,-Bsymbolic-functions" - # Prevent symbol relocations internal to our wrapper library to be - # overwritten by the application. - RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/wrappers - ) - - target_link_libraries (egltrace - common - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ${CMAKE_THREAD_LIBS_INIT} - dl - ) - - install (TARGETS egltrace LIBRARY DESTINATION ${WRAPPER_INSTALL_DIR}) -endif () - -############################################################################## -# API retracers - -add_custom_command ( - OUTPUT glretrace_gl.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/glretrace.py > ${CMAKE_CURRENT_BINARY_DIR}/glretrace_gl.cpp - DEPENDS glretrace.py retrace.py specs/glapi.py specs/gltypes.py specs/stdapi.py -) - -add_custom_command ( - OUTPUT glstate_params.cpp - COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/glstate_params.py > ${CMAKE_CURRENT_BINARY_DIR}/glstate_params.cpp - DEPENDS glstate_params.py specs/glparams.py specs/gltypes.py specs/stdapi.py -) - -add_library (retrace_common - glretrace_gl.cpp - glretrace_cgl.cpp - glretrace_glx.cpp - glretrace_wgl.cpp - glretrace_egl.cpp - glretrace_main.cpp - glstate.cpp - glstate_images.cpp - glstate_params.cpp - glstate_shaders.cpp - retrace.cpp - retrace_stdc.cpp - glws.cpp -) +# Sub-directories -add_dependencies (retrace_common glproc) +add_subdirectory (dispatch) +add_subdirectory (wrappers) +add_subdirectory (retrace) -set_property ( - TARGET retrace_common - APPEND - PROPERTY COMPILE_DEFINITIONS "RETRACE" -) - -if (WIN32 OR APPLE OR X11_FOUND) - add_executable (glretrace - ${glws_os} - glproc_gl.cpp - ) - - add_dependencies (glretrace glproc) - - set_property ( - TARGET glretrace - APPEND - PROPERTY COMPILE_DEFINITIONS "RETRACE" - ) - - target_link_libraries (glretrace - retrace_common - common - ${PNG_LIBRARIES} - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ) - - if (WIN32) - else () - if (APPLE) - target_link_libraries (glretrace - "-framework Cocoa" - "-framework ApplicationServices" # CGS* - #"-framework OpenGL" # CGL* - ) - else () - target_link_libraries (glretrace ${X11_X11_LIB}) - endif () - - target_link_libraries (glretrace - # gdb doesn't like when pthreads is loaded through dlopen (which happens - # when dlopen'ing libGL), so link pthreads to avoid this issue. See also - # http://stackoverflow.com/questions/2702628/gdb-cannot-find-new-threads-generic-error - ${CMAKE_THREAD_LIBS_INIT} - dl - ) - - if (${CMAKE_SYSTEM_NAME} MATCHES "Linux") - target_link_libraries (glretrace rt) - endif () - - endif () - - install (TARGETS glretrace RUNTIME DESTINATION bin) -endif () - -if (ENABLE_EGL AND X11_FOUND AND NOT WIN32 AND NOT APPLE) - add_executable (eglretrace - glws_egl_xlib.cpp - glproc_egl.cpp - ) - - add_dependencies (eglretrace glproc) - - set_property ( - TARGET eglretrace - APPEND - PROPERTY COMPILE_DEFINITIONS "RETRACE" - ) - - target_link_libraries (eglretrace - retrace_common - common - ${PNG_LIBRARIES} - ${ZLIB_LIBRARIES} - ${SNAPPY_LIBRARIES} - ${X11_X11_LIB} - ${CMAKE_THREAD_LIBS_INIT} - dl - ) - - if (${CMAKE_SYSTEM_NAME} MATCHES "Linux") - target_link_libraries (eglretrace rt) - endif () - - install (TARGETS eglretrace RUNTIME DESTINATION bin) -endif () ############################################################################## # CLI