Struct dia_semver::Range

source ·
pub struct Range { /* private fields */ }
Expand description

Range

A range can be respresented in string, following these rules:

  • Start and end are placed inside one of [], [)…, separated by a comma.

  • [ and ] are inclusive.

  • ( and ) are exclusive.

  • White spaces can be included. They will be ignored by parser.

  • For unbounded ranges, start and/or end indexes must be inclusive.

  • For protection against flood attack, max length of the string is one of:

    • 255 bytes (on 8-bit machines)
    • 4096 bytes (on larger machines)

Examples

use core::ops::RangeBounds;
use core::str::FromStr;
use dia_semver::{Range, Semver};

// An empty range
let range = Range::from(Semver::new(0, 1, 2)..Semver::new(0, 0, 0));
assert!(range.is_empty());

// Only one single semver
let range = Range::from(Semver::new(0, 1, 2));
assert!(range.contains(&Semver::new(0, 1, 2)));
assert!(range.contains(&Semver::new(0, 1, 3)) == false);

// Inclusive range
let range = Range::from_str("[0.1.2, 0.2.0-beta]")?;
assert!(range.contains(&Semver::new(0, 1, 3)));
assert!(range.contains(&Semver::from_str("0.2.0-alpha")?));
assert!(range.contains(&Semver::new(0, 2, 0)) == false);

// Exclusive range
let range = Range::from(Semver::new(0, 1, 2)..Semver::new(0, 2, 0));
assert!(range.contains(&Semver::new(0, 2, 0)) == false);

// Unbounded ranges
assert!(Range::from(..).contains(&Semver::new(1, 2, 0)));
assert!(Range::from_str("[ , 1]")?.contains(&Semver::from(1_u8)));
assert!(Range::from_str("[ , 1)")?.contains(&Semver::from(1_u8)) == false);

Implementations§

Trait Implementations§

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Formats the value using the given formatter. Read more
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
The associated error which can be returned from parsing.
Parses a string s to return a value of this type. Read more
Feeds this value into the given Hasher. Read more
Feeds a slice of this type into the given Hasher. Read more
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason. Read more
Start index bound. Read more
End index bound. Read more
Returns true if item is contained in the range. Read more

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

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

The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
Converts the given value to a String. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.