mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 06:44:35 +00:00
122 lines
2.9 KiB
Rust
122 lines
2.9 KiB
Rust
//@ min-lldb-version: 1800
|
|
//@ min-gdb-version: 13.0
|
|
//@ compile-flags:-g
|
|
//@ ignore-windows-gnu: #128973
|
|
|
|
// === 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
|
|
|
|
#![feature(omit_gdb_pretty_printer_section)]
|
|
#![omit_gdb_pretty_printer_section]
|
|
|
|
#[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() { () }
|