diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2014-04-28 20:36:08 -0700 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2014-05-07 23:43:39 -0700 |
| commit | ab92ea526d455b402efbccc7160c8aec0237c88f (patch) | |
| tree | 92e748f3e3496a48ac68dd290a0a08aa342740a1 /src/libstd/macros.rs | |
| parent | ef6daf9935da103f1b915a5c9904794da79b0b60 (diff) | |
| download | rust-ab92ea526d455b402efbccc7160c8aec0237c88f.tar.gz rust-ab92ea526d455b402efbccc7160c8aec0237c88f.zip | |
std: Modernize the local_data api
This commit brings the local_data api up to modern rust standards with a few key improvements: * The `pop` and `set` methods have been combined into one method, `replace` * The `get_mut` method has been removed. All interior mutability should be done through `RefCell`. * All functionality is now exposed as a method on the keys themselves. Instead of importing std::local_data, you now use "key.replace()" and "key.get()". * All closures have been removed in favor of RAII functionality. This means that get() and get_mut() no long require closures, but rather return Option<SmartPointer> where the smart pointer takes care of relinquishing the borrow and also implements the necessary Deref traits * The modify() function was removed to cut the local_data interface down to its bare essentials (similarly to how RefCell removed set/get). [breaking-change]
Diffstat (limited to 'src/libstd/macros.rs')
| -rw-r--r-- | src/libstd/macros.rs | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/src/libstd/macros.rs b/src/libstd/macros.rs index 4ae3d453f03..1efe56756ed 100644 --- a/src/libstd/macros.rs +++ b/src/libstd/macros.rs @@ -289,12 +289,10 @@ macro_rules! println( /// # Example /// /// ``` -/// use std::local_data; -/// /// local_data_key!(my_integer: int) /// -/// local_data::set(my_integer, 2); -/// local_data::get(my_integer, |val| println!("{}", val.map(|i| *i))); +/// my_integer.replace(Some(2)); +/// println!("{}", my_integer.get().map(|a| *a)); /// ``` #[macro_export] macro_rules! local_data_key( |
