diff --git a/.github/workflows/build-deb.yml b/.github/workflows/build-deb.yml index cff419b5b..cadc95b7d 100644 --- a/.github/workflows/build-deb.yml +++ b/.github/workflows/build-deb.yml @@ -1,9 +1,12 @@ name: Build Debian Package on: push: - tags: - - 1.** - pull_request: + tags: [ '[0-9]+.[0-9]+.[0-9]+' ] + workflow_dispatch: + inputs: + version: + description: 'The optional semantic version number. If not supplied the branch/tag will be used.' + type: string jobs: package-ubuntu-latest-amd64: @@ -22,11 +25,25 @@ jobs: run: sudo apt install -y libssl-dev libcurl4-openssl-dev - name: "Install building tools" run: sudo apt install -y cmake debmake devscripts debhelper - + # Set version number + - name: Set version based on input + if: ${{ inputs.version }} + run: echo "RELEASE_VERSION=${{ inputs.version }}" >> "$GITHUB_ENV" + - name: Set version based on ref + if: ${{ !inputs.version }} + run: | + mkdir -p cpr/build + pushd cpr/build + cmake .. -DCPR_BUILD_VERSION_OUTPUT_ONLY=ON + echo "RELEASE_VERSION=$(cat version.txt)" >> $GITHUB_ENV + popd + rm -rf cpr/build + - name: Print Version + run: echo "deb version will be '${{ env.RELEASE_VERSION }}'" # Build package of runtime library - name: "Package build of runtime library" env: - VERSION: ${{ github.ref_name }} + VERSION: ${{ env.RELEASE_VERSION }} run: bash cpr/package-build/build-package.sh cpr - name: "Upload deb-packages" diff --git a/CMakeLists.txt b/CMakeLists.txt index ea6991f77..7d2d83941 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -66,6 +66,7 @@ cpr_option(CPR_ENABLE_CPPCHECK "Set to ON to enable Cppcheck static analysis. Re cpr_option(CPR_BUILD_TESTS "Set to ON to build cpr tests." OFF) cpr_option(CPR_BUILD_TESTS_SSL "Set to ON to build cpr ssl tests" ${CPR_BUILD_TESTS}) cpr_option(CPR_BUILD_TESTS_PROXY "Set to ON to build proxy tests. They fail in case there is no valid proxy server available in proxy_tests.cpp" OFF) +cpr_option(CPR_BUILD_VERSION_OUTPUT_ONLY "Set to ON to only export the version into 'build/version.txt' and exit" OFF) cpr_option(CPR_SKIP_CA_BUNDLE_SEARCH "Skip searching for Certificate Authority certs. Turn ON for systems like iOS where file access is restricted and prevents https from working." OFF) cpr_option(CPR_USE_BOOST_FILESYSTEM "Set to ON to use the Boost.Filesystem library. This is useful, on, e.g., Apple platforms, where std::filesystem may not always be available when targeting older OS versions." OFF) cpr_option(CPR_DEBUG_SANITIZER_FLAG_THREAD "Enables the ThreadSanitizer for debug builds." OFF) @@ -75,6 +76,13 @@ cpr_option(CPR_DEBUG_SANITIZER_FLAG_UB "Enables the UndefinedBehaviorSanitizer f cpr_option(CPR_DEBUG_SANITIZER_FLAG_ALL "Enables all sanitizers for debug builds except the ThreadSanitizer since it is incompatible with the other sanitizers." OFF) message(STATUS "=======================================================") +# Save the project version as txt file for deb and NuGet builds +if(CPR_BUILD_VERSION_OUTPUT_ONLY) + message(STATUS "Printing version and exiting...") + file(WRITE "${CMAKE_BINARY_DIR}/version.txt" "${PROJECT_VERSION}") + return() +endif() + if (CPR_FORCE_USE_SYSTEM_CURL) message(WARNING "The variable CPR_FORCE_USE_SYSTEM_CURL is deprecated, please use CPR_USE_SYSTEM_CURL instead") set(CPR_USE_SYSTEM_CURL ${CPR_FORCE_USE_SYSTEM_CURL}) diff --git a/nuget/libcpr.nuspec b/nuget/libcpr.nuspec index e47a8c08e..1169ebf4e 100644 --- a/nuget/libcpr.nuspec +++ b/nuget/libcpr.nuspec @@ -13,7 +13,7 @@ https://github.com/libcpr C++ Requests: Curl for People, a spiritual port of Python Requests. Native, native - english - + english + \ No newline at end of file