aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Merry <alex.merry@kde.org>2015-01-24 14:47:59 +0000
committerAlex Merry <alex.merry@kde.org>2015-01-24 14:47:59 +0000
commitd609e598170064b4ee65392177a9d07f4302698d (patch)
tree0d958c3148592f0510153499a5d8fcc2e6b943c4
parent959c374c022394a116e8ceb2b1fce2df11752068 (diff)
downloadextra-cmake-modules-d609e598170064b4ee65392177a9d07f4302698d.tar.gz
extra-cmake-modules-d609e598170064b4ee65392177a9d07f4302698d.tar.bz2
Revert "Add SameMajorVersionWithPreleases compat option to ecm_setup_version."
This reverts commit 959c374c022394a116e8ceb2b1fce2df11752068. I merged and pushed the wrong branch.
-rw-r--r--modules/BasicConfigVersion-SameMajorVersionWithPrereleases.cmake.in64
-rw-r--r--modules/ECMSetupVersion.cmake66
-rw-r--r--tests/ECMSetupVersionTest/CMakeLists.txt1
-rw-r--r--tests/ECMSetupVersionTest/old_version_file_prereleases/CMakeLists.txt189
-rw-r--r--tests/ECMSetupVersionTest/old_version_file_prereleases/main.c4
-rw-r--r--tests/test_helpers.cmake4
6 files changed, 8 insertions, 320 deletions
diff --git a/modules/BasicConfigVersion-SameMajorVersionWithPrereleases.cmake.in b/modules/BasicConfigVersion-SameMajorVersionWithPrereleases.cmake.in
deleted file mode 100644
index 6d4e16f4..00000000
--- a/modules/BasicConfigVersion-SameMajorVersionWithPrereleases.cmake.in
+++ /dev/null
@@ -1,64 +0,0 @@
-# This is a basic version file for the Config-mode of find_package().
-# It is used by write_basic_package_version_file() as input file for configure_file()
-# to create a version-file which can be installed along a config.cmake file.
-#
-# The created file sets PACKAGE_VERSION_EXACT if the current version string and
-# the requested version string are exactly the same and it sets
-# PACKAGE_VERSION_COMPATIBLE if the current version is >= requested version,
-# but only if the requested major version is the same as the current one EXCEPT
-# that all minor releases after (and including) @CVF_FIRST_PRERELEASE_VERSION@
-# are considered to be part of the next major release.
-#
-# The variables CVF_VERSION and CVF_FIRST_PRERELEASE_VERSION must be set before
-# calling configure_file().
-
-
-set(PACKAGE_VERSION "@CVF_VERSION@")
-
-if("${PACKAGE_VERSION}" VERSION_LESS "${PACKAGE_FIND_VERSION}" )
- set(PACKAGE_VERSION_COMPATIBLE FALSE)
-else()
-
- if("@CVF_VERSION@" MATCHES "^([0-9]+)\\.([0-9]+)(\\.|$)")
- set(CVF_VERSION_MAJOR "${CMAKE_MATCH_1}")
- set(CVF_VERSION_MINOR "${CMAKE_MATCH_2}")
- else()
- set(CVF_VERSION_MAJOR "@CVF_VERSION@")
- set(CVF_VERSION_MINOR "0")
- endif()
-
- set(_real_version_major "${CVF_VERSION_MAJOR}")
- if(NOT "${CVF_VERSION_MINOR}" LESS "@CVF_FIRST_PRERELEASE_VERSION@")
- math(EXPR _real_version_major "${CVF_VERSION_MAJOR}+1")
- endif()
-
- set(_real_find_version_major "${PACKAGE_FIND_VERSION_MAJOR}")
- if("${PACKAGE_FIND_VERSION_COUNT}" GREATER 1)
- if(NOT "${PACKAGE_FIND_VERSION_MINOR}" LESS "@CVF_FIRST_PRERELEASE_VERSION@")
- math(EXPR _real_find_version_major "${PACKAGE_FIND_VERSION_MAJOR}+1")
- endif()
- endif()
-
- if("${_real_find_version_major}" STREQUAL "${_real_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()
diff --git a/modules/ECMSetupVersion.cmake b/modules/ECMSetupVersion.cmake
index 5f738c53..b908f96e 100644
--- a/modules/ECMSetupVersion.cmake
+++ b/modules/ECMSetupVersion.cmake
@@ -10,9 +10,7 @@
# VARIABLE_PREFIX <prefix>
# [SOVERSION <soversion>]
# [VERSION_HEADER <filename>]
-# [PACKAGE_VERSION_FILE <filename>
-# [COMPATIBILITY <compat>
-# [FIRST_PRERELEASE_VERSION <prerelease_version>]]] )
+# [PACKAGE_VERSION_FILE <filename> [COMPATIBILITY <compat>]] )
#
# This parses a version string and sets up a standard set of version variables.
# It can optionally also create a C version header file and a CMake package
@@ -57,20 +55,9 @@
# file is created using the write_basic_package_version_file() macro provided by
# CMake. It should be installed in the same location as the Config.cmake file of
# the library so that it can be found by find_package(). If the filename is a
-# relative path, it is interpreted as relative to CMAKE_CURRENT_BINARY_DIR.
-#
-# The optional COMPATIBILITY option is similar to that accepted by
-# write_basic_package_version_file(), except that it defaults to
-# AnyNewerVersion if it is omitted, and it also accepts
-# ``SameMajorVersionWithPrereleases`` as a value, in which case the
-# ``FIRST_PRERELEASE_VERSION`` option must also be given. This versioning
-# system behaves like SameMajorVersion, except that it treats all x.y releases,
-# where y is at least ``<prerelease_version>``, as (x+1) releases. So if
-# ``<prerelease_version>`` is 90, a request for version 2.90.0 will be satisfied
-# by 3.1.0, while a request for 2.89.0 will not be. Note that in this scenario,
-# version 2.90.0 of the software will not satisfy requests for version 2, version
-# version 2.1.1 *or* version 3 of the software, as prereleases are not considered
-# unless explicitly requested.
+# relative path, it is interpreted as relative to CMAKE_CURRENT_BINARY_DIR. The
+# optional COMPATIBILITY option is forwarded to
+# write_basic_package_version_file(), and defaults to AnyNewerVersion.
#
# If CMake policy CMP0048 is NEW, an alternative form of the command is
# available::
@@ -106,47 +93,10 @@ include(CMakePackageConfigHelpers)
# save the location of the header template while CMAKE_CURRENT_LIST_DIR
# has the value we want
set(_ECM_SETUP_VERSION_HEADER_TEMPLATE "${CMAKE_CURRENT_LIST_DIR}/ECMVersionHeader.h.in")
-set(_ECM_PACKAGE_VERSION_TEMPLATE_DIR "${CMAKE_CURRENT_LIST_DIR}")
-
-# like write_basic_package_version_file from CMake, but
-# looks for our template files as well
-function(ecm_write_package_version_file _filename)
- set(options )
- set(oneValueArgs VERSION COMPATIBILITY FIRST_PRERELEASE_VERSION)
- set(multiValueArgs )
-
- cmake_parse_arguments(CVF "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
-
- if(CVF_UNPARSED_ARGUMENTS)
- message(FATAL_ERROR "Unknown keywords given to ecm_write_basic_package_version_file(): \"${CVF_UNPARSED_ARGUMENTS}\"")
- endif()
-
- set(versionTemplateFile "${_ECM_PACKAGE_VERSION_TEMPLATE_DIR}/BasicConfigVersion-${CVF_COMPATIBILITY}.cmake.in")
- if(NOT EXISTS "${versionTemplateFile}")
- write_basic_package_version_file("${_filename}" VERSION "${CVF_VERSION}" COMPATIBILITY "${CVF_COMPATIBILITY}")
- return()
- endif()
-
- if("${CVF_COMPATIBILITY}" STREQUAL "SameMajorVersionWithPrereleases")
- if("${CVF_FIRST_PRERELEASE_VERSION}" STREQUAL "")
- message(FATAL_ERROR "No FIRST_PRERELEASE_VERSION specified for ecm_write_basic_package_version_file()")
- endif()
- endif()
-
- if("${CVF_VERSION}" STREQUAL "")
- if ("${PROJECT_VERSION}" STREQUAL "")
- message(FATAL_ERROR "No VERSION specified for ecm_write_basic_package_version_file()")
- else()
- set(CVF_VERSION "${PROJECT_VERSION}")
- endif()
- endif()
-
- configure_file("${versionTemplateFile}" "${_filename}" @ONLY)
-endfunction()
function(ecm_setup_version _version)
set(options )
- set(oneValueArgs VARIABLE_PREFIX SOVERSION VERSION_HEADER PACKAGE_VERSION_FILE COMPATIBILITY FIRST_PRERELEASE_VERSION)
+ set(oneValueArgs VARIABLE_PREFIX SOVERSION VERSION_HEADER PACKAGE_VERSION_FILE COMPATIBILITY)
set(multiValueArgs )
cmake_parse_arguments(ESV "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
@@ -230,11 +180,7 @@ function(ecm_setup_version _version)
if(NOT ESV_COMPATIBILITY)
set(ESV_COMPATIBILITY AnyNewerVersion)
endif()
- ecm_write_package_version_file("${ESV_PACKAGE_VERSION_FILE}"
- VERSION ${_version}
- COMPATIBILITY ${ESV_COMPATIBILITY}
- FIRST_PRERELEASE_VERSION "${ESV_FIRST_PRERELEASE_VERSION}"
- )
+ write_basic_package_version_file("${ESV_PACKAGE_VERSION_FILE}" VERSION ${_version} COMPATIBILITY ${ESV_COMPATIBILITY})
endif()
if(should_set_prefixed_vars)
diff --git a/tests/ECMSetupVersionTest/CMakeLists.txt b/tests/ECMSetupVersionTest/CMakeLists.txt
index c15af921..b0845e57 100644
--- a/tests/ECMSetupVersionTest/CMakeLists.txt
+++ b/tests/ECMSetupVersionTest/CMakeLists.txt
@@ -19,7 +19,6 @@ add_version_test(old_version_file dummy)
add_version_test(old_version_file_abspath dummy)
add_version_test(old_version_file_anynewer dummy)
add_version_test(old_version_file_exact dummy)
-add_version_test(old_version_file_prereleases dummy)
add_version_test(old_version_file_samemajor dummy)
add_version_test(old_header check_header)
add_version_test(old_header_abspath check_header)
diff --git a/tests/ECMSetupVersionTest/old_version_file_prereleases/CMakeLists.txt b/tests/ECMSetupVersionTest/old_version_file_prereleases/CMakeLists.txt
deleted file mode 100644
index e498fce6..00000000
--- a/tests/ECMSetupVersionTest/old_version_file_prereleases/CMakeLists.txt
+++ /dev/null
@@ -1,189 +0,0 @@
-cmake_minimum_required(VERSION 2.8.12)
-
-project(old_version_file_prereleases)
-
-set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../modules)
-include(ECMSetupVersion)
-
-ecm_setup_version(2.3.4
- VARIABLE_PREFIX Foo
- PACKAGE_VERSION_FILE FooVersion.cmake
- COMPATIBILITY SameMajorVersionWithPrereleases
- FIRST_PRERELEASE_VERSION 90
-)
-
-include(../../test_helpers.cmake)
-include(../version_helpers.cmake)
-
-macro(find_foo version)
- test_version_file("${CMAKE_CURRENT_BINARY_DIR}/FooVersion.cmake" "${version}")
- assert_var_str_value(PACKAGE_VERSION "2.3.4")
-endmacro()
-
-standard_version_var_checks(Foo 2.3.4)
-
-# too old - fails
-find_foo("3.1.1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("1.1.1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# prerelease for wrong major version - fails
-find_foo("2.90.0")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# prerelease for correct major version - succeeds
-find_foo("1.90")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# prerelease for correct major version - succeeds
-find_foo("1.90.1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# prerelease for correct major version - succeeds
-find_foo("1.95.0")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# correct major version, more recent - succeeds
-find_foo("2.1.1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# correct major version - succeeds
-find_foo("2")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# correct major version, but too old - fails
-find_foo("2.4.4")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# exact - succeeds
-find_foo("2.3.4")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT TRUE)
-
-
-
-
-ecm_setup_version(2.90.0
- VARIABLE_PREFIX Foo3Prerelease
- PACKAGE_VERSION_FILE Foo3PrereleaseVersion.cmake
- COMPATIBILITY SameMajorVersionWithPrereleases
- FIRST_PRERELEASE_VERSION 90
-)
-
-macro(find_foo version)
- test_version_file("${CMAKE_CURRENT_BINARY_DIR}/Foo3PrereleaseVersion.cmake" "${version}")
- assert_var_str_value(PACKAGE_VERSION "2.90.0")
-endmacro()
-
-standard_version_var_checks(Foo3Prerelease 2.90.0)
-
-# too old - fails
-find_foo("3.1.1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# too old - fails
-find_foo("2.90.1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("2")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# correct major version, but don't want a prerelease - fails
-find_foo("3")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("2.89.9")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# exact version - succeeds
-find_foo("2.90.0")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT TRUE)
-
-
-
-
-ecm_setup_version(2.93.4
- VARIABLE_PREFIX Foo3Prerelease2
- PACKAGE_VERSION_FILE Foo3Prerelease2Version.cmake
- COMPATIBILITY SameMajorVersionWithPrereleases
- FIRST_PRERELEASE_VERSION 90
-)
-
-macro(find_foo version)
- test_version_file("${CMAKE_CURRENT_BINARY_DIR}/Foo3Prerelease2Version.cmake" "${version}")
- assert_var_str_value(PACKAGE_VERSION "2.93.4")
-endmacro()
-
-standard_version_var_checks(Foo3Prerelease2 2.93.4)
-
-# too old - fails
-find_foo("3.1.1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# too old - fails
-find_foo("2.94.0")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("1")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("2")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# correct major version, but don't want a prerelease - fails
-find_foo("3")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# wrong major version - fails
-find_foo("2.89.9")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE FALSE ALLOW_UNDEFINED)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# correct major version - succeeds
-find_foo("2.90.0")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT FALSE ALLOW_UNDEFINED)
-
-# exact version - succeeds
-find_foo("2.93.4")
-assert_var_bool_value(PACKAGE_VERSION_COMPATIBLE TRUE)
-assert_var_bool_value(PACKAGE_VERSION_EXACT TRUE)
-
-add_executable(dummy main.c)
diff --git a/tests/ECMSetupVersionTest/old_version_file_prereleases/main.c b/tests/ECMSetupVersionTest/old_version_file_prereleases/main.c
deleted file mode 100644
index c13815ce..00000000
--- a/tests/ECMSetupVersionTest/old_version_file_prereleases/main.c
+++ /dev/null
@@ -1,4 +0,0 @@
-int main()
-{
- return 0;
-}
diff --git a/tests/test_helpers.cmake b/tests/test_helpers.cmake
index 236a1868..73be343e 100644
--- a/tests/test_helpers.cmake
+++ b/tests/test_helpers.cmake
@@ -38,9 +38,9 @@ macro(assert_var_bool_value varname value)
assert_var_defined(${varname})
endif()
if(${value} AND NOT ${varname})
- message(SEND_ERROR "${varname} was FALSE")
+ message(FATAL_ERROR "${varname} was FALSE")
elseif(${varname} AND NOT ${value})
- message(SEND_ERROR "${varname} was TRUE")
+ message(FATAL_ERROR "${varname} was TRUE")
endif()
endmacro()