pub enum SourceDataEncoding<C: ConnectionAccess = InlinedConnection> {
Single(DataEncoding<C>),
KeyValue {
key: DataEncoding<C>,
value: DataEncoding<C>,
},
}
Expand description
A description of how to interpret data from various sources
Almost all sources only present values as part of their records, but Kafka allows a key to be associated with each record, which has a possibly independent encoding.
Variants§
Implementations§
source§impl<C: ConnectionAccess> SourceDataEncoding<C>
impl<C: ConnectionAccess> SourceDataEncoding<C>
pub fn key_ref(&self) -> Option<&DataEncoding<C>>
sourcepub fn value(self) -> DataEncoding<C>
pub fn value(self) -> DataEncoding<C>
Return either the Single encoding if this was a SourceDataEncoding::Single
, else return the value encoding
pub fn value_ref(&self) -> &DataEncoding<C>
pub fn desc(&self) -> Result<(Option<RelationDesc>, RelationDesc), Error>
Trait Implementations§
source§impl<C: ConnectionAccess + Arbitrary> Arbitrary for SourceDataEncoding<C>
impl<C: ConnectionAccess + Arbitrary> Arbitrary for SourceDataEncoding<C>
§type Parameters = (<DataEncoding<C> as Arbitrary>::Parameters, (<DataEncoding<C> as Arbitrary>::Parameters, <DataEncoding<C> as Arbitrary>::Parameters))
type Parameters = (<DataEncoding<C> as Arbitrary>::Parameters, (<DataEncoding<C> as Arbitrary>::Parameters, <DataEncoding<C> as Arbitrary>::Parameters))
The type of parameters that
arbitrary_with
accepts for configuration
of the generated Strategy
. Parameters must implement Default
.§type Strategy = Union<BoxedStrategy<SourceDataEncoding<C>>>
type Strategy = Union<BoxedStrategy<SourceDataEncoding<C>>>
The type of
Strategy
used to generate values of type Self
.source§fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
source§impl<C: Clone + ConnectionAccess> Clone for SourceDataEncoding<C>
impl<C: Clone + ConnectionAccess> Clone for SourceDataEncoding<C>
source§fn clone(&self) -> SourceDataEncoding<C>
fn clone(&self) -> SourceDataEncoding<C>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<C: Debug + ConnectionAccess> Debug for SourceDataEncoding<C>
impl<C: Debug + ConnectionAccess> Debug for SourceDataEncoding<C>
source§impl<'de, C> Deserialize<'de> for SourceDataEncoding<C>where
C: Deserialize<'de> + ConnectionAccess,
impl<'de, C> Deserialize<'de> for SourceDataEncoding<C>where C: Deserialize<'de> + ConnectionAccess,
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl<R: ConnectionResolver> IntoInlineConnection<SourceDataEncoding<InlinedConnection>, R> for SourceDataEncoding<ReferencedConnection>
impl<R: ConnectionResolver> IntoInlineConnection<SourceDataEncoding<InlinedConnection>, R> for SourceDataEncoding<ReferencedConnection>
fn into_inline_connection(self, r: R) -> SourceDataEncoding
source§impl<C: PartialEq + ConnectionAccess> PartialEq<SourceDataEncoding<C>> for SourceDataEncoding<C>
impl<C: PartialEq + ConnectionAccess> PartialEq<SourceDataEncoding<C>> for SourceDataEncoding<C>
source§fn eq(&self, other: &SourceDataEncoding<C>) -> bool
fn eq(&self, other: &SourceDataEncoding<C>) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl RustType<ProtoSourceDataEncoding> for SourceDataEncoding
impl RustType<ProtoSourceDataEncoding> for SourceDataEncoding
source§fn into_proto(&self) -> ProtoSourceDataEncoding
fn into_proto(&self) -> ProtoSourceDataEncoding
Convert a
Self
into a Proto
value.source§fn from_proto(proto: ProtoSourceDataEncoding) -> Result<Self, TryFromProtoError>
fn from_proto(proto: ProtoSourceDataEncoding) -> Result<Self, TryFromProtoError>
source§impl<C> Serialize for SourceDataEncoding<C>where
C: Serialize + ConnectionAccess,
impl<C> Serialize for SourceDataEncoding<C>where C: Serialize + ConnectionAccess,
impl<C: Eq + ConnectionAccess> Eq for SourceDataEncoding<C>
impl<C: ConnectionAccess> StructuralEq for SourceDataEncoding<C>
impl<C: ConnectionAccess> StructuralPartialEq for SourceDataEncoding<C>
Auto Trait Implementations§
impl<C> RefUnwindSafe for SourceDataEncoding<C>where <C as ConnectionAccess>::Ssh: RefUnwindSafe,
impl<C> Send for SourceDataEncoding<C>where <C as ConnectionAccess>::Ssh: Send,
impl<C> Sync for SourceDataEncoding<C>where <C as ConnectionAccess>::Ssh: Sync,
impl<C> Unpin for SourceDataEncoding<C>where <C as ConnectionAccess>::Ssh: Unpin,
impl<C> UnwindSafe for SourceDataEncoding<C>where <C as ConnectionAccess>::Ssh: UnwindSafe,
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<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.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
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
.