Skip to content

Commit 5bf1997

Browse files
committed
---
yaml --- r: 29756 b: refs/heads/incoming c: ac4132b h: refs/heads/master v: v3
1 parent 8e26040 commit 5bf1997

File tree

2 files changed

+33
-5
lines changed

2 files changed

+33
-5
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ refs/heads/try: d324a424d8f84b1eb049b12cf34182bda91b0024
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: d0c6ce338884ee21843f4b40bf6bf18d222ce5df
9-
refs/heads/incoming: 78d19d8f1bdb64317ebdb072c25ee1240a562095
9+
refs/heads/incoming: ac4132b7fda1e2bd356a5af8d89badf3e05f7a1a
1010
refs/heads/dist-snap: 2f32a1581f522e524009138b33b1c7049ced668d
1111
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596
1212
refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503

branches/incoming/src/libstd/cell.rs

Lines changed: 32 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -18,17 +18,18 @@ fn empty_cell<T>() -> Cell<T> {
1818
impl<T> Cell<T> {
1919
/// Yields the value, failing if the cell is empty.
2020
fn take() -> T {
21-
let mut value = none;
22-
value <-> self.value;
23-
if value.is_none() {
21+
if self.is_empty() {
2422
fail ~"attempt to take an empty cell";
2523
}
24+
25+
let mut value = none;
26+
value <-> self.value;
2627
return option::unwrap(value);
2728
}
2829

2930
/// Returns the value, failing if the cell is full.
3031
fn put_back(+value: T) {
31-
if self.value.is_none() {
32+
if !self.is_empty() {
3233
fail ~"attempt to put a value back into a full cell";
3334
}
3435
self.value = some(move value);
@@ -39,3 +40,30 @@ impl<T> Cell<T> {
3940
self.value.is_none()
4041
}
4142
}
43+
44+
#[test]
45+
fn test_basic() {
46+
let value_cell = Cell(~10);
47+
assert !value_cell.is_empty();
48+
let value = value_cell.take();
49+
assert value == ~10;
50+
assert value_cell.is_empty();
51+
value_cell.put_back(value);
52+
assert !value_cell.is_empty();
53+
}
54+
55+
#[test]
56+
#[should_fail]
57+
#[ignore(cfg(windows))]
58+
fn test_take_empty() {
59+
let value_cell = empty_cell::<~int>();
60+
value_cell.take();
61+
}
62+
63+
#[test]
64+
#[should_fail]
65+
#[ignore(cfg(windows))]
66+
fn test_put_back_non_empty() {
67+
let value_cell = Cell(~10);
68+
value_cell.put_back(~20);
69+
}

0 commit comments

Comments
 (0)