2013-03-16 14:49:12 -05:00
|
|
|
// Copyright 2012-2013 The Rust Project Developers. See the COPYRIGHT
|
2012-12-03 18:48:01 -06:00
|
|
|
// 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.
|
|
|
|
|
2012-07-04 16:53:12 -05:00
|
|
|
/*!
|
2012-10-04 17:14:28 -05:00
|
|
|
|
|
|
|
Operations on the ubiquitous `Option` type.
|
|
|
|
|
|
|
|
Type `Option` represents an optional value.
|
|
|
|
|
|
|
|
Every `Option<T>` value can either be `Some(T)` or `None`. Where in other
|
|
|
|
languages you might use a nullable type, in Rust you would use an option
|
|
|
|
type.
|
|
|
|
|
|
|
|
Options are most commonly used with pattern matching to query the presence
|
|
|
|
of a value and take action, always accounting for the `None` case.
|
|
|
|
|
|
|
|
# Example
|
|
|
|
|
|
|
|
~~~
|
|
|
|
let msg = Some(~"howdy");
|
|
|
|
|
|
|
|
// Take a reference to the contained string
|
|
|
|
match msg {
|
|
|
|
Some(ref m) => io::println(m),
|
|
|
|
None => ()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove the contained string, destroying the Option
|
2013-02-15 02:51:28 -06:00
|
|
|
let unwrapped_msg = match msg {
|
|
|
|
Some(m) => m,
|
2012-10-04 17:14:28 -05:00
|
|
|
None => ~"default message"
|
|
|
|
};
|
|
|
|
~~~
|
|
|
|
|
|
|
|
*/
|
2012-07-04 16:53:12 -05:00
|
|
|
|
2013-02-04 19:12:31 -06:00
|
|
|
use cmp::{Eq,Ord};
|
2013-03-11 21:46:16 -05:00
|
|
|
use ops::Add;
|
2013-01-08 21:37:25 -06:00
|
|
|
use kinds::Copy;
|
2012-12-23 16:41:37 -06:00
|
|
|
use util;
|
2013-01-03 17:36:23 -06:00
|
|
|
use num::Zero;
|
2013-06-10 16:45:59 -05:00
|
|
|
use iterator::Iterator;
|
2013-05-12 19:34:15 -05:00
|
|
|
use str::StrSlice;
|
2013-05-15 01:23:12 -05:00
|
|
|
use clone::DeepClone;
|
2012-08-27 19:24:15 -05:00
|
|
|
|
2013-02-28 10:57:33 -06:00
|
|
|
#[cfg(test)] use str;
|
2013-06-10 16:50:12 -05:00
|
|
|
#[cfg(test)] use iterator::IteratorUtil;
|
2013-02-28 10:57:33 -06:00
|
|
|
|
2012-07-04 16:53:12 -05:00
|
|
|
/// The option type
|
2013-05-24 00:16:15 -05:00
|
|
|
#[deriving(Clone, DeepClone, Eq)]
|
2012-10-01 16:08:34 -05:00
|
|
|
pub enum Option<T> {
|
2012-08-20 14:23:37 -05:00
|
|
|
None,
|
|
|
|
Some(T),
|
2011-12-13 18:25:51 -06:00
|
|
|
}
|
|
|
|
|
2013-02-26 19:12:00 -06:00
|
|
|
impl<T:Ord> Ord for Option<T> {
|
2013-03-21 23:20:48 -05:00
|
|
|
fn lt(&self, other: &Option<T>) -> bool {
|
2013-02-04 19:12:31 -06:00
|
|
|
match (self, other) {
|
|
|
|
(&None, &None) => false,
|
|
|
|
(&None, &Some(_)) => true,
|
|
|
|
(&Some(_), &None) => false,
|
|
|
|
(&Some(ref a), &Some(ref b)) => *a < *b
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-21 23:20:48 -05:00
|
|
|
fn le(&self, other: &Option<T>) -> bool {
|
2013-02-04 19:12:31 -06:00
|
|
|
match (self, other) {
|
|
|
|
(&None, &None) => true,
|
|
|
|
(&None, &Some(_)) => true,
|
|
|
|
(&Some(_), &None) => false,
|
|
|
|
(&Some(ref a), &Some(ref b)) => *a <= *b
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-21 23:20:48 -05:00
|
|
|
fn ge(&self, other: &Option<T>) -> bool {
|
2013-05-18 01:52:11 -05:00
|
|
|
!(self < other)
|
2013-02-04 19:12:31 -06:00
|
|
|
}
|
|
|
|
|
2013-03-21 23:20:48 -05:00
|
|
|
fn gt(&self, other: &Option<T>) -> bool {
|
2013-05-18 01:52:11 -05:00
|
|
|
!(self <= other)
|
2013-02-04 19:12:31 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-11 21:46:16 -05:00
|
|
|
impl<T: Copy + Add<T,T>> Add<Option<T>, Option<T>> for Option<T> {
|
|
|
|
#[inline(always)]
|
2013-03-21 23:20:48 -05:00
|
|
|
fn add(&self, other: &Option<T>) -> Option<T> {
|
2013-03-11 21:46:16 -05:00
|
|
|
match (*self, *other) {
|
|
|
|
(None, None) => None,
|
|
|
|
(_, None) => *self,
|
|
|
|
(None, _) => *other,
|
|
|
|
(Some(ref lhs), Some(ref rhs)) => Some(*lhs + *rhs)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-31 17:17:22 -05:00
|
|
|
impl<T> Option<T> {
|
2013-06-10 16:50:12 -05:00
|
|
|
/// Return an iterator over the possibly contained value
|
2013-06-10 16:45:59 -05:00
|
|
|
#[inline]
|
|
|
|
pub fn iter<'r>(&'r self) -> OptionIterator<'r, T> {
|
|
|
|
match *self {
|
|
|
|
Some(ref x) => OptionIterator{opt: Some(x)},
|
|
|
|
None => OptionIterator{opt: None}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-10 16:50:12 -05:00
|
|
|
/// Return a mutable iterator over the possibly contained value
|
2013-06-10 16:45:59 -05:00
|
|
|
#[inline]
|
|
|
|
pub fn mut_iter<'r>(&'r mut self) -> OptionMutIterator<'r, T> {
|
|
|
|
match *self {
|
|
|
|
Some(ref mut x) => OptionMutIterator{opt: Some(x)},
|
|
|
|
None => OptionMutIterator{opt: None}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-07-04 16:53:12 -05:00
|
|
|
/// Returns true if the option equals `none`
|
2013-06-10 16:45:59 -05:00
|
|
|
#[inline]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn is_none(&const self) -> bool {
|
2013-03-16 14:49:12 -05:00
|
|
|
match *self { None => true, Some(_) => false }
|
|
|
|
}
|
2012-12-18 20:55:19 -06:00
|
|
|
|
2012-07-04 16:53:12 -05:00
|
|
|
/// Returns true if the option contains some value
|
2012-12-18 20:55:19 -06:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn is_some(&const self) -> bool { !self.is_none() }
|
2013-03-16 14:49:12 -05:00
|
|
|
|
2013-05-18 01:50:23 -05:00
|
|
|
/// Update an optional value by optionally running its content through a
|
|
|
|
/// function that returns an option.
|
2013-03-16 14:49:12 -05:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn chain<U>(self, f: &fn(t: T) -> Option<U>) -> Option<U> {
|
2013-03-16 14:49:12 -05:00
|
|
|
match self {
|
|
|
|
Some(t) => f(t),
|
|
|
|
None => None
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-18 01:50:23 -05:00
|
|
|
/// Returns the leftmost Some() value, or None if both are None.
|
2013-03-16 14:49:12 -05:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn or(self, optb: Option<T>) -> Option<T> {
|
2013-03-16 14:49:12 -05:00
|
|
|
match self {
|
|
|
|
Some(opta) => Some(opta),
|
|
|
|
_ => optb
|
|
|
|
}
|
|
|
|
}
|
2012-04-11 18:27:11 -05:00
|
|
|
|
2013-05-18 01:50:23 -05:00
|
|
|
/// Update an optional value by optionally running its content by reference
|
|
|
|
/// through a function that returns an option.
|
2013-04-10 15:11:35 -05:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn chain_ref<'a, U>(&'a self, f: &fn(x: &'a T) -> Option<U>)
|
|
|
|
-> Option<U> {
|
|
|
|
match *self {
|
|
|
|
Some(ref x) => f(x),
|
|
|
|
None => None
|
|
|
|
}
|
2013-04-10 15:11:35 -05:00
|
|
|
}
|
|
|
|
|
2012-12-18 20:55:19 -06:00
|
|
|
/// Maps a `some` value from one type to another by reference
|
2013-04-10 15:11:35 -05:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn map<'a, U>(&self, f: &fn(&'a T) -> U) -> Option<U> {
|
2013-04-10 15:11:35 -05:00
|
|
|
match *self { Some(ref x) => Some(f(x)), None => None }
|
|
|
|
}
|
|
|
|
|
2013-01-12 23:47:00 -06:00
|
|
|
/// As `map`, but consumes the option and gives `f` ownership to avoid
|
|
|
|
/// copying.
|
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn map_consume<U>(self, f: &fn(v: T) -> U) -> Option<U> {
|
2013-03-16 14:49:12 -05:00
|
|
|
match self { None => None, Some(v) => Some(f(v)) }
|
2013-01-12 23:47:00 -06:00
|
|
|
}
|
|
|
|
|
2012-08-14 18:17:59 -05:00
|
|
|
/// Applies a function to the contained value or returns a default
|
2013-04-10 15:11:35 -05:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn map_default<'a, U>(&'a self, def: U, f: &fn(&'a T) -> U) -> U {
|
2013-04-10 15:11:35 -05:00
|
|
|
match *self { None => def, Some(ref t) => f(t) }
|
|
|
|
}
|
|
|
|
|
2013-01-12 23:56:50 -06:00
|
|
|
/// As `map_default`, but consumes the option and gives `f`
|
|
|
|
/// ownership to avoid copying.
|
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn map_consume_default<U>(self, def: U, f: &fn(v: T) -> U) -> U {
|
2013-01-12 23:56:50 -06:00
|
|
|
match self { None => def, Some(v) => f(v) }
|
|
|
|
}
|
|
|
|
|
2013-01-13 10:09:09 -06:00
|
|
|
/// Apply a function to the contained value or do nothing
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn mutate(&mut self, f: &fn(T) -> T) {
|
2013-01-13 10:09:09 -06:00
|
|
|
if self.is_some() {
|
|
|
|
*self = Some(f(self.swap_unwrap()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Apply a function to the contained value or set it to a default
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn mutate_default(&mut self, def: T, f: &fn(T) -> T) {
|
2013-01-13 10:09:09 -06:00
|
|
|
if self.is_some() {
|
|
|
|
*self = Some(f(self.swap_unwrap()));
|
|
|
|
} else {
|
|
|
|
*self = Some(def);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-10-04 17:14:28 -05:00
|
|
|
/**
|
|
|
|
Gets an immutable reference to the value inside an option.
|
|
|
|
|
|
|
|
# Failure
|
|
|
|
|
|
|
|
Fails if the value equals `None`
|
|
|
|
|
|
|
|
# Safety note
|
|
|
|
|
|
|
|
In general, because this function may fail, its use is discouraged
|
|
|
|
(calling `get` on `None` is akin to dereferencing a null pointer).
|
|
|
|
Instead, prefer to use pattern matching and handle the `None`
|
|
|
|
case explicitly.
|
|
|
|
*/
|
2012-12-18 20:55:19 -06:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn get_ref<'a>(&'a self) -> &'a T {
|
2013-04-10 15:11:35 -05:00
|
|
|
match *self {
|
|
|
|
Some(ref x) => x,
|
2013-05-05 17:18:51 -05:00
|
|
|
None => fail!("option::get_ref none")
|
2013-04-10 15:11:35 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-02-03 20:15:43 -06:00
|
|
|
/**
|
|
|
|
Gets a mutable reference to the value inside an option.
|
|
|
|
|
|
|
|
# Failure
|
|
|
|
|
|
|
|
Fails if the value equals `None`
|
|
|
|
|
|
|
|
# Safety note
|
|
|
|
|
|
|
|
In general, because this function may fail, its use is discouraged
|
|
|
|
(calling `get` on `None` is akin to dereferencing a null pointer).
|
|
|
|
Instead, prefer to use pattern matching and handle the `None`
|
|
|
|
case explicitly.
|
|
|
|
*/
|
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn get_mut_ref<'a>(&'a mut self) -> &'a mut T {
|
2013-04-10 15:11:35 -05:00
|
|
|
match *self {
|
|
|
|
Some(ref mut x) => x,
|
2013-05-05 17:18:51 -05:00
|
|
|
None => fail!("option::get_mut_ref none")
|
2013-04-10 15:11:35 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-12-18 20:55:19 -06:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn unwrap(self) -> T {
|
2013-03-16 14:49:12 -05:00
|
|
|
/*!
|
|
|
|
Moves a value out of an option type and returns it.
|
|
|
|
|
|
|
|
Useful primarily for getting strings, vectors and unique pointers out
|
|
|
|
of option types without copying them.
|
|
|
|
|
|
|
|
# Failure
|
|
|
|
|
|
|
|
Fails if the value equals `None`.
|
|
|
|
|
|
|
|
# Safety note
|
|
|
|
|
|
|
|
In general, because this function may fail, its use is discouraged.
|
|
|
|
Instead, prefer to use pattern matching and handle the `None`
|
|
|
|
case explicitly.
|
|
|
|
*/
|
|
|
|
match self {
|
|
|
|
Some(x) => x,
|
2013-05-05 17:18:51 -05:00
|
|
|
None => fail!("option::unwrap none")
|
2013-03-16 14:49:12 -05:00
|
|
|
}
|
|
|
|
}
|
2012-12-18 20:55:19 -06:00
|
|
|
|
2013-01-12 23:47:00 -06:00
|
|
|
/**
|
|
|
|
* The option dance. Moves a value out of an option type and returns it,
|
|
|
|
* replacing the original with `None`.
|
|
|
|
*
|
|
|
|
* # Failure
|
|
|
|
*
|
|
|
|
* Fails if the value equals `None`.
|
|
|
|
*/
|
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn swap_unwrap(&mut self) -> T {
|
2013-05-05 17:18:51 -05:00
|
|
|
if self.is_none() { fail!("option::swap_unwrap none") }
|
2013-03-16 14:49:12 -05:00
|
|
|
util::replace(self, None).unwrap()
|
|
|
|
}
|
2013-01-12 23:47:00 -06:00
|
|
|
|
2012-12-18 20:55:19 -06:00
|
|
|
/**
|
|
|
|
* Gets the value out of an option, printing a specified message on
|
|
|
|
* failure
|
|
|
|
*
|
|
|
|
* # Failure
|
|
|
|
*
|
|
|
|
* Fails if the value equals `none`
|
|
|
|
*/
|
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn expect(self, reason: &str) -> T {
|
2013-03-16 14:49:12 -05:00
|
|
|
match self {
|
|
|
|
Some(val) => val,
|
|
|
|
None => fail!(reason.to_owned()),
|
|
|
|
}
|
|
|
|
}
|
2012-08-14 18:17:59 -05:00
|
|
|
}
|
|
|
|
|
2013-05-31 17:17:22 -05:00
|
|
|
impl<T:Copy> Option<T> {
|
2012-07-04 16:53:12 -05:00
|
|
|
/**
|
2012-10-04 17:14:28 -05:00
|
|
|
Gets the value out of an option
|
|
|
|
|
|
|
|
# Failure
|
|
|
|
|
|
|
|
Fails if the value equals `None`
|
|
|
|
|
|
|
|
# Safety note
|
|
|
|
|
|
|
|
In general, because this function may fail, its use is discouraged
|
|
|
|
(calling `get` on `None` is akin to dereferencing a null pointer).
|
|
|
|
Instead, prefer to use pattern matching and handle the `None`
|
|
|
|
case explicitly.
|
|
|
|
*/
|
2012-12-18 20:55:19 -06:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn get(self) -> T {
|
2013-03-16 14:49:12 -05:00
|
|
|
match self {
|
2013-05-29 18:59:33 -05:00
|
|
|
Some(x) => return x,
|
2013-05-05 17:18:51 -05:00
|
|
|
None => fail!("option::get none")
|
2013-03-16 14:49:12 -05:00
|
|
|
}
|
|
|
|
}
|
2012-12-18 20:55:19 -06:00
|
|
|
|
2013-03-16 14:49:12 -05:00
|
|
|
/// Returns the contained value or a default
|
2012-12-18 20:55:19 -06:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn get_or_default(self, def: T) -> T {
|
2013-05-29 18:59:33 -05:00
|
|
|
match self { Some(x) => x, None => def }
|
2013-03-16 14:49:12 -05:00
|
|
|
}
|
2012-12-18 20:55:19 -06:00
|
|
|
|
2012-07-17 12:54:24 -05:00
|
|
|
/// Applies a function zero or more times until the result is none.
|
2012-12-18 20:55:19 -06:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn while_some(self, blk: &fn(v: T) -> Option<T>) {
|
2013-03-16 14:49:12 -05:00
|
|
|
let mut opt = self;
|
|
|
|
while opt.is_some() {
|
|
|
|
opt = blk(opt.unwrap());
|
|
|
|
}
|
2012-12-18 20:55:19 -06:00
|
|
|
}
|
2012-03-16 19:49:58 -05:00
|
|
|
}
|
|
|
|
|
2013-05-31 17:17:22 -05:00
|
|
|
impl<T:Copy + Zero> Option<T> {
|
2013-03-16 14:49:12 -05:00
|
|
|
/// Returns the contained value or zero (for this type)
|
2013-01-03 17:36:23 -06:00
|
|
|
#[inline(always)]
|
2013-05-31 17:17:22 -05:00
|
|
|
pub fn get_or_zero(self) -> T {
|
|
|
|
match self {
|
|
|
|
Some(x) => x,
|
|
|
|
None => Zero::zero()
|
|
|
|
}
|
2013-03-16 14:49:12 -05:00
|
|
|
}
|
2013-01-03 17:36:23 -06:00
|
|
|
}
|
|
|
|
|
2013-06-10 16:50:12 -05:00
|
|
|
/// Immutable iterator over an `Option<A>`
|
2013-06-10 16:45:59 -05:00
|
|
|
pub struct OptionIterator<'self, A> {
|
|
|
|
priv opt: Option<&'self A>
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'self, A> Iterator<&'self A> for OptionIterator<'self, A> {
|
|
|
|
fn next(&mut self) -> Option<&'self A> {
|
|
|
|
util::replace(&mut self.opt, None)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-10 16:50:12 -05:00
|
|
|
/// Mutable iterator over an `Option<A>`
|
2013-06-10 16:45:59 -05:00
|
|
|
pub struct OptionMutIterator<'self, A> {
|
|
|
|
priv opt: Option<&'self mut A>
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'self, A> Iterator<&'self mut A> for OptionMutIterator<'self, A> {
|
|
|
|
fn next(&mut self) -> Option<&'self mut A> {
|
|
|
|
util::replace(&mut self.opt, None)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-02-21 01:06:47 -06:00
|
|
|
#[test]
|
|
|
|
fn test_unwrap_ptr() {
|
2013-04-22 16:27:30 -05:00
|
|
|
unsafe {
|
|
|
|
let x = ~0;
|
2013-04-26 16:04:39 -05:00
|
|
|
let addr_x: *int = ::cast::transmute(&*x);
|
2013-04-22 16:27:30 -05:00
|
|
|
let opt = Some(x);
|
|
|
|
let y = opt.unwrap();
|
2013-04-26 16:04:39 -05:00
|
|
|
let addr_y: *int = ::cast::transmute(&*y);
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(addr_x, addr_y);
|
2013-04-22 16:27:30 -05:00
|
|
|
}
|
2012-02-21 01:06:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_unwrap_str() {
|
2012-07-14 00:57:48 -05:00
|
|
|
let x = ~"test";
|
2012-10-01 18:06:28 -05:00
|
|
|
let addr_x = str::as_buf(x, |buf, _len| buf);
|
2013-02-15 02:51:28 -06:00
|
|
|
let opt = Some(x);
|
2013-03-16 14:49:12 -05:00
|
|
|
let y = opt.unwrap();
|
2012-10-01 18:06:28 -05:00
|
|
|
let addr_y = str::as_buf(y, |buf, _len| buf);
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(addr_x, addr_y);
|
2012-02-21 01:06:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_unwrap_resource() {
|
2012-09-02 17:39:37 -05:00
|
|
|
struct R {
|
2012-09-06 21:40:15 -05:00
|
|
|
i: @mut int,
|
2013-02-27 18:13:53 -06:00
|
|
|
}
|
|
|
|
|
2013-03-20 20:18:57 -05:00
|
|
|
#[unsafe_destructor]
|
2013-02-27 18:13:53 -06:00
|
|
|
impl ::ops::Drop for R {
|
|
|
|
fn finalize(&self) { *(self.i) += 1; }
|
2012-02-21 01:06:47 -06:00
|
|
|
}
|
2012-09-04 17:23:28 -05:00
|
|
|
|
|
|
|
fn R(i: @mut int) -> R {
|
|
|
|
R {
|
|
|
|
i: i
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-26 20:35:18 -05:00
|
|
|
let i = @mut 0;
|
2012-02-21 01:06:47 -06:00
|
|
|
{
|
2012-09-02 17:39:37 -05:00
|
|
|
let x = R(i);
|
2013-02-15 02:51:28 -06:00
|
|
|
let opt = Some(x);
|
2013-03-16 14:49:12 -05:00
|
|
|
let _y = opt.unwrap();
|
2012-02-21 01:06:47 -06:00
|
|
|
}
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(*i, 1);
|
2012-02-21 01:06:47 -06:00
|
|
|
}
|
|
|
|
|
2012-08-02 13:40:42 -05:00
|
|
|
#[test]
|
|
|
|
fn test_option_dance() {
|
2012-08-20 14:23:37 -05:00
|
|
|
let x = Some(());
|
|
|
|
let mut y = Some(5);
|
2012-08-02 13:40:42 -05:00
|
|
|
let mut y2 = 0;
|
2013-06-10 16:50:12 -05:00
|
|
|
for x.iter().advance |_x| {
|
2013-03-16 14:49:12 -05:00
|
|
|
y2 = y.swap_unwrap();
|
2012-08-02 13:40:42 -05:00
|
|
|
}
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(y2, 5);
|
2013-03-28 20:39:09 -05:00
|
|
|
assert!(y.is_none());
|
2012-08-02 13:40:42 -05:00
|
|
|
}
|
|
|
|
#[test] #[should_fail] #[ignore(cfg(windows))]
|
|
|
|
fn test_option_too_much_dance() {
|
2013-06-04 07:08:25 -05:00
|
|
|
let mut y = Some(util::NonCopyable::new());
|
2013-03-16 14:49:12 -05:00
|
|
|
let _y2 = y.swap_unwrap();
|
|
|
|
let _y3 = y.swap_unwrap();
|
2012-08-02 13:40:42 -05:00
|
|
|
}
|
|
|
|
|
2012-07-17 12:54:24 -05:00
|
|
|
#[test]
|
|
|
|
fn test_option_while_some() {
|
|
|
|
let mut i = 0;
|
2012-08-20 14:23:37 -05:00
|
|
|
do Some(10).while_some |j| {
|
2012-07-17 12:54:24 -05:00
|
|
|
i += 1;
|
|
|
|
if (j > 0) {
|
2012-08-20 14:23:37 -05:00
|
|
|
Some(j-1)
|
2012-07-17 12:54:24 -05:00
|
|
|
} else {
|
2012-08-20 14:23:37 -05:00
|
|
|
None
|
2012-07-17 12:54:24 -05:00
|
|
|
}
|
|
|
|
}
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(i, 11);
|
2012-07-17 12:54:24 -05:00
|
|
|
}
|
|
|
|
|
2013-01-03 17:36:23 -06:00
|
|
|
#[test]
|
2013-01-04 18:01:26 -06:00
|
|
|
fn test_get_or_zero() {
|
2013-01-03 17:36:23 -06:00
|
|
|
let some_stuff = Some(42);
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(some_stuff.get_or_zero(), 42);
|
2013-01-03 17:36:23 -06:00
|
|
|
let no_stuff: Option<int> = None;
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(no_stuff.get_or_zero(), 0);
|
2013-01-03 17:36:23 -06:00
|
|
|
}
|