diff --git a/.devcontainer b/.devcontainer index cce8c7c..ad67bce 160000 --- a/.devcontainer +++ b/.devcontainer @@ -1 +1 @@ -Subproject commit cce8c7c390158d4bb1f33449ec1afd04bd20a073 +Subproject commit ad67bce5fb63e89f6f8c0fbffda1c1baccaaca26 diff --git a/.github/workflows/xpbuild.yml b/.github/workflows/xpbuild.yml index 151d481..7be8f1e 100644 --- a/.github/workflows/xpbuild.yml +++ b/.github/workflows/xpbuild.yml @@ -1,4 +1,7 @@ name: Build +permissions: + contents: read + pull-requests: write on: push: branches: [ "dev" ] @@ -7,24 +10,15 @@ on: workflow_dispatch: jobs: linux: - uses: externpro/externpro/.github/workflows/build-linux.yml@25.05.1 - with: - cmake-workflow-preset: Linux - runon: ubuntu-latest - secrets: inherit - linux-arm64: - uses: externpro/externpro/.github/workflows/build-linux.yml@25.05.1 - with: - cmake-workflow-preset: Linux - runon: ubuntu-24.04-arm + permissions: + contents: read + pull-requests: write + packages: write + uses: externpro/externpro/.github/workflows/build-linux.yml@25.07 secrets: inherit macos: - uses: externpro/externpro/.github/workflows/build-macos.yml@25.05.1 - with: - cmake-workflow-preset: Darwin + uses: externpro/externpro/.github/workflows/build-macos.yml@25.07 secrets: inherit windows: - uses: externpro/externpro/.github/workflows/build-windows.yml@25.05.1 - with: - cmake-workflow-preset: Windows + uses: externpro/externpro/.github/workflows/build-windows.yml@25.07 secrets: inherit diff --git a/.github/workflows/xprelease.yml b/.github/workflows/xprelease.yml index f868a82..e7fbd63 100644 --- a/.github/workflows/xprelease.yml +++ b/.github/workflows/xprelease.yml @@ -9,10 +9,9 @@ on: jobs: # Upload build artifacts as release assets release-from-build: - uses: externpro/externpro/.github/workflows/release-from-build.yml@25.05.1 + uses: externpro/externpro/.github/workflows/release-from-build.yml@25.07 with: workflow_run_url: ${{ github.event.inputs.workflow_run_url }} - artifact_pattern: "*.tar.xz" permissions: contents: write id-token: write diff --git a/CMakeLists.txt b/CMakeLists.txt index 304bf43..e3a767c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,9 +1,6 @@ cmake_minimum_required(VERSION 3.31) -set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_LIST_DIR}/.devcontainer/cmake) -set(CMAKE_PROJECT_TOP_LEVEL_INCLUDES xproinc) -project(bzip2 VERSION 1.0.8.2 LANGUAGES C) -include(flags) -include(GNUInstallDirs) +set(CMAKE_PROJECT_TOP_LEVEL_INCLUDES .devcontainer/cmake/xproinc.cmake) +project(bzip2 VERSION 1.0.8 LANGUAGES C) set(lib_name bz2) ######################################## add_definitions(-D_FILE_OFFEST_BITS=64) @@ -43,13 +40,6 @@ add_test(NAME bzip2_check ) ######################################## set(targetsFile ${PROJECT_NAME}-targets) -set(exe bzip2) -set(lib ${lib_name}) -if(DEFINED XP_NAMESPACE) - string(PREPEND exe "${XP_NAMESPACE}::") - string(PREPEND lib "${XP_NAMESPACE}::") -endif() -xpPackageDevel(TARGETS_FILE ${targetsFile} LIBRARIES ${lib} EXE ${exe}) install(TARGETS ${lib_name} EXPORT ${targetsFile} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} @@ -65,9 +55,18 @@ install(PROGRAMS $ DESTINATION ${CMAKE_INSTALL_BINDIR} CONFIG install(PROGRAMS $ DESTINATION ${CMAKE_INSTALL_BINDIR} CONFIGURATIONS Release RENAME bzcat${CMAKE_EXECUTABLE_SUFFIX}) install(FILES bzlib.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}) if(DEFINED XP_NAMESPACE) - set(nameSpace NAMESPACE ${XP_NAMESPACE}::) -endif() -if(NOT DEFINED XP_INSTALL_CMAKEDIR) - set(XP_INSTALL_CMAKEDIR ${CMAKE_INSTALL_DATADIR}/cmake) + string(JOIN "\n" ALIASES + "if(NOT TARGET BZip2::BZip2)" + " add_library(BZip2::BZip2 ALIAS ${XP_NAMESPACE}::${lib_name})" + "endif()" + "" + ) + xpExternPackage(NAMESPACE ${XP_NAMESPACE} + TARGETS_FILE ${targetsFile} LIBRARIES ${lib_name} EXE bzip2 + BASE ${CMAKE_PROJECT_NAME}-${CMAKE_PROJECT_VERSION} XPDIFF "intro" + WEB "https://sourceware.org/bzip2/" UPSTREAM "github.com/opencor/bzip2" + DESC "lossless block-sorting data compression library" + LICENSE "[bzip2-1.0.6](https://spdx.org/licenses/bzip2-1.0.6.html 'BSD-like, modified zlib license')" + ) + install(EXPORT ${targetsFile} DESTINATION ${XP_INSTALL_CMAKEDIR} NAMESPACE ${XP_NAMESPACE}::) endif() -install(EXPORT ${targetsFile} DESTINATION ${XP_INSTALL_CMAKEDIR} ${nameSpace}) diff --git a/CMakePresetsBase.json b/CMakePresetsBase.json index 5aa0fca..4489d79 100644 --- a/CMakePresetsBase.json +++ b/CMakePresetsBase.json @@ -6,9 +6,14 @@ "hidden": true, "binaryDir": "${sourceDir}/_bld-${presetName}", "cacheVariables": { - "XP_INSTALL_CMAKEDIR": "share/cmake", "XP_NAMESPACE": "xpro" } } + ], + "buildPresets": [ + { + "name": "build-base", + "hidden": true + } ] }