提交 7841b776 编写于 作者: B bors

auto merge of #8772 : thestinger/rust/option, r=anasazi

Closes #6002 

There is consensus that the current implementation should be changed or
removed, so removing it seems like the right decision for now.
......@@ -43,7 +43,6 @@
use clone::Clone;
use cmp::{Eq,Ord};
use ops::Add;
use util;
use num::Zero;
use iterator;
......@@ -77,18 +76,6 @@ fn gt(&self, other: &Option<T>) -> bool {
}
}
impl<T: Add<T, T>> Add<Option<T>, Option<T>> for Option<T> {
#[inline]
fn add(&self, other: &Option<T>) -> Option<T> {
match (&*self, &*other) {
(&None, &None) => None,
(_, &None) => None,
(&None, _) => None,
(&Some(ref lhs), &Some(ref rhs)) => Some(*lhs + *rhs)
}
}
}
// FIXME: #8242 implementing manually because deriving doesn't work for some reason
impl<T: ToStr> ToStr for Option<T> {
fn to_str(&self) -> ~str {
......
// Copyright 2013 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.
pub fn main() {
let foo: int = 1;
let bar: int = 2;
let foobar = foo + bar;
let nope = None::<int> + None::<int>;
let somefoo = Some(foo) + None::<int>;
let somebar = None::<int> + Some(bar);
let somefoobar = Some(foo) + Some(bar);
assert_eq!(nope, None::<int>);
assert_eq!(somefoo, None::<int>);
assert_eq!(somebar, None::<int>);
assert_eq!(foobar, somefoobar.unwrap());
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册