PandaVersion.cmake 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. # This file defines the current version number for Panda. It is read
  2. # by the top CMakeLists.txt, which puts it in the global namespace for
  3. # all CMake scripts for Panda.
  4. option(PANDA_OFFICIAL_VERSION
  5. "This variable will be defined to false in the CVS repository, but
  6. scripts that generate source tarballs and/or binary releases for
  7. distribution, by checking out Panda from an official CVS tag,
  8. should explictly set this to true. When false, it indicates that
  9. the current version of Panda was checked out from CVS, so it may
  10. not be a complete representation of the indicated version."
  11. OFF)
  12. set(PANDA_DISTRIBUTOR homebuilt CACHE STRING
  13. "This string is reported verbatim by PandaSystem::get_distributor().
  14. It should be set by whoever provides a particular distribution of
  15. Panda. If you build your own Panda, leave this unchanged.")
  16. set(PANDA_DIST_USE_LICENSES "BSD-3;BSD-2;MIT" CACHE STRING
  17. "This is a list of allowed licenses for 3rd-party packages to build
  18. support for when performing a Distribution build of Panda3d.
  19. Note: This only is checked for packages that CMake has declared with a
  20. particular license. Some packages don't have a listed license because
  21. they are almost always required/used, or because they are only used in
  22. plugins that can be easily removed (eg. directx, ffmpeg, fmod, ...).")
  23. set(PANDA_PACKAGE_VERSION CACHE STRING
  24. "This string is used to describe the Panda3D \"package\" associated
  25. with this current build of Panda. It should increment with major
  26. and minor version changes, but not sequence (or \"bugfix\") changes.
  27. It should be unique for each unique distributor. The default is
  28. the empty string, which means this build does not precisely match
  29. any distributable Panda3D packages. If you are making a Panda3D
  30. build which you will be using to produce a distributable Panda3D
  31. package, you should set this string appropriately.")
  32. set(P3D_PLUGIN_VERSION "1.0.4" CACHE STRING
  33. "We also define a version for the Panda3D plugin/runtime,
  34. i.e. nppanda3d.dll, p3dactivex.ocx, and panda3d.exe. This is an
  35. independent version number from PANDA_VERSION or
  36. PANDA_PACKAGE_VERSION, because it is anticipated that this plugin
  37. code, once settled, will need to be updated much less frequently
  38. than Panda itself.")
  39. set(P3D_COREAPI_VERSION "${P3D_PLUGIN_VERSION}.1" CACHE STRING
  40. "Finally, there's a separate version number for the Core API. At
  41. first, we didn't believe we needed a Core API version number, but
  42. in this belief we were naive. This version number is a little less
  43. strict in its format requirements than P3D_PLUGIN_VERSION, above,
  44. and it doesn't necessarily consist of a specific number of
  45. integers, but by convention it will consist of four integers, with
  46. the first three matching the plugin version, and the fourth integer
  47. being incremented with each new Core API revision.")
  48. mark_as_advanced(PANDA_VERSION PANDA_OFFICIAL_VERSION
  49. PANDA_PACKAGE_VERSION P3D_PLUGIN_VERSION P3D_COREAPI_VERSION
  50. PANDA_DIST_USE_LICENSES)
  51. # The version gets a "c" at the end if it's not an official one.
  52. if(PANDA_OFFICIAL_VERSION)
  53. set(VERSION_SUFFIX "")
  54. else()
  55. set(VERSION_SUFFIX "c")
  56. endif()
  57. set(PANDA_VERSION_STR "${PROJECT_VERSION}${VERSION_SUFFIX}")
  58. # This symbol is used to enforce ABI incompatibility between
  59. # major versions of Panda3D.
  60. set(PANDA_VERSION_SYMBOL panda_version_${PROJECT_VERSION_MAJOR}_${PROJECT_VERSION_MINOR})
  61. # The Panda version as a number, with three digits reserved
  62. # for each component.
  63. math(EXPR PANDA_NUMERIC_VERSION "${PROJECT_VERSION_MAJOR}*1000000 + ${PROJECT_VERSION_MINOR}*1000 + ${PROJECT_VERSION_PATCH}")
  64. # The Panda Git SHA1 refspec, for PandaSystem::get_git_commit()
  65. find_package(Git QUIET)
  66. if(GIT_EXECUTABLE)
  67. execute_process(
  68. COMMAND "${GIT_EXECUTABLE}" rev-parse HEAD
  69. WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}"
  70. OUTPUT_VARIABLE PANDA_GIT_COMMIT_STR
  71. ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE)
  72. endif()
  73. # Separate the plugin version into its three components.
  74. string(REPLACE "." ";" P3D_PLUGIN_VERSION_LIST "${P3D_PLUGIN_VERSION}")
  75. list(GET P3D_PLUGIN_VERSION_LIST 0 P3D_PLUGIN_MAJOR_VERSION)
  76. list(GET P3D_PLUGIN_VERSION_LIST 1 P3D_PLUGIN_MINOR_VERSION)
  77. list(GET P3D_PLUGIN_VERSION_LIST 2 P3D_PLUGIN_SEQUENCE_VERSION)
  78. set(P3D_PLUGIN_VERSION_STR "${P3D_PLUGIN_VERSION}${VERSION_SUFFIX}")
  79. # The plugin version as dot-delimited integer quad, according to MS
  80. # conventions for DLL version numbers.
  81. if(PANDA_OFFICIAL_VERSION)
  82. set(P3D_PLUGIN_DLL_DOT_VERSION "${P3D_PLUGIN_VERSION}.1000")
  83. else()
  84. set(P3D_PLUGIN_DLL_DOT_VERSION "${P3D_PLUGIN_VERSION}.0")
  85. endif()
  86. # The same thing as a comma-delimited quad.
  87. string(REPLACE "." "," P3D_PLUGIN_DLL_COMMA_VERSION "${P3D_PLUGIN_DLL_DOT_VERSION}")