cmake_minimum_required(VERSION 3.5) project(FindPkgConfig_IMPORTED_TARGET C) find_package(PkgConfig REQUIRED) pkg_check_modules(NCURSES IMPORTED_TARGET QUIET ncurses) if (NCURSES_FOUND) set(tgt PkgConfig::NCURSES) if (NOT TARGET ${tgt}) message(FATAL_ERROR "FindPkgConfig found ncurses, but did not create an imported target for it") endif () set(prop_found FALSE) foreach (prop IN ITEMS INTERFACE_INCLUDE_DIRECTORIES INTERFACE_LINK_LIBRARIES INTERFACE_COMPILE_OPTIONS) get_target_property(value ${tgt} ${prop}) if (value) message(STATUS "Found property ${prop} on target: ${value}") set(prop_found TRUE) endif () endforeach () if (NOT prop_found) message(FATAL_ERROR "target ${tgt} found, but it has no properties") endif () else () message(STATUS "skipping test; ncurses not found") endif () # Setup for the remaining package tests below set(PKG_CONFIG_USE_CMAKE_PREFIX_PATH) set(fakePkgDir ${CMAKE_CURRENT_BINARY_DIR}/pc-fakepackage) foreach(i 1 2) set(pname cmakeinternalfakepackage${i}) file(WRITE ${fakePkgDir}/lib/lib${pname}.a "") file(WRITE ${fakePkgDir}/lib/${pname}.lib "") file(WRITE ${fakePkgDir}/lib/pkgconfig/${pname}.pc "Name: CMakeInternalFakePackage${i} Description: Dummy package (${i}) for FindPkgConfig IMPORTED_TARGET test Version: 1.2.3 Libs: -l${pname} ") endforeach() # Always find the .pc file in the calls further below so that we can test that # the import target find_library() calls handle the NO...PATH options correctly set(ENV{PKG_CONFIG_PATH} ${fakePkgDir}/lib/pkgconfig) # Confirm correct behavior of NO_CMAKE_PATH, ensuring we only find the library # for the imported target if we have both set CMAKE_PREFIX_PATH and have not # given the NO_CMAKE_PATH option unset(CMAKE_PREFIX_PATH) unset(ENV{CMAKE_PREFIX_PATH}) pkg_check_modules(FakePackage1 QUIET IMPORTED_TARGET cmakeinternalfakepackage1) if (TARGET PkgConfig::FakePackage1) message(FATAL_ERROR "Have import target for fake package 1 with no path prefix") endif() set(CMAKE_PREFIX_PATH ${fakePkgDir}) pkg_check_modules(FakePackage1 QUIET IMPORTED_TARGET NO_CMAKE_PATH cmakeinternalfakepackage1) if (TARGET PkgConfig::FakePackage1) message(FATAL_ERROR "Have import target for fake package 1 with ignored cmake path") endif() pkg_check_modules(FakePackage1 REQUIRED QUIET IMPORTED_TARGET cmakeinternalfakepackage1) if (NOT TARGET PkgConfig::FakePackage1) message(FATAL_ERROR "No import target for fake package 1 with prefix path") endif() # And now do the same for the NO_CMAKE_ENVIRONMENT_PATH - ENV{CMAKE_PREFIX_PATH} # combination unset(CMAKE_PREFIX_PATH) unset(ENV{CMAKE_PREFIX_PATH}) pkg_check_modules(FakePackage2 QUIET IMPORTED_TARGET cmakeinternalfakepackage2) if (TARGET PkgConfig::FakePackage2) message(FATAL_ERROR "Have import target for fake package 2 with no path prefix") endif() set(ENV{CMAKE_PREFIX_PATH} ${fakePkgDir}) pkg_check_modules(FakePackage2 QUIET IMPORTED_TARGET NO_CMAKE_ENVIRONMENT_PATH cmakeinternalfakepackage2) if (TARGET PkgConfig::FakePackage2) message(FATAL_ERROR "Have import target for fake package 2 with ignored cmake path") endif() pkg_check_modules(FakePackage2 REQUIRED QUIET IMPORTED_TARGET cmakeinternalfakepackage2) if (NOT TARGET PkgConfig::FakePackage2) message(FATAL_ERROR "No import target for fake package 2 with prefix path") endif() # check that the full library path is also returned if (NOT FakePackage2_LINK_LIBRARIES STREQUAL "${fakePkgDir}/lib/libcmakeinternalfakepackage2.a") message(FATAL_ERROR "FakePackage2_LINK_LIBRARIES has bad content on first run: ${FakePackage2_LINK_LIBRARIES}") endif() # the information in *_LINK_LIBRARIES is not cached, so ensure is also is present on second run unset(FakePackage2_LINK_LIBRARIES) pkg_check_modules(FakePackage2 REQUIRED QUIET IMPORTED_TARGET cmakeinternalfakepackage2) if (NOT FakePackage2_LINK_LIBRARIES STREQUAL "${fakePkgDir}/lib/libcmakeinternalfakepackage2.a") message(FATAL_ERROR "FakePackage2_LINK_LIBRARIES has bad content on second run: ${FakePackage2_LINK_LIBRARIES}") endif()