forked from eclipse-iceoryx/iceoryx2
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[eclipse-iceoryx#210] Workaround for 'rust-lang/cargo#6313'
- Loading branch information
1 parent
ba883fe
commit 2996910
Showing
16 changed files
with
186 additions
and
160 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,135 @@ | ||
// Copyright (c) 2024 Contributors to the Eclipse Foundation | ||
// | ||
// See the NOTICE file(s) distributed with this work for additional | ||
// information regarding copyright ownership. | ||
// | ||
// This program and the accompanying materials are made available under the | ||
// terms of the Apache Software License 2.0 which is available at | ||
// https://www.apache.org/licenses/LICENSE-2.0, or the MIT license | ||
// which is available at https://opensource.org/licenses/MIT. | ||
// | ||
// SPDX-License-Identifier: Apache-2.0 OR MIT | ||
|
||
#![allow(non_camel_case_types)] | ||
|
||
use iceoryx2::prelude::*; | ||
use iceoryx2_bb_container::semantic_string::SemanticStringError; | ||
use iceoryx2_bb_log::set_log_level; | ||
|
||
use core::ffi::c_int; | ||
|
||
mod config; | ||
mod node; | ||
mod node_builder; | ||
mod node_name; | ||
mod publisher; | ||
mod service; | ||
mod service_builder; | ||
mod subscriber; | ||
|
||
pub use config::*; | ||
pub use node::*; | ||
pub use node_builder::*; | ||
pub use node_name::*; | ||
pub use publisher::*; | ||
pub use service::*; | ||
pub use service_builder::*; | ||
pub use subscriber::*; | ||
|
||
/// This constant signals an successful function call | ||
pub const IOX2_OK: c_int = 0; | ||
|
||
#[repr(C)] | ||
#[derive(Copy, Clone)] | ||
pub enum iox2_callback_progression_e { | ||
STOP = 0, | ||
CONTINUE, | ||
} | ||
|
||
impl From<iox2_callback_progression_e> for CallbackProgression { | ||
fn from(value: iox2_callback_progression_e) -> Self { | ||
match value { | ||
iox2_callback_progression_e::STOP => CallbackProgression::Stop, | ||
iox2_callback_progression_e::CONTINUE => CallbackProgression::Continue, | ||
} | ||
} | ||
} | ||
|
||
#[repr(C)] | ||
#[derive(Copy, Clone)] | ||
pub enum iox2_semantic_string_error_e { | ||
INVALID_CONTENT = IOX2_OK as isize + 1, | ||
EXCEEDS_MAXIMUM_LENGTH, | ||
} | ||
|
||
impl IntoCInt for SemanticStringError { | ||
fn into_c_int(self) -> c_int { | ||
(match self { | ||
SemanticStringError::InvalidContent => iox2_semantic_string_error_e::INVALID_CONTENT, | ||
SemanticStringError::ExceedsMaximumLength => { | ||
iox2_semantic_string_error_e::EXCEEDS_MAXIMUM_LENGTH | ||
} | ||
}) as c_int | ||
} | ||
} | ||
|
||
#[no_mangle] | ||
pub extern "C" fn zero_copy_service_list() -> i32 { | ||
set_log_level(iceoryx2_bb_log::LogLevel::Info); | ||
|
||
let callback = |service| { | ||
println!("\n{:#?}", service?); | ||
Ok(CallbackProgression::Continue) | ||
}; | ||
|
||
match zero_copy::Service::list(Config::global_config(), callback) { | ||
Ok(_) => 0, | ||
Err(_) => -1, | ||
} | ||
} | ||
|
||
/// This is a trait to convert a Rust error enum into the corresponding C error enum and then to a c_int in one go | ||
/// | ||
/// # Example | ||
/// | ||
/// ```no_run | ||
/// use core::ffi::c_int; | ||
/// | ||
/// trait IntoCInt { | ||
/// fn into_c_int(self) -> c_int; | ||
/// } | ||
/// | ||
/// enum FooError { | ||
/// BAR, | ||
/// BAZ | ||
/// } | ||
/// | ||
/// #[repr(C)] | ||
/// #[derive(Copy, Clone)] | ||
/// pub enum iox2_foo_error_e { | ||
/// BAR = 1, // start at 1 since IOX2_OK is already 0 | ||
/// BAZ, | ||
/// } | ||
/// | ||
/// impl IntoCInt for FooError { | ||
/// fn into_c_int(self) -> c_int { | ||
/// (match self { | ||
/// FooError::BAR => iox2_foo_error_e::BAR, | ||
/// FooError::BAZ => iox2_foo_error_e::BAZ, | ||
/// }) as c_int | ||
/// } | ||
/// } | ||
/// ``` | ||
trait IntoCInt { | ||
fn into_c_int(self) -> c_int; | ||
} | ||
|
||
trait HandleToType { | ||
type Target; | ||
|
||
// NOTE in this case, the handle `self` is already a `*mut`. Passing by value means a copy | ||
// of the pointer; passing by reference make the implementation more error prone since one | ||
// has to remember to de-reference `self` in order to get the `*mut` | ||
#[allow(clippy::wrong_self_convention)] | ||
fn as_type(self) -> Self::Target; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.