Struct mz_persist_client::cache::LockingTypedState
source · pub(crate) struct LockingTypedState<K, V, T, D> {
shard_id: ShardId,
state: RwLock<TypedState<K, V, T, D>>,
notifier: StateWatchNotifier,
cfg: Arc<PersistConfig>,
metrics: Arc<Metrics>,
shard_metrics: Arc<ShardMetrics>,
_subscription_token: Arc<ShardSubscriptionToken>,
}
Expand description
A locked decorator for TypedState that abstracts out the specific lock implementation used. Guards the private lock with public accessor fns to make locking scopes more explicit and simpler to reason about.
Fields§
§shard_id: ShardId
§state: RwLock<TypedState<K, V, T, D>>
§notifier: StateWatchNotifier
§cfg: Arc<PersistConfig>
§metrics: Arc<Metrics>
§shard_metrics: Arc<ShardMetrics>
§_subscription_token: Arc<ShardSubscriptionToken>
Implementations§
source§impl<K, V, T, D> LockingTypedState<K, V, T, D>
impl<K, V, T, D> LockingTypedState<K, V, T, D>
fn new( shard_id: ShardId, initial_state: TypedState<K, V, T, D>, metrics: Arc<Metrics>, cfg: Arc<PersistConfig>, subscription_token: Arc<ShardSubscriptionToken>, diagnostics: &Diagnostics ) -> Self
pub(crate) fn shard_id(&self) -> &ShardId
pub(crate) fn read_lock<R, F: FnMut(&TypedState<K, V, T, D>) -> R>( &self, metrics: &LockMetrics, f: F ) -> R
pub(crate) fn write_lock<R, F: FnOnce(&mut TypedState<K, V, T, D>) -> R>( &self, metrics: &LockMetrics, f: F ) -> R
pub(crate) fn notifier(&self) -> &StateWatchNotifier
Trait Implementations§
source§impl<K, V, T: Debug, D> Debug for LockingTypedState<K, V, T, D>
impl<K, V, T: Debug, D> Debug for LockingTypedState<K, V, T, D>
Auto Trait Implementations§
impl<K, V, T, D> !RefUnwindSafe for LockingTypedState<K, V, T, D>
impl<K, V, T, D> Send for LockingTypedState<K, V, T, D>where T: Send + Sync,
impl<K, V, T, D> Sync for LockingTypedState<K, V, T, D>where T: Send + Sync,
impl<K, V, T, D> Unpin for LockingTypedState<K, V, T, D>where T: Unpin,
impl<K, V, T, D> !UnwindSafe for LockingTypedState<K, V, T, D>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> FutureExt for T
impl<T> FutureExt for T
source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request
Creates a shared type from an unshared type.
source§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<P, R> ProtoType<R> for Pwhere
R: RustType<P>,
impl<P, R> ProtoType<R> for Pwhere R: RustType<P>,
source§fn into_rust(self) -> Result<R, TryFromProtoError>
fn into_rust(self) -> Result<R, TryFromProtoError>
See
RustType::from_proto
.source§fn from_rust(rust: &R) -> P
fn from_rust(rust: &R) -> P
See
RustType::into_proto
.