mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-10-31 04:57:19 +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`.
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| //@ compile-flags: -g -Zmir-opt-level=0 -Zmir-enable-passes=+ScalarReplacementOfAggregates
 | |
| //@ compile-flags: -Cno-prepopulate-passes
 | |
| //
 | |
| // Tested offsets are only correct for x86_64.
 | |
| //@ only-x86_64
 | |
| 
 | |
| #![crate_type = "lib"]
 | |
| 
 | |
| pub struct ExtraSlice<'input> {
 | |
|     slice: &'input [u8],
 | |
|     extra: u32,
 | |
| }
 | |
| 
 | |
| #[no_mangle]
 | |
| pub fn extra(s: &[u8]) {
 | |
|     // CHECK: void @extra(
 | |
|     // CHECK: %slice.dbg.spill1 = alloca [4 x i8],
 | |
|     // CHECK: %slice.dbg.spill = alloca [16 x i8],
 | |
|     // CHECK: %s.dbg.spill = alloca [16 x i8],
 | |
|     // CHECK: dbg{{.}}declare({{(metadata )?}}ptr %s.dbg.spill, {{(metadata )?}}![[S_EXTRA:.*]], {{(metadata )?}}!DIExpression()
 | |
|     // CHECK: dbg{{.}}declare({{(metadata )?}}ptr %slice.dbg.spill, {{(metadata )?}}![[SLICE_EXTRA:.*]], {{(metadata )?}}!DIExpression(DW_OP_LLVM_fragment, 0, 128)
 | |
|     // CHECK: dbg{{.}}declare({{(metadata )?}}ptr %slice.dbg.spill1, {{(metadata )?}}![[SLICE_EXTRA]], {{(metadata )?}}!DIExpression(DW_OP_LLVM_fragment, 128, 32)
 | |
|     let slice = ExtraSlice { slice: s, extra: s.len() as u32 };
 | |
| }
 | |
| 
 | |
| struct Zst;
 | |
| 
 | |
| pub struct ZstSlice<'input> {
 | |
|     slice: &'input [u8],
 | |
|     extra: Zst,
 | |
| }
 | |
| 
 | |
| #[no_mangle]
 | |
| pub fn zst(s: &[u8]) {
 | |
|     // The field `extra` is a ZST. The fragment for the field `slice` encompasses the whole
 | |
|     // variable, so is not a fragment. In that case, the variable must have no fragment.
 | |
| 
 | |
|     // CHECK: void @zst(
 | |
|     // CHECK-NOT: dbg{{.}}declare({{(metadata )?}}ptr %slice.dbg.spill, {{(metadata )?}}!{}, {{(metadata )?}}!DIExpression(DW_OP_LLVM_fragment,
 | |
|     // CHECK: dbg{{.}}declare({{(metadata )?}}ptr %{{.*}}, {{(metadata )?}}![[SLICE_ZST:.*]], {{(metadata )?}}!DIExpression()
 | |
|     // CHECK-NOT: dbg{{.}}declare({{(metadata )?}}ptr %{{.*}}, {{(metadata )?}}![[SLICE_ZST]],
 | |
|     let slice = ZstSlice { slice: s, extra: Zst };
 | |
| }
 | |
| 
 | |
| // CHECK: ![[S_EXTRA]] = !DILocalVariable(name: "s",
 | |
| // CHECK: ![[SLICE_EXTRA]] = !DILocalVariable(name: "slice",
 |