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]
This commit is contained in:
parent
ef6daf9935
commit
ab92ea526d
23 changed files with 444 additions and 661 deletions
|
@ -19,7 +19,6 @@ use util::interner;
|
|||
use serialize::{Decodable, Decoder, Encodable, Encoder};
|
||||
use std::cast;
|
||||
use std::fmt;
|
||||
use std::local_data;
|
||||
use std::path::BytesContainer;
|
||||
use std::rc::Rc;
|
||||
use std::strbuf::StrBuf;
|
||||
|
@ -529,11 +528,11 @@ pub type IdentInterner = StrInterner;
|
|||
// FIXME(eddyb) #8726 This should probably use a task-local reference.
|
||||
pub fn get_ident_interner() -> Rc<IdentInterner> {
|
||||
local_data_key!(key: Rc<::parse::token::IdentInterner>)
|
||||
match local_data::get(key, |k| k.map(|k| k.clone())) {
|
||||
Some(interner) => interner,
|
||||
match key.get() {
|
||||
Some(interner) => interner.clone(),
|
||||
None => {
|
||||
let interner = Rc::new(mk_fresh_ident_interner());
|
||||
local_data::set(key, interner.clone());
|
||||
key.replace(Some(interner.clone()));
|
||||
interner
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue