Skip to content

Commit 1d01124

Browse files
committed
---
yaml --- r: 94539 b: refs/heads/try c: fffbe7a h: refs/heads/master i: 94537: 32fc90e 94535: 73b2825 v: v3
1 parent 95c06ed commit 1d01124

File tree

2 files changed

+13
-7
lines changed

2 files changed

+13
-7
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
refs/heads/master: 0da105a8b7b6b1e0568e8ff20f6ff4b13cc7ecc2
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: a6d3e57dca68fde4effdda3e4ae2887aa535fcd6
5-
refs/heads/try: 09589aae4f36aeb1bb028e0f3e4f2bbc697412b2
5+
refs/heads/try: fffbe7a8cdf2378a3c5617d1600cf2d31b7a357f
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: 147ecfdd8221e4a4d4e090486829a06da1e0ca3c

branches/try/src/librustc/middle/ty.rs

Lines changed: 12 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,7 @@ use util::ppaux::{Repr, UserString};
3030
use util::common::{indenter};
3131

3232
use std::cast;
33+
use std::cell::RefCell;
3334
use std::cmp;
3435
use std::hashmap::{HashMap, HashSet};
3536
use std::ops;
@@ -264,7 +265,7 @@ pub type ctxt = @ctxt_;
264265
/// later on.
265266
struct ctxt_ {
266267
diag: @mut syntax::diagnostic::span_handler,
267-
interner: @mut HashMap<intern_key, ~t_box_>,
268+
interner: RefCell<HashMap<intern_key, ~t_box_>>,
268269
next_id: @mut uint,
269270
cstore: @mut metadata::cstore::CStore,
270271
sess: session::Session,
@@ -977,7 +978,7 @@ pub fn mk_ctxt(s: session::Session,
977978
named_region_map: named_region_map,
978979
item_variance_map: @mut HashMap::new(),
979980
diag: s.diagnostic(),
980-
interner: @mut HashMap::new(),
981+
interner: RefCell::new(HashMap::new()),
981982
next_id: @mut primitives::LAST_PRIMITIVE_ID,
982983
cstore: s.cstore,
983984
sess: s,
@@ -1042,9 +1043,13 @@ pub fn mk_t(cx: ctxt, st: sty) -> t {
10421043
};
10431044

10441045
let key = intern_key { sty: to_unsafe_ptr(&st) };
1045-
match cx.interner.find(&key) {
1046-
Some(t) => unsafe { return cast::transmute(&t.sty); },
1047-
_ => ()
1046+
1047+
{
1048+
let mut interner = cx.interner.borrow_mut();
1049+
match interner.get().find(&key) {
1050+
Some(t) => unsafe { return cast::transmute(&t.sty); },
1051+
_ => ()
1052+
}
10481053
}
10491054

10501055
let mut flags = 0u;
@@ -1138,7 +1143,8 @@ pub fn mk_t(cx: ctxt, st: sty) -> t {
11381143
sty: sty_ptr,
11391144
};
11401145

1141-
cx.interner.insert(key, t);
1146+
let mut interner = cx.interner.borrow_mut();
1147+
interner.get().insert(key, t);
11421148

11431149
*cx.next_id += 1;
11441150

0 commit comments

Comments
 (0)