2014-12-18 19:13:32 -08:00
|
|
|
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
|
|
|
//! Operations on tuples
|
|
|
|
//!
|
2015-01-05 08:57:43 -05:00
|
|
|
//! To access the _N_-th element of a tuple one can use `N` itself
|
|
|
|
//! as a field of the tuple.
|
2014-12-18 19:13:32 -08:00
|
|
|
//!
|
2015-01-05 08:57:43 -05:00
|
|
|
//! Indexing starts from zero, so `0` returns first value, `1`
|
2014-12-18 19:13:32 -08:00
|
|
|
//! returns second value, and so on. In general, a tuple with _S_
|
2015-01-05 16:22:03 -05:00
|
|
|
//! elements provides aforementioned fields from `0` to `S-1`.
|
2014-12-18 19:13:32 -08:00
|
|
|
//!
|
|
|
|
//! If every type inside a tuple implements one of the following
|
|
|
|
//! traits, then a tuple itself also implements it.
|
|
|
|
//!
|
|
|
|
//! * `Clone`
|
|
|
|
//! * `PartialEq`
|
|
|
|
//! * `Eq`
|
|
|
|
//! * `PartialOrd`
|
|
|
|
//! * `Ord`
|
|
|
|
//! * `Default`
|
|
|
|
//!
|
|
|
|
//! # Examples
|
2015-01-05 16:46:46 -05:00
|
|
|
//!
|
2015-01-05 16:22:03 -05:00
|
|
|
//! Accessing elements of a tuple at specified indices:
|
2015-01-05 16:46:46 -05:00
|
|
|
//!
|
2015-01-05 16:22:03 -05:00
|
|
|
//! ```
|
|
|
|
//! let x = ("colorless", "green", "ideas", "sleep", "furiously");
|
|
|
|
//! assert_eq!(x.3, "sleep");
|
2015-01-05 16:46:46 -05:00
|
|
|
//!
|
2015-01-25 22:05:03 +01:00
|
|
|
//! let v = (3, 3);
|
|
|
|
//! let u = (1, -5);
|
|
|
|
//! assert_eq!(v.0 * u.0 + v.1 * u.1, -12);
|
2015-01-05 16:22:03 -05:00
|
|
|
//! ```
|
2014-12-18 19:13:32 -08:00
|
|
|
//!
|
|
|
|
//! Using traits implemented for tuples:
|
|
|
|
//!
|
|
|
|
//! ```
|
|
|
|
//! use std::default::Default;
|
|
|
|
//!
|
2015-01-25 22:05:03 +01:00
|
|
|
//! let a = (1, 2);
|
|
|
|
//! let b = (3, 4);
|
2014-12-18 19:13:32 -08:00
|
|
|
//! assert!(a != b);
|
|
|
|
//!
|
|
|
|
//! let c = b.clone();
|
|
|
|
//! assert!(b == c);
|
|
|
|
//!
|
|
|
|
//! let d : (u32, f32) = Default::default();
|
|
|
|
//! assert_eq!(d, (0u32, 0.0f32));
|
|
|
|
//! ```
|
|
|
|
|
|
|
|
#![doc(primitive = "tuple")]
|
2015-01-23 21:48:20 -08:00
|
|
|
#![stable(feature = "rust1", since = "1.0.0")]
|