0
0
mirror of https://github.com/hufrea/byedpi.git synced 2025-07-05 05:24:08 +00:00

Main version read from source file.

Revision part of version read from git order number.
Version info block added to NSIS package.
This commit is contained in:
raspopov 2024-08-08 18:07:38 +03:00
parent 5464319124
commit 37d0c28832
No known key found for this signature in database
GPG Key ID: 2B35203E97E80E13

View File

@ -1,18 +1,42 @@
cmake_minimum_required( VERSION 3.5 ) cmake_minimum_required( VERSION 3.5 )
# Read version number
file( STRINGS main.c MAIN_VERSION_LINE REGEX "#define[ \t]+VERSION[ \t]+" LIMIT_COUNT 1 )
string( REGEX MATCH "([0-9\.]+)" MAIN_VERSION "${MAIN_VERSION_LINE}" )
if( NOT MAIN_VERSION )
message( FATAL_ERROR "Version not found!" )
endif()
# Prepend version by "0"
string( REGEX MATCHALL "([0-9]+)" MAIN_VERSION "${MAIN_VERSION}" )
list( LENGTH MAIN_VERSION _LENGTH )
while( ${_LENGTH} LESS 3 )
list( PREPEND MAIN_VERSION "0" )
list( LENGTH MAIN_VERSION _LENGTH )
endwhile()
string( JOIN "." MAIN_VERSION ${MAIN_VERSION} )
# Extract Git revision order number, used as last part of version
find_package( Git )
set( GIT_REVISION "0" )
if( Git_FOUND )
execute_process( COMMAND "${GIT_EXECUTABLE}" rev-list HEAD --count
WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}"
OUTPUT_VARIABLE GIT_REVISION
ERROR_QUIET
OUTPUT_STRIP_TRAILING_WHITESPACE
)
endif()
project( ByeDPI project( ByeDPI
VERSION 12 VERSION "${MAIN_VERSION}.${GIT_REVISION}"
DESCRIPTION "Local SOCKS proxy server to bypass DPI (Deep Packet Inspection)." DESCRIPTION "Local SOCKS proxy server to bypass DPI (Deep Packet Inspection)."
HOMEPAGE_URL "https://github.com/hufrea/byedpi" HOMEPAGE_URL "https://github.com/hufrea/byedpi"
LANGUAGES C LANGUAGES C
) )
set( PROJECT_VENDOR "GitHub" ) set( PROJECT_VENDOR "hufrea" )
set( CMAKE_RUNTIME_OUTPUT_DIRECTORY "$<CONFIG>" )
add_compile_options( -D_XOPEN_SOURCE=500 )
add_compile_definitions( _XOPEN_SOURCE=500 )
# Optimizations # Optimizations
add_compile_options( $<$<NOT:$<CONFIG:Debug>>:-O3> ) add_compile_options( $<$<NOT:$<CONFIG:Debug>>:-O3> )
# Link time optimizations # Link time optimizations
@ -69,9 +93,19 @@ if( WIN32 )
"service_install.bat" "Service install and run" "service_install.bat" "Service install and run"
"service_restart.bat" "Service restart" "service_restart.bat" "Service restart"
) )
file( WRITE "${CMAKE_BINARY_DIR}/ver.nsi" "VIProductVersion ${PROJECT_VERSION}\n" )
file( APPEND "${CMAKE_BINARY_DIR}/ver.nsi" "VIAddVersionKey /LANG=0 \"ProductName\" \"${PROJECT_NAME}\"\n" )
file( APPEND "${CMAKE_BINARY_DIR}/ver.nsi" "VIAddVersionKey /LANG=0 \"FileDescription\" \"${PROJECT_DESCRIPTION}\"\n" )
file( APPEND "${CMAKE_BINARY_DIR}/ver.nsi" "VIAddVersionKey /LANG=0 \"CompanyName\" \"${PROJECT_VENDOR}\"\n" )
file( APPEND "${CMAKE_BINARY_DIR}/ver.nsi" "VIAddVersionKey /LANG=0 \"FileVersion\" \"${PROJECT_VERSION}\"\n" )
set( CPACK_NSIS_EXECUTABLE_PRE_ARGUMENTS "V0 ${CMAKE_BINARY_DIR}/ver.nsi" )
set( CPACK_NSIS_EXTRA_PREINSTALL_COMMANDS "ExecWait \"sc stop ${PROJECT_NAME}\"" ) set( CPACK_NSIS_EXTRA_PREINSTALL_COMMANDS "ExecWait \"sc stop ${PROJECT_NAME}\"" )
set( CPACK_NSIS_EXTRA_INSTALL_COMMANDS "ExecWait \"$INSTDIR\\service_install.bat\"" ) set( CPACK_NSIS_EXTRA_INSTALL_COMMANDS "ExecWait \"$INSTDIR\\service_install.bat\"" )
set( CPACK_NSIS_EXTRA_UNINSTALL_COMMANDS "ExecWait \"$INSTDIR\\service_delete.bat\"" ) set( CPACK_NSIS_EXTRA_UNINSTALL_COMMANDS "ExecWait \"$INSTDIR\\service_delete.bat\"" )
set( CPACK_NSIS_CONTACT "${PROJECT_VENDOR}" )
set( CPACK_NSIS_HELP_LINK "${PROJECT_HOMEPAGE_URL}" )
set( CPACK_NSIS_URL_INFO_ABOUT "${PROJECT_HOMEPAGE_URL}" )
set( CPACK_NSIS_BRANDING_TEXT " " )
set( CMAKE_INSTALL_BINDIR . ) set( CMAKE_INSTALL_BINDIR . )
set( CMAKE_INSTALL_DOCDIR . ) set( CMAKE_INSTALL_DOCDIR . )
else() else()