Primitive Type tuple []

A finite heterogeneous sequence, (T, U, ..).

Let's cover each of those in turn:

Tuples are finite. In other words, a tuple has a length. Here's a tuple of length 3:

fn main() { ("hello", 5, 'c'); }
("hello", 5, 'c');

'Length' is also sometimes called 'arity' here; each tuple of a different length is a different, distinct type.

Tuples are heterogeneous. This means that each element of the tuple can have a different type. In that tuple above, it has the type:

fn main() { (&'static str, i32, char) }
(&'static str, i32, char)

Tuples are a sequence. This means that they can be accessed by position; this is called 'tuple indexing', and it looks like this:

fn main() { let tuple = ("hello", 5, 'c'); assert_eq!(tuple.0, "hello"); assert_eq!(tuple.1, 5); assert_eq!(tuple.2, 'c'); }
let tuple = ("hello", 5, 'c');

assert_eq!(tuple.0, "hello");
assert_eq!(tuple.1, 5);
assert_eq!(tuple.2, 'c');

For more about tuples, see the book.

Trait implementations

If every type inside a tuple implements one of the following traits, then a tuple itself also implements it.

Due to a temporary restriction in Rust's type system, these traits are only implemented on tuples of arity 32 or less. In the future, this may change.

Examples

Basic usage:

fn main() { let tuple = ("hello", 5, 'c'); assert_eq!(tuple.0, "hello"); }
let tuple = ("hello", 5, 'c');

assert_eq!(tuple.0, "hello");

Tuples are often used as a return type when you want to return more than one value:

fn main() { fn calculate_point() -> (i32, i32) { // Don't do a calculation, that's not the point of the example (4, 5) } let point = calculate_point(); assert_eq!(point.0, 4); assert_eq!(point.1, 5); // Combining this with patterns can be nicer. let (x, y) = calculate_point(); assert_eq!(x, 4); assert_eq!(y, 5); }
fn calculate_point() -> (i32, i32) {
    // Don't do a calculation, that's not the point of the example
    (4, 5)
}

let point = calculate_point();

assert_eq!(point.0, 4);
assert_eq!(point.1, 5);

// Combining this with patterns can be nicer.

let (x, y) = calculate_point();

assert_eq!(x, 4);
assert_eq!(y, 5);

Trait Implementations

impl<A, B, C, D, E, F, G, H, I, J, K, L> Default for (A, B, C, D, E, F, G, H, I, J, K, L) where B: Default, A: Default, D: Default, F: Default, K: Default, G: Default, I: Default, J: Default, E: Default, C: Default, H: Default, L: Default1.0.0

fn default() -> (A, B, C, D, E, F, G, H, I, J, K, L)

impl<A, B, C, D, E, F, G, H, I, J, K, L> Ord for (A, B, C, D, E, F, G, H, I, J, K, L) where E: Ord, I: Ord, J: Ord, G: Ord, A: Ord, L: Ord, F: Ord, K: Ord, C: Ord, H: Ord, D: Ord, B: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> Ordering

impl<A, B, C, D, E, F, G, H, I, J, K, L> PartialOrd<(A, B, C, D, E, F, G, H, I, J, K, L)> for (A, B, C, D, E, F, G, H, I, J, K, L) where F: PartialEq<F> + PartialOrd<F>, C: PartialEq<C> + PartialOrd<C>, L: PartialEq<L> + PartialOrd<L>, H: PartialEq<H> + PartialOrd<H>, J: PartialEq<J> + PartialOrd<J>, A: PartialEq<A> + PartialOrd<A>, I: PartialEq<I> + PartialOrd<I>, B: PartialEq<B> + PartialOrd<B>, E: PartialEq<E> + PartialOrd<E>, D: PartialEq<D> + PartialOrd<D>, G: PartialEq<G> + PartialOrd<G>, K: PartialEq<K> + PartialOrd<K>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> bool

fn le(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> bool

fn ge(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> bool

fn gt(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> bool

impl<A, B, C, D, E, F, G, H, I, J, K, L> Eq for (A, B, C, D, E, F, G, H, I, J, K, L) where H: Eq, D: Eq, E: Eq, L: Eq, I: Eq, G: Eq, B: Eq, C: Eq, A: Eq, K: Eq, F: Eq, J: Eq1.0.0

impl<A, B, C, D, E, F, G, H, I, J, K, L> PartialEq<(A, B, C, D, E, F, G, H, I, J, K, L)> for (A, B, C, D, E, F, G, H, I, J, K, L) where D: PartialEq<D>, F: PartialEq<F>, K: PartialEq<K>, A: PartialEq<A>, G: PartialEq<G>, I: PartialEq<I>, C: PartialEq<C>, L: PartialEq<L>, B: PartialEq<B>, H: PartialEq<H>, J: PartialEq<J>, E: PartialEq<E>1.0.0

fn eq(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> bool

fn ne(&self, other: &(A, B, C, D, E, F, G, H, I, J, K, L)) -> bool

impl<A, B, C, D, E, F, G, H, I, J, K, L> Clone for (A, B, C, D, E, F, G, H, I, J, K, L) where E: Clone, I: Clone, J: Clone, G: Clone, K: Clone, A: Clone, L: Clone, D: Clone, C: Clone, F: Clone, H: Clone, B: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E, F, G, H, I, J, K, L)

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

impl<A, B, C, D, E, F, G, H, I, J, K> Default for (A, B, C, D, E, F, G, H, I, J, K) where C: Default, A: Default, I: Default, D: Default, K: Default, E: Default, G: Default, F: Default, J: Default, H: Default, B: Default1.0.0

fn default() -> (A, B, C, D, E, F, G, H, I, J, K)

impl<A, B, C, D, E, F, G, H, I, J, K> Ord for (A, B, C, D, E, F, G, H, I, J, K) where I: Ord, F: Ord, B: Ord, A: Ord, E: Ord, J: Ord, C: Ord, K: Ord, G: Ord, H: Ord, D: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> Ordering

impl<A, B, C, D, E, F, G, H, I, J, K> PartialOrd<(A, B, C, D, E, F, G, H, I, J, K)> for (A, B, C, D, E, F, G, H, I, J, K) where B: PartialEq<B> + PartialOrd<B>, A: PartialEq<A> + PartialOrd<A>, E: PartialEq<E> + PartialOrd<E>, F: PartialEq<F> + PartialOrd<F>, J: PartialEq<J> + PartialOrd<J>, H: PartialEq<H> + PartialOrd<H>, C: PartialEq<C> + PartialOrd<C>, I: PartialEq<I> + PartialOrd<I>, G: PartialEq<G> + PartialOrd<G>, K: PartialEq<K> + PartialOrd<K>, D: PartialEq<D> + PartialOrd<D>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> bool

fn le(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> bool

fn ge(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> bool

fn gt(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> bool

impl<A, B, C, D, E, F, G, H, I, J, K> Eq for (A, B, C, D, E, F, G, H, I, J, K) where I: Eq, J: Eq, D: Eq, G: Eq, K: Eq, H: Eq, B: Eq, C: Eq, E: Eq, F: Eq, A: Eq1.0.0

impl<A, B, C, D, E, F, G, H, I, J, K> PartialEq<(A, B, C, D, E, F, G, H, I, J, K)> for (A, B, C, D, E, F, G, H, I, J, K) where H: PartialEq<H>, E: PartialEq<E>, C: PartialEq<C>, A: PartialEq<A>, J: PartialEq<J>, D: PartialEq<D>, K: PartialEq<K>, I: PartialEq<I>, B: PartialEq<B>, F: PartialEq<F>, G: PartialEq<G>1.0.0

fn eq(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> bool

fn ne(&self, other: &(A, B, C, D, E, F, G, H, I, J, K)) -> bool

impl<A, B, C, D, E, F, G, H, I, J, K> Clone for (A, B, C, D, E, F, G, H, I, J, K) where B: Clone, A: Clone, H: Clone, C: Clone, G: Clone, K: Clone, I: Clone, J: Clone, E: Clone, F: Clone, D: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E, F, G, H, I, J, K)

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

impl<A, B, C, D, E, F, G, H, I, J> Default for (A, B, C, D, E, F, G, H, I, J) where J: Default, B: Default, F: Default, E: Default, C: Default, H: Default, I: Default, G: Default, D: Default, A: Default1.0.0

fn default() -> (A, B, C, D, E, F, G, H, I, J)

impl<A, B, C, D, E, F, G, H, I, J> Ord for (A, B, C, D, E, F, G, H, I, J) where G: Ord, A: Ord, J: Ord, C: Ord, H: Ord, D: Ord, F: Ord, B: Ord, E: Ord, I: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> Ordering

impl<A, B, C, D, E, F, G, H, I, J> PartialOrd<(A, B, C, D, E, F, G, H, I, J)> for (A, B, C, D, E, F, G, H, I, J) where F: PartialEq<F> + PartialOrd<F>, A: PartialEq<A> + PartialOrd<A>, C: PartialEq<C> + PartialOrd<C>, H: PartialEq<H> + PartialOrd<H>, I: PartialEq<I> + PartialOrd<I>, J: PartialEq<J> + PartialOrd<J>, B: PartialEq<B> + PartialOrd<B>, E: PartialEq<E> + PartialOrd<E>, D: PartialEq<D> + PartialOrd<D>, G: PartialEq<G> + PartialOrd<G>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> bool

fn le(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> bool

fn ge(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> bool

fn gt(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> bool

impl<A, B, C, D, E, F, G, H, I, J> Eq for (A, B, C, D, E, F, G, H, I, J) where I: Eq, H: Eq, E: Eq, D: Eq, G: Eq, F: Eq, A: Eq, J: Eq, B: Eq, C: Eq1.0.0

impl<A, B, C, D, E, F, G, H, I, J> PartialEq<(A, B, C, D, E, F, G, H, I, J)> for (A, B, C, D, E, F, G, H, I, J) where A: PartialEq<A>, C: PartialEq<C>, J: PartialEq<J>, E: PartialEq<E>, F: PartialEq<F>, I: PartialEq<I>, B: PartialEq<B>, G: PartialEq<G>, D: PartialEq<D>, H: PartialEq<H>1.0.0

fn eq(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> bool

fn ne(&self, other: &(A, B, C, D, E, F, G, H, I, J)) -> bool

impl<A, B, C, D, E, F, G, H, I, J> Clone for (A, B, C, D, E, F, G, H, I, J) where I: Clone, G: Clone, B: Clone, F: Clone, E: Clone, H: Clone, D: Clone, A: Clone, J: Clone, C: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E, F, G, H, I, J)

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

impl<A, B, C, D, E, F, G, H, I> Default for (A, B, C, D, E, F, G, H, I) where B: Default, H: Default, F: Default, A: Default, E: Default, G: Default, D: Default, C: Default, I: Default1.0.0

fn default() -> (A, B, C, D, E, F, G, H, I)

impl<A, B, C, D, E, F, G, H, I> Ord for (A, B, C, D, E, F, G, H, I) where H: Ord, G: Ord, E: Ord, F: Ord, B: Ord, D: Ord, C: Ord, A: Ord, I: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E, F, G, H, I)) -> Ordering

impl<A, B, C, D, E, F, G, H, I> PartialOrd<(A, B, C, D, E, F, G, H, I)> for (A, B, C, D, E, F, G, H, I) where B: PartialEq<B> + PartialOrd<B>, G: PartialEq<G> + PartialOrd<G>, D: PartialEq<D> + PartialOrd<D>, F: PartialEq<F> + PartialOrd<F>, C: PartialEq<C> + PartialOrd<C>, H: PartialEq<H> + PartialOrd<H>, A: PartialEq<A> + PartialOrd<A>, E: PartialEq<E> + PartialOrd<E>, I: PartialEq<I> + PartialOrd<I>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E, F, G, H, I)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E, F, G, H, I)) -> bool

fn le(&self, other: &(A, B, C, D, E, F, G, H, I)) -> bool

fn ge(&self, other: &(A, B, C, D, E, F, G, H, I)) -> bool

fn gt(&self, other: &(A, B, C, D, E, F, G, H, I)) -> bool

impl<A, B, C, D, E, F, G, H, I> Eq for (A, B, C, D, E, F, G, H, I) where G: Eq, C: Eq, E: Eq, B: Eq, H: Eq, F: Eq, D: Eq, I: Eq, A: Eq1.0.0

impl<A, B, C, D, E, F, G, H, I> PartialEq<(A, B, C, D, E, F, G, H, I)> for (A, B, C, D, E, F, G, H, I) where H: PartialEq<H>, B: PartialEq<B>, G: PartialEq<G>, I: PartialEq<I>, D: PartialEq<D>, C: PartialEq<C>, E: PartialEq<E>, F: PartialEq<F>, A: PartialEq<A>1.0.0

fn eq(&self, other: &(A, B, C, D, E, F, G, H, I)) -> bool

fn ne(&self, other: &(A, B, C, D, E, F, G, H, I)) -> bool

impl<A, B, C, D, E, F, G, H, I> Clone for (A, B, C, D, E, F, G, H, I) where E: Clone, G: Clone, I: Clone, A: Clone, B: Clone, F: Clone, H: Clone, D: Clone, C: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E, F, G, H, I)

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

impl<A, B, C, D, E, F, G, H> Default for (A, B, C, D, E, F, G, H) where E: Default, F: Default, A: Default, H: Default, D: Default, G: Default, B: Default, C: Default1.0.0

fn default() -> (A, B, C, D, E, F, G, H)

impl<A, B, C, D, E, F, G, H> Ord for (A, B, C, D, E, F, G, H) where C: Ord, B: Ord, D: Ord, E: Ord, H: Ord, G: Ord, F: Ord, A: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E, F, G, H)) -> Ordering

impl<A, B, C, D, E, F, G, H> PartialOrd<(A, B, C, D, E, F, G, H)> for (A, B, C, D, E, F, G, H) where F: PartialEq<F> + PartialOrd<F>, B: PartialEq<B> + PartialOrd<B>, C: PartialEq<C> + PartialOrd<C>, A: PartialEq<A> + PartialOrd<A>, E: PartialEq<E> + PartialOrd<E>, H: PartialEq<H> + PartialOrd<H>, G: PartialEq<G> + PartialOrd<G>, D: PartialEq<D> + PartialOrd<D>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E, F, G, H)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E, F, G, H)) -> bool

fn le(&self, other: &(A, B, C, D, E, F, G, H)) -> bool

fn ge(&self, other: &(A, B, C, D, E, F, G, H)) -> bool

fn gt(&self, other: &(A, B, C, D, E, F, G, H)) -> bool

impl<A, B, C, D, E, F, G, H> Eq for (A, B, C, D, E, F, G, H) where B: Eq, H: Eq, E: Eq, G: Eq, D: Eq, F: Eq, C: Eq, A: Eq1.0.0

impl<A, B, C, D, E, F, G, H> PartialEq<(A, B, C, D, E, F, G, H)> for (A, B, C, D, E, F, G, H) where C: PartialEq<C>, B: PartialEq<B>, E: PartialEq<E>, G: PartialEq<G>, F: PartialEq<F>, A: PartialEq<A>, H: PartialEq<H>, D: PartialEq<D>1.0.0

fn eq(&self, other: &(A, B, C, D, E, F, G, H)) -> bool

fn ne(&self, other: &(A, B, C, D, E, F, G, H)) -> bool

impl<A, B, C, D, E, F, G, H> Clone for (A, B, C, D, E, F, G, H) where E: Clone, G: Clone, A: Clone, B: Clone, D: Clone, C: Clone, H: Clone, F: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E, F, G, H)

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

impl<A, B, C, D, E, F, G> Default for (A, B, C, D, E, F, G) where C: Default, E: Default, F: Default, D: Default, G: Default, A: Default, B: Default1.0.0

fn default() -> (A, B, C, D, E, F, G)

impl<A, B, C, D, E, F, G> Ord for (A, B, C, D, E, F, G) where G: Ord, A: Ord, B: Ord, C: Ord, F: Ord, D: Ord, E: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E, F, G)) -> Ordering

impl<A, B, C, D, E, F, G> PartialOrd<(A, B, C, D, E, F, G)> for (A, B, C, D, E, F, G) where G: PartialEq<G> + PartialOrd<G>, E: PartialEq<E> + PartialOrd<E>, F: PartialEq<F> + PartialOrd<F>, C: PartialEq<C> + PartialOrd<C>, B: PartialEq<B> + PartialOrd<B>, A: PartialEq<A> + PartialOrd<A>, D: PartialEq<D> + PartialOrd<D>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E, F, G)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E, F, G)) -> bool

fn le(&self, other: &(A, B, C, D, E, F, G)) -> bool

fn ge(&self, other: &(A, B, C, D, E, F, G)) -> bool

fn gt(&self, other: &(A, B, C, D, E, F, G)) -> bool

impl<A, B, C, D, E, F, G> Eq for (A, B, C, D, E, F, G) where F: Eq, A: Eq, E: Eq, G: Eq, B: Eq, D: Eq, C: Eq1.0.0

impl<A, B, C, D, E, F, G> PartialEq<(A, B, C, D, E, F, G)> for (A, B, C, D, E, F, G) where A: PartialEq<A>, B: PartialEq<B>, E: PartialEq<E>, D: PartialEq<D>, C: PartialEq<C>, G: PartialEq<G>, F: PartialEq<F>1.0.0

fn eq(&self, other: &(A, B, C, D, E, F, G)) -> bool

fn ne(&self, other: &(A, B, C, D, E, F, G)) -> bool

impl<A, B, C, D, E, F, G> Clone for (A, B, C, D, E, F, G) where D: Clone, A: Clone, B: Clone, E: Clone, G: Clone, C: Clone, F: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E, F, G)

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

impl<A, B, C, D, E, F> Default for (A, B, C, D, E, F) where E: Default, D: Default, B: Default, F: Default, A: Default, C: Default1.0.0

fn default() -> (A, B, C, D, E, F)

impl<A, B, C, D, E, F> Ord for (A, B, C, D, E, F) where F: Ord, B: Ord, D: Ord, A: Ord, E: Ord, C: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E, F)) -> Ordering

impl<A, B, C, D, E, F> PartialOrd<(A, B, C, D, E, F)> for (A, B, C, D, E, F) where A: PartialEq<A> + PartialOrd<A>, F: PartialEq<F> + PartialOrd<F>, B: PartialEq<B> + PartialOrd<B>, C: PartialEq<C> + PartialOrd<C>, E: PartialEq<E> + PartialOrd<E>, D: PartialEq<D> + PartialOrd<D>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E, F)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E, F)) -> bool

fn le(&self, other: &(A, B, C, D, E, F)) -> bool

fn ge(&self, other: &(A, B, C, D, E, F)) -> bool

fn gt(&self, other: &(A, B, C, D, E, F)) -> bool

impl<A, B, C, D, E, F> Eq for (A, B, C, D, E, F) where E: Eq, A: Eq, F: Eq, C: Eq, B: Eq, D: Eq1.0.0

impl<A, B, C, D, E, F> PartialEq<(A, B, C, D, E, F)> for (A, B, C, D, E, F) where C: PartialEq<C>, E: PartialEq<E>, A: PartialEq<A>, D: PartialEq<D>, F: PartialEq<F>, B: PartialEq<B>1.0.0

fn eq(&self, other: &(A, B, C, D, E, F)) -> bool

fn ne(&self, other: &(A, B, C, D, E, F)) -> bool

impl<A, B, C, D, E, F> Clone for (A, B, C, D, E, F) where A: Clone, F: Clone, B: Clone, D: Clone, C: Clone, E: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E, F)

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

impl<A, B, C, D, E> Default for (A, B, C, D, E) where A: Default, C: Default, B: Default, E: Default, D: Default1.0.0

fn default() -> (A, B, C, D, E)

impl<A, B, C, D, E> Ord for (A, B, C, D, E) where D: Ord, B: Ord, C: Ord, E: Ord, A: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D, E)) -> Ordering

impl<A, B, C, D, E> PartialOrd<(A, B, C, D, E)> for (A, B, C, D, E) where A: PartialEq<A> + PartialOrd<A>, C: PartialEq<C> + PartialOrd<C>, B: PartialEq<B> + PartialOrd<B>, E: PartialEq<E> + PartialOrd<E>, D: PartialEq<D> + PartialOrd<D>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D, E)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D, E)) -> bool

fn le(&self, other: &(A, B, C, D, E)) -> bool

fn ge(&self, other: &(A, B, C, D, E)) -> bool

fn gt(&self, other: &(A, B, C, D, E)) -> bool

impl<A, B, C, D, E> Eq for (A, B, C, D, E) where C: Eq, D: Eq, E: Eq, A: Eq, B: Eq1.0.0

impl<A, B, C, D, E> PartialEq<(A, B, C, D, E)> for (A, B, C, D, E) where C: PartialEq<C>, D: PartialEq<D>, B: PartialEq<B>, A: PartialEq<A>, E: PartialEq<E>1.0.0

fn eq(&self, other: &(A, B, C, D, E)) -> bool

fn ne(&self, other: &(A, B, C, D, E)) -> bool

impl<A, B, C, D, E> Clone for (A, B, C, D, E) where A: Clone, D: Clone, E: Clone, C: Clone, B: Clone1.0.0

fn clone(&self) -> (A, B, C, D, E)

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

impl<A, B, C, D> Default for (A, B, C, D) where B: Default, C: Default, D: Default, A: Default1.0.0

fn default() -> (A, B, C, D)

impl<A, B, C, D> Ord for (A, B, C, D) where B: Ord, D: Ord, C: Ord, A: Ord1.0.0

fn cmp(&self, other: &(A, B, C, D)) -> Ordering

impl<A, B, C, D> PartialOrd<(A, B, C, D)> for (A, B, C, D) where B: PartialEq<B> + PartialOrd<B>, C: PartialEq<C> + PartialOrd<C>, A: PartialEq<A> + PartialOrd<A>, D: PartialEq<D> + PartialOrd<D>1.0.0

fn partial_cmp(&self, other: &(A, B, C, D)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C, D)) -> bool

fn le(&self, other: &(A, B, C, D)) -> bool

fn ge(&self, other: &(A, B, C, D)) -> bool

fn gt(&self, other: &(A, B, C, D)) -> bool

impl<A, B, C, D> Eq for (A, B, C, D) where D: Eq, B: Eq, C: Eq, A: Eq1.0.0

impl<A, B, C, D> PartialEq<(A, B, C, D)> for (A, B, C, D) where C: PartialEq<C>, B: PartialEq<B>, A: PartialEq<A>, D: PartialEq<D>1.0.0

fn eq(&self, other: &(A, B, C, D)) -> bool

fn ne(&self, other: &(A, B, C, D)) -> bool

impl<A, B, C, D> Clone for (A, B, C, D) where D: Clone, A: Clone, B: Clone, C: Clone1.0.0

fn clone(&self) -> (A, B, C, D)

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

impl<A, B, C> Default for (A, B, C) where B: Default, C: Default, A: Default1.0.0

fn default() -> (A, B, C)

impl<A, B, C> Ord for (A, B, C) where A: Ord, B: Ord, C: Ord1.0.0

fn cmp(&self, other: &(A, B, C)) -> Ordering

impl<A, B, C> PartialOrd<(A, B, C)> for (A, B, C) where A: PartialEq<A> + PartialOrd<A>, C: PartialEq<C> + PartialOrd<C>, B: PartialEq<B> + PartialOrd<B>1.0.0

fn partial_cmp(&self, other: &(A, B, C)) -> Option<Ordering>

fn lt(&self, other: &(A, B, C)) -> bool

fn le(&self, other: &(A, B, C)) -> bool

fn ge(&self, other: &(A, B, C)) -> bool

fn gt(&self, other: &(A, B, C)) -> bool

impl<A, B, C> Eq for (A, B, C) where C: Eq, A: Eq, B: Eq1.0.0

impl<A, B, C> PartialEq<(A, B, C)> for (A, B, C) where C: PartialEq<C>, A: PartialEq<A>, B: PartialEq<B>1.0.0

fn eq(&self, other: &(A, B, C)) -> bool

fn ne(&self, other: &(A, B, C)) -> bool

impl<A, B, C> Clone for (A, B, C) where B: Clone, A: Clone, C: Clone1.0.0

fn clone(&self) -> (A, B, C)

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

impl<A, B> Default for (A, B) where A: Default, B: Default1.0.0

fn default() -> (A, B)

impl<A, B> Ord for (A, B) where A: Ord, B: Ord1.0.0

fn cmp(&self, other: &(A, B)) -> Ordering

impl<A, B> PartialOrd<(A, B)> for (A, B) where A: PartialEq<A> + PartialOrd<A>, B: PartialEq<B> + PartialOrd<B>1.0.0

fn partial_cmp(&self, other: &(A, B)) -> Option<Ordering>

fn lt(&self, other: &(A, B)) -> bool

fn le(&self, other: &(A, B)) -> bool

fn ge(&self, other: &(A, B)) -> bool

fn gt(&self, other: &(A, B)) -> bool

impl<A, B> Eq for (A, B) where A: Eq, B: Eq1.0.0

impl<A, B> PartialEq<(A, B)> for (A, B) where B: PartialEq<B>, A: PartialEq<A>1.0.0

fn eq(&self, other: &(A, B)) -> bool

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

impl<A, B> Clone for (A, B) where B: Clone, A: Clone1.0.0

fn clone(&self) -> (A, B)

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

impl<A> Default for (A,) where A: Default1.0.0

fn default() -> (A,)

impl<A> Ord for (A,) where A: Ord1.0.0

fn cmp(&self, other: &(A,)) -> Ordering

impl<A> PartialOrd<(A,)> for (A,) where A: PartialEq<A> + PartialOrd<A>1.0.0

fn partial_cmp(&self, other: &(A,)) -> Option<Ordering>

fn lt(&self, other: &(A,)) -> bool

fn le(&self, other: &(A,)) -> bool

fn ge(&self, other: &(A,)) -> bool

fn gt(&self, other: &(A,)) -> bool

impl<A> Eq for (A,) where A: Eq1.0.0

impl<A> PartialEq<(A,)> for (A,) where A: PartialEq<A>1.0.0

fn eq(&self, other: &(A,)) -> bool

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

impl<A> Clone for (A,) where A: Clone1.0.0

fn clone(&self) -> (A,)

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

impl Debug for ()1.0.0

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

impl<T11> Debug for (T11,) where T11: Debug1.0.0

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

impl<T10, T11> Debug for (T10, T11) where T11: Debug, T10: Debug1.0.0

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

impl<T9, T10, T11> Debug for (T9, T10, T11) where T10: Debug, T11: Debug, T9: Debug1.0.0

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

impl<T8, T9, T10, T11> Debug for (T8, T9, T10, T11) where T10: Debug, T11: Debug, T9: Debug, T8: Debug1.0.0

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

impl<T7, T8, T9, T10, T11> Debug for (T7, T8, T9, T10, T11) where T11: Debug, T9: Debug, T7: Debug, T8: Debug, T10: Debug1.0.0

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

impl<T6, T7, T8, T9, T10, T11> Debug for (T6, T7, T8, T9, T10, T11) where T6: Debug, T11: Debug, T8: Debug, T10: Debug, T7: Debug, T9: Debug1.0.0

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

impl<T5, T6, T7, T8, T9, T10, T11> Debug for (T5, T6, T7, T8, T9, T10, T11) where T9: Debug, T7: Debug, T11: Debug, T10: Debug, T8: Debug, T5: Debug, T6: Debug1.0.0

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

impl<T4, T5, T6, T7, T8, T9, T10, T11> Debug for (T4, T5, T6, T7, T8, T9, T10, T11) where T7: Debug, T4: Debug, T6: Debug, T8: Debug, T9: Debug, T11: Debug, T5: Debug, T10: Debug1.0.0

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

impl<T3, T4, T5, T6, T7, T8, T9, T10, T11> Debug for (T3, T4, T5, T6, T7, T8, T9, T10, T11) where T7: Debug, T3: Debug, T11: Debug, T6: Debug, T10: Debug, T5: Debug, T4: Debug, T8: Debug, T9: Debug1.0.0

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

impl<T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> Debug for (T2, T3, T4, T5, T6, T7, T8, T9, T10, T11) where T11: Debug, T2: Debug, T10: Debug, T7: Debug, T4: Debug, T5: Debug, T3: Debug, T6: Debug, T8: Debug, T9: Debug1.0.0

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

impl<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> Debug for (T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11) where T4: Debug, T6: Debug, T11: Debug, T1: Debug, T10: Debug, T3: Debug, T2: Debug, T7: Debug, T5: Debug, T9: Debug, T8: Debug1.0.0

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

impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> Debug for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11) where T10: Debug, T4: Debug, T1: Debug, T7: Debug, T8: Debug, T2: Debug, T9: Debug, T5: Debug, T0: Debug, T3: Debug, T6: Debug, T11: Debug1.0.0

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

impl<A, B, C, D, E, F, G, H, I, J, K, L> Hash for (A, B, C, D, E, F, G, H, I, J, K, L) where C: Hash, L: Hash, F: Hash, G: Hash, J: Hash, D: Hash, H: Hash, K: Hash, A: Hash, I: Hash, E: Hash, B: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D, E, F, G, H, I, J, K> Hash for (A, B, C, D, E, F, G, H, I, J, K) where A: Hash, C: Hash, H: Hash, D: Hash, J: Hash, K: Hash, G: Hash, I: Hash, F: Hash, E: Hash, B: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D, E, F, G, H, I, J> Hash for (A, B, C, D, E, F, G, H, I, J) where J: Hash, A: Hash, E: Hash, F: Hash, C: Hash, H: Hash, G: Hash, B: Hash, I: Hash, D: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D, E, F, G, H, I> Hash for (A, B, C, D, E, F, G, H, I) where A: Hash, D: Hash, I: Hash, G: Hash, H: Hash, C: Hash, F: Hash, E: Hash, B: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D, E, F, G, H> Hash for (A, B, C, D, E, F, G, H) where A: Hash, C: Hash, B: Hash, H: Hash, D: Hash, G: Hash, E: Hash, F: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D, E, F, G> Hash for (A, B, C, D, E, F, G) where F: Hash, E: Hash, B: Hash, G: Hash, A: Hash, C: Hash, D: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D, E, F> Hash for (A, B, C, D, E, F) where F: Hash, A: Hash, C: Hash, B: Hash, E: Hash, D: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D, E> Hash for (A, B, C, D, E) where A: Hash, B: Hash, E: Hash, C: Hash, D: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C, D> Hash for (A, B, C, D) where B: Hash, A: Hash, D: Hash, C: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B, C> Hash for (A, B, C) where C: Hash, B: Hash, A: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A, B> Hash for (A, B) where A: Hash, B: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl<A> Hash for (A,) where A: Hash1.0.0

fn hash<S>(&self, state: &mut S) where S: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl Hash for ()1.0.0

fn hash<H>(&self, _state: &mut H) where H: Hasher

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0

impl Default for ()1.0.0

fn default()

impl Clone for ()1.0.0

fn clone(&self)

Returns a deep copy of the value.

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

impl Ord for ()1.0.0

fn cmp(&self, _other: &()) -> Ordering

impl PartialOrd<()> for ()1.0.0

fn partial_cmp(&self, &()) -> Option<Ordering>

fn lt(&self, other: &Rhs) -> bool1.0.0

fn le(&self, other: &Rhs) -> bool1.0.0

fn gt(&self, other: &Rhs) -> bool1.0.0

fn ge(&self, other: &Rhs) -> bool1.0.0

impl Eq for ()1.0.0

impl PartialEq<()> for ()1.0.0

fn eq(&self, _other: &()) -> bool

fn ne(&self, _other: &()) -> bool

impl ToSocketAddrs for (IpAddr, u16)1.0.0

type Iter = IntoIter<SocketAddr>

fn to_socket_addrs(&self) -> Result<IntoIter<SocketAddr>>

impl ToSocketAddrs for (Ipv4Addr, u16)1.0.0

type Iter = IntoIter<SocketAddr>

fn to_socket_addrs(&self) -> Result<IntoIter<SocketAddr>>

impl ToSocketAddrs for (Ipv6Addr, u16)1.0.0

type Iter = IntoIter<SocketAddr>

fn to_socket_addrs(&self) -> Result<IntoIter<SocketAddr>>

impl<'a> ToSocketAddrs for (&'a str, u16)1.0.0

type Iter = IntoIter<SocketAddr>

fn to_socket_addrs(&self) -> Result<IntoIter<SocketAddr>>