Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
07fb93e6
R
Rust
项目概览
int
/
Rust
11 个月 前同步成功
通知
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,发现更多精彩内容 >>
提交
07fb93e6
编写于
4月 13, 2017
作者:
N
Niko Matsakis
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
make `write_metadata` take `tcx` intead of `SharedCrateContext`
上级
f2487b81
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
11 deletion
+11
-11
src/librustc_trans/base.rs
src/librustc_trans/base.rs
+11
-11
未找到文件。
src/librustc_trans/base.rs
浏览文件 @
07fb93e6
...
...
@@ -725,14 +725,14 @@ fn contains_null(s: &str) -> bool {
s
.bytes
()
.any
(|
b
|
b
==
0
)
}
fn
write_metadata
(
cx
:
&
SharedCrateContext
,
link_meta
:
&
LinkMeta
,
exported_symbols
:
&
NodeSet
)
->
(
ContextRef
,
ModuleRef
,
EncodedMetadata
)
{
fn
write_metadata
<
'a
,
'gcx
>
(
tcx
:
TyCtxt
<
'a
,
'gcx
,
'gcx
>
,
link_meta
:
&
LinkMeta
,
exported_symbols
:
&
NodeSet
)
->
(
ContextRef
,
ModuleRef
,
EncodedMetadata
)
{
use
flate
;
let
(
metadata_llcx
,
metadata_llmod
)
=
unsafe
{
context
::
create_context_and_module
(
cx
.sess
()
,
"metadata"
)
context
::
create_context_and_module
(
tcx
.sess
,
"metadata"
)
};
#[derive(PartialEq,
Eq,
PartialOrd,
Ord)]
...
...
@@ -742,7 +742,7 @@ enum MetadataKind {
Compressed
}
let
kind
=
cx
.sess
()
.crate_types
.borrow
()
.iter
()
.map
(|
ty
|
{
let
kind
=
tcx
.sess
.crate_types
.borrow
()
.iter
()
.map
(|
ty
|
{
match
*
ty
{
config
::
CrateTypeExecutable
|
config
::
CrateTypeStaticlib
|
...
...
@@ -762,8 +762,8 @@ enum MetadataKind {
});
}
let
cstore
=
&
cx
.tcx
()
.sess.cstore
;
let
metadata
=
cstore
.encode_metadata
(
cx
.tcx
()
,
let
cstore
=
&
tcx
.sess.cstore
;
let
metadata
=
cstore
.encode_metadata
(
tcx
,
&
link_meta
,
exported_symbols
);
if
kind
==
MetadataKind
::
Uncompressed
{
...
...
@@ -776,7 +776,7 @@ enum MetadataKind {
let
llmeta
=
C_bytes_in_context
(
metadata_llcx
,
&
compressed
);
let
llconst
=
C_struct_in_context
(
metadata_llcx
,
&
[
llmeta
],
false
);
let
name
=
symbol_export
::
metadata_symbol_name
(
cx
.tcx
()
);
let
name
=
symbol_export
::
metadata_symbol_name
(
tcx
);
let
buf
=
CString
::
new
(
name
)
.unwrap
();
let
llglobal
=
unsafe
{
llvm
::
LLVMAddGlobal
(
metadata_llmod
,
val_ty
(
llconst
)
.to_ref
(),
buf
.as_ptr
())
...
...
@@ -784,7 +784,7 @@ enum MetadataKind {
unsafe
{
llvm
::
LLVMSetInitializer
(
llglobal
,
llconst
);
let
section_name
=
cx
.tcx
()
.sess.cstore
.metadata_section_name
(
&
cx
.sess
()
.target.target
);
tcx
.sess.cstore
.metadata_section_name
(
&
tcx
.sess
.target.target
);
let
name
=
CString
::
new
(
section_name
)
.unwrap
();
llvm
::
LLVMSetSection
(
llglobal
,
name
.as_ptr
());
...
...
@@ -1078,7 +1078,7 @@ pub fn trans_crate<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
// Translate the metadata.
let
(
metadata_llcx
,
metadata_llmod
,
metadata
)
=
time
(
tcx
.sess
.time_passes
(),
"write metadata"
,
||
{
write_metadata
(
&
shared_c
cx
,
&
link_meta
,
shared_ccx
.exported_symbols
())
write_metadata
(
t
cx
,
&
link_meta
,
shared_ccx
.exported_symbols
())
});
let
metadata_module
=
ModuleTranslation
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录