chore(versioning): improve version script with enhanced validation and refactored command handling

This commit is contained in:
Mathis HERRIOT
2026-01-20 11:57:24 +01:00
parent 9699127739
commit afc18b555a

View File

@@ -17,10 +17,13 @@ endfunction()
# Fonction pour incrémenter la version SemVer # Fonction pour incrémenter la version SemVer
function(increment_version CURRENT_VERSION TYPE OUT_VAR) function(increment_version CURRENT_VERSION TYPE OUT_VAR)
string(REPLACE "." ";" VERSION_LIST ${CURRENT_VERSION}) if(CURRENT_VERSION MATCHES "^([0-9]+)\\.([0-9]+)\\.([0-9]+)")
list(GET VERSION_LIST 0 MAJOR) set(MAJOR ${CMAKE_MATCH_1})
list(GET VERSION_LIST 1 MINOR) set(MINOR ${CMAKE_MATCH_2})
list(GET VERSION_LIST 2 PATCH) set(PATCH ${CMAKE_MATCH_3})
else()
message(FATAL_ERROR "Format de version invalide: ${CURRENT_VERSION}. Attendu: X.Y.Z")
endif()
if("${TYPE}" STREQUAL "MAJOR") if("${TYPE}" STREQUAL "MAJOR")
math(EXPR MAJOR "${MAJOR} + 1") math(EXPR MAJOR "${MAJOR} + 1")
@@ -70,40 +73,42 @@ function(set_new_version NEW_VERSION)
endif() endif()
endforeach() endforeach()
# Demander à l'utilisateur s'il veut tagger (ou le faire par défaut si spécifié) # Créer le tag git
create_git_tag(${NEW_VERSION}) create_git_tag(${NEW_VERSION})
endfunction() endfunction()
# Logique principale # Logique principale
set(ARG_OFFSET 0) if(CMAKE_SCRIPT_MODE_FILE STREQUAL CMAKE_CURRENT_LIST_FILE)
while(ARG_OFFSET LESS CMAKE_ARGC) set(ARG_OFFSET 0)
if("${CMAKE_ARGV${ARG_OFFSET}}" STREQUAL "-P") while(ARG_OFFSET LESS CMAKE_ARGC)
math(EXPR COMMAND_INDEX "${ARG_OFFSET} + 2") if("${CMAKE_ARGV${ARG_OFFSET}}" STREQUAL "-P")
math(EXPR VERSION_INDEX "${ARG_OFFSET} + 3") math(EXPR COMMAND_INDEX "${ARG_OFFSET} + 2")
break() math(EXPR VERSION_INDEX "${ARG_OFFSET} + 3")
break()
endif()
math(EXPR ARG_OFFSET "${ARG_OFFSET} + 1")
endwhile()
if(NOT DEFINED COMMAND_INDEX OR COMMAND_INDEX GREATER_EQUAL CMAKE_ARGC)
message(FATAL_ERROR "Usage: cmake -P version.cmake [GET|SET|PATCH|MINOR|MAJOR] [new_version]")
endif() endif()
math(EXPR ARG_OFFSET "${ARG_OFFSET} + 1")
endwhile() set(COMMAND "${CMAKE_ARGV${COMMAND_INDEX}}")
if(NOT DEFINED COMMAND_INDEX OR COMMAND_INDEX GREATER_EQUAL CMAKE_ARGC) if("${COMMAND}" STREQUAL "GET")
message(FATAL_ERROR "Usage: cmake -P version.cmake [GET|SET|PATCH|MINOR|MAJOR] [new_version]") get_current_version(VERSION)
endif() message("${VERSION}")
elseif("${COMMAND}" STREQUAL "SET")
set(COMMAND "${CMAKE_ARGV${COMMAND_INDEX}}") if(VERSION_INDEX GREATER_EQUAL CMAKE_ARGC)
message(FATAL_ERROR "Veuillez spécifier la nouvelle version: cmake -P version.cmake SET 0.0.0")
if("${COMMAND}" STREQUAL "GET") endif()
get_current_version(VERSION) set(NEW_VERSION "${CMAKE_ARGV${VERSION_INDEX}}")
message("${VERSION}") set_new_version("${NEW_VERSION}")
elseif("${COMMAND}" STREQUAL "SET") elseif("${COMMAND}" MATCHES "^(PATCH|MINOR|MAJOR)$")
if(VERSION_INDEX GREATER_EQUAL CMAKE_ARGC) get_current_version(CURRENT_VERSION)
message(FATAL_ERROR "Veuillez spécifier la nouvelle version: cmake -P version.cmake SET 0.0.0") increment_version("${CURRENT_VERSION}" "${COMMAND}" NEW_VERSION)
set_new_version("${NEW_VERSION}")
else()
message(FATAL_ERROR "Commande inconnue: ${COMMAND}. Utilisez GET, SET, PATCH, MINOR ou MAJOR.")
endif() endif()
set(NEW_VERSION "${CMAKE_ARGV${VERSION_INDEX}}")
set_new_version("${NEW_VERSION}")
elseif("${COMMAND}" MATCHES "^(PATCH|MINOR|MAJOR)$")
get_current_version(CURRENT_VERSION)
increment_version("${CURRENT_VERSION}" "${COMMAND}" NEW_VERSION)
set_new_version("${NEW_VERSION}")
else()
message(FATAL_ERROR "Commande inconnue: ${COMMAND}. Utilisez GET, SET, PATCH, MINOR ou MAJOR.")
endif() endif()