From bc5ed7ac4c6a516e9d2a573caedb8d0f3518fa0e Mon Sep 17 00:00:00 2001 From: Jonathan LEI Date: Tue, 21 May 2024 09:03:42 +0800 Subject: [PATCH] fix: corrosion cpp integration Fixes a recent breaking change in corrosion-rs breaking the starknet-cxx example. Also adds a CI workflow for checking the integration example. --- .github/workflows/build.yml | 27 +++++++++++++++++++ examples/starknet-cxx/CMakeLists.txt | 2 +- .../starknet-cxx/starknet-cxx/CMakeLists.txt | 2 +- 3 files changed, 29 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 8825669a..638c4ac6 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -49,3 +49,30 @@ jobs: - name: "Build all feature combinations" run: | cargo hack build --package ${{ matrix.package }} --feature-powerset + + cpp-integration: + name: "Build C++ integration example" + runs-on: "ubuntu-latest" + + steps: + - name: "Checkout source code" + uses: "actions/checkout@v3" + + - name: "Setup stable toolchain" + uses: "actions-rs/toolchain@v1" + with: + toolchain: "stable" + profile: "minimal" + override: true + + - name: "Build starknet-cxx example" + run: | + cd ./examples/starknet-cxx + mkdir build + cd ./build + cmake -DCMAKE_BUILD_TYPE=Release .. + make + + - name: "Run starknet-cxx example" + run: | + ./examples/starknet-cxx/build/main diff --git a/examples/starknet-cxx/CMakeLists.txt b/examples/starknet-cxx/CMakeLists.txt index e1a93fd9..90a70247 100644 --- a/examples/starknet-cxx/CMakeLists.txt +++ b/examples/starknet-cxx/CMakeLists.txt @@ -10,7 +10,7 @@ set(CMAKE_CXX_STANDARD 17) FetchContent_Declare( Corrosion GIT_REPOSITORY https://github.com/corrosion-rs/corrosion.git - GIT_TAG master + GIT_TAG v0.5.0 ) FetchContent_MakeAvailable(Corrosion) diff --git a/examples/starknet-cxx/starknet-cxx/CMakeLists.txt b/examples/starknet-cxx/starknet-cxx/CMakeLists.txt index 2400ac0b..a23b70c1 100644 --- a/examples/starknet-cxx/starknet-cxx/CMakeLists.txt +++ b/examples/starknet-cxx/starknet-cxx/CMakeLists.txt @@ -1,2 +1,2 @@ corrosion_import_crate(MANIFEST_PATH Cargo.toml) -corrosion_add_cxxbridge(starknet_cxx_bridge CRATE starknet-cxx MANIFEST_PATH starknet-cxx FILES lib.rs) +corrosion_add_cxxbridge(starknet_cxx_bridge CRATE starknet_cxx MANIFEST_PATH starknet_cxx FILES lib.rs)