Stream

Struct Stream 

Source
pub struct Stream<'a> { /* private fields */ }
Expand description

A streaming text parsing interface.

Implementations§

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 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 get_curr_byte(&self) -> Option<u8>

Returns a byte from a current stream position if there is one.

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.

§Examples
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 starts_with_space(&self) -> bool

Checks if the stream is starts with a space.

Uses skip_spaces() internally.

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
§Examples
Source

pub fn skip_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 consume_ident(&mut self) -> &'a str

Consumes bytes by the predicate and returns them.

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(&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/SVG11/types.html#DataTypeNumber

§Errors

Returns only InvalidNumber.

Source

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

Parses number from the list of numbers.

§Examples
Source

pub fn parse_integer(&mut self) -> Result<i32, Error>

Parses integer number from the stream.

Same as parse_number(), but only for integer. Does not refer to any SVG type.

Source

pub fn parse_list_integer(&mut self) -> Result<i32, Error>

Parses integer from the list of numbers.

Source

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

Parses length from the stream.

https://www.w3.org/TR/SVG11/types.html#DataTypeLength

§Examples
§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 the list of lengths.

Source

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

Parses angle from the stream.

https://www.w3.org/TR/SVG11/types.html#DataTypeAngle

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

pub fn skip_digits(&mut self)

Skips digits.

Source

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

Parses a IRI.

By the SVG spec, the ID must contain only Name characters, but since no one fallows this it will parse any characters.

Source

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

Parses a FuncIRI.

By the SVG spec, the ID must contain only Name characters, but since no one fallows this it will parse any characters.

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> 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<Fr, To> IntoColor<To> for Fr
where To: FromColor<Fr>,

Source§

fn into_color(self) -> To

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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V