pub struct Choice<Fst, Snd>(pub Fst, pub Snd);Expand description
Combinator that tries the Fst combinator and if it fails, tries the Snd combinator.
Tuple Fields§
§0: Fst§1: SndImplementations§
Trait Implementations§
Source§impl<'x, I, O, Fst, Snd> Combinator<'x, I, O> for Choice<Fst, Snd>where
I: VestInput,
O: VestOutput<I>,
Fst: Combinator<'x, I, O>,
Snd: Combinator<'x, I, O>,
Fst::V: SecureSpecCombinator<Type = <Fst::Type as View>::V>,
Snd::V: SecureSpecCombinator<Type = <Snd::Type as View>::V> + DisjointFrom<Fst::V>,
impl<'x, I, O, Fst, Snd> Combinator<'x, I, O> for Choice<Fst, Snd>where
I: VestInput,
O: VestOutput<I>,
Fst: Combinator<'x, I, O>,
Snd: Combinator<'x, I, O>,
Fst::V: SecureSpecCombinator<Type = <Fst::Type as View>::V>,
Snd::V: SecureSpecCombinator<Type = <Snd::Type as View>::V> + DisjointFrom<Fst::V>,
Source§open spec fn ex_requires(&self) -> bool
open spec fn ex_requires(&self) -> bool
{ self.0.ex_requires() && self.1.ex_requires() }Source§exec fn serialize(
&self,
v: Self::SType,
data: &mut O,
pos: usize,
) -> res : Result<usize, SerializeError>
exec fn serialize( &self, v: Self::SType, data: &mut O, pos: usize, ) -> res : Result<usize, SerializeError>
Source§type Type = Either<<Fst as Combinator<'x, I, O>>::Type, <Snd as Combinator<'x, I, O>>::Type>
type Type = Either<<Fst as Combinator<'x, I, O>>::Type, <Snd as Combinator<'x, I, O>>::Type>
The result type of parsing
Source§type SType = Either<<Fst as Combinator<'x, I, O>>::SType, <Snd as Combinator<'x, I, O>>::SType>
type SType = Either<<Fst as Combinator<'x, I, O>>::SType, <Snd as Combinator<'x, I, O>>::SType>
The input type of serialization, often a reference to
Self::Type.
For “structural” formats though (e.g., crate::regular::sequence::Pair and crate::regular::variant::Choice),
this is the tuple/sum of the corresponding Combinator::SType types.Source§impl<S1, S2, S3> DisjointFrom<S3> for Choice<S1, S2>where
S1: SpecCombinator + DisjointFrom<S3>,
S2: SpecCombinator + DisjointFrom<S1> + DisjointFrom<S3>,
S3: SpecCombinator,
impl<S1, S2, S3> DisjointFrom<S3> for Choice<S1, S2>where
S1: SpecCombinator + DisjointFrom<S3>,
S2: SpecCombinator + DisjointFrom<S1> + DisjointFrom<S3>,
S3: SpecCombinator,
Source§open spec fn disjoint_from(&self, other: &S3) -> bool
open spec fn disjoint_from(&self, other: &S3) -> bool
{ self.0.disjoint_from(other) && self.1.disjoint_from(other) }Source§proof fn parse_disjoint_on(&self, other: &S3, buf: Seq<u8>)
proof fn parse_disjoint_on(&self, other: &S3, buf: Seq<u8>)
Source§impl<Fst, Snd> SecureSpecCombinator for Choice<Fst, Snd>
impl<Fst, Snd> SecureSpecCombinator for Choice<Fst, Snd>
Source§open spec fn is_prefix_secure() -> bool
open spec fn is_prefix_secure() -> bool
{ Fst::is_prefix_secure() && Snd::is_prefix_secure() }Source§open spec fn is_productive(&self) -> bool
open spec fn is_productive(&self) -> bool
{ self.0.is_productive() && self.1.is_productive() }Source§proof fn lemma_prefix_secure(&self, s1: Seq<u8>, s2: Seq<u8>)
proof fn lemma_prefix_secure(&self, s1: Seq<u8>, s2: Seq<u8>)
Source§proof fn theorem_serialize_parse_roundtrip(&self, v: Self::Type)
proof fn theorem_serialize_parse_roundtrip(&self, v: Self::Type)
Source§proof fn theorem_parse_serialize_roundtrip(&self, buf: Seq<u8>)
proof fn theorem_parse_serialize_roundtrip(&self, buf: Seq<u8>)
Source§proof fn lemma_parse_length(&self, s: Seq<u8>)
proof fn lemma_parse_length(&self, s: Seq<u8>)
Source§proof fn lemma_parse_productive(&self, s: Seq<u8>)
proof fn lemma_parse_productive(&self, s: Seq<u8>)
Source§fn corollary_parse_surjective(&self, v: Self::Type)
fn corollary_parse_surjective(&self, v: Self::Type)
Source§fn corollary_serialize_injective_contraposition(
&self,
v1: Self::Type,
v2: Self::Type,
)
fn corollary_serialize_injective_contraposition( &self, v1: Self::Type, v2: Self::Type, )
Source§fn lemma_serialize_productive(&self, v: Self::Type)
fn lemma_serialize_productive(&self, v: Self::Type)
Source§impl<Fst, Snd> SpecCombinator for Choice<Fst, Snd>
impl<Fst, Snd> SpecCombinator for Choice<Fst, Snd>
Source§open spec fn requires(&self) -> bool
open spec fn requires(&self) -> bool
{ self.0.requires() && self.1.requires() && self.1.disjoint_from(&self.0) }Source§open spec fn wf(&self, v: Self::Type) -> bool
open spec fn wf(&self, v: Self::Type) -> bool
{
match v {
Either::Left(v) => self.0.wf(v),
Either::Right(v) => self.1.wf(v),
}
}Source§open spec fn spec_parse(&self, s: Seq<u8>) -> Option<(int, Self::Type)>
open spec fn spec_parse(&self, s: Seq<u8>) -> Option<(int, Self::Type)>
{
if let Some((n, v)) = self.0.spec_parse(s) {
Some((n, Either::Left(v)))
} else {
if let Some((n, v)) = self.1.spec_parse(s) {
Some((n, Either::Right(v)))
} else {
None
}
}
}Source§open spec fn spec_serialize(&self, v: Self::Type) -> Seq<u8>
open spec fn spec_serialize(&self, v: Self::Type) -> Seq<u8>
{
match v {
Either::Left(v) => self.0.spec_serialize(v),
Either::Right(v) => self.1.spec_serialize(v),
}
}Source§type Type = Either<<Fst as SpecCombinator>::Type, <Snd as SpecCombinator>::Type>
type Type = Either<<Fst as SpecCombinator>::Type, <Snd as SpecCombinator>::Type>
The view of [
Combinator::Result].Auto Trait Implementations§
impl<Fst, Snd> Freeze for Choice<Fst, Snd>
impl<Fst, Snd> RefUnwindSafe for Choice<Fst, Snd>where
Fst: RefUnwindSafe,
Snd: RefUnwindSafe,
impl<Fst, Snd> Send for Choice<Fst, Snd>
impl<Fst, Snd> Sync for Choice<Fst, Snd>
impl<Fst, Snd> Unpin for Choice<Fst, Snd>
impl<Fst, Snd> UnwindSafe for Choice<Fst, Snd>where
Fst: UnwindSafe,
Snd: 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
§impl<T, VERUS_SPEC__A> FromSpec<T> for VERUS_SPEC__Awhere
VERUS_SPEC__A: From<T>,
impl<T, VERUS_SPEC__A> FromSpec<T> for VERUS_SPEC__Awhere
VERUS_SPEC__A: From<T>,
fn obeys_from_spec() -> bool
fn from_spec(v: T) -> VERUS_SPEC__A
§impl<T, VERUS_SPEC__A> IntoSpec<T> for VERUS_SPEC__Awhere
VERUS_SPEC__A: Into<T>,
impl<T, VERUS_SPEC__A> IntoSpec<T> for VERUS_SPEC__Awhere
VERUS_SPEC__A: Into<T>,
fn obeys_into_spec() -> bool
fn into_spec(self) -> T
§impl<T, U> IntoSpecImpl<U> for Twhere
U: From<T>,
impl<T, U> IntoSpecImpl<U> for Twhere
U: From<T>,
fn obeys_into_spec() -> bool
fn into_spec(self) -> U
Source§impl<T, U> SpecTryInto<U> for Twhere
U: SpecTryFrom<T>,
impl<T, U> SpecTryInto<U> for Twhere
U: SpecTryFrom<T>,
Source§open spec fn spec_try_into(self) -> Result<U, <U as SpecTryFrom<T>>::Error>
open spec fn spec_try_into(self) -> Result<U, <U as SpecTryFrom<T>>::Error>
{ U::spec_try_from(self) }Source§type Error = <U as SpecTryFrom<T>>::Error
type Error = <U as SpecTryFrom<T>>::Error
The type returned in the event of a conversion error.