Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
ccf4e8cf
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,发现更多精彩内容 >>
提交
ccf4e8cf
编写于
6月 12, 2012
作者:
M
Michael Sullivan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Make vectors contain the right type descriptor. Closes #2536.
上级
4f61dcb0
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
12 addition
and
17 deletion
+12
-17
src/rustc/middle/trans/tvec.rs
src/rustc/middle/trans/tvec.rs
+8
-16
src/rustc/middle/ty.rs
src/rustc/middle/ty.rs
+4
-1
未找到文件。
src/rustc/middle/trans/tvec.rs
浏览文件 @
ccf4e8cf
...
...
@@ -57,17 +57,14 @@ fn alloc_uniq_raw(bcx: block, unit_ty: ty::t,
fill
:
ValueRef
,
alloc
:
ValueRef
)
->
result
{
let
_
icx
=
bcx
.insn_ctxt
(
"tvec::alloc_uniq_raw"
);
let
ccx
=
bcx
.ccx
();
let
llunitty
=
type_of
::
type_of
(
ccx
,
unit_ty
);
let
llvecty
=
T_vec
(
ccx
,
llunit
ty
);
let
vecsize
=
Add
(
bcx
,
alloc
,
llsize_of
(
ccx
,
llvecty
));
let
vecbodyty
=
unit_ty
;
// FIXME: This is not the correct type (#2536)
let
vecbodyty
=
ty
::
mk_mut_unboxed_vec
(
bcx
.tcx
(),
unit_
ty
);
let
vecsize
=
Add
(
bcx
,
alloc
,
llsize_of
(
ccx
,
ccx
.opaque_vec_type
));
let
{
box
,
body
}
=
base
::
malloc_unique_dyn
(
bcx
,
vecbodyty
,
vecsize
);
let
boxptr
=
PointerCast
(
bcx
,
box
,
T_unique_ptr
(
T_unique
(
bcx
.ccx
(),
llvecty
)));
let
bodyptr
=
PointerCast
(
bcx
,
body
,
T_ptr
(
llvecty
));
Store
(
bcx
,
fill
,
GEPi
(
bcx
,
bodyptr
,
[
0u
,
abi
::
vec_elt_fill
]));
Store
(
bcx
,
alloc
,
GEPi
(
bcx
,
bodyptr
,
[
0u
,
abi
::
vec_elt_alloc
]));
ret
{
bcx
:
bcx
,
val
:
boxptr
};
Store
(
bcx
,
fill
,
GEPi
(
bcx
,
body
,
[
0u
,
abi
::
vec_elt_fill
]));
Store
(
bcx
,
alloc
,
GEPi
(
bcx
,
body
,
[
0u
,
abi
::
vec_elt_alloc
]));
ret
{
bcx
:
bcx
,
val
:
box
};
}
fn
alloc_uniq
(
bcx
:
block
,
unit_ty
:
ty
::
t
,
elts
:
uint
)
->
result
{
...
...
@@ -91,14 +88,9 @@ fn duplicate_uniq(bcx: block, vptr: ValueRef, vec_ty: ty::t) -> result {
let
size
=
Add
(
bcx
,
fill
,
llsize_of
(
ccx
,
ccx
.opaque_vec_type
));
let
unit_ty
=
ty
::
sequence_element_type
(
bcx
.tcx
(),
vec_ty
);
let
llunitty
=
type_of
::
type_of
(
ccx
,
unit_ty
);
let
llvecty
=
T_vec
(
ccx
,
llunitty
);
let
vecbodyty
=
unit_ty
;
// FIXME: This is not the correct type (#2536)
let
vecbodyty
=
ty
::
mk_mut_unboxed_vec
(
bcx
.tcx
(),
unit_ty
);
let
{
box
:
newptr
,
body
:
new_body_ptr
}
=
base
::
malloc_unique_dyn
(
bcx
,
vecbodyty
,
size
);
let
newptr
=
PointerCast
(
bcx
,
newptr
,
T_unique_ptr
(
T_unique
(
bcx
.ccx
(),
llvecty
)));
let
new_body_ptr
=
PointerCast
(
bcx
,
new_body_ptr
,
T_ptr
(
llvecty
));
call_memmove
(
bcx
,
new_body_ptr
,
body_ptr
,
size
);
Store
(
bcx
,
fill
,
GEPi
(
bcx
,
new_body_ptr
,
[
0u
,
abi
::
vec_elt_alloc
]));
...
...
src/rustc/middle/ty.rs
浏览文件 @
ccf4e8cf
...
...
@@ -88,7 +88,7 @@
export
ty_vec
,
mk_vec
,
type_is_vec
;
export
ty_estr
,
mk_estr
;
export
ty_evec
,
mk_evec
;
export
ty_unboxed_vec
,
mk_unboxed_vec
;
export
ty_unboxed_vec
,
mk_unboxed_vec
,
mk_mut_unboxed_vec
;
export
vstore
,
vstore_fixed
,
vstore_uniq
,
vstore_box
,
vstore_slice
;
export
ty_nil
,
mk_nil
,
type_is_nil
;
export
ty_iface
,
mk_iface
;
...
...
@@ -677,6 +677,9 @@ fn mk_evec(cx: ctxt, tm: mt, t: vstore) -> t {
fn
mk_unboxed_vec
(
cx
:
ctxt
,
tm
:
mt
)
->
t
{
mk_t
(
cx
,
ty_unboxed_vec
(
tm
))
}
fn
mk_mut_unboxed_vec
(
cx
:
ctxt
,
ty
:
t
)
->
t
{
mk_t
(
cx
,
ty_unboxed_vec
({
ty
:
ty
,
mutbl
:
ast
::
m_imm
}))
}
fn
mk_rec
(
cx
:
ctxt
,
fs
:
[
field
])
->
t
{
mk_t
(
cx
,
ty_rec
(
fs
))
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录