diff options
| author | bors <bors@rust-lang.org> | 2018-06-01 03:24:54 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2018-06-01 03:24:54 +0000 |
| commit | 63cd4a39ead1bdcc6f4df5f11d187916bd8d3ea7 (patch) | |
| tree | c16da5601fbe4b7cef6a46d53d94fecf004afc34 /src/test | |
| parent | b7a9d4ea744c9a99952bc4576727b57c58c0e958 (diff) | |
| parent | 97a0d46dece080714a4fe1ac21f84ad54f6ab76d (diff) | |
| download | rust-63cd4a39ead1bdcc6f4df5f11d187916bd8d3ea7.tar.gz rust-63cd4a39ead1bdcc6f4df5f11d187916bd8d3ea7.zip | |
Auto merge of #51171 - faern:const-bswap-ctpop-cttz-ctlz, r=oli-obk
Make some std::intrinsics `const fn`s Making some rustc intrinsics (`ctpop`, `cttz`, `ctlz` and `bswap`) `const fn`s. This is a pre-step to being able to make `swap_bytes`, `to_be` and `from_be` constant functions. That in itself could be ergonomic and useful. But even better is that it would allow `Ipv4Addr::new` etc becoming `const fn`s as well. Which might be really useful since I find it quite common to want to define them as constants. r? @oli-obk
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/run-pass/ctfe/bswap-const.rs | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/src/test/run-pass/ctfe/bswap-const.rs b/src/test/run-pass/ctfe/bswap-const.rs new file mode 100644 index 00000000000..b951a9b72b1 --- /dev/null +++ b/src/test/run-pass/ctfe/bswap-const.rs @@ -0,0 +1,23 @@ +// Copyright 2017 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +#![feature(core_intrinsics)] + +use std::intrinsics; + +const SWAPPED_U8: u8 = unsafe { intrinsics::bswap(0x12_u8) }; +const SWAPPED_U16: u16 = unsafe { intrinsics::bswap(0x12_34_u16) }; +const SWAPPED_I32: i32 = unsafe { intrinsics::bswap(0x12_34_56_78_i32) }; + +fn main() { + assert_eq!(SWAPPED_U8, 0x12); + assert_eq!(SWAPPED_U16, 0x34_12); + assert_eq!(SWAPPED_I32, 0x78_56_34_12); +} |
