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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// SPDX-License-Identifier: Apache-2.0
// Copyright 2026 ZeroDDS Contributors
//! Crate `zerodds-foundation`. Safety classification: **SAFE**.
//!
//! Foundation-Layer-Primitives fuer den ZeroDDS-Stack: Hot-Path-
//! Buffer-Pools, Wire-Integritaets-Hashes (CRC-32C / CRC-64-XZ / MD5),
//! Observability-Event-Sprache + Sinks, Tracing-Spans + Histogramme,
//! und ein Lock-Free-Read RCU-Cell-Container.
//!
//! `no_std`-tauglich, `forbid(unsafe_code)`. Pure-Rust ohne externe
//! Crates — die Foundation-Pillar-Idee „Frame bleibt nicht hohl".
//!
//! ## Schichten-Position
//!
//! Layer 0 (Foundation). Hat **keine** Dependencies auf andere
//! ZeroDDS-Crates. Wird von Layer 1 (Primitives: cdr, qos, types)
//! und allen hoeheren Schichten verwendet.
//!
//! Architektur-Referenz: `docs/architecture/02_architecture.md §3`
//! und `docs/architecture/04_safety_by_architecture.md §2`.
//!
//! ## Public API
//!
//! - **Stack-Buffer** ([`PoolBuffer`], [`PoolBufferError`]): fixed-capacity
//! Buffer fuer Hot-Path-Allokationen, on-stack mit `CAP`-Generic.
//! Append-Operationen sind O(1) ohne Heap-Touch; Overflow wird als
//! Result signalisiert statt zu panicen.
//! - **CRC + MD5** ([`crc32c`], [`crc64_xz`], [`md5`]): Wire-Integritaets-
//! Hashes; pure-Rust mit Standard-Lookup-Tables.
//! - **Observability** ([`Event`], [`Sink`], [`Level`], [`Component`],
//! [`NullSink`], [`StderrJsonSink`], [`VecSink`]): strukturierte
//! DDS-Events; Sink-Trait fuer beliebige Konsumenten.
//! - **Tracing** ([`Span`], [`SpanContext`], [`TraceId`], [`SpanId`],
//! [`SpanKind`], [`SpanStatus`], [`Histogram`]): Spans + Histogramme
//! fuer grobgranulares Tracing; OTLP-Export im
//! `zerodds-observability-otlp`-Crate.
//! - **RCU** ([`RcuCell`]): Copy-on-Write-Container fuer wenig-Schreib/
//! viel-Lese-Patterns ohne `unsafe`.
//!
//! ## Feature-Flags
//!
//! | Feature | Default | Zweck |
//! |---------|---------|-------|
//! | `std` | ✅ | Aktiviert `BufferPool`, `RcuCell`, `StderrJsonSink`, `VecSink`. Implies `alloc`. |
//! | `alloc` | ✅ (via `std`) | Aktiviert `observability` + `tracing` + MD5 mit Vec-Padding. |
//! | `safety` | ❌ | Reserviert fuer zukuenftige Safety-Build-Constraints. |
//!
//! Ohne Features (`default-features = false`): nur `PoolBuffer`,
//! `crc32c`, `crc64_xz`, `md5` (no_std-MD5-Pfad ist auf 56 Byte
//! Eingabe limitiert).
//!
//! ## Beispiel
//!
//! ```rust
//! use zerodds_foundation::{crc32c, PoolBuffer, PoolBufferError};
//!
//! // CRC-32C ueber ein RTPS-Datagramm.
//! let payload = b"\x52\x54\x50\x53\x02\x05\x01\x0F";
//! let checksum = crc32c(payload);
//! assert_eq!(checksum & 0xFFFF_FFFF, checksum);
//!
//! // Hot-Path-Buffer mit fester Kapazitaet.
//! let mut buf: PoolBuffer<256> = PoolBuffer::new();
//! buf.extend_from_slice(payload).unwrap();
//! assert_eq!(buf.as_slice(), payload);
//!
//! // Overflow ist explizit, kein Panic.
//! let mut tiny: PoolBuffer<4> = PoolBuffer::new();
//! assert_eq!(
//! tiny.extend_from_slice(payload),
//! Err(PoolBufferError::Overflow)
//! );
//! ```
extern crate alloc;
extern crate std;
pub use ;
pub use ;
pub use ;
pub use ;
pub use RcuCell;
pub use ;