mirror of
https://github.com/rust-lang/rust.git
synced 2025-09-27 12:48:20 +00:00

Disabling loading of pretty printers in the debugger itself is more reliable. Before this commit the .gdb_debug_scripts section couldn't be included in dylibs or rlibs as otherwise there is no way to disable the section anymore without recompiling the entire standard library.
122 lines
3.0 KiB
Rust
122 lines
3.0 KiB
Rust
//@ min-lldb-version: 1800
|
|
//@ min-gdb-version: 13.0
|
|
//@ compile-flags:-g
|
|
//@ disable-gdb-pretty-printers
|
|
//@ ignore-windows-gnu: #128973
|
|
//@ ignore-aarch64-unknown-linux-gnu (gdb tries to read from 0x0; FIXME: #128973)
|
|
//@ ignore-powerpc64: #128973 on both -gnu and -musl
|
|
|
|
// === GDB TESTS ===================================================================================
|
|
|
|
// gdb-command:run
|
|
|
|
// gdb-command:print s
|
|
// gdb-check:$1 = by_value_non_immediate_argument::Struct {a: 1, b: 2.5}
|
|
// gdb-command:continue
|
|
|
|
// gdb-command:print x
|
|
// gdb-check:$2 = by_value_non_immediate_argument::Struct {a: 3, b: 4.5}
|
|
// gdb-command:print y
|
|
// gdb-check:$3 = 5
|
|
// gdb-command:print z
|
|
// gdb-check:$4 = 6.5
|
|
// gdb-command:continue
|
|
|
|
// gdb-command:print a
|
|
// gdb-check:$5 = (7, 8, 9.5, 10.5)
|
|
// gdb-command:continue
|
|
|
|
// gdb-command:print a
|
|
// gdb-check:$6 = by_value_non_immediate_argument::Newtype (11.5, 12.5, 13, 14)
|
|
// gdb-command:continue
|
|
|
|
// gdb-command:print x
|
|
// gdb-check:$7 = by_value_non_immediate_argument::Enum::Case1{x: 0, y: 8970181431921507452}
|
|
// gdb-command:continue
|
|
|
|
|
|
// === LLDB TESTS ==================================================================================
|
|
|
|
// lldb-command:run
|
|
|
|
// lldb-command:v s
|
|
// lldb-check:[...] Struct { a = 1 b = 2.5 }
|
|
// lldb-command:continue
|
|
|
|
// lldb-command:v x
|
|
// lldb-check:[...] Struct { a = 3 b = 4.5 }
|
|
// lldb-command:v y
|
|
// lldb-check:[...] 5
|
|
// lldb-command:v z
|
|
// lldb-check:[...] 6.5
|
|
// lldb-command:continue
|
|
|
|
// lldb-command:v a
|
|
// lldb-check:[...] (7, 8, 9.5, 10.5)
|
|
// lldb-command:continue
|
|
|
|
// lldb-command:v a
|
|
// lldb-check:[...] Newtype(11.5, 12.5, 13, 14)
|
|
// lldb-command:continue
|
|
|
|
// lldb-command:v x
|
|
// lldb-check:[...] Case1 { x: 0, y: 8970181431921507452 }
|
|
// lldb-command:continue
|
|
|
|
#[derive(Clone)]
|
|
struct Struct {
|
|
a: isize,
|
|
b: f64
|
|
}
|
|
|
|
#[derive(Clone)]
|
|
struct StructStruct {
|
|
a: Struct,
|
|
b: Struct
|
|
}
|
|
|
|
fn fun(s: Struct) {
|
|
zzz(); // #break
|
|
}
|
|
|
|
fn fun_fun(StructStruct { a: x, b: Struct { a: y, b: z } }: StructStruct) {
|
|
zzz(); // #break
|
|
}
|
|
|
|
fn tup(a: (isize, usize, f64, f64)) {
|
|
zzz(); // #break
|
|
}
|
|
|
|
struct Newtype(f64, f64, isize, usize);
|
|
|
|
fn new_type(a: Newtype) {
|
|
zzz(); // #break
|
|
}
|
|
|
|
// The first element is to ensure proper alignment, irrespective of the machines word size. Since
|
|
// the size of the discriminant value is machine dependent, this has be taken into account when
|
|
// datatype layout should be predictable as in this case.
|
|
enum Enum {
|
|
Case1 { x: i64, y: i64 },
|
|
Case2 (i64, i32, i32),
|
|
}
|
|
|
|
fn by_val_enum(x: Enum) {
|
|
zzz(); // #break
|
|
}
|
|
|
|
fn main() {
|
|
fun(Struct { a: 1, b: 2.5 });
|
|
fun_fun(StructStruct { a: Struct { a: 3, b: 4.5 }, b: Struct { a: 5, b: 6.5 } });
|
|
tup((7, 8, 9.5, 10.5));
|
|
new_type(Newtype(11.5, 12.5, 13, 14));
|
|
|
|
// 0b0111110001111100011111000111110001111100011111000111110001111100 = 8970181431921507452
|
|
// 0b01111100011111000111110001111100 = 2088533116
|
|
// 0b0111110001111100 = 31868
|
|
// 0b01111100 = 124
|
|
by_val_enum(Enum::Case1 { x: 0, y: 8970181431921507452 });
|
|
}
|
|
|
|
fn zzz() { () }
|