diff options
| author | bors <bors@rust-lang.org> | 2023-01-11 11:17:22 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2023-01-11 11:17:22 +0000 |
| commit | b22c152958eade17a71d899b29a2d39bcc77aa48 (patch) | |
| tree | ec6da75dc598a0a4086c0cc032c86d7241be1bc1 /tests/debuginfo/borrowed-struct.rs | |
| parent | 8ecaad85f61375b18e1667b51a3ef350121d2ca0 (diff) | |
| parent | 40ba0e84d53f605ccf01836e9c2d27892728ae81 (diff) | |
| download | rust-b22c152958eade17a71d899b29a2d39bcc77aa48.tar.gz rust-b22c152958eade17a71d899b29a2d39bcc77aa48.zip | |
Auto merge of #106458 - albertlarsan68:move-tests, r=jyn514
Move src/test to the root
See MCP at rust-lang/compiler-team#573
There may be more changes needed.
The first commit is just the move of the files:
You can check that the first commit did not do anything else than renames by running
```
git diff --diff-filter=r -M100% <rust-lang remote>/master <first commit hash>
```
The output should be empty, because the filter excludes renames, and the match threshold for qualifying a rename is 100%.
The second one is mostly a "find and replace" of `src/test` to `tests` and whatever is needed to make CI pass.
What is left to do:
---
- [x] Move directory
- [ ] Change references to `src/test`
- [x] Change references in-tree
- [ ] Change references in submodules / out-of-tree docs
- [x] Make CI pass:
- [x] Fix tidy
- [x] Fix tests
- [x] Bless tests if needed (shouldn't normally)
- [ ] Merge it !
Diffstat (limited to 'tests/debuginfo/borrowed-struct.rs')
| -rw-r--r-- | tests/debuginfo/borrowed-struct.rs | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/tests/debuginfo/borrowed-struct.rs b/tests/debuginfo/borrowed-struct.rs new file mode 100644 index 00000000000..fe945266b13 --- /dev/null +++ b/tests/debuginfo/borrowed-struct.rs @@ -0,0 +1,89 @@ +// compile-flags:-g +// min-lldb-version: 310 + +// === GDB TESTS =================================================================================== + +// gdb-command:run + +// gdb-command:print *stack_val_ref +// gdbg-check:$1 = {x = 10, y = 23.5} +// gdbr-check:$1 = borrowed_struct::SomeStruct {x: 10, y: 23.5} + +// gdb-command:print *stack_val_interior_ref_1 +// gdb-check:$2 = 10 + +// gdb-command:print *stack_val_interior_ref_2 +// gdb-check:$3 = 23.5 + +// gdb-command:print *ref_to_unnamed +// gdbg-check:$4 = {x = 11, y = 24.5} +// gdbr-check:$4 = borrowed_struct::SomeStruct {x: 11, y: 24.5} + +// gdb-command:print *unique_val_ref +// gdbg-check:$5 = {x = 13, y = 26.5} +// gdbr-check:$5 = borrowed_struct::SomeStruct {x: 13, y: 26.5} + +// gdb-command:print *unique_val_interior_ref_1 +// gdb-check:$6 = 13 + +// gdb-command:print *unique_val_interior_ref_2 +// gdb-check:$7 = 26.5 + + +// === LLDB TESTS ================================================================================== + +// lldb-command:run + +// lldb-command:print *stack_val_ref +// lldbg-check:[...]$0 = { x = 10 y = 23.5 } +// lldbr-check:(borrowed_struct::SomeStruct) *stack_val_ref = (x = 10, y = 23.5) + +// lldb-command:print *stack_val_interior_ref_1 +// lldbg-check:[...]$1 = 10 +// lldbr-check:(isize) *stack_val_interior_ref_1 = 10 + +// lldb-command:print *stack_val_interior_ref_2 +// lldbg-check:[...]$2 = 23.5 +// lldbr-check:(f64) *stack_val_interior_ref_2 = 23.5 + +// lldb-command:print *ref_to_unnamed +// lldbg-check:[...]$3 = { x = 11 y = 24.5 } +// lldbr-check:(borrowed_struct::SomeStruct) *ref_to_unnamed = (x = 11, y = 24.5) + +// lldb-command:print *unique_val_ref +// lldbg-check:[...]$4 = { x = 13 y = 26.5 } +// lldbr-check:(borrowed_struct::SomeStruct) *unique_val_ref = (x = 13, y = 26.5) + +// lldb-command:print *unique_val_interior_ref_1 +// lldbg-check:[...]$5 = 13 +// lldbr-check:(isize) *unique_val_interior_ref_1 = 13 + +// lldb-command:print *unique_val_interior_ref_2 +// lldbg-check:[...]$6 = 26.5 +// lldbr-check:(f64) *unique_val_interior_ref_2 = 26.5 + +#![allow(unused_variables)] +#![feature(omit_gdb_pretty_printer_section)] +#![omit_gdb_pretty_printer_section] + +struct SomeStruct { + x: isize, + y: f64 +} + +fn main() { + let stack_val: SomeStruct = SomeStruct { x: 10, y: 23.5 }; + let stack_val_ref: &SomeStruct = &stack_val; + let stack_val_interior_ref_1: &isize = &stack_val.x; + let stack_val_interior_ref_2: &f64 = &stack_val.y; + let ref_to_unnamed: &SomeStruct = &SomeStruct { x: 11, y: 24.5 }; + + let unique_val: Box<_> = Box::new(SomeStruct { x: 13, y: 26.5 }); + let unique_val_ref: &SomeStruct = &*unique_val; + let unique_val_interior_ref_1: &isize = &unique_val.x; + let unique_val_interior_ref_2: &f64 = &unique_val.y; + + zzz(); // #break +} + +fn zzz() {()} |
