From 290b37a4c8f97f332880fc828e440b98e7fd43cc Mon Sep 17 00:00:00 2001 From: Alex Day <83617511+AlexDayCRL@users.noreply.github.com> Date: Tue, 26 Mar 2024 20:26:59 -0400 Subject: [PATCH 1/3] capture message bytes by reference (#142) --- rmw_zenoh_cpp/src/rmw_zenoh.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rmw_zenoh_cpp/src/rmw_zenoh.cpp b/rmw_zenoh_cpp/src/rmw_zenoh.cpp index fe3203b7..802a1269 100644 --- a/rmw_zenoh_cpp/src/rmw_zenoh.cpp +++ b/rmw_zenoh_cpp/src/rmw_zenoh.cpp @@ -878,7 +878,7 @@ rmw_publish( } }); auto free_msg_bytes = rcpputils::make_scope_exit( - [msg_bytes, allocator, &shmbuf]() { + [&msg_bytes, allocator, &shmbuf]() { if (msg_bytes && !shmbuf.has_value()) { allocator->deallocate(msg_bytes, allocator->state); } From eac1d8480ccc50533eb610fdff82eda3306701f2 Mon Sep 17 00:00:00 2001 From: Yadu Date: Wed, 3 Apr 2024 07:42:12 +0800 Subject: [PATCH 2/3] Patch cargo toolchain for noble (#136) * Patch cargo toolchain for noble Signed-off-by: Yadunund * Add tmp build for noble job Signed-off-by: Yadunund * Try to fix iron Signed-off-by: Yadunund * Patch even for iron builds Signed-off-by: Yadunund * Force build with 1.75.0 on jammy Signed-off-by: Yadunund * Update zenoh_c_vendor/CMakeLists.txt Co-authored-by: Chris Lalancette Signed-off-by: Yadu * Update zenoh_c_vendor/CMakeLists.txt Co-authored-by: Chris Lalancette Signed-off-by: Yadu * Update zenoh_c_vendor/CMakeLists.txt Co-authored-by: Chris Lalancette Signed-off-by: Yadu * Patch zenoh-c based on cargo toolchain availability Signed-off-by: Yadunund * Make patch from zenoh-c PR #301 Signed-off-by: Yadunund --------- Signed-off-by: Yadunund Signed-off-by: Yadu Co-authored-by: Chris Lalancette --- .github/workflows/build.yaml | 3 ++- .github/workflows/style.yaml | 1 + .github/workflows/tmp_build_noble.yaml | 36 ++++++++++++++++++++++++++ README.md | 6 +++-- zenoh_c_vendor/CMakeLists.txt | 3 +++ zenoh_c_vendor/package.xml | 2 +- zenoh_c_vendor/patches/pr_301.patch | 24 +++++++++++++++++ 7 files changed, 71 insertions(+), 4 deletions(-) create mode 100644 .github/workflows/tmp_build_noble.yaml create mode 100644 zenoh_c_vendor/patches/pr_301.patch diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 07c90a86..7dd4881f 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -11,6 +11,7 @@ jobs: test: runs-on: ubuntu-latest strategy: + fail-fast: false matrix: docker_image: ['ros:iron-ros-base', 'ros:rolling-ros-base'] container: @@ -21,7 +22,7 @@ jobs: run: | apt update && apt install -y curl - name: Setup Rust - uses: dtolnay/rust-toolchain@stable + uses: dtolnay/rust-toolchain@1.75.0 - uses: actions/checkout@v2 - name: rosdep run: | diff --git a/.github/workflows/style.yaml b/.github/workflows/style.yaml index 5c3a7160..04f818b1 100644 --- a/.github/workflows/style.yaml +++ b/.github/workflows/style.yaml @@ -10,6 +10,7 @@ jobs: test: runs-on: ubuntu-latest strategy: + fail-fast: false matrix: docker_image: ['ros:iron-ros-base', 'ros:rolling-ros-base'] container: diff --git a/.github/workflows/tmp_build_noble.yaml b/.github/workflows/tmp_build_noble.yaml new file mode 100644 index 00000000..17d9fe2e --- /dev/null +++ b/.github/workflows/tmp_build_noble.yaml @@ -0,0 +1,36 @@ +name: build_noble +on: + pull_request: + push: + branches: [ rolling ] + workflow_dispatch: +defaults: + run: + shell: bash +jobs: + test: + runs-on: ubuntu-latest + strategy: + matrix: + docker_image: ['ubuntu:noble-20240225'] + container: + image: ${{ matrix.docker_image }} + timeout-minutes: 30 + steps: + - name: Setup rolling + run: | + apt update && apt install curl -y + curl -sSL https://raw.githubusercontent.com/ros/rosdistro/master/ros.key -o /usr/share/keyrings/ros-archive-keyring.gpg + echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/ros-archive-keyring.gpg] http://packages.ros.org/ros2/ubuntu $(. /etc/os-release && echo $UBUNTU_CODENAME) main" | tee /etc/apt/sources.list.d/ros2.list > /dev/null + apt update && apt install ros-dev-tools -y + apt install ros-rolling-ros-base -y + - uses: actions/checkout@v2 + - name: rosdep + run: | + rosdep init + rosdep update + rosdep install --from-paths . --rosdistro rolling -yir + - name: build + run: | + source /opt/ros/rolling/setup.bash + colcon build diff --git a/README.md b/README.md index 1d831c3c..278ebc26 100644 --- a/README.md +++ b/README.md @@ -15,10 +15,12 @@ For information about the Design please visit [design](docs/design.md) page. ## Setup -Install latest rustc. -> Note: The version of rustc that can be installed via apt is outdated. +Install latest rustc via `rustup` if building on Ubuntu Jammy. +Skip this step if building on Ubuntu Noble as `cargo` and `rustc` will be +installed via `rosdep`. ```bash curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh +rustup install 1.75.0 ``` Build `rmw_zenoh_cpp` diff --git a/zenoh_c_vendor/CMakeLists.txt b/zenoh_c_vendor/CMakeLists.txt index 73246032..da56c50a 100644 --- a/zenoh_c_vendor/CMakeLists.txt +++ b/zenoh_c_vendor/CMakeLists.txt @@ -26,11 +26,14 @@ set(ZENOHC_CARGO_FLAGS "--no-default-features$--features=zenoh/transp # Set VCS_VERSION to include changes from https://github.com/eclipse-zenoh/zenoh/pull/802 # which was synced to zenoh-c in https://github.com/eclipse-zenoh/zenoh-c/pull/272. +# Apply patches: +# - https://github.com/eclipse-zenoh/zenoh-c/pull/301 ament_vendor(zenoh_c_vendor VCS_URL https://github.com/eclipse-zenoh/zenoh-c.git VCS_VERSION 10176b911096cb92b8ee46bc491b78079ee26c20 CMAKE_ARGS "-DZENOHC_CARGO_FLAGS=${ZENOHC_CARGO_FLAGS}" + PATCHES patches ) # set(INSTALL_DIR "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-prefix/install") diff --git a/zenoh_c_vendor/package.xml b/zenoh_c_vendor/package.xml index 6515c1e9..55c17616 100644 --- a/zenoh_c_vendor/package.xml +++ b/zenoh_c_vendor/package.xml @@ -12,7 +12,7 @@ ament_cmake ament_cmake_vendor_package - + cargo clang diff --git a/zenoh_c_vendor/patches/pr_301.patch b/zenoh_c_vendor/patches/pr_301.patch new file mode 100644 index 00000000..68008fd9 --- /dev/null +++ b/zenoh_c_vendor/patches/pr_301.patch @@ -0,0 +1,24 @@ +diff --git a/CMakeLists.txt b/CMakeLists.txt +index 00aa5ca..d236e99 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -27,7 +27,7 @@ declare_cache_var_true_if_vscode(ZENOHC_BUILD_IN_SOURCE_TREE "Do build inside so + declare_cache_var(ZENOHC_BUILD_WITH_LOGGER_AUTOINIT TRUE BOOL "Enable logger-autoinit zenoh-c feature") + declare_cache_var(ZENOHC_BUILD_WITH_SHARED_MEMORY TRUE BOOL "Enable shared-memory zenoh-c feature") + declare_cache_var(ZENOHC_CUSTOM_TARGET "" STRING "Rust target for cross compilation, 'aarch64-unknown-linux-gnu' for example") +-declare_cache_var(ZENOHC_CARGO_CHANNEL "stable" STRING "Cargo channel selected: stable or nightly") ++declare_cache_var(ZENOHC_CARGO_CHANNEL "" STRING "Cargo channel parameter. Should be '+stable', '+nightly' or empty value") + declare_cache_var(ZENOHC_CARGO_FLAGS "" STRING "Additional cargo flags") + declare_cache_var(ZENOHC_LIB_STATIC FALSE BOOL "Alias zenohc::lib target to zenohc::static if TRUE, to zenohc::shared if FALSE") + +@@ -198,8 +198,8 @@ file(GLOB_RECURSE rust_sources "Cargo.toml.in" "src/*.rs" "build.rs" "splitguide + add_custom_command( + OUTPUT ${libs} + COMMAND ${CMAKE_COMMAND} -E echo \"RUSTFLAGS = $$RUSTFLAGS\" +- COMMAND ${CMAKE_COMMAND} -E echo \"cargo +${ZENOHC_CARGO_CHANNEL} build ${cargo_flags}\" +- COMMAND cargo +${ZENOHC_CARGO_CHANNEL} build ${cargo_flags} ++ COMMAND ${CMAKE_COMMAND} -E echo \"cargo ${ZENOHC_CARGO_CHANNEL} build ${cargo_flags}\" ++ COMMAND cargo ${ZENOHC_CARGO_CHANNEL} build ${cargo_flags} + VERBATIM + COMMAND_EXPAND_LISTS + DEPENDS "${rust_sources}" From ab61bfbb9c25f6a532f53f1dde87961ff6c01798 Mon Sep 17 00:00:00 2001 From: Julien Enoch Date: Wed, 3 Apr 2024 11:48:43 +0200 Subject: [PATCH 3/3] Bump zenoh-c to eclipse-zenoh/zenoh-c#307 --- zenoh_c_vendor/CMakeLists.txt | 10 +++------- zenoh_c_vendor/patches/pr_301.patch | 24 ------------------------ 2 files changed, 3 insertions(+), 31 deletions(-) delete mode 100644 zenoh_c_vendor/patches/pr_301.patch diff --git a/zenoh_c_vendor/CMakeLists.txt b/zenoh_c_vendor/CMakeLists.txt index ad75856c..81211fae 100644 --- a/zenoh_c_vendor/CMakeLists.txt +++ b/zenoh_c_vendor/CMakeLists.txt @@ -24,17 +24,13 @@ find_package(ament_cmake_vendor_package REQUIRED) # when expanded. set(ZENOHC_CARGO_FLAGS "--no-default-features$--features=zenoh/transport_tcp zenoh/shared-memory") -# Set VCS_VERSION to include changes from https://github.com/eclipse-zenoh/zenoh/pull/830 -# and https://github.com/eclipse-zenoh/zenoh/pull/848 which was synced to zenoh-c in -# https://github.com/eclipse-zenoh/zenoh-c/pull/293. -# Apply patches: -# - https://github.com/eclipse-zenoh/zenoh-c/pull/301 +# Set VCS_VERSION to include changes from https://github.com/eclipse-zenoh/zenoh/pull/875 +# which was synced to zenoh-c in https://github.com/eclipse-zenoh/zenoh-c/pull/307. ament_vendor(zenoh_c_vendor VCS_URL https://github.com/eclipse-zenoh/zenoh-c.git - VCS_VERSION bd0fe98772b7d65e8fb71eb0369d7c85c9b09c73 + VCS_VERSION c1498fcaf08d3dad15e49b1ac15cd380c0dc175c CMAKE_ARGS "-DZENOHC_CARGO_FLAGS=${ZENOHC_CARGO_FLAGS}" - PATCHES patches ) # set(INSTALL_DIR "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-prefix/install") diff --git a/zenoh_c_vendor/patches/pr_301.patch b/zenoh_c_vendor/patches/pr_301.patch deleted file mode 100644 index 68008fd9..00000000 --- a/zenoh_c_vendor/patches/pr_301.patch +++ /dev/null @@ -1,24 +0,0 @@ -diff --git a/CMakeLists.txt b/CMakeLists.txt -index 00aa5ca..d236e99 100644 ---- a/CMakeLists.txt -+++ b/CMakeLists.txt -@@ -27,7 +27,7 @@ declare_cache_var_true_if_vscode(ZENOHC_BUILD_IN_SOURCE_TREE "Do build inside so - declare_cache_var(ZENOHC_BUILD_WITH_LOGGER_AUTOINIT TRUE BOOL "Enable logger-autoinit zenoh-c feature") - declare_cache_var(ZENOHC_BUILD_WITH_SHARED_MEMORY TRUE BOOL "Enable shared-memory zenoh-c feature") - declare_cache_var(ZENOHC_CUSTOM_TARGET "" STRING "Rust target for cross compilation, 'aarch64-unknown-linux-gnu' for example") --declare_cache_var(ZENOHC_CARGO_CHANNEL "stable" STRING "Cargo channel selected: stable or nightly") -+declare_cache_var(ZENOHC_CARGO_CHANNEL "" STRING "Cargo channel parameter. Should be '+stable', '+nightly' or empty value") - declare_cache_var(ZENOHC_CARGO_FLAGS "" STRING "Additional cargo flags") - declare_cache_var(ZENOHC_LIB_STATIC FALSE BOOL "Alias zenohc::lib target to zenohc::static if TRUE, to zenohc::shared if FALSE") - -@@ -198,8 +198,8 @@ file(GLOB_RECURSE rust_sources "Cargo.toml.in" "src/*.rs" "build.rs" "splitguide - add_custom_command( - OUTPUT ${libs} - COMMAND ${CMAKE_COMMAND} -E echo \"RUSTFLAGS = $$RUSTFLAGS\" -- COMMAND ${CMAKE_COMMAND} -E echo \"cargo +${ZENOHC_CARGO_CHANNEL} build ${cargo_flags}\" -- COMMAND cargo +${ZENOHC_CARGO_CHANNEL} build ${cargo_flags} -+ COMMAND ${CMAKE_COMMAND} -E echo \"cargo ${ZENOHC_CARGO_CHANNEL} build ${cargo_flags}\" -+ COMMAND cargo ${ZENOHC_CARGO_CHANNEL} build ${cargo_flags} - VERBATIM - COMMAND_EXPAND_LISTS - DEPENDS "${rust_sources}"