File tree Expand file tree Collapse file tree 2 files changed +17
-1
lines changed Expand file tree Collapse file tree 2 files changed +17
-1
lines changed Original file line number Diff line number Diff line change 1
1
---
2
- refs/heads/master: a076c287de55bd69328fbf542bf769ca20a12ab4
2
+ refs/heads/master: 0e3825d38cc459f9fcb24f1e95d4f6e867265300
3
3
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4
4
refs/heads/snap-stage3: cd6f24f9d14ac90d167386a56e7a6ac1f0318195
5
5
refs/heads/try: ffbe0e0e00374358b789b0037bcb3a577cd218be
Original file line number Diff line number Diff line change @@ -29,6 +29,20 @@ pure fn get<T: copy>(opt: option<T>) -> T {
29
29
}
30
30
}
31
31
32
+ pure fn get_ref < T > ( opt : & option < T > ) -> & T {
33
+ /*!
34
+ * Gets an immutable reference to the value inside an option.
35
+ *
36
+ * # Failure
37
+ *
38
+ * Fails if the value equals `none`
39
+ */
40
+ match * opt {
41
+ some( ref x) => x,
42
+ none => fail ~"option:: get_ref none"
43
+ }
44
+ }
45
+
32
46
pure fn expect < T : copy > ( opt : option < T > , reason : ~str ) -> T {
33
47
#[ doc = "
34
48
Gets the value out of an option, printing a specified message on failure
@@ -201,6 +215,8 @@ impl<T> &option<T> {
201
215
pure fn iter_ref ( f : fn ( x : & T ) ) { iter_ref ( self , f) }
202
216
/// Maps a `some` value from one type to another by reference
203
217
pure fn map_ref < U > ( f : fn ( x : & T ) -> U ) -> option < U > { map_ref ( self , f) }
218
+ /// Gets an immutable reference to the value inside a `some`.
219
+ pure fn get_ref ( ) -> & self /T { get_ref ( self ) }
204
220
}
205
221
206
222
impl < T : copy > option < T > {
You can’t perform that action at this time.
0 commit comments