Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
ed7e4e1e
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,发现更多精彩内容 >>
提交
ed7e4e1e
编写于
1月 27, 2018
作者:
R
Ryan Cumming
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Expand union test to include different types
上级
75c79bdb
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
26 addition
and
7 deletion
+26
-7
src/test/run-pass/union/union-const-eval-field.rs
src/test/run-pass/union/union-const-eval-field.rs
+26
-7
未找到文件。
src/test/run-pass/union/union-const-eval-field.rs
浏览文件 @
ed7e4e1e
...
...
@@ -10,17 +10,36 @@
#![feature(const_fn)]
type
Field1
=
i32
;
type
Field2
=
f32
;
type
Field3
=
i64
;
union
DummyUnion
{
field1
:
i32
,
field2
:
i32
,
field1
:
Field1
,
field2
:
Field2
,
field3
:
Field3
,
}
const
FLOAT1_AS_I32
:
i32
=
1065353216
;
const
UNION
:
DummyUnion
=
DummyUnion
{
field1
:
FLOAT1_AS_I32
};
const
fn
read_field1
()
->
Field1
{
const
FIELD1
:
Field1
=
unsafe
{
UNION
.field1
};
FIELD1
}
const
fn
read_field2
()
->
Field2
{
const
FIELD2
:
Field2
=
unsafe
{
UNION
.field2
};
FIELD2
}
const
fn
read_field
()
->
i32
{
const
UNION
:
DummyUnion
=
DummyUnion
{
field1
:
5
};
const
FIELD
:
i32
=
unsafe
{
UNION
.field2
};
FIELD
const
fn
read_field3
()
->
Field3
{
const
FIELD3
:
Field3
=
unsafe
{
UNION
.field3
};
FIELD3
}
fn
main
()
{
assert_eq!
(
read_field
(),
5
);
assert_eq!
(
read_field1
(),
FLOAT1_AS_I32
);
assert_eq!
(
read_field2
(),
1.0
);
assert_eq!
(
read_field3
(),
unsafe
{
UNION
.field3
});
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录