Browse Source

Merge pull request #1666 from yeswalrus/cmake-prerelease-examples

CMake Fix up prerelease version handling
Feng Xiao 9 years ago
parent
commit
4f93098eb3
2 changed files with 22 additions and 15 deletions
  1. 1 0
      cmake/examples.cmake
  2. 21 15
      cmake/protobuf-config-version.cmake.in

+ 1 - 0
cmake/examples.cmake

@@ -11,6 +11,7 @@ include(ExternalProject)
 
 
 # Internal utility function: Create a custom target representing a build of examples with custom options.
 # Internal utility function: Create a custom target representing a build of examples with custom options.
 function(add_examples_build NAME)
 function(add_examples_build NAME)
+
   ExternalProject_Add(${NAME}
   ExternalProject_Add(${NAME}
     PREFIX ${NAME}
     PREFIX ${NAME}
     SOURCE_DIR "${examples_dir}"
     SOURCE_DIR "${examples_dir}"

+ 21 - 15
cmake/protobuf-config-version.cmake.in

@@ -1,28 +1,35 @@
 set(PACKAGE_VERSION "@protobuf_VERSION@")
 set(PACKAGE_VERSION "@protobuf_VERSION@")
+set(${PACKAGE_FIND_NAME}_VERSION_PRERELEASE "@protobuf_VERSION_PRERELEASE@" PARENT_SCOPE)
+
+# Prerelease versions cannot be passed in directly via the find_package command,
+# so we allow users to specify it in a variable
+if(NOT DEFINED "${${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE}")
+  set("${${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE}" "")
+else()
+  set(PACKAGE_FIND_VERSION ${PACKAGE_FIND_VERSION}-${${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE})
+endif()
+set(PACKAGE_FIND_VERSION_PRERELEASE "${${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE}")
 
 
+# VERSION_EQUAL ignores the prerelease strings, so we use STREQUAL.
 if(PACKAGE_FIND_VERSION STREQUAL PACKAGE_VERSION)
 if(PACKAGE_FIND_VERSION STREQUAL PACKAGE_VERSION)
   set(PACKAGE_VERSION_EXACT TRUE)
   set(PACKAGE_VERSION_EXACT TRUE)
 endif()
 endif()
 
 
 set(PACKAGE_VERSION_COMPATIBLE TRUE) #Assume true until shown otherwise
 set(PACKAGE_VERSION_COMPATIBLE TRUE) #Assume true until shown otherwise
 
 
-# Handle prerelease versions
-set(PACKAGE_FIND_VERSION_PRERELEASE "${${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE}")
-if(NOT "@protobuf_VERSION_PRERELEASE@" STREQUAL "")
-  if(NOT ${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE)
+if(NOT PACKAGE_FIND_VERSION_MAJOR EQUAL "@protobuf_VERSION_MAJOR@")
+  set(PACKAGE_VERSION_COMPATIBLE FALSE)
+elseif(PACKAGE_FIND_VERSION VERSION_GREATER PACKAGE_VERSION)
+  set(PACKAGE_VERSION_COMPATIBLE FALSE)
+elseif(PACKAGE_FIND_VERSION VERSION_EQUAL PACKAGE_VERSION)
+  # Do not match prerelease versions to non-prerelease version requests.
+  if(NOT "@protobuf_VERSION_PRERELEASE@" STREQUAL "" AND PACKAGE_FIND_VERSION_PRERELEASE STREQUAL "")
+    message(AUTHOR_WARNING "To use this prerelease version of ${PACKAGE_FIND_NAME}, set ${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE to '@protobuf_VERSION_PRERELEASE@' or greater.")
     set(PACKAGE_VERSION_COMPATIBLE FALSE)
     set(PACKAGE_VERSION_COMPATIBLE FALSE)
-    message(AUTHOR_WARNING "To use this prerelease version of ${PACKAGE_FIND_NAME}, set ${PACKAGE_FIND_NAME}_FIND_VERSION_PRERELEASE to '@protobuf_VERSION_PRERELEASE@'.")
   endif()
   endif()
 
 
-  if(NOT "${PACKAGE_FIND_VERSION}-${PACKAGE_FIND_VERSION_PRERELEASE}" STREQUAL "${PACKAGE_VERSION}")
-    set(PACKAGE_VERSION_COMPATIBLE FALSE)
-  else()
-    set(PACKAGE_VERSION_EXACT TRUE)
-  endif()
-else()
-  if(NOT PACKAGE_FIND_VERSION_MAJOR EQUAL "@protobuf_VERSION_MAJOR@")
-    set(PACKAGE_VERSION_COMPATIBLE FALSE)
-  elseif(PACKAGE_FIND_VERSION VERSION_GREATER PACKAGE_VERSION)
+  # Not robustly SemVer compliant, but protobuf never uses '.' separated prerelease identifiers.
+  if(PACKAGE_FIND_VERSION_PRERELEASE STRGREATER "@protobuf_VERSION_PRERELEASE@")
     set(PACKAGE_VERSION_COMPATIBLE FALSE)
     set(PACKAGE_VERSION_COMPATIBLE FALSE)
   endif()
   endif()
 endif()
 endif()
@@ -49,4 +56,3 @@ if(NOT "${CMAKE_SIZEOF_VOID_P}" STREQUAL "" AND NOT "@CMAKE_SIZEOF_VOID_P@" STRE
   endif()
   endif()
 endif()
 endif()
 
 
-set(${PACKAGE_FIND_NAME}_VERSION_PRERELEASE "@protobuf_VERSION_PRERELEASE@" PARENT_SCOPE)