mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-10-25 14:41:47 +00:00 
			
		
		
		
	 72800d3b89
			
		
	
	
		72800d3b89
		
	
	
	
	
		
			
			Except for `simd-intrinsic/`, which has a lot of files containing multiple types like `u8x64` which really are better when hand-formatted. There is a surprising amount of two-space indenting in this directory. Non-trivial changes: - `rustfmt::skip` needed in `debug-column.rs` to preserve meaning of the test. - `rustfmt::skip` used in a few places where hand-formatting read more nicely: `enum/enum-match.rs` - Line number adjustments needed for the expected output of `debug-column.rs` and `coroutine-debug.rs`.
		
			
				
	
	
		
			75 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| //@ compile-flags: -O -Zmerge-functions=disabled
 | |
| //@ min-llvm-version: 18
 | |
| #![crate_type = "lib"]
 | |
| 
 | |
| extern crate core;
 | |
| use core::cmp::Ordering;
 | |
| use core::num::NonZero;
 | |
| use core::ptr::NonNull;
 | |
| 
 | |
| // CHECK-LABEL: @non_zero_eq
 | |
| #[no_mangle]
 | |
| pub fn non_zero_eq(l: Option<NonZero<u32>>, r: Option<NonZero<u32>>) -> bool {
 | |
|     // CHECK: start:
 | |
|     // CHECK-NEXT: icmp eq i32
 | |
|     // CHECK-NEXT: ret i1
 | |
|     l == r
 | |
| }
 | |
| 
 | |
| // CHECK-LABEL: @non_zero_signed_eq
 | |
| #[no_mangle]
 | |
| pub fn non_zero_signed_eq(l: Option<NonZero<i64>>, r: Option<NonZero<i64>>) -> bool {
 | |
|     // CHECK: start:
 | |
|     // CHECK-NEXT: icmp eq i64
 | |
|     // CHECK-NEXT: ret i1
 | |
|     l == r
 | |
| }
 | |
| 
 | |
| // CHECK-LABEL: @non_null_eq
 | |
| #[no_mangle]
 | |
| pub fn non_null_eq(l: Option<NonNull<u8>>, r: Option<NonNull<u8>>) -> bool {
 | |
|     // CHECK: start:
 | |
|     // CHECK-NEXT: icmp eq ptr
 | |
|     // CHECK-NEXT: ret i1
 | |
|     l == r
 | |
| }
 | |
| 
 | |
| // CHECK-LABEL: @ordering_eq
 | |
| #[no_mangle]
 | |
| pub fn ordering_eq(l: Option<Ordering>, r: Option<Ordering>) -> bool {
 | |
|     // CHECK: start:
 | |
|     // CHECK-NEXT: icmp eq i8
 | |
|     // CHECK-NEXT: ret i1
 | |
|     l == r
 | |
| }
 | |
| 
 | |
| #[derive(PartialEq)]
 | |
| pub enum EnumWithNiche {
 | |
|     A,
 | |
|     B,
 | |
|     C,
 | |
|     D,
 | |
|     E,
 | |
|     F,
 | |
|     G,
 | |
| }
 | |
| 
 | |
| // CHECK-LABEL: @niche_eq
 | |
| #[no_mangle]
 | |
| pub fn niche_eq(l: Option<EnumWithNiche>, r: Option<EnumWithNiche>) -> bool {
 | |
|     // CHECK: start:
 | |
|     // CHECK-NEXT: icmp eq i8
 | |
|     // CHECK-NEXT: ret i1
 | |
|     l == r
 | |
| }
 | |
| 
 | |
| // FIXME: This should work too
 | |
| // // FIXME-CHECK-LABEL: @bool_eq
 | |
| // #[no_mangle]
 | |
| // pub fn bool_eq(l: Option<bool>, r: Option<bool>) -> bool {
 | |
| //     // FIXME-CHECK: start:
 | |
| //     // FIXME-CHECK-NEXT: icmp eq i8
 | |
| //     // FIXME-CHECK-NEXT: ret i1
 | |
| //     l == r
 | |
| // }
 |