Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
d730bb73
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,发现更多精彩内容 >>
提交
d730bb73
编写于
6月 28, 2011
作者:
M
Marijn Haverbeke
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Make it possible to use * to dereference a resource
上级
b3443eb0
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
16 addition
and
9 deletion
+16
-9
src/comp/middle/alias.rs
src/comp/middle/alias.rs
+8
-4
src/comp/middle/trans.rs
src/comp/middle/trans.rs
+7
-5
src/comp/middle/typeck.rs
src/comp/middle/typeck.rs
+1
-0
未找到文件。
src/comp/middle/alias.rs
浏览文件 @
d730bb73
...
...
@@ -544,10 +544,14 @@ fn maybe_push_auto_unbox(&option::t[deref] d, &mutable vec[deref] ds) {
auto
base_t
=
ty
::
expr_ty
(
*
cx
.tcx
,
base
);
alt
(
ty
::
struct
(
*
cx
.tcx
,
base_t
))
{
case
(
ty
::
ty_box
(
?
mt
))
{
vec
::
push
(
ds
,
rec
(
mut
=
mt
.mut
!=
ast
::
imm
,
kind
=
unbox
,
outer_t
=
base_t
));
vec
::
push
(
ds
,
rec
(
mut
=
mt
.mut
!=
ast
::
imm
,
kind
=
unbox
,
outer_t
=
base_t
));
}
case
(
ty
::
ty_res
(
_
,
?
inner
))
{
vec
::
push
(
ds
,
rec
(
mut
=
false
,
kind
=
unbox
,
outer_t
=
base_t
));
}
}
ex
=
base
;
...
...
src/comp/middle/trans.rs
浏览文件 @
d730bb73
...
...
@@ -4511,8 +4511,7 @@ fn trans_for_each(&@block_ctxt cx, &@ast::local local, &@ast::expr seq,
cx
.build
.Store
(
llenvblobptr
,
env_cell
);
// log "lliterbody: " + val_str(lcx.ccx.tn, lliterbody);
r
=
trans_call
(
cx
,
f
,
some
[
ValueRef
](
cx
.build
.Load
(
pair
)),
args
,
r
=
trans_call
(
cx
,
f
,
some
[
ValueRef
](
cx
.build
.Load
(
pair
)),
args
,
seq
.id
);
ret
rslt
(
r
.bcx
,
C_nil
());
}
...
...
@@ -4993,9 +4992,12 @@ fn trans_lval(&@block_ctxt cx, &@ast::expr e) -> lval_result {
case
(
ast
::
expr_unary
(
?
unop
,
?
base
))
{
assert
(
unop
==
ast
::
deref
);
auto
sub
=
trans_expr
(
cx
,
base
);
auto
val
=
sub
.bcx.build
.GEP
(
sub
.val
,
[
C_int
(
0
),
C_int
(
abi
::
box_rc_field_body
)]);
auto
t
=
ty
::
expr_ty
(
cx
.fcx.lcx.ccx.tcx
,
base
);
auto
offset
=
alt
(
ty
::
struct
(
cx
.fcx.lcx.ccx.tcx
,
t
))
{
case
(
ty
::
ty_box
(
_
))
{
abi
::
box_rc_field_body
}
case
(
ty
::
ty_res
(
_
,
_
))
{
1
}
};
auto
val
=
sub
.bcx.build
.GEP
(
sub
.val
,
[
C_int
(
0
),
C_int
(
offset
)]);
ret
lval_mem
(
sub
.bcx
,
val
);
}
case
(
ast
::
expr_self_method
(
?
ident
))
{
...
...
src/comp/middle/typeck.rs
浏览文件 @
d730bb73
...
...
@@ -1526,6 +1526,7 @@ fn check_binop_type_compat(&@fn_ctxt fcx, common::span span,
case
(
ast
::
deref
)
{
alt
(
structure_of
(
fcx
,
expr
.span
,
oper_t
))
{
case
(
ty
::
ty_box
(
?
inner
))
{
oper_t
=
inner
.ty
;
}
case
(
ty
::
ty_res
(
_
,
?
inner
))
{
oper_t
=
inner
;
}
case
(
_
)
{
auto
s
=
"dereferencing non-box type: "
+
ty_to_str
(
fcx
.ccx.tcx
,
oper_t
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录