diff options
Diffstat (limited to 'cmake')
-rw-r--r-- | cmake/install.cmake | 10 | ||||
-rw-r--r-- | cmake/protobuf-config-version.cmake.in | 35 |
2 files changed, 43 insertions, 2 deletions
diff --git a/cmake/install.cmake b/cmake/install.cmake index dbb4265d..e0962659 100644 --- a/cmake/install.cmake +++ b/cmake/install.cmake @@ -83,9 +83,15 @@ foreach(_file ${nobase_dist_proto_DATA}) endforeach() # Export configuration +set(_cmakedir_desc "Directory relative to CMAKE_INSTALL to install the cmake configuration files") +if(NOT MSVC) + set(CMAKE_INSTALL_CMAKEDIR "${CMAKE_INSTALL_LIBDIR}/cmake/protobuf" CACHE STRING "${_cmakedir_desc") +else() + set(CMAKE_INSTALL_CMAKEDIR "cmake" CACHE STRING "${_cmakedir_desc}") +endif() install(EXPORT protobuf-targets - DESTINATION "lib/cmake/protobuf" + DESTINATION "${CMAKE_INSTALL_CMAKEDIR}" COMPONENT protobuf-export) configure_file(protobuf-config.cmake.in @@ -99,5 +105,5 @@ install(FILES "${protobuf_BINARY_DIR}/protobuf-config.cmake" "${protobuf_BINARY_DIR}/protobuf-config-version.cmake" "${protobuf_BINARY_DIR}/protobuf-module.cmake" - DESTINATION "lib/cmake/protobuf" + DESTINATION "${CMAKE_INSTALL_CMAKEDIR}" COMPONENT protobuf-export) diff --git a/cmake/protobuf-config-version.cmake.in b/cmake/protobuf-config-version.cmake.in index 1f171c66..cc11037a 100644 --- a/cmake/protobuf-config-version.cmake.in +++ b/cmake/protobuf-config-version.cmake.in @@ -1 +1,36 @@ +# This is a basic version file for the Config-mode of find_package(). +# It is derived from the format suggested in the CMake module +# CMakePackageConfigHelpers. introduced in CMake 2.8.8. +# If the cmake_minimum_required version is ever bumped to 2.8.8 or +# above, this file may be deleted and replaced with a call to +# write_basic_package_version_file(...) + set(PACKAGE_VERSION @protobuf_VERSION@) + +if(PACKAGE_VERSION VERSION_LESS PACKAGE_FIND_VERSION) + set(PACKAGE_VERSION_COMPATIBLE FALSE) +else() + + if(PACKAGE_FIND_VERSION_MAJOR STREQUAL @protobuf_VERSION_MAJOR@) + set(PACKAGE_VERSION_COMPATIBLE TRUE) + else() + set(PACKAGE_VERSION_COMPATIBLE FALSE) + endif() + + if(PACKAGE_FIND_VERSION STREQUAL PACKAGE_VERSION) + set(PACKAGE_VERSION_EXACT TRUE) + endif() +endif() + + +# if the installed or the using project don't have CMAKE_SIZEOF_VOID_P set, ignore it: +if("${CMAKE_SIZEOF_VOID_P}" STREQUAL "" OR "@CMAKE_SIZEOF_VOID_P@" STREQUAL "") + return() +endif() + +# check that the installed version has the same 32/64bit-ness as the one which is currently searching: +if(NOT CMAKE_SIZEOF_VOID_P STREQUAL "@CMAKE_SIZEOF_VOID_P@") + math(EXPR installedBits "@CMAKE_SIZEOF_VOID_P@ * 8") + set(PACKAGE_VERSION "${PACKAGE_VERSION} (${installedBits}bit)") + set(PACKAGE_VERSION_UNSUITABLE TRUE) +endif() |