pub enum StandardToken<Char, CS>{
ControlSequence(CS),
Character(Char, CommandCode),
Primitive(PrimitiveIdentifier),
}
Expand description
Variants§
Trait Implementations§
Source§impl<Char, CS> Clone for StandardToken<Char, CS>
impl<Char, CS> Clone for StandardToken<Char, CS>
Source§fn clone(&self) -> StandardToken<Char, CS>
fn clone(&self) -> StandardToken<Char, CS>
Returns a duplicate 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<Char, CS> Debug for StandardToken<Char, CS>
impl<Char, CS> Debug for StandardToken<Char, CS>
Source§impl<Char, CS> PartialEq for StandardToken<Char, CS>
impl<Char, CS> PartialEq for StandardToken<Char, CS>
Source§impl<Char, CS> Token for StandardToken<Char, CS>
impl<Char, CS> Token for StandardToken<Char, CS>
Source§type CS = CS
type CS = CS
The
CSName
type used for control sequence names (e.g. Rc<str>
or something interned).Source§fn to_enum(&self) -> StandardToken<Char, CS>
fn to_enum(&self) -> StandardToken<Char, CS>
Converts to the canonical enum representation of a token, i.e.
StandardToken
.Source§fn from_cs(cs: CS) -> StandardToken<Char, CS>
fn from_cs(cs: CS) -> StandardToken<Char, CS>
Create a new token from a control sequence name.
Source§fn space() -> StandardToken<Char, CS>
fn space() -> StandardToken<Char, CS>
Create a new space token.
Source§fn eof() -> StandardToken<Char, CS>
fn eof() -> StandardToken<Char, CS>
Create a new end-of-file token.
Source§fn from_char_cat(c: Char, cat: CommandCode) -> StandardToken<Char, CS>
fn from_char_cat(c: Char, cat: CommandCode) -> StandardToken<Char, CS>
Create a new character token with given
CommandCode
(i.e.
conceptually the CategoryCode
).Source§fn primitive(id: PrimitiveIdentifier) -> StandardToken<Char, CS>
fn primitive(id: PrimitiveIdentifier) -> StandardToken<Char, CS>
Source§fn argument_marker(i: u8) -> StandardToken<Char, CS>
fn argument_marker(i: u8) -> StandardToken<Char, CS>
Create a new argument marker token.
i
needs to be in the range 0..=8
.Source§fn char_value(&self) -> Option<Self::Char>
fn char_value(&self) -> Option<Self::Char>
The
Character
value of this token, if it is a character token.Source§fn command_code(&self) -> CommandCode
fn command_code(&self) -> CommandCode
The
CommandCode
(i.e. conceptually the CategoryCode
) of this token.Source§fn is_cs_or_active(&self) -> bool
fn is_cs_or_active(&self) -> bool
Check if this token is a control sequence or an active character
Source§fn is_cs(&self, name: &Self::CS) -> bool
fn is_cs(&self, name: &Self::CS) -> bool
Check if this token is a control sequence with the given name.
fn is_primitive(&self) -> Option<PrimitiveIdentifier>
Source§fn is_argument_marker(&self) -> Option<u8>
fn is_argument_marker(&self) -> Option<u8>
Check if this token is a argument token, and if so, return its number (in the range
0..=8
).Source§fn display_fmt<W>(
&self,
int: &<Self::CS as CSName<Self::Char>>::Handler,
cc: &<Self::Char as Character>::CharMap<CategoryCode>,
escapechar: Option<Self::Char>,
f: &mut W,
) -> Result<(), Error>where
W: Write,
fn display_fmt<W>(
&self,
int: &<Self::CS as CSName<Self::Char>>::Handler,
cc: &<Self::Char as Character>::CharMap<CategoryCode>,
escapechar: Option<Self::Char>,
f: &mut W,
) -> Result<(), Error>where
W: Write,
Display this token to a writer, using the given
CSHandler
(in case it is a control sequence).
In that case, we also need the current \escapechar
to optionally insert it in front of the control sequence
name, and the current CategoryCodeScheme
to determine whether or not to insert a space afterwards - which
we do unless the control sequence name is a single character with any CommandCode
other than
Letter
.impl<Char, CS> Copy for StandardToken<Char, CS>
impl<Char, CS> Eq for StandardToken<Char, CS>
Auto Trait Implementations§
impl<Char, CS> Freeze for StandardToken<Char, CS>
impl<Char, CS> RefUnwindSafe for StandardToken<Char, CS>where
CS: RefUnwindSafe,
Char: RefUnwindSafe,
impl<Char, CS> Send for StandardToken<Char, CS>
impl<Char, CS> Sync for StandardToken<Char, CS>
impl<Char, CS> Unpin for StandardToken<Char, CS>
impl<Char, CS> UnwindSafe for StandardToken<Char, CS>where
CS: UnwindSafe,
Char: UnwindSafe,
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
§fn deserialize(
&self,
deserializer: &mut D,
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>
Deserializes using the given deserializer
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
, which can then be
downcast
into Box<dyn ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
, which can then be further
downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSend for T
impl<T> DowncastSend for T
§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more