struct TokenHandler<'a, 'tcx, F: Write> {
out: &'a mut F,
class_stack: ClassStack,
href_context: Option<HrefContext<'a, 'tcx>>,
line_number_kind: LineNumberKind,
line: u32,
max_lines: u32,
}Expand description
This type is used as a conveniency to prevent having to pass all its fields as arguments into the various functions (which became its methods).
Fields§
§out: &'a mut F§class_stack: ClassStack§href_context: Option<HrefContext<'a, 'tcx>>We need to keep the Class for each element because it could contain a Span which is
used to generate links.
line_number_kind: LineNumberKind§line: u32§max_lines: u32Implementations§
Source§impl<'a, F: Write> TokenHandler<'a, '_, F>
impl<'a, F: Write> TokenHandler<'a, '_, F>
fn handle_backline(&mut self) -> Option<impl Display + use<F>>
fn push_token_without_backline_check( &mut self, class: Option<Class>, text: Cow<'a, str>, needs_escape: bool, )
fn push_token(&mut self, class: Option<Class>, text: Cow<'a, str>)
fn start_expansion(&mut self)
fn add_expanded_code(&mut self, expanded_code: &ExpandedCode)
fn close_expansion(&mut self)
Sourcefn close_original_tag(&mut self)
fn close_original_tag(&mut self)
Used when we’re done with the current expansion “original code” (ie code before expansion).
We close all tags inside Class::Original and only keep the ones that were not closed yet.
Trait Implementations§
Source§impl<F: Write> Debug for TokenHandler<'_, '_, F>
impl<F: Write> Debug for TokenHandler<'_, '_, F>
Auto Trait Implementations§
impl<'a, 'tcx, F> Freeze for TokenHandler<'a, 'tcx, F>
impl<'a, 'tcx, F> !RefUnwindSafe for TokenHandler<'a, 'tcx, F>
impl<'a, 'tcx, F> !Send for TokenHandler<'a, 'tcx, F>
impl<'a, 'tcx, F> !Sync for TokenHandler<'a, 'tcx, F>
impl<'a, 'tcx, F> Unpin for TokenHandler<'a, 'tcx, F>
impl<'a, 'tcx, F> !UnwindSafe for TokenHandler<'a, 'tcx, F>
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> 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§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 104 bytes