W3cubDocs

/Rust

Enum std::collections::Bound

pub enum Bound<T> {
    Included(T),
    Excluded(T),
    Unbounded,
}

An endpoint of a range of keys.

Examples

Bounds are range endpoints:

#![feature(collections_range)]

use std::collections::range::RangeArgument;
use std::collections::Bound::*;

assert_eq!((..100).start(), Unbounded);
assert_eq!((1..12).start(), Included(&1));
assert_eq!((1..12).end(), Excluded(&12));

Using a tuple of Bounds as an argument to BTreeMap::range. Note that in most cases, it's better to use range syntax (1..5) instead.

use std::collections::BTreeMap;
use std::collections::Bound::{Excluded, Included, Unbounded};

let mut map = BTreeMap::new();
map.insert(3, "a");
map.insert(5, "b");
map.insert(8, "c");

for (key, value) in map.range((Excluded(3), Included(8))) {
    println!("{}: {}", key, value);
}

assert_eq!(Some((&3, &"a")), map.range((Unbounded, Included(5))).next());

Variants

An inclusive bound.

An exclusive bound.

An infinite endpoint. Indicates that there is no bound in this direction.

Trait Implementations

impl<T> PartialEq<Bound<T>> for Bound<T> where
    T: PartialEq<T>, 
[src]

[src]

This method tests for self and other values to be equal, and is used by ==. Read more

[src]

This method tests for !=.

impl<T> Debug for Bound<T> where
    T: Debug
[src]

[src]

Formats the value using the given formatter. Read more

impl<T> Hash for Bound<T> where
    T: Hash
[src]

[src]

Feeds this value into the given [Hasher]. Read more

1.3.0
[src]

Feeds a slice of this type into the given [Hasher]. Read more

impl<T> Clone for Bound<T> where
    T: Clone
[src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl<T> Eq for Bound<T> where
    T: Eq
[src]

impl<T> Copy for Bound<T> where
    T: Copy
[src]

© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/collections/enum.Bound.html