Struct rustc_parse_format::Parser 
source · pub struct Parser<'a> {Show 13 fields
    pub(crate) mode: ParseMode,
    pub(crate) input: &'a str,
    pub(crate) cur: Peekable<CharIndices<'a>>,
    pub errors: Vec<ParseError>,
    pub curarg: usize,
    pub(crate) style: Option<usize>,
    pub arg_places: Vec<InnerSpan>,
    pub(crate) width_map: Vec<InnerWidthMapping>,
    pub(crate) last_opening_brace: Option<InnerSpan>,
    pub(crate) append_newline: bool,
    pub is_source_literal: bool,
    pub(crate) cur_line_start: usize,
    pub line_spans: Vec<InnerSpan>,
}Expand description
The parser structure for interpreting the input format string. This is
modeled as an iterator over Piece structures to form a stream of tokens
being output.
This is a recursive-descent parser for the sake of simplicity, and if necessary there’s probably lots of room for improvement performance-wise.
Fields§
§mode: ParseMode§input: &'a str§cur: Peekable<CharIndices<'a>>§errors: Vec<ParseError>Error messages accumulated during parsing
curarg: usizeCurrent position of implicit positional argument pointer
style: Option<usize>Some(raw count) when the string is “raw”, used to position spans correctly
arg_places: Vec<InnerSpan>Start and end byte offset of every successfully parsed argument
width_map: Vec<InnerWidthMapping>Characters whose length has been changed from their in-code representation
last_opening_brace: Option<InnerSpan>Span of the last opening brace seen, used for error reporting
append_newline: boolWhether the source string is comes from println! as opposed to format! or print!
is_source_literal: boolWhether this formatting string was written directly in the source. This controls whether we can use spans to refer into it and give better error messages. N.B: This does not control whether implicit argument captures can be used.
cur_line_start: usizeStart position of the current line.
line_spans: Vec<InnerSpan>Start and end byte offset of every line of the format string. Excludes newline characters and leading whitespace.
Implementations§
source§impl<'a> Parser<'a>
 
impl<'a> Parser<'a>
sourcepub fn new(
    s: &'a str,
    style: Option<usize>,
    snippet: Option<String>,
    append_newline: bool,
    mode: ParseMode
) -> Parser<'a> ⓘ
 
pub fn new( s: &'a str, style: Option<usize>, snippet: Option<String>, append_newline: bool, mode: ParseMode ) -> Parser<'a> ⓘ
Creates a new parser for the given format string
sourcepub(crate) fn err<S1: Into<String>, S2: Into<String>>(
    &mut self,
    description: S1,
    label: S2,
    span: InnerSpan
)
 
pub(crate) fn err<S1: Into<String>, S2: Into<String>>( &mut self, description: S1, label: S2, span: InnerSpan )
Notifies of an error. The message doesn’t actually need to be of type String, but I think it does when this eventually uses conditions so it might as well start using it now.
sourcepub(crate) fn err_with_note<S1: Into<String>, S2: Into<String>, S3: Into<String>>(
    &mut self,
    description: S1,
    label: S2,
    note: S3,
    span: InnerSpan
)
 
pub(crate) fn err_with_note<S1: Into<String>, S2: Into<String>, S3: Into<String>>( &mut self, description: S1, label: S2, note: S3, span: InnerSpan )
Notifies of an error. The message doesn’t actually need to be of type String, but I think it does when this eventually uses conditions so it might as well start using it now.
sourcepub(crate) fn consume(&mut self, c: char) -> bool
 
pub(crate) fn consume(&mut self, c: char) -> bool
Optionally consumes the specified character. If the character is not at
the current position, then the current iterator isn’t moved and false is
returned, otherwise the character is consumed and true is returned.
sourcepub(crate) fn consume_pos(&mut self, c: char) -> Option<usize>
 
pub(crate) fn consume_pos(&mut self, c: char) -> Option<usize>
Optionally consumes the specified character. If the character is not at
the current position, then the current iterator isn’t moved and None is
returned, otherwise the character is consumed and the current position is
returned.
pub(crate) fn remap_pos(&self, pos: usize) -> InnerOffset
pub(crate) fn to_span_index(&self, pos: usize) -> InnerOffset
pub(crate) fn to_span_width(&self, pos: usize) -> usize
pub(crate) fn span(&self, start_pos: usize, end_pos: usize) -> InnerSpan
sourcepub(crate) fn consume_closing_brace(
    &mut self,
    arg: &Argument<'_>
) -> Option<usize>
 
pub(crate) fn consume_closing_brace( &mut self, arg: &Argument<'_> ) -> Option<usize>
Forces consumption of the specified character. If the character is not found, an error is emitted.
sourcepub(crate) fn ws(&mut self)
 
pub(crate) fn ws(&mut self)
Consumes all whitespace characters until the first non-whitespace character
sourcepub(crate) fn string(&mut self, start: usize) -> &'a str
 
pub(crate) fn string(&mut self, start: usize) -> &'a str
Parses all of a string which is to be considered a “raw literal” in a format string. This is everything outside of the braces.
sourcepub(crate) fn argument(&mut self, start: InnerOffset) -> Argument<'a>
 
pub(crate) fn argument(&mut self, start: InnerOffset) -> Argument<'a>
Parses an Argument structure, or what’s contained within braces inside the format string.
sourcepub(crate) fn position(&mut self) -> Option<Position<'a>>
 
pub(crate) fn position(&mut self) -> Option<Position<'a>>
Parses a positional argument for a format. This could either be an
integer index of an argument, a named argument, or a blank string.
Returns Some(parsed_position) if the position is not implicitly
consuming a macro argument, None if it’s the case.
pub(crate) fn current_pos(&mut self) -> usize
sourcepub(crate) fn format(&mut self) -> FormatSpec<'a>
 
pub(crate) fn format(&mut self) -> FormatSpec<'a>
Parses a format specifier at the current position, returning all of the
relevant information in the FormatSpec struct.
sourcepub(crate) fn inline_asm(&mut self) -> FormatSpec<'a>
 
pub(crate) fn inline_asm(&mut self) -> FormatSpec<'a>
Parses an inline assembly template modifier at the current position, returning the modifier
in the ty field of the FormatSpec struct.
sourcepub(crate) fn count(&mut self, start: usize) -> Count<'a>
 
pub(crate) fn count(&mut self, start: usize) -> Count<'a>
Parses a Count parameter at the current position. This does not check
for ‘CountIsNextParam’ because that is only used in precision, not
width.
sourcepub(crate) fn word(&mut self) -> &'a str
 
pub(crate) fn word(&mut self) -> &'a str
Parses a word starting at the current position. A word is the same as
Rust identifier, except that it can’t start with _ character.
pub(crate) fn integer(&mut self) -> Option<usize>
pub(crate) fn suggest_format_debug(&mut self)
pub(crate) fn suggest_format_align(&mut self, alignment: char)
pub(crate) fn suggest_positional_arg_instead_of_captured_arg( &mut self, arg: Argument<'a> )
Trait Implementations§
source§impl<'a> Iterator for Parser<'a>
 
impl<'a> Iterator for Parser<'a>
source§fn next(&mut self) -> Option<Piece<'a>>
 
fn next(&mut self) -> Option<Piece<'a>>
source§fn next_chunk<const N: usize>(
    &mut self
) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>where
    Self: Sized,
 
fn next_chunk<const N: usize>(
    &mut self
) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>where
    Self: Sized,
iter_next_chunk)N values. Read more1.0.0 · source§fn size_hint(&self) -> (usize, Option<usize>)
 
fn size_hint(&self) -> (usize, Option<usize>)
1.0.0 · source§fn count(self) -> usizewhere
    Self: Sized,
 
fn count(self) -> usizewhere
    Self: Sized,
1.0.0 · source§fn last(self) -> Option<Self::Item>where
    Self: Sized,
 
fn last(self) -> Option<Self::Item>where
    Self: Sized,
source§fn advance_by(&mut self, n: usize) -> Result<(), NonZero<usize>>
 
fn advance_by(&mut self, n: usize) -> Result<(), NonZero<usize>>
iter_advance_by)n elements. Read more1.0.0 · source§fn nth(&mut self, n: usize) -> Option<Self::Item>
 
fn nth(&mut self, n: usize) -> Option<Self::Item>
nth element of the iterator. Read more1.28.0 · source§fn step_by(self, step: usize) -> StepBy<Self>where
    Self: Sized,
 
fn step_by(self, step: usize) -> StepBy<Self>where
    Self: Sized,
1.0.0 · source§fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>
 
fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>
1.0.0 · source§fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>where
    Self: Sized,
    U: IntoIterator,
 
fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>where
    Self: Sized,
    U: IntoIterator,
source§fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>
 
fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>
iter_intersperse)separator
between adjacent items of the original iterator. Read more1.0.0 · source§fn map<B, F>(self, f: F) -> Map<Self, F>
 
fn map<B, F>(self, f: F) -> Map<Self, F>
1.0.0 · source§fn filter<P>(self, predicate: P) -> Filter<Self, P>
 
fn filter<P>(self, predicate: P) -> Filter<Self, P>
1.0.0 · source§fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>
 
fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>
1.0.0 · source§fn enumerate(self) -> Enumerate<Self>where
    Self: Sized,
 
fn enumerate(self) -> Enumerate<Self>where
    Self: Sized,
1.0.0 · source§fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>
 
fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>
1.0.0 · source§fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>
 
fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>
1.57.0 · source§fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>
 
fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>
1.0.0 · source§fn skip(self, n: usize) -> Skip<Self>where
    Self: Sized,
 
fn skip(self, n: usize) -> Skip<Self>where
    Self: Sized,
n elements. Read more1.0.0 · source§fn take(self, n: usize) -> Take<Self>where
    Self: Sized,
 
fn take(self, n: usize) -> Take<Self>where
    Self: Sized,
n elements, or fewer
if the underlying iterator ends sooner. Read more1.0.0 · source§fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>
 
fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>
source§fn map_windows<F, R, const N: usize>(self, f: F) -> MapWindows<Self, F, N>
 
fn map_windows<F, R, const N: usize>(self, f: F) -> MapWindows<Self, F, N>
iter_map_windows)f for each contiguous window of size N over
self and returns an iterator over the outputs of f. Like slice::windows(),
the windows during mapping overlap as well. Read more1.0.0 · source§fn inspect<F>(self, f: F) -> Inspect<Self, F>
 
fn inspect<F>(self, f: F) -> Inspect<Self, F>
1.0.0 · source§fn by_ref(&mut self) -> &mut Selfwhere
    Self: Sized,
 
fn by_ref(&mut self) -> &mut Selfwhere
    Self: Sized,
source§fn collect_into<E>(self, collection: &mut E) -> &mut E
 
fn collect_into<E>(self, collection: &mut E) -> &mut E
iter_collect_into)1.0.0 · source§fn partition<B, F>(self, f: F) -> (B, B)
 
fn partition<B, F>(self, f: F) -> (B, B)
source§fn is_partitioned<P>(self, predicate: P) -> bool
 
fn is_partitioned<P>(self, predicate: P) -> bool
iter_is_partitioned)true precede all those that return false. Read more1.27.0 · source§fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R
 
fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R
1.27.0 · source§fn try_for_each<F, R>(&mut self, f: F) -> R
 
fn try_for_each<F, R>(&mut self, f: F) -> R
1.0.0 · source§fn fold<B, F>(self, init: B, f: F) -> B
 
fn fold<B, F>(self, init: B, f: F) -> B
1.51.0 · source§fn reduce<F>(self, f: F) -> Option<Self::Item>
 
fn reduce<F>(self, f: F) -> Option<Self::Item>
source§fn try_reduce<F, R>(
    &mut self,
    f: F
) -> <<R as Try>::Residual as Residual<Option<<R as Try>::Output>>>::TryType
 
fn try_reduce<F, R>( &mut self, f: F ) -> <<R as Try>::Residual as Residual<Option<<R as Try>::Output>>>::TryType
iterator_try_reduce)1.0.0 · source§fn all<F>(&mut self, f: F) -> bool
 
fn all<F>(&mut self, f: F) -> bool
1.0.0 · source§fn any<F>(&mut self, f: F) -> bool
 
fn any<F>(&mut self, f: F) -> bool
1.0.0 · source§fn find<P>(&mut self, predicate: P) -> Option<Self::Item>
 
fn find<P>(&mut self, predicate: P) -> Option<Self::Item>
1.30.0 · source§fn find_map<B, F>(&mut self, f: F) -> Option<B>
 
fn find_map<B, F>(&mut self, f: F) -> Option<B>
source§fn try_find<F, R>(
    &mut self,
    f: F
) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryType
 
fn try_find<F, R>( &mut self, f: F ) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryType
try_find)1.0.0 · source§fn position<P>(&mut self, predicate: P) -> Option<usize>
 
fn position<P>(&mut self, predicate: P) -> Option<usize>
1.6.0 · source§fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>
 
fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>
1.15.0 · source§fn max_by<F>(self, compare: F) -> Option<Self::Item>
 
fn max_by<F>(self, compare: F) -> Option<Self::Item>
1.6.0 · source§fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>
 
fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>
1.15.0 · source§fn min_by<F>(self, compare: F) -> Option<Self::Item>
 
fn min_by<F>(self, compare: F) -> Option<Self::Item>
1.0.0 · source§fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)
 
fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)
1.36.0 · source§fn copied<'a, T>(self) -> Copied<Self>
 
fn copied<'a, T>(self) -> Copied<Self>
source§fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>where
    Self: Sized,
 
fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>where
    Self: Sized,
iter_array_chunks)N elements of the iterator at a time. Read more1.11.0 · source§fn product<P>(self) -> P
 
fn product<P>(self) -> P
source§fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering
 
fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering
iter_order_by)Iterator with those
of another with respect to the specified comparison function. Read more1.5.0 · source§fn partial_cmp<I>(self, other: I) -> Option<Ordering>
 
fn partial_cmp<I>(self, other: I) -> Option<Ordering>
PartialOrd elements of
this Iterator with those of another. The comparison works like short-circuit
evaluation, returning a result without comparing the remaining elements.
As soon as an order can be determined, the evaluation stops and a result is returned. Read moresource§fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering>where
    Self: Sized,
    I: IntoIterator,
    F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
 
fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering>where
    Self: Sized,
    I: IntoIterator,
    F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
iter_order_by)Iterator with those
of another with respect to the specified comparison function. Read moresource§fn eq_by<I, F>(self, other: I, eq: F) -> bool
 
fn eq_by<I, F>(self, other: I, eq: F) -> bool
iter_order_by)1.5.0 · source§fn lt<I>(self, other: I) -> bool
 
fn lt<I>(self, other: I) -> bool
Iterator are lexicographically
less than those of another. Read more1.5.0 · source§fn le<I>(self, other: I) -> bool
 
fn le<I>(self, other: I) -> bool
Iterator are lexicographically
less or equal to those of another. Read more1.5.0 · source§fn gt<I>(self, other: I) -> bool
 
fn gt<I>(self, other: I) -> bool
Iterator are lexicographically
greater than those of another. Read more1.5.0 · source§fn ge<I>(self, other: I) -> bool
 
fn ge<I>(self, other: I) -> bool
Iterator are lexicographically
greater than or equal to those of another. Read moresource§fn is_sorted_by<F>(self, compare: F) -> bool
 
fn is_sorted_by<F>(self, compare: F) -> bool
is_sorted)source§fn is_sorted_by_key<F, K>(self, f: F) -> bool
 
fn is_sorted_by_key<F, K>(self, f: F) -> bool
is_sorted)Auto Trait Implementations§
impl<'a> Freeze for Parser<'a>
impl<'a> RefUnwindSafe for Parser<'a>
impl<'a> Send for Parser<'a>
impl<'a> Sync for Parser<'a>
impl<'a> Unpin for Parser<'a>
impl<'a> UnwindSafe for Parser<'a>
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
source§impl<I> IntoIterator for Iwhere
    I: Iterator,
 
impl<I> IntoIterator for Iwhere
    I: Iterator,
§impl<T> Pointable for T
 
impl<T> Pointable for T
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: 216 bytes