Skip to content

Commit 3253b5e

Browse files
committed
---
yaml --- r: 3782 b: refs/heads/master c: e494e73 h: refs/heads/master v: v3
1 parent b9f1385 commit 3253b5e

File tree

4 files changed

+70
-26
lines changed

4 files changed

+70
-26
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,2 @@
11
---
2-
refs/heads/master: 18ebef5bbadac330dcb350a072bb864231c3e920
2+
refs/heads/master: e494e73cdd30fda0a10d6b3c067ca3a2809527eb

trunk/src/comp/metadata/cstore.rs

Lines changed: 66 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,23 @@ import std::vec;
66
import std::str;
77
import syntax::ast;
88

9+
export cstore;
10+
export cnum_map;
11+
export crate_metadata;
12+
export mk_cstore;
13+
export get_crate_data;
14+
export set_crate_data;
15+
export have_crate_data;
16+
export iter_crate_data;
17+
export add_used_crate_file;
18+
export get_used_crate_files;
19+
export add_used_library;
20+
export get_used_libraries;
21+
export add_used_link_args;
22+
export get_used_link_args;
23+
export add_use_stmt_cnum;
24+
export get_use_stmt_cnum;
25+
926
// A map from external crate numbers (as decoded from some crate file) to
1027
// local crate numbers (as generated during this session). Each external
1128
// crate may refer to types in other external crates, and each has their
@@ -16,73 +33,100 @@ type crate_metadata = rec(str name,
1633
vec[u8] data,
1734
cnum_map cnum_map);
1835

36+
// This is a bit of an experiment at encapsulating the data in cstore. By
37+
// keeping all the data in a non-exported tag variant, it's impossible for
38+
// other modules to access the cstore's private data. This could also be
39+
// achieved with an obj, but at the expense of a vtable. Not sure if this is a
40+
// good pattern or not.
41+
tag cstore {
42+
private(cstore_private);
43+
}
44+
45+
type cstore_private = @rec(map::hashmap[ast::crate_num, crate_metadata] metas,
46+
use_crate_map use_crate_map,
47+
mutable vec[str] used_crate_files,
48+
mutable vec[str] used_libraries,
49+
mutable vec[str] used_link_args);
50+
1951
// Map from node_id's of local use statements to crate numbers
2052
type use_crate_map = map::hashmap[ast::node_id, ast::crate_num];
2153

22-
type cstore = @rec(map::hashmap[ast::crate_num, crate_metadata] metas,
23-
use_crate_map use_crate_map,
24-
mutable vec[str] used_crate_files,
25-
mutable vec[str] used_libraries,
26-
mutable vec[str] used_link_args);
54+
// Internal method to retrieve the data from the cstore
55+
fn p(&cstore cstore) -> cstore_private {
56+
alt (cstore) {
57+
case (private(?p)) { p }
58+
}
59+
}
2760

2861
fn mk_cstore() -> cstore {
2962
auto meta_cache = map::new_int_hash[crate_metadata]();
3063
auto crate_map = map::new_int_hash[ast::crate_num]();
31-
ret @rec(metas = meta_cache,
32-
use_crate_map = crate_map,
33-
mutable used_crate_files = [],
34-
mutable used_libraries = [],
35-
mutable used_link_args = []);
64+
ret private(@rec(metas = meta_cache,
65+
use_crate_map = crate_map,
66+
mutable used_crate_files = [],
67+
mutable used_libraries = [],
68+
mutable used_link_args = []));
3669
}
3770

3871
fn get_crate_data(&cstore cstore, ast::crate_num cnum) -> crate_metadata {
39-
ret cstore.metas.get(cnum);
72+
ret p(cstore).metas.get(cnum);
4073
}
4174

4275
fn set_crate_data(&cstore cstore, ast::crate_num cnum, &crate_metadata data) {
43-
cstore.metas.insert(cnum, data);
76+
p(cstore).metas.insert(cnum, data);
4477
}
4578

4679
fn have_crate_data(&cstore cstore, ast::crate_num cnum) -> bool {
47-
ret cstore.metas.contains_key(cnum);
80+
ret p(cstore).metas.contains_key(cnum);
81+
}
82+
83+
iter iter_crate_data(&cstore cstore) -> @tup(ast::crate_num, crate_metadata) {
84+
for each (@tup(ast::crate_num, crate_metadata) kv
85+
in p(cstore).metas.items()) {
86+
put kv;
87+
}
4888
}
4989

5090
fn add_used_crate_file(&cstore cstore, &str lib) {
51-
if (!vec::member(lib, cstore.used_crate_files)) {
52-
cstore.used_crate_files += [lib];
91+
if (!vec::member(lib, p(cstore).used_crate_files)) {
92+
p(cstore).used_crate_files += [lib];
5393
}
5494
}
5595

5696
fn get_used_crate_files(&cstore cstore) -> vec[str] {
57-
ret cstore.used_crate_files;
97+
ret p(cstore).used_crate_files;
5898
}
5999

60100
fn add_used_library(&cstore cstore, &str lib) -> bool {
61101
if (lib == "") { ret false; }
62102

63-
if (vec::member(lib, cstore.used_libraries)) {
103+
if (vec::member(lib, p(cstore).used_libraries)) {
64104
ret false;
65105
}
66106

67-
cstore.used_libraries += [lib];
107+
p(cstore).used_libraries += [lib];
68108
ret true;
69109
}
70110

71111
fn get_used_libraries(&cstore cstore) -> vec[str] {
72-
ret cstore.used_libraries;
112+
ret p(cstore).used_libraries;
73113
}
74114

75115
fn add_used_link_args(&cstore cstore, &str args) {
76-
cstore.used_link_args += str::split(args, ' ' as u8);
116+
p(cstore).used_link_args += str::split(args, ' ' as u8);
77117
}
78118

79119
fn get_used_link_args(&cstore cstore) -> vec[str] {
80-
ret cstore.used_link_args;
120+
ret p(cstore).used_link_args;
81121
}
82122

83123
fn add_use_stmt_cnum(&cstore cstore, ast::node_id use_id,
84124
ast::crate_num cnum) {
85-
cstore.use_crate_map.insert(use_id, cnum);
125+
p(cstore).use_crate_map.insert(use_id, cnum);
126+
}
127+
128+
fn get_use_stmt_cnum(&cstore cstore, ast::node_id use_id) -> ast::crate_num {
129+
ret p(cstore).use_crate_map.get(use_id);
86130
}
87131

88132
// Local Variables:

trunk/src/comp/metadata/encoder.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -528,7 +528,7 @@ fn encode_crate_deps(&ebml::writer ebml_w, &cstore::cstore cstore) {
528528

529529
// Pull the cnums and names out of cstore
530530
let vec[mutable numname] pairs = [mutable];
531-
for each (hashkv hashkv in cstore.metas.items()) {
531+
for each (hashkv hashkv in cstore::iter_crate_data(cstore)) {
532532
pairs += [mutable tup(hashkv._0, hashkv._1.name)];
533533
}
534534

trunk/src/comp/middle/resolve.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -886,8 +886,8 @@ fn found_view_item(&env e, @ast::view_item vi, namespace ns) ->
886886
option::t[def] {
887887
alt (vi.node) {
888888
case (ast::view_item_use(_, _, ?id)) {
889-
auto crate_map = e.cstore.use_crate_map;
890-
ret some(ast::def_mod(tup(crate_map.get(id), -1)));
889+
auto cnum = cstore::get_use_stmt_cnum(e.cstore, id);
890+
ret some(ast::def_mod(tup(cnum, -1)));
891891
}
892892
case (ast::view_item_import(_, _, ?id)) {
893893
ret lookup_import(e, local_def(id), ns);

0 commit comments

Comments
 (0)