wasmcloud_runtime/experimental.rs
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
use tracing::warn;
/// Feature flags to enable experimental functionality in the runtime. Flags are disabled
/// by default and must be explicitly enabled.
#[derive(Copy, Clone, Debug, Default)]
pub struct Features {
/// Enable the wasmcloud:messaging@v3 interface support in the runtime
pub wasmcloud_messaging_v3: bool,
}
impl Features {
/// Create a new set of feature flags with all features disabled
#[must_use]
pub fn new() -> Self {
Self::default()
}
/// Enable the wasmcloud:messaging@v3 interface support in the runtime
#[must_use]
pub fn enable_wasmcloud_messaging_v3(mut self) -> Self {
self.wasmcloud_messaging_v3 = true;
self
}
}
/// This enables unioning feature flags together
impl std::ops::BitOr for Features {
type Output = Self;
fn bitor(self, rhs: Self) -> Self::Output {
Self {
wasmcloud_messaging_v3: self.wasmcloud_messaging_v3 || rhs.wasmcloud_messaging_v3,
}
}
}
/// Allow for summing over a collection of feature flags
impl std::iter::Sum for Features {
fn sum<I: Iterator<Item = Self>>(mut iter: I) -> Self {
// Grab the first set of flags, fall back on defaults (all disabled)
let first = iter.next().unwrap_or_default();
iter.fold(first, |a, b| a | b)
}
}
/// Parse a feature flag from a string, enabling the feature if the string matches
impl From<&str> for Features {
fn from(s: &str) -> Self {
match &*s.to_ascii_lowercase() {
"wasmcloud-messaging-v3" | "wasmcloud_messaging_v3" => {
Self::new().enable_wasmcloud_messaging_v3()
}
_ => {
warn!(%s, "unknown feature flag");
Self::new()
}
}
}
}