Struct Stream

Source
pub struct Stream<'a> {
    text: &'a str,
    pos: usize,
}
Expand description

A streaming text parsing interface.

Fields§

§text: &'a str§pos: usize

Implementations§

Source§

impl Stream<'_>

Source

pub fn parse_angle(&mut self) -> Result<Angle, Error>

Parses angle from the stream.

https://www.w3.org/TR/SVG2/types.html#InterfaceSVGAngle

§Notes
  • Suffix must be lowercase, otherwise it will be an error.
Source§

impl Stream<'_>

Source

pub fn try_parse_color(&mut self) -> Option<Color>

Tries to parse a color, but doesn’t advance on error.

Source

pub fn parse_color(&mut self) -> Result<Color, Error>

Parses a color.

Source§

impl Stream<'_>

Source

pub fn parse_directional_position( &mut self, ) -> Result<DirectionalPosition, Error>

Parses a directional position [left, center, right, bottom, top] from the stream.

Source§

impl Stream<'_>

Source§

impl<'a> Stream<'a>

Source

pub fn parse_iri(&mut self) -> Result<&'a str, Error>

Source

pub fn parse_func_iri(&mut self) -> Result<&'a str, Error>

Source§

impl Stream<'_>

Source

pub fn parse_length(&mut self) -> Result<Length, Error>

Parses length from the stream.

https://www.w3.org/TR/SVG2/types.html#InterfaceSVGLength

§Notes
  • Suffix must be lowercase, otherwise it will be an error.
Source

pub fn parse_list_length(&mut self) -> Result<Length, Error>

Parses length from a list of lengths.

Source§

impl Stream<'_>

Source

pub fn parse_number(&mut self) -> Result<f64, Error>

Parses number from the stream.

This method will detect a number length and then will pass a substring to the f64::from_str method.

https://www.w3.org/TR/SVG2/types.html#InterfaceSVGNumber

§Errors

Returns only InvalidNumber.

Source

fn parse_number_impl(&mut self) -> Result<f64, Error>

Source

pub fn parse_list_number(&mut self) -> Result<f64, Error>

Parses number from a list of numbers.

Source§

impl<'a> Stream<'a>

Source

pub fn pos(&self) -> usize

Returns the current position in bytes.

Source

pub fn calc_char_pos(&self) -> usize

Calculates the current position in chars.

Source

pub fn calc_char_pos_at(&self, byte_pos: usize) -> usize

Calculates the current position in chars.

Source

pub fn jump_to_end(&mut self)

Sets current position equal to the end.

Used to indicate end of parsing on error.

Source

pub fn at_end(&self) -> bool

Checks if the stream is reached the end.

Any pos() value larger than original text length indicates stream end.

Accessing stream after reaching end via safe methods will produce an UnexpectedEndOfStream error.

Accessing stream after reaching end via *_unchecked methods will produce a Rust’s bound checking error.

Source

pub fn curr_byte(&self) -> Result<u8, Error>

Returns a byte from a current stream position.

§Errors
  • UnexpectedEndOfStream
Source

pub fn chars(&self) -> Chars<'a>

Source

pub fn curr_byte_unchecked(&self) -> u8

Returns a byte from a current stream position.

§Panics
  • if the current position is after the end of the data
Source

pub fn is_curr_byte_eq(&self, c: u8) -> bool

Checks that current byte is equal to provided.

Returns false if no bytes left.

Source

pub fn next_byte(&self) -> Result<u8, Error>

Returns a next byte from a current stream position.

§Errors
  • UnexpectedEndOfStream
Source

pub fn advance(&mut self, n: usize)

Advances by n bytes.

Source

pub fn skip_spaces(&mut self)

Skips whitespaces.

Accepted values: ' ' \n \r \t.

Source

pub fn starts_with(&self, text: &[u8]) -> bool

Checks that the stream starts with a selected text.

We are using &[u8] instead of &str for performance reasons.

Source

pub fn consume_byte(&mut self, c: u8) -> Result<(), Error>

Consumes current byte if it’s equal to the provided byte.

§Errors
  • InvalidChar
  • UnexpectedEndOfStream
Source

pub fn parse_ident(&mut self) -> Result<&'a str, Error>

Parses a single ident.

§Errors
  • InvalidIdent
Source

pub fn consume_ascii_ident(&mut self) -> &'a str

Consumes a single ident consisting of ASCII characters, if available.

Source

pub fn parse_quoted_string(&mut self) -> Result<&'a str, Error>

Parses a single quoted string

§Errors
  • UnexpectedEndOfStream
  • InvalidValue
Source

pub fn consume_string(&mut self, text: &[u8]) -> Result<(), Error>

Consumes selected string.

§Errors
  • InvalidChar
  • UnexpectedEndOfStream
Source

pub fn consume_bytes<F>(&mut self, f: F) -> &'a str
where F: Fn(&Stream<'_>, u8) -> bool,

Consumes bytes by the predicate and returns them.

The result can be empty.

Source

pub fn skip_bytes<F>(&mut self, f: F)
where F: Fn(&Stream<'_>, u8) -> bool,

Consumes bytes by the predicate.

Source

pub fn slice_back(&self, pos: usize) -> &'a str

Slices data from pos to the current position.

Source

pub fn slice_tail(&self) -> &'a str

Slices data from the current position to the end.

Source

pub fn parse_number_or_percent(&mut self) -> Result<f64, Error>

Parses number or percent from the stream.

Percent value will be normalized.

Source

pub fn parse_list_number_or_percent(&mut self) -> Result<f64, Error>

Parses number or percent from a list of numbers and/or percents.

Source

pub fn skip_digits(&mut self)

Skips digits.

Source

pub(crate) fn parse_list_separator(&mut self)

Trait Implementations§

Source§

impl<'a> Clone for Stream<'a>

Source§

fn clone(&self) -> Stream<'a>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<'a> Debug for Stream<'a>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a> From<&'a str> for Stream<'a>

Source§

fn from(text: &'a str) -> Self

Converts to this type from the input type.
Source§

impl<'a> PartialEq for Stream<'a>

Source§

fn eq(&self, other: &Stream<'a>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<'a> Copy for Stream<'a>

Source§

impl<'a> Eq for Stream<'a>

Source§

impl<'a> StructuralPartialEq for Stream<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for Stream<'a>

§

impl<'a> RefUnwindSafe for Stream<'a>

§

impl<'a> Send for Stream<'a>

§

impl<'a> Sync for Stream<'a>

§

impl<'a> Unpin for Stream<'a>

§

impl<'a> UnwindSafe for Stream<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.