File tree Expand file tree Collapse file tree 2 files changed +20
-1
lines changed Expand file tree Collapse file tree 2 files changed +20
-1
lines changed Original file line number Diff line number Diff line change 1
1
---
2
2
refs/heads/master: 2d28d645422c1617be58c8ca7ad9a457264ca850
3
3
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4
- refs/heads/snap-stage3: ddd8c156c650347267e4b02938f8efb207cb2150
4
+ refs/heads/snap-stage3: eb74f0ccf60a1e8dda1afe9a3be0e8dd4fd96f9f
5
5
refs/heads/try: 7b78b52e602bb3ea8174f9b2006bff3315f03ef9
6
6
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
7
7
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
Original file line number Diff line number Diff line change @@ -60,6 +60,19 @@ impl<A:Clone> Future<A> {
60
60
}
61
61
}
62
62
63
+ impl < A > Future < A > {
64
+ /// Gets the value from this future, forcing evaluation.
65
+ pub fn unwrap ( self ) -> A {
66
+ let mut this = self ;
67
+ this. get_ref ( ) ;
68
+ let state = replace ( & mut this. state , Evaluating ) ;
69
+ match state {
70
+ Forced ( v) => v,
71
+ _ => fail ! ( "Logic error." ) ,
72
+ }
73
+ }
74
+ }
75
+
63
76
impl < A > Future < A > {
64
77
pub fn get_ref < ' a > ( & ' a mut self ) -> & ' a A {
65
78
/*!
@@ -179,6 +192,12 @@ mod test {
179
192
assert_eq!(f.get(), ~" fail");
180
193
}
181
194
195
+ #[test]
196
+ fn test_interface_unwrap() {
197
+ let mut f = from_value(~" fail");
198
+ assert_eq!(f.unwrap(), ~" fail");
199
+ }
200
+
182
201
#[test]
183
202
fn test_get_ref_method() {
184
203
let mut f = from_value(22);
You can’t perform that action at this time.
0 commit comments