Praborrow Core
Core primitives for the PraBorrow distributed systems framework. This crate provides the foundational types for enforcing sovereign ownership semantics across network boundaries.
Sovereign
The Sovereign<T> wrapper implements a distinct state machine for data ownership:
- Domestic: Data is local and accessible via
Deref. - Exiled: Data has been moved to a remote node. Access attempts trigger a panic (or return
Errwithtry_get).
Usage
use ;
let data = new;
// Access allowed (Domestic)
assert_eq!;
// Safe access with error handling (v0.5+)
assert!;
// Transition state
data.annex.expect;
// Graceful error handling instead of panic
match data.try_get
Thread Safety
Uses AtomicU8 for state tracking, ensuring Send + Sync compliance where T: Send + Sync.