| #![feature(no_core, unboxed_closures)] |
| #![no_core] |
| #![allow(dead_code)] |
| |
| extern crate mini_core; |
| |
| use mini_core::*; |
| |
| pub fn abc(a: u8) -> u8 { |
| a * 2 |
| } |
| |
| pub fn bcd(b: bool, a: u8) -> u8 { |
| if b { a * 2 } else { a * 3 } |
| } |
| |
| pub fn call() { |
| abc(42); |
| } |
| |
| pub fn indirect_call() { |
| let f: fn() = call; |
| f(); |
| } |
| |
| pub enum BoolOption { |
| Some(bool), |
| None, |
| } |
| |
| pub fn option_unwrap_or(o: BoolOption, d: bool) -> bool { |
| match o { |
| BoolOption::Some(b) => b, |
| BoolOption::None => d, |
| } |
| } |
| |
| pub fn ret_42() -> u8 { |
| 42 |
| } |
| |
| pub fn return_str() -> &'static str { |
| "hello world" |
| } |
| |
| pub fn promoted_val() -> &'static u8 { |
| &(1 * 2) |
| } |
| |
| pub fn cast_ref_to_raw_ptr(abc: &u8) -> *const u8 { |
| abc as *const u8 |
| } |
| |
| pub fn cmp_raw_ptr(a: *const u8, b: *const u8) -> bool { |
| a == b |
| } |
| |
| pub fn int_cast(a: u16, b: i16) -> (u8, u16, u32, usize, i8, i16, i32, isize, u8, u32) { |
| ( |
| a as u8, a as u16, a as u32, a as usize, a as i8, a as i16, a as i32, a as isize, b as u8, |
| b as u32, |
| ) |
| } |
| |
| pub fn char_cast(c: char) -> u8 { |
| c as u8 |
| } |
| |
| pub struct DebugTuple(()); |
| |
| pub fn debug_tuple() -> DebugTuple { |
| DebugTuple(()) |
| } |
| |
| pub fn size_of<T>() -> usize { |
| intrinsics::size_of::<T>() |
| } |
| |
| pub fn use_size_of() -> usize { |
| size_of::<u64>() |
| } |
| |
| pub unsafe fn use_copy_intrinsic(src: *const u8, dst: *mut u8) { |
| intrinsics::copy::<u8>(src, dst, 1); |
| } |
| |
| pub unsafe fn use_copy_intrinsic_ref(src: *const u8, dst: *mut u8) { |
| let copy2 = &intrinsics::copy::<u8>; |
| copy2(src, dst, 1); |
| } |
| |
| pub const ABC: u8 = 6 * 7; |
| |
| pub fn use_const() -> u8 { |
| ABC |
| } |
| |
| pub fn call_closure_3arg() { |
| (|_, _, _| {})(0u8, 42u16, 0u8) |
| } |
| |
| pub fn call_closure_2arg() { |
| (|_, _| {})(0u8, 42u16) |
| } |
| |
| pub struct IsNotEmpty; |
| |
| impl<'a, 'b> FnOnce<(&'a &'b [u16],)> for IsNotEmpty { |
| type Output = (u8, u8); |
| |
| #[inline] |
| extern "rust-call" fn call_once(mut self, arg: (&'a &'b [u16],)) -> (u8, u8) { |
| self.call_mut(arg) |
| } |
| } |
| |
| impl<'a, 'b> FnMut<(&'a &'b [u16],)> for IsNotEmpty { |
| #[inline] |
| extern "rust-call" fn call_mut(&mut self, _arg: (&'a &'b [u16],)) -> (u8, u8) { |
| (0, 42) |
| } |
| } |
| |
| pub fn call_is_not_empty() { |
| IsNotEmpty.call_once((&(&[0u16] as &[_]),)); |
| } |
| |
| pub fn eq_char(a: char, b: char) -> bool { |
| a == b |
| } |
| |
| pub unsafe fn transmute(c: char) -> u32 { |
| intrinsics::transmute(c) |
| } |
| |
| pub unsafe fn deref_str_ptr(s: *const str) -> &'static str { |
| &*s |
| } |
| |
| pub fn use_array(arr: [u8; 3]) -> u8 { |
| arr[1] |
| } |
| |
| pub fn repeat_array() -> [u8; 3] { |
| [0; 3] |
| } |
| |
| pub fn array_as_slice(arr: &[u8; 3]) -> &[u8] { |
| arr |
| } |
| |
| pub unsafe fn use_ctlz_nonzero(a: u16) -> u16 { |
| intrinsics::ctlz_nonzero(a) |
| } |
| |
| pub fn ptr_as_usize(ptr: *const u8) -> usize { |
| ptr as usize |
| } |
| |
| pub fn float_cast(a: f32, b: f64) -> (f64, f32) { |
| (a as f64, b as f32) |
| } |
| |
| pub fn int_to_float(a: u8, b: i32) -> (f64, f32) { |
| (a as f64, b as f32) |
| } |
| |
| pub fn make_array() -> [u8; 3] { |
| [42, 0, 5] |
| } |
| |
| pub fn some_promoted_tuple() -> &'static (&'static str, &'static str) { |
| &("abc", "some") |
| } |
| |
| pub fn index_slice(s: &[u8]) -> u8 { |
| s[2] |
| } |
| |
| pub struct StrWrapper { |
| s: str, |
| } |
| |
| pub fn str_wrapper_get(w: &StrWrapper) -> &str { |
| &w.s |
| } |
| |
| pub fn i16_as_i8(a: i16) -> i8 { |
| a as i8 |
| } |
| |
| pub struct Unsized(u8, str); |
| |
| pub fn get_sized_field_ref_from_unsized_type(u: &Unsized) -> &u8 { |
| &u.0 |
| } |
| |
| pub fn get_unsized_field_ref_from_unsized_type(u: &Unsized) -> &str { |
| &u.1 |
| } |
| |
| pub fn reuse_byref_argument_storage(a: (u8, u16, u32)) -> u8 { |
| a.0 |
| } |