1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// Copyright (c) 2023 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

//! # iceoryx2 Building Blocks (BB) Container
//!
//! This is a support library for iceoryx2 which comes with containers that are
//! compatible with shared memory and can be used to construct custom payload types for
//! inter-process communication.
//!
//! Most containers come in 3 variations:
//!  1. `FixedSize*Container*`, compile-time fixed size version. The capacity must be known at compile
//!     time. Those fixed-size constructs are always self-contained, meaning that the required
//!     memory is part of the constructs and usually stored in some kind of array.
//!  2. `Relocatable*Container*`, run-time fixed size version that is shared memory compatible. The
//!     capacity must be known when the object is created. **This object is not movable!**
//!  3. `*Container*`, run-time fixed size version that is **not** shared memory compatible but can be
//!     moved. The memory is by default stored on the heap.
//!
//! # Example
//!
//! ## 1. Compile-Time FixedSize Containers
//!
//! We create a struct consisting of compile-time fixed size containers that can be used for
//! zero copy inter-process communication.
//!
//! ```
//! use iceoryx2_bb_container::byte_string::*;
//! use iceoryx2_bb_container::vec::*;
//!
//! const TEXT_CAPACITY: usize = 123;
//! const DATA_CAPACITY: usize = 456;
//!
//! #[repr(C)]
//! struct MyMessageType {
//!     some_text: FixedSizeByteString<TEXT_CAPACITY>,
//!     some_data: FixedSizeVec<u64, DATA_CAPACITY>,
//! }
//!
//! # fn main() -> Result<(), Box<dyn std::error::Error>> {
//! let my_message = MyMessageType {
//!     some_text: FixedSizeByteString::from_bytes(b"Hello World")?,
//!     some_data: FixedSizeVec::new(),
//! };
//! # Ok(())
//! # }
//! ```
//!
//! ## 2. Shared Memory Compatible Run-Time FixedSize Containers
//!
//! Despite that the containers are already implemented, iceoryx2 itself does not yet support
//! run-time fixed size types. It is planned and will be part of an upcoming release.
//!
//! ## 3. Run-Time FixedSize Containers
//!
//! We create a struct consisting of run-time fixed size containers. This can be interesting when
//! it shall be used in a safety-critical environment where everything must be pre-allocated to
//! ensure that required memory is always available.
//!
//! ```
//! use iceoryx2_bb_container::queue::*;
//!
//! const QUEUE_CAPACITY: usize = 123;
//!
//! #[repr(C)]
//! struct MyType {
//!     some_queue: Queue<u64>,
//! }
//!
//! # fn main() -> Result<(), Box<dyn std::error::Error>> {
//! let my_thing = MyType {
//!     some_queue: Queue::new(QUEUE_CAPACITY),
//! };
//! # Ok(())
//! # }
//! ```

/// A byte string similar to [`std::string::String`] but it does not support UTF-8
pub mod byte_string;
/// A queue similar to [`std::collections::VecDeque`]
pub mod queue;
/// Extends the [ByteString](crate::byte_string) so that custom string types with a semantic
/// ruleset on their content can be realized.
#[macro_use]
pub mod semantic_string;
/// A vector similar to [`std::vec::Vec`]
pub mod vec;