diff --git a/.github/workflows/build_wheel.yml b/.github/workflows/build_wheel.yml index c49cd0a..65c86da 100644 --- a/.github/workflows/build_wheel.yml +++ b/.github/workflows/build_wheel.yml @@ -44,11 +44,15 @@ jobs: - os: ARM64 python: 311 platform_id: manylinux_aarch64 + # windows-arm64 + - os: windows-latest + python: 311 + platform_id: win_arm64 steps: - uses: actions/checkout@v4 - uses: ilammy/setup-nasm@v1 - if: matrix.platform_id == 'win_amd64' + if: matrix.platform_id == 'win_amd64' || matrix.platform_id == 'win_arm64' - name: Build wheels uses: pypa/cibuildwheel@v2.22 env: @@ -96,3 +100,13 @@ jobs: merge-multiple: true - uses: pypa/gh-action-pypi-publish@release/v1 + pass: + name: Pass testing build wheels + needs: [build_wheels, build_sdist] + runs-on: ubuntu-latest + if: always() + steps: + - name: Decide whether the needed jobs succeeded or failed + uses: re-actors/alls-green@release/v1 + with: + jobs: ${{ toJSON(needs) }} diff --git a/CMakeLists.txt b/CMakeLists.txt index 0af66c5..baded76 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -23,7 +23,7 @@ if (UNIX) USES_TERMINAL_INSTALL true USES_TERMINAL_TEST true ) -elseif(WIN32) +elseif(WIN32 AND CMAKE_GENERATOR_PLATFORM STREQUAL "x64") ExternalProject_Add(nodejs URL /~https://github.com/nodejs/node/archive/refs/tags/v${CMAKE_PROJECT_VERSION}.tar.gz CONFIGURE_COMMAND "" @@ -56,6 +56,39 @@ elseif(WIN32) DESTINATION ${SKBUILD_PLATLIB_DIR}/nodejs_wheel/lib/node_modules/ USE_SOURCE_PERMISSIONS ) +elseif(WIN32 AND CMAKE_GENERATOR_PLATFORM STREQUAL "ARM64") + ExternalProject_Add(nodejs + URL /~https://github.com/nodejs/node/archive/refs/tags/v${CMAKE_PROJECT_VERSION}.tar.gz + CONFIGURE_COMMAND "" + BUILD_IN_SOURCE 1 + BUILD_COMMAND /vcbuild arm64 + INSTALL_COMMAND "" + SOURCE_DIR ${CMAKE_CURRENT_BINARY_DIR}/nodejs_source + USES_TERMINAL_DOWNLOAD true + USES_TERMINAL_UPDATE true + USES_TERMINAL_PATCH true + USES_TERMINAL_CONFIGURE true + USES_TERMINAL_BUILD true + USES_TERMINAL_INSTALL true + USES_TERMINAL_TEST true + ) + install( + FILES ${CMAKE_CURRENT_BINARY_DIR}/nodejs_source/out/Release/node.exe + DESTINATION ${SKBUILD_PLATLIB_DIR}/nodejs_wheel + PERMISSIONS + OWNER_READ + OWNER_WRITE + OWNER_EXECUTE + GROUP_READ + GROUP_EXECUTE + WORLD_READ + WORLD_EXECUTE + ) + install( + DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/nodejs_source/deps/npm + DESTINATION ${SKBUILD_PLATLIB_DIR}/nodejs_wheel/lib/node_modules/ + USE_SOURCE_PERMISSIONS + ) else() message(FATAL_ERROR "Unsupported platform") endif() diff --git a/README.md b/README.md index 8803987..bfe65b5 100644 --- a/README.md +++ b/README.md @@ -36,6 +36,7 @@ The project is powered by [scikit-build-core](/~https://github.com/scikit-build/sc | macOS | x86_64 | 64 | >= macOS-11 | v18.18.0 | | macOS | arm64 | 64 | >= macOS-11 | v20.11.1 | | Windows | amd64 | 64 | | v18.18.0 | +| Windows | arm64 | 64 | | v22.12.0 | ## Usage diff --git a/cmd/README.md b/cmd/README.md index 8803987..bfe65b5 100644 --- a/cmd/README.md +++ b/cmd/README.md @@ -36,6 +36,7 @@ The project is powered by [scikit-build-core](/~https://github.com/scikit-build/sc | macOS | x86_64 | 64 | >= macOS-11 | v18.18.0 | | macOS | arm64 | 64 | >= macOS-11 | v20.11.1 | | Windows | amd64 | 64 | | v18.18.0 | +| Windows | arm64 | 64 | | v22.12.0 | ## Usage