Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
1386420c
R
Rust
项目概览
int
/
Rust
大约 1 年 前同步成功
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rust
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
1386420c
编写于
7月 07, 2011
作者:
B
Brian Anderson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Move used_crate_files from session to cstore
上级
82983e50
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
24 addition
and
25 deletion
+24
-25
src/comp/driver/rustc.rs
src/comp/driver/rustc.rs
+4
-3
src/comp/driver/session.rs
src/comp/driver/session.rs
+0
-14
src/comp/metadata/creader.rs
src/comp/metadata/creader.rs
+3
-2
src/comp/metadata/cstore.rs
src/comp/metadata/cstore.rs
+17
-6
未找到文件。
src/comp/driver/rustc.rs
浏览文件 @
1386420c
...
...
@@ -2,6 +2,7 @@
// -*- rust -*-
import
metadata
::
creader
;
import
metadata
::
cstore
;
import
syntax
::
parse
::
parser
;
import
syntax
::
parse
::
token
;
import
syntax
::
ast
;
...
...
@@ -352,8 +353,8 @@ fn build_session_options(str binary, getopts::match match, str binary_dir) ->
fn
build_session
(
@
session
::
options
sopts
)
->
session
::
session
{
auto
target_cfg
=
build_target_config
();
auto
cstore
=
metadata
::
cstore
::
mk_cstore
();
ret
session
::
session
(
target_cfg
,
sopts
,
cstore
,
[],
auto
cstore
=
cstore
::
mk_cstore
();
ret
session
::
session
(
target_cfg
,
sopts
,
cstore
,
[],
[],
codemap
::
new_codemap
(),
0u
);
}
...
...
@@ -516,7 +517,7 @@ fn rmext(str filename) -> str {
};
}
for
(
str
cratepath
in
sess
.get_used_crate_files
(
))
{
for
(
str
cratepath
in
cstore
::
get_used_crate_files
(
sess
.get_cstore
()
))
{
auto
dir
=
fs
::
dirname
(
cratepath
);
if
(
dir
!=
""
)
{
gcc_args
+=
[
"-L"
+
dir
];
...
...
src/comp/driver/session.rs
浏览文件 @
1386420c
...
...
@@ -46,7 +46,6 @@
obj
session
(
@
config
targ_cfg
,
@
options
opts
,
metadata
::
cstore
::
cstore
cstore
,
mutable
vec
[
str
]
used_crate_files
,
mutable
vec
[
str
]
used_libraries
,
mutable
vec
[
str
]
used_link_args
,
codemap
::
codemap
cm
,
...
...
@@ -123,19 +122,6 @@ fn add_used_library(&str lib) -> bool {
fn
get_used_libraries
()
->
vec
[
str
]
{
ret
used_libraries
;
}
fn
add_used_crate_file
(
&
str
lib
)
{
// A program has a small number of crates, so a vector is probably
// a good data structure in here.
for
(
str
l
in
used_crate_files
)
{
if
(
l
==
lib
)
{
ret
;
}
}
used_crate_files
+=
[
lib
];
}
fn
get_used_crate_files
()
->
vec
[
str
]
{
ret
used_crate_files
;
}
fn
get_codemap
()
->
codemap
::
codemap
{
ret
cm
;
}
fn
lookup_pos
(
uint
pos
)
->
codemap
::
loc
{
ret
codemap
::
lookup_pos
(
cm
,
pos
);
...
...
src/comp/metadata/creader.rs
浏览文件 @
1386420c
...
...
@@ -138,9 +138,10 @@ fn load_library_crate(&session::session sess, span span, int cnum,
&
vec
[
str
]
library_search_paths
)
{
alt
(
find_library_crate
(
sess
,
ident
,
metas
,
library_search_paths
))
{
case
(
some
(
?
t
))
{
cstore
::
set_crate_data
(
sess
.get_cstore
(),
cnum
,
auto
cstore
=
sess
.get_cstore
();
cstore
::
set_crate_data
(
cstore
,
cnum
,
rec
(
name
=
ident
,
data
=
t
._1
));
sess
.add_used_crate_file
(
t
._0
);
cstore
::
add_used_crate_file
(
cstore
,
t
._0
);
ret
;
}
case
(
_
)
{
}
...
...
src/comp/metadata/cstore.rs
浏览文件 @
1386420c
import
std
::
map
;
import
std
::
vec
;
type
crate_metadata
=
rec
(
str
name
,
vec
[
u8
]
data
);
type
cstore
=
@
rec
(
map
::
hashmap
[
int
,
crate_metadata
]
metas
,
vec
[
str
]
used_crate_files
,
vec
[
str
]
used_libraries
,
vec
[
str
]
used_link_args
);
mutable
vec
[
str
]
used_crate_files
,
mutable
vec
[
str
]
used_libraries
,
mutable
vec
[
str
]
used_link_args
);
fn
mk_cstore
()
->
cstore
{
auto
meta_cache
=
map
::
new_int_hash
[
crate_metadata
]();
ret
@
rec
(
metas
=
meta_cache
,
used_crate_files
=
[],
used_libraries
=
[],
used_link_args
=
[]);
mutable
used_crate_files
=
[],
mutable
used_libraries
=
[],
mutable
used_link_args
=
[]);
}
fn
get_crate_data
(
&
cstore
cstore
,
int
cnum
)
->
crate_metadata
{
...
...
@@ -27,6 +28,16 @@ fn have_crate_data(&cstore cstore, int cnum) -> bool {
ret
cstore
.metas
.contains_key
(
cnum
);
}
fn
add_used_crate_file
(
&
cstore
cstore
,
&
str
lib
)
{
if
(
!
vec
::
member
(
lib
,
cstore
.used_crate_files
))
{
cstore
.used_crate_files
+=
[
lib
];
}
}
fn
get_used_crate_files
(
&
cstore
cstore
)
->
vec
[
str
]
{
ret
cstore
.used_crate_files
;
}
// Local Variables:
// mode: rust
// fill-column: 78;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录