cmake: Rework Findepoxy.cmake
This makes Findepoxy.cmake more upstreamable and easier to use.master
parent
5edfccac12
commit
d16c15301f
@ -1,34 +1,83 @@
|
|||||||
# - Try to find libepoxy
|
#.rst:
|
||||||
# Once done this will define
|
# Findepoxy
|
||||||
|
# ---------
|
||||||
#
|
#
|
||||||
# epoxy_FOUND - System has libepoxy
|
# Try to find libepoxy on a Unix system.
|
||||||
# epoxy_LIBRARY - The libepoxy library
|
#
|
||||||
# epoxy_INCLUDE_DIR - The libepoxy include dir
|
# This will define the following variables:
|
||||||
# epoxy_DEFINITIONS - Compiler switches required for using libepoxy
|
#
|
||||||
# epoxy_HAS_GLX - Whether GLX support is available
|
# ``epoxy_FOUND``
|
||||||
|
# True if (the requested version of) libepoxy is available
|
||||||
|
# ``epoxy_VERSION``
|
||||||
|
# The version of libepoxy
|
||||||
|
# ``epoxy_LIBRARIES``
|
||||||
|
# This should be passed to target_link_libraries() if the target is not
|
||||||
|
# used for linking
|
||||||
|
# ``epoxy_INCLUDE_DIRS``
|
||||||
|
# This should be passed to target_include_directories() if the target is not
|
||||||
|
# used for linking
|
||||||
|
# ``epoxy_DEFINITIONS``
|
||||||
|
# This should be passed to target_compile_options() if the target is not
|
||||||
|
# used for linking
|
||||||
|
# ``epoxy_HAS_GLX``
|
||||||
|
# True if GLX support is available
|
||||||
|
#
|
||||||
|
# If ``epoxy_FOUND`` is TRUE, it will also define the following imported target:
|
||||||
|
#
|
||||||
|
# ``epoxy::epoxy``
|
||||||
|
# The epoxy library
|
||||||
|
#
|
||||||
|
# In general we recommend using the imported target, as it is easier to use.
|
||||||
|
# Bear in mind, however, that if the target is in the link interface of an
|
||||||
|
# exported library, it must be made available by the package config file.
|
||||||
|
|
||||||
# SPDX-FileCopyrightText: 2014 Fredrik Höglund <fredrik@kde.org>
|
# SPDX-FileCopyrightText: 2014 Fredrik Höglund <fredrik@kde.org>
|
||||||
|
# SPDX-FileCopyrightText: 2020 Vlad Zahorodnii <vlad.zahorodnii@kde.org>
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: BSD-3-Clause
|
# SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
|
||||||
if (NOT WIN32)
|
find_package(PkgConfig)
|
||||||
find_package(PkgConfig)
|
pkg_check_modules(PKG_epoxy QUIET epoxy)
|
||||||
pkg_check_modules(PKG_epoxy QUIET epoxy)
|
|
||||||
|
|
||||||
set(epoxy_DEFINITIONS ${PKG_epoxy_CFLAGS})
|
set(epoxy_VERSION ${PKG_epoxy_VERSION})
|
||||||
|
set(epoxy_DEFINITIONS ${PKG_epoxy_CFLAGS})
|
||||||
|
|
||||||
find_path(epoxy_INCLUDE_DIR NAMES epoxy/gl.h HINTS ${PKG_epoxy_INCLUDEDIR} ${PKG_epoxy_INCLUDE_DIRS})
|
find_path(epoxy_INCLUDE_DIRS
|
||||||
find_library(epoxy_LIBRARY NAMES epoxy HINTS ${PKG_epoxy_LIBDIR} ${PKG_epoxy_LIBRARY_DIRS})
|
NAMES epoxy/gl.h
|
||||||
find_file(epoxy_GLX_HEADER NAMES epoxy/glx.h HINTS ${epoxy_INCLUDE_DIR})
|
HINTS ${PKG_epoxy_INCLUDEDIR} ${PKG_epoxy_INCLUDE_DIRS}
|
||||||
|
)
|
||||||
|
find_library(epoxy_LIBRARIES
|
||||||
|
NAMES epoxy
|
||||||
|
HINTS ${PKG_epoxy_LIBDIR} ${PKG_epoxy_LIBRARY_DIRS}
|
||||||
|
)
|
||||||
|
find_file(epoxy_GLX_HEADER NAMES epoxy/glx.h HINTS ${epoxy_INCLUDE_DIR})
|
||||||
|
|
||||||
if (epoxy_GLX_HEADER STREQUAL "epoxy_GLX_HEADER-NOTFOUND")
|
if (epoxy_GLX_HEADER STREQUAL "epoxy_GLX_HEADER-NOTFOUND")
|
||||||
set(epoxy_HAS_GLX FALSE CACHE BOOL "whether glx is available")
|
set(epoxy_HAS_GLX FALSE CACHE BOOL "whether glx is available")
|
||||||
else ()
|
else ()
|
||||||
set(epoxy_HAS_GLX TRUE CACHE BOOL "whether glx is available")
|
set(epoxy_HAS_GLX TRUE CACHE BOOL "whether glx is available")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
include(FindPackageHandleStandardArgs)
|
include(FindPackageHandleStandardArgs)
|
||||||
find_package_handle_standard_args(epoxy DEFAULT_MSG epoxy_LIBRARY epoxy_INCLUDE_DIR)
|
find_package_handle_standard_args(epoxy
|
||||||
|
FOUND_VAR epoxy_FOUND
|
||||||
|
REQUIRED_VARS epoxy_LIBRARIES epoxy_INCLUDE_DIRS
|
||||||
|
VERSION_VAR epoxy_VERSION
|
||||||
|
)
|
||||||
|
|
||||||
mark_as_advanced(epoxy_INCLUDE_DIR epoxy_LIBRARY epoxy_HAS_GLX)
|
if (epoxy_FOUND AND NOT TARGET epoxy::epoxy)
|
||||||
|
add_library(epoxy::epoxy UNKNOWN IMPORTED)
|
||||||
|
set_target_properties(epoxy::epoxy PROPERTIES
|
||||||
|
IMPORTED_LOCATION "${epoxy_LIBRARIES}"
|
||||||
|
INTERFACE_COMPILE_OPTIONS "${epoxy_DEFINITIONS}"
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${epoxy_INCLUDE_DIRS}"
|
||||||
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
mark_as_advanced(
|
||||||
|
epoxy_DEFINITIONS
|
||||||
|
epoxy_HAS_GLX
|
||||||
|
epoxy_INCLUDE_DIRS
|
||||||
|
epoxy_LIBRARIES
|
||||||
|
epoxy_VERSION
|
||||||
|
)
|
||||||
|
Loading…
Reference in New Issue