Merge commit 'dd2c7e902aa095fd7844329e38bca7cd7c51e6d9' into osx-refactor_sync-mplus Conflicts: cmake/FindWinHID.cmake
127 lines
3.3 KiB
CMake
127 lines
3.3 KiB
CMake
# - Find Microsoft DirectShow sample files, library, and headers.
|
|
#
|
|
# DIRECTSHOW_INCLUDE_DIRS - where to find needed include file
|
|
# DIRECTSHOW_BASECLASS_DIR- Directory containing the DirectShow baseclass sample code.
|
|
# DIRECTSHOW_FOUND - True if DirectShow found.
|
|
#
|
|
# Requires these CMake modules:
|
|
# FindPackageHandleStandardArgs (known included with CMake >=2.6.2)
|
|
#
|
|
# Initially in VRPN - Distributed under the Boost Software License, Version 1.0.
|
|
#
|
|
# Almost entirely re-written by:
|
|
# 2012 Ryan Pavlik <rpavlik@iastate.edu> <abiryan@ryand.net>
|
|
# http://academic.cleardefinition.com
|
|
# Iowa State University HCI Graduate Program/VRAC
|
|
#
|
|
# Copyright Iowa State University 2012.
|
|
# Distributed under the Boost Software License, Version 1.0.
|
|
# (See accompanying file LICENSE_1_0.txt or copy at
|
|
# http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
# Look for one of the sample files.
|
|
|
|
find_package(WindowsSDK)
|
|
find_package(DirectX QUIET)
|
|
|
|
set(DIRECTSHOW_WINDOWSSDK_ROOT
|
|
"${DIRECTSHOW_WINDOWSSDK_ROOT}"
|
|
CACHE
|
|
PATH
|
|
"A specific Windows SDK to use for DirectShow.")
|
|
|
|
if(MSVC AND CMAKE_CL_64)
|
|
set(DIRECTSHOW_LIB_SUBDIR /x64)
|
|
else()
|
|
set(DIRECTSHOW_LIB_SUBDIR)
|
|
endif()
|
|
|
|
set(_acceptable_winsdk)
|
|
if(WINDOWSSDK_FOUND)
|
|
foreach(_sdkdir ${WINDOWSSDK_DIRS})
|
|
if(EXISTS "${_sdkdir}/Samples/Multimedia/DirectShow/BaseClasses/streams.h"
|
|
AND EXISTS "${_sdkdir}/Lib${DIRECTSHOW_LIB_SUBDIR}/strmiids.lib"
|
|
AND EXISTS "${_sdkdir}/Include/DShow.h")
|
|
list(APPEND _acceptable_winsdk "${_sdkdir}")
|
|
endif()
|
|
endforeach()
|
|
endif()
|
|
|
|
find_path(DIRECTSHOW_BASECLASS_DIR
|
|
NAMES
|
|
streams.h
|
|
HINTS
|
|
"${DIRECTSHOW_WINDOWSSDK_ROOT}"
|
|
PATHS
|
|
${_acceptable_winsdk}
|
|
PATH_SUFFIXES
|
|
"Samples/Multimedia/DirectShow/BaseClasses")
|
|
|
|
find_path(DIRECTSHOW_WINDOWSSDK_INCLUDE_DIR
|
|
NAMES
|
|
DShow.h
|
|
HINTS
|
|
"${DIRECTSHOW_WINDOWSSDK_ROOT}"
|
|
PATHS
|
|
${_acceptable_winsdk}
|
|
PATH_SUFFIXES
|
|
"Include")
|
|
|
|
# This one we can grab from another SDK version.
|
|
find_path(DIRECTSHOW_QEDIT_INCLUDE_DIR
|
|
NAMES
|
|
qedit.h
|
|
HINTS
|
|
"${DIRECTSHOW_WINDOWSSDK_ROOT}"
|
|
PATHS
|
|
${WINDOWSSDK_DIRS}
|
|
PATH_SUFFIXES
|
|
"Include")
|
|
|
|
find_library(DIRECTSHOW_STRMIIDS_LIBRARY
|
|
NAMES
|
|
strmiids
|
|
HINTS
|
|
"${DIRECTSHOW_WINDOWSSDK_ROOT}"
|
|
PATHS
|
|
${_acceptable_winsdk}
|
|
PATH_SUFFIXES
|
|
"Lib${DIRECTSHOW_LIB_SUBDIR}")
|
|
|
|
include(FindPackageHandleStandardArgs)
|
|
find_package_handle_standard_args(DirectShow
|
|
DEFAULT_MSG
|
|
DIRECTSHOW_BASECLASS_DIR
|
|
DIRECTSHOW_WINDOWSSDK_INCLUDE_DIR
|
|
DIRECTSHOW_QEDIT_INCLUDE_DIR
|
|
DIRECTX_INCLUDE_DIR
|
|
DIRECTX_FOUND
|
|
DIRECTSHOW_STRMIIDS_LIBRARY)
|
|
|
|
if(DIRECTSHOW_FOUND)
|
|
set(DIRECTSHOW_INCLUDE_DIRS
|
|
# Baseclass must be before SDK so it gets the correct refclock.h
|
|
"${DIRECTSHOW_BASECLASS_DIR}"
|
|
"${DIRECTSHOW_WINDOWSSDK_INCLUDE_DIR}"
|
|
"${DIRECTX_INCLUDE_DIR}"
|
|
)
|
|
if(EXISTS "${DIRECTSHOW_WINDOWSSDK_INCLUDE_DIR}/atl/atlbase.h")
|
|
list(APPEND
|
|
DIRECTSHOW_INCLUDE_DIRS
|
|
"${DIRECTSHOW_WINDOWSSDK_INCLUDE_DIR}/atl")
|
|
endif()
|
|
if(NOT "${DIRECTSHOW_QEDIT_INCLUDE_DIR}" STREQUAL "${DIRECTSHOW_WINDOWSSDK_INCLUDE_DIR}")
|
|
# QEdit include dir might be an older SDK, so put it last.
|
|
list(APPEND DIRECTSHOW_INCLUDE_DIRS "${DIRECTSHOW_QEDIT_INCLUDE_DIR}")
|
|
endif()
|
|
|
|
set(DIRECTSHOW_LIBRARIES "${DIRECTSHOW_STRMIIDS_LIBRARY}")
|
|
|
|
mark_as_advanced(DIRECTSHOW_WINDOWSSDK_ROOT)
|
|
endif()
|
|
|
|
mark_as_advanced(DIRECTSHOW_BASECLASS_DIR
|
|
DIRECTSHOW_WINDOWSSDK_INCLUDE_DIR
|
|
DIRECTSHOW_QEDIT_INCLUDE_DIR
|
|
DIRECTSHOW_STRMIIDS_LIBRARY)
|